[
  {
    "path": ".bowerrc",
    "content": "{\n  \"directory\": \"source/lib\"\n}\n"
  },
  {
    "path": ".editorconfig",
    "content": "# editorconfig.org\n\nroot = true\n\n[*]\ncharset = utf-8\nend_of_line = lf\ninsert_final_newline = true\ntrim_trailing_whitespace = true\nindent_style = space\nindent_size = 2\n\n[*.py]\nindent_size = 4\n"
  },
  {
    "path": ".gitattributes",
    "content": "source/lib/* linguist-vendored\nscripts/merge.js linguist-vendored\n"
  },
  {
    "path": ".github/CONTRIBUTING.md",
    "content": "Before submitting an issue, please search for the issue [here](https://github.com/iissnan/hexo-theme-next/issues?utf8=%E2%9C%93&q=) to find if the issue is already reported.\n\nAlso, you can search for answers on the [NexT Documentation Site](http://theme-next.iissnan.com/):\n\n- [常见问题 - 中文文档](http://theme-next.iissnan.com/faqs.html)\n- FAQs (Work in progress)\n"
  },
  {
    "path": ".github/ISSUE_TEMPLATE.md",
    "content": "THIS REPO IS NOT SUPPORTED ANYMORE!\nDON'T NEED CREATE ISSUE HERE!\nNEXT MOVED HERE: https://github.com/theme-next/hexo-theme-next\n\nNexT is rebased into organization repo https://github.com/theme-next\nIf you want new feature, fix, or support, create new issue in NexT v6.x repo (desirable in English).\n\nThere is instructions\non English: https://github.com/theme-next/hexo-theme-next/blob/master/docs/UPDATE-FROM-5.1.X.md\nor Chinese: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/UPDATE-FROM-5.1.X.md\nhow to update from v5.1.x to v 6.x\n\nYou also may read this for details: https://github.com/iissnan/hexo-theme-next/issues/2061\n\n***\n\n该工程已不再提供任何支持与维护！\n请大家不要再在这里创建issue了！\nNexT主题仓库已移动到此处: https://github.com/theme-next/hexo-theme-next\n\nNexT已经rebase到theme-next组织(https://github.com/theme-next) 的repo中.\n如果你想要求新的特性，bug修复或其他支持，请在新的v6.x的仓库下创建新issue（最好用英文，谢谢）\n\n\n英文文档: (https://github.com/theme-next/hexo-theme-next/blob/master/docs/UPDATE-FROM-5.1.X.md)\n或中文文档: (https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/UPDATE-FROM-5.1.X.md)\n如何从 v5.1.x 更新到 v 6.x\n\n相关细节参考这里: https://github.com/iissnan/hexo-theme-next/issues/2061\n"
  },
  {
    "path": ".github/PULL_REQUEST_TEMPLATE.md",
    "content": "<!-- ATTENTION!\n\n1. Please, write pulls readme in English. Not all contributors/collaborators know Chinese language and Google translate can't always give true translates on issues. Thanks!\n\n2. If your pull is short and simple, recommended to use \"Usual pull template\".\n   If your pull is big and include many separated changes, recommended to use \"BIG pull template\".\n\n3. Always remember what NexT include 4 schemes. And if on one of them all worked fine after changes, on another scheme this changes can be broken. Muse and Mist have similar structure, but Pisces is very difference from them. Gemini is a mirror of Pisces with some styles and layouts remakes. So, please, make the tests at least on two schemes (Muse or Mist and Pisces or Gemini).\n-->\n\n<!-- Usual pull template -->\n\n## PR Checklist\n**Please check if your PR fulfills the following requirements:**\n\n- [ ] The commit message follows [our guidelines](https://github.com/iissnan/hexo-theme-next/blob/master/.github/CONTRIBUTING.md).\n- [ ] Tests for the changes have been added (for bug fixes / features).\n   - [ ] Muse | Mist have been tested.\n   - [ ] Pisces | Gemini have been tested.\n- [ ] Docs have been added / updated (for bug fixes / features).\n\n## PR Type\n**What kind of change does this PR introduce?**  <!-- (Check one with \"x\") -->\n\n- [ ] Bugfix.\n- [ ] Feature.\n- [ ] Code style update (formatting, local variables).\n- [ ] Refactoring (no functional changes, no api changes).\n- [ ] Build related changes.\n- [ ] CI related changes.\n- [ ] Documentation content changes.\n- [ ] Other... Please describe:\n\n## What is the current behavior?\n<!-- Please describe the current behavior that you are modifying, or link to a relevant issue. -->\n\nIssue Number(s): N/A\n\n## What is the new behavior?\nDescription about this pull, in several words...\n\n* Screens with this changes: N/A\n* Link to demo site with this changes: N/A\n\n### How to use?\nIn NexT `_config.yml`:\n```yml\n...\n```\n\n## Does this PR introduce a breaking change?\n- [ ] Yes.\n- [ ] No.\n\n<!-- If this PR contains a breaking change, please describe the impact and migration path for existing applications below. -->\n\n<!-- BIG pull template -->\n<!-- \n1. xxxxxxx - commit link on modified file. Just copy this below your pull request readme.\n2. You can paste any image directly from your clipboard. Just press **Print Scr** and paste it into pull readme - link on image will generate and paste automaticly.\n-->\n<!--\n## PART X. Title of fixes and/or enhancements.\nShort description in several words here.\n\nIssue Number(s): #xxxx.\n\n### Files modified:\n1.\tShort description of modified file [1].\t\t\txxxxxxx\n2.\tShort description of modified file [2].\t\t\txxxxxxx\n3.\tShort description of modified file [3].\t\t\txxxxxxx\n\n### Global code changes:\n* ADD: `newFunction` in `utils.js`.\n* DEL: `oldFunction` from `utils.js`\n\n### How it looks?\n![image](https://user-images.githubusercontent.com/xxxxxxxx/xxxxxxxx-xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxx.png)\n\nLive demo [here](http://site.com/).\n\n### How to use?\nIn Next `_config.yml`:\n```yml\n...\n```\n-->\n"
  },
  {
    "path": ".gitignore",
    "content": ".DS_Store\n.idea/\n*.log\n*.iml\nyarn.lock\npackage-lock.json\nnode_modules/\n\n# Ignore unused verdors' files\nsource/lib/fancybox/*\n!source/lib/fancybox/source/\n\nsource/lib/font-awesome/less/\nsource/lib/font-awesome/scss/\n\nsource/lib/ua-parser-js/*\n!source/lib/ua-parser-js/dist/\n\nsource/lib/Han/*\n!source/lib/Han/dist/\n"
  },
  {
    "path": ".hound.yml",
    "content": "javascript:\n  enabled: true\n  config_file: .jshintrc\n  ignore_file: .javascript_ignore\n"
  },
  {
    "path": ".javascript_ignore",
    "content": "source/vendors/*\nsource/lib/*\nsource/js/src/affix.js\nsource/js/src/scrollspy.js\nsource/js/src/js.cookie.js\n"
  },
  {
    "path": ".jshintrc",
    "content": "{\n  \"asi\": false,\n  \"bitwise\": true,\n  \"browser\": true,\n  \"camelcase\": true,\n  \"curly\": true,\n  \"forin\": true,\n  \"immed\": true,\n  \"latedef\": \"nofunc\",\n  \"maxlen\": 120,\n  \"newcap\": true,\n  \"noarg\": true,\n  \"noempty\": true,\n  \"nonew\": true,\n  \"predef\": [\n    \"$\",\n    \"jQuery\",\n    \"NexT\",\n    \"CONFIG\"\n  ],\n  \"quotmark\": true,\n  \"trailing\": true,\n  \"undef\": true,\n  \"unused\": true,\n\n  \"expr\": true\n}\n"
  },
  {
    "path": ".stylintrc",
    "content": "{\n  \"blocks\": false,\n  \"brackets\": \"always\",\n  \"colons\": \"always\",\n  \"colors\": \"always\",\n  \"commaSpace\": \"always\",\n  \"commentSpace\": \"always\",\n  \"cssLiteral\": \"never\",\n  \"customProperties\": [],\n  \"depthLimit\": false,\n  \"duplicates\": true,\n  \"efficient\": \"always\",\n  \"exclude\": [],\n  \"extendPref\": false,\n  \"globalDupe\": false,\n  \"groupOutputByFile\": true,\n  \"indentPref\": false,\n  \"leadingZero\": \"never\",\n  \"maxErrors\": false,\n  \"maxWarnings\": false,\n  \"mixed\": false,\n  \"mixins\": [],\n  \"namingConvention\": \"lowercase-dash\",\n  \"namingConventionStrict\": false,\n  \"none\": \"never\",\n  \"noImportant\": true,\n  \"parenSpace\": false,\n  \"placeholders\": \"always\",\n  \"prefixVarsWithDollar\": \"always\",\n  \"quotePref\": false,\n  \"reporterOptions\": {\n    \"columns\": [\"lineData\", \"severity\", \"description\", \"rule\"],\n    \"columnSplitter\": \"  \",\n    \"showHeaders\": false,\n    \"truncate\": true\n  },\n  \"semicolons\": \"always\",\n  \"sortOrder\": \"grouped\",\n  \"stackedProperties\": false,\n  \"trailingWhitespace\": \"never\",\n  \"universal\": false,\n  \"valid\": true,\n  \"zeroUnits\": \"never\",\n  \"zIndexNormalize\": false\n}\n"
  },
  {
    "path": ".travis.yml",
    "content": "language: node_js\nnode_js: node\n\ncache:\n  directories:\n    - node_modules\n\ninstall: npm install\n\nbefore_script:\n  - npm install -g gulp\n\naddons:\n  browserstack:\n    username: \"ivannginx1\"\n    access_key:\n      secure: \"NutOhdgtUdBUXMPZhy8X1F1Jq+tan1LeNOV0FArBt15SNlxtNArqhiyTi4XnG9MPruX4306aGF2RBrKso+OiGNRdGtRGngH613Q0GWNtlC/boMqnI7fHqLIyCs6S12y2uA8PK4Ifxg9bZ0VtCTYYbMy+p1KvBM//L12vmtfdnby8z5Qvex3tB3dLoPOR50CKkINHJVDLm+iVRFrdz4/83oDsulZSRRGIaxu5taDWPIcp3fYZtre2Nc+RXcsyFDyjN7U0Hvr5tKBbloJxXEQEBv2xLkMOtp85nmCPD06s1Il8Wus1ux3raVsfUyaW5FpNX37Jeb5e00RQUM1wgU5m75H6qiGwDvQswbugJG0i/a2nNfsgVmbrSZdMnkHcx2Uxmrw4ejyEP5NSrJSBi05Ck1fQ4UsZ4Qkdf1fd04SI0LpLWt43eoNO/7rHKsQoP4LCX9gxKUuC075NEBLODyJ529RYfA6dKKwwH6o0ZbOgASmCoAWaM65g4+FHRnJcKL/Kj9ZWklQtRa7/ynlHaA65jefFS2lB8Ut6d3rXDDBih9mIrwV1uUaEH96xgAN42bgU/vY6FGzNkDOYZqj4YfsepDM0wbOsslFie7JZq7iFjsYvrXqLvYUMk37AZwQ2Sb6uH4tIT4Qw/4oZfDzA1En3/8HdZJ28nKW/lzjwMSqheIY=\"\n"
  },
  {
    "path": "LICENSE",
    "content": "MIT License\n\nCopyright (c) 2014-2017 iissnan\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n"
  },
  {
    "path": "README.cn.md",
    "content": "<h1 align=\"center\">本项目已停止维护。:warning:</h1>\n<h2 align=\"center\">社区维护的版本请移步这里：<a href=\"https://github.com/theme-next/hexo-theme-next\">NexT v6 and v7 :triangular_flag_on_post:</a></h2>\n\n<h1 align=\"center\">NexT</h1>\n\n<p align=\"center\">NexT 是一个高质量并且优雅的<a href=\"http://hexo.io\">Hexo</a> 主题。这是精心制作做出来的 hexo 主题。</p>\n\n[![Join the chat at https://gitter.im/iissnan/hexo-theme-next](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/iissnan/hexo-theme-next?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)\n[![mnt-image]][commits-url]\n[![travis-image]][travis-url]\n[![rel-image]][releases-url]\n[![hexo-image]][hexo-url]\n[![lic-image]](LICENSE)\n\n* <a href=\"http://theme-next.iissnan.com\" target=\"_blank\">NexT 使用文档</a> |  [English Documentation](README.md)\n\n## 实时预览 Live Preview\n\n\n* :heart_decoration: Muse 方案: [LEAFERx](https://leaferx.online) | [XiaMo](https://notes.wanghao.work) | [OAwan](https://oawan.me)\n* :six_pointed_star: Mist 方案: [Jeff](https://blog.zzbd.org) | [uchuhimo](http://uchuhimo.me) | [xirong](http://www.ixirong.com)\n* :pisces: Pisces 方案: [Vi](http://notes.iissnan.com) | [Acris](https://acris.me) | [Rainy](https://rainylog.com)\n* :gemini: Gemini 方案: [Ivan.Nginx](https://almostover.ru) | [Raincal](https://raincal.com) | [Dandy](https://dandyxu.me)\n\n\n更多 NexT 例子点击 [这里](https://github.com/iissnan/hexo-theme-next/issues/119).\n\n## 安装 Installation\n\n**1.** 在终端切换到**hexo 根**目录. 在hexo目录下一定有 `node_modules`, `source`, `themes` 和其他文件夹:\n   ```sh\n   $ cd hexo\n   $ ls\n   _config.yml  node_modules  package.json  public  scaffolds  source  themes\n   ```\n\n**2.** 从 github 上获取主题 。这里有几种方式来获取主题:\n\n### 下载[最新发布的版本][releases-latest-url]  Download tagged release version\n   在大多数情况下 **稳定**。 推荐用户下载这个。\n\n   [![curl-tar-wget-image]][curl-tar-wget-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -s https://api.github.com/repos/iissnan/hexo-theme-next/releases/latest | grep tarball_url | cut -d '\"' -f 4 | wget -i - -O- | tar -zx -C themes/next --strip-components=1\n   ```\n\n### 下载[标签发布版本][releases-url]  Download tagged release version\n   您必须定义版本。从[标签列表][tags-url]里选择版本替换`v5.1.2`。\n\n   [![curl-tar-image]][curl-tar-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -L https://api.github.com/repos/iissnan/hexo-theme-next/tarball/v5.1.2 | tar -zxv -C themes/next --strip-components=1\n   ```\n\n   [![git-image]][git-url]\n\n   ```sh\n   $ git clone --branch v5.1.2 https://github.com/iissnan/hexo-theme-next themes/next\n   ```\n\n### 下载[最新的 master 分支][download-latest-url]  Download latest master branch\n  可能会 **不稳定**, 但是包含最新的特色，推荐开发者下载.\n\n   [![curl-tar-image]][curl-tar-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -L https://api.github.com/repos/iissnan/hexo-theme-next/tarball | tar -zxv -C themes/next --strip-components=1\n   ```\n\n   [![git-image]][git-url]\n\n   ```sh\n   $ git clone https://github.com/iissnan/hexo-theme-next themes/next\n   ```\n\n  使用克隆命令，你将得到**整个存储库**。而且在任何时候你都可以切换到任何标签发布版本。\n  获取标签列表：\n\n   ```sh\n   $ cd themes/next\n   $ git tag -l\n   …\n   v5.0.0\n   v5.0.1\n   v5.1.0\n   v5.1.1\n   v5.1.2\n   ```\n\n   例如, 你想要切换到`v5.1.0` [标签发布版本][tags-url]. 输入以下命令:\n\n   ```sh\n   $ git checkout tags/v5.1.0\n   Note: checking out 'tags/v5.1.0'.\n   …\n   HEAD now on 1f72f68... CSS: Remove global list-style setting of ul\n   ```\n\n   如果你想切换回 [master 分支][commits-url]的话, 输入这个命令:\n\n   ```sh\n   $ git checkout master\n   ```\n\n**3.** 在 **hexo 根目录下** 的配置文件`_config.yml`里设置主题:\n\n    theme: next\n\n### Bugs\n对于那些遇到 **Error: Cannot find module 'hexo-util'** [问题](https://github.com/iissnan/hexo-theme-next/issues/1490)的人, 请检查你的NPM 版本.\n\n- `版本 > 3`: 如果仍然不行的话，请移除 `node_modules` 文件 然后重新安装，使用 `npm install`命令。\n- `版本 < 3`: 请通过`npm install --save-dev hexo-util`命令添加`hexo-util`到你的站点包依赖里\n\n## 更新 Update\n\n```sh\n$ cd themes/next\n$ git pull\n```\n\n### Bugs\n\n> 提交您的更改或存储它们，然后才能合并。\n\n您必须提交，存储或放弃本地更改. 看 [here](https://stackoverflow.com/a/15745424/5861495) 是如何做的。\n\n### 使用Hexo data files([#328](https://github.com/iissnan/hexo-theme-next/issues/328))配置主题  Theme configurations using Hexo data files #328\n\n\n目前升级 NexT 主题的时候并不是非常的流畅。若使用 `git pull` 的方式，很多时候可能会产生冲突；而下载新版本覆盖安装的方式又需要手动合并主题的 `_config.yml` 文件。\n\n在此修改之前， NexT 建议将配置分离，一部分在 站点的配置文件中，另外一部分在主题的配置文件中。将需要自定的选项放置在 站点配置文件中，从而脱离避免更新主题时可能遇到的麻烦。这种方式是可行，但是有一些缺点：\n\n1. 配置分离成了两个部分\n2. 用户可能会疑惑一些选项该放置在哪里比较合适\n\n为了解决这个问题， NexT 将会使用 Hexo 的 [Data Files](https://hexo.io/docs/data-files.html) 。然而由于 Data Files 是在 Hexo 3 版本时引进的，所以要使用这个特性，需要 Hexo 的版本不低于 3。\n\n若你比较喜欢 Hexo 2.x 版本，可以继续使用原先的配置方式。 NexT 保持着向下兼容。\n\n\n#### 特性 Benefits\n\n通过这个特性，你可以将所有的主题配置放置在站点的 `source/_data/next.yml` 文件中。原先放置在 站点配置文件 中的选项可以迁移到新的位置，同时，主题配置文件可以不用做任何修改。若后续版本有配置相关的改动时，你仅需在 `next.yml` 中做相应调整即可\n\n\n#### 如何使用这个特性 How to use this feature\n\n1. 请先确保你所使用的 Hexo 版本在 3 以上\n2. 在站点的 `source/_data` 目录下新建 `next.yml` 文件（`_data`目录可能需要新建）\n3. 迁移站点配置文件和主题配置文件中的配置到 `next.yml` 中\n4. 使用 `--config source/_data/next.yml` 参数启动服务器, 生成或者部署。\\\n   例如: `hexo clean --config source/_data/next.yml && hexo g --config source/_data/next.yml`。\n\n## 特色 Features\n\n### 支持多国语言, 包括:\n:cn: 简体中文 & 繁体中文<br>\n:us: 英语<br>\n:ru: 俄语<br>\n:fr: 法语<br>\n:de: 德语<br>\n:jp: 日语<br>\n:indonesia: 印度尼西亚语<br>\n:portugal: 葡萄牙语 (巴西)<br>\n:kr: 朝鲜语<br>\n:it: 意大利语<br>\n:netherlands: 荷兰语\n\n默认语言是英语。\n\n```yml\nlanguage: en\n# language: zh-Hans\n# language: zh-hk\n# language: zh-tw\n# language: ru\n# language: fr-FR\n# language: de\n# language: ja\n# language: id\n# language: pt\n# language: pt-BR\n# language: ko\n# language: it\n# language: nl-NL\n```\n\n在站点配置文件`_config.yml`中可以将语言切换成中文\n\n```yml\nlanguage: zh-Hans\n```\n\n### 评论支持 Comment support\n\nNexT 已经原生支持 `多说` and `Disqus` 评论系统。\n\n添加以下代码到你的主题配置文件 `_config.yml`:\n\n```yml\nduoshuo:\n  enable: true\n  shortname: your-duoshuo-shortname\n```\n\n或者\n\n```yml\ndisqus_shortname: your-disqus-shortname\n```\n\n### 标签页 Tags page\n\n> 添加一个标签页面，里面包含您网站中的所有标签。\n\n- 创建一个名为 `tags` 页面\n\n        hexo new page \"tags\"\n\n- 编辑标签页, 设置页面类型为`tags`.\n\n        title: All tags\n        date: 2014-12-22 12:39:04\n        type: \"tags\"\n\n- 添加 `tags` 到主题配置文件 `_config.yml` 里:\n\n        menu:\n          home: /\n          archives: /archives\n          tags: /tags\n\n### 分类页 Categories page\n\n> 添加一个分类页面，里面包含您网站中的所有分类。\n\n- 创建一个名为 `categories` 页面\n\n        hexo new page \"categories\"\n\n- 编辑分类页, 设置页面类型为 `categories`.\n\n        title: All categories\n        date: 2014-12-22 12:39:04\n        type: \"categories\"\n\n- 添加 `categories` 到主题配置文件 `_config.yml` 里:\n\n        menu:\n          home: /\n          archives: /archives\n          categories: /categories\n\n### 社交媒体 Social Media\n\nNexT 可以自动添加链接到您的社交媒体帐户里:\n\n```yml\nsocial:\n  GitHub: your-github-url\n  Twitter: your-twitter-url\n  Weibo: your-weibo-url\n  DouBan: your-douban-url\n  ZhiHu: your-zhihu-url\n```\n\n### Feed 链接 Feed link\n\n> 显示 feed 链接。\n\n在主题配置文件`_config.yml`里设置`rss` , 如下所示:\n\n1. `rss: false` 会禁用 feed 链接。\n2. `rss:  ` 使用站点 feed 链接。这是默认的选项。\n\n    按照插件[hexo-generator-feed](https://github.com/hexojs/hexo-generator-feed)的README中的安装说明进行操作。在完成这个插件的配置后，Feed链接也生成好了\n\n3. `rss: http://your-feed-url` 设置你的 feed 链接.\n\n### 内置5种代码高亮主题 Up to 5 code highlight themes built-in\n\nNexT 使用的是 [Tomorrow 主题](https://github.com/chriskempson/tomorrow-theme) ，一共有5种主题供你选择。\nNext 默认使用 `normal`. 下面是 `normal` 和 `night` 主题的预览:\n\n![Tomorrow Normal Preview](http://iissnan.com/nexus/next/tomorrow-normal.png)\n![Tomorrow Night Preview](http://iissnan.com/nexus/next/tomorrow-night.png)\n\n查看更多信息点击[Tomorrow 主题](https://github.com/chriskempson/tomorrow-theme)。\n\n## 配置 Configuration\n\nNexT 的配置很少\n\n```yml\n\n# Menu configuration.\nmenu:\n  home: /\n  archives: /archives\n\n# Favicon\nfavicon: /favicon.ico\n\n# Avatar (put the image into next/source/images/)\n# can be any image format supported by web browsers (JPEG,PNG,GIF,SVG,..)\navatar: /default_avatar.png\n\n# Code highlight theme\n# available: normal | night | night eighties | night blue | night bright\nhighlight_theme: normal\n\n# Fancybox for image gallery\nfancybox: true\n\n# Specify the date when the site was setup\nsince: 2013\n\n```\n\n\n## 浏览器支持 Browser support\n\n![Browser support](http://iissnan.com/nexus/next/browser-support.png)\n\n[![Browser Stack](.github/browserstack_logo.png)](https://www.browserstack.com/)\n>**BrowserStack** is a cloud-based cross-browser testing tool that enables developers to test their websites across various browsers on different operating systems and mobile devices, without requiring users to install virtual machines, devices or emulators.\n\n## 贡献 Contributing\n\n接受各种形式的贡献，包括不限于提交问题与需求，修复代码。等待您的`Pull Request`。\n\nAny types of contribution are welcome. Thanks.\n\n**ATTENTION! Contributors on Chinese docs needed!**\\\nNeed to translate from [English docs](README.md) to Chinese docs.\\\nAny help wanted!\\\nThank's a lot!\n\n## 开发 Development\n\nNexT 主旨在于简洁优雅且易于使用，所以首先要尽量确保 NexT 的简洁易用性。\n\nNexT is built for easily use with elegant appearance. First things first, always keep things simple.\n\n## [开发历史 Changelog](https://github.com/iissnan/hexo-theme-next/wiki/Changelog)\n\n\n\n[browser-image]: https://img.shields.io/badge/browser-%20chrome%20%7C%20firefox%20%7C%20opera%20%7C%20safari%20%7C%20ie%20%3E%3D%209-lightgrey.svg\n[browser-url]: https://www.browserstack.com\n\n[gitter-image]: https://badges.gitter.im/Join%20Chat.svg\n[gitter-url]: https://gitter.im/iissnan/hexo-theme-next?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge\n\n[travis-image]: https://travis-ci.org/iissnan/hexo-theme-next.svg?branch=master\n[travis-url]: https://travis-ci.org/iissnan/hexo-theme-next?branch=master \"Travis CI\"\n\n[hexo-image]: https://img.shields.io/badge/hexo-%3E%3D%203.0-blue.svg\n[hexo-url]: http://hexo.io\n\n[mnt-image]: https://img.shields.io/maintenance/yes/2017.svg\n[rel-image]: https://img.shields.io/github/release/iissnan/hexo-theme-next.svg\n<!--[lic-image]: https://img.shields.io/npm/l/hexo-theme-next.svg-->\n[lic-image]: https://img.shields.io/dub/l/vibe-d.svg\n\n[git-image]: https://img.shields.io/badge/install%20with%20-git-blue.svg\n[curl-tar-image]: https://img.shields.io/badge/install%20with%20-curl%20%7C%20tar-blue.svg\n[curl-tar-wget-image]: https://img.shields.io/badge/install%20with%20-curl%20%7C%20tar%20%7C%20wget-blue.svg\n[git-url]: http://lmgtfy.com/?q=linux+git+install\n[curl-tar-url]: http://lmgtfy.com/?q=linux+curl+tar+install\n[curl-tar-wget-url]: http://lmgtfy.com/?q=linux+curl+tar+wget+install\n\n[download-latest-url]: https://github.com/iissnan/hexo-theme-next/archive/master.zip\n[releases-latest-url]: https://github.com/iissnan/hexo-theme-next/releases/latest\n[releases-url]: https://github.com/iissnan/hexo-theme-next/releases\n[tags-url]: https://github.com/iissnan/hexo-theme-next/tags\n[commits-url]: https://github.com/iissnan/hexo-theme-next/commits/master\n"
  },
  {
    "path": "README.md",
    "content": "<h1 align=\"center\">This repository is no longer maintained! :warning:</h1>\n<h2 align=\"center\">The community-maintained version is here: <a href=\"https://github.com/theme-next/hexo-theme-next\">NexT v6 and v7 :triangular_flag_on_post:</a></h2>\n\n<h1 align=\"center\">NexT</h1>\n\n<p align=\"center\">NexT is a high quality elegant <a href=\"http://hexo.io\">Hexo</a> theme. It is crafted from scratch, with love.</p>\n\n[![gitter-image]][gitter-url]\n[![mnt-image]](https://github.com/theme-next/hexo-theme-next)\n[![travis-image]][travis-url]\n[![rel-image]][releases-url]\n[![hexo-image]][hexo-url]\n[![lic-image]](LICENSE)\n\n* [Chinese Documentation](README.cn.md)\n\n## Live Preview\n\n* :heart_decoration: Muse scheme: [LEAFERx](https://leaferx.online) | [XiaMo](https://notes.wanghao.work) | [OAwan](https://oawan.me)\n* :six_pointed_star: Mist scheme: [Jeff](https://blog.zzbd.org) | [uchuhimo](http://uchuhimo.me) | [xirong](http://www.ixirong.com)\n* :pisces: Pisces scheme: [Vi](http://notes.iissnan.com) | [Acris](https://acris.me) | [Rainy](https://rainylog.com)\n* :gemini: Gemini scheme: [Ivan.Nginx](https://almostover.ru) | [Raincal](https://raincal.com) | [Dandy](https://dandyxu.me)\n\nMore NexT examples [here](https://github.com/iissnan/hexo-theme-next/issues/119).\n\n## Installation\n\n**1.** Change dir to **hexo root** directory. There must be `node_modules`, `source`, `themes` and other directories:\n   ```sh\n   $ cd hexo\n   $ ls\n   _config.yml  node_modules  package.json  public  scaffolds  source  themes\n   ```\n\n**2.** Get theme from GitHub. There are several variants to do it:\n\n### Download [latest release version][releases-latest-url].\n   At most cases **stable**. Recommended for most users.\n\n   [![curl-tar-wget-image]][curl-tar-wget-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -s https://api.github.com/repos/iissnan/hexo-theme-next/releases/latest | grep tarball_url | cut -d '\"' -f 4 | wget -i - -O- | tar -zx -C themes/next --strip-components=1\n   ```\n\n### Download [tagged release version][releases-url].\n   You must define version. Replace `v5.1.2` with any version from [tags list][tags-url].\n\n   [![curl-tar-image]][curl-tar-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -L https://api.github.com/repos/iissnan/hexo-theme-next/tarball/v5.1.2 | tar -zxv -C themes/next --strip-components=1\n   ```\n\n   [![git-image]][git-url]\n\n   ```sh\n   $ git clone --branch v5.1.2 https://github.com/iissnan/hexo-theme-next themes/next\n   ```\n\n### Download [latest master branch][download-latest-url].\n   May be **unstable**, but includes latest features. Recommended for developers.\n\n   [![curl-tar-image]][curl-tar-url]\n\n   ```sh\n   $ mkdir themes/next\n   $ curl -L https://api.github.com/repos/iissnan/hexo-theme-next/tarball | tar -zxv -C themes/next --strip-components=1\n   ```\n\n   [![git-image]][git-url]\n\n   ```sh\n   $ git clone https://github.com/iissnan/hexo-theme-next themes/next\n   ```\n\n   Clone command will give you the **whole repository**. And in any time you can switch to any tagged release.\\\n   Get tags list:\n\n   ```sh\n   $ cd themes/next\n   $ git tag -l\n   …\n   v5.0.0\n   v5.0.1\n   v5.1.0\n   v5.1.1\n   v5.1.2\n   ```\n\n   For example, you want to switch on `v5.1.0` [tagged release version][tags-url]. Input the following command:\n\n   ```sh\n   $ git checkout tags/v5.1.0\n   Note: checking out 'tags/v5.1.0'.\n   …\n   HEAD now on 1f72f68... CSS: Remove global list-style setting of ul\n   ```\n\n   And if you want to switch back on [master branch][commits-url], input this command:\n\n   ```sh\n   $ git checkout master\n   ```\n\n**3.** Set theme in main **hexo root config** `_config.yml` file:\n\n    theme: next\n\n### Bugs\nFor those who also encounter **Error: Cannot find module 'hexo-util'** [issue](https://github.com/iissnan/hexo-theme-next/issues/1490), please check your NPM version.\n\n- `> 3`: Still not work. Please remove `node_modules` directory and reinstall using `npm install`.\n- `< 3`: Please add `hexo-util` explicitly via `npm install --save-dev hexo-util` to you site package deps.\n\n## Update\n\n```sh\n$ cd themes/next\n$ git pull\n```\n\n### Bugs\n\n> Commit your changes or stash them before you can merge\n\nYou must Commit, Stash or Discard local changes. See [here](https://stackoverflow.com/a/15745424/5861495) how to do it.\n\n### Theme configurations using Hexo data files ([#328](https://github.com/iissnan/hexo-theme-next/issues/328))\n\nCurrently, it is not smooth to update NexT theme from pulling or downloading new releases. It is quite often running into conflict status when updating NexT theme via `git pull`, or need to merge configurations manually when upgrading to new releases.\n\n At present, NexT encourages users to store some options in site's `_config.yml` and other options in theme's `_config.yml`. This approach is applicable, but has some drawbacks:\n1. Configurations are splited into two pieces\n2. Users maybe confuse which place should be for options\n\nIn order to resolve this issue, NexT will take advantage of Hexo [Data files](https://hexo.io/docs/data-files.html). Because Data files is introduced in Hexo 3, so you need upgrade Hexo to 3.0 (or above) to use this feature.\n\nIf you prefer Hexo 2.x, you can still use the old approach for configurations. NexT is still compatible with Hexo 2.x.\n\n#### Benefits\n\nWith this feature, now you can put all your configurations into one place (`source/_data/next.yml`), you don't need to touch `next/_config.yml`. If there are any new options in new releases, you just need to copy those options from `next/_config.yml`, paste into `_data/next.yml` and set their values to whatever you want.\n\n#### How to use this feature\n\n1. Please ensure you are using Hexo 3 (or above)\n2. Create an file named `next.yml` in site's `source/_data` directory (create `_data` directory if it did not exist)\n3. Copy NexT theme options both in site's `_config.yml` and theme's `_config.yml` into `next.yml`.\n4. Use `--config source/_data/next.yml` parameter to start server, generate or deploy.\\\n   For example: `hexo clean --config source/_data/next.yml && hexo g --config source/_data/next.yml`.\n\n## Features\n\n### Multiple languages support, including:\n:cn: Simplified Chinese & Traditional Chinese.<br>\n:us: English<br>\n:ru: Russian<br>\n:fr: French<br>\n:de: German<br>\n:jp: Japanese<br>\n:indonesia: Indonesian<br>\n:portugal: Portuguese (Brazil)<br>\n:kr: Korean<br>\n:it: Italian<br>\n:netherlands: Dutch<br>\n:vietnam: Vietnamese\n\nDefault language is English.\n\n```yml\nlanguage: en\n# language: zh-Hans\n# language: zh-hk\n# language: zh-tw\n# language: ru\n# language: fr-FR\n# language: de\n# language: ja\n# language: id\n# language: pt\n# language: pt-BR\n# language: ko\n# language: it\n# language: nl-NL\n# language: vi\n```\n\nSet `language` field as following in site `_config.yml` to change to Chinese.\n\n```yml\nlanguage: zh-Hans\n```\n\n### Comment support.\n\nNexT has native support for `DuoShuo` and `Disqus` comment systems.\n\nAdd the following snippets to your `_config.yml`:\n\n```yml\nduoshuo:\n  enable: true\n  shortname: your-duoshuo-shortname\n```\n\nOR\n\n```yml\ndisqus_shortname: your-disqus-shortname\n```\n\n### Tags page.\n\n> Add a tags page contains all tags in your site.\n\n- Create a page named `tags`\n\n        hexo new page \"tags\"\n\n- Edit tags page, set page type to `tags`.\n\n        title: All tags\n        date: 2014-12-22 12:39:04\n        type: \"tags\"\n\n- Add `tags` to theme `_config.yml`:\n\n        menu:\n          home: /\n          archives: /archives\n          tags: /tags\n\n### Categories page.\n\n> Add a categories page contains all categories in your site.\n\n- Create a page named `categories`\n\n        hexo new page \"categories\"\n\n- Edit categories page, set page type to `categories`.\n\n        title: All categories\n        date: 2014-12-22 12:39:04\n        type: \"categories\"\n\n- Add `categories` to theme `_config.yml`:\n\n        menu:\n          home: /\n          archives: /archives\n          categories: /categories\n\n### Social Media\n\nNexT can automatically add links to your Social Media accounts:\n\n```yml\nsocial:\n  GitHub: your-github-url\n  Twitter: your-twitter-url\n  Weibo: your-weibo-url\n  DouBan: your-douban-url\n  ZhiHu: your-zhihu-url\n```\n\n### Feed link.\n\n> Show a feed link.\n\nSet `rss` field in theme's `_config.yml`, as the following value:\n\n1. `rss: false` will totally disable feed link.\n2. `rss:  ` use sites' feed link. This is the default option.\n\n    Follow the installation instruction in the plugin's README. After the configuration is done for this plugin, the feed link is ready too.\n\n3. `rss: http://your-feed-url` set specific feed link.\n\n### Up to 5 code highlight themes built-in.\n\nNexT uses [Tomorrow Theme](https://github.com/chriskempson/tomorrow-theme) with 5 themes for you to choose from.\nNext use `normal` by default. Have a preview about `normal` and `night`:\n\n![Tomorrow Normal Preview](http://iissnan.com/nexus/next/tomorrow-normal.png)\n![Tomorrow Night Preview](http://iissnan.com/nexus/next/tomorrow-night.png)\n\nHead over to [Tomorrow Theme](https://github.com/chriskempson/tomorrow-theme) for more details.\n\n## Configuration\n\nNexT comes with few configurations.\n\n```yml\n\n# Menu configuration.\nmenu:\n  home: /\n  archives: /archives\n\n# Favicon\nfavicon: /favicon.ico\n\n# Avatar (put the image into next/source/images/)\n# can be any image format supported by web browsers (JPEG,PNG,GIF,SVG,..)\navatar: /default_avatar.png\n\n# Code highlight theme\n# available: normal | night | night eighties | night blue | night bright\nhighlight_theme: normal\n\n# Fancybox for image gallery\nfancybox: true\n\n# Specify the date when the site was setup\nsince: 2013\n\n```\n\n## Browser support\n\n![browser-image]\n\n[![Browser Stack](.github/browserstack_logo.png)](https://www.browserstack.com/)\n>**BrowserStack** is a cloud-based cross-browser testing tool that enables developers to test their websites across various browsers on different operating systems and mobile devices, without requiring users to install virtual machines, devices or emulators.\n\n## Contributing\n\nContribution is welcome, feel free to open an issue and fork. Waiting for your pull request.\n<!--\n[![hexo-image]][hexo-url]\n[![bower-image]][bower-url]\n[![jquery-image]][jquery-url]\n\n[hexo-image]: http://img.shields.io/badge/Hexo-2.4+-2BAF2B.svg?style=flat-square\n[hexo-url]: http://hexo.io\n[bower-image]: http://img.shields.io/badge/Bower-*-2BAF2B.svg?style=flat-square\n[bower-url]: http://bower.io\n[jquery-image]: https://img.shields.io/badge/jquery-1.9-blue.svg?style=flat-square\n[jquery-url]: http://jquery.com/\n-->\n\n[browser-image]: https://img.shields.io/badge/browser-%20chrome%20%7C%20firefox%20%7C%20opera%20%7C%20safari%20%7C%20ie%20%3E%3D%209-lightgrey.svg\n[browser-url]: https://www.browserstack.com\n\n[gitter-image]: https://badges.gitter.im/Join%20Chat.svg\n[gitter-url]: https://gitter.im/iissnan/hexo-theme-next?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge\n\n[travis-image]: https://travis-ci.org/iissnan/hexo-theme-next.svg?branch=master\n[travis-url]: https://travis-ci.org/iissnan/hexo-theme-next?branch=master \"Travis CI\"\n\n[hexo-image]: https://img.shields.io/badge/hexo-%3E%3D%203.0-blue.svg\n[hexo-url]: http://hexo.io\n\n[mnt-image]: https://img.shields.io/maintenance/yes/2017.svg\n[rel-image]: https://img.shields.io/github/release/iissnan/hexo-theme-next.svg\n<!--[lic-image]: https://img.shields.io/npm/l/hexo-theme-next.svg-->\n[lic-image]: https://img.shields.io/dub/l/vibe-d.svg\n\n[git-image]: https://img.shields.io/badge/install%20with%20-git-blue.svg\n[curl-tar-image]: https://img.shields.io/badge/install%20with%20-curl%20%7C%20tar-blue.svg\n[curl-tar-wget-image]: https://img.shields.io/badge/install%20with%20-curl%20%7C%20tar%20%7C%20wget-blue.svg\n[git-url]: http://lmgtfy.com/?q=linux+git+install\n[curl-tar-url]: http://lmgtfy.com/?q=linux+curl+tar+install\n[curl-tar-wget-url]: http://lmgtfy.com/?q=linux+curl+tar+wget+install\n\n[download-latest-url]: https://github.com/iissnan/hexo-theme-next/archive/master.zip\n[releases-latest-url]: https://github.com/iissnan/hexo-theme-next/releases/latest\n[releases-url]: https://github.com/iissnan/hexo-theme-next/releases\n[tags-url]: https://github.com/iissnan/hexo-theme-next/tags\n[commits-url]: https://github.com/iissnan/hexo-theme-next/commits/master\n"
  },
  {
    "path": "_config.yml",
    "content": "# ===============================================================\n# ========================= ATTENTION! ==========================\n# ===============================================================\n# NexT repository is moving here: https://github.com/theme-next\n# ===============================================================\n# It's rebase to v6.0.0 and future maintenance will resume there\n# ===============================================================\n\n# ---------------------------------------------------------------\n# Theme Core Configuration Settings\n# ---------------------------------------------------------------\n\n# Set to true, if you want to fully override the default configuration.\n# Useful if you don't want to inherit the theme _config.yml configurations.\noverride: false\n\n# ---------------------------------------------------------------\n# Site Information Settings\n# ---------------------------------------------------------------\n\n# To get or check favicons visit: https://realfavicongenerator.net\n# Put your favicons into `hexo-site/source/` (recommend) or `hexo-site/themes/next/source/images/` directory.\n\n# Default NexT favicons placed in `hexo-site/themes/next/source/images/` directory.\n# And if you want to place your icons in `hexo-site/source/` root directory, you must remove `/images` prefix from pathes.\n\n# For example, you put your favicons into `hexo-site/source/images` directory.\n# Then need to rename & redefine they on any other names, otherwise icons from Next will rewrite your custom icons in Hexo.\nfavicon:\n  small: /images/favicon-16x16-next.png\n  medium: /images/favicon-32x32-next.png\n  apple_touch_icon: /images/apple-touch-icon-next.png\n  safari_pinned_tab: /images/logo.svg\n  #android_manifest: /images/manifest.json\n  #ms_browserconfig: /images/browserconfig.xml\n\n# Set default keywords (Use a comma to separate)\nkeywords: \"Hexo, NexT\"\n\n# Set rss to false to disable feed link.\n# Leave rss as empty to use site's feed link.\n# Set rss to specific value if you have burned your feed already.\nrss:\n\nfooter:\n  # Specify the date when the site was setup.\n  # If not defined, current year will be used.\n  #since: 2015\n\n  # Icon between year and copyright info.\n  icon: user\n\n  # If not defined, will be used `author` from Hexo main config.\n  copyright:\n  # -------------------------------------------------------------\n  # Hexo link (Powered by Hexo).\n  powered: true\n\n  theme:\n    # Theme & scheme info link (Theme - NexT.scheme).\n    enable: true\n    # Version info of NexT after scheme info (vX.X.X).\n    version: true\n  # -------------------------------------------------------------\n  # Any custom text can be defined here.\n  #custom_text: Hosted by <a target=\"_blank\" href=\"https://pages.github.com\">GitHub Pages</a>\n\n# ---------------------------------------------------------------\n# SEO Settings\n# ---------------------------------------------------------------\n\n# Canonical, set a canonical link tag in your hexo, you could use it for your SEO of blog.\n# See: https://support.google.com/webmasters/answer/139066\n# Tips: Before you open this tag, remember set up your URL in hexo _config.yml ( ex. url: http://yourdomain.com )\ncanonical: true\n\n# Change headers hierarchy on site-subtitle (will be main site description) and on all post/pages titles for better SEO-optimization.\nseo: false\n\n# If true, will add site-subtitle to index page, added in main hexo config.\n# subtitle: Subtitle\nindex_with_subtitle: false\n\n\n# ---------------------------------------------------------------\n# Menu Settings\n# ---------------------------------------------------------------\n\n# When running the site in a subdirectory (e.g. domain.tld/blog), remove the leading slash from link value (/archives -> archives).\n# Usage: `Key: /link/ || icon`\n# Key is the name of menu item. If translate for this menu will find in languages - this translate will be loaded; if not - Key name will be used. Key is case-senstive.\n# Value before `||` delimeter is the target link.\n# Value after `||` delimeter is the name of FontAwesome icon. If icon (with or without delimeter) is not specified, question icon will be loaded.\nmenu:\n  home: / || home\n  #about: /about/ || user\n  #tags: /tags/ || tags\n  #categories: /categories/ || th\n  archives: /archives/ || archive\n  #schedule: /schedule/ || calendar\n  #sitemap: /sitemap.xml || sitemap\n  #commonweal: /404/ || heartbeat\n\n# Enable/Disable menu icons.\nmenu_icons:\n  enable: true\n\n\n# ---------------------------------------------------------------\n# Scheme Settings\n# ---------------------------------------------------------------\n\n# Schemes\nscheme: Muse\n#scheme: Mist\n#scheme: Pisces\n#scheme: Gemini\n\n\n# ---------------------------------------------------------------\n# Sidebar Settings\n# ---------------------------------------------------------------\n\n# Social Links.\n# Usage: `Key: permalink || icon`\n# Key is the link label showing to end users.\n# Value before `||` delimeter is the target permalink.\n# Value after `||` delimeter is the name of FontAwesome icon. If icon (with or without delimeter) is not specified, globe icon will be loaded.\n#social:\n  #GitHub: https://github.com/yourname || github\n  #E-Mail: mailto:yourname@gmail.com || envelope\n  #Google: https://plus.google.com/yourname || google\n  #Twitter: https://twitter.com/yourname || twitter\n  #FB Page: https://www.facebook.com/yourname || facebook\n  #VK Group: https://vk.com/yourname || vk\n  #StackOverflow: https://stackoverflow.com/yourname || stack-overflow\n  #YouTube: https://youtube.com/yourname || youtube\n  #Instagram: https://instagram.com/yourname || instagram\n  #Skype: skype:yourname?call|chat || skype\n\nsocial_icons:\n  enable: true\n  icons_only: false\n  transition: false\n\n# Blog rolls\nlinks_icon: link\nlinks_title: Links\nlinks_layout: block\n#links_layout: inline\n#links:\n  #Title: http://example.com/\n\n# Sidebar Avatar\n# in theme directory(source/images): /images/avatar.gif\n# in site  directory(source/uploads): /uploads/avatar.gif\n#avatar: /images/avatar.gif\n\n# Table Of Contents in the Sidebar\ntoc:\n  enable: true\n\n  # Automatically add list number to toc.\n  number: true\n\n  # If true, all words will placed on next lines if header width longer then sidebar width.\n  wrap: false\n\n# Creative Commons 4.0 International License.\n# http://creativecommons.org/\n# Available: by | by-nc | by-nc-nd | by-nc-sa | by-nd | by-sa | zero\n#creative_commons: by-nc-sa\n#creative_commons:\n\nsidebar:\n  # Sidebar Position, available value: left | right (only for Pisces | Gemini).\n  position: left\n  #position: right\n\n  # Sidebar Display, available value (only for Muse | Mist):\n  #  - post    expand on posts automatically. Default.\n  #  - always  expand for all pages automatically\n  #  - hide    expand only when click on the sidebar toggle icon.\n  #  - remove  Totally remove sidebar including sidebar toggle.\n  display: post\n  #display: always\n  #display: hide\n  #display: remove\n\n  # Sidebar offset from top menubar in pixels (only for Pisces | Gemini).\n  offset: 12\n\n  # Back to top in sidebar (only for Pisces | Gemini).\n  b2t: false\n\n  # Scroll percent label in b2t button.\n  scrollpercent: false\n\n  # Enable sidebar on narrow view (only for Muse | Mist).\n  onmobile: false\n\n\n# ---------------------------------------------------------------\n# Post Settings\n# ---------------------------------------------------------------\n\n# Automatically scroll page to section which is under <!-- more --> mark.\nscroll_to_more: true\n\n# Automatically saving scroll position on each post/page in cookies.\nsave_scroll: false\n\n# Automatically excerpt description in homepage as preamble text.\nexcerpt_description: true\n\n# Automatically Excerpt. Not recommend.\n# Please use <!-- more --> in the post to control excerpt accurately.\nauto_excerpt:\n  enable: false\n  length: 150\n\n# Post meta display settings\npost_meta:\n  item_text: true\n  created_at: true\n  updated_at: false\n  categories: true\n\n# Post wordcount display settings\n# Dependencies: https://github.com/willin/hexo-wordcount\npost_wordcount:\n  item_text: true\n  wordcount: false\n  min2read: false\n  totalcount: false\n  separated_meta: true\n\n# Wechat Subscriber\n#wechat_subscriber:\n  #enabled: true\n  #qcode: /path/to/your/wechatqcode ex. /uploads/wechat-qcode.jpg\n  #description: ex. subscribe to my blog by scanning my public wechat account\n\n# Reward\n#reward_comment: Donate comment here\n#wechatpay: /images/wechatpay.jpg\n#alipay: /images/alipay.jpg\n#bitcoin: /images/bitcoin.png\n\n# Declare license on posts\npost_copyright:\n  enable: false\n  license: CC BY-NC-SA 3.0\n  license_url: https://creativecommons.org/licenses/by-nc-sa/3.0/\n\n\n# ---------------------------------------------------------------\n# Misc Theme Settings\n# ---------------------------------------------------------------\n\n# Reduce padding / margin indents on devices with narrow width.\nmobile_layout_economy: false\n\n# Android Chrome header panel color ($black-deep).\nandroid_chrome_color: \"#222\"\n\n# Custom Logo.\n# !!Only available for Default Scheme currently.\n# Options:\n#   enabled: [true/false] - Replace with specific image\n#   image: url-of-image   - Images's url\ncustom_logo:\n  enabled: false\n  image:\n\n# Code Highlight theme\n# Available value:\n#    normal | night | night eighties | night blue | night bright\n# https://github.com/chriskempson/tomorrow-theme\nhighlight_theme: normal\n\n\n# ---------------------------------------------------------------\n# Font Settings\n# - Find fonts on Google Fonts (https://www.google.com/fonts)\n# - All fonts set here will have the following styles:\n#     light, light italic, normal, normal italic, bold, bold italic\n# - Be aware that setting too much fonts will cause site running slowly\n# - Introduce in 5.0.1\n# ---------------------------------------------------------------\n# CAUTION! Safari Version 10.1.2 bug: https://github.com/iissnan/hexo-theme-next/issues/1844\n# To avoid space between header and sidebar in Pisces / Gemini themes recommended to use Web Safe fonts for `global` (and `logo`):\n# Arial | Tahoma | Helvetica | Times New Roman | Courier New | Verdana | Georgia | Palatino | Garamond | Comic Sans MS | Trebuchet MS\n# ---------------------------------------------------------------\nfont:\n  enable: false\n\n  # Uri of fonts host. E.g. //fonts.googleapis.com (Default).\n  host:\n\n  # Font options:\n  # `external: true` will load this font family from `host` above.\n  # `family: Times New Roman`. Without any quotes.\n  # `size: xx`. Use `px` as unit.\n\n  # Global font settings used on <body> element.\n  global:\n    external: true\n    family: Lato\n    size:\n\n  # Font settings for Headlines (h1, h2, h3, h4, h5, h6).\n  # Fallback to `global` font settings.\n  headings:\n    external: true\n    family:\n    size:\n\n  # Font settings for posts.\n  # Fallback to `global` font settings.\n  posts:\n    external: true\n    family:\n\n  # Font settings for Logo.\n  # Fallback to `global` font settings.\n  logo:\n    external: true\n    family:\n    size:\n\n  # Font settings for <code> and code blocks.\n  codes:\n    external: true\n    family:\n    size:\n\n\n# ---------------------------------------------------------------\n# Third Party Services Settings\n# ---------------------------------------------------------------\n\n# MathJax Support\nmathjax:\n  enable: false\n  per_page: false\n  cdn: //cdn.bootcss.com/mathjax/2.7.1/latest.js?config=TeX-AMS-MML_HTMLorMML\n\n# Han Support docs: https://hanzi.pro/\nhan: false\n\n# Swiftype Search API Key\n#swiftype_key:\n\n# Baidu Analytics ID\n#baidu_analytics:\n\n# Duoshuo ShortName\n#duoshuo_shortname:\n\n# Disqus\ndisqus:\n  enable: false\n  shortname:\n  count: true\n\n# Hypercomments\n#hypercomments_id:\n\n# changyan\nchangyan:\n  enable: false\n  appid:\n  appkey:\n\n\n# Valine.\n# You can get your appid and appkey from https://leancloud.cn\n# more info please open https://valine.js.org\nvaline:\n  enable: false\n  appid:  # your leancloud application appid\n  appkey:  # your leancloud application appkey\n  notify: false # mail notifier , https://github.com/xCss/Valine/wiki\n  verify: false # Verification code\n  placeholder: Just go go # comment box placeholder\n  avatar: mm # gravatar style\n  guest_info: nick,mail,link # custom comment header\n  pageSize: 10 # pagination size\n\n\n# Support for youyan comments system.\n# You can get your uid from http://www.uyan.cc\n#youyan_uid: your uid\n\n# Support for LiveRe comments system.\n# You can get your uid from https://livere.com/insight/myCode (General web site)\n#livere_uid: your uid\n\n# Gitment\n# Introduction: https://imsun.net/posts/gitment-introduction/\n# You can get your Github ID from https://api.github.com/users/<Github username>\ngitment:\n  enable: false\n  mint: true # RECOMMEND, A mint on Gitment, to support count, language and proxy_gateway\n  count: true # Show comments count in post meta area\n  lazy: false # Comments lazy loading with a button\n  cleanly: false # Hide 'Powered by ...' on footer, and more\n  language: # Force language, or auto switch by theme\n  github_user: # MUST HAVE, Your Github ID\n  github_repo: # MUST HAVE, The repo you use to store Gitment comments\n  client_id: # MUST HAVE, Github client id for the Gitment\n  client_secret: # EITHER this or proxy_gateway, Github access secret token for the Gitment\n  proxy_gateway: # Address of api proxy, See: https://github.com/aimingoo/intersect\n  redirect_protocol: # Protocol of redirect_uri with force_redirect_protocol when mint enabled\n\n# Baidu Share\n# Available value:\n#    button | slide\n# Warning: Baidu Share does not support https.\n#baidushare:\n##  type: button\n\n# Share\n# This plugin is more useful in China, make sure you known how to use it.\n# And you can find the use guide at official webiste: http://www.jiathis.com/.\n# Warning: JiaThis does not support https.\n#jiathis:\n  ##uid: Get this uid from http://www.jiathis.com/\n#add_this_id:\n\n# Share\n#duoshuo_share: true\n\n# NeedMoreShare2\n# This plugin is a pure javascript sharing lib which is useful in China.\n# See: https://github.com/revir/need-more-share2\n# Also see: https://github.com/DzmVasileusky/needShareButton\n# iconStyle: default | box\n# boxForm: horizontal | vertical\n# position: top / middle / bottom + Left / Center / Right\n# networks: Weibo,Wechat,Douban,QQZone,Twitter,Linkedin,Mailto,Reddit,\n#           Delicious,StumbleUpon,Pinterest,Facebook,GooglePlus,Slashdot,\n#           Technorati,Posterous,Tumblr,GoogleBookmarks,Newsvine,\n#           Evernote,Friendfeed,Vkontakte,Odnoklassniki,Mailru\nneedmoreshare2:\n  enable: false\n  postbottom:\n    enable: false\n    options:\n      iconStyle: box\n      boxForm: horizontal\n      position: bottomCenter\n      networks: Weibo,Wechat,Douban,QQZone,Twitter,Facebook\n  float:\n    enable: false\n    options:\n      iconStyle: box\n      boxForm: horizontal\n      position: middleRight\n      networks: Weibo,Wechat,Douban,QQZone,Twitter,Facebook\n\n# Google Webmaster tools verification setting\n# See: https://www.google.com/webmasters/\n#google_site_verification:\n\n# Google Analytics\n#google_analytics:\n\n# Bing Webmaster tools verification setting\n# See: https://www.bing.com/webmaster/\n#bing_site_verification:\n\n# Yandex Webmaster tools verification setting\n# See: https://webmaster.yandex.ru/\n#yandex_site_verification:\n\n# CNZZ count\n#cnzz_siteid:\n\n# Application Insights\n# See https://azure.microsoft.com/en-us/services/application-insights/\n# application_insights:\n\n# Make duoshuo show UA\n# user_id must NOT be null when admin_enable is true!\n# you can visit http://dev.duoshuo.com get duoshuo user id.\nduoshuo_info:\n  ua_enable: true\n  admin_enable: false\n  user_id: 0\n  #admin_nickname: Author\n\n# Post widgets & FB/VK comments settings.\n# ---------------------------------------------------------------\n# Facebook SDK Support.\n# https://github.com/iissnan/hexo-theme-next/pull/410\nfacebook_sdk:\n  enable:       false\n  app_id:       #<app_id>\n  fb_admin:     #<user_id>\n  like_button:  #true\n  webmaster:    #true\n\n# Facebook comments plugin\n# This plugin depends on Facebook SDK.\n# If facebook_sdk.enable is false, Facebook comments plugin is unavailable.\nfacebook_comments_plugin:\n  enable:       false\n  num_of_posts: 10    # min posts num is 1\n  width:        100%  # default width is 550px\n  scheme:       light # default scheme is light (light or dark)\n\n# VKontakte API Support.\n# To get your AppID visit https://vk.com/editapp?act=create\nvkontakte_api:\n  enable:       false\n  app_id:       #<app_id>\n  like:         true\n  comments:     true\n  num_of_posts: 10\n\n# Star rating support to each article.\n# To get your ID visit https://widgetpack.com\nrating:\n  enable: false\n  id:     #<app_id>\n  color:  fc6423\n# ---------------------------------------------------------------\n\n# Show number of visitors to each article.\n# You can visit https://leancloud.cn get AppID and AppKey.\nleancloud_visitors:\n  enable: false\n  app_id: #<app_id>\n  app_key: #<app_key>\n\n# Another tool to show number of visitors to each article.\n# visit https://console.firebase.google.com/u/0/ to get apiKey and projectId\n# visit https://firebase.google.com/docs/firestore/ to get more information about firestore\nfirestore:\n  enable: false\n  collection: articles #required, a string collection name to access firestore database\n  apiKey: #required\n  projectId: #required\n  bluebird: false #enable this if you want to include bluebird 3.5.1(core version) Promise polyfill\n\n# Show PV/UV of the website/page with busuanzi.\n# Get more information on http://ibruce.info/2015/04/04/busuanzi/\nbusuanzi_count:\n  # count values only if the other configs are false\n  enable: false\n  # custom uv span for the whole site\n  site_uv: true\n  site_uv_header: <i class=\"fa fa-user\"></i>\n  site_uv_footer:\n  # custom pv span for the whole site\n  site_pv: true\n  site_pv_header: <i class=\"fa fa-eye\"></i>\n  site_pv_footer:\n  # custom pv span for one page only\n  page_pv: true\n  page_pv_header: <i class=\"fa fa-file-o\"></i>\n  page_pv_footer:\n\n\n# Tencent analytics ID\n# tencent_analytics:\n\n# Tencent MTA ID\n# tencent_mta:\n\n\n# Enable baidu push so that the blog will push the url to baidu automatically which is very helpful for SEO\nbaidu_push: false\n\n# Google Calendar\n# Share your recent schedule to others via calendar page\n#\n# API Documentation:\n# https://developers.google.com/google-apps/calendar/v3/reference/events/list\ncalendar:\n  enable: false\n  calendar_id: <required>\n  api_key: <required>\n  orderBy: startTime\n  offsetMax: 24\n  offsetMin: 4\n  timeZone:\n  showDeleted: false\n  singleEvents: true\n  maxResults: 250\n\n# Algolia Search\nalgolia_search:\n  enable: false\n  hits:\n    per_page: 10\n  labels:\n    input_placeholder: Search for Posts\n    hits_empty: \"We didn't find any results for the search: ${query}\"\n    hits_stats: \"${hits} results found in ${time} ms\"\n\n# Local search\n# Dependencies: https://github.com/flashlab/hexo-generator-search\nlocal_search:\n  enable: false\n  # if auto, trigger search by changing input\n  # if manual, trigger search by pressing enter key or search button\n  trigger: auto\n  # show top n results per article, show all results by setting to -1\n  top_n_per_article: 1\n\n\n# ---------------------------------------------------------------\n# Tags Settings\n# ---------------------------------------------------------------\n\n# External URL with BASE64 encrypt & decrypt.\n# Usage: {% exturl text url \"title\" %}\n# Alias: {% extlink text url \"title\" %}\nexturl: false\n\n# Note tag (bs-callout).\nnote:\n  # Note tag style values:\n  #  - simple    bs-callout old alert style. Default.\n  #  - modern    bs-callout new (v2-v3) alert style.\n  #  - flat      flat callout style with background, like on Mozilla or StackOverflow.\n  #  - disabled  disable all CSS styles import of note tag.\n  style: simple\n  icons: false\n  border_radius: 3\n  # Offset lighter of background in % for modern and flat styles (modern: -12 | 12; flat: -18 | 6).\n  # Offset also applied to label tag variables. This option can work with disabled note tag.\n  light_bg_offset: 0\n\n# Label tag.\nlabel: true\n\n# Tabs tag.\ntabs:\n  enable: true\n  transition:\n    tabs: false\n    labels: true\n  border_radius: 0\n\n\n#! ---------------------------------------------------------------\n#! DO NOT EDIT THE FOLLOWING SETTINGS\n#! UNLESS YOU KNOW WHAT YOU ARE DOING\n#! ---------------------------------------------------------------\n\n# Use velocity to animate everything.\nmotion:\n  enable: true\n  async: false\n  transition:\n    # Transition variants:\n    # fadeIn | fadeOut | flipXIn | flipXOut | flipYIn | flipYOut | flipBounceXIn | flipBounceXOut | flipBounceYIn | flipBounceYOut\n    # swoopIn | swoopOut | whirlIn | whirlOut | shrinkIn | shrinkOut | expandIn | expandOut\n    # bounceIn | bounceOut | bounceUpIn | bounceUpOut | bounceDownIn | bounceDownOut | bounceLeftIn | bounceLeftOut | bounceRightIn | bounceRightOut\n    # slideUpIn | slideUpOut | slideDownIn | slideDownOut | slideLeftIn | slideLeftOut | slideRightIn | slideRightOut\n    # slideUpBigIn | slideUpBigOut | slideDownBigIn | slideDownBigOut | slideLeftBigIn | slideLeftBigOut | slideRightBigIn | slideRightBigOut\n    # perspectiveUpIn | perspectiveUpOut | perspectiveDownIn | perspectiveDownOut | perspectiveLeftIn | perspectiveLeftOut | perspectiveRightIn | perspectiveRightOut\n    post_block: fadeIn\n    post_header: slideDownIn\n    post_body: slideDownIn\n    coll_header: slideLeftIn\n    # Only for Pisces | Gemini.\n    sidebar: slideUpIn\n\n# Fancybox\nfancybox: true\n\n# Progress bar in the top during page loading.\npace: false\n# Themes list:\n#pace-theme-big-counter\n#pace-theme-bounce\n#pace-theme-barber-shop\n#pace-theme-center-atom\n#pace-theme-center-circle\n#pace-theme-center-radar\n#pace-theme-center-simple\n#pace-theme-corner-indicator\n#pace-theme-fill-left\n#pace-theme-flash\n#pace-theme-loading-bar\n#pace-theme-mac-osx\n#pace-theme-minimal\n# For example\n# pace_theme: pace-theme-center-simple\npace_theme: pace-theme-minimal\n\n# Canvas-nest\ncanvas_nest: false\n\n# three_waves\nthree_waves: false\n\n# canvas_lines\ncanvas_lines: false\n\n# canvas_sphere\ncanvas_sphere: false\n\n# Only fit scheme Pisces\n# Canvas-ribbon\n# size: The width of the ribbon.\n# alpha: The transparency of the ribbon.\n# zIndex: The display level of the ribbon.\ncanvas_ribbon:\n  enable: false\n  size: 300\n  alpha: 0.6\n  zIndex: -1\n\n# Script Vendors.\n# Set a CDN address for the vendor you want to customize.\n# For example\n#    jquery: https://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js\n# Be aware that you should use the same version as internal ones to avoid potential problems.\n# Please use the https protocol of CDN files when you enable https on your site.\nvendors:\n  # Internal path prefix. Please do not edit it.\n  _internal: lib\n\n  # Internal version: 2.1.3\n  jquery:\n\n  # Internal version: 2.1.5\n  # See: http://fancyapps.com/fancybox/\n  fancybox:\n  fancybox_css:\n\n  # Internal version: 1.0.6\n  # See: https://github.com/ftlabs/fastclick\n  fastclick:\n\n  # Internal version: 1.9.7\n  # See: https://github.com/tuupola/jquery_lazyload\n  lazyload:\n\n  # Internal version: 1.2.1\n  # See: http://VelocityJS.org\n  velocity:\n\n  # Internal version: 1.2.1\n  # See: http://VelocityJS.org\n  velocity_ui:\n\n  # Internal version: 0.7.9\n  # See: https://faisalman.github.io/ua-parser-js/\n  ua_parser:\n\n  # Internal version: 4.6.2\n  # See: http://fontawesome.io/\n  fontawesome:\n\n  # Internal version: 1\n  # https://www.algolia.com\n  algolia_instant_js:\n  algolia_instant_css:\n\n  # Internal version: 1.0.2\n  # See: https://github.com/HubSpot/pace\n  # Or use direct links below:\n  # pace: //cdn.bootcss.com/pace/1.0.2/pace.min.js\n  # pace_css: //cdn.bootcss.com/pace/1.0.2/themes/blue/pace-theme-flash.min.css\n  pace:\n  pace_css:\n\n  # Internal version: 1.0.0\n  # https://github.com/hustcc/canvas-nest.js\n  canvas_nest:\n\n  # three\n  three:\n\n  # three_waves\n  # https://github.com/jjandxa/three_waves\n  three_waves:\n\n  # three_waves\n  # https://github.com/jjandxa/canvas_lines\n  canvas_lines:\n\n  # three_waves\n  # https://github.com/jjandxa/canvas_sphere\n  canvas_sphere:\n\n  # Internal version: 1.0.0\n  # https://github.com/zproo/canvas-ribbon\n  canvas_ribbon:\n\n  # Internal version: 3.3.0\n  # https://github.com/ethantw/Han\n  han:\n\n  # needMoreShare2\n  # https://github.com/revir/need-more-share2\n  needMoreShare2:\n\n\n# Assets\ncss: css\njs: js\nimages: images\n\n# Theme version\nversion: 5.1.4\n"
  },
  {
    "path": "bower.json",
    "content": "{\n  \"name\": \"isn-next\",\n  \"version\": \"5.1.4\",\n  \"homepage\": \"https://github.com/iissnan/hexo-theme-next\",\n  \"authors\": [\n    \"iissnan <iissnan@gmail.com>\"\n  ],\n  \"description\": \"Elegant theme for Hexo\",\n  \"repository\": \"https://github.com/iissnan/hexo-theme-next\",\n  \"keywords\": [\n    \"hexo\",\n    \"notes\",\n    \"theme\",\n    \"iissnan\",\n    \"NexT\"\n  ],\n  \"license\": \"MIT\",\n  \"ignore\": [\n    \"**/.*\",\n    \"node_modules\",\n    \"bower_components\",\n    \"source/lib\",\n    \"test\",\n    \"tests\",\n    \"screenshots\"\n  ],\n  \"dependencies\": {\n    \"fancybox\": \"~2.1.5\",\n    \"velocity\": \"~1.2.1\",\n    \"jquery\": \"http://code.jquery.com/jquery-2.1.3.min.js\",\n    \"fastclick\": \"~1.0.6\",\n    \"font-awesome\": \"fontawesome#*\",\n    \"jquery_lazyload\": \"jquery.lazyload#~1.9.7\",\n    \"ua-parser-js\": \"~0.7.9\",\n    \"Han\": \"^3.3.0\"\n  }\n}\n"
  },
  {
    "path": "gulpfile.coffee",
    "content": "fs = require('fs')\npath = require('path')\ngulp = require('gulp')\njshint = require('gulp-jshint')\nstylish = require('jshint-stylish')\nshell   = require('gulp-shell')\nyaml = require('js-yaml')\n\ngulp.task 'lint', ->\n  return gulp.src([\n    './source/js/src/utils.js',\n    './source/js/src/motion.js',\n    './source/js/src/hook-duoshuo.js',\n    './source/js/src/algolia-search.js',\n    './source/js/src/bootstrap.js',\n    './source/js/src/post-details.js',\n    './source/js/src/schemes/pisces.js'\n  ]).pipe jshint()\n    .pipe jshint.reporter(stylish)\n\ngulp.task 'lint:stylus', shell.task [\n  '\"./node_modules/.bin/stylint\" ./source/css/'\n]\n\ngulp.task 'validate:config', (cb) ->\n  themeConfig = fs.readFileSync path.join(__dirname, '_config.yml')\n\n  try\n    yaml.safeLoad(themeConfig)\n    cb()\n  catch error\n    cb new Error(error)\n\ngulp.task 'validate:languages', (cb) ->\n  languagesPath = path.join __dirname, 'languages'\n  languages = fs.readdirSync languagesPath\n  errors = []\n\n  for lang in languages\n    languagePath = path.join languagesPath, lang\n    try\n      yaml.safeLoad fs.readFileSync(languagePath), {\n        filename: path.relative(__dirname, languagePath)\n      }\n    catch error\n      errors.push error\n\n  if errors.length == 0\n    cb()\n  else\n    cb(errors)\n\n\ngulp.task 'default', ['lint', 'validate:config', 'validate:languages']\n"
  },
  {
    "path": "languages/de.yml",
    "content": "title:\n  archive: Archiv\n  category: Kategorie\n  tag: Tag\n\nauthor: Author\n\nmenu:\n  home: Startseite\n  archives: Archiv\n  categories: Kategorien\n  tags: Tags\n  about: Über\n  feed: RSS\n  search: Suche\n\nsidebar:\n  overview: Übersicht\n  toc: Inhaltsverzeichnis\n\npost:\n  created: Post created\n  sticky: Sticky\n  posted: Veröffentlicht am\n  modified: Updated at\n  in: in\n  read_more: Weiterlesen\n  untitled: Unbenannt\n  toc_empty: Dieser Artikel hat kein Inhaltsverzeichnis\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Gesamt\n  tags: tags\n\nfooter:\n  powered: \"Erstellt mit  %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: Keine Tags\n    one: Insgesamt ein Tag\n    other: \"Insgesamt %d Tags\"\n\n  categories:\n    zero: Keine Kategorien\n    one: Insgesamt eine Kategorie\n    other: \"Insgesamt %d Kategorien\"\n\n  archive_posts:\n    zero: Keine Artikel vorhanden.\n    one: Ein Artikel.\n    other: \"Insgesamt %d Artikel.\"\n\nstate:\n  posts: Artikel\n  pages: Seiten\n  tags: Tags\n  categories: Kategorien\n\ncheers:\n  um: Öhm..\n  ok: OK\n  nice: Schön\n  good: Gut\n  great: Wunderbar\n  excellent: Exzellent\n\nkeep_on: Bleib dran.\n\nsymbol:\n  comma: '. '\n  period: ', '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/default.yml",
    "content": "title:\n  archive: Archive\n  category: Category\n  tag: Tag\n  schedule: Schedule\n\nauthor: Author\n\nmenu:\n  home: Home\n  archives: Archives\n  categories: Categories\n  tags: Tags\n  about: About\n  search: Search\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\n\nsidebar:\n  overview: Overview\n  toc: Table of Contents\n\npost:\n  created: Post created\n  modified: Post modified\n  sticky: Sticky\n  posted: Posted on\n  in: In\n  more: more\n  read_more: Read more\n  untitled: Untitled\n  toc_empty: This post does not have a Table of Contents\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Totally\n  tags: tags\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: No tags\n    one: 1 tag in total\n    other: \"%d tags in total\"\n\n  categories:\n    zero: No categories\n    one: 1 category in total\n    other: \"%d categories in total\"\n\n  archive_posts:\n    zero: No posts.\n    one: 1 post.\n    other: \"%d posts in total.\"\n\nstate:\n  posts: posts\n  pages: pages\n  tags: tags\n  categories: categories\n\nsearch:\n  placeholder: Searching...\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Nice\n  good: Good\n  great: Great\n  excellent: Excellent\n\nkeep_on: Keep on posting.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/en.yml",
    "content": "title:\n  archive: Archive\n  category: Category\n  tag: Tag\n  schedule: Schedule\n\nauthor: Author\n\nmenu:\n  home: Home\n  archives: Archives\n  categories: Categories\n  tags: Tags\n  about: About\n  search: Search\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\n\nsidebar:\n  overview: Overview\n  toc: Table of Contents\n\npost:\n  created: Post created\n  modified: Post modified\n  sticky: Sticky\n  posted: Posted on\n  in: In\n  more: more\n  read_more: Read more\n  untitled: Untitled\n  toc_empty: This post does not have a Table of Contents\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Totally\n  tags: tags\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: No tags\n    one: 1 tag in total\n    other: \"%d tags in total\"\n\n  categories:\n    zero: No categories\n    one: 1 category in total\n    other: \"%d categories in total\"\n\n  archive_posts:\n    zero: No posts.\n    one: 1 post.\n    other: \"%d posts in total.\"\n\nstate:\n  posts: posts\n  pages: pages\n  tags: tags\n  categories: categories\n\nsearch:\n  placeholder: Searching...\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Nice\n  good: Good\n  great: Great\n  excellent: Excellent\n\nkeep_on: Keep on posting.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n\ngitmentbutton: Show comments from Gitment\n"
  },
  {
    "path": "languages/fr-FR.yml",
    "content": "title:\n  archive: Archive\n  category: Catégorie\n  tag: Tag\n\nauthor: Author\n\nmenu:\n  home: Accueil\n  archives: Archives\n  categories: Categories\n  tags: Tags\n  about: A propos\n  search: recherche\n\nsidebar:\n  overview: Ensemble\n  toc: Table Des Matières\n\npost:\n  sticky: Sticky\n  posted: Posté le\n  modified: Updated at\n  in: In\n  read_more: Lire la suite\n  untitled: Non titré\n  toc_empty: This post does not have a Table of Contents\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Total\n  tags: tags\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Thème\n\ncounter:\n  tag_cloud:\n    zero: Aucun tags\n    one: 1 tag au total\n    other: \"%d tags au total\"\n\n  categories:\n    zero: Aucun categories\n    one: 1 category au total\n    other: \"%d categories au total\"\n\n  archive_posts:\n    zero: Aucun article.\n    one: 1 article.\n    other: \"%d articles au total.\"\n\nstate:\n  posts: articles\n  pages: pages\n  tags: tags\n  categories: categories\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Jolie\n  good: Bien\n  great: Super\n  excellent: Excellent\n\nkeep_on: Et ca ne fait que commencer.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/id.yml",
    "content": "title:\n  archive: Arsip\n  category: Kategori\n  tag: Tag\n\nauthor: Penulis\n\nmenu:\n  home: Beranda\n  archives: Arsip\n  categories: Kategori\n  tags: Tags\n  about: Tentang\n  search: Pencarian\n\nsidebar:\n  overview: Ikhtisar\n  toc: Daftar Isi\n\npost:\n  sticky: Sticky\n  posted: Diposting di\n  modified: Updated at\n  in: Di\n  read_more: Baca lebih\n  untitled: Tidak ada title\n  toc_empty: Posting ini tidak memiliki Daftar Isi\n  visitors: Pengunjung\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Total\n  tags: tags\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Tema\n\ncounter:\n  tag_cloud:\n    zero: Tidak ada tags\n    one: 1 total tag\n    other: \"%d total tags\"\n\n  categories:\n    zero: Tidak ada kategori\n    one: 1 total categori\n    other: \"%d total kategori\"\n\n  archive_posts:\n    zero: Tidak ada posting.\n    one: 1 posting.\n    other: \"%d total posting.\"\n\nstate:\n  posts: posting\n  pages: halaman\n  tags: tags\n  categories: kategori\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Bagus\n  good: Bagus\n  great: Besar\n  excellent: Baik\n\nkeep_on: Terus Posting.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/it.yml",
    "content": "title:\n  archive: Archivio\n  category: Categoria\n  tag: Tag\n  schedule: Programma\n\nauthor: Autore\n\nmenu:\n  home: Home\n  archives: Archivi\n  categories: Categorie\n  tags: Tags\n  about: Informazioni su\n  search: Cerca\n  schedule: Programma\n  sitemap: Sitemap\n  commonweal: Commonweal 404\n\nsidebar:\n  overview: Panoramica\n  toc: Indice\n\npost:\n  created: Post creato\n  modified: Post modificato\n  sticky: Sticky\n  posted: Scritto il\n  in: In\n  more: espandi\n  read_more: Leggi di più\n  untitled: Senza titolo\n  toc_empty: Questo post non ha un indice\n  visitors: Visitatori\n  wordcount: Numero di parole nell'articolo\n  min2read: Tempo di lettura\n  totalcount: Numero totale di parole\n  copyright:\n    author: Autore\n    link: Link\n    license_title: Copyright\n    license_content: 'Tutti gli articoli in questo sito sono sotto licenza\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> salvo disposizione contraria.'\n\npage:\n  totally: Totale\n  tags: tags\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Tema\n\ncounter:\n  tag_cloud:\n    zero: Nessun tag\n    one: 1 tag in totale\n    other: \"%d tags in totale.\"\n\n  categories:\n    zero: Nessuna categoria\n    one: 1 categoria in totale\n    other: \"%d categorie in totale.\"\n\n  archive_posts:\n    zero: Nessun post.\n    one: 1 post.\n    other: \"%d posts in totale.\"\n\nstate:\n  posts: posts\n  pages: pagine\n  tags: tags\n  categories: categorie\n\nsearch:\n  placeholder: Cerca...\n\ncheers:\n  um: Mh..\n  ok: OK\n  nice: Bello\n  good: Buono\n  great: Ottimo\n  excellent: Eccellente\n\nkeep_on: Continua così.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Dona\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/ja.yml",
    "content": "title:\n  archive: アーカイブ\n  category: カテゴリ\n  tag: タグ\n\nauthor: Author\n\nmenu:\n  home: ホーム\n  archives: アーカイブ\n  categories: カテゴリ\n  tags: タグ\n  about: About\n  search: 検索\n\nsidebar:\n  overview: 概要\n  toc: 見出し\n\npost:\n  sticky: 固定\n  posted: 投稿日\n  modified: Updated at\n  in: In\n  read_more: 続きを読む\n  untitled: 無題\n  toc_empty: 見出しがありません\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: 全ページ\n  tags: タグ\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: タグなし\n    one: \"全 1 タグ\"\n    other: \"全 %d タグ\"\n\n  categories:\n    zero: カテゴリなし\n    one: \"全 1 カテゴリ\"\n    other: \"全 %d カテゴリ\"\n\n  archive_posts:\n    zero: ポストなし\n    one: \"全 1 ポスト\"\n    other: \"全 %d ポスト\"\n\nstate:\n  posts: ポスト\n  pages: ページ\n  tags: タグ\n  categories: カテゴリ\n\ncheers:\n  um: うーん\n  ok: OK\n  nice: まあまあ\n  good: いいね\n  great: すごい\n  excellent: 最高\n\nkeep_on: もっと書こう！\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/ko.yml",
    "content": "title:\n  archive: 아카이브\n  category: 카테고리\n  tag: 태그\n\nauthor: 작성자\n\nmenu:\n  home: 홈\n  archives: 아카이브\n  categories: 카테고리\n  tags: 태그\n  about: About\n  search: 검색\n\nsidebar:\n  overview: 흝어보기\n  toc: 목차\n\npost:\n  sticky: 고정\n  posted: 작성일\n  modified: Updated at\n  in: In\n  read_more: 더 읽어보기\n  untitled: 제목 없음\n  toc_empty: 목차 없음\n  visitors: 방문객\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: 모두\n  tags: 태그\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: 태그 없음\n    one: 1개의 태그\n    other: \"총 %d개의 태그\"\n\n  categories:\n    zero: 카테고리 없음\n    one: 1개의 카테고리\n    other: \"총 %d개의 카테고리\"\n\n  archive_posts:\n    zero: 포스트 없음\n    one: 1개의 포스트\n    other: \"총 %d개의 포스트\"\n\nstate:\n  posts: 포스트\n  pages: 페이지\n  tags: 태그\n  categories: 카테고리\n\ncheers:\n  um: 음..\n  ok: OK\n  nice: 잘했어요\n  good: 좋아요\n  great: 훌륭해요\n  excellent: 완벽해요\n\nkeep_on: 포스트를 마저 작성하세요\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/nl-NL.yml",
    "content": "title:\n  archive: Archief\n  category: Categorie\n  tag: Label\n  schedule: Rooster\n\nauthor: Auteur\n\nmenu:\n  home: Home\n  archives: Archieven\n  categories: Categorieën\n  tags: Labels\n  about: Over\n  search: Zoeken\n  schedule: Rooster\n  sitemap: Sitemap\n  commonweal: Gezond verstand 404\n\nsidebar:\n  overview: Overzicht\n  toc: Inhoudsopgave\n\npost:\n  created: Post aangemaakt\n  modified: Post aangepast\n  sticky: Sticky\n  posted: Geplaatst op\n  in: In\n  more: meer\n  read_more: Lees meer\n  untitled: Naamloos\n  toc_empty: Deze post heeft geen inhoudsopgave\n  visitors: Bezoekers\n  wordcount: Aantal woorden in artikel\n  min2read: Leestijd\n  totalcount: Aantal woorden in site\n  copyright:\n    author: Post auteur\n    link: Post link\n    license_title: Copyright melding\n    license_content: 'Alle artikelen op deze blog zijn gelicenseerd onder\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a>, mits niet anders aangegeven.'\n\npage:\n  totally: Totaal\n  tags: labels\n\nfooter:\n  powered: \"Mede mogelijk gemaakt door %s\"\n  theme: Thema\n\ncounter:\n  tag_cloud:\n    zero: Geen labels\n    one: 1 label in totaal\n    other: \"%d labels in totaal\"\n\n  categories:\n    zero: Geen categorieën\n    one: 1 categorie in totaal\n    other: \"%d categorieën in totaal\"\n\n  archive_posts:\n    zero: Geen posts.\n    one: 1 post.\n    other: \"%d posts in totaal.\"\n\nstate:\n  posts: posts\n  pages: pagina's\n  tags: labels\n  categories: categorieën\n\nsearch:\n  placeholder: Zoeken...\n\ncheers:\n  um: Um..\n  ok: Oké\n  nice: Leuk\n  good: Goed\n  great: Geweldig\n  excellent: Uitstekend\n\nkeep_on: Blijf posten.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Doneer\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/pt-BR.yml",
    "content": "title:\n  archive: Arquivo\n  category: Categoria\n  tag: Tag\n\nauthor: Autor\n\nmenu:\n  home: Home\n  archives: Arquivos\n  categories: Categorias\n  tags: Tags\n  about: Sobre\n  search: Pesquisar\n\nsidebar:\n  overview: Visão geral\n  toc: Tabela de conteúdo\n\npost:\n  sticky: Sticky\n  posted: Postado em\n  modified: Updated at\n  in: Em\n  read_more: Leia mais\n  untitled: Sem título\n  toc_empty: Este post não possui tabela de conteúdo\n  visitors: Visitantes\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Totalmente\n  tags: tags\n\nfooter:\n  powered: \"Feito com %s\"\n  theme: Tema\n\ncounter:\n  tag_cloud:\n    zero: Sem tags\n    one: 1 tag no total de\n    other: \"%d tags no total de\"\n\n  categories:\n    zero: Sem categoria\n    one: 1 categoria no total de\n    other: \"%d categoria no total de\"\n\n  archive_posts:\n    zero: Sem posts.\n    one: 1 post.\n    other: \"%d posts no total.\"\n\nstate:\n  posts: Posts\n  pages: Páginas\n  tags: Tags\n  categories: Categorias\n\ncheers:\n  um: Uhmmmm...\n  ok: OK\n  nice: Bom\n  good: Muito Bom\n  great: Ótimo\n  excellent: Excelente\n\nkeep_on: Continuar no post.\n\nsymbol:\n  comma: '. '\n  period: ', '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/pt.yml",
    "content": "title:\n  archive: Arquivo\n  category: Categoria\n  tag: Tag\n\nauthor: Author\n\nmenu:\n  home: Home\n  archives: Arquivos\n  categories: Categorias\n  tags: Tags\n  about: Sobre\n  search: Pesquisa\n\nsidebar:\n  overview: Visão Geral\n  toc: Tabela de Conteúdo\n\npost:\n  sticky: Sticky\n  posted: Postado em\n  modified: Updated at\n  in: Em\n  read_more: Ler mais\n  untitled: Sem título\n  toc_empty: Esta publicação não possui uma tabela de conteúdo\n  visitors: Visitors\n  wordcount: Words count in article\n  min2read: Reading time\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: Totalmente\n  tags: tags\n\nfooter:\n  powered: \"Desenvolvido com amor com %s\"\n  theme: Tema\n\ncounter:\n  tag_cloud:\n    zero: Sem tags\n    one: 1 tag no total\n    other: \"%d tags no total\"\n\n  categories:\n    zero: Sem categorias\n    one: 1 categoria no total\n    other: \"%d categorias no total\"\n\n  archive_posts:\n    zero: Sem publicações.\n    one: 1 post.\n    other: \"%d publicações no total.\"\n\nstate:\n  posts: publicações\n  pages: páginas\n  tags: tags\n  categories: categorias\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Legal\n  good: Bom\n  great: Grandioso\n  excellent: Excelente\n\nkeep_on: Mantenha-se publicando!\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/ru.yml",
    "content": "title:\n  archive: Архив\n  category: Категория\n  tag: Тэг\n  schedule: Календарь\n\nauthor: Автор\n\nmenu:\n  home: Главная\n  archives: Архив\n  categories: Категории\n  tags: Тэги\n  about: О сайте\n  search: Поиск\n  schedule: Календарь\n  sitemap: Карта сайта\n\nsidebar:\n  overview: Обзор\n  toc: Содержание\n\npost:\n  created: Дата создания записи\n  modified: Дата обновления записи\n  sticky: Ссылка\n  posted: Размещено\n  in: в категории\n  more: далее\n  read_more: Читать полностью\n  untitled: Без имени\n  toc_empty: Эта запись без оглавления\n  visitors: Просмотров\n  wordcount: Кол-во слов в статье\n  min2read: Время чтения в минутах\n  totalcount: Общее кол-во слов в записях\n  copyright:\n    author: Автор записи\n    link: Ссылка на запись\n    license_title: Информация об авторских правах\n    license_content: 'Все записи на этом сайте защищены лицензией\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> если не указано дополнительно.'\n\npage:\n  totally: Всего\n  tags: тэги\n\nfooter:\n  powered: \"Powered by %s\"\n  theme: Theme\n\ncounter:\n  tag_cloud:\n    zero: Нет тэгов.\n    one: 1 тэг.\n    two: \"%d тэга всего.\"\n    three: \"%d тэга всего.\"\n    four: \"%d тэга всего.\"\n    other: \"%d тэгов всего.\"\n\n  categories:\n    zero: Нет категорий.\n    one: 1 категория.\n    two: \"%d категории всего.\"\n    three: \"%d категории всего.\"\n    four: \"%d категории всего.\"\n    other: \"%d категорий всего.\"\n\n  archive_posts:\n    zero: Нет записей.\n    one: 1 запись.\n    two: \"%d записи всего.\"\n    three: \"%d записи всего.\"\n    four: \"%d записи всего.\"\n    other: \"%d записей всего.\"\n\nstate:\n  posts: Архив\n  pages: Страницы\n  tags: Тэги\n  categories: Категории\n\nsearch:\n  placeholder: Поиск...\n\ncheers:\n  um: Эм..\n  ok: OK\n  nice: Неплохо\n  good: Хорошо\n  great: Замечательно\n  excellent: Великолепно\n\nkeep_on: Продолжаю писать.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Донат\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n"
  },
  {
    "path": "languages/vi.yml",
    "content": "title:\n  archive: Lưu Trữ\n  category: Phân Loại\n  tag: Thẻ\n  schedule: Danh Mục\n\nauthor: Tác giả\n\nmenu:\n  home: Trang Chủ\n  archives: Lưu Trữ\n  categories: Đầu Mục\n  tags: Thẻ\n  about: Giới Thiệu\n  search: Tìm Kiếm\n  schedule: Danh Mục\n  sitemap: Bản đồ trang\n  commonweal: Commonweal 404\n\nsidebar:\n  overview: Tổng Quan\n  toc: Mục Lục\n\npost:\n  created: Được tạo\n  modified: Được thay đổi\n  sticky: Đính\n  posted: Tạo lúc\n  in: Trong\n  more: thêm\n  read_more: Đọc tiếp\n  untitled: Không có tiêu đề\n  toc_empty: Bài viết này không có mục lục\n  visitors: Người xem\n  wordcount: Số từ trong bài viết\n  min2read: Thời gian đọc\n  totalcount: Số từ trong trang\n  copyright:\n    author: Người viết\n    link: Liên kết bài viết\n    license_title: Chú ý bản quyền\n    license_content: 'Tất cả bài viết trong blog này được đăng ký bởi\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> trừ khi có thông báo bổ sung.'\n\npage:\n  totally: Toàn bộ\n  tags: thẻ\n\nfooter:\n  powered: \"Cung cấp bởi %s\"\n  theme: Giao Diện\n\ncounter:\n  tag_cloud:\n    zero: Không có thẻ nào\n    one: có 1 thẻ tất cả\n    other: \"có %d thẻ tất cả\"\n\n  categories:\n    zero: Không có trong mục nào\n    one: có 1 mục tất cả\n    other: \"có %d mục tất cả\"\n\n  archive_posts:\n    zero: Không có bài viết.\n    one: 1 bài viết.\n    other: \"tổng số %d bài viết.\"\n\nstate:\n  posts: bài viết\n  pages: trang\n  tags: thẻ\n  categories: mục\n\nsearch:\n  placeholder: Đang tìm...\n\ncheers:\n  um: Um..\n  ok: Đồng Ý\n  nice: Hay\n  good: Tốt\n  great: Tuyệt vời\n  excellent: Tuyệt cú mèo\n\nkeep_on: Giữ tiến độ nha.\n\nsymbol:\n  comma: ', '\n  period: '. '\n  colon: ':'\n\nreward:\n  donate: Tài trợ\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  bitcoin: Bitcoin\n\ngitmentbutton: Hiển thị bình luận từ Gitment\n"
  },
  {
    "path": "languages/zh-Hans.yml",
    "content": "title:\n  archive: 归档\n  category: 分类\n  tag: 标签\n  schedule: 日程表\n\nauthor: 博主\n\nmenu:\n  home: 首页\n  archives: 归档\n  categories: 分类\n  tags: 标签\n  about: 关于\n  search: 搜索\n  schedule: 日程表\n  sitemap: 站点地图\n  commonweal: 公益404\n\nsidebar:\n  overview: 站点概览\n  toc: 文章目录\n\npost:\n  created: 创建于\n  modified: 更新于\n  sticky: 置顶\n  posted: 发表于\n  in: 分类于\n  read_more: 阅读全文\n  untitled: 未命名\n  toc_empty: 此文章未包含目录\n  visitors: 阅读次数\n  wordcount: 字数统计\n  min2read: 阅读时长\n  totalcount: Site words total count\n  copyright:\n    author: 本文作者\n    link: 本文链接\n    license_title: 版权声明\n    license_content: '本博客所有文章除特别声明外，均采用\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> 许可协议。转载请注明出处！'\n\npage:\n  totally: 共有\n  tags: 标签\n\nfooter:\n  powered: \"由 %s 强力驱动\"\n  theme: 主题\n\ncounter:\n  tag_cloud:\n    zero: 暂无标签\n    one: 目前共计 1 个标签\n    other: \"目前共计 %d 个标签\"\n\n  categories:\n    zero: 暂无分类\n    one: 目前共计 1 个分类\n    other: \"目前共计 %d 个分类\"\n\n  archive_posts:\n    zero: 暂无日志。\n    one: 目前共计 1 篇日志。\n    other: \"目前共计 %d 篇日志。\"\n\nstate:\n  posts: 日志\n  pages: 页面\n  tags: 标签\n  categories: 分类\n\nsearch:\n  placeholder: 搜索...\n\ncheers:\n  um: 嗯..\n  ok: OK\n  nice: 好\n  good: 很好\n  great: 非常好\n  excellent: 太棒了\n\nkeep_on: 继续努力。\n\nsymbol:\n  comma: '， '\n  period: '。 '\n  colon: '：'\n\nreward:\n  donate: 打赏\n  wechatpay: 微信支付\n  alipay: 支付宝\n  bitcoin: 比特币\n\ngitmentbutton: 显示 Gitment 评论\n"
  },
  {
    "path": "languages/zh-hk.yml",
    "content": "title:\n  archive: 歸檔\n  category: 分類\n  tag: 標籤\n  schedule: 日程表\n\nauthor: 博主\n\nmenu:\n  home: 首頁\n  archives: 歸檔\n  categories: 分類\n  tags: 標籤\n  about: 關於\n  search: 檢索\n  schedule: 日程表\n  sitemap: 站點地圖\n  commonweal: 公益404\n\nsidebar:\n  overview: 本站概覽\n  toc: 文章目錄\n\npost:\n  created: 創建於\n  modified: 更新於\n  sticky: 置頂\n  posted: 發表於\n  in: 分類於\n  read_more: 閱讀全文\n  untitled: 未命名\n  toc_empty: 此文章未包含目錄\n  visitors: 閱讀次數\n  wordcount: 字數統計\n  min2read: 閱讀時長\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: 共有\n  tags: 標籤\n\nfooter:\n  powered: \"由 %s 強力驅動\"\n  theme: 主題\n\ncounter:\n  tag_cloud:\n    zero: 暫無標籤\n    one: 目前共有 1 個標籤\n    other: \"目前共有 %d 個標籤\"\n\n  categories:\n    zero: 暫無分類\n    one: 目前共有 1 個分類\n    other: \"目前共有 %d 個分類\"\n\n  archive_posts:\n    zero: 暫無文章。\n    one: 目前共有 1 篇文章。\n    other: \"目前共有 %d 篇文章。\"\n\nstate:\n  posts: 文章\n  pages: 頁面\n  tags: 標籤\n  categories: 分類\n\nsearch:\n  placeholder: 搜索...\n\ncheers:\n  um: 嗯..\n  ok: OK\n  nice: 好\n  good: 很好\n  great: 非常好\n  excellent: 激爆好\n\nkeep_on: 繼續努力。\n\nsymbol:\n  comma: '， '\n  period: '。 '\n  colon: '：'\n\nreward:\n  donate: 打賞\n  wechatpay: 微信支付\n  alipay: 支付寶\n  bitcoin: 比特幣\n\ngitmentbutton: 顯示 Gitment 評論\n"
  },
  {
    "path": "languages/zh-tw.yml",
    "content": "title:\n  archive: 歸檔\n  category: 分類\n  tag: 標籤\n  schedule: 日程表\n\nauthor: 博主\n\nmenu:\n  home: 首頁\n  archives: 歸檔\n  categories: 分類\n  tags: 標籤\n  about: 關於\n  search: 檢索\n  schedule: 日程表\n  sitemap: 站點地圖\n  commonweal: 公益404\n\nsidebar:\n  overview: 本站概覽\n  toc: 文章目錄\n\npost:\n  created: 創建於\n  modified: 更新於\n  sticky: 置頂\n  posted: 發表於\n  in: 分類於\n  read_more: 閱讀全文\n  untitled: 未命名\n  toc_empty: 此文章未包含目錄\n  visitors: 閱讀次數\n  wordcount: 字數統計\n  min2read: 閱讀時長\n  totalcount: Site words total count\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: 'All articles in this blog are licensed under\n      <a href=\"%s\" rel=\"external nofollow\" target=\"_blank\">%s</a> unless stating additionally.'\n\npage:\n  totally: 共有\n  tags: 標籤\n\nfooter:\n  powered: \"由 %s 強力驅動\"\n  theme: 主題\n\ncounter:\n  tag_cloud:\n    zero: 暫無標籤\n    one: 目前共計 1 個標籤\n    other: \"目前共計 %d 個標籤\"\n\n  categories:\n    zero: 暫無分類\n    one: 目前共計 1 個分類\n    other: \"目前共計 %d 個分類\"\n\n  archive_posts:\n    zero: 暫無文章。\n    one: 目前共計 1 篇文章。\n    other: \"目前共計 %d 篇文章。\"\n\nstate:\n  posts: 文章\n  pages: 頁面\n  tags: 標籤\n  categories: 分類\n\nsearch:\n  placeholder: 搜索...\n\ncheers:\n  um: 嗯..\n  ok: OK\n  nice: 好\n  good: 很好\n  great: 非常好\n  excellent: 非常屌\n\nkeep_on: 繼續努力。\n\nsymbol:\n  comma: '， '\n  period: '。 '\n  colon: '：'\n\nreward:\n  donate: 打賞\n  wechatpay: 微信支付\n  alipay: 支付寶\n  bitcoin: 比特幣\n\ngitmentbutton: 顯示 Gitment 評論\n"
  },
  {
    "path": "layout/_custom/header.swig",
    "content": "\n"
  },
  {
    "path": "layout/_custom/sidebar.swig",
    "content": "\n"
  },
  {
    "path": "layout/_layout.swig",
    "content": "<!DOCTYPE html>\n\n{% set html_class = 'theme-next ' + theme.scheme %}\n{% if theme.motion.enable %}\n  {% set html_class = html_class + ' use-motion' %}\n{% endif %}\n\n<html class=\"{{ html_class | lower }}\" lang=\"{{ config.language }}\">\n<head>\n  {% include '_partials/head.swig' %}\n  <title>{% block title %}{% endblock %}</title>\n  {% include '_third-party/analytics/index.swig' %}\n</head>\n\n<body itemscope itemtype=\"http://schema.org/WebPage\" lang=\"{{ page.lang || page.language || config.language }}\">\n\n  {% set container_class = \"container \" %}\n  {% if theme.sidebar.position %}\n    {% set container_class = container_class + 'sidebar-position-' + theme.sidebar.position %}\n  {% endif %}\n\n  <div class=\"{{ container_class }} {% block page_class %}{% endblock %}\">\n    <div class=\"headband\"></div>\n\n    <header id=\"header\" class=\"header\" itemscope itemtype=\"http://schema.org/WPHeader\">\n      <div class=\"header-inner\"> {%- include '_partials/header.swig' %} </div>\n    </header>\n\n    <main id=\"main\" class=\"main\">\n      <div class=\"main-inner\">\n        <div class=\"content-wrap\">\n          <div id=\"content\" class=\"content\">\n            {% block content %}{% endblock %}\n          </div>\n          {% include '_third-party/duoshuo-hot-articles.swig' %}\n          {% include '_partials/comments.swig' %}\n        </div>\n        {% if theme.sidebar.display !== 'remove' %}\n          {% block sidebar %}{% endblock %}\n        {% endif %}\n      </div>\n    </main>\n\n    <footer id=\"footer\" class=\"footer\">\n      <div class=\"footer-inner\">\n        {% include '_partials/footer.swig' %}\n        {% include '_third-party/analytics/analytics-with-widget.swig' %}\n        {% block footer %}{% endblock %}\n      </div>\n    </footer>\n\n    {% if not theme.sidebar.b2t %}\n      <div class=\"back-to-top\">\n        <i class=\"fa fa-arrow-up\"></i>\n        {% if theme.sidebar.scrollpercent %}\n          <span id=\"scrollpercent\"><span>0</span>%</span>\n        {% endif %}\n      </div>\n    {% endif %}\n\n    {% if theme.needmoreshare2.enable and theme.needmoreshare2.float.enable %}\n      <div id=\"needsharebutton-float\">\n        <span class=\"btn\">\n          <i class=\"fa fa-share-alt\" aria-hidden=\"true\"></i>\n        </span>\n      </div>\n    {% endif %}\n\n  </div>\n\n  {% include '_scripts/vendors.swig' %}\n  {% include '_scripts/commons.swig' %}\n\n  {% set scheme_script = '_scripts/schemes/' + theme.scheme | lower + '.swig' %}\n  {% include scheme_script %}\n\n  {% block script_extra %}{% endblock %}\n\n  {% include '_scripts/boostrap.swig' %}\n\n  {% include '_third-party/comments/index.swig' %}\n  {% include '_third-party/search/index.swig' %}\n  {% include '_third-party/analytics/lean-analytics.swig' %}\n  {% include '_third-party/analytics/firestore.swig' %}\n  {% include '_third-party/seo/baidu-push.swig' %}\n  {% include '_third-party/needsharebutton.swig' %}\n  {% include '_third-party/rating.swig' %}\n  {% include '_third-party/mathjax.swig' %}\n  {% include '_third-party/scroll-cookie.swig' %}\n  {% include '_third-party/exturl.swig' %}\n</body>\n</html>\n"
  },
  {
    "path": "layout/_macro/post-collapse.swig",
    "content": "{% macro render(post) %}\n\n  <article class=\"post post-type-{{ post.type | default('normal') }}\" itemscope itemtype=\"http://schema.org/Article\">\n    <header class=\"post-header\">\n\n      <{% if theme.seo %}h3{% else %}h2{% endif %} class=\"post-title\">\n        {% if post.link %}{# Link posts #}\n          <a class=\"post-title-link post-title-link-external\" target=\"_blank\" href=\"{{ url_for(post.link) }}\" itemprop=\"url\">\n            {{ post.title or post.link }}\n            <i class=\"fa fa-external-link\"></i>\n          </a>\n        {% else %}\n            <a class=\"post-title-link\" href=\"{{ url_for(post.path) }}\" itemprop=\"url\">\n              {% if post.type === 'picture' %}\n                {{ post.content }}\n              {% else %}\n                <span itemprop=\"name\">{{ post.title | default(__('post.untitled')) }}</span>\n              {% endif %}\n            </a>\n        {% endif %}\n      </{% if theme.seo %}h3{% else %}h2{% endif %}>\n\n      <div class=\"post-meta\">\n        <time class=\"post-time\" itemprop=\"dateCreated\"\n              datetime=\"{{ moment(post.date).format() }}\"\n              content=\"{{ date(post.date, config.date_format) }}\" >\n          {{ date(post.date, 'MM-DD') }}\n        </time>\n      </div>\n\n    </header>\n  </article>\n\n{% endmacro %}\n"
  },
  {
    "path": "layout/_macro/post-copyright.swig",
    "content": "<ul class=\"post-copyright\">\n  <li class=\"post-copyright-author\">\n    <strong>{{ __('post.copyright.author') + __('symbol.colon') }}</strong>\n    {{ post.author | default(config.author) }}\n  </li>\n  <li class=\"post-copyright-link\">\n    <strong>{{ __('post.copyright.link') + __('symbol.colon') }}</strong>\n    <a href=\"{{ post.url | default(post.permalink) }}\" title=\"{{ post.title }}\">{{ post.url | default(post.permalink) }}</a>\n  </li>\n  <li class=\"post-copyright-license\">\n    <strong>{{ __('post.copyright.license_title') + __('symbol.colon') }} </strong>\n    {{ __('post.copyright.license_content', theme.post_copyright.license_url, theme.post_copyright.license) }}\n  </li>\n</ul>\n"
  },
  {
    "path": "layout/_macro/post.swig",
    "content": "{% macro render(post, is_index, post_extra_class) %}\n\n  {% set headlessPost = Array.prototype.indexOf.call(['quote', 'picture'], post.type) > -1 %}\n\n  {% set post_class = 'post post-type-' + post.type | default('normal') %}\n  {% if post_extra_class > 0 %}\n    {% set post_class = post_class + ' ' + post_extra_class | default('') %}\n  {% endif %}\n  {% if post.sticky > 0 %}\n    {% set post_class = post_class + ' ' + 'post-sticky' %}\n  {% endif %}\n\n  <article class=\"{{ post_class }}\" itemscope itemtype=\"http://schema.org/Article\">\n  {##################}\n  {### POST BLOCK ###}\n  {##################}\n  <div class=\"post-block\">\n    <link itemprop=\"mainEntityOfPage\" href=\"{{ config.url }}{{ url_for(post.path) }}\">\n\n    <span hidden itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\">\n      <meta itemprop=\"name\" content=\"{{ theme.author }}\">\n      <meta itemprop=\"description\" content=\"{{ theme.signature }}\">\n      <meta itemprop=\"image\" content=\"{{ url_for( theme.avatar | default(theme.images + '/avatar.gif') ) }}\">\n    </span>\n\n    <span hidden itemprop=\"publisher\" itemscope itemtype=\"http://schema.org/Organization\">\n      <meta itemprop=\"name\" content=\"{{ config.title }}\">\n    </span>\n\n    {% if not headlessPost %}\n      <header class=\"post-header\">\n\n        {# Not to show title for quote posts that do not have a title #}\n        {% if not (is_index and post.type === 'quote' and not post.title) %}\n          <{% if theme.seo %}h2{% else %}h1{% endif %} class=\"post-title{% if post.direction && post.direction.toLowerCase() === 'rtl' %} rtl{% endif %}\" itemprop=\"name headline\">{#\n          #}{# Link posts #}{#\n          #}{% if post.link %}\n              {% if post.sticky > 0 %}\n                {{ post.sticky }}\n                <span class=\"post-sticky-flag\" title=\"{{ __('post.sticky') }}\">\n                  <i class=\"fa fa-thumb-tack\"></i>\n                </span>\n              {% endif %}\n              <a class=\"post-title-link post-title-link-external\" target=\"_blank\" href=\"{{ url_for(post.link) }}\" itemprop=\"url\">\n                {{ post.title or post.link }}\n                <i class=\"fa fa-external-link\"></i>\n              </a>\n            {% else %}{#\n            #}{% if is_index %}\n                {% if post.sticky > 0 %}\n                  <span class=\"post-sticky-flag\" title=\"{{ __('post.sticky') }}\">\n                    <i class=\"fa fa-thumb-tack\"></i>\n                  </span>\n                {% endif %}\n                <a class=\"post-title-link\" href=\"{{ url_for(post.path) }}\" itemprop=\"url\">{#\n                #}{{ post.title | default(__('post.untitled'))}}{#\n              #}</a>{#\n            #}{% else %}{{ post.title }}{% endif %}{#\n          #}{% endif %}{#\n        #}</{% if theme.seo %}h2{% else %}h1{% endif %}>\n        {% endif %}\n\n        <div class=\"post-meta\">\n          <span class=\"post-time\">\n            {% if theme.post_meta.created_at %}\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-calendar-o\"></i>\n              </span>\n              {% if theme.post_meta.item_text %}\n                <span class=\"post-meta-item-text\">{{ __('post.posted') }}</span>\n              {% endif %}\n              <time title=\"{{ __('post.created') }}\" itemprop=\"dateCreated datePublished\" datetime=\"{{ moment(post.date).format() }}\">\n                {{ date(post.date, config.date_format) }}\n              </time>\n            {% endif %}\n\n            {% if theme.post_meta.created_at and theme.post_meta.updated_at %}\n              <span class=\"post-meta-divider\">|</span>\n            {% endif %}\n\n            {% if theme.post_meta.updated_at %}\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-calendar-check-o\"></i>\n              </span>\n              {% if theme.post_meta.item_text %}\n                <span class=\"post-meta-item-text\">{{ __('post.modified') }}&#58;</span>\n              {% endif %}\n              <time title=\"{{ __('post.modified') }}\" itemprop=\"dateModified\" datetime=\"{{ moment(post.updated).format() }}\">\n                {{ date(post.updated, config.date_format) }}\n              </time>\n            {% endif %}\n          </span>\n\n          {% if post.categories and post.categories.length and theme.post_meta.categories %}\n            <span class=\"post-category\" >\n            {% if theme.post_meta.created_at or theme.post_meta.updated_at %}\n              <span class=\"post-meta-divider\">|</span>\n            {% endif %}\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-folder-o\"></i>\n              </span>\n              {% if theme.post_meta.item_text %}\n                <span class=\"post-meta-item-text\">{{ __('post.in') }}</span>\n              {% endif %}\n              {% for cat in post.categories %}\n                <span itemprop=\"about\" itemscope itemtype=\"http://schema.org/Thing\">\n                  <a href=\"{{ url_for(cat.path) }}\" itemprop=\"url\" rel=\"index\">\n                    <span itemprop=\"name\">{{ cat.name }}</span>\n                  </a>\n                </span>\n\n                {% set cat_length = post.categories.length %}\n                {% if cat_length > 1 and loop.index !== cat_length %}\n                  {{ __('symbol.comma') }}\n                {% endif %}\n              {% endfor %}\n            </span>\n          {% endif %}\n\n          {% if post.comments %}\n            {% if (theme.duoshuo and theme.duoshuo.shortname) or theme.duoshuo_shortname %}\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count ds-thread-count\" data-thread-key=\"{{ post.path }}\" itemprop=\"commentCount\"></span>\n                </a>\n              </span>\n            {% elseif theme.facebook_comments_plugin.enable %}\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count fb-comments-count\" data-href=\"{{ post.permalink }}\" itemprop=\"commentCount\">0</span> comments\n                </a>\n              </span>\n            {% elseif theme.disqus.enable and theme.disqus.count %}\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count disqus-comment-count\"\n                        data-disqus-identifier=\"{{ post.path }}\" itemprop=\"commentCount\"></span>\n                </a>\n              </span>\n            {% elseif theme.hypercomments_id %}\n            <!--noindex-->\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count hc-comment-count\" data-xid=\"{{ post.path }}\" itemprop=\"commentsCount\"></span>\n                </a>\n              </span>\n              <!--/noindex-->\n            {% elseif theme.changyan.enable and theme.changyan.appid and theme.changyan.appkey %}\n              <span class=\"post-comments-count\">\n              <span class=\"post-meta-divider\">|</span>\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-comment-o\"></i>\n              </span>\n              {% if is_post() %}\n                <a href=\"{{ url_for(post.path) }}#SOHUCS\" itemprop=\"discussionUrl\">\n                  <span id=\"changyan_count_unit\" class=\"post-comments-count hc-comment-count\" data-xid=\"{{ post.path }}\" itemprop=\"commentsCount\"></span>\n                </a>\n              {% else %}\n                <a href=\"{{ url_for(post.path) }}#SOHUCS\" itemprop=\"discussionUrl\">\n                  <span id=\"url::{{ post.permalink }}\" class=\"cy_cmt_count\" data-xid=\"{{ post.path }}\" itemprop=\"commentsCount\" ></span>\n                </a>\n              {% endif %}\n            {% elseif is_post() and theme.gitment.enable and theme.gitment.mint and theme.gitment.count %}\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count gitment-comments-count\" data-xid=\"{{ url_for(post.path) }}\" itemprop=\"commentsCount\"></span>\n                </a>\n              </span>\n            {% elseif theme.valine.enable and theme.valine.appid and theme.valine.appkey %}\n              <span class=\"post-comments-count\">\n                <span class=\"post-meta-divider\">|</span>\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-comment-o\"></i>\n                </span>\n                <a href=\"{{ url_for(post.path) }}#comments\" itemprop=\"discussionUrl\">\n                  <span class=\"post-comments-count valine-comment-count\" data-xid=\"{{ url_for(post.path) }}\" itemprop=\"commentCount\"></span>\n                </a>\n              </span>\n            {% endif %}\n          {% endif %}\n\n          {# LeanCould PageView #}\n          {% if theme.leancloud_visitors.enable %}\n             <span id=\"{{ url_for(post.path) }}\" class=\"leancloud_visitors\" data-flag-title=\"{{ post.title }}\">\n               <span class=\"post-meta-divider\">|</span>\n               <span class=\"post-meta-item-icon\">\n                 <i class=\"fa fa-eye\"></i>\n               </span>\n               {% if theme.post_meta.item_text %}\n                 <span class=\"post-meta-item-text\">{{__('post.visitors')}}&#58;</span>\n               {% endif %}\n                 <span class=\"leancloud-visitors-count\"></span>\n             </span>\n          {% endif %}\n\n          {% if not is_index and theme.busuanzi_count.enable and theme.busuanzi_count.page_pv %}\n            <span class=\"post-meta-divider\">|</span>\n            <span class=\"page-pv\">{{ theme.busuanzi_count.page_pv_header }}\n            <span class=\"busuanzi-value\" id=\"busuanzi_value_page_pv\" ></span>{{ theme.busuanzi_count.page_pv_footer }}\n            </span>\n          {% endif %}\n\n          {% if theme.post_wordcount.wordcount or theme.post_wordcount.min2read %}\n            <div class=\"post-wordcount\">\n              {% if theme.post_wordcount.wordcount %}\n                {% if not theme.post_wordcount.separated_meta %}\n                  <span class=\"post-meta-divider\">|</span>\n                {% endif %}\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-file-word-o\"></i>\n                </span>\n                {% if theme.post_wordcount.item_text %}\n                  <span class=\"post-meta-item-text\">{{ __('post.wordcount') }}&#58;</span>\n                {% endif %}\n                <span title=\"{{ __('post.wordcount') }}\">\n                  {{ wordcount(post.content) }}\n                </span>\n              {% endif %}\n\n              {% if theme.post_wordcount.wordcount and theme.post_wordcount.min2read %}\n                <span class=\"post-meta-divider\">|</span>\n              {% endif %}\n\n              {% if theme.post_wordcount.min2read %}\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"fa fa-clock-o\"></i>\n                </span>\n                {% if theme.post_wordcount.item_text %}\n                  <span class=\"post-meta-item-text\">{{ __('post.min2read') }} &asymp;</span>\n                {% endif %}\n                <span title=\"{{ __('post.min2read') }}\">\n                  {{ min2read(post.content) }}\n                </span>\n              {% endif %}\n            </div>\n          {% endif %}\n\n          {% if post.description and (not theme.excerpt_description or not is_index) %}\n              <div class=\"post-description\">\n                  {{ post.description }}\n              </div>\n          {% endif %}\n\n        </div>\n      </header>\n    {% endif %}\n\n    {#################}\n    {### POST BODY ###}\n    {#################}\n    <div class=\"post-body{% if theme.han %} han-init-context{% endif %}{% if post.direction && post.direction.toLowerCase() === 'rtl' %} rtl{% endif %}\" itemprop=\"articleBody\">\n\n      {# Gallery support #}\n      {% if post.photos and post.photos.length %}\n        <div class=\"post-gallery\" itemscope itemtype=\"http://schema.org/ImageGallery\">\n          {% set COLUMN_NUMBER = 3 %}\n          {% for photo in post.photos %}\n            {% if loop.index0 % COLUMN_NUMBER === 0 %}<div class=\"post-gallery-row\">{% endif %}\n              <a class=\"post-gallery-img fancybox\"\n                 href=\"{{ url_for(photo) }}\" rel=\"gallery_{{ post._id }}\"\n                 itemscope itemtype=\"http://schema.org/ImageObject\" itemprop=\"url\">\n                <img src=\"{{ url_for(photo) }}\" itemprop=\"contentUrl\"/>\n              </a>\n            {% if loop.index0 % COLUMN_NUMBER === 2 %}</div>{% endif %}\n          {% endfor %}\n\n          {# Append end tag for `post-gallery-row` when (photos size mod COLUMN_NUMBER) is less than COLUMN_NUMBER #}\n          {% if post.photos.length % COLUMN_NUMBER > 0 %}</div>{% endif %}\n        </div>\n      {% endif %}\n\n      {% if is_index %}\n        {% if post.description and theme.excerpt_description %}\n          {{ post.description }}\n          <!--noindex-->\n          <div class=\"post-button text-center\">\n            <a class=\"btn\" href=\"{{ url_for(post.path) }}\">\n              {{ __('post.read_more') }} &raquo;\n            </a>\n          </div>\n          <!--/noindex-->\n        {% elif post.excerpt  %}\n          {{ post.excerpt }}\n          <!--noindex-->\n          <div class=\"post-button text-center\">\n            <a class=\"btn\" href=\"{{ url_for(post.path) }}{% if theme.scroll_to_more %}#{{ __('post.more') }}{% endif %}\" rel=\"contents\">\n              {{ __('post.read_more') }} &raquo;\n            </a>\n          </div>\n          <!--/noindex-->\n        {% elif theme.auto_excerpt.enable %}\n          {% set content = post.content | striptags %}\n          {{ content.substring(0, theme.auto_excerpt.length) }}\n          {% if content.length > theme.auto_excerpt.length %}...{% endif %}\n          <!--noindex-->\n          <div class=\"post-button text-center\">\n            <a class=\"btn\" href=\"{{ url_for(post.path) }}{% if theme.scroll_to_more %}#{{ __('post.more') }}{% endif %}\" rel=\"contents\">\n              {{ __('post.read_more') }} &raquo;\n            </a>\n          </div>\n          <!--/noindex-->\n        {% else %}\n          {% if post.type === 'picture' %}\n            <a href=\"{{ url_for(post.path) }}\">{{ post.content }}</a>\n          {% else %}\n            {{ post.content }}\n          {% endif %}\n        {% endif %}\n      {% else %}\n        {{ post.content }}\n      {% endif  %}\n    </div>\n    {#####################}\n    {### END POST BODY ###}\n    {#####################}\n\n    {% if theme.wechat_subscriber.enabled and not is_index %}\n      <div>\n        {% include 'wechat-subscriber.swig' %}\n      </div>\n    {% endif %}\n\n    {% if (theme.alipay or theme.wechatpay or theme.bitcoin) and not is_index %}\n      <div>\n        {% include 'reward.swig' %}\n      </div>\n    {% endif %}\n\n    {% if theme.post_copyright.enable and not is_index %}\n      <div>\n        {% include 'post-copyright.swig' with { post: post } %}\n      </div>\n    {% endif %}\n\n    <footer class=\"post-footer\">\n      {% if post.tags and post.tags.length and not is_index %}\n        <div class=\"post-tags\">\n          {% for tag in post.tags %}\n            <a href=\"{{ url_for(tag.path) }}\" rel=\"tag\"># {{ tag.name }}</a>\n          {% endfor %}\n        </div>\n      {% endif %}\n\n      {% if not is_index %}\n      {% if theme.rating.enable or (theme.vkontakte_api.enable and theme.vkontakte_api.like) or (theme.facebook_sdk.enable and theme.facebook_sdk.like_button) or (theme.needmoreshare2.enable and theme.needmoreshare2.postbottom.enable) %}\n        <div class=\"post-widgets\">\n        {% if theme.rating.enable %}\n          <div class=\"wp_rating\">\n            <div id=\"wpac-rating\"></div>\n          </div>\n        {% endif %}\n\n        {% if (theme.vkontakte_api.enable and theme.vkontakte_api.like) or (theme.facebook_sdk.enable and theme.facebook_sdk.like_button) %}\n          <div class=\"social-like\">\n            {% if theme.vkontakte_api.enable and theme.vkontakte_api.like %}\n              <div class=\"vk_like\">\n                <span id=\"vk_like\"></span>\n              </div>\n            {% endif %}\n\n            {% if theme.facebook_sdk.enable and theme.facebook_sdk.like_button %}\n              <div class=\"fb_like\">\n                <div class=\"fb-like\" data-layout=\"button_count\" data-share=\"true\"></div>\n              </div>\n            {% endif %}\n          </div>\n        {% endif %}\n\n        {% if theme.needmoreshare2.enable and theme.needmoreshare2.postbottom.enable %}\n          {% if (theme.vkontakte_api.enable and theme.vkontakte_api.like) or (theme.facebook_sdk.enable and theme.facebook_sdk.like_button) %}\n            <span class=\"post-meta-divider\">|</span>\n          {% endif %}\n          <div id=\"needsharebutton-postbottom\">\n            <span class=\"btn\">\n              <i class=\"fa fa-share-alt\" aria-hidden=\"true\"></i>\n            </span>\n          </div>\n        {% endif %}\n        </div>\n      {% endif %}\n      {% endif %}\n\n      {% if not is_index and (post.prev or post.next) %}\n        <div class=\"post-nav\">\n          <div class=\"post-nav-next post-nav-item\">\n            {% if post.next %}\n              <a href=\"{{ url_for(post.next.path) }}\" rel=\"next\" title=\"{{ post.next.title }}\">\n                <i class=\"fa fa-chevron-left\"></i> {{ post.next.title }}\n              </a>\n            {% endif %}\n          </div>\n\n          <span class=\"post-nav-divider\"></span>\n\n          <div class=\"post-nav-prev post-nav-item\">\n            {% if post.prev %}\n              <a href=\"{{ url_for(post.prev.path) }}\" rel=\"prev\" title=\"{{ post.prev.title }}\">\n                {{ post.prev.title }} <i class=\"fa fa-chevron-right\"></i>\n              </a>\n            {% endif %}\n          </div>\n        </div>\n      {% endif %}\n\n      {% set isLast = loop.index % page.per_page === 0 %}\n      {% if is_index and not isLast %}\n        <div class=\"post-eof\"></div>\n      {% endif %}\n    </footer>\n  </div>\n  {######################}\n  {### END POST BLOCK ###}\n  {######################}\n  </article>\n\n{% endmacro %}\n"
  },
  {
    "path": "layout/_macro/reward.swig",
    "content": "<div style=\"padding: 10px 0; margin: 20px auto; width: 90%; text-align: center;\">\n  <div>{{ theme.reward_comment }}</div>\n  <button id=\"rewardButton\" disable=\"enable\" onclick=\"var qr = document.getElementById('QR'); if (qr.style.display === 'none') {qr.style.display='block';} else {qr.style.display='none'}\">\n    <span>{{ __('reward.donate') }}</span>\n  </button>\n  <div id=\"QR\" style=\"display: none;\">\n\n    {% if theme.wechatpay %}\n      <div id=\"wechat\" style=\"display: inline-block\">\n        <img id=\"wechat_qr\" src=\"{{ theme.wechatpay }}\" alt=\"{{ theme.author }} {{ __('reward.wechatpay') }}\"/>\n        <p>{{ __('reward.wechatpay') }}</p>\n      </div>\n    {% endif %}\n\n    {% if theme.alipay %}\n      <div id=\"alipay\" style=\"display: inline-block\">\n        <img id=\"alipay_qr\" src=\"{{ theme.alipay }}\" alt=\"{{ theme.author }} {{ __('reward.alipay') }}\"/>\n        <p>{{ __('reward.alipay') }}</p>\n      </div>\n    {% endif %}\n\n    {% if theme.bitcoin %}\n      <div id=\"bitcoin\" style=\"display: inline-block\">\n        <img id=\"bitcoin_qr\" src=\"{{ theme.bitcoin }}\" alt=\"{{ theme.author }} {{ __('reward.bitcoin') }}\"/>\n        <p>{{ __('reward.bitcoin') }}</p>\n      </div>\n    {% endif %}\n\n  </div>\n</div>\n"
  },
  {
    "path": "layout/_macro/sidebar.swig",
    "content": "{% macro render(is_post) %}\n  <div class=\"sidebar-toggle\">\n    <div class=\"sidebar-toggle-line-wrap\">\n      <span class=\"sidebar-toggle-line sidebar-toggle-line-first\"></span>\n      <span class=\"sidebar-toggle-line sidebar-toggle-line-middle\"></span>\n      <span class=\"sidebar-toggle-line sidebar-toggle-line-last\"></span>\n    </div>\n  </div>\n\n  <aside id=\"sidebar\" class=\"sidebar\">\n    {% if theme.sidebar.onmobile %}\n      <div id=\"sidebar-dimmer\"></div>\n    {% endif %}\n    <div class=\"sidebar-inner\">\n\n      {% set display_toc = is_post and theme.toc.enable or is_page and theme.toc.enable %}\n\n      {% if display_toc and toc(page.content).length > 1 %}\n        <ul class=\"sidebar-nav motion-element\">\n          <li class=\"sidebar-nav-toc sidebar-nav-active\" data-target=\"post-toc-wrap\">\n            {{ __('sidebar.toc') }}\n          </li>\n          <li class=\"sidebar-nav-overview\" data-target=\"site-overview-wrap\">\n            {{ __('sidebar.overview') }}\n          </li>\n        </ul>\n      {% endif %}\n\n      <section class=\"site-overview-wrap sidebar-panel{% if not display_toc or toc(page.content).length <= 1 %} sidebar-panel-active{% endif %}\">\n        <div class=\"site-overview\">\n          <div class=\"site-author motion-element\" itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\">\n            {% if theme.avatar %}\n              <img class=\"site-author-image\" itemprop=\"image\"\n                src=\"{{ url_for( theme.avatar | default(theme.images + '/avatar.gif') ) }}\"\n                alt=\"{{ theme.author }}\" />\n            {% endif %}\n              <p class=\"site-author-name\" itemprop=\"name\">{{ theme.author }}</p>\n              <p class=\"site-description motion-element\" itemprop=\"description\">{#\n            #}{% if theme.seo %}{#\n              #}{{ theme.signature }}{#\n            #}{% else %}{#\n              #}{{ theme.description }}{#\n            #}{% endif %}{#\n            #}</p>\n          </div>\n\n          <nav class=\"site-state motion-element\">\n\n            {% if config.archive_dir != '/' and site.posts.length > 0 %}\n              <div class=\"site-state-item site-state-posts\">\n              {% if theme.menu.archives %}\n                <a href=\"{{ url_for(theme.menu.archives).split('||')[0] | trim }}\">\n              {% else %}\n                <a href=\"{{ url_for(config.archive_dir) }}\">\n              {% endif %}\n                  <span class=\"site-state-item-count\">{{ site.posts.length }}</span>\n                  <span class=\"site-state-item-name\">{{ __('state.posts') }}</span>\n                </a>\n              </div>\n            {% endif %}\n\n            {% if site.categories.length > 0 %}\n              {% set categoriesPageQuery = site.pages.find({type: 'categories'}, {lean: true}) %}\n              {% set hasCategoriesPage = categoriesPageQuery.length > 0 %}\n              <div class=\"site-state-item site-state-categories\">\n                {% if hasCategoriesPage %}<a href=\"{{ url_for(categoriesPageQuery[0].path) }}\">{% endif %}\n                  <span class=\"site-state-item-count\">{{ site.categories.length }}</span>\n                  <span class=\"site-state-item-name\">{{ __('state.categories') }}</span>\n                {% if hasCategoriesPage %}</a>{% endif %}\n              </div>\n            {% endif %}\n\n            {% if site.tags.length > 0 %}\n              {% set tagsPageQuery = site.pages.find({type: 'tags'}, {lean: true}) %}\n              {% set hasTagsPage = tagsPageQuery.length > 0 %}\n              <div class=\"site-state-item site-state-tags\">\n                {% if hasTagsPage %}<a href=\"{{ url_for(tagsPageQuery[0].path) }}\">{% endif %}\n                  <span class=\"site-state-item-count\">{{ site.tags.length }}</span>\n                  <span class=\"site-state-item-name\">{{ __('state.tags') }}</span>\n                {% if hasTagsPage %}</a>{% endif %}\n              </div>\n            {% endif %}\n\n          </nav>\n\n          {% if theme.rss %}\n            <div class=\"feed-link motion-element\">\n              <a href=\"{{ url_for(theme.rss) }}\" rel=\"alternate\">\n                <i class=\"fa fa-rss\"></i>\n                RSS\n              </a>\n            </div>\n          {% endif %}\n\n          {% if theme.social %}\n            <div class=\"links-of-author motion-element\">\n                {% for name, link in theme.social %}\n                  <span class=\"links-of-author-item\">\n                    <a href=\"{{ link.split('||')[0] | trim }}\" target=\"_blank\" title=\"{{ name }}\">\n                      {% if theme.social_icons.enable %}\n                        <i class=\"fa fa-fw fa-{{ link.split('||')[1] | trim | default('globe') }}\"></i>{#\n                    #}{% endif %}{#\n                      #}{% if not theme.social_icons.icons_only %}{#\n                        #}{{ name }}{#\n                      #}{% endif %}{#\n                  #}</a>\n                  </span>\n                {% endfor %}\n            </div>\n          {% endif %}\n\n          {% set cc = {'by': 1, 'by-nc': 1, 'by-nc-nd': 1, 'by-nc-sa': 1, 'by-nd': 1, 'by-sa': 1, 'zero': 1} %}\n          {% if theme.creative_commons in cc %}\n            <div class=\"cc-license motion-element\" itemprop=\"license\">\n              <a href=\"https://creativecommons.org/{% if theme.creative_commons === 'zero' %}publicdomain/zero/1.0{% else %}licenses/{{ theme.creative_commons }}/4.0{% endif %}/\" class=\"cc-opacity\" target=\"_blank\">\n                <img src=\"{{ url_for(theme.images) }}/cc-{{ theme.creative_commons }}.svg\" alt=\"Creative Commons\" />\n              </a>\n            </div>\n          {% endif %}\n\n          {# Blogroll #}\n          {% if theme.links %}\n            <div class=\"links-of-blogroll motion-element {{ \"links-of-blogroll-\" + theme.links_layout | default('inline') }}\">\n              <div class=\"links-of-blogroll-title\">\n                <i class=\"fa  fa-fw fa-{{ theme.links_icon | default('globe') | lower }}\"></i>\n                {{ theme.links_title }}\n              </div>\n              <ul class=\"links-of-blogroll-list\">\n                {% for name, link in theme.links %}\n                  <li class=\"links-of-blogroll-item\">\n                    <a href=\"{{ link }}\" title=\"{{ name }}\" target=\"_blank\">{{ name }}</a>\n                  </li>\n                {% endfor %}\n              </ul>\n            </div>\n          {% endif %}\n\n          {% include '../_custom/sidebar.swig' %}\n        </div>\n      </section>\n\n      {% if display_toc and toc(page.content).length > 1 %}\n      <!--noindex-->\n        <section class=\"post-toc-wrap motion-element sidebar-panel sidebar-panel-active\">\n          <div class=\"post-toc\">\n\n            {% if page.toc_number === undefined %}\n              {% set toc = toc(page.content, { \"class\": \"nav\", list_number: theme.toc.number }) %}\n            {% else %}\n              {% set toc = toc(page.content, { \"class\": \"nav\", list_number: page.toc_number }) %}\n            {% endif %}\n\n            {% if toc.length <= 1 %}\n              <p class=\"post-toc-empty\">{{ __('post.toc_empty') }}</p>\n            {% else %}\n              <div class=\"post-toc-content\">{{ toc }}</div>\n            {% endif %}\n\n          </div>\n        </section>\n      <!--/noindex-->\n      {% endif %}\n\n      {% if theme.sidebar.b2t %}\n        <div class=\"back-to-top\">\n          <i class=\"fa fa-arrow-up\"></i>\n          {% if theme.sidebar.scrollpercent %}\n            <span id=\"scrollpercent\"><span>0</span>%</span>\n          {% endif %}\n        </div>\n      {% endif %}\n\n    </div>\n  </aside>\n{% endmacro %}\n"
  },
  {
    "path": "layout/_macro/wechat-subscriber.swig",
    "content": "<div id=\"wechat_subscriber\" style=\"display: block; padding: 10px 0; margin: 20px auto; width: 100%; text-align: center\">\n    <img id=\"wechat_subscriber_qcode\" src=\"{{ theme.wechat_subscriber.qcode }}\" alt=\"{{ theme.author }} wechat\" style=\"width: 200px; max-width: 100%;\"/>\n    <div>{{ theme.wechat_subscriber.description }}</div>\n</div>\n"
  },
  {
    "path": "layout/_partials/comments.swig",
    "content": "{% if page.comments %}\n\n  {% if (theme.duoshuo and theme.duoshuo.shortname) or theme.duoshuo_shortname %}\n    <div class=\"comments\" id=\"comments\">\n      <div class=\"ds-thread\" data-thread-key=\"{{ page.path }}\"\n           data-title=\"{{ page.title }}\" data-url=\"{{ page.permalink }}\">\n      </div>\n    </div>\n\n  {% elseif theme.facebook_sdk.enable and theme.facebook_comments_plugin.enable %}\n    <div class=\"comments\" id=\"comments\">\n      <div class=\"fb-comments\"\n           data-href=\"{{ page.permalink }}\"\n           data-numposts=\"{{ theme.facebook_comments_plugin.num_of_posts }}\"\n           data-width=\"{{ theme.facebook_comments_plugin.width }}\"\n           data-colorscheme=\"{{ theme.facebook_comments_plugin.scheme }}\">\n      </div>\n    </div>\n\n  {% elseif theme.vkontakte_api.enable and theme.vkontakte_api.comments %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"vk_comments\"></div>\n    </div>\n\n  {% elseif theme.disqus.enable %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"disqus_thread\">\n        <noscript>\n          Please enable JavaScript to view the\n          <a href=\"https://disqus.com/?ref_noscript\">comments powered by Disqus.</a>\n        </noscript>\n      </div>\n    </div>\n\n  {% elseif theme.hypercomments_id %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"hypercomments_widget\"></div>\n    </div>\n\n  {% elseif theme.youyan_uid %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"uyan_frame\"></div>\n    </div>\n\n  {% elseif theme.livere_uid %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"lv-container\" data-id=\"city\" data-uid=\"{{ theme.livere_uid }}\"></div>\n    </div>\n\n  {% elseif theme.changyan.appid and theme.changyan.appkey %}\n    <div class=\"comments\" id=\"comments\">\n      <div id=\"SOHUCS\"></div>\n    </div>\n\n  {% elseif theme.gitment.enable %}\n    <div class=\"comments\" id=\"comments\">\n      {% if theme.gitment.lazy %}\n        <div onclick=\"showGitment()\" id=\"gitment-display-button\">{{ __('gitmentbutton') }}</div>\n        <div id=\"gitment-container\" style=\"display:none\"></div>\n      {% else %}\n        <div id=\"gitment-container\"></div>\n      {% endif %}\n    </div>\n\n  {% elseif theme.valine.appid and theme.valine.appkey %}\n    <div class=\"comments\" id=\"comments\">\n    </div>\n  {% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_partials/footer.swig",
    "content": "<div class=\"copyright\">{#\n#}{% set current = date(Date.now(), \"YYYY\") %}{#\n#}&copy; {% if theme.footer.since and theme.footer.since != current %}{{ theme.footer.since }} &mdash; {% endif %}{#\n#}<span itemprop=\"copyrightYear\">{{ current }}</span>\n  <span class=\"with-love\">\n    <i class=\"fa fa-{{ theme.footer.icon }}\"></i>\n  </span>\n  <span class=\"author\" itemprop=\"copyrightHolder\">{{ theme.footer.copyright || config.author }}</span>\n\n  {% if theme.post_wordcount.totalcount %}\n    <span class=\"post-meta-divider\">|</span>\n    <span class=\"post-meta-item-icon\">\n      <i class=\"fa fa-area-chart\"></i>\n    </span>\n    {% if theme.post_wordcount.item_text %}\n      <span class=\"post-meta-item-text\">{{ __('post.totalcount') }}&#58;</span>\n    {% endif %}\n    <span title=\"{{ __('post.totalcount') }}\">{#\n    #}{{ totalcount(site, '0,0.0a') }}{#\n  #}</span>\n  {% endif %}\n</div>\n\n{% if theme.footer.powered %}\n  <div class=\"powered-by\">{#\n  #}{{ __('footer.powered', '<a class=\"theme-link\" target=\"_blank\" href=\"https://hexo.io\">Hexo</a>') }}{#\n#}</div>\n{% endif %}\n\n{% if theme.footer.powered and theme.footer.theme.enable %}\n  <span class=\"post-meta-divider\">|</span>\n{% endif %}\n\n{% if theme.footer.theme.enable %}\n  <div class=\"theme-info\">{#\n  #}{{ __('footer.theme') }} &mdash; {#\n  #}<a class=\"theme-link\" target=\"_blank\" href=\"https://github.com/iissnan/hexo-theme-next\">{#\n    #}NexT.{{ theme.scheme }}{#\n  #}</a>{% if theme.footer.theme.version %} v{{ theme.version }}{% endif %}{#\n#}</div>\n{% endif %}\n\n{% if theme.footer.custom_text %}\n  <div class=\"footer-custom\">{#\n  #}{{ theme.footer.custom_text }}{#\n#}</div>\n{% endif %}\n"
  },
  {
    "path": "layout/_partials/head/custom-head.swig",
    "content": "{#\nCustom head.\n#}\n"
  },
  {
    "path": "layout/_partials/head/external-fonts.swig",
    "content": "{% if theme.font.enable %}\n\n  {% set font_config = theme.font %}\n  {% set font_families = '' %}\n  {% set font_styles = ':300,300italic,400,400italic,700,700italic' %}\n  {% set font_found = false %}\n\n  {% if font_config.global.family and font_config.global.external %}\n    {% set font_families += font_config.global.family + font_styles %}\n    {% set font_found = true %}\n  {% endif %}\n\n  {% if font_config.headings.family and font_config.headings.external %}\n    {% if font_found %}\n      {% set font_families += '|' %}\n    {% endif %}\n\n    {% set font_families += font_config.headings.family + font_styles %}\n  {% endif %}\n\n  {% if font_config.posts.family and font_config.posts.external %}\n    {% if font_found %}\n      {% set font_families += '|' %}\n    {% endif %}\n\n    {% set font_families += font_config.posts.family + font_styles %}\n  {% endif %}\n\n  {% if font_config.logo.family and font_config.logo.external %}\n    {% if font_found %}\n      {% set font_families += '|' %}\n    {% endif %}\n\n    {% set font_families += font_config.logo.family + font_styles %}\n  {% endif %}\n\n  {% if font_config.codes.family and font_config.codes.external %}\n    {% if font_found %}\n      {% set font_families += '|' %}\n    {% endif %}\n\n    {% set font_families += font_config.codes.family + font_styles %}\n  {% endif %}\n\n  {% if font_families !== '' %}\n    {% set font_families += '&subset=latin,latin-ext' %}\n    {% set font_host = font_config.host | default('//fonts.googleapis.com') %}\n    <link href=\"{{ font_host }}/css?family={{ font_families }}\" rel=\"stylesheet\" type=\"text/css\">\n  {% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_partials/head.swig",
    "content": "<meta charset=\"UTF-8\"/>\n<meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\" />\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1, maximum-scale=1\"/>\n<meta name=\"theme-color\" content=\"{{ theme.android_chrome_color }}\">\n\n\n{% if theme.pace %}\n  {% set pace_css_uri = url_for(theme.vendors._internal + '/pace/'+ theme.pace_theme +'.min.css?v=1.0.2') %}\n  {% set pace_js_uri = url_for(theme.vendors._internal + '/pace/pace.min.js?v=1.0.2') %}\n    {% if theme.vendors.pace %}\n      {% set pace_js_uri = theme.vendors.pace %}\n    {% endif %}\n    {% if theme.vendors.pace_css %}\n      {% set pace_css_uri = theme.vendors.pace_css %}\n    {% endif %}\n  <script src=\"{{ pace_js_uri }}\"></script>\n  <link href=\"{{ pace_css_uri }}\" rel=\"stylesheet\">\n{% endif %}\n\n\n{% if theme.han %}\n  {% set Han_uri = url_for(theme.vendors._internal + '/Han/dist/han.min.css?v=3.3') %}\n  {% if theme.vendors.Han %}\n    {% set Han_uri = theme.vendors.Han %}\n  {% endif %}\n  <link rel=\"stylesheet\" media=\"all\" href=\"{{ Han_uri }}\">\n{% endif %}\n\n\n{# #238, Disable Baidu tranformation #}\n<meta http-equiv=\"Cache-Control\" content=\"no-transform\" />\n<meta http-equiv=\"Cache-Control\" content=\"no-siteapp\" />\n\n\n{% if theme.google_site_verification %}\n  <meta name=\"google-site-verification\" content=\"{{ theme.google_site_verification }}\" />\n{% endif %}\n\n{% if theme.bing_site_verification %}\n  <meta name=\"msvalidate.01\" content=\"{{ theme.bing_site_verification }}\" />\n{% endif %}\n\n{% if theme.yandex_site_verification %}\n  <meta name=\"yandex-verification\" content=\"{{ theme.yandex_site_verification }}\" />\n{% endif %}\n\n\n{% if theme.baidu_site_verification %}\n  <meta name=\"baidu-site-verification\" content=\"{{ theme.baidu_site_verification }}\" />\n{% endif %}\n\n\n{% if theme.qihu_site_verification %}\n  <meta name=\"360-site-verification\" content=\"{{ theme.qihu_site_verification }}\" />\n{% endif %}\n\n\n{% if theme.fancybox %}\n  {% set fancybox_css_uri = url_for(theme.vendors._internal + '/fancybox/source/jquery.fancybox.css?v=2.1.5') %}\n  {% if theme.vendors.fancybox_css %}\n    {% set fancybox_css_uri = theme.vendors.fancybox_css %}\n  {% endif %}\n  <link href=\"{{ fancybox_css_uri }}\" rel=\"stylesheet\" type=\"text/css\" />\n{% endif %}\n\n{% include \"./head/external-fonts.swig\" %}\n\n{% set font_awesome_uri = url_for(theme.vendors._internal + '/font-awesome/css/font-awesome.min.css?v=4.6.2') %}\n{% if theme.vendors.fontawesome %}\n  {% set font_awesome_uri = theme.vendors.fontawesome %}\n{% endif %}\n<link href=\"{{ font_awesome_uri }}\" rel=\"stylesheet\" type=\"text/css\" />\n\n<link href=\"{{ url_for(theme.css) }}/main.css?v={{ theme.version }}\" rel=\"stylesheet\" type=\"text/css\" />\n\n{% if theme.favicon.apple_touch_icon %}\n  <link rel=\"apple-touch-icon\" sizes=\"180x180\" href=\"{{ url_for(theme.favicon.apple_touch_icon) }}?v={{ theme.version }}\">\n{% endif %}\n{% if theme.favicon.medium %}\n  <link rel=\"icon\" type=\"image/png\" sizes=\"32x32\" href=\"{{ url_for(theme.favicon.medium) }}?v={{ theme.version }}\">\n{% endif %}\n{% if theme.favicon.small %}\n  <link rel=\"icon\" type=\"image/png\" sizes=\"16x16\" href=\"{{ url_for(theme.favicon.small) }}?v={{ theme.version }}\">\n{% endif %}\n{% if theme.favicon.safari_pinned_tab %}\n  <link rel=\"mask-icon\" href=\"{{ url_for(theme.favicon.safari_pinned_tab) }}?v={{ theme.version }}\" color=\"{{ theme.android_chrome_color }}\">\n{% endif %}\n{% if theme.favicon.android_manifest %}\n  <link rel=\"manifest\" href=\"{{ url_for(theme.favicon.android_manifest) }}\">\n{% endif %}\n{% if theme.favicon.ms_browserconfig %}\n  <meta name=\"msapplication-config\" content=\"{{ url_for(theme.favicon.ms_browserconfig) }}\" />\n{% endif %}\n\n{% if page.keywords %}\n  <meta name=\"keywords\" content=\"{{ page.keywords }}\" />\n{% elif page.tags and page.tags.length %}\n  <meta name=\"keywords\" content=\"{% for tag in page.tags %}{{ tag.name }},{% endfor %}\" />\n{% elif theme.keywords %}\n  <meta name=\"keywords\" content=\"{{ theme.keywords }}\" />\n{% endif %}\n\n\n{% if theme.rss === '' and config.feed and config.feed.path %}\n  {% set theme.rss = config.feed.path %}\n{% endif %}\n{% if theme.rss %}\n  <link rel=\"alternate\" href=\"{{ url_for(theme.rss) }}\" title=\"{{ config.title }}\" type=\"application/atom+xml\" />\n{% endif %}\n\n\n{% if theme.facebook_sdk.enable and theme.facebook_sdk.webmaster %}\n  <meta property=\"fb:admins\" content=\"{{ theme.facebook_sdk.fb_admin }}\" />\n  <meta property=\"fb:app_id\" content=\"{{ theme.facebook_sdk.app_id }}\" />\n{% endif %}\n\n\n{{\n  open_graph({\n    twitter_id: theme.twitter,\n    google_plus: theme.google_plus,\n    fb_admins: theme.fb_admins,\n    fb_app_id: theme.fb_app_id\n  })\n}}\n\n\n{# Export some HEXO Configurations to Front-End #}\n<script type=\"text/javascript\" id=\"hexo.configurations\">\n  var NexT = window.NexT || {};\n  var CONFIG = {\n    root: '{{ theme.root }}',\n    scheme: '{{ theme.scheme }}',\n    version: '{{ theme.version }}',\n    sidebar: {{ theme.sidebar | json_encode }},\n    fancybox: {{ theme.fancybox }},\n    tabs: {{ theme.tabs.enable }},\n    motion: {{ theme.motion | json_encode }},\n    duoshuo: {\n      userId: '{{ theme.duoshuo_info.user_id | default() }}',\n      author: '{{ theme.duoshuo_info.admin_nickname | default(__('author'))}}'\n    },\n    algolia: {\n      applicationID: '{{ theme.algolia.applicationID }}',\n      apiKey: '{{ theme.algolia.apiKey }}',\n      indexName: '{{ theme.algolia.indexName }}',\n      hits: {{ theme.algolia_search.hits | json_encode }},\n      labels: {{ theme.algolia_search.labels | json_encode }}\n    }\n  };\n</script>\n\n{# Canonical, good for google search engine (SEO) : https://support.google.com/webmasters/answer/139066 #}\n{% if theme.canonical %}\n  <link rel=\"canonical\" href=\"{{ config.url }}/{{ page.canonical_path.replace('index.html', '') }}\"/>\n{% endif %}\n\n{% include 'head/custom-head.swig' %}\n"
  },
  {
    "path": "layout/_partials/header.swig",
    "content": "<div class=\"site-brand-wrapper\">\n  <div class=\"site-meta {% if theme.custom_logo.enabled %}custom-logo{% endif %}\">\n    {% if theme.custom_logo.image and theme.scheme === 'Muse' %}\n      <div class=\"site-meta-headline\">\n        <a>\n          <img class=\"custom-logo-image\" src=\"{{ theme.custom_logo.image }}\"\n               alt=\"{{ config.title }}\"/>\n        </a>\n      </div>\n    {% endif %}\n\n    <div class=\"custom-logo-site-title\">\n      <a href=\"{{ config.root }}\"  class=\"brand\" rel=\"start\">\n        <span class=\"logo-line-before\"><i></i></span>\n        <span class=\"site-title\">{{ config.title }}</span>\n        <span class=\"logo-line-after\"><i></i></span>\n      </a>\n    </div>\n      {% if theme.seo %}\n        <h1 class=\"site-subtitle\" itemprop=\"description\">{{ config.subtitle }}</h1>\n      {% else %}\n        <p class=\"site-subtitle\">{{ config.subtitle }}</p>\n      {% endif %}\n  </div>\n\n  <div class=\"site-nav-toggle\">\n    <button>\n      <span class=\"btn-bar\"></span>\n      <span class=\"btn-bar\"></span>\n      <span class=\"btn-bar\"></span>\n    </button>\n  </div>\n</div>\n\n<nav class=\"site-nav\">\n  {% set hasSearch = theme.swiftype_key || theme.algolia_search.enable || theme.tinysou_Key || theme.local_search.enable %}\n\n  {% if theme.menu %}\n    <ul id=\"menu\" class=\"menu\">\n      {% for name, path in theme.menu %}\n        {% set itemName = name.toLowerCase() %}\n        <li class=\"menu-item menu-item-{{ itemName | replace(' ', '-') }}\">\n          <a href=\"{{ url_for(path.split('||')[0]) | trim }}\" rel=\"section\">\n            {% if theme.menu_icons.enable %}\n              <i class=\"menu-item-icon fa fa-fw fa-{{ path.split('||')[1] | trim | default('question-circle') }}\"></i> <br />\n            {% endif %}\n            {{ __('menu.' + name) | replace('menu.', '') }}\n          </a>\n        </li>\n      {% endfor %}\n\n      {% if hasSearch %}\n        <li class=\"menu-item menu-item-search\">\n          {% if theme.swiftype_key %}\n            <a href=\"javascript:;\" class=\"st-search-show-outputs\">\n          {% elseif theme.local_search.enable || theme.algolia_search.enable %}\n            <a href=\"javascript:;\" class=\"popup-trigger\">\n          {% endif %}\n            {% if theme.menu_icons.enable %}\n              <i class=\"menu-item-icon fa fa-search fa-fw\"></i> <br />\n            {% endif %}\n            {{ __('menu.search') }}\n          </a>\n        </li>\n      {% endif %}\n    </ul>\n  {% endif %}\n\n  {% if hasSearch %}\n    <div class=\"site-search\">\n      {% include 'search.swig' %}\n    </div>\n  {% endif %}\n</nav>\n\n{% include '../_custom/header.swig' %}\n"
  },
  {
    "path": "layout/_partials/page-header.swig",
    "content": "<header class=\"post-header\">\n\n\t<{% if theme.seo %}h2{% else %}h1{% endif %} class=\"post-title\" itemprop=\"name headline\">{{ page.title }}</{% if theme.seo %}h2{% else %}h1{% endif %}>\n\n{% if page.description %}\n\t<div class=\"post-meta\">\n\t\t<div class=\"post-description\">{{ page.description }}</div>\n\t</div>\n{% endif %}\n\n</header>\n"
  },
  {
    "path": "layout/_partials/pagination.swig",
    "content": "{% if page.prev or page.next %}\n  <nav class=\"pagination\">\n    {{\n      paginator({\n        prev_text: '<i class=\"fa fa-angle-left\"></i>',\n        next_text: '<i class=\"fa fa-angle-right\"></i>',\n        mid_size: 1\n      })\n    }}\n  </nav>\n{% endif %}\n"
  },
  {
    "path": "layout/_partials/search/localsearch.swig",
    "content": "<div class=\"popup search-popup local-search-popup\">\n  <div class=\"local-search-header clearfix\">\n    <span class=\"search-icon\">\n      <i class=\"fa fa-search\"></i>\n    </span>\n    <span class=\"popup-btn-close\">\n      <i class=\"fa fa-times-circle\"></i>\n    </span>\n    <div class=\"local-search-input-wrapper\">\n      <input autocomplete=\"off\"\n             placeholder=\"{{ __('search.placeholder') }}\" spellcheck=\"false\"\n             type=\"text\" id=\"local-search-input\">\n    </div>\n  </div>\n  <div id=\"local-search-result\"></div>\n</div>\n"
  },
  {
    "path": "layout/_partials/search/swiftype.swig",
    "content": "<form class=\"site-search-form\">\n  <input type=\"text\" id=\"st-search-input\" class=\"st-search-input st-default-search-input\" />\n</form>\n\n<script type=\"text/javascript\">\n  (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){\n    (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);\n    e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);\n  })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');\n\n  _st('install', '{{ theme.swiftype_key }}','2.0.0');\n</script>\n"
  },
  {
    "path": "layout/_partials/search/tinysou.swig",
    "content": "<form class=\"site-search-form\" >\n  <input type=\"text\" id=\"ts-search-input\" class=\"menu-search-input\">\n</form>\n"
  },
  {
    "path": "layout/_partials/search.swig",
    "content": "{% if theme.algolia_search.enable %}\n  {% include '../_third-party/search/algolia-search/dom.swig' %}\n{% elseif theme.swiftype_key %}\n  {% include 'search/swiftype.swig' %}\n{% elseif theme.tinysou_Key %}\n  {% include 'search/tinysou.swig' %}\n{% elseif theme.local_search.enable %}\n  {% include 'search/localsearch.swig' %}\n{% endif %}\n"
  },
  {
    "path": "layout/_partials/share/add-this.swig",
    "content": "<!-- Go to www.addthis.com/dashboard to customize your tools -->\n<div class=\"addthis_inline_share_toolbox\">\n  <script type = \"text/javascript\" src = \"//s7.addthis.com/js/300/addthis_widget.js#pubid={{ theme.add_this_id }}\" async = \"async\" ></script>\n</div>\n"
  },
  {
    "path": "layout/_partials/share/baidushare.swig",
    "content": "{% if theme.baidushare.type === \"button\" %}\n  <div class=\"bdsharebuttonbox\">\n    <a href=\"#\" class=\"bds_tsina\" data-cmd=\"tsina\" title=\"分享到新浪微博\"></a>\n    <a href=\"#\" class=\"bds_douban\" data-cmd=\"douban\" title=\"分享到豆瓣网\"></a>\n    <a href=\"#\" class=\"bds_sqq\" data-cmd=\"sqq\" title=\"分享到QQ好友\"></a>\n    <a href=\"#\" class=\"bds_qzone\" data-cmd=\"qzone\" title=\"分享到QQ空间\"></a>\n    <a href=\"#\" class=\"bds_weixin\" data-cmd=\"weixin\" title=\"分享到微信\"></a>\n    <a href=\"#\" class=\"bds_tieba\" data-cmd=\"tieba\" title=\"分享到百度贴吧\"></a>\n    <a href=\"#\" class=\"bds_twi\" data-cmd=\"twi\" title=\"分享到Twitter\"></a>\n    <a href=\"#\" class=\"bds_fbook\" data-cmd=\"fbook\" title=\"分享到Facebook\"></a>\n    <a href=\"#\" class=\"bds_more\" data-cmd=\"more\"></a>\n    <a class=\"bds_count\" data-cmd=\"count\"></a>\n  </div>\n  <script>\n    window._bd_share_config = {\n      \"common\": {\n        \"bdText\": \"\",\n        \"bdMini\": \"2\",\n        \"bdMiniList\": false,\n        \"bdPic\": \"\"\n      },\n      \"share\": {\n        \"bdSize\": \"16\",\n        \"bdStyle\": \"0\"\n      },\n      \"image\": {\n        \"viewList\": [\"tsina\", \"douban\", \"sqq\", \"qzone\", \"weixin\", \"twi\", \"fbook\"],\n        \"viewText\": \"分享到：\",\n        \"viewSize\": \"16\"\n      }\n    }\n  </script>\n{% elseif theme.baidushare.type === \"slide\" %}\n  <script>\n    window._bd_share_config = {\n      \"common\": {\n        \"bdText\": \"\",\n        \"bdMini\": \"1\",\n        \"bdMiniList\": false,\n        \"bdPic\": \"\"\n      },\n      \"image\": {\n        \"viewList\": [\"tsina\", \"douban\", \"sqq\", \"qzone\", \"weixin\", \"twi\", \"fbook\"],\n        \"viewText\": \"分享到：\",\n        \"viewSize\": \"16\"\n      },\n      \"slide\": {\n        \"bdImg\": \"5\",\n        \"bdPos\": \"left\",\n        \"bdTop\": \"100\"\n      }\n    }\n  </script>\n{% endif %}\n<script>\n  with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='//bdimg.share.baidu.com/static/api/js/share.js?cdnversion='+~(-new Date()/36e5)];\n</script>\n"
  },
  {
    "path": "layout/_partials/share/duoshuo_share.swig",
    "content": "<div class=\"ds-share flat\" data-thread-key=\"{{ page.path }}\"\n     data-title=\"{{ page.title }}\"\n     data-content=\"\"\n     data-url=\"{{ page.permalink }}\">\n  <div class=\"ds-share-inline\">\n    <ul  class=\"ds-share-icons-16\">\n\n      <li data-toggle=\"ds-share-icons-more\"><a class=\"ds-more\" href=\"javascript:void(0);\">分享到：</a></li>\n      <li><a class=\"ds-weibo\" href=\"javascript:void(0);\" data-service=\"weibo\">微博</a></li>\n      <li><a class=\"ds-qzone\" href=\"javascript:void(0);\" data-service=\"qzone\">QQ空间</a></li>\n      <li><a class=\"ds-qqt\" href=\"javascript:void(0);\" data-service=\"qqt\">腾讯微博</a></li>\n      <li><a class=\"ds-wechat\" href=\"javascript:void(0);\" data-service=\"wechat\">微信</a></li>\n\n    </ul>\n    <div class=\"ds-share-icons-more\">\n    </div>\n  </div>\n</div>"
  },
  {
    "path": "layout/_partials/share/jiathis.swig",
    "content": "<!-- JiaThis Button BEGIN -->\n<div class=\"jiathis_style\">\n<span class=\"jiathis_txt\">分享到：</span>\n<a class=\"jiathis_button_fav\">收藏夹</a>\n<a class=\"jiathis_button_copy\">复制网址</a>\n<a class=\"jiathis_button_email\">邮件</a>\n<a class=\"jiathis_button_weixin\">微信</a>\n<a class=\"jiathis_button_qzone\">QQ空间</a>\n<a class=\"jiathis_button_tqq\">腾讯微博</a>\n<a class=\"jiathis_button_douban\">豆瓣</a>\n<a class=\"jiathis_button_share\">一键分享</a>\n\n<a href=\"http://www.jiathis.com/share?uid=2140465\" class=\"jiathis jiathis_txt jiathis_separator jtico jtico_jiathis\" target=\"_blank\">更多</a>\n<a class=\"jiathis_counter_style\"></a>\n</div>\n<script type=\"text/javascript\" >\nvar jiathis_config={\n  data_track_clickback:true,\n  summary:\"\",\n  shortUrl:false,\n  hideMore:false\n}\n</script>\n<script type=\"text/javascript\" src=\"http://v3.jiathis.com/code/jia.js?uid={{ theme.jiathis.uid }}\" charset=\"utf-8\"></script>\n<!-- JiaThis Button END -->"
  },
  {
    "path": "layout/_scripts/boostrap.swig",
    "content": "{%\n  set boot_scripts = [\n    'src/bootstrap.js'\n  ]\n%}\n\n{% for bs in boot_scripts %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/{{ bs }}?v={{ theme.version }}\"></script>\n{% endfor %}\n"
  },
  {
    "path": "layout/_scripts/commons.swig",
    "content": "{%\n  set js_commons = [\n    'src/utils.js',\n    'src/motion.js'\n  ]\n%}\n\n{% for common in js_commons %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/{{ common }}?v={{ theme.version }}\"></script>\n{% endfor %}\n"
  },
  {
    "path": "layout/_scripts/pages/post-details.swig",
    "content": "<script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/src/scrollspy.js?v={{ theme.version }}\"></script>\n<script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/src/post-details.js?v={{ theme.version }}\"></script>\n"
  },
  {
    "path": "layout/_scripts/schemes/gemini.swig",
    "content": "{%\n  set scripts = [\n    'src/affix.js',\n    'src/schemes/pisces.js'\n  ]\n%}\n\n{% for script in scripts %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/{{ script }}?v={{ theme.version }}\"></script>\n{% endfor %}\n"
  },
  {
    "path": "layout/_scripts/schemes/mist.swig",
    "content": ""
  },
  {
    "path": "layout/_scripts/schemes/muse.swig",
    "content": ""
  },
  {
    "path": "layout/_scripts/schemes/pisces.swig",
    "content": "{%\n  set scripts = [\n    'src/affix.js',\n    'src/schemes/pisces.js'\n  ]\n%}\n\n{% for script in scripts %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/{{ script }}?v={{ theme.version }}\"></script>\n{% endfor %}\n"
  },
  {
    "path": "layout/_scripts/vendors.swig",
    "content": "{# Reset `window.Promise` when it was not a function. #}\n{# IE refers the element whose id is `Promise` as `window.Promise`, this causes Velocity throwing an exception #}\n<script type=\"text/javascript\">\n  if (Object.prototype.toString.call(window.Promise) !== '[object Function]') {\n    window.Promise = null;\n  }\n</script>\n\n{% set js_vendors = {} %}\n{% set js_vendors.jquery      = 'jquery/index.js?v=2.1.3' %}\n{% set js_vendors.fastclick   = 'fastclick/lib/fastclick.min.js?v=1.0.6' %}\n{% set js_vendors.lazyload    = 'jquery_lazyload/jquery.lazyload.js?v=1.9.7' %}\n{% set js_vendors.velocity    = 'velocity/velocity.min.js?v=1.2.1' %}\n{% set js_vendors.velocity_ui = 'velocity/velocity.ui.min.js?v=1.2.1' %}\n\n{% if theme.fancybox %}\n  {% set js_vendors.fancybox  = 'fancybox/source/jquery.fancybox.pack.js?v=2.1.5' %}\n{% endif %}\n{% if theme.canvas_nest %}\n  {% set js_vendors.canvas_nest  = 'canvas-nest/canvas-nest.min.js' %}\n{% endif %}\n\n{% if theme.three_waves %}\n  {% set js_vendors.three  = 'three/three.min.js' %}\n  {% set js_vendors.three_waves  = 'three/three-waves.min.js' %}\n{% endif %}\n\n{% if theme.canvas_lines %}\n  {% set js_vendors.three  = 'three/three.min.js' %}\n  {% set js_vendors.canvas_lines  = 'three/canvas_lines.min.js' %}\n{% endif %}\n\n{% if theme.canvas_sphere %}\n  {% set js_vendors.three  = 'three/three.min.js' %}\n  {% set js_vendors.canvas_sphere  = 'three/canvas_sphere.min.js' %}\n{% endif %}\n\n{% if theme.canvas_ribbon.enable and theme.scheme === 'Pisces'%}\n  {% set js_vendors.canvas_ribbon  = 'canvas-ribbon/canvas-ribbon.js' %}\n{% endif %}\n\n{% for name, internal in js_vendors %}\n  {% set internal_script = url_for(theme.vendors._internal) + '/' + internal %}\n  {% if name == 'canvas_ribbon' %}\n    <script id=\"ribbon\" type=\"text/javascript\" size=\"{{ theme.canvas_ribbon.size }}\" alpha=\"{{ theme.canvas_ribbon.alpha }}\"  zIndex=\"{{theme.canvas_ribbon.zIndex }}\" src=\"{{ theme.vendors[name] | default(internal_script) }}\"></script>\n  {% else %}\n    <script type=\"text/javascript\" src=\"{{ theme.vendors[name] | default(internal_script) }}\"></script>\n  {% endif %}\n{% endfor %}\n"
  },
  {
    "path": "layout/_third-party/analytics/analytics-with-widget.swig",
    "content": "{% include 'busuanzi-counter.swig' %}\n{% include 'tencent-mta.swig' %}\n{% include 'tencent-analytics.swig' %}\n{% include 'cnzz-analytics.swig' %}"
  },
  {
    "path": "layout/_third-party/analytics/application-insights.swig",
    "content": "{% if theme.application_insights %}\n<script type=\"text/javascript\">\n  var appInsights=window.appInsights||function(config){\n    function i(config){t[config]=function(){var i=arguments;t.queue.push(function(){t[config].apply(t,i)})}}var t={config:config},u=document,e=window,o=\"script\",s=\"AuthenticatedUserContext\",h=\"start\",c=\"stop\",l=\"Track\",a=l+\"Event\",v=l+\"Page\",y=u.createElement(o),r,f;y.src=config.url||\"https://az416426.vo.msecnd.net/scripts/a/ai.0.js\";u.getElementsByTagName(o)[0].parentNode.appendChild(y);try{t.cookie=u.cookie}catch(p){}for(t.queue=[],t.version=\"1.0\",r=[\"Event\",\"Exception\",\"Metric\",\"PageView\",\"Trace\",\"Dependency\"];r.length;)i(\"track\"+r.pop());return i(\"set\"+s),i(\"clear\"+s),i(h+a),i(c+a),i(h+v),i(c+v),i(\"flush\"),config.disableExceptionTracking||(r=\"onerror\",i(\"_\"+r),f=e[r],e[r]=function(config,i,u,e,o){var s=f&&f(config,i,u,e,o);return s!==!0&&t[\"_\"+r](config,i,u,e,o),s}),t\n    }({\n        instrumentationKey:\"{{ theme.application_insights }}\"\n    });\n    window.appInsights=appInsights;\n    appInsights.trackPageView();\n</script>\n{% endif %}"
  },
  {
    "path": "layout/_third-party/analytics/baidu-analytics.swig",
    "content": "{% if theme.baidu_analytics %}\n  <script type=\"text/javascript\">\n    var _hmt = _hmt || [];\n    (function() {\n      var hm = document.createElement(\"script\");\n      hm.src = \"https://hm.baidu.com/hm.js?{{ theme.baidu_analytics }}\";\n      var s = document.getElementsByTagName(\"script\")[0];\n      s.parentNode.insertBefore(hm, s);\n    })();\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/busuanzi-counter.swig",
    "content": "{% if theme.busuanzi_count.enable %}\n<div class=\"busuanzi-count\">\n  <script async src=\"https://dn-lbstatics.qbox.me/busuanzi/2.3/busuanzi.pure.mini.js\"></script>\n\n  {% if theme.busuanzi_count.site_uv %}\n    <span class=\"site-uv\">\n      {{ theme.busuanzi_count.site_uv_header }}\n      <span class=\"busuanzi-value\" id=\"busuanzi_value_site_uv\"></span>\n      {{ theme.busuanzi_count.site_uv_footer }}\n    </span>\n  {% endif %}\n\n  {% if theme.busuanzi_count.site_pv %}\n    <span class=\"site-pv\">\n      {{ theme.busuanzi_count.site_pv_header }}\n      <span class=\"busuanzi-value\" id=\"busuanzi_value_site_pv\"></span>\n      {{ theme.busuanzi_count.site_pv_footer }}\n    </span>\n  {% endif %}\n</div>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/cnzz-analytics.swig",
    "content": "{% if theme.cnzz_siteid %}\n\n  <div style=\"display: none;\">\n    <script src=\"//s95.cnzz.com/z_stat.php?id={{ theme.cnzz_siteid }}&web_id={{ theme.cnzz_siteid }}\" language=\"JavaScript\"></script>\n  </div>\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/facebook-sdk.swig",
    "content": "{% if theme.facebook_sdk.enable %}\n<script>\n  window.fbAsyncInit = function() {\n    FB.init({\n      appId      : '{{ theme.facebook_sdk.app_id }}',\n      xfbml      : true,\n      version    : 'v2.10'\n    });\n  };\n\n  (function(d, s, id){\n     var js, fjs = d.getElementsByTagName(s)[0];\n     if (d.getElementById(id)) {return;}\n     js = d.createElement(s); js.id = id;\n     js.src = \"//connect.facebook.net/{{ config.language|replace('-', '_') }}/sdk.js\";\n     fjs.parentNode.insertBefore(js, fjs);\n   }(document, 'script', 'facebook-jssdk'));\n</script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/firestore.swig",
    "content": "{% if theme.firestore.enable %}\n  <script src=\"https://www.gstatic.com/firebasejs/4.6.0/firebase.js\"></script>\n  <script src=\"https://www.gstatic.com/firebasejs/4.6.0/firebase-firestore.js\"></script>\n  {% if theme.firestore.bluebird %}\n    <script src=\"https://cdnjs.cloudflare.com/ajax/libs/bluebird/3.5.1/bluebird.core.min.js\"></script>\n  {% endif %}\n  <script>\n    (function () {\n\n      firebase.initializeApp({\n        apiKey: '{{ theme.firestore.apiKey }}',\n        projectId: '{{ theme.firestore.projectId }}'\n      })\n\n      function getCount(doc, increaseCount) {\n        //increaseCount will be false when not in article page\n\n        return doc.get().then(function (d) {\n          var count\n          if (!d.exists) { //has no data, initialize count\n            if (increaseCount) {\n              doc.set({\n                count: 1\n              })\n              count = 1\n            }\n            else {\n              count = 0\n            }\n          }\n          else { //has data\n            count = d.data().count\n            if (increaseCount) {\n              if (!(window.localStorage && window.localStorage.getItem(title))) { //if first view this article\n                doc.set({ //increase count\n                  count: count + 1\n                })\n                count++\n              }\n            }\n          }\n          if (window.localStorage && increaseCount) { //mark as visited\n            localStorage.setItem(title, true)\n          }\n\n          return count\n        })\n      }\n\n      function appendCountTo(el) {\n        return function (count) {\n          $(el).append(\n            $('<span>').addClass('post-visitors-count').append(\n              $('<span>').addClass('post-meta-divider').text('|')\n            ).append(\n              $('<span>').addClass('post-meta-item-icon').append(\n                $('<i>').addClass('fa fa-users')\n              )\n              ).append($('<span>').text('{{ __(\"post.visitors\")}} ' + count))\n          )\n        }\n      }\n\n      var db = firebase.firestore()\n      var articles = db.collection('{{ theme.firestore.collection }}')\n\n      //https://hexo.io/zh-tw/docs/variables.html\n      var isPost = '{{ page.title }}'.length > 0\n      var isArchive = '{{ archive }}' === 'true'\n      var isCategory = '{{ category }}'.length > 0\n      var isTag = '{{ tag }}'.length > 0\n\n      if (isPost) { //is article page\n        var title = '{{ page.title }}'\n        var doc = articles.doc(title)\n\n        getCount(doc, true).then(appendCountTo($('.post-meta')))\n      }\n      else if (!isArchive && !isCategory && !isTag) { //is index page\n        var titles = [] //array to titles\n\n        var postsstr = '{% for post in page.posts %}titles.push(\"{{ post.title }}\");{% endfor %}' //if you have a better way to get titles of posts, please change it\n        eval(postsstr)\n\n        var promises = titles.map(function (title) {\n          return articles.doc(title)\n        }).map(function (doc) {\n          return getCount(doc)\n        })\n        Promise.all(promises).then(function (counts) {\n          var metas = $('.post-meta')\n          counts.forEach(function (val, idx) {\n            appendCountTo(metas[idx])(val)\n          })\n        })\n      }\n    })()\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/google-analytics.swig",
    "content": "{% if theme.google_analytics %}\n<script>\n  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){\n            (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),\n          m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)\n  })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');\n  ga('create', '{{ theme.google_analytics }}', 'auto');\n  ga('send', 'pageview');\n</script>\n{% endif %}"
  },
  {
    "path": "layout/_third-party/analytics/index.swig",
    "content": "{% include 'facebook-sdk.swig' %}\n{% include 'vkontakte-api.swig' %}\n{% include 'google-analytics.swig' %}\n{% include 'baidu-analytics.swig' %}\n{% include 'application-insights.swig' %}\n"
  },
  {
    "path": "layout/_third-party/analytics/lean-analytics.swig",
    "content": "{% if theme.leancloud_visitors.enable %}\n\n  {# custom analytics part create by xiamo #}\n  <script src=\"https://cdn1.lncld.net/static/js/av-core-mini-0.6.4.js\"></script>\n  <script>AV.initialize(\"{{theme.leancloud_visitors.app_id}}\", \"{{theme.leancloud_visitors.app_key}}\");</script>\n  <script>\n    function showTime(Counter) {\n      var query = new AV.Query(Counter);\n      var entries = [];\n      var $visitors = $(\".leancloud_visitors\");\n\n      $visitors.each(function () {\n        entries.push( $(this).attr(\"id\").trim() );\n      });\n\n      query.containedIn('url', entries);\n      query.find()\n        .done(function (results) {\n          var COUNT_CONTAINER_REF = '.leancloud-visitors-count';\n\n          if (results.length === 0) {\n            $visitors.find(COUNT_CONTAINER_REF).text(0);\n            return;\n          }\n\n          for (var i = 0; i < results.length; i++) {\n            var item = results[i];\n            var url = item.get('url');\n            var time = item.get('time');\n            var element = document.getElementById(url);\n\n            $(element).find(COUNT_CONTAINER_REF).text(time);\n          }\n          for(var i = 0; i < entries.length; i++) {\n            var url = entries[i];\n            var element = document.getElementById(url);\n            var countSpan = $(element).find(COUNT_CONTAINER_REF);\n            if( countSpan.text() == '') {\n              countSpan.text(0);\n            }\n          }\n        })\n        .fail(function (object, error) {\n          console.log(\"Error: \" + error.code + \" \" + error.message);\n        });\n    }\n\n    function addCount(Counter) {\n      var $visitors = $(\".leancloud_visitors\");\n      var url = $visitors.attr('id').trim();\n      var title = $visitors.attr('data-flag-title').trim();\n      var query = new AV.Query(Counter);\n\n      query.equalTo(\"url\", url);\n      query.find({\n        success: function(results) {\n          if (results.length > 0) {\n            var counter = results[0];\n            counter.fetchWhenSave(true);\n            counter.increment(\"time\");\n            counter.save(null, {\n              success: function(counter) {\n                var $element = $(document.getElementById(url));\n                $element.find('.leancloud-visitors-count').text(counter.get('time'));\n              },\n              error: function(counter, error) {\n                console.log('Failed to save Visitor num, with error message: ' + error.message);\n              }\n            });\n          } else {\n            var newcounter = new Counter();\n            /* Set ACL */\n            var acl = new AV.ACL();\n            acl.setPublicReadAccess(true);\n            acl.setPublicWriteAccess(true);\n            newcounter.setACL(acl);\n            /* End Set ACL */\n            newcounter.set(\"title\", title);\n            newcounter.set(\"url\", url);\n            newcounter.set(\"time\", 1);\n            newcounter.save(null, {\n              success: function(newcounter) {\n                var $element = $(document.getElementById(url));\n                $element.find('.leancloud-visitors-count').text(newcounter.get('time'));\n              },\n              error: function(newcounter, error) {\n                console.log('Failed to create');\n              }\n            });\n          }\n        },\n        error: function(error) {\n          console.log('Error:' + error.code + \" \" + error.message);\n        }\n      });\n    }\n\n    $(function() {\n      var Counter = AV.Object.extend(\"Counter\");\n      if ($('.leancloud_visitors').length == 1) {\n        addCount(Counter);\n      } else if ($('.post-title-link').length > 1) {\n        showTime(Counter);\n      }\n    });\n  </script>\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/tencent-analytics.swig",
    "content": "{% if theme.tencent_analytics %}\n  <script type=\"text/javascript\">\n    (function() {\n      var hm = document.createElement(\"script\");\n      hm.src = \"//tajs.qq.com/stats?sId={{ theme.tencent_analytics }}\";\n      var s = document.getElementsByTagName(\"script\")[0];\n      s.parentNode.insertBefore(hm, s);\n    })();\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/tencent-mta.swig",
    "content": "{% if theme.tencent_mta %}\n<script>\n  \tvar _mtac = {};\n  \t(function() {\n  \t\tvar mta = document.createElement(\"script\");\n  \t\tmta.src = \"https://pingjs.qq.com/h5/stats.js?v2.0.4\";\n  \t\tmta.setAttribute(\"name\", \"MTAH5\");\n  \t\tmta.setAttribute(\"sid\", \"{{theme.tencent_mta}}\");\n\n  \t\tvar s = document.getElementsByTagName(\"script\")[0];\n  \t\ts.parentNode.insertBefore(mta, s);\n  \t})();\n</script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/vkontakte-api.swig",
    "content": "{% if theme.vkontakte_api.enable %}\n\n\t<div id=\"vk_api_transport\"></div>\n\t<script type=\"text/javascript\">\n\t\twindow.vkAsyncInit = function() {\n\t\t\tVK.init({\n\t\t\t\tapiId: {{ theme.vkontakte_api.app_id }}\n\t\t\t});\n\n\t\t\t{% if not is_home() and (is_post() and theme.vkontakte_api.like) %}\n\t\t\t\tVK.Widgets.Like(\"vk_like\", {type: \"mini\", height: 20});\n\t\t\t{% endif %}\n\n\t\t\t{% if page.comments and theme.vkontakte_api.comments %}\n\t\t\t\tVK.Widgets.Comments(\"vk_comments\", {limit: {{  theme.vkontakte_api.num_of_posts }}, attach: \"*\"});\n\t\t\t{% endif %}\n\t\t};\n\t\tsetTimeout(function() {\n\t\t\tvar el = document.createElement(\"script\");\n\t\t\tel.type = \"text/javascript\";\n\t\t\tel.src = \"//vk.com/js/api/openapi.js\";\n\t\t\tel.async = true;\n\t\t\tdocument.getElementById(\"vk_api_transport\").appendChild(el);\n\t\t}, 0);\n\t</script>\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/changyan.swig",
    "content": "{% if theme.changyan.enable and theme.changyan.appid and theme.changyan.appkey %}\n  {% if is_home() %}\n    <script id=\"cy_cmt_num\" src=\"https://changyan.sohu.com/upload/plugins/plugins.list.count.js?clientId={{theme.changyan.appid}}\"></script>\n  {% else %}\n    <script type=\"text/javascript\">\n    (function(){\n      var appid = '{{theme.changyan.appid}}';\n      var conf = '{{theme.changyan.appkey}}';\n      var width = window.innerWidth || document.documentElement.clientWidth;\n      if (width < 960) {\n      window.document.write('<script id=\"changyan_mobile_js\" charset=\"utf-8\" type=\"text/javascript\" src=\"https://changyan.sohu.com/upload/mobile/wap-js/changyan_mobile.js?client_id=' + appid + '&conf=' + conf + '\"><\\/script>'); } else { var loadJs=function(d,a){var c=document.getElementsByTagName(\"head\")[0]||document.head||document.documentElement;var b=document.createElement(\"script\");b.setAttribute(\"type\",\"text/javascript\");b.setAttribute(\"charset\",\"UTF-8\");b.setAttribute(\"src\",d);if(typeof a===\"function\"){if(window.attachEvent){b.onreadystatechange=function(){var e=b.readyState;if(e===\"loaded\"||e===\"complete\"){b.onreadystatechange=null;a()}}}else{b.onload=a}}c.appendChild(b)};loadJs(\"https://changyan.sohu.com/upload/changyan.js\",function(){\n        window.changyan.api.config({appid:appid,conf:conf})});\n      }\n    })();\n    </script>\n    <script type=\"text/javascript\" src=\"https://assets.changyan.sohu.com/upload/plugins/plugins.count.js\"></script>\n  {% endif %}\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/disqus.swig",
    "content": "{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname %}\n  {% if theme.disqus.enable %}\n\n    {% if theme.disqus.count  %}\n      <script id=\"dsq-count-scr\" src=\"https://{{theme.disqus.shortname}}.disqus.com/count.js\" async></script>\n    {% endif %}\n\n    {% if page.comments %}\n      <script type=\"text/javascript\">\n        var disqus_config = function () {\n          this.page.url = '{{ page.permalink }}';\n          this.page.identifier = '{{ page.path }}';\n          this.page.title = '{{ page.title| addslashes }}';\n        };\n        var d = document, s = d.createElement('script');\n        s.src = 'https://{{theme.disqus.shortname}}.disqus.com/embed.js';\n        s.setAttribute('data-timestamp', '' + +new Date());\n        (d.head || d.body).appendChild(s);\n      </script>\n    {% endif %}\n\n  {% endif %}\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/duoshuo.swig",
    "content": "{% if (theme.duoshuo and theme.duoshuo.shortname) or theme.duoshuo_shortname %}\n\n  {% if theme.duoshuo %}\n    {% set duoshuo_shortname = theme.duoshuo.shortname %}\n  {% else %}\n    {% set duoshuo_shortname = theme.duoshuo_shortname %}\n  {% endif %}\n\n  <script type=\"text/javascript\">\n    var duoshuoQuery = {short_name:\"{{duoshuo_shortname}}\"};\n    (function() {\n      var ds = document.createElement('script');\n      ds.type = 'text/javascript';ds.async = true;\n      ds.id = 'duoshuo-script';\n      ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js';\n      ds.charset = 'UTF-8';\n      (document.getElementsByTagName('head')[0]\n      || document.getElementsByTagName('body')[0]).appendChild(ds);\n    })();\n  </script>\n\n  {% if theme.duoshuo_info.ua_enable %}\n    {% if theme.duoshuo_info.admin_enable %}\n      {% set ua_parser_internal = url_for(theme.vendors._internal) + '/ua-parser-js/dist/ua-parser.min.js?v=0.7.9' %}\n      <script src=\"{{ theme.vendors.ua_parser | default(ua_parser_internal) }}\"></script>\n      <script src=\"{{ url_for(theme.js) }}/src/hook-duoshuo.js?v={{ theme.version }}\"></script>\n    {% endif %}\n    {% set ua_parser_internal = url_for(theme.vendors._internal) + '/ua-parser-js/dist/ua-parser.min.js?v=0.7.9' %}\n    <script src=\"{{ theme.vendors.ua_parser | default(ua_parser_internal) }}\"></script>\n    <script src=\"{{ url_for(theme.js) }}/src/hook-duoshuo.js\"></script>\n  {% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/gitment.swig",
    "content": "{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname %}\n{% if theme.gitment.enable and theme.gitment.client_id %}\n<!-- LOCAL: You can save these files to your site and update links -->\n    {% if theme.gitment.mint %}\n        {% set CommentsClass = \"Gitmint\" %}\n        <link rel=\"stylesheet\" href=\"https://aimingoo.github.io/gitmint/style/default.css\">\n        <script src=\"https://aimingoo.github.io/gitmint/dist/gitmint.browser.js\"></script>\n    {% else %}\n        {% set CommentsClass = \"Gitment\" %}\n        <link rel=\"stylesheet\" href=\"https://imsun.github.io/gitment/style/default.css\">\n        <script src=\"https://imsun.github.io/gitment/dist/gitment.browser.js\"></script>\n    {% endif %}\n<!-- END LOCAL -->\n\n    {% if theme.gitment.cleanly %}\n      <style>\n        a.gitment-editor-footer-tip { display: none; }\n        .gitment-container.gitment-footer-container { display: none; }\n      </style>\n    {% endif %}\n\n    {% if page.comments %}\n      <script type=\"text/javascript\">\n      function renderGitment(){\n        var gitment = new {{CommentsClass}}({\n            id: window.location.pathname, \n            owner: '{{ theme.gitment.github_user }}',\n            repo: '{{ theme.gitment.github_repo }}',\n            {% if theme.gitment.mint %}\n            lang: \"{{ theme.gitment.language }}\" || navigator.language || navigator.systemLanguage || navigator.userLanguage,\n            {% endif %}\n            oauth: {\n            {% if theme.gitment.mint and theme.gitment.redirect_protocol %}\n                redirect_protocol: '{{ theme.gitment.redirect_protocol }}',\n            {% endif %}\n            {% if theme.gitment.mint and theme.gitment.proxy_gateway %}\n                proxy_gateway: '{{ theme.gitment.proxy_gateway }}',\n            {% else %}\n                client_secret: '{{ theme.gitment.client_secret }}',\n            {% endif %}\n                client_id: '{{ theme.gitment.client_id }}'\n            }});\n        gitment.render('gitment-container');\n      }\n\n      {% if not theme.gitment.lazy %}\n      renderGitment();\n      {% else %}\n      function showGitment(){\n        document.getElementById(\"gitment-display-button\").style.display = \"none\";\n        document.getElementById(\"gitment-container\").style.display = \"block\";\n        renderGitment();\n      }\n      {% endif %}\n      </script>\n    {% endif %}\n\n{% endif %}\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/hypercomments.swig",
    "content": "{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname and not theme.disqus_shortname %}\n\n\t{% if theme.hypercomments_id %}\n\n\t\t<script type=\"text/javascript\">\n\t\t_hcwp = window._hcwp || [];\n\n\t\t_hcwp.push({widget:\"Bloggerstream\", widget_id: {{ theme.hypercomments_id }}, selector:\".hc-comment-count\", label: \"{\\%COUNT%\\}\" });\n\n\t\t{% if page.comments %}\n\t\t_hcwp.push({widget:\"Stream\", widget_id: {{ theme.hypercomments_id }}, xid: \"{{ page.path }}\"});\n\t\t{% endif %}\n\n\t\t(function() {\n\t\tif(\"HC_LOAD_INIT\" in window)return;\n\t\tHC_LOAD_INIT = true;\n\t\tvar lang = (navigator.language || navigator.systemLanguage || navigator.userLanguage || \"en\").substr(0, 2).toLowerCase();\n\t\tvar hcc = document.createElement(\"script\"); hcc.type = \"text/javascript\"; hcc.async = true;\n\t\thcc.src = (\"https:\" == document.location.protocol ? \"https\" : \"http\")+\"://w.hypercomments.com/widget/hc/{{ theme.hypercomments_id }}/\"+lang+\"/widget.js\";\n\t\tvar s = document.getElementsByTagName(\"script\")[0];\n\t\ts.parentNode.insertBefore(hcc, s.nextSibling);\n\t\t})();\n\t\t</script>\n\n\t{% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/index.swig",
    "content": "{% include 'duoshuo.swig' %}\n{% include 'disqus.swig' %}\n{% include 'hypercomments.swig' %}\n{% include 'youyan.swig' %}\n{% include 'livere.swig' %}\n{% include 'changyan.swig' %}\n{% include 'gitment.swig' %}\n{% include 'valine.swig' %}\n"
  },
  {
    "path": "layout/_third-party/comments/livere.swig",
    "content": "{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname and not (theme.disqus.enable and theme.disqus.shortname) and not theme.hypercomments_id %}\n\n  {% if page.comments and theme.livere_uid %}\n    <script type=\"text/javascript\">\n      (function(d, s) {\n        var j, e = d.getElementsByTagName(s)[0];\n        if (typeof LivereTower === 'function') { return; }\n        j = d.createElement(s);\n        j.src = 'https://cdn-city.livere.com/js/embed.dist.js';\n        j.async = true;\n        e.parentNode.insertBefore(j, e);\n      })(document, 'script');\n    </script>\n  {% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/valine.swig",
    "content": "{% if theme.valine.enable and theme.valine.appid and theme.valine.appkey %}\n  <script src=\"//cdn1.lncld.net/static/js/3.0.4/av-min.js\"></script>\n  <script src=\"//unpkg.com/valine/dist/Valine.min.js\"></script>\n  \n  <script type=\"text/javascript\">\n    var GUEST = ['nick','mail','link'];\n    var guest = '{{ theme.valine.guest_info }}';\n    guest = guest.split(',').filter(item=>{\n      return GUEST.indexOf(item)>-1;\n    });\n    new Valine({\n        el: '#comments' ,\n        verify: {{ theme.valine.verify }},\n        notify: {{ theme.valine.notify }},\n        appId: '{{ theme.valine.appid }}',\n        appKey: '{{ theme.valine.appkey }}',\n        placeholder: '{{ theme.valine.placeholder }}',\n        avatar:'{{ theme.valine.avatar }}',\n        guest_info:guest,\n        pageSize:'{{ theme.valine.pageSize }}' || 10,\n    });\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/youyan.swig",
    "content": "{% if not (theme.duoshuo and theme.duoshuo.shortname)\n  and not theme.duoshuo_shortname\n  and not theme.disqus_shortname\n  and not theme.hypercomments_id %}\n\n  {% if theme.youyan_uid %}\n    {% set uid = theme.youyan_uid %}\n\n    {% if page.comments %}\n      <!-- UY BEGIN -->\n      <script type=\"text/javascript\" src=\"http://v2.uyan.cc/code/uyan.js?uid={{uid}}\"></script>\n      <!-- UY END -->\n    {% endif %}\n  {% endif %}\n\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/duoshuo-hot-articles.swig",
    "content": "{# 多说热评文章 #}\n{% if (theme.duoshuo_hotartical and page.title) %}\n  <p>热评文章</p>\n  <div class=\"ds-top-threads\" data-range=\"weekly\" data-num-items=\"4\"></div>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/exturl.swig",
    "content": "{% if theme.exturl %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/src/exturl.js?v={{ theme.version }}\"></script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/mathjax.swig",
    "content": "{% if theme.mathjax.enable %}\n  {% if not theme.mathjax.per_page or (page.total or page.mathjax) %}\n    <script type=\"text/x-mathjax-config\">\n      MathJax.Hub.Config({\n        tex2jax: {\n          inlineMath: [ ['$','$'], [\"\\\\(\",\"\\\\)\"]  ],\n          processEscapes: true,\n          skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']\n        }\n      });\n    </script>\n\n    <script type=\"text/x-mathjax-config\">\n      MathJax.Hub.Queue(function() {\n        var all = MathJax.Hub.getAllJax(), i;\n        for (i=0; i < all.length; i += 1) {\n          all[i].SourceElement().parentNode.className += ' has-jax';\n        }\n      });\n    </script>\n    <script type=\"text/javascript\" src=\"{{ theme.mathjax.cdn }}\"></script>\n  {% endif %}\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/needsharebutton.swig",
    "content": "{% if theme.needmoreshare2.enable %}\n  {% set needmoreshare2_css = url_for(theme.vendors._internal + '/needsharebutton/needsharebutton.css') %}\n  {% if theme.vendors.needmoreshare2 %}\n    {% set needmoreshare2_css = theme.vendors.needmoreshare2_css %}\n  {% endif %}\n  <link rel=\"stylesheet\" href=\"{{ needmoreshare2_css }}\">\n\n  {% set needmoreshare2_js = url_for(theme.vendors._internal + '/needsharebutton/needsharebutton.js') %}\n  {% if theme.vendors.needmoreshare2_js %}\n    {% set needmoreshare2_js = theme.vendors.needmoreshare2_js %}\n  {% endif %}\n  <script src=\"{{ needmoreshare2_js }}\"></script>\n\n  <script>\n    {% if theme.needmoreshare2.postbottom.enable %}\n      pbOptions = {};\n      {% for k,v in theme.needmoreshare2.postbottom.options %}\n          pbOptions.{{ k }} = \"{{ v }}\";\n      {% endfor %}\n      new needShareButton('#needsharebutton-postbottom', pbOptions);\n    {% endif %}\n    {% if theme.needmoreshare2.float.enable %}\n      flOptions = {};\n      {% for k,v in theme.needmoreshare2.float.options %}\n          flOptions.{{ k }} = \"{{ v }}\";\n      {% endfor %}\n      new needShareButton('#needsharebutton-float', flOptions);\n    {% endif %}\n  </script>\n{% endif %}"
  },
  {
    "path": "layout/_third-party/rating.swig",
    "content": "{% if theme.rating.enable and (not is_home() and is_post()) %}\n  <script type=\"text/javascript\">\n  wpac_init = window.wpac_init || [];\n  wpac_init.push({widget: 'Rating', id: {{ theme.rating.id }},\n    el: 'wpac-rating',\n    color: '{{ theme.rating.color }}'\n  });\n  (function() {\n    if ('WIDGETPACK_LOADED' in window) return;\n    WIDGETPACK_LOADED = true;\n    var mc = document.createElement('script');\n    mc.type = 'text/javascript';\n    mc.async = true;\n    mc.src = '//embed.widgetpack.com/widget.js';\n    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(mc, s.nextSibling);\n  })();\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/schedule.swig",
    "content": "{% if theme.calendar.enable %}\n{% if page.type == 'schedule' %}\n\n<script>\n\n// Initialization\nvar _n = function(arg) { if(arg) return arg; else return void 0;}\n\nvar cal_data = void 0;\n\nvar now = new Date();\nvar timeMax = new Date();\nvar timeMin = new Date();\n\n// Read config form theme config file\nvar calId           = _n('{{ theme.calendar.calendar_id  }}')                ;\nvar apiKey          = _n('{{ theme.calendar.api_key      }}')                ;\nvar orderBy         = _n('{{ theme.calendar.ordarBy      }}')  || 'startTime';\nvar showLocation    = _n('{{ theme.calendar.showLocation }}')  || 'false'    ;\nvar offsetMax       = _n( {{ theme.calendar.offsetMax    }} )  || 72         ;\nvar offsetMin       = _n( {{ theme.calendar.offsetMin    }} )  || 4          ;\nvar timeZone        = _n( {{ theme.calendar.timeZone     }} )  || void 0     ;\nvar showDeleted     = _n( {{ theme.calendar.showDeleted  }} )  || 'false'    ;\nvar singleEvents    = _n( {{ theme.calendar.singleEvents }} )  || 'true'     ;\nvar maxResults      = _n( {{ theme.calendar.maxResults   }} )  || '250'      ;\n\ntimeMax.setHours(now.getHours() + offsetMax);\ntimeMin.setHours(now.getHours() - offsetMin);\n\n// Build URL\nBASE_URL            = 'https://www.googleapis.com/calendar/v3/calendars/';\nFIELD_KEY           = 'key';\nFIELD_ORDERBY       = 'orderBy';\nFIELD_TIMEMAX       = 'timeMax';\nFIELD_TIMEMIN       = 'timeMin';\nFIELD_TIMEZONE      = 'timeZone';\nFIELD_SHOWDELETED   = 'showDeleted';\nFIELD_SINGLEEVENTS  = 'singleEvents';\nFIELD_MAXRESULTS    = 'maxResults';\n\ntimeMaxISO          = timeMax.toISOString();\ntimeMinISO          = timeMin.toISOString();\n\nrequest_url = BASE_URL + calId + '/events?'  +\n  FIELD_KEY           + '=' + apiKey        + '&' +\n  FIELD_ORDERBY       + '=' + orderBy       + '&' +\n  FIELD_TIMEMAX       + '=' + timeMaxISO    + '&' +\n  FIELD_TIMEMIN       + '=' + timeMinISO    + '&' +\n  FIELD_SHOWDELETED   + '=' + showDeleted   + '&' +\n  FIELD_SINGLEEVENTS  + '=' + singleEvents  + '&' +\n  FIELD_MAXRESULTS    + '=' + maxResults;\n\nif (timeZone) {\n  request_url = request_url + '&' + FIELD_TIMEZONE + '=' + timeZone;\n}\n\nfetchData();\nvar queryLoop = setInterval(fetchData, 60000);\n\nfunction fetchData() {\n  $.ajax({\n    dataType: 'json',\n    url: request_url,\n    success: function(data) {\n\n      $eventList = $('#schedule #event-list');\n\n      // clean the event list\n      $eventList.html(\"\");\n      var prevEnd = 0; // used to decide where to insert an <hr>\n\n      data['items'].forEach((event) => {\n\n        // parse data\n        var start = new Date(event.start.dateTime);\n        var end   = new Date(event.end.dateTime);\n\n        tense = judgeTense(now, start, end); // 0:now 1:future -1:past\n\n        if (tense == 1 && prevEnd < now) $eventList.append('<hr>');\n\n        eventDOM = buildEventDOM(tense, event);\n        $eventList.append(eventDOM);\n\n        prevEnd = end;\n      });\n    }\n  });\n}\n\nfunction getRelativeTime(current, previous) {\n  var msPerMinute = 60 * 1000;\n  var msPerHour = msPerMinute * 60;\n  var msPerDay = msPerHour * 24;\n  var msPerMonth = msPerDay * 30;\n  var msPerYear = msPerDay * 365;\n\n  var elapsed = current - previous;\n  var tense = elapsed > 0 ? \"ago\" : \"later\";\n\n  elapsed = Math.abs(elapsed);\n\n  if      ( elapsed < msPerHour  ) {\n    return Math.round(elapsed/msPerMinute) + ' minutes ' + tense;\n  }\n  else if ( elapsed < msPerDay   ) {\n    return Math.round(elapsed/msPerHour) + ' hours ' + tense;\n  }\n  else if ( elapsed < msPerMonth ) {\n    return 'about ' + Math.round(elapsed/msPerDay) + ' days ' + tense;\n  }\n  else if ( elapsed < msPerYear  ) {\n    return 'about ' + Math.round(elapsed/msPerMonth) + ' months ' + tense;\n  }\n  else {\n    return 'about' + Math.round(elapsed/msPerYear) + ' years' + tense;\n  }\n}\n\nfunction judgeTense(now, eventStart, eventEnd) {\n  if      (eventEnd   < now)  { return -1; }\n  else if (eventStart > now)  { return  1; }\n  else                        { return  0; }\n}\n\nfunction buildEventDOM(tense, event) {\n  var tenseClass = \"\";\n  var start      = new Date(event.start.dateTime);\n  var end        = new Date(event.end.dateTime);\n  switch(tense) {\n    case 0 : // now\n      tenseClass = \"event-now\";\n      break;\n    case 1 : // future\n      tenseClass = \"event-future\";\n      break;\n    case -1: // past\n      tenseClass = \"event-past\";\n      break;\n    default:\n      throw \"Time data error\";\n  }\n  durationFormat = {\n    weekday: 'short',\n    hour: '2-digit',\n    minute:'2-digit'\n  };\n  relativeTimeStr = (tense == 0) ? \"NOW\" : getRelativeTime(now, start);\n  durationStr = start.toLocaleTimeString([], durationFormat) + \" - \" +\n                end.toLocaleTimeString([], durationFormat);\n\n  liOpen                = `<li class=\"event ${tenseClass}\">`;\n  liClose               = `</li>`;\n  h2Open                = `<h2 class=\"event-summary\">`;\n  h2Close               = `</h2>`;\n\n  locationDOM     = \"\";\n  if (showLocation && event['location']) {\n    locationDOM   = `<span class=\"event-location event-details\">\n                      ${event['location']}\n                     </span>`;\n  }\n  relativeTimeDOM = `<span class=\"event-relative-time\">\n                      ${relativeTimeStr}\n                     </span>`;\n  durationDOM     = `<span class=\"event-duration event-details\">\n                      ${durationStr}\n                     </span>`;\n\n  eventContent =\n    liOpen +\n      h2Open +\n        event['summary'] +\n        relativeTimeDOM+\n      h2Close +\n      locationDOM +\n      durationDOM +\n    liClose;\n  return eventContent;\n}\n\n</script>\n\n{% endif %}\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/scroll-cookie.swig",
    "content": "{% if theme.save_scroll %}\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/src/js.cookie.js?v={{ theme.version }}\"></script>\n  <script type=\"text/javascript\" src=\"{{ url_for(theme.js) }}/src/scroll-cookie.js?v={{ theme.version }}\"></script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/search/algolia-search/assets.swig",
    "content": "{% if theme.algolia_search.enable %}\n\n  {# S: Include Algolia instantsearch.js library #}\n  {% set algolia_instant_css = url_for(theme.vendors._internal + '/algolia-instant-search/instantsearch.min.css') %}\n  {% if theme.vendors.algolia_instant_css %}\n    {% set algolia_instant_css = theme.vendors.algolia_instant_css %}\n  {% endif %}\n  <link rel=\"stylesheet\" href=\"{{ algolia_instant_css }}\">\n\n  {% set algolia_instant_js = url_for(theme.vendors._internal + '/algolia-instant-search/instantsearch.min.js') %}\n  {% if theme.vendors.algolia_instant_js %}\n    {% set algolia_instant_js = theme.vendors.algolia_instant_js %}\n  {% endif %}\n  <script src=\"{{ algolia_instant_js }}\"></script>\n  {# E: Include Algolia instantsearch.js library #}\n\n  <script src=\"{{ url_for(theme.js) }}/src/algolia-search.js?v={{ theme.version }}\"></script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/search/algolia-search/dom.swig",
    "content": "{% if theme.algolia_search.enable %}\n  <div class=\"algolia-popup popup search-popup\">\n    <div class=\"algolia-search\">\n      <div class=\"algolia-search-input-icon\">\n        <i class=\"fa fa-search\"></i>\n      </div>\n      <div class=\"algolia-search-input\" id=\"algolia-search-input\"></div>\n    </div>\n\n    <div class=\"algolia-results\">\n      <div id=\"algolia-stats\"></div>\n      <div id=\"algolia-hits\"></div>\n      <div id=\"algolia-pagination\" class=\"algolia-pagination\"></div>\n    </div>\n\n    <span class=\"popup-btn-close\">\n      <i class=\"fa fa-times-circle\"></i>\n    </span>\n  </div>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/search/index.swig",
    "content": "{% include 'tinysou.swig' %}\n{% include 'localsearch.swig' %}\n{% include 'algolia-search/assets.swig' %}\n"
  },
  {
    "path": "layout/_third-party/search/localsearch.swig",
    "content": "{% if theme.local_search.enable %}\n  <script type=\"text/javascript\">\n    // Popup Window;\n    var isfetched = false;\n    var isXml = true;\n    // Search DB path;\n    var search_path = \"{{ config.search.path }}\";\n    if (search_path.length === 0) {\n      search_path = \"search.xml\";\n    } else if (/json$/i.test(search_path)) {\n      isXml = false;\n    }\n    var path = \"{{ config.root }}\" + search_path;\n    // monitor main search box;\n\n    var onPopupClose = function (e) {\n      $('.popup').hide();\n      $('#local-search-input').val('');\n      $('.search-result-list').remove();\n      $('#no-result').remove();\n      $(\".local-search-pop-overlay\").remove();\n      $('body').css('overflow', '');\n    }\n\n    function proceedsearch() {\n      $(\"body\")\n        .append('<div class=\"search-popup-overlay local-search-pop-overlay\"></div>')\n        .css('overflow', 'hidden');\n      $('.search-popup-overlay').click(onPopupClose);\n      $('.popup').toggle();\n      var $localSearchInput = $('#local-search-input');\n      $localSearchInput.attr(\"autocapitalize\", \"none\");\n      $localSearchInput.attr(\"autocorrect\", \"off\");\n      $localSearchInput.focus();\n    }\n\n    // search function;\n    var searchFunc = function(path, search_id, content_id) {\n      'use strict';\n\n      // start loading animation\n      $(\"body\")\n        .append('<div class=\"search-popup-overlay local-search-pop-overlay\">' +\n          '<div id=\"search-loading-icon\">' +\n          '<i class=\"fa fa-spinner fa-pulse fa-5x fa-fw\"></i>' +\n          '</div>' +\n          '</div>')\n        .css('overflow', 'hidden');\n      $(\"#search-loading-icon\").css('margin', '20% auto 0 auto').css('text-align', 'center');\n\n      $.ajax({\n        url: path,\n        dataType: isXml ? \"xml\" : \"json\",\n        async: true,\n        success: function(res) {\n          // get the contents from search data\n          isfetched = true;\n          $('.popup').detach().appendTo('.header-inner');\n          var datas = isXml ? $(\"entry\", res).map(function() {\n            return {\n              title: $(\"title\", this).text(),\n              content: $(\"content\",this).text(),\n              url: $(\"url\" , this).text()\n            };\n          }).get() : res;\n          var input = document.getElementById(search_id);\n          var resultContent = document.getElementById(content_id);\n          var inputEventFunction = function() {\n            var searchText = input.value.trim().toLowerCase();\n            var keywords = searchText.split(/[\\s\\-]+/);\n            if (keywords.length > 1) {\n              keywords.push(searchText);\n            }\n            var resultItems = [];\n            if (searchText.length > 0) {\n              // perform local searching\n              datas.forEach(function(data) {\n                var isMatch = false;\n                var hitCount = 0;\n                var searchTextCount = 0;\n                var title = data.title.trim();\n                var titleInLowerCase = title.toLowerCase();\n                var content = data.content.trim().replace(/<[^>]+>/g,\"\");\n                var contentInLowerCase = content.toLowerCase();\n                var articleUrl = decodeURIComponent(data.url);\n                var indexOfTitle = [];\n                var indexOfContent = [];\n                // only match articles with not empty titles\n                if(title != '') {\n                  keywords.forEach(function(keyword) {\n                    function getIndexByWord(word, text, caseSensitive) {\n                      var wordLen = word.length;\n                      if (wordLen === 0) {\n                        return [];\n                      }\n                      var startPosition = 0, position = [], index = [];\n                      if (!caseSensitive) {\n                        text = text.toLowerCase();\n                        word = word.toLowerCase();\n                      }\n                      while ((position = text.indexOf(word, startPosition)) > -1) {\n                        index.push({position: position, word: word});\n                        startPosition = position + wordLen;\n                      }\n                      return index;\n                    }\n\n                    indexOfTitle = indexOfTitle.concat(getIndexByWord(keyword, titleInLowerCase, false));\n                    indexOfContent = indexOfContent.concat(getIndexByWord(keyword, contentInLowerCase, false));\n                  });\n                  if (indexOfTitle.length > 0 || indexOfContent.length > 0) {\n                    isMatch = true;\n                    hitCount = indexOfTitle.length + indexOfContent.length;\n                  }\n                }\n\n                // show search results\n\n                if (isMatch) {\n                  // sort index by position of keyword\n\n                  [indexOfTitle, indexOfContent].forEach(function (index) {\n                    index.sort(function (itemLeft, itemRight) {\n                      if (itemRight.position !== itemLeft.position) {\n                        return itemRight.position - itemLeft.position;\n                      } else {\n                        return itemLeft.word.length - itemRight.word.length;\n                      }\n                    });\n                  });\n\n                  // merge hits into slices\n\n                  function mergeIntoSlice(text, start, end, index) {\n                    var item = index[index.length - 1];\n                    var position = item.position;\n                    var word = item.word;\n                    var hits = [];\n                    var searchTextCountInSlice = 0;\n                    while (position + word.length <= end && index.length != 0) {\n                      if (word === searchText) {\n                        searchTextCountInSlice++;\n                      }\n                      hits.push({position: position, length: word.length});\n                      var wordEnd = position + word.length;\n\n                      // move to next position of hit\n\n                      index.pop();\n                      while (index.length != 0) {\n                        item = index[index.length - 1];\n                        position = item.position;\n                        word = item.word;\n                        if (wordEnd > position) {\n                          index.pop();\n                        } else {\n                          break;\n                        }\n                      }\n                    }\n                    searchTextCount += searchTextCountInSlice;\n                    return {\n                      hits: hits,\n                      start: start,\n                      end: end,\n                      searchTextCount: searchTextCountInSlice\n                    };\n                  }\n\n                  var slicesOfTitle = [];\n                  if (indexOfTitle.length != 0) {\n                    slicesOfTitle.push(mergeIntoSlice(title, 0, title.length, indexOfTitle));\n                  }\n\n                  var slicesOfContent = [];\n                  while (indexOfContent.length != 0) {\n                    var item = indexOfContent[indexOfContent.length - 1];\n                    var position = item.position;\n                    var word = item.word;\n                    // cut out 100 characters\n                    var start = position - 20;\n                    var end = position + 80;\n                    if(start < 0){\n                      start = 0;\n                    }\n                    if (end < position + word.length) {\n                      end = position + word.length;\n                    }\n                    if(end > content.length){\n                      end = content.length;\n                    }\n                    slicesOfContent.push(mergeIntoSlice(content, start, end, indexOfContent));\n                  }\n\n                  // sort slices in content by search text's count and hits' count\n\n                  slicesOfContent.sort(function (sliceLeft, sliceRight) {\n                    if (sliceLeft.searchTextCount !== sliceRight.searchTextCount) {\n                      return sliceRight.searchTextCount - sliceLeft.searchTextCount;\n                    } else if (sliceLeft.hits.length !== sliceRight.hits.length) {\n                      return sliceRight.hits.length - sliceLeft.hits.length;\n                    } else {\n                      return sliceLeft.start - sliceRight.start;\n                    }\n                  });\n\n                  // select top N slices in content\n\n                  var upperBound = parseInt('{{ theme.local_search.top_n_per_article }}');\n                  if (upperBound >= 0) {\n                    slicesOfContent = slicesOfContent.slice(0, upperBound);\n                  }\n\n                  // highlight title and content\n\n                  function highlightKeyword(text, slice) {\n                    var result = '';\n                    var prevEnd = slice.start;\n                    slice.hits.forEach(function (hit) {\n                      result += text.substring(prevEnd, hit.position);\n                      var end = hit.position + hit.length;\n                      result += '<b class=\"search-keyword\">' + text.substring(hit.position, end) + '</b>';\n                      prevEnd = end;\n                    });\n                    result += text.substring(prevEnd, slice.end);\n                    return result;\n                  }\n\n                  var resultItem = '';\n\n                  if (slicesOfTitle.length != 0) {\n                    resultItem += \"<li><a href='\" + articleUrl + \"' class='search-result-title'>\" + highlightKeyword(title, slicesOfTitle[0]) + \"</a>\";\n                  } else {\n                    resultItem += \"<li><a href='\" + articleUrl + \"' class='search-result-title'>\" + title + \"</a>\";\n                  }\n\n                  slicesOfContent.forEach(function (slice) {\n                    resultItem += \"<a href='\" + articleUrl + \"'>\" +\n                      \"<p class=\\\"search-result\\\">\" + highlightKeyword(content, slice) +\n                      \"...</p>\" + \"</a>\";\n                  });\n\n                  resultItem += \"</li>\";\n                  resultItems.push({\n                    item: resultItem,\n                    searchTextCount: searchTextCount,\n                    hitCount: hitCount,\n                    id: resultItems.length\n                  });\n                }\n              })\n            };\n            if (keywords.length === 1 && keywords[0] === \"\") {\n              resultContent.innerHTML = '<div id=\"no-result\"><i class=\"fa fa-search fa-5x\" /></div>'\n            } else if (resultItems.length === 0) {\n              resultContent.innerHTML = '<div id=\"no-result\"><i class=\"fa fa-frown-o fa-5x\" /></div>'\n            } else {\n              resultItems.sort(function (resultLeft, resultRight) {\n                if (resultLeft.searchTextCount !== resultRight.searchTextCount) {\n                  return resultRight.searchTextCount - resultLeft.searchTextCount;\n                } else if (resultLeft.hitCount !== resultRight.hitCount) {\n                  return resultRight.hitCount - resultLeft.hitCount;\n                } else {\n                  return resultRight.id - resultLeft.id;\n                }\n              });\n              var searchResultList = '<ul class=\\\"search-result-list\\\">';\n              resultItems.forEach(function (result) {\n                searchResultList += result.item;\n              })\n              searchResultList += \"</ul>\";\n              resultContent.innerHTML = searchResultList;\n            }\n          }\n\n          if ('auto' === '{{ theme.local_search.trigger }}') {\n            input.addEventListener('input', inputEventFunction);\n          } else {\n            $('.search-icon').click(inputEventFunction);\n            input.addEventListener('keypress', function (event) {\n              if (event.keyCode === 13) {\n                inputEventFunction();\n              }\n            });\n          }\n\n          // remove loading animation\n          $(\".local-search-pop-overlay\").remove();\n          $('body').css('overflow', '');\n\n          proceedsearch();\n        }\n      });\n    }\n\n    // handle and trigger popup window;\n    $('.popup-trigger').click(function(e) {\n      e.stopPropagation();\n      if (isfetched === false) {\n        searchFunc(path, 'local-search-input', 'local-search-result');\n      } else {\n        proceedsearch();\n      };\n    });\n\n    $('.popup-btn-close').click(onPopupClose);\n    $('.popup').click(function(e){\n      e.stopPropagation();\n    });\n    $(document).on('keyup', function (event) {\n      var shouldDismissSearchPopup = event.which === 27 &&\n        $('.search-popup').is(':visible');\n      if (shouldDismissSearchPopup) {\n        onPopupClose();\n      }\n    });\n  </script>\n{% endif %}\n"
  },
  {
    "path": "layout/_third-party/search/tinysou.swig",
    "content": "{% if config.tinysou_Key %}\n  <script>\n    var customRenderActFunction = function(item) {\n      var out = '<p class=\"title\">' + item['document']['title'].split(\" // \")[0] + '</p>';\n      return out;\n    };\n    var option = {\n      engineKey: '{{ config.tinysou_Key }}',\n      renderActFunction: customRenderActFunction\n    };\n    (function(w,d,t,u,n,s,e){\n      s = d.createElement(t);\n      s.src = u;\n      s.async = 1;\n      w[n] = function(r){\n        w[n].opts = r;\n      };\n      e = d.getElementsByTagName(t)[0];\n      e.parentNode.insertBefore(s, e);\n    })(window,document,'script','//tinysou-cdn.b0.upaiyun.com/ts.js','_ts');\n    _ts(option);\n  </script>\n{% endif %}"
  },
  {
    "path": "layout/_third-party/seo/baidu-push.swig",
    "content": "{% if theme.baidu_push %}\n<script>\n(function(){\n    var bp = document.createElement('script');\n    var curProtocol = window.location.protocol.split(':')[0];\n    if (curProtocol === 'https') {\n        bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';        \n    }\n    else {\n        bp.src = 'http://push.zhanzhang.baidu.com/push.js';\n    }\n    var s = document.getElementsByTagName(\"script\")[0];\n    s.parentNode.insertBefore(bp, s);\n})();\n</script>\n{% endif %}\n"
  },
  {
    "path": "layout/archive.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n{% block title %}{{ __('title.archive') }} | {{ config.title }}{% endblock %}\n\n{% block page_class %}page-archive{% endblock %}\n\n{% block content %}\n\n  {#####################}\n  {### ARCHIVE BLOCK ###}\n  {#####################}\n  <div class=\"post-block archive\">\n    <div id=\"posts\" class=\"posts-collapse\">\n      <span class=\"archive-move-on\"></span>\n\n      <span class=\"archive-page-counter\">\n        {% set cheers %}\n        {% set posts_length = site.posts.length %}\n        {% if posts_length > 210 %} {% set cheers = 'excellent' %}\n          {% elif posts_length > 130 %} {% set cheers = 'great' %}\n          {% elif posts_length > 80 %} {% set cheers = 'good' %}\n          {% elif posts_length > 50 %} {% set cheers = 'nice' %}\n          {% elif posts_length > 30 %} {% set cheers = 'ok' %}\n        {% else %}\n          {% set cheers = 'um' %}\n        {% endif %}\n        {{ __('cheers.' + cheers) }}! {{ _p(\"counter.archive_posts\", site.posts.length) }} {{ __('keep_on') }}\n      </span>\n\n      {% for post in page.posts %}\n\n        {# Show year #}\n        {% set year %}\n        {% set post.year = date(post.date, 'YYYY') %}\n\n        {% if post.year !== year %}\n          {% set year = post.year %}\n          <div class=\"collection-title\">\n            <{% if theme.seo %}h2{% else %}h1{% endif %} class=\"archive-year\" id=\"archive-year-{{ year }}\">{{ year }}</{% if theme.seo %}h2{% else %}h1{% endif %}>\n          </div>\n        {% endif %}\n        {# endshow #}\n\n        {{ post_template.render(post) }}\n\n      {% endfor %}\n\n    </div>\n  </div>\n  {#########################}\n  {### END ARCHIVE BLOCK ###}\n  {#########################}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/category.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n{% block title %}{{ __('title.category') }}: {{ page.category }} | {{ config.title }}{% endblock %}\n\n{% block content %}\n\n  {######################}\n  {### CATEGORY BLOCK ###}\n  {######################}\n  <div class=\"post-block category\">\n\n    <div id=\"posts\" class=\"posts-collapse\">\n      <div class=\"collection-title\">\n        <{% if theme.seo %}h2{% else %}h1{% endif %}>{#\n        #}{{ page.category }}{#\n        #}<small>{{  __('title.category')  }}</small>\n        </{% if theme.seo %}h2{% else %}h1{% endif %}>\n      </div>\n\n      {% for post in page.posts %}\n        {{ post_template.render(post) }}\n      {% endfor %}\n    </div>\n\n  </div>\n  {##########################}\n  {### END CATEGORY BLOCK ###}\n  {##########################}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/index.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post.swig' as post_template %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n{% block title %}{{ config.title }}{% if theme.index_with_subtitle and config.subtitle %} - {{config.subtitle }}{% endif %}{% endblock %}\n\n{% block page_class %}\n  {% if is_home() %}page-home{% endif -%}\n{% endblock %}\n\n{% block content %}\n  <section id=\"posts\" class=\"posts-expand\">\n    {% for post in page.posts %}\n      {{ post_template.render(post, true) }}\n    {% endfor %}\n  </section>\n\n  {% include '_partials/pagination.swig' %}\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/page.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n  {% block title %}{#\n  #}{% set page_title_suffix = ' | ' + config.title %}{#\n\n  #}{% if page.type === \"categories\" and not page.title %}{#\n    #}{{ __('title.category') + page_title_suffix }}{#\n  #}{% elif page.type === \"tags\" and not page.title %}{#\n    #}{{ __('title.tag') + page_title_suffix }}{#\n  #}{% else %}{#\n    #}{{ page.title + page_title_suffix }}{#\n  #}{% endif %}{#\n#}{% endblock %}\n\n{% block page_class %}page-post-detail{% endblock %}\n\n{% block content %}\n\n  <div id=\"posts\" class=\"posts-expand\">\n    {##################}\n    {### PAGE BLOCK ###}\n    {##################}\n    <div class=\"post-block page\">\n      {% include '_partials/page-header.swig' %}\n      {#################}\n      {### PAGE BODY ###}\n      {#################}\n      <div class=\"post-body{% if theme.han %} han-init-context{% endif %}{% if page.direction && page.direction.toLowerCase() === 'rtl' %} rtl{% endif %}\">\n        {# tagcloud page support #}\n        {% if page.type === \"tags\" %}\n          <div class=\"tag-cloud\">\n            <div class=\"tag-cloud-title\">\n                {{ _p('counter.tag_cloud', site.tags.length) }}\n            </div>\n            <div class=\"tag-cloud-tags\">\n              {{ tagcloud({min_font: 12, max_font: 30, amount: 300, color: true, start_color: '#ccc', end_color: '#111'}) }}\n            </div>\n          </div>\n        {% elif page.type === 'categories' %}\n          <div class=\"category-all-page\">\n            <div class=\"category-all-title\">\n                {{ _p('counter.categories', site.categories.length) }}\n            </div>\n            <div class=\"category-all\">\n              {{ list_categories() }}\n            </div>\n          </div>\n        {% else %}\n          {{ page.content }}\n        {% endif %}\n      </div>\n      {#####################}\n      {### END PAGE BODY ###}\n      {#####################}\n    </div>\n    {######################}\n    {### END PAGE BLOCK ###}\n    {######################}\n  </div>\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n\n{% block script_extra %}\n  {% include '_scripts/pages/post-details.swig' %}\n{% endblock %}\n"
  },
  {
    "path": "layout/post.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post.swig' as post_template %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n\n{% block title %}{{ page.title }} | {{ config.title }}{% endblock %}\n\n{% block page_class %}page-post-detail{% endblock %}\n\n\n{% block content %}\n\n  <div id=\"posts\" class=\"posts-expand\">\n    {{ post_template.render(page) }}\n\n    <div class=\"post-spread\">\n      {% if theme.jiathis %}\n        {% include '_partials/share/jiathis.swig' %}\n      {% elseif theme.baidushare %}\n        {% include '_partials/share/baidushare.swig' %}\n      {% elseif theme.add_this_id %}\n        {% include '_partials/share/add-this.swig' %}\n      {% elseif theme.duoshuo_shortname and theme.duoshuo_share %}\n        {% include '_partials/share/duoshuo_share.swig' %}\n      {% endif %}\n    </div>\n  </div>\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(true) }}\n{% endblock %}\n\n{% block script_extra %}\n  {% include '_scripts/pages/post-details.swig' %}\n{% endblock %}\n"
  },
  {
    "path": "layout/schedule.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n{% block title %}{{ __('title.schedule') }} | {{ config.title }}{% endblock %}\n\n{% block page_class %}page-post-detail page-calendar{% endblock %}\n\n{% block content %}\n  {######################}\n  {### SCHEDULE BLOCK ###}\n  {######################}\n  <div class=\"post-block schedule\">\n    <div id=\"schedule\">\n      <ul id=\"event-list\">\n      </ul>\n    </div>\n  </div>\n  {##########################}\n  {### END SCHEDULE BLOCK ###}\n  {##########################}\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/tag.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template %}\n{% import '_macro/sidebar.swig' as sidebar_template %}\n\n{% block title %}{{ __('title.tag') }}: {{ page.tag }} | {{ config.title }}{% endblock %}\n\n{% block content %}\n\n  {#################}\n  {### TAG BLOCK ###}\n  {#################}\n  <div class=\"post-block tag\">\n\n    <div id=\"posts\" class=\"posts-collapse\">\n      <div class=\"collection-title\">\n        <{% if theme.seo %}h2{% else %}h1{% endif %}>{#\n        #}{{ page.tag }}{#\n        #}<small>{{  __('title.tag')  }}</small>\n        </{% if theme.seo %}h2{% else %}h1{% endif %}>\n      </div>\n\n      {% for post in page.posts %}\n        {{ post_template.render(post) }}\n      {% endfor %}\n    </div>\n\n  </div>\n  {#####################}\n  {### END TAG BLOCK ###}\n  {#####################}\n\n  {% include '_partials/pagination.swig' %}\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "package.json",
    "content": "{\n  \"name\": \"hexo-theme-next\",\n  \"version\": \"5.1.4\",\n  \"description\": \"Elegant theme for Hexo\",\n  \"main\": \"index.js\",\n  \"directories\": {\n    \"test\": \"test\"\n  },\n  \"scripts\": {\n    \"test\": \"gulp\"\n  },\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/iissnan/hexo-theme-next.git\"\n  },\n  \"keywords\": [\n    \"NexT\",\n    \"Hexo\"\n  ],\n  \"author\": \"iissnan <iissnan@gmail.com>\",\n  \"maintainers\": [\n    \"Ivan Nginx <ivan.nginx@gmail.com> (https://almostover.ru)\"\n    ],\n  \"license\": \"MIT\",\n  \"bugs\": {\n    \"url\": \"https://github.com/iissnan/hexo-theme-next/issues\"\n  },\n  \"homepage\": \"https://theme-next.iissnan.com\",\n  \"devDependencies\": {\n    \"coffee-script\": \"^1.10.0\",\n    \"gulp\": \"^3.9.0\",\n    \"gulp-jshint\": \"^1.12.0\",\n    \"gulp-shell\": \"^0.6.1\",\n    \"js-yaml\": \"^3.8.1\",\n    \"jshint-stylish\": \"^2.1.0\",\n    \"stylint\": \"^1.5.9\"\n  }\n}\n"
  },
  {
    "path": "scripts/merge-configs.js",
    "content": "/* global hexo */\n\nvar merge = require('./merge');\n\n/**\n * Merge configs in _data/next.yml into hexo.theme.config.\n * Note: configs in _data/next.yml will override configs in hexo.theme.config.\n */\nhexo.on('generateBefore', function () {\n  if (hexo.locals.get) {\n    var data = hexo.locals.get('data');\n    if ( data && data.next ) {\n      if ( data.next.override ) {\n        hexo.theme.config = data.next;\n      } else {\n        merge(hexo.theme.config, data.next);\n      }\n    }\n  }\n});\n\nhexo.on('generateAfter', function () {\n  hexo.log.warn(\"===============================================================\");\n  hexo.log.warn(\"========================= ATTENTION! ==========================\");\n  hexo.log.warn(\"===============================================================\");\n  hexo.log.warn(\" NexT repository is moving here: https://github.com/theme-next \");\n  hexo.log.warn(\"===============================================================\");\n  hexo.log.warn(\" It's rebase to v6.0.0 and future maintenance will resume there\");\n  hexo.log.warn(\"===============================================================\");\n});\n"
  },
  {
    "path": "scripts/merge.js",
    "content": "/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n  arrayTag = '[object Array]',\n  boolTag = '[object Boolean]',\n  dateTag = '[object Date]',\n  errorTag = '[object Error]',\n  funcTag = '[object Function]',\n  genTag = '[object GeneratorFunction]',\n  mapTag = '[object Map]',\n  numberTag = '[object Number]',\n  objectTag = '[object Object]',\n  promiseTag = '[object Promise]',\n  regexpTag = '[object RegExp]',\n  setTag = '[object Set]',\n  stringTag = '[object String]',\n  symbolTag = '[object Symbol]',\n  weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n  dataViewTag = '[object DataView]',\n  float32Tag = '[object Float32Array]',\n  float64Tag = '[object Float64Array]',\n  int8Tag = '[object Int8Array]',\n  int16Tag = '[object Int16Array]',\n  int32Tag = '[object Int32Array]',\n  uint8Tag = '[object Uint8Array]',\n  uint8ClampedTag = '[object Uint8ClampedArray]',\n  uint16Tag = '[object Uint16Array]',\n  uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n  typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n    typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n      typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n        typedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\n  typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n    typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n      typedArrayTags[errorTag] = typedArrayTags[funcTag] =\n        typedArrayTags[mapTag] = typedArrayTags[numberTag] =\n          typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n            typedArrayTags[setTag] = typedArrayTags[stringTag] =\n              typedArrayTags[weakMapTag] = false;\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\n  cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\n    cloneableTags[boolTag] = cloneableTags[dateTag] =\n      cloneableTags[float32Tag] = cloneableTags[float64Tag] =\n        cloneableTags[int8Tag] = cloneableTags[int16Tag] =\n          cloneableTags[int32Tag] = cloneableTags[mapTag] =\n            cloneableTags[numberTag] = cloneableTags[objectTag] =\n              cloneableTags[regexpTag] = cloneableTags[setTag] =\n                cloneableTags[stringTag] = cloneableTags[symbolTag] =\n                  cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\n                    cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\n  cloneableTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function () {\n  try {\n    return freeProcess && freeProcess.binding('util');\n  } catch (e) {\n  }\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Adds the key-value `pair` to `map`.\n *\n * @private\n * @param {Object} map The map to modify.\n * @param {Array} pair The key-value pair to add.\n * @returns {Object} Returns `map`.\n */\nfunction addMapEntry(map, pair) {\n  // Don't return `map.set` because it's not chainable in IE 11.\n  map.set(pair[0], pair[1]);\n  return map;\n}\n\n/**\n * Adds `value` to `set`.\n *\n * @private\n * @param {Object} set The set to modify.\n * @param {*} value The value to add.\n * @returns {Object} Returns `set`.\n */\nfunction addSetEntry(set, value) {\n  // Don't return `set.add` because it's not chainable in IE 11.\n  set.add(value);\n  return set;\n}\n\n/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  switch (args.length) {\n    case 0:\n      return func.call(thisArg);\n    case 1:\n      return func.call(thisArg, args[0]);\n    case 2:\n      return func.call(thisArg, args[0], args[1]);\n    case 3:\n      return func.call(thisArg, args[0], args[1], args[2]);\n  }\n  return func.apply(thisArg, args);\n}\n\n/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n    length = array ? array.length : 0;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n    length = values.length,\n    offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\n/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n *  the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n  var index = -1,\n    length = array ? array.length : 0;\n\n  if (initAccum && length) {\n    accumulator = array[++index];\n  }\n  while (++index < length) {\n    accumulator = iteratee(accumulator, array[index], index, array);\n  }\n  return accumulator;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n    result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n  return function (value) {\n    return func(value);\n  };\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\n/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n  // Many host objects are `Object` objects that can coerce to strings\n  // despite having improperly defined `toString` methods.\n  var result = false;\n  if (value != null && typeof value.toString != 'function') {\n    try {\n      result = !!(value + '');\n    } catch (e) {\n    }\n  }\n  return result;\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n  var index = -1,\n    result = Array(map.size);\n\n  map.forEach(function (value, key) {\n    result[++index] = [key, value];\n  });\n  return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function (arg) {\n    return func(transform(arg));\n  };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n  var index = -1,\n    result = Array(set.size);\n\n  set.forEach(function (value) {\n    result[++index] = value;\n  });\n  return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n  funcProto = Function.prototype,\n  objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function () {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n    .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n  Symbol = root.Symbol,\n  Uint8Array = root.Uint8Array,\n  getPrototype = overArg(Object.getPrototypeOf, Object),\n  objectCreate = Object.create,\n  propertyIsEnumerable = objectProto.propertyIsEnumerable,\n  splice = arrayProto.splice;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n  nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n  nativeKeys = overArg(Object.keys, Object),\n  nativeMax = Math.max;\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n  Map = getNative(root, 'Map'),\n  Promise = getNative(root, 'Promise'),\n  Set = getNative(root, 'Set'),\n  WeakMap = getNative(root, 'WeakMap'),\n  nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n  mapCtorString = toSource(Map),\n  promiseCtorString = toSource(Promise),\n  setCtorString = toSource(Set),\n  weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n  symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n    length = entries ? entries.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n  return this.has(key) && delete this.__data__[key];\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n  var data = this.__data__;\n  if (nativeCreate) {\n    var result = data[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n    length = entries ? entries.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n  var data = this.__data__,\n    index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = data.length - 1;\n  if (index == lastIndex) {\n    data.pop();\n  } else {\n    splice.call(data, index, 1);\n  }\n  return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n    index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n    index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n  var index = -1,\n    length = entries ? entries.length : 0;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n  return getMapData(this, key)['delete'](key);\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n  getMapData(this, key).set(key, value);\n  return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n  this.__data__ = new ListCache(entries);\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  return this.__data__['delete'](key);\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n  var cache = this.__data__;\n  if (cache instanceof ListCache) {\n    var pairs = cache.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      return this;\n    }\n    cache = this.__data__ = new MapCache(pairs);\n  }\n  cache.set(key, value);\n  return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  // Safari 9 makes `arguments.length` enumerable in strict mode.\n  var result = (isArray(value) || isArguments(value))\n    ? baseTimes(value.length, String)\n    : [];\n\n  var length = result.length,\n    skipIndexes = !!length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes && (key == 'length' || isIndex(key, length)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n  if ((value !== undefined && !eq(object[key], value)) ||\n    (typeof key == 'number' && value === undefined && !(key in object))) {\n    object[key] = value;\n  }\n}\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n  var objValue = object[key];\n  if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n    (value === undefined && !(key in object))) {\n    object[key] = value;\n  }\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n  var length = array.length;\n  while (length--) {\n    if (eq(array[length][0], key)) {\n      return length;\n    }\n  }\n  return -1;\n}\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\n}\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @param {boolean} [isFull] Specify a clone including symbols.\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, isDeep, isFull, customizer, key, object, stack) {\n  var result;\n  if (customizer) {\n    result = object ? customizer(value, key, object, stack) : customizer(value);\n  }\n  if (result !== undefined) {\n    return result;\n  }\n  if (!isObject(value)) {\n    return value;\n  }\n  var isArr = isArray(value);\n  if (isArr) {\n    result = initCloneArray(value);\n    if (!isDeep) {\n      return copyArray(value, result);\n    }\n  } else {\n    var tag = getTag(value),\n      isFunc = tag == funcTag || tag == genTag;\n\n    if (isBuffer(value)) {\n      return cloneBuffer(value, isDeep);\n    }\n    if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n      if (isHostObject(value)) {\n        return object ? value : {};\n      }\n      result = initCloneObject(isFunc ? {} : value);\n      if (!isDeep) {\n        return copySymbols(value, baseAssign(result, value));\n      }\n    } else {\n      if (!cloneableTags[tag]) {\n        return object ? value : {};\n      }\n      result = initCloneByTag(value, tag, baseClone, isDeep);\n    }\n  }\n  // Check for circular references and return its corresponding clone.\n  stack || (stack = new Stack);\n  var stacked = stack.get(value);\n  if (stacked) {\n    return stacked;\n  }\n  stack.set(value, result);\n\n  if (!isArr) {\n    var props = isFull ? getAllKeys(value) : keys(value);\n  }\n  arrayEach(props || value, function (subValue, key) {\n    if (props) {\n      key = subValue;\n      subValue = value[key];\n    }\n    // Recursively populate clone (susceptible to call stack limits).\n    assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));\n  });\n  return result;\n}\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nfunction baseCreate(proto) {\n  return isObject(proto) ? objectCreate(proto) : {};\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n  var result = keysFunc(object);\n  return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  return objectToString.call(value);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[objectToString.call(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n  if (!isPrototype(object)) {\n    return nativeKeys(object);\n  }\n  var result = [];\n  for (var key in Object(object)) {\n    if (hasOwnProperty.call(object, key) && key != 'constructor') {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n  if (!isObject(object)) {\n    return nativeKeysIn(object);\n  }\n  var isProto = isPrototype(object),\n    result = [];\n\n  for (var key in object) {\n    if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  if (!(isArray(source) || isTypedArray(source))) {\n    var props = baseKeysIn(source);\n  }\n  arrayEach(props || source, function (srcValue, key) {\n    if (props) {\n      key = srcValue;\n      srcValue = source[key];\n    }\n    if (isObject(srcValue)) {\n      stack || (stack = new Stack);\n      baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n    }\n    else {\n      var newValue = customizer\n        ? customizer(object[key], srcValue, (key + ''), object, source, stack)\n        : undefined;\n\n      if (newValue === undefined) {\n        newValue = srcValue;\n      }\n      assignMergeValue(object, key, newValue);\n    }\n  });\n}\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = object[key],\n    srcValue = source[key],\n    stacked = stack.get(srcValue);\n\n  if (stacked) {\n    assignMergeValue(object, key, stacked);\n    return;\n  }\n  var newValue = customizer\n    ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n    : undefined;\n\n  var isCommon = newValue === undefined;\n\n  if (isCommon) {\n    newValue = srcValue;\n    if (isArray(srcValue) || isTypedArray(srcValue)) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else {\n        isCommon = false;\n        newValue = baseClone(srcValue, true);\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || (srcIndex && isFunction(objValue))) {\n        isCommon = false;\n        newValue = baseClone(srcValue, true);\n      }\n      else {\n        newValue = objValue;\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, newValue);\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n    stack['delete'](srcValue);\n  }\n  assignMergeValue(object, key, newValue);\n}\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n  start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n  return function () {\n    var args = arguments,\n      index = -1,\n      length = nativeMax(args.length - start, 0),\n      array = Array(length);\n\n    while (++index < length) {\n      array[index] = args[start + index];\n    }\n    index = -1;\n    var otherArgs = Array(start + 1);\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = array;\n    return apply(func, this, otherArgs);\n  };\n}\n\n/**\n * Creates a clone of  `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var result = new buffer.constructor(buffer.length);\n  buffer.copy(result);\n  return result;\n}\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n  return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\n/**\n * Creates a clone of `map`.\n *\n * @private\n * @param {Object} map The map to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned map.\n */\nfunction cloneMap(map, isDeep, cloneFunc) {\n  var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map);\n  return arrayReduce(array, addMapEntry, new map.constructor);\n}\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n  var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n  result.lastIndex = regexp.lastIndex;\n  return result;\n}\n\n/**\n * Creates a clone of `set`.\n *\n * @private\n * @param {Object} set The set to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned set.\n */\nfunction cloneSet(set, isDeep, cloneFunc) {\n  var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set);\n  return arrayReduce(array, addSetEntry, new set.constructor);\n}\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n  return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\n/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n    length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n  object || (object = {});\n\n  var index = -1,\n    length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n\n    var newValue = customizer\n      ? customizer(object[key], source[key], key, object, source)\n      : undefined;\n\n    assignValue(object, key, newValue === undefined ? source[key] : newValue);\n  }\n  return object;\n}\n\n/**\n * Copies own symbol properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\n}\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n  return baseRest(function (object, sources) {\n    var index = -1,\n      length = sources.length,\n      customizer = length > 1 ? sources[length - 1] : undefined,\n      guard = length > 2 ? sources[2] : undefined;\n\n    customizer = (assigner.length > 3 && typeof customizer == 'function')\n      ? (length--, customizer)\n      : undefined;\n\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    object = Object(object);\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, index, customizer);\n      }\n    }\n    return object;\n  });\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * Creates an array of the own enumerable symbol properties of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray;\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11,\n// for data views in Edge < 14, and promises in Node.js.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n  (Map && getTag(new Map) != mapTag) ||\n  (Promise && getTag(Promise.resolve()) != promiseTag) ||\n  (Set && getTag(new Set) != setTag) ||\n  (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n  getTag = function (value) {\n    var result = objectToString.call(value),\n      Ctor = result == objectTag ? value.constructor : undefined,\n      ctorString = Ctor ? toSource(Ctor) : undefined;\n\n    if (ctorString) {\n      switch (ctorString) {\n        case dataViewCtorString:\n          return dataViewTag;\n        case mapCtorString:\n          return mapTag;\n        case promiseCtorString:\n          return promiseTag;\n        case setCtorString:\n          return setTag;\n        case weakMapCtorString:\n          return weakMapTag;\n      }\n    }\n    return result;\n  };\n}\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n    result = array.constructor(length);\n\n  // Add properties assigned by `RegExp#exec`.\n  if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n    result.index = array.index;\n    result.input = array.input;\n  }\n  return result;\n}\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, cloneFunc, isDeep) {\n  var Ctor = object.constructor;\n  switch (tag) {\n    case arrayBufferTag:\n      return cloneArrayBuffer(object);\n\n    case boolTag:\n    case dateTag:\n      return new Ctor(+object);\n\n    case dataViewTag:\n      return cloneDataView(object, isDeep);\n\n    case float32Tag:\n    case float64Tag:\n    case int8Tag:\n    case int16Tag:\n    case int32Tag:\n    case uint8Tag:\n    case uint8ClampedTag:\n    case uint16Tag:\n    case uint32Tag:\n      return cloneTypedArray(object, isDeep);\n\n    case mapTag:\n      return cloneMap(object, isDeep, cloneFunc);\n\n    case numberTag:\n    case stringTag:\n      return new Ctor(object);\n\n    case regexpTag:\n      return cloneRegExp(object);\n\n    case setTag:\n      return cloneSet(object, isDeep, cloneFunc);\n\n    case symbolTag:\n      return cloneSymbol(object);\n  }\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n *  else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n      ? (isArrayLike(object) && isIndex(index, object.length))\n      : (type == 'string' && index in object)\n  ) {\n    return eq(object[index], value);\n  }\n  return false;\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n    ? (value !== '__proto__')\n    : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n    proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\n/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n  var result = [];\n  if (object != null) {\n    for (var key in Object(object)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to process.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n  if (func != null) {\n    try {\n      return funcToString.call(func);\n    } catch (e) {\n    }\n    try {\n      return (func + '');\n    } catch (e) {\n    }\n  }\n  return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n    (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\n}\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 8-9 which returns 'object' for typed array and other constructors.\n  var tag = isObject(value) ? objectToString.call(value) : '';\n  return tag == funcTag || tag == genTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) ||\n    objectToString.call(value) != objectTag || isHostObject(value)) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return (typeof Ctor == 'function' &&\n  Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n *   'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n *   'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function (object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n  return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n  return false;\n}\n\nmodule.exports = merge;\n"
  },
  {
    "path": "scripts/tags/button.js",
    "content": "/* global hexo */\n// Usage: {% button /path/to/url/, text, icon [class], title %}\n// Alias: {% btn /path/to/url/, text, icon [class], title %}\n\nfunction postButton(args) {\n  args = args.join(' ').split(',');\n  var url = args[0];\n  var text = args[1] || '';\n  var icon = args[2] || '';\n  var title = args[3] || '';\n\n  if (!url) {\n    hexo.log.warn('URL can NOT be empty');\n  }\n\n  text = text.trim();\n  icon = icon.trim();\n  title = title.trim();\n\n  var result = ['<a class=\"btn\" href=\"' + url + '\"'];\n  title.length > 0 && result.push(' title=\"' + title + '\"');\n  result.push('>');\n  icon.length > 0 && result.push('<i class=\"fa fa-' + icon + '\"></i>');\n  text.length > 0 && result.push(text);\n  result.push('</a>');\n\n  return result.join('');\n}\n\nhexo.extend.tag.register('button', postButton);\nhexo.extend.tag.register('btn', postButton);\n"
  },
  {
    "path": "scripts/tags/center-quote.js",
    "content": "/* global hexo */\n// Usage: {% centerquote %} Something {% endcenterquote %}\n// Alias: {% cq %} Something {% endcq %}\n\nfunction centerQuote (args, content) {\n  return '<blockquote class=\"blockquote-center\">' +\n            hexo.render.renderSync({text: content, engine: 'markdown'}) +\n          '</blockquote>';\n}\n\nhexo.extend.tag.register('centerquote', centerQuote, {ends: true});\nhexo.extend.tag.register('cq', centerQuote, {ends: true});\n"
  },
  {
    "path": "scripts/tags/exturl.js",
    "content": "/* global hexo */\n// Usage: {% exturl text url \"title\" %}\n// Alias: {% extlink text url \"title\" %}\n\n'use strict';\n\n/*jshint camelcase: false */\nvar util = require('hexo-util');\n/*jshint camelcase: true */\nvar htmlTag = util.htmlTag;\n\nvar rUrl = /((([A-Za-z]{3,9}:(?:\\/\\/)?)(?:[-;:&=\\+\\$,\\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\\+\\$,\\w]+@)[A-Za-z0-9.-]+)((?:\\/[\\+~%\\/.\\w-_]*)?\\??(?:[-\\+=&;%@.\\w_]*)#?(?:[.\\!\\/\\\\w]*))?)/;\n\n// Create Base64 Object\nvar Base64={_keyStr:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\",encode:function(e){var t=\"\";var n,r,i,s,o,u,a;var f=0;e=Base64._utf8_encode(e);while(f<e.length){n=e.charCodeAt(f++);r=e.charCodeAt(f++);i=e.charCodeAt(f++);s=n>>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t=\"\";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9+/=]/g,\"\");while(f<e.length){s=this._keyStr.indexOf(e.charAt(f++));o=this._keyStr.indexOf(e.charAt(f++));u=this._keyStr.indexOf(e.charAt(f++));a=this._keyStr.indexOf(e.charAt(f++));n=s<<2|o>>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/rn/g,\"n\");var t=\"\";for(var n=0;n<e.length;n++){var r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r)}else if(r>127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t=\"\";var n=0;var r=c1=c2=0;while(n<e.length){r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r);n++}else if(r>191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}};\n\nfunction extURL(args, content) {\n  var exturl = 'exturl';\n  var url = '';\n  var text = ['<i class=\"fa fa-external-link\"></i>'];\n  var title = '';\n  var item = '';\n  var i = 0;\n  var len = args.length;\n\n  // Find link URL and text\n  for (; i < len; i++) {\n    item = args[i];\n\n    if (rUrl.test(item)) {\n      url = Base64.encode(item);\n      break;\n    } else {\n      text.push(item);\n    }\n  }\n\n  // Delete link URL and text from arguments\n  args = args.slice(i + 1);\n\n  // Check if the link should be open in a new window\n  // and collect the last text as the link title\n  if (args.length) {\n    var shift = args[0];\n    title = args.join(' ');\n  }\n\n  var attrs = {\n    class: exturl,\n    'data-url': url,\n    title: title\n  };\n\n  return htmlTag('span', attrs, text.join(' '));\n}\n\nhexo.extend.tag.register('exturl', extURL, {ends: false});\nhexo.extend.tag.register('extlink', extURL, {ends: false});\n"
  },
  {
    "path": "scripts/tags/full-image.js",
    "content": "/* global hexo */\n// Usage: {% fullimage /path/to/image, alt, title %}\n// Alias: {% fi /path/to/image, alt, title %}\n\nfunction fullImage(args) {\n  args = args.join(' ').split(',');\n  var src = args[0];\n  var alt = args[1] || '';\n  var title = args[2] || '';\n\n  if (!src) {\n    hexo.log.warn('Image src can NOT be empty');\n  }\n  alt = alt.trim();\n  title = title.trim();\n\n  var image = ['<span itemprop=\"image\" itemscope itemtype=\"http://schema.org/ImageObject\"><img itemprop=\"url image\" src=\"' + src + '\" class=\"full-image\"'];\n  alt.length > 0 && image.push('alt=\"' + alt + '\"');\n  title.length > 0 && image.push('title=\"' + title + '\"');\n  image.push('/><meta itemprop=\"width\" content=\"auto\"><meta itemprop=\"height\" content=\"auto\"></span>');\n\n  return image.join(' ');\n}\n\nhexo.extend.tag.register('fullimage', fullImage);\nhexo.extend.tag.register('fi', fullImage);\n"
  },
  {
    "path": "scripts/tags/group-pictures.js",
    "content": "/* global hexo */\n// Usage: {% grouppicture group-layout %}{% endgrouppicture %}\n// Alias: {% gp group-layout %}{% endgp %}\n\nfunction groupPicture(args, content) {\n  args = args[0].split('-');\n  var group = parseInt(args[0]);\n  var layout = parseInt(args[1]);\n\n  content = hexo.render.renderSync({text: content, engine: 'markdown'});\n\n  var pictures = content.match(/<img[\\s\\S]*?>/g);\n\n  return '<div class=\"group-picture\">' +\n            templates.dispatch(pictures, group, layout) +\n         '</div>';\n}\n\nvar templates = {\n\n  dispatch: function (pictures, group, layout) {\n    var fn = 'group' + group + 'Layout' + layout;\n    fn = templates[fn] || templates.defaults;\n    return fn.call(templates, pictures);\n  },\n\n  /**\n   * 2-1\n   *\n   *  □\n   *  □\n   *\n   * @param pictures\n   * @returns {string}\n   */\n  group2Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1)\n    ]);\n  },\n\n  /**\n   * 2-2\n   *\n   * □ □\n   *\n   * @param pictures\n   */\n  group2Layout2: function (pictures) {\n    return this.getHTML(pictures);\n  },\n\n  /**\n   * 3-1\n   *\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group3Layout1: function (pictures) {\n    return this.getHTML(pictures);\n  },\n\n  /**\n   * 3-2\n   *\n   *  □\n   * □ □\n   *\n   * @param pictures\n   */\n  group3Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1)\n    ]);\n  },\n\n  /**\n   * 3-3\n   *\n   * □ □\n   *  □\n   *\n   * @param pictures\n   */\n  group3Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2)\n    ]);\n  },\n\n  /**\n   * 4-1\n   *\n   *  □\n   * □ □\n   *  □\n   *\n   * @param pictures\n   */\n  group4Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 4-2\n   *\n   *   □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group4Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1)\n    ]);\n  },\n\n  /**\n   * 4-3\n   *\n   * □ □\n   * □ □\n   *\n   * @param pictures\n   */\n  group4Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2)\n    ]);\n  },\n\n  /**\n   * 4-4\n   *\n   * □ □ □\n   *   □\n   *\n   * @param pictures\n   */\n  group4Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 5-1\n   *\n   *  □\n   * □ □\n   * □ □\n   *\n   * @param pictures\n   */\n  group5Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 5-2\n   *\n   * □ □\n   *  □\n   * □ □\n   *\n   * @param pictures\n   */\n  group5Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 5-3\n   *\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group5Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2)\n    ]);\n  },\n\n  /**\n   * 5-4\n   *\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group5Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 6-1\n   *\n   *   □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group6Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 6-2\n   *\n   *   □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group6Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 4),\n      pictures.slice(4)\n    ]);\n  },\n\n  /**\n   * 6-3\n   *\n   *  □ □\n   *   □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group6Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 6-4\n   *\n   * □ □\n   * □ □\n   * □ □\n   *\n   * @param pictures\n   */\n  group6Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4)\n    ]);\n  },\n\n  /**\n   * 6-5\n   *\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group6Layout5: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3)\n    ]);\n  },\n\n  /**\n   * 7-1\n   *\n   *  □\n   * □ □\n   * □ □\n   * □ □\n   *\n   * @param pictures\n   */\n  group7Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 7-2\n   *\n   *   □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group7Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 4),\n      pictures.slice(4)\n    ]);\n  },\n\n  /**\n   * 7-3\n   *\n   *  □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group7Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4)\n    ]);\n  },\n\n  /**\n   * 7-4\n   *\n   *  □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group7Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 7-5\n   *\n   * □ □ □\n   *  □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group7Layout5: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 8-1\n   *\n   *   □\n   *  □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group8Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 8-2\n   *\n   *   □\n   *  □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group8Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 8-3\n   *\n   *   □\n   * □ □ □\n   *  □ □\n   *  □ □\n   * @param pictures\n   */\n  group8Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 4),\n      pictures.slice(4, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 8-4\n   *\n   * □ □\n   * □ □\n   * □ □\n   * □ □\n   *\n   * @param pictures\n   */\n  group8Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 8-5\n   *\n   *  □ □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group8Layout5: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 8-6\n   *\n   * □ □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group8Layout6: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5)\n    ]);\n  },\n\n  /**\n   * 8-7\n   *\n   * □ □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group8Layout7: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 9-1\n   *\n   *   □\n   *  □ □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group9Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 3),\n      pictures.slice(3, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 9-2\n   *\n   *   □\n   * □ □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group9Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 4),\n      pictures.slice(4, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 9-3\n   *\n   *  □ □\n   *  □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group9Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 9-4\n   *\n   *  □ □\n   *  □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group9Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 9-5\n   *\n   *  □ □\n   * □ □ □\n   *  □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group9Layout5: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 5),\n      pictures.slice(5, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 9-6\n   *\n   * □ □ □\n   *  □ □\n   *  □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group9Layout6: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 9-7\n   *\n   * □ □ □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group9Layout7: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 6),\n      pictures.slice(6)\n    ]);\n  },\n\n  /**\n   * 10-1\n   *\n   *   □\n   * □ □ □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group10Layout1: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 1),\n      pictures.slice(1, 4),\n      pictures.slice(4, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 10-2\n   *\n   *  □ □\n   *  □ □\n   * □ □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group10Layout2: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 4),\n      pictures.slice(4, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 10-3\n   *\n   *  □ □\n   * □ □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group10Layout3: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 5),\n      pictures.slice(5, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 10-4\n   *\n   *  □ □\n   * □ □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group10Layout4: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 2),\n      pictures.slice(2, 5),\n      pictures.slice(5, 8),\n      pictures.slice(8)\n    ]);\n  },\n\n  /**\n   * 10-5\n   *\n   * □ □ □\n   *  □ □\n   *  □ □\n   * □ □ □\n   *\n   * @param pictures\n   */\n  group10Layout5: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5, 7),\n      pictures.slice(7)\n    ]);\n  },\n\n  /**\n   * 10-6\n   *\n   * □ □ □\n   *  □ □\n   * □ □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group10Layout6: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 5),\n      pictures.slice(5, 8),\n      pictures.slice(8)\n    ]);\n  },\n\n  /**\n   * 10-7\n   *\n   * □ □ □\n   * □ □ □\n   *  □ □\n   *  □ □\n   *\n   * @param pictures\n   */\n  group10Layout7: function (pictures) {\n    return this.getHTML([\n      pictures.slice(0, 3),\n      pictures.slice(3, 6),\n      pictures.slice(6, 8),\n      pictures.slice(8)\n    ]);\n  },\n\n  /**\n   * Defaults Layout\n   *\n   * □ □ □\n   * □ □ □\n   * ...\n   *\n   * @param pictures\n   */\n  defaults: function (pictures) {\n    var ROW_SIZE = 3;\n    var rows = pictures.length / ROW_SIZE + 1;\n    var pictureArr = [];\n\n    for (var i = 0; i < rows; i++) {\n      pictureArr.push(pictures.slice(i * ROW_SIZE, (i + 1) * ROW_SIZE));\n    }\n\n    return this.getHTML(pictureArr);\n  },\n\n  getHTML: function (rows) {\n    var rowHTML = '';\n\n    for (var i = 0; i < rows.length; i++) {\n      rowHTML += this.getRowHTML(rows[i]);\n    }\n\n    return '<div class=\"group-picture-container\">' + rowHTML + '</div>';\n  },\n\n  getRowHTML: function (pictures) {\n    return (\n      '<div class=\"group-picture-row\">' +\n        this.getColumnHTML(pictures) +\n      '</div>'\n    );\n  },\n\n  getColumnHTML: function (pictures) {\n    var columns = [];\n    var columnWidth = 100 / pictures.length;\n    var columnStyle = ' style=\"width: ' + columnWidth + '%;\"';\n\n    for (var i = 0; i < pictures.length; i++) {\n      columns.push('<div class=\"group-picture-column\" ' + columnStyle + '>' + pictures[i] + '</div>');\n    }\n    return columns.join('');\n  }\n};\n\nhexo.extend.tag.register('grouppicture', groupPicture, {ends: true});\nhexo.extend.tag.register('gp', groupPicture, {ends: true});\n"
  },
  {
    "path": "scripts/tags/label.js",
    "content": "/**\n * label.js | global hexo script.\n *\n * Usage:\n *\n * {% label [class]@Text %}\n *\n * [class] : default | primary | success | info | warning | danger.\n *           If not defined, default class will be selected.\n */\n\nfunction postLabel (args) {\n  args = args.join(' ').split('@');\n  var classes = args[0] || 'default';\n  var text = args[1] || '';\n\n  classes = classes.trim();\n  !text && hexo.log.warn('Label text must be defined!');\n\n  return '<span class=\"label ' + classes + '\">' + text + '</span>';\n}\n\nhexo.extend.tag.register('label', postLabel, { ends: false });\n"
  },
  {
    "path": "scripts/tags/lazy-image.js",
    "content": "/* global hexo */\n// Usage: {% lazyimage /path/to/image, alt, title %}\n// Alias: {% li /path/to/image, alt, title %}\n\nfunction lazyImage(args) {\n  args = args.join(' ').split(',');\n  var src = args[0];\n  var alt = args[1] || '';\n  var title = args[2] || '';\n\n  if (!src) {\n    hexo.log.warn('Image src can NOT be empty');\n  }\n  alt = alt.trim();\n  title = title.trim();\n\n  var image = ['<span itemprop=\"image\" itemscope itemtype=\"http://schema.org/ImageObject\"><img itemprop=\"url image\" src=\"/images/loading.gif\" data-original=\"' + src + '\" class=\"full-image\"'];\n  alt.length > 0 && image.push('alt=\"' + alt + '\"');\n  title.length > 0 && image.push('title=\"' + title + '\"');\n  image.push('/><meta itemprop=\"width\" content=\"auto\"><meta itemprop=\"height\" content=\"auto\"></span>');\n\n  return image.join(' ');\n}\n\nhexo.extend.tag.register('lazyimage', lazyImage);\nhexo.extend.tag.register('li', lazyImage);\n"
  },
  {
    "path": "scripts/tags/note.js",
    "content": "/**\n * note.js | global hexo script.\n *\n * ATTENTION! No need to write this tag in 1 line if u don't want see probally bugs.\n *\n * Usage:\n *\n * {% note [class] %}\n * Any content (support inline tags too).\n * {% endnote %}\n *\n * [class] : default | primary | success | info | warning | danger.\n *           May be not defined.\n */\n\nfunction bscallOut (args, content) {\n  return '<div class=\"note ' + args.join(' ') + '\">' + hexo.render.renderSync({text: content, engine: 'markdown'}).trim() + '</div>';\n}\n\nhexo.extend.tag.register('note', bscallOut, {ends: true});\n"
  },
  {
    "path": "scripts/tags/tabs.js",
    "content": "/**\n * tabs.js | global hexo script.\n *\n * Usage:\n *\n * {% tabs [Unique name], [index] %}\n * <!-- tab [Tab caption]@[icon] -->\n * Any content (support inline tags too).\n *  <!-- endtab -->\n * {% endtabs %}\n *\n * [Unique name]      : Unique name of tabs block tag without comma.\n *                      Will be used in #id's as prefix for each tab with their index numbers.\n *                      If there are whitespaces in name, for generate #id all whitespaces will replaced by dashes.\n *                      Only for current url of post/page must be unique!\n * [index]            : Index number of active tab.\n *                      If not defined, first tab (1) will be selected.\n *                      If index is -1, no tab will be selected. It's will be something like spoiler.\n *                      May be not defined.\n * [Tab caption]      : Caption of current tab.\n *                      If not caption specified, unique name with tab index suffix will be used as caption of tab.\n *                      If not caption specified, but specified icon, caption will empty.\n *                      May be not defined.\n * [icon]             : Font awesome icon.\n *                      May be not defined.\n */\n\n'use strict';\n\n  function postTabs (args, content) {\n    var tabBlock = /<!--\\s*tab (.*?)\\s*-->\\n([\\w\\W\\s\\S]*?)<!--\\s*endtab\\s*-->/g;\n\n    var args = args.join(' ').split(',');\n    var tabName = args[0];\n    var tabActive = args[1] || '';\n\n    var matches = [];\n    var match;\n    var tabId = 0;\n    var tabNav = '';\n    var tabContent = '';\n\n    !tabName && hexo.log.warn('Tabs block must have unique name!');\n\n    while (match = tabBlock.exec(content)) {\n      matches.push(match[1]);\n      matches.push(match[2]);\n    }\n\n    for (var i = 0; i < matches.length; i += 2) {\n      var tabParameters = matches[i].split('@');\n      var postContent = matches[i + 1];\n      var tabCaption = tabParameters[0] || '';\n      var tabIcon = tabParameters[1] || '';\n      var tabHref =  '';\n\n      postContent = hexo.render.renderSync({text: postContent, engine: 'markdown'});\n\n      tabId += 1;\n      tabHref = (tabName + ' ' + tabId).toLowerCase().split(' ').join('-');\n\n      ((tabCaption.length === 0) && (tabIcon.length === 0)) && (tabCaption = tabName + ' ' + tabId);\n\n      var isOnlyicon = (tabIcon.length > 0 && tabCaption.length === 0) ? 'style=\"text-align: center;' : '';\n      tabIcon.length > 0 && (tabIcon = '<i class=\"fa fa-' + tabIcon.trim() + '\"' + isOnlyicon + '\"></i>');\n\n      var isActive = ((tabActive.length > 0 && tabActive == tabId) || (tabActive.length === 0 && tabId == 1)) ? ' active' : '';\n      tabNav += '<li class=\"tab' + isActive + '\"><a href=\"#' + tabHref + '\">' + tabIcon + tabCaption + '</a></li>';\n      tabContent += '<div class=\"tab-pane' + isActive + '\" id=\"' + tabHref + '\">' + postContent + '</div>';\n    }\n\n    tabNav = '<ul class=\"nav-tabs\">' + tabNav + '</ul>';\n    tabContent = '<div class=\"tab-content\">' + tabContent + '</div>';\n\n    return '<div class=\"tabs\" id=\"' + tabName.toLowerCase().split(' ').join('-') + '\">' + tabNav + tabContent + '</div>';\n  }\n\n  hexo.extend.tag.register('tabs', postTabs, {ends: true});\n"
  },
  {
    "path": "source/css/_common/components/back-to-top-sidebar.styl",
    "content": ".back-to-top {\n  display: none;\n  margin: 20px -10px -20px;\n  background: $body-bg-color;\n  font-size: $b2t-font-size;\n  opacity: $b2t-opacity;\n  cursor: pointer;\n  text-align: center;\n  -webkit-transform: translateZ(0);\n  the-transition();\n    &:hover { opacity: 0.8; }\n\n  +tablet() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n  +mobile() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n\n  &.back-to-top-on {\n    display: block;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/back-to-top.styl",
    "content": ".back-to-top {\n  box-sizing: border-box;\n  position: fixed;\n  bottom: $b2t-position-bottom;\n  right: $b2t-position-right;\n  z-index: $zindex-5;\n  padding: 0 6px;\n  width: hexo-config('sidebar.scrollpercent') ? initial : 24px;\n  background: $b2t-bg-color;\n  font-size: $b2t-font-size;\n  opacity: $b2t-opacity;\n  color: $b2t-color;\n  cursor: pointer;\n  text-align: center;\n  -webkit-transform: translateZ(0);\n  transition-property: bottom;\n  the-transition();\n\n  +tablet() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n  +mobile() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n\n  &.back-to-top-on {\n    bottom: $b2t-position-bottom-on;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/buttons.styl",
    "content": ".btn {\n  display: inline-block;\n  padding: 0 20px;\n  font-size: $btn-default-font-size;\n  color: $btn-default-color;\n  background: $btn-default-bg;\n  border: $btn-default-border-width solid $btn-default-border-color;\n  text-decoration: none;\n  border-radius: $btn-default-radius;\n  transition-property: background-color;\n  the-transition();\n  line-height: 2;\n\n  &:hover {\n    border-color: $btn-default-hover-border-color;\n    color: $btn-default-hover-color;\n    background: $btn-default-hover-bg;\n  }\n\n  +.btn {\n    margin: 0 0 8px 8px;\n  }\n\n  .fa-fw {\n    width: (18em / 14);\n    text-align: left;\n  }\n}\n\n.btn-bar {\n  display: block;\n  width: 22px;\n  height: 2px;\n  background: $text-color;\n  border-radius: 1px;\n\n  &+.btn-bar { margin-top: 4px; }\n}\n"
  },
  {
    "path": "source/css/_common/components/comments.styl",
    "content": ".comments { margin: 60px 20px 0; }\n"
  },
  {
    "path": "source/css/_common/components/components.styl",
    "content": "@import \"highlight\";\n@import \"tags\";\n\n@import \"buttons\";\n@import \"pagination\";\n@import \"comments\";\n@import \"tag-cloud\";\n@import hexo-config('sidebar.b2t') ? \"back-to-top-sidebar\" : \"back-to-top\";\n\n@import \"header\";\n@import \"post\";\n@import \"sidebar\";\n@import \"footer\";\n@import \"third-party\";\n\n@import \"pages\";\n"
  },
  {
    "path": "source/css/_common/components/footer/footer.styl",
    "content": ".footer {\n  font-size: 14px;\n  color: $grey-dark;\n\n  img { border: none; }\n}\n\n.footer-inner { text-align: center; }\n\n.with-love {\n  display: inline-block;\n  margin: 0 5px;\n}\n\n.powered-by,\n.theme-info { display: inline-block; }\n\n.cc-license {\n  margin-top: 10px;\n  text-align: center;\n\n  .cc-opacity {\n    opacity: 0.7;\n    border-bottom: none;\n\n    &:hover { opacity: 0.9; }\n  }\n\n  img { display: inline-block; }\n}\n"
  },
  {
    "path": "source/css/_common/components/header/header.styl",
    "content": ".header { background: $head-bg; }\n\n.header-inner { position: relative; }\n\n\n@import \"headerband\";\n@import \"site-meta\";\n@import \"site-nav\";\n@import \"menu\";\n"
  },
  {
    "path": "source/css/_common/components/header/headerband.styl",
    "content": ".headband {\n  height: $headband-height;\n  background: $headband-bg;\n}\n"
  },
  {
    "path": "source/css/_common/components/header/menu.styl",
    "content": "// Menu\n// --------------------------------------------------\n.menu {\n  margin-top: 20px;\n  padding-left: 0;\n  text-align: center;\n}\n\n.menu .menu-item {\n  display: inline-block;\n  margin: 0 10px;\n  list-style: none;\n\n  @media screen and (max-width: 767px) {\n    margin-top: 10px;\n  }\n\n  a {\n    display: block;\n    font-size: 13px;\n    line-height: inherit;\n    border-bottom: 1px solid $menu-link-border;\n    transition-property: border-color;\n    the-transition();\n\n    &:hover { border-bottom-color: $menu-link-hover-border; }\n  }\n\n  .fa { margin-right: 5px; }\n}\n\n.use-motion .menu-item { opacity: 0; }\n"
  },
  {
    "path": "source/css/_common/components/header/site-meta.styl",
    "content": ".site-meta {\n  margin: 0;\n  text-align: $site-meta-text-align;\n\n  +mobile() { text-align: center; }\n}\n\n.brand {\n  position: relative;\n  display: inline-block;\n  padding: 0 40px;\n  color: $brand-color;\n  background: $brand-bg;\n  border-bottom: none;\n  &:hover { color: $brand-hover-color; }\n}\n\n.logo {\n  display: inline-block;\n  margin-right: 5px;\n  line-height: 36px;\n  vertical-align: top;\n}\n\n.site-title {\n  display: inline-block;\n  vertical-align: top;\n  line-height: 36px;\n  font-size: $logo-font-size;\n  font-weight: normal;\n  font-family: $font-family-logo;\n}\n\n.site-subtitle {\n  margin-top: 10px;\n  font-size: $subtitle-font-size;\n  color: $subtitle-color;\n}\n\n.use-motion {\n  .brand { opacity: 0; }\n\n  .logo, .site-title, .site-subtitle {\n    opacity: 0;\n    position: relative;\n    top: -10px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/header/site-nav.styl",
    "content": ".site-nav-toggle {\n  display: none;\n  position: absolute;\n  top: 10px;\n  left: 10px;\n  +mobile() {\n    display: block;\n  }\n\n  button {\n    margin-top: 2px;\n    padding: 9px 10px;\n    background: transparent;\n    border: none;\n  }\n}\n\n.site-nav {\n  +mobile() {\n    display: none;\n    margin: 0 -10px;\n    padding: 0 10px;\n    clear: both;\n    border-top: 1px solid $gray-lighter;\n  }\n  +tablet() { display: block !important; }\n  +desktop() { display: block !important; }\n}\n"
  },
  {
    "path": "source/css/_common/components/highlight/diff.styl",
    "content": "$highlight_theme = hexo-config(\"highlight_theme\")\n\nif $highlight_theme == \"normal\"\n  $highlight-deletion     = #fdd\n  $highlight-addition     = #dfd\nelse\n  $highlight-deletion     = #008000\n  $highlight-addition     = #800000\n"
  },
  {
    "path": "source/css/_common/components/highlight/highlight.styl",
    "content": "// https://github.com/chriskempson/tomorrow-theme\n\n@require \"theme\"\n@require \"diff\"\n\n// Placeholder: $code-block\n$code-block {\n  overflow: auto;\n  margin: 20px 0;\n  padding: 0;\n  font-size $code-font-size;\n  color: $highlight-foreground;\n  background: $highlight-background;\n  line-height: $line-height-code-block;\n}\n\npre, code { font-family: $code-font-family; }\n\ncode {\n  padding: 2px 4px;\n  word-wrap: break-word;\n  color: $code-foreground;\n  background: $code-background;\n  border-radius: $code-border-radius;\n  font-size $code-font-size;\n}\n\npre {\n  @extend $code-block;\n  padding: 10px;\n\n  code {\n    padding: 0;\n    color: $highlight-foreground;\n    background: none;\n    text-shadow: none;\n  }\n}\n\n.highlight {\n  @extend $code-block;\n  border-radius: 1px\n\n  pre {\n    border: none;\n    margin: 0;\n    padding: 10px 0;\n  }\n\n  table {\n    margin: 0;\n    width: auto;\n    border: none;\n  }\n\n  td {\n    border: none;\n    padding: 0;\n  }\n\n  figcaption {\n    clearfix();\n    font-size: 1em;\n    color: $highlight-foreground;\n    line-height: 1em;\n    margin-bottom: 1em;\n\n    a {\n      float: right;\n      color: $highlight-foreground;\n\n      &:hover { border-bottom-color: $highlight-foreground; }\n    }\n  }\n\n  .gutter pre {\n    padding-left: 10px\n    padding-right: 10px\n    color: $highlight-gutter.color\n    text-align: right\n    background-color: $highlight-gutter.bg-color\n  }\n\n  .code pre {\n    width: 100%\n    padding-left: 10px\n    padding-right: 10px\n    background-color: $highlight-background\n  }\n\n  .line { height: 20px; }\n}\n\n\n.gutter {\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n\n.gist table {\n  width: auto;\n\n  td { border: none; }\n}\n\n// For diff highlight\npre .deletion { background: $highlight-deletion; }\npre .addition { background: $highlight-addition; }\npre .meta     { color: $highlight-purple; }\n\npre {\n\n  .comment { color: $highlight-comment; }\n\n  .variable\n  .attribute\n  .tag\n  .regexp\n  .ruby .constant\n  .xml .tag .title\n  .xml .pi\n  .xml .doctype\n  .html .doctype\n  .css .id\n  .css .class\n  .css .pseudo {\n    color: $highlight-red;\n  }\n\n  .number\n  .preprocessor\n  .built_in\n  .literal\n  .params\n  .constant\n  .command {\n    color: $highlight-orange;\n  }\n\n  .ruby .class .title\n  .css .rules .attribute\n  .string\n  .value\n  .inheritance\n  .header\n  .ruby .symbol\n  .xml .cdata\n  .special\n  .number\n  .formula {\n    color: $highlight-green;\n  }\n\n  .title\n  .css .hexcolor {\n    color: $highlight-aqua;\n  }\n\n  .function\n  .python .decorator\n  .python .title\n  .ruby .function .title\n  .ruby .title .keyword\n  .perl .sub\n  .javascript .title\n  .coffeescript .title {\n    color: $highlight-blue;\n  }\n\n  .keyword\n  .javascript .function {\n    color: $highlight-purple;\n  }\n\n}\n"
  },
  {
    "path": "source/css/_common/components/highlight/theme.styl",
    "content": "$highlight_theme = hexo-config(\"highlight_theme\")\n\n\nif $highlight_theme == \"normal\"\n  $highlight-background   = #f7f7f7\n  $highlight-current-line = #efefef\n  $highlight-selection    = #d6d6d6\n  $highlight-foreground   = #4d4d4c\n  $highlight-comment      = #8e908c\n  $highlight-red          = #c82829\n  $highlight-orange       = #f5871f\n  $highlight-yellow       = #eab700\n  $highlight-green        = #718c00\n  $highlight-aqua         = #3e999f\n  $highlight-blue         = #4271ae\n  $highlight-purple       = #8959a8\n  $highlight-gutter       = {\n    color: #869194,\n    bg-color: #eff2f3\n  }\n\nif $highlight_theme == \"night\"\n  $highlight-background   = #1d1f21\n  $highlight-current-line = #282a2e\n  $highlight-selection    = #373b41\n  $highlight-foreground   = #c5c8c6\n  $highlight-comment      = #969896\n  $highlight-red          = #cc6666\n  $highlight-orange       = #de935f\n  $highlight-yellow       = #f0c674\n  $highlight-green        = #b5bd68\n  $highlight-aqua         = #8abeb7\n  $highlight-blue         = #81a2be\n  $highlight-purple       = #b294bb\n  $highlight-gutter       = {\n    color: lighten($highlight-background, 50%),\n    bg-color: darken($highlight-background, 100%)\n  }\n\nif $highlight_theme == \"night eighties\"\n  $highlight-background   = #2d2d2d\n  $highlight-current-line = #393939\n  $highlight-selection    = #515151\n  $highlight-foreground   = #cccccc\n  $highlight-comment      = #999999\n  $highlight-red          = #f2777a\n  $highlight-orange       = #f99157\n  $highlight-yellow       = #ffcc66\n  $highlight-green        = #99cc99\n  $highlight-aqua         = #66cccc\n  $highlight-blue         = #6699cc\n  $highlight-purple       = #cc99cc\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: darken($highlight-background, 40%)\n  }\n\nif $highlight_theme == \"night blue\"\n  $highlight-background   = #002451\n  $highlight-current-line = #00346e\n  $highlight-selection    = #003f8e\n  $highlight-foreground   = #ffffff\n  $highlight-comment      = #7285b7\n  $highlight-red          = #ff9da4\n  $highlight-orange       = #ffc58f\n  $highlight-yellow       = #ffeead\n  $highlight-green        = #d1f1a9\n  $highlight-aqua         = #99ffff\n  $highlight-blue         = #bbdaff\n  $highlight-purple       = #ebbbff\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: darken($highlight-background, 60%)\n  }\n\nif $highlight_theme == \"night bright\"\n  $highlight-background   = #000000\n  $highlight-current-line = #2a2a2a\n  $highlight-selection    = #424242\n  $highlight-foreground   = #eaeaea\n  $highlight-comment      = #969896\n  $highlight-red          = #d54e53\n  $highlight-orange       = #e78c45\n  $highlight-yellow       = #e7c547\n  $highlight-green        = #b9ca4a\n  $highlight-aqua         = #70c0b1\n  $highlight-blue         = #7aa6da\n  $highlight-purple       = #c397d8\n  $highlight-gutter       = {\n    color: lighten($highlight-background, 40%),\n    bg-color: lighten($highlight-background, 16%)\n  }\n"
  },
  {
    "path": "source/css/_common/components/pages/archive.styl",
    "content": ".page-archive {\n\n  .archive-page-counter {\n    position: relative;\n    top: 3px;\n    left: 20px;\n\n    +mobile() {\n      top: 5px;\n    }\n  }\n\n  .posts-collapse {\n\n    .archive-move-on {\n      position: absolute;\n      top: 11px;\n      left: 0;\n      margin-left: -6px;\n      width: 10px;\n      height: 10px;\n      opacity: 0.5;\n      background: $black-light;\n      border: 1px solid white;\n\n      circle();\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/categories.styl",
    "content": ".category-all-page {\n  .category-all-title { text-align: center; }\n\n  .category-all { margin-top: 20px; }\n\n  .category-list {\n    margin: 0;\n    padding: 0;\n    list-style: none;\n  }\n\n  .category-list-item { margin: 5px 10px; }\n\n  .category-list-count {\n    color: $grey;\n    &:before {\n      display: inline;\n      content: \" (\"\n    }\n    &:after {\n      display: inline;\n      content: \") \"\n    }\n  }\n\n  .category-list-child { padding-left: 10px; }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/pages.styl",
    "content": "// Page specific styles\n\n@import \"archive\";\n@import \"categories\";\n@import \"schedule\";\n@import \"post-detail\";\n"
  },
  {
    "path": "source/css/_common/components/pages/post-detail.styl",
    "content": ".page-post-detail {\n\n  .sidebar-toggle-line { background: $sidebar-highlight; }\n\n  .comments { overflow: hidden; }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/schedule.styl",
    "content": "@keyframes dot-flash {\n    from {opacity: 1; transform:scale(1.1);}\n    to {opacity: 0; transform:scale(1);}\n}\n\n#schedule {\n  ul#event-list {\n    padding-left: 30px\n    hr {\n      margin: 20px 0 45px 0!important\n      background: #222\n        &:after {\n          display: inline-block\n          content: 'NOW'\n          background: #222\n          color: #FFF\n          font-weight:bold\n          text-align: right\n          padding: 0 5px\n        }\n    }\n    li.event {\n      margin: 20px 0px\n      background: #F9F9F9\n      padding-left: 10px\n      min-height: 40px\n      h2.event-summary {\n        margin: 0\n        padding-bottom: 3px\n        &:before {\n          display: inline-block\n          font-family: FontAwesome\n          font-size: 8px\n          content: '\\f111'\n          vertical-align: middle\n          margin-right: 25px\n          color: #bbb\n        }\n      }\n      span.event-relative-time {\n        display: inline-block\n        font-size: 12px\n        font-weight: 400\n        padding-left: 12px\n        color: #bbb\n      }\n      span.event-details {\n        display: block\n        color: #bbb\n        margin-left: 56px\n        padding-top: 3px\n        padding-bottom: 6px\n        text-indent: -24px\n        line-height: 18px\n        &:before {\n          text-indent: 0\n          display: inline-block\n          width: 14px\n          font-family: FontAwesome\n          text-align: center\n          margin-right: 9px\n          color: #bbb\n        }\n        &.event-location:before {\n          content: '\\f041'\n        }\n        &.event-duration:before {\n          content: '\\f017'\n        }\n      }\n    }\n    li.event-past {\n      background: #FCFCFC\n      & > * {\n        opacity: .6\n      }\n      h2.event-summary {\n        color: #bbb\n        &:before {\n          color: #DFDFDF\n        }\n      }\n    }\n    li.event-now {\n      background: #222\n      color: #FFF\n      padding: 15px 0 15px 10px\n      h2.event-summary {\n        &:before {\n          transform: scale(1.2)\n          color: #FFF\n          animation: dot-flash 1s alternate infinite ease-in-out;\n        }\n      }\n      * {\n        color: #FFF!important\n      }\n    }\n  }\n}\n\n"
  },
  {
    "path": "source/css/_common/components/pagination.styl",
    "content": ".pagination {\n  margin: 120px 0 40px;\n  text-align: center;\n  border-top: 1px solid $pagination-border;\n}\n\n.page-number-basic {\n  display: inline-block;\n  position: relative;\n  top: -1px;\n  margin: 0 10px;\n  padding: 0 11px;\n\n  +mobile() { margin: 0 5px; }\n}\n\n.pagination {\n  .prev, .next, .page-number {\n    @extend .page-number-basic;\n    border-bottom: 0;\n    border-top: 1px solid $pagination-link-border;\n    transition-property: border-color;\n    the-transition();\n\n    &:hover { border-top-color: $pagination-link-hover-border; }\n  }\n\n  .space {\n    @extend .page-number-basic;\n    padding: 0;\n    margin: 0;\n  }\n\n  .prev { margin-left: 0; }\n  .next { margin-right: 0; }\n\n  .page-number.current {\n    color: $pagination-active-color;\n    background: $pagination-active-bg;\n    border-top-color: $pagination-active-border;\n  }\n}\n\n@media (max-width: 767px)\n  .pagination { border-top: none; }\n\n  .pagination {\n    .prev, .next, .page-number {\n      margin-bottom: 10px;\n      border-top: 0;\n      border-bottom: 1px solid $pagination-link-border;\n      padding: 0 10px;\n\n      &:hover { border-bottom-color: $pagination-link-hover-border; }\n    }\n  }\n"
  },
  {
    "path": "source/css/_common/components/post/post-button.styl",
    "content": ".post-button {\n  margin-top: 40px;\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-collapse.styl",
    "content": "// TODO: Refactor.\n\n@media (max-width: 767px) {\n  .posts-collapse {\n    margin: 0 20px;\n\n    .post-title, .post-meta {\n      display: block;\n      width: auto;\n      text-align: left;\n    }\n  }\n}\n\n.posts-collapse {\n  position: relative;\n  z-index: $zindex-1;\n  \n  &::after {\n    content: \" \";\n    position: absolute;\n    top: 20px;\n    left: 0;\n    margin-left: -2px;\n    width: 4px;\n    height: 100%;\n    background: $whitesmoke;\n    z-index: $zindex-bottom;\n  }\n\n  margin-left: $posts-collapse-left;\n  +mobile() { margin: 0 20px; }\n\n  .collection-title {\n    position: relative;\n    margin: 60px 0;\n\n    h1, h2 { margin-left: 20px; }\n\n    small { color: $grey; margin-left: 5px; }\n\n    &::before {\n      content: \" \";\n      position: absolute;\n      left: 0;\n      top: 50%;\n      margin-left: -4px;\n      margin-top: -4px;\n      width: 8px;\n      height: 8px;\n      background: $grey;\n      circle();\n    }\n  }\n\n  .post { margin: 30px 0; }\n\n  .post-header {\n    position: relative;\n    the-transition();\n    transition-property: border;\n    border-bottom: 1px dashed $grey-light;\n\n    &::before {\n      content: \" \";\n      position: absolute;\n      left: 0;\n      top: 12px;\n      width: 6px;\n      height: 6px;\n      margin-left: -4px;\n      background: $grey;\n      circle();\n      border: 1px solid white;\n      the-transition();\n      transition-property: background;\n    }\n  }\n\n  .post-header:hover {\n    border-bottom-color: $grey-dim;\n\n    &::before { background: $black-deep; }\n  }\n\n  .post-meta {\n    position: absolute;\n    font-size: 12px;\n    left: 20px;\n    top: 5px;\n  }\n\n  .post-comments-count { display: none; }\n\n  .post-title {\n    margin-left: 60px;\n    font-size: 16px;\n    font-weight: normal;\n    line-height: inherit;\n\n    &::after {\n      margin-left: 3px;\n      opacity: 0.6;\n    }\n\n    a {\n      color: $grey-dim;\n      border-bottom: none;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-copyright.styl",
    "content": ".post-copyright {\n  margin: $post-copyright.margin;\n  padding: $post-copyright.padding;\n  border-left: $post-copyright.border.width $post-copyright.border.style $post-copyright.border.color;\n  background-color: $post-copyright.bg;\n  list-style: none;\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-eof.styl",
    "content": ".posts-expand {\n  .post-eof {\n    display: block;\n    margin: $post-eof-margin-top auto $post-eof-margin-bottom;\n    width: 8%;\n    height: 1px;\n    background: $grey-light;\n    text-align: center;\n  }\n}\n\n\n.post:last-child {\n  .post-eof.post-eof.post-eof {\n    display: none;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-expand.styl",
    "content": "// TODO: Refactor.\n\n.posts-expand {\n  padding-top: 40px;\n}\n\n@media (max-width: 767px) {\n  .posts-expand {\n    margin: 0 20px;\n  }\n\n  .post-body {\n    pre {\n      .gutter pre {\n        padding-right: 10px;\n      }\n    }\n\n    .highlight {\n      margin-left: 0px;\n      margin-right: 0px;\n      padding: 0;\n      .gutter pre {\n        padding-right: 10px;\n      }\n    }\n  }\n}\n\n.posts-expand .post-body {\n  +desktop() { text-align: justify; }\n\n\n  h2, h3, h4, h5, h6 {\n    padding-top: 10px;\n\n    .header-anchor{\n      float: right;\n      margin-left: 10px;\n      color: $grey-light;\n      border-bottom-style: none;\n      visibility: hidden;\n\n      &:hover{\n        color: inherit;\n      }\n    }\n\n    &:hover .header-anchor{\n      visibility: visible;\n    }\n  }\n\n  ul li { list-style: circle; }\n\n  img {\n    box-sizing: border-box;\n    margin: auto;\n    padding: 3px;\n    border: 1px solid $gray-lighter;\n  }\n}\n\n.posts-expand .post-body .fancybox img { margin: 0 auto 25px; }\n"
  },
  {
    "path": "source/css/_common/components/post/post-gallery.styl",
    "content": ".post-gallery {\n  display: table;\n  table-layout: fixed;\n  width: 100%;\n  border-collapse: separate;\n}\n\n.post-gallery-row { display: table-row; }\n\n.post-gallery .post-gallery-img {\n  display: table-cell;\n  text-align: center;\n  vertical-align: middle;\n  border: none;\n}\n\n.post-gallery .post-gallery-img img {\n  max-width: 100%;\n  max-height: 100%;\n  border: none;\n}\n\n.fancybox-close, .fancybox-close:hover { border: none; }\n"
  },
  {
    "path": "source/css/_common/components/post/post-meta.styl",
    "content": ".posts-expand .post-meta {\n  margin: 3px 0 60px 0;\n  color: $grey-dark;\n  font-family: $font-family-posts;\n  font-size: 12px;\n  text-align: center;\n\n  .post-category-list {\n    display: inline-block;\n    margin: 0;\n    padding: 3px;\n  }\n  .post-category-list-link { color: $grey-dark; }\n  \n  .post-description {\n    font-size: 14px;\n    margin-top: 2px;\n  }\n}\n\n.post-wordcount {\n  if !hexo-config('post_wordcount.separated_meta') { display: inline-block; }\n}\n\n.post-meta-divider {\n  margin: 0 .5em;\n}\n\n.post-meta-item-icon {\n  margin-right: 3px;\n  +tablet() {\n    display: inline-block;\n  }\n  +mobile() {\n    display: inline-block;\n  }\n}\n.post-meta-item-text {\n  +tablet() {\n    display: none;\n  }\n  +mobile() {\n    display: none;\n  }\n}\n\n.posts-expand .post-comments-count {\n  +mobile() { display: none; }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-nav.styl",
    "content": ".post-nav {\n  display: table;\n  margin-top: 15px;\n  width: 100%;\n  border-top: 1px solid $gainsboro;\n}\n\n.post-nav-divider {\n  display: table-cell;\n  width: 10%;\n}\n\n.post-nav-item {\n  display: table-cell;\n  padding: 10px 0 0 0;\n  width: 45%;\n  vertical-align: top;\n\n  a {\n    position: relative;\n    display: block;\n    line-height: 25px;\n    font-size: 14px;\n    color: $link-color;\n    border-bottom: none;\n\n    &:hover {\n      color: $link-hover-color;\n      border-bottom: none;\n    }\n\n    &:active { top: 2px; }\n  }\n\n  .fa {\n    position: absolute;\n    top: 8px;\n    left: 0;\n    font-size: 12px;\n  }\n\n}\n\n.post-nav-next {\n  a { padding-left: 15px; }\n}\n\n.post-nav-prev {\n  text-align: right;\n\n  a { padding-right: 15px; }\n\n  .fa {\n    right: 0;\n    left: auto;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-reward.styl",
    "content": "#rewardButton {\n    cursor: pointer;\n    border: 0;\n    outline: 0;\n    border-radius: 5px;\n    padding: 0;\n    margin: 0;\n    letter-spacing: normal;\n    text-transform: none;\n    text-indent: 0px;\n    text-shadow: none;\n}\n#rewardButton span {\n    display: inline-block;\n    width: 80px;\n    height: 35px;\n    border-radius: 5px;\n    color: #fff;\n    font-weight: 400;\n    font-style: normal;\n    font-variant: normal;\n    font-stretch: normal;\n    font-size: 18px;\n    font-family: \"Microsoft Yahei\";\n    background: #F44336;\n}\n#rewardButton span:hover{\n    background: #F7877F;\n}\n#QR{\n    padding-top:20px;\n}\n#QR a{\n    border:0;\n}\n#QR img{\n    width: 180px;\n    max-width: 100%;\n    display: inline-block;\n    margin: 0.8em 2em 0 2em;\n}\n#wechat:hover p{\n    animation: roll 0.1s infinite linear;\n    -webkit-animation: roll 0.1s infinite linear;\n    -moz-animation: roll 0.1s infinite linear;\n}\n#alipay:hover p{\n    animation: roll 0.1s infinite linear;\n    -webkit-animation: roll 0.1s infinite linear;\n    -moz-animation: roll 0.1s infinite linear;\n}\n#bitcoin:hover p {\n    animation: roll 0.1s infinite linear;\n    -webkit-animation: roll 0.1s infinite linear;\n    -moz-animation: roll 0.1s infinite linear;\n}\n@keyframes roll {\n    from {\n      transform(rotateZ(30deg));\n    }\n    to {\n      transform(rotateZ(-30deg));\n    }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-rtl.styl",
    "content": ".rtl {\n  &.post-body {\n    p, a, h1, h2, h3, h4, h5, h6, li, ul, ol {\n      direction: rtl;\n      font-family: UKIJ Ekran;\n    }\n  }\n  &.post-title {\n    font-family: UKIJ Ekran;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-tags.styl",
    "content": ".posts-expand .post-tags {\n  margin-top: 40px;\n  text-align: center;\n\n  a {\n    display: inline-block;\n    margin-right: 10px;\n    font-size: 13px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-title.styl",
    "content": ".posts-expand .post-title {\n  text-align: center;\n  word-break: break-word;\n  font-weight: $posts-expand-title-font-weight\n}\n.posts-expand .post-title-link {\n  display: inline-block;\n  position: relative;\n  color: $black-light;\n  border-bottom: none;\n  line-height: 1.2;\n  vertical-align: top;\n\n  &::before {\n    content: \"\";\n    position: absolute;\n    width: 100%;\n    height: 2px;\n    bottom: 0;\n    left: 0;\n    background-color: #000;\n    visibility: hidden;\n    transform: scaleX(0);\n    the-transition();\n  }\n\n  &:hover::before {\n    visibility: visible;\n    transform: scaleX(1);\n  }\n\n  .fa { font-size: 16px; }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-type.styl",
    "content": "// TODO: Refactor.\n\n.page-home, .page-post-detail {\n  .post-type-quote {\n    .post-header,\n    .post-tags {\n      display: none;\n    }\n\n    blockquote {\n      @extend .blockquote-center\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-widgets.styl",
    "content": ".post-widgets {\n  border-top: 1px solid #eee;\n  padding-top: 9px;\n  margin-top: 45px;\n  display: flex;\n  justify-content: center;\n  flex-wrap: wrap;\n  align-items: center;\n\n  .post-meta-divider {\n    height: 28px;\n    color: $grey-dark;\n  }\n}\n\n.wp_rating {\n  height: 20px;\n  margin-right: 10px;\n  text-align: center;\n  line-height: 20px;\n  padding-top: 6px;\n}\n\n.social-like {\n  font-size: 14px;\n  text-align: center;\n  display: flex;\n  justify-content: center;\n}\n\n.vk_like {\n  width: 85px;\n  height: 21px;\n  padding-top: 7px;\n  align-self: center;\n}\n\n.fb_like {\n  height: 30px;\n  align-self: center;\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post.styl",
    "content": ".post-body {\n  font-family: $font-family-posts;\n  +mobile() {\n    word-break: break-word;\n  }\n}\n\n.post-body .fancybox img {\n  display: block !important;\n  margin: 0 auto;\n  cursor: pointer;\n  cursor: zoom-in;\n  cursor: -webkit-zoom-in;\n}\n\n.post-body .image-caption {\n  margin: -20px auto 15px;\n  text-align: center;\n  font-size: $font-size-base;\n  color: $grey-dark;\n  font-weight: bold;\n  line-height: 1;\n}\n\n.post-body .figure .caption {\n  @extend .post-body .image-caption;\n}\n\n.post-sticky-flag {\n  display: inline-block;\n  font-size: 16px;\n  -ms-transform: rotate(30deg);\n  transform: rotate(30deg);\n}\n\n.use-motion {\n  if hexo-config('motion.transition.post_block') {\n    .post-block,\n    .pagination,\n    .comments { opacity: 0; }\n  }\n  if hexo-config('motion.transition.post_header') { .post-header { opacity: 0; } }\n  if hexo-config('motion.transition.post_body') { .post-body { opacity: 0; } }\n  if hexo-config('motion.transition.coll_header') { .collection-title { opacity: 0; } }\n}\n\n@import \"post-expand\";\n@import \"post-collapse\";\n@import \"post-type\";\n@import \"post-title\";\n@import \"post-meta\";\n@import \"post-button\";\n@import \"post-tags\";\n@import \"post-nav\";\n@import \"post-eof\";\n@import \"post-gallery\";\n@import \"post-reward\" if hexo-config('alipay') or hexo-config('wechatpay') or hexo-config('bitcoin');\n@import \"post-copyright\" if hexo-config('post_copyright.enable');\n@import \"post-widgets\" if (hexo-config('facebook_sdk.enable') and hexo-config('facebook_sdk.like_button')) or (hexo-config('vkontakte_api.enable') and hexo-config('vkontakte_api.like')) or hexo-config('rating.enable') or (hexo-config('needmoreshare2.enable') and hexo-config('needmoreshare2.postbottom.enable'));\n@import \"post-rtl\";\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-author-links.styl",
    "content": ".links-of-author {\n  margin-top: 20px;\n}\n\n.links-of-author a {\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 10px;\n  margin-bottom: 10px;\n  border-bottom-color: $black-light;\n  font-size: 13px;\n\n  &:before {\n    display: inline-block;\n    vertical-align: middle;\n    margin-right: 3px;\n    content: \" \";\n    width: 4px;\n    height: 4px;\n    border-radius: 50%;\n    background: rgb(random-color(0, 255) - 50%, random-color(0, 255) - 50%, random-color(0, 255) - 50%);\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-author.styl",
    "content": ".site-author-image {\n  display: block;\n  margin: 0 auto;\n  padding: $site-author-image-padding;\n  max-width: $site-author-image-width;\n  height: $site-author-image-height;\n  border: $site-author-image-border-width solid $site-author-image-border-color;\n}\n\n.site-author-name {\n  margin: $site-author-name-margin;\n  text-align: $site-author-name-align;\n  color: $site-author-name-color;\n  font-weight: $site-author-name-weight;\n}\n\n.site-description {\n  margin-top: $site-description-margin-top;\n  text-align: $site-description-align;\n  font-size: $site-description-font-size;\n  color: $site-description-color;\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-blogroll.styl",
    "content": ".links-of-blogroll { font-size: 13px; }\n\n.links-of-blogroll-title {\n  margin-top: 20px;\n  font-size: 14px;\n  font-weight: $font-weight-bold;\n}\n.links-of-blogroll-list {\n  margin: 0;\n  padding: 0;\n  list-style: none;\n}\n\n.links-of-blogroll-item {\n  padding: 2px 10px;\n\n  a {\n    max-width: 280px;\n    box-sizing: border-box;\n    display: inline-block;\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-dimmer.styl",
    "content": ".sidebar-active #sidebar-dimmer {\n  opacity: .7;\n  -webkit-transform: translateX(-150%);\n  transform: translateX(-150%);\n  transition: opacity .2s;\n}\n\n#sidebar-dimmer {\n  display: none;\n  position: absolute;\n  top: 0;\n  left: 100%;\n  width: 200%;\n  height: 100%;\n  background: #000;\n  opacity: 0;\n  transition: opacity .2s,transform 0s .2s;\n  +mobile() {\n    display: block;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-feed-link.styl",
    "content": ".feed-link {\n  margin-top: 20px;\n\n  a {\n    display: inline-block;\n    padding: 0 15px;\n    color: rgb(252, 100, 35);\n    border: 1px solid rgb(252, 100, 35);\n    border-radius: 4px;\n\n    i {\n      color: rgb(252, 100, 35);\n      font-size: 14px;\n    }\n\n    &:hover {\n      color:white;\n      background: rgb(252, 100, 35);\n\n      i { color: white; }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-nav.styl",
    "content": "// Sidebar Navigation\n\n.sidebar-nav {\n  margin: 0 0 20px;\n  padding-left: 0;\n}\n.sidebar-nav li {\n  display: inline-block;\n  cursor: pointer;\n  border-bottom: 1px solid transparent;\n  font-size: 14px;\n  color: $sidebar-nav-color;\n\n  &:hover { color: $sidebar-nav-hover-color; }\n}\n\n.page-post-detail .sidebar-nav-toc { padding: 0 5px; }\n\n.page-post-detail .sidebar-nav-overview { margin-left: 10px; }\n\n.sidebar-nav .sidebar-nav-active {\n  color: $sidebar-highlight;\n  border-bottom-color: $sidebar-highlight;\n\n  &:hover { color: $sidebar-highlight; }\n}\n\n.sidebar-panel { display: none; }\n.sidebar-panel-active { display: block; }\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-toc.styl",
    "content": "\n.post-toc-empty {\n  font-size: 14px;\n  color: $grey-dim;\n}\n\n.post-toc-wrap { overflow: hidden; }\n\n.post-toc { overflow: auto; }\n\n.post-toc ol {\n  margin: 0;\n  padding: 0 2px 5px 10px;\n  text-align: left;\n  list-style: none;\n  font-size: 14px;\n\n  & > ol { padding-left: 0; }\n\n  a {\n    the-transition();\n    transition-property: all;\n    color: $toc-link-color;\n    border-bottom-color: $toc-link-border-color;\n\n    &:hover {\n      color: $toc-link-hover-color;\n      border-bottom-color: $toc-link-hover-border-color;\n    }\n  }\n}\n\n.post-toc .nav-item {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  text-align: justify;\n  white-space: nowrap if !hexo-config('toc.wrap');\n  line-height: 1.8;\n}\n\n.post-toc .nav .nav-child { display: none; }\n\n.post-toc .nav .active > .nav-child { display: block; }\n\n.post-toc .nav .active-current > .nav-child {\n  display: block;\n  & > .nav-item { display: block; }\n}\n\n.post-toc .nav .active > a {\n  color: $toc-link-active-color;\n  border-bottom-color: $toc-link-active-border-color;\n}\n\n.post-toc .nav .active-current > a {\n  color: $toc-link-active-current-color;\n  &:hover {\n    color: $toc-link-active-current-border-color;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar-toggle.styl",
    "content": ".sidebar-toggle {\n  position: fixed;\n  right: $b2t-position-right;\n  bottom: 45px;\n  width: 14px;\n  height: 14px;\n  padding: 5px;\n  background: $black-deep;\n  line-height: 0;\n  z-index: $zindex-5;\n  cursor: pointer;\n  -webkit-transform: translateZ(0);\n\n  +tablet() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n  +mobile() {\n    fixbutton() if hexo-config('sidebar.onmobile');\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n}\n\n\n\n.sidebar-toggle-line {\n  position: relative;\n  display: inline-block;\n  vertical-align: top;\n  height: 2px;\n  width: 100%;\n  background: white;\n  margin-top: 3px;\n\n  &:first-child { margin-top: 0; }\n}\n"
  },
  {
    "path": "source/css/_common/components/sidebar/sidebar.styl",
    "content": ".sidebar {\n  position: fixed;\n  right: 0;\n  top: 0;\n  bottom: 0;\n\n  width: 0;\n  z-index: $zindex-4;\n  box-shadow: inset 0 2px 6px black;\n  background: $black-deep;\n  -webkit-transform: translateZ(0); // http://stackoverflow.com/questions/17079857/position-fixed-broken-in-chrome-with-flash-behind\n\n  a {\n    color: $grey-dark;\n    border-bottom-color: $black-light;\n    &:hover { color: $gainsboro; }\n  }\n\n  +tablet() {\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n  +mobile() {\n    hide() if not hexo-config('sidebar.onmobile');\n  }\n\n}\n\n.sidebar-inner {\n  position: relative;\n  padding: 20px 10px;\n  color: $grey-dark;\n  text-align: center;\n}\n\n.site-overview-wrap {\n  overflow: hidden;\n}\n\n.site-overview {\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n\n@import \"sidebar-toggle\";\n@import \"sidebar-author\";\n@import \"site-state\";\n@import \"sidebar-feed-link\";\n@import \"sidebar-author-links\";\n@import \"sidebar-blogroll\";\n@import \"sidebar-nav\";\n@import \"sidebar-toc\";\n@import \"sidebar-dimmer\" if hexo-config('sidebar.onmobile');\n"
  },
  {
    "path": "source/css/_common/components/sidebar/site-state.styl",
    "content": ".site-state {\n  overflow: hidden;\n  line-height: 1.4;\n  white-space: nowrap;\n  text-align: $site-state-align;\n}\n\n.site-state-item {\n  display: inline-block;\n  padding: 0 15px;\n  border-left: 1px solid $site-state-item-border-color;\n\n  &:first-child { border-left: none; }\n\n  a { border-bottom: none; }\n}\n.site-state-item-count {\n  display: block;\n  text-align: center;\n  color: $site-state-item-count-color;\n  font-weight: $font-weight-bold;\n  font-size: $site-state-item-count-font-size;\n}\n\n.site-state-item-name {\n  font-size: $site-state-item-name-font-size;\n  color: $site-state-item-name-color;\n}\n"
  },
  {
    "path": "source/css/_common/components/tag-cloud.styl",
    "content": ".tag-cloud {\n  text-align: center;\n\n  a {\n    display: inline-block;\n    margin: 10px;\n  }\n}"
  },
  {
    "path": "source/css/_common/components/tags/blockquote-center.styl",
    "content": "// Blockquote with all children centered.\n.blockquote-center {\n  position: relative;\n  margin: 40px 0;\n  padding: 0;\n  border-left: none;\n  text-align: center;\n\n  &::before, &::after {\n    position: absolute;\n    content: ' ';\n    display: block;\n    width: 100%;\n    height: 24px;\n    opacity: 0.2;\n    background-repeat: no-repeat;\n    background-position: 0 -6px;\n    background-size: 22px 22px;\n  }\n  &::before {\n    top: -20px;\n    background-image: url($center-quote-left);\n    border-top: 1px solid $grey-light;\n  }\n  &::after {\n    bottom: -20px;\n    background-image: url($center-quote-right);\n    border-bottom: 1px solid $grey-light;\n    background-position: 100% 8px;\n  }\n\n  p, div { text-align: center; }\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/exturl.styl",
    "content": ".exturl {\n  // Remove the gray background color from active links in IE 10.\n  background-color: transparent;\n\n  cursor: pointer;\n  border-bottom: 1px solid #999;\n\n  .fa {\n    font-size: 14px;\n  }\n}\n\n// Improve readability when focused and also mouse hovered in all browsers.\n.exturl:active, .exturl:hover {\n  outline: 0;\n  color: $black-deep;\n  border-bottom-color: $black-deep;\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/full-image.styl",
    "content": "// Expand image to 126% with nagative margin-left/right on Desktop.\n.full-image.full-image.full-image.full-image {\n  border: none;\n  max-width: 100%;\n  width: auto;\n  margin: 20px auto 25px;\n  +desktop() {\n    max-width: none;\n    width: $full-image-width;\n    margin: $full-image-margin-vertical $full-image-margin-horizontal;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/group-pictures.styl",
    "content": ".post .post-body .group-picture {\n  img {\n    box-sizing: border-box;\n    padding: 0 3px;\n    border: none;\n  }\n}\n\n.post .group-picture-row {\n  overflow: hidden;\n  margin-top: 6px;\n  &:first-child { margin-top: 0; }\n}\n\n.post .group-picture-column { float: left; }\n\n.page-post-detail .post-body .group-picture-column {\n  float: none;\n  margin-top: 10px;\n  width: auto !important;\n  img { margin: 0 auto; }\n}\n\n.page-archive {\n  .group-picture-container { overflow: hidden; }\n  .group-picture-row {\n    float: left;\n    &:first-child { margin-top: 6px; }\n  }\n\n  .group-picture-column {\n    max-width: 150px;\n    max-height: 150px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/label.styl",
    "content": ".post-body .label {\n  display: inline;\n  padding: 0 2px;\n  white-space: nowrap;\n\n  &.default { background-color: $label-default; }\n  &.primary { background-color: $label-primary; }\n  &.info    { background-color: $label-info; }\n  &.success { background-color: $label-success; }\n  &.warning { background-color: $label-warning; }\n  &.danger  { background-color: $label-danger; }\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/note-modern.styl",
    "content": ".post-body .note {\n  note_icons = hexo-config('note.icons');\n\n  position:          relative;\n  padding:           15px;\n  margin-bottom:     20px;\n\n  border:            1px solid transparent;\n  background-color:  $whitesmoke;\n  border-radius:     unit(hexo-config('note.border_radius'), px) if hexo-config('note.border_radius') is a 'unit';\n\n  h2, h3, h4, h5, h6 {\n    if note_icons {\n      margin-top:    3px;\n    } else {\n      margin-top:    0;\n    }\n    margin-bottom:   0;\n    border-bottom:   initial;\n    padding-top:     0 !important;\n  }\n\n  p, ul, ol, table, pre, blockquote {\n    &:first-child {\n      margin-top:    0;\n    }\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  if note_icons {\n    &:not(.no-icon) {\n      padding-left:     45px;\n      &:before {\n        position:       absolute;\n        font-family:    'FontAwesome';\n        font-size:      larger;\n        top:            13px;\n        left:           15px;\n      }\n    }\n  }\n\n  &.default {\n    background-color:            $note-modern-default-bg;\n    border-color:                $note-modern-default-border;\n    color:                       $note-modern-default-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-default-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-default-text;\n        border-bottom:   1px solid $note-modern-default-text;\n        &:hover {\n          color:                   $note-modern-default-hover;\n          border-bottom: 1px solid $note-modern-default-hover;\n        }\n      }\n    }\n  }\n\n  &.primary {\n    background-color:            $note-modern-primary-bg;\n    border-color:                $note-modern-primary-border;\n    color:                       $note-modern-primary-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-primary-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-primary-text;\n        border-bottom:   1px solid $note-modern-primary-text;\n        &:hover {\n          color:                   $note-modern-primary-hover;\n          border-bottom: 1px solid $note-modern-primary-hover;\n        }\n      }\n    }\n  }\n\n  &.info {\n    background-color:            $note-modern-info-bg;\n    border-color:                $note-modern-info-border;\n    color:                       $note-modern-info-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-info-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-info-text;\n        border-bottom:   1px solid $note-modern-info-text;\n        &:hover {\n          color:                   $note-modern-info-hover;\n        border-bottom: 1px solid $note-modern-info-hover;\n        }\n      }\n    }\n  }\n\n  &.success {\n    background-color:            $note-modern-success-bg;\n    border-color:                $note-modern-success-border;\n    color:                       $note-modern-success-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-success-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-success-text;\n        border-bottom:   1px solid $note-modern-success-text;\n        &:hover {\n          color:                   $note-modern-success-hover;\n          border-bottom: 1px solid $note-modern-success-hover;\n        }\n      }\n    }\n  }\n\n  &.warning {\n    background-color:            $note-modern-warning-bg;\n    border-color:                $note-modern-warning-border;\n    color:                       $note-modern-warning-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-warning-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-warning-text;\n        border-bottom:   1px solid $note-modern-warning-text;\n        &:hover {\n          color:                   $note-modern-warning-hover;\n          border-bottom: 1px solid $note-modern-warning-hover;\n        }\n      }\n    }\n  }\n\n  &.danger {\n    background-color:            $note-modern-danger-bg;\n    border-color:                $note-modern-danger-border;\n    color:                       $note-modern-danger-text;\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:               $note-danger-icon;\n        }\n      }\n    }\n    a {\n      &:not(.btn) {\n        color:                     $note-modern-danger-text;\n        border-bottom:   1px solid $note-modern-danger-text;\n        &:hover {\n          color:                   $note-modern-danger-hover;\n          border-bottom: 1px solid $note-modern-danger-hover;\n        }\n      }\n    }\n  }\n\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/note.styl",
    "content": ".post-body .note {\n  note_style = hexo-config('note.style');\n  note_icons = hexo-config('note.icons');\n\n  position:             relative;\n  padding:              15px;\n  margin-bottom:        20px;\n\n  if note_style == 'simple' {\n    border:             1px solid $gainsboro;\n    border-left-width:  5px;\n  }\n  if note_style == 'flat' {\n    border:             initial;\n    border-left:        3px solid $gainsboro;\n    background-color:   lighten($gainsboro, 65%);\n  }\n  border-radius:        unit(hexo-config('note.border_radius'), px) if hexo-config('note.border_radius') is a 'unit';\n\n  h2, h3, h4, h5, h6 {\n    if note_icons {\n      margin-top:       3px;\n    } else {\n      margin-top:       0;\n    }\n    margin-bottom:      0;\n    border-bottom:      initial;\n    padding-top:        0 !important;\n  }\n\n  p, ul, ol, table, pre, blockquote {\n    &:first-child {\n      margin-top:       0;\n    }\n    &:last-child {\n      margin-bottom:    0;\n    }\n  }\n\n  if note_icons {\n    &:not(.no-icon) {\n      padding-left:     45px;\n      &:before {\n        position:       absolute;\n        font-family:    'FontAwesome';\n        font-size:      larger;\n        top:            13px;\n        left:           15px;\n      }\n    }\n  }\n\n  &.default {\n    if note_style == 'flat' {\n      background-color: $note-default-bg;\n    }\n    border-left-color:  $note-default-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-default-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-default-icon;\n          color :       $note-default-text;\n        }\n      }\n    }\n  }\n\n  &.primary {\n    if note_style == 'flat' {\n      background-color: $note-primary-bg;\n    }\n    border-left-color:  $note-primary-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-primary-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-primary-icon;\n          color :       $note-primary-text;\n        }\n      }\n    }\n  }\n\n  &.info {\n    if note_style == 'flat' {\n      background-color: $note-info-bg;\n    }\n    border-left-color:  $note-info-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-info-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-info-icon;\n          color :       $note-info-text;\n        }\n      }\n    }\n  }\n\n  &.success {\n    if note_style == 'flat' {\n      background-color: $note-success-bg;\n    }\n    border-left-color:  $note-success-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-success-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-success-icon;\n          color :       $note-success-text;\n        }\n      }\n    }\n  }\n\n  &.warning {\n    if note_style == 'flat' {\n      background-color: $note-warning-bg;\n    }\n    border-left-color:  $note-warning-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-warning-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-warning-icon;\n          color :       $note-warning-text;\n        }\n      }\n    }\n  }\n\n  &.danger {\n    if note_style == 'flat' {\n      background-color: $note-danger-bg;\n    }\n    border-left-color:  $note-danger-border;\n    h2, h3, h4, h5, h6 {\n      color:            $note-danger-text;\n    }\n    if note_icons {\n      &:not(.no-icon) {\n        &:before {\n          content:      $note-danger-icon;\n          color :       $note-danger-text;\n        }\n      }\n    }\n  }\n\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/tabs.styl",
    "content": ".post-body .tabs {\n  position: relative;\n  display: block;\n  margin-bottom: 20px;\n  padding-top: 10px;\n\n  // Read tabs border_radius from NexT config and set in \"tbr px\" to use it as string variable in this CSS section.\n  hexo-config('tabs.border_radius') is a 'unit' ? (tbr = unit(hexo-config('tabs.border_radius'), px)) : (tbr = 0)\n\n  ul.nav-tabs {\n    margin: 0;\n    padding: 0;\n    display: flex;\n    margin-bottom: -1px;\n\n    +mobile-smallest() {\n      display: block;\n      margin-bottom: 5px;\n    }\n\n    li.tab {\n      list-style-type: none !important;\n      margin: 0 .25em 0 0;\n      border-top: 3px solid transparent;\n      border-left: 1px solid transparent;\n      border-right: 1px solid transparent;\n\n      +mobile-smallest() {\n        margin: initial;\n        border-top: 1px solid transparent;\n        border-left: 3px solid transparent;\n        border-right: 1px solid transparent;\n        border-bottom: 1px solid transparent;\n      }\n\n      if tbr > 0 {\n        border-radius: tbr tbr 0 0;\n        +mobile-smallest() { border-radius: tbr; }\n      }\n      if hexo-config('tabs.transition.tabs') { the-transition-ease-out(); }\n\n      & a {\n        outline: 0;\n        border-bottom: initial;\n        display: block;\n        line-height: 1.8em;\n        padding: .25em .75em;\n        & i { width: (18em / 14); }\n        if hexo-config('tabs.transition.labels') { the-transition-ease-out(); }\n      }\n\n      &.active {\n        border-top: 3px solid $orange;\n        border-left: 1px solid $table-border-color;\n        border-right: 1px solid $table-border-color;\n        background-color: #fff;\n\n        +mobile-smallest() {\n          border-top: 1px solid $table-border-color;\n          border-left: 3px solid $orange;\n          border-right: 1px solid $table-border-color;\n          border-bottom: 1px solid $table-border-color;\n        }\n\n        & a {\n          cursor: default;\n          color: $link-color;\n        }\n      }\n    }\n\n  }\n\n  .tab-content {\n    background-color: #fff;\n\n    .tab-pane {\n      border: 1px solid $table-border-color;\n      padding: 20px 20px 0 20px;\n      if tbr > 0 { border-radius: tbr; }\n\n      &:not(.active) {\n        hide();\n      }\n      &.active {\n        show();\n        if tbr > 0 {\n          &:nth-of-type(1) {\n            border-radius: 0 tbr tbr tbr;\n            +mobile-smallest() { border-radius: tbr; }\n          }\n        }\n      }\n\n    }\n\n  }\n\n}\n"
  },
  {
    "path": "source/css/_common/components/tags/tags.styl",
    "content": "@import \"full-image\";\n@import \"blockquote-center\";\n@import \"group-pictures\";\n@import \"exturl\" if hexo-config('exturl');\n@import \"note\" if hexo-config('note.style') == 'simple' || hexo-config('note.style') == 'flat';\n@import \"note-modern\" if hexo-config('note.style') == 'modern';\n@import \"label\" if hexo-config('label');\n@import \"tabs\" if hexo-config('tabs.enable');\n"
  },
  {
    "path": "source/css/_common/components/third-party/algolia-search.styl",
    "content": ".algolia-pop-overlay\n  position: fixed\n  width: 100%\n  height: 100%\n  top: 0\n  left: 0\n  z-index: 2080\n  background-color: rgba(0, 0, 0, 0.3)\n\n.algolia-popup\n  overflow: hidden\n  padding: 0\n  display: none\n  position: fixed\n  top: 10%\n  left: 50%\n  width: 700px\n  height: 80%\n  margin-left: -350px\n  background: #fff\n  color: #333\n  z-index: 9999\n  border-radius: 5px\n  +mobile()\n    padding: 0\n    top: 0\n    left: 0\n    margin: 0\n    width: 100%\n    height: 100%\n    border-radius: 0\n\n  .popup-btn-close\n    position: absolute\n    right: 14px\n    color: #4EBD79\n    font-size: 14px\n    font-weight: bold\n    text-transform: uppercase\n    cursor: pointer\n    padding-left: 15px\n    border-left: 1px solid #eee\n    top: 10px\n    .fa\n      color: $grey-dark\n      font-size: 18px\n    &:hover .fa\n      color: $black-deep\n\n.algolia-search\n  padding: 10px 15px 5px\n  max-height: 50px\n  border-bottom: 1px solid #ccc\n  background: $whitesmoke\n  border-top-left-radius: 5px\n  border-top-right-radius: 5px\n\n.algolia-search-input-icon\n  display: inline-block\n  width: 20px\n  .fa\n    font-size: 18px\n\n.algolia-search-input\n  display: inline-block\n  width: calc(90% - 20px)\n  input\n    padding: 5px 0\n    width: 100%\n    outline: none\n    border: none\n    background: transparent\n\n.algolia-powered\n  float: right\n  img\n    display: inline-block\n    height: 18px\n    vertical-align: middle\n\n.algolia-results\n  position: relative\n  overflow: auto\n  padding: 10px 30px\n  height: calc(100% - 50px)\n\n  hr\n    margin: 10px 0\n\n  .highlight\n    font-style: normal\n    margin: 0\n    padding: 0 2px\n    font-size: inherit\n    color: red\n\n.algolia-hits\n  margin-top: 20px\n\n.algolia-hit-item\n  margin: 15px 0\n\n.algolia-hit-item-link\n  display: block\n  border-bottom: 1px dashed #ccc\n  the-transition()\n\n.algolia-pagination\n  .pagination\n    margin-top: 40px\n    border-top: none\n    padding: 0\n  .pagination-item\n    display: inline-block\n  .page-number\n    border-top: none\n    &:hover\n      border-bottom: 1px solid $black-deep\n\n  .current .page-number\n    @extend .pagination .page-number.current\n\n  .disabled-item\n    visibility: hidden\n\n"
  },
  {
    "path": "source/css/_common/components/third-party/baidushare.styl",
    "content": ".post-spread {\n  margin-top: 20px;\n  text-align: center;\n}\n\n.bdshare-slide-button-box a { border: none; }\n\n.bdsharebuttonbox {\n  display: inline-block;\n\n  a { border: none; }\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/busuanzi-counter.styl",
    "content": "if hexo-config(\"scheme\") == Pisces\n  .busuanzi-count {\n    +tablet() {\n      width: auto;\n    }\n    +mobile() {\n      width: auto;\n    }\n  }\n\n.site-uv,\n.site-pv,\n.page-pv {\n  display: inline-block;\n\n  .busuanzi-value {\n    margin: 0 5px;\n  }\n}\n\nif hexo-config(\"busuanzi_count.site_pv\") and hexo-config(\"busuanzi_count.site_uv\")\n  .site-uv\n  {\n    margin-right: 10px;\n\n    &::after {\n      content: \"|\";\n      padding-left: 10px;\n    }\n  }\n"
  },
  {
    "path": "source/css/_common/components/third-party/duoshuo.styl",
    "content": "\n.theme-next {\n  $duoshuoBaseBorderColor = #c7d4e1;\n  $duoshuoBaseBgColor = #f6f8fa;\n\n  #ds-thread #ds-reset {\n    color: #555;\n  }\n\n  #ds-thread #ds-reset .ds-replybox {\n    margin-bottom: 30px;\n  }\n\n  #ds-thread #ds-reset .ds-replybox .ds-avatar, #ds-reset .ds-avatar img {\n    box-shadow: none;\n  }\n\n  #ds-thread #ds-reset .ds-textarea-wrapper {\n    border-color: $duoshuoBaseBorderColor;\n    background: none;\n    border-top-right-radius: 3px;\n    border-top-left-radius: 3px;\n  }\n\n\n  #ds-thread #ds-reset .ds-textarea-wrapper textarea {\n    height: 60px;\n  }\n\n  #ds-reset .ds-rounded-top {\n    border-radius: 0;\n  }\n\n  #ds-thread #ds-reset .ds-post-toolbar {\n    box-sizing: border-box;\n    border: 1px solid $duoshuoBaseBorderColor;\n    background: $duoshuoBaseBgColor;\n  }\n\n  #ds-thread #ds-reset .ds-post-options {\n    height: 40px;\n    border: none;\n    background: none;\n  }\n\n  #ds-thread #ds-reset .ds-toolbar-buttons {\n    top: 11px;\n  }\n\n  #ds-thread #ds-reset .ds-sync {\n    top: 5px;\n  }\n\n  #ds-thread #ds-reset .ds-post-button {\n    top: 4px;\n    right: 5px;\n    width: 90px;\n    height: 30px;\n    border: 1px solid #c5ced7;\n    border-radius: 3px;\n    background-image: linear-gradient(#fbfbfc, #f5f7f9);\n    color: #60676d;\n  }\n\n  #ds-thread #ds-reset .ds-post-button:hover {\n    background-position: 0 -30px;\n    color: #60676d;\n  }\n\n  #ds-thread #ds-reset .ds-comments-info {\n    padding: 10px 0;\n  }\n\n  #ds-thread #ds-reset .ds-sort {\n    display: none;\n  }\n\n  #ds-thread #ds-reset li.ds-tab a.ds-current {\n    border: none;\n    background: $duoshuoBaseBgColor;\n    color: #60676d;\n\n    &:hover {\n      background-color: #e9f0f7;\n      color: #60676d;\n    }\n  }\n\n  #ds-thread #ds-reset li.ds-tab a {\n    border-radius: 2px;\n    padding: 5px;\n  }\n\n  #ds-thread #ds-reset .ds-login-buttons p {\n    color: #999;\n    line-height: 36px;\n  }\n\n  #ds-thread #ds-reset .ds-login-buttons .ds-service-list li {\n    height: 28px;\n  }\n\n  #ds-thread #ds-reset .ds-service-list a {\n    background: none;\n    padding: 5px;\n    border: 1px solid;\n    border-radius: 3px;\n    text-align: center;\n\n    &:hover {\n      color: #fff;\n      background: #666;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-weibo {\n    color: #fc9b00;\n    border-color: #fc9b00;\n\n    &:hover {\n      background: #fc9b00;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-qq {\n    color: #60a3ec;\n    border-color: #60a3ec;\n\n    &:hover {\n      background: #60a3ec;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-renren {\n    color: #2e7ac4;\n    border-color: #2e7ac4;\n\n    &:hover {\n      background: #2e7ac4;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-douban {\n    color: #37994c;\n    border-color: #37994c;\n\n    &:hover {\n      background: #37994c;\n    }\n  }\n  #ds-thread #ds-reset .ds-service-list .ds-kaixin {\n    color: #fef20d;\n    border-color: #fef20d;\n\n    &:hover {\n      background: #fef20d;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-netease {\n    color: #f00;\n    border-color: #f00;\n\n    &:hover {\n      background: #f00;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-sohu {\n    color: #ffcb05;\n    border-color: #ffcb05;\n\n    &:hover {\n      background: #ffcb05;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-baidu {\n    color: #2831e0;\n    border-color: #2831e0;\n\n    &:hover {\n      background: #2831e0;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-google {\n    color: #166bec;\n    border-color: #166bec;\n\n    &:hover {\n      background: #166bec;\n    }\n  }\n\n  #ds-thread #ds-reset .ds-service-list .ds-weixin {\n    color: #00CE0D;\n    border-color: #00CE0D;\n\n    &:hover {\n      background: #00CE0D;\n    }\n  }\n  #ds-thread #ds-reset .ds-service-list .ds-more-services {\n    border: none;\n    &:hover {\n      background: none;\n    }\n  }\n\n/*duoshuo UA style begin*/\n\n  #ds-reset .duoshuo-ua-admin {\n    display: inline-block;\n    color: red;\n  }\n\n  #ds-reset .duoshuo-ua-platform,\n  #ds-reset .duoshuo-ua-browser {\n    color: #ccc;\n\n    .fa {\n      display: inline-block;\n      margin-right: 3px;\n    }\n  }\n\n  #ds-reset .duoshuo-ua-separator {\n    display: inline-block;\n    margin-left: 5px;\n  }\n\n  .this_ua {\n    background-color: #ccc !important;\n    border-radius: 4px;\n    padding: 0 5px !important;\n    margin: 1px 1px !important;\n    border: 1px solid #BBB !important;\n    color: #fff;\n    display: inline-block !important;\n  }\n\n  .this_ua.admin {\n    background-color: #d9534f !important;\n    border-color: #d9534f !important;\n  }\n\n  .this_ua.platform.iOS, .this_ua.platform.Mac, .this_ua.platform.Windows {\n    background-color: #39b3d7 !important;\n    border-color: #46b8da !important;\n  }\n\n  .this_ua.platform.Linux {\n    background-color: #3A3A3A !important;\n    border-color: #1F1F1F !important;\n  }\n\n  .this_ua.platform.Android {\n    background-color: #00C47D !important;\n    border-color: #01B171 !important;\n  }\n\n  .this_ua.browser.Mobile, .this_ua.browser.Chrome {\n    background-color: #5cb85c !important;\n    border-color: #4cae4c !important;\n  }\n\n  .this_ua.browser.Firefox {\n    background-color: #f0ad4e !important;\n    border-color: #eea236 !important;\n  }\n\n  .this_ua.browser.Maxthon, .this_ua.browser.IE {\n    background-color: #428bca !important;\n    border-color: #357ebd !important;\n  }\n\n  .this_ua.browser.baidu, .this_ua.browser.UCBrowser, .this_ua.browser.Opera {\n    background-color: #d9534f !important;\n    border-color: #d43f3a !important;\n  }\n\n  .this_ua.browser.Android, .this_ua.browser.QQBrowser {\n    background-color: #78ACE9 !important;\n    border-color: #4cae4c !important;\n  }\n\n/*duoshuo UA style end*/\n\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/gitment.styl",
    "content": "#gitment-display-button{\n    display: inline-block;\n    padding: 0 15px;\n    color: #0a9caf;\n    cursor: pointer;\n    font-size: 14px;\n    border: 1px solid #0a9caf;\n    border-radius: 4px;\n}\n#gitment-display-button:hover{\n    color: #fff;\n    background: #0a9caf;\n}"
  },
  {
    "path": "source/css/_common/components/third-party/han.styl",
    "content": ".fa {\n  font-family: FontAwesome!important;\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/jiathis.styl",
    "content": ".post-spread {\n  margin-top: 20px;\n  text-align: center;\n}\n\n.jiathis_style {\n  display: inline-block;\n\n  a { border: none; }\n}"
  },
  {
    "path": "source/css/_common/components/third-party/localsearch.styl",
    "content": ".local-search-pop-overlay\n  position: fixed\n  width: 100%\n  height: 100%\n  top: 0\n  left: 0\n  z-index: 2080\n  background-color: rgba(0, 0, 0, 0.3)\n\n.local-search-popup\n  display: none\n  position: fixed\n  top: 10%\n  left: 50%\n  margin-left: -350px\n  width: 700px\n  height: 80%\n  padding: 0\n  background: #fff\n  color: #333\n  z-index: 9999\n  border-radius: 5px\n  +mobile()\n    padding: 0\n    top: 0\n    left: 0\n    margin: 0\n    width: 100%\n    height: 100%\n    border-radius: 0\n\n  ul.search-result-list\n    padding: 0\n    margin: 0 5px\n\n  p.search-result\n    border-bottom: 1px dashed #ccc\n    padding: 5px 0\n\n  a.search-result-title\n    font-weight: bold\n    font-size: 16px\n\n  .search-keyword\n    border-bottom: 1px dashed #f00\n    font-weight: bold\n    color: #f00\n\n  .local-search-header\n    padding: 5px\n    height: 36px\n    background: #f5f5f5\n    border-top-left-radius: 5px\n    border-top-right-radius: 5px\n\n  #local-search-result\n    overflow: auto\n    position: relative\n    padding: 5px 25px\n    height: calc(100% - 55px)\n\n  .local-search-input-wrapper\n    display: inline-block\n    width: calc(100% - 90px)\n    height: 36px\n    line-height: 36px\n    padding: 0 5px\n\n  .local-search-input-wrapper input\n    padding: 8px 0\n    height: 20px\n    display: block\n    width: 100%\n    outline: none\n    border: none\n    background: transparent\n    vertical-align: middle\n\n  .search-icon, .popup-btn-close\n    display: inline-block\n    font-size: 18px\n    color: #999\n    height: 36px\n    width: 18px\n    padding-left: 10px\n    padding-right: 10px\n\n  .search-icon\n    float: left\n\n  .popup-btn-close\n    border-left: 1px solid #eee\n    float: right\n    cursor: pointer\n\n  #no-result\n    position: absolute\n    left: 50%\n    top: 50%\n    -webkit-transform: translate(-50%, -50%)\n    transform: translate(-50%, -50%)\n    color: #ccc\n"
  },
  {
    "path": "source/css/_common/components/third-party/needsharebutton.styl",
    "content": "#needsharebutton-postbottom {\n  position: relative;\n  cursor: pointer;\n  height: 26px;\n\n  .btn {\n    display: initial;\n    padding: 1px 4px;\n    border: 1px solid $btn-default-border-color;\n    border-radius: 3px;\n  }\n}\n\n#needsharebutton-float {\n    position: fixed;\n    bottom: 38px;\n    left: -8px;\n    z-index: 9999;\n    cursor: pointer;\n\n  .btn {\n    //display: initial;\n    padding: 0 10px 0 14px\n    border: 1px solid $btn-default-border-color;\n    border-radius: 4px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/third-party.styl",
    "content": "@import \"duoshuo\";\n@import \"gitment\" if hexo-config('gitment.enable');\n@import \"jiathis\";\n@import \"han\";\n@import \"baidushare\";\n@import \"localsearch\";\n@import \"busuanzi-counter\";\n@import \"algolia-search\" if hexo-config('algolia_search.enable');\n@import \"needsharebutton\" if hexo-config('needmoreshare2.enable');\n"
  },
  {
    "path": "source/css/_common/outline/outline.styl",
    "content": "//\n// Layout\n// Note: Must name this file \"outline\" instead of \"layout\"\n//       Or Hexo will use it as template layout.\n// =================================================\n\n\nhtml, body { height: 100%; }\n\n.container {\n  position: relative;\n  min-height: 100%;\n}\n\n\n// Header Section\n// --------------------------------------------------\n.header-inner {\n  margin: 0 auto;\n  padding: 100px 0 70px;\n  width: $content-desktop;\n\n  +desktop-large() {\n    .container & { width: $content-desktop-large; }\n  }\n}\n\n// Main Section\n// --------------------------------------------------\n.main { padding-bottom: $footer-height + $gap-between-main-and-footer; }\n.main-inner {\n  margin: 0 auto;\n  width: $content-desktop;\n\n  +desktop-large() {\n    .container & { width: $content-desktop-large; }\n  }\n}\n\n\n// Footer Section\n// --------------------------------------------------\n.footer {\n  position: absolute;\n  left: 0;\n  bottom: 0;\n  width: 100%;\n  min-height: $footer-height;\n}\n.footer-inner {\n  box-sizing: border-box;\n  margin: 20px auto;\n  width: $content-desktop;\n\n  +desktop-large() {\n    .container & { width: $content-desktop-large; }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/base.styl",
    "content": "\n::selection {\n  background: $selection-bg;\n  color: $selection-color;\n}\n\nbody {\n  position: relative; // Required by scrollspy\n  font-family: $font-family-base;\n  font-size: $font-size-base;\n  line-height: $line-height-base;\n  color: $text-color;\n  background: $body-bg-color;\n\n  +mobile() { padding-right: 0 !important; }\n  +tablet() { padding-right: 0 !important; }\n  +desktop-large() { font-size: $font-size-large; }\n}\n\nh1, h2, h3, h4, h5, h6 {\n  margin: 0;\n  padding: 0;\n  font-weight: bold;\n  line-height: 1.5;\n  font-family: $font-family-headings;\n}\n\nh2, h3, h4, h5, h6 { margin: 20px 0 15px; }\n\nfor headline in (1..6) {\n  h{headline} {\n    font-size: $font-size-headings-base - $font-size-headings-step * headline;\n  }\n\n  +mobile() {\n    h{headline} {\n      font-size: $font-size-headings-base - $font-size-headings-step * headline - 4px;\n    }\n  }\n}\n\np { margin: 0 0 20px 0; }\n\na {\n  color: $link-color;\n  text-decoration: none;\n  outline: none;\n  border-bottom: 1px solid $grey-dark;\n  word-wrap: break-word;\n\n  &:hover {\n    color: $link-hover-color;\n    border-bottom-color: $link-decoration-hover-color;\n  }\n}\n\nblockquote {\n  margin: 0;\n  padding: 0;\n}\n\nimg {\n  display: block;\n  margin: auto;\n  max-width: 100%;\n  height: auto;\n}\n\n\nhr {\n  margin: 40px 0;\n  height: 3px;\n  border: none;\n  background-color: $gray-lighter;\n  background-image: repeating-linear-gradient(\n    -45deg,\n    white,\n    white 4px,\n    transparent 4px,\n    transparent 8px\n  );\n}\n\nblockquote {\n  padding: 0 15px;\n  color: $grey-dim;\n  border-left: 4px solid $gray-lighter;\n\n  cite::before {\n    content: \"-\";\n    padding: 0 5px;\n  }\n}\n\ndt { font-weight: $font-weight-bolder; }\n\ndd {\n  margin: 0;\n  padding: 0;\n}\n\nkbd {\n  border: 1px solid $grey-light;\n  border-radius: 0.2em;\n  box-shadow: 0.1em 0.1em 0.2em rgba(0,0,0,0.1);\n  background-color: #f9f9f9;\n  font-family: inherit;\n  background-image: -webkit-linear-gradient(top, #eee, white, #eee);\n  padding: 0.1em 0.3em;\n  white-space: nowrap;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/helpers.styl",
    "content": "//\n// Helpers\n// =================================================\n\n\n\n// Alignment\n.text-left    { text-align: left; }\n.text-center  { text-align: center; }\n.text-right   { text-align: right; }\n.text-justify { text-align: justify; }\n.text-nowrap  { white-space: nowrap; }\n\n\n// Transformation\n.text-lowercase  { text-transform: lowercase; }\n.text-uppercase  { text-transform: uppercase; }\n.text-capitalize { text-transform: capitalize; }\n\n\n// Center-align a block level element.\n.center-block {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n\n\n// Clearfix. http://nicolasgallagher.com/micro-clearfix-hack/\n.clearfix {\n  clearfix();\n}\n\n.pullquote {\n  width: 45%;\n\n  &.left {\n    float: left;\n    margin-left: 5px;\n    margin-right: 10px;\n  }\n\n  &.right {\n    float: right;\n    margin-left: 10px;\n    margin-right: 5px;\n  }\n}\n\n.affix.affix.affix { position: fixed; }\n\n.translation {\n  margin-top: -20px;\n  font-size: 14px;\n  color: $grey-dark;\n}\n\n// https://davidwalsh.name/detect-scrollbar-width\n.scrollbar-measure {\n  width: 100px;\n  height: 100px;\n  overflow: scroll;\n  position: absolute;\n  top: -9999px;\n}\n\n.use-motion .motion-element { opacity: 0; }\n"
  },
  {
    "path": "source/css/_common/scaffolding/mobile.styl",
    "content": "/*\n// > 1600px\n+desktop-large() {\n\n}\n\n// > 992px\n+desktop() {\n\n}\n\n// > 768px & < 991px\n+tablet() {\n\n}\n\n\n// < 767px\n+mobile() {\n\n}\n*/\n\n// < 567px\n+mobile-small() {\n\n  // For Muse & Mist schemes only vertical economy.\n  .header-inner {\n    margin-bottom: initial !important;\n  }\n  .main-inner {\n    margin-top: initial !important;\n  }\n\n  // For Pisces & Gemini schemes only wider width (remove main blocks in Gemini).\n  .content-wrap {\n    padding: initial !important;\n  }\n\n  // For all schemes wider width.\n  .posts-expand {\n    padding-top: $content-mobile-padding !important;\n    // For Muse & Mist & Pisces schemes only wider width.\n    margin: initial !important;\n\n    .post-header {\n      padding: 0 18px;\n    }\n\n    .post-meta {\n      margin: 3px 0 10px 0 !important;\n    }\n\n  }\n\n  .post-block {\n    // Inside posts blocks content padding (default 40px).\n    padding: $content-mobile-padding 0 !important;\n  }\n\n  .post-body {\n    // For headers narrow width.\n    h2, h3, h4, h5, h6 {\n      margin: 10px 18px 8px;\n    }\n    // Rewrite paddings & margins inside tags.\n    .note, .tabs .tab-content .tab-pane {\n      h2, h3, h4, h5, h6 {\n        margin: 0 5px;\n      }\n    }\n\n    // For paragraphs narrow width.\n    p {\n      margin: 0 0 10px 0;\n      padding: 0 18px;\n    }\n\n    // Rewrite paddings & margins inside tags.\n    .note > p, .tabs .tab-content .tab-pane > p {\n      padding: 0 5px;\n    }\n\n    .video-container .fluid-vids {\n      margin-bottom:  10px !important;\n    }\n\n    .note {\n      padding:        10px !important;\n      margin-bottom:  10px !important;\n\n      if hexo-config('note.icons') {\n        &:not(.no-icon) {\n          padding-left: 35px !important;\n          &:before {\n            top:        8px !important;\n            left:       12px !important;\n          }\n        }\n      }\n    }\n\n    .tabs .tab-content .tab-pane {\n      padding: 10px 10px 0 10px !important;\n    }\n  }\n\n  // Need to refactor into flex.\n  .post-nav {\n    padding-bottom: 2px;\n    //padding: 2px 8px;\n  }\n\n}\n\n/*\n// < 413px\n+mobile-smallest() {\n\n}\n*/\n"
  },
  {
    "path": "source/css/_common/scaffolding/normalize.styl",
    "content": "/*! normalize.css v3.0.2 | MIT License | git.io/normalize */\n\n/**\n * 1. Set default font family to sans-serif.\n * 2. Prevent iOS text size adjust after orientation change, without disabling\n *    user zoom.\n */\n\nhtml {\n  font-family: sans-serif; /* 1 */\n  -ms-text-size-adjust: 100%; /* 2 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/**\n * Remove default margin.\n */\n\nbody {\n  margin: 0;\n}\n\n/* HTML5 display definitions\n   ========================================================================== */\n\n/**\n * Correct `block` display not defined for any HTML5 element in IE 8/9.\n * Correct `block` display not defined for `details` or `summary` in IE 10/11\n * and Firefox.\n * Correct `block` display not defined for `main` in IE 11.\n */\n\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\n\n/**\n * 1. Correct `inline-block` display not defined in IE 8/9.\n * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\n */\n\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block; /* 1 */\n  vertical-align: baseline; /* 2 */\n}\n\n/**\n * Prevent modern browsers from displaying `audio` without controls.\n * Remove excess height in iOS 5 devices.\n */\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Address `[hidden]` styling not present in IE 8/9/10.\n * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.\n */\n\n[hidden],\ntemplate {\n  display: none;\n}\n\n/* Links\n   ========================================================================== */\n\n/**\n * Remove the gray background color from active links in IE 10.\n */\n\na {\n  background-color: transparent;\n}\n\n/**\n * Improve readability when focused and also mouse hovered in all browsers.\n */\n\na:active,\na:hover {\n  outline: 0;\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * Address styling not present in IE 8/9/10/11, Safari, and Chrome.\n */\n\nabbr[title] {\n  border-bottom: 1px dotted;\n}\n\n/**\n * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.\n */\n\nb,\nstrong {\n  font-weight: bold;\n}\n\n/**\n * Address styling not present in Safari and Chrome.\n */\n\ndfn {\n  font-style: italic;\n}\n\n/**\n * Address variable `h1` font-size and margin within `section` and `article`\n * contexts in Firefox 4+, Safari, and Chrome.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/**\n * Address styling not present in IE 8/9.\n */\n\nmark {\n  background: #ff0;\n  color: #000;\n}\n\n/**\n * Address inconsistent and variable font size in all browsers.\n */\n\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` affecting `line-height` in all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  top: -0.5em;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Remove border when inside `a` element in IE 8/9/10.\n */\n\nimg {\n  border: 0;\n}\n\n/**\n * Correct overflow not hidden in IE 9/10/11.\n */\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * Address margin not present in IE 8/9 and Safari.\n */\n\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * Address differences between Firefox and other browsers.\n */\n\nhr {\n  -moz-box-sizing: content-box;\n  box-sizing: content-box;\n  height: 0;\n}\n\n/**\n * Contain overflow in all browsers.\n */\n\npre {\n  overflow: auto;\n}\n\n/**\n * Address odd `em`-unit font size rendering in all browsers.\n */\n\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * Known limitation: by default, Chrome and Safari on OS X allow very limited\n * styling of `select`, unless a `border` property is set.\n */\n\n/**\n * 1. Correct color not being inherited.\n *    Known issue: affects color of disabled elements.\n * 2. Correct font properties not being inherited.\n * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit; /* 1 */\n  font: inherit; /* 2 */\n  margin: 0; /* 3 */\n}\n\n/**\n * Address `overflow` set to `hidden` in IE 8/9/10/11.\n */\n\nbutton {\n  overflow: visible;\n}\n\n/**\n * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * All other form control elements do not inherit `text-transform` values.\n * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.\n * Correct `select` style inheritance in Firefox.\n */\n\nbutton,\nselect {\n  text-transform: none;\n}\n\n/**\n * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n *    and `video` controls.\n * 2. Correct inability to style clickable `input` types in iOS.\n * 3. Improve usability and consistency of cursor style between image-type\n *    `input` and others.\n */\n\nbutton,\nhtml input[type=\"button\"], /* 1 */\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button; /* 2 */\n  cursor: pointer; /* 3 */\n}\n\n/**\n * Re-set default cursor for disabled elements.\n */\n\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\n\n/**\n * Remove inner padding and border in Firefox 4+.\n */\n\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\n\n/**\n * Address Firefox 4+ setting `line-height` on `input` using `!important` in\n * the UA stylesheet.\n */\n\ninput {\n  line-height: normal;\n}\n\n/**\n * It's recommended that you don't attempt to style these elements.\n * Firefox's implementation doesn't respect box-sizing, padding, or width.\n *\n * 1. Address box sizing set to `content-box` in IE 8/9/10.\n * 2. Remove excess padding in IE 8/9/10.\n */\n\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Fix the cursor style for Chrome's increment/decrement buttons. For certain\n * `font-size` values of the `input`, it causes the cursor style of the\n * decrement button to change from `default` to `text`.\n */\n\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Address `appearance` set to `searchfield` in Safari and Chrome.\n * 2. Address `box-sizing` set to `border-box` in Safari and Chrome\n *    (include `-moz` to future-proof).\n */\n\ninput[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  -moz-box-sizing: content-box;\n  -webkit-box-sizing: content-box; /* 2 */\n  box-sizing: content-box;\n}\n\n/**\n * Remove inner padding and search cancel button in Safari and Chrome on OS X.\n * Safari (but not Chrome) clips the cancel button when the search input has\n * padding (and `textfield` appearance).\n */\n\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * Define consistent border, margin, and padding.\n */\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\n/**\n * 1. Correct `color` not being inherited in IE 8/9/10/11.\n * 2. Remove padding so people aren't caught out if they zero out fieldsets.\n */\n\nlegend {\n  border: 0; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Remove default vertical scrollbar in IE 8/9/10/11.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * Don't inherit the `font-weight` (applied by a rule above).\n * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\n */\n\noptgroup {\n  font-weight: bold;\n}\n\n/* Tables\n   ========================================================================== */\n\n/**\n * Remove most spacing between table cells.\n */\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}"
  },
  {
    "path": "source/css/_common/scaffolding/scaffolding.styl",
    "content": "//\n// Scaffolding\n// =================================================\n\n@import \"normalize\";\n@import \"base\";\n@import \"helpers\";\n@import \"tables\";\n@import \"mobile\" if hexo-config('mobile_layout_economy');\n"
  },
  {
    "path": "source/css/_common/scaffolding/tables.styl",
    "content": "table {\n  margin: 20px 0;\n  width: $table-width;\n  border-collapse: collapse;\n  border-spacing: 0;\n  border: 1px solid $table-border-color;\n  font-size: $table-font-size;\n  table-layout: fixed;\n  word-wrap: break-all;\n}\ntable>tbody>tr {\n  &:nth-of-type(odd) { background-color: $table-row-odd-bg-color; }\n  &:hover { background-color: $table-row-hover-bg-color; }\n}\n\ncaption, th, td {\n  padding: $table-cell-padding;\n  text-align: $table-content-alignment;\n  vertical-align: $table-content-vertical;\n  font-weight: normal;\n}\n\nth, td {\n  border-bottom: 3px solid $table-cell-border-bottom-color;\n  border-right: 1px solid $table-cell-border-right-color;\n}\n\nth {\n  padding-bottom: 10px;\n  font-weight: $table-th-font-weight;\n}\n\ntd { border-bottom-width: 1px; }\n"
  },
  {
    "path": "source/css/_custom/custom.styl",
    "content": "// Custom styles.\n"
  },
  {
    "path": "source/css/_mixins/Gemini.styl",
    "content": "@import \"Pisces.styl\";\n"
  },
  {
    "path": "source/css/_mixins/Mist.styl",
    "content": ""
  },
  {
    "path": "source/css/_mixins/Muse.styl",
    "content": ""
  },
  {
    "path": "source/css/_mixins/Pisces.styl",
    "content": "sidebar-inline-links-item() {\n  margin: 5px 0 0;\n  if !hexo-config('social_icons.icons_only') { width: 50%; }\n\n  & a {\n    max-width: 216px;\n    box-sizing: border-box;\n    display: inline-block;\n    margin-right: 0;\n    margin-bottom: 0;\n    padding: 0 5px;\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    if hexo-config('social_icons.transition') { the-transition(); }\n  }\n}\n"
  },
  {
    "path": "source/css/_mixins/base.styl",
    "content": "the-transition() {\n  transition-duration: 0.2s;\n  transition-timing-function: ease-in-out;\n  transition-delay: 0s;\n}\n\nthe-transition-ease-in() {\n  transition-duration: 0.2s;\n  transition-timing-function: ease-in;\n  transition-delay: 0s;\n}\n\nthe-transition-ease-out() {\n  transition-duration: 0.2s;\n  transition-timing-function: ease-out;\n  transition-delay: 0s;\n}\n\nmobile-smallest() {\n  @media (max-width: 413px) {\n    {block}\n  }\n}\n\nmobile-small() {\n  @media (max-width: 567px) {\n    {block}\n  }\n}\n\nmobile() {\n  @media (max-width: 767px) {\n    {block}\n  }\n}\n\ntablet() {\n  @media (min-width: 768px) and (max-width: 991px) {\n    {block}\n  }\n}\n\ndesktop() {\n  @media (min-width: 992px) {\n    {block}\n  }\n}\n\ndesktop-large() {\n  @media (min-width: 1600px) {\n    {block}\n  }\n}\n\ncircle() {\n  border-radius: 50%;\n}\n\ntransform() {\n  -webkit-transform: arguments\n  -moz-transform: arguments\n  -ms-transform: arguments\n  -o-transform: arguments\n  transform: arguments\n}\n\nhide() {\n  display: none !important;\n}\n\nshow() {\n  display: block !important;\n}\n\nfixbutton() {\n  right: 20px;\n  opacity: 0.8;\n}\n\nrandom-color($min, $max) {\n  return floor(math(0, 'random') * ($max - $min + 1) + $min);\n}\n\n// Clearfix. http://nicolasgallagher.com/micro-clearfix-hack/\nclearfix() {\n  &:before,\n  &:after {\n    content: \" \";\n    display: table;\n  }\n  &:after { clear: both; }\n}\n"
  },
  {
    "path": "source/css/_mixins/custom.styl",
    "content": ""
  },
  {
    "path": "source/css/_schemes/Gemini/index.styl",
    "content": "@import \"../Pisces/_layout\";\n@import \"../Pisces/_brand\";\n@import \"../Pisces/_menu\";\n@import \"../Pisces/_sidebar\";\n// Import _posts if want to justify text-align on mobile.\n//@import \"../Pisces/_posts\";\n\n// =================================================\n// Rewrite _layout.styl\n// =================================================\n// Sidebar padding used as main desktop content padding for sidebar padding and post blocks padding too.\n\n// In main NexT config set `sidebar: offset: 12` option as main padding.\n// In `source/css/_variables/Gemini.styl` there are variables for other resolutions:\n// $content-tablet-paddin            = 10px;\n// $content-mobile-padding           = 8px;\n// P.S. If u want to change this paddings u may set this variables into `source/css/_variables/custom.styl`.\n\n// So, it will 12px in Desktop, 10px in Tablets and 8px in Mobiles for all possible paddings.\n// =================================================\n// Read values from NexT config and set they as local variables to use as string variables (in any CSS section).\nhexo-config('sidebar.offset') is a 'unit' ? (sboffset = unit(hexo-config('sidebar.offset'), px)) : (sboffset = 0)\nuse_seo = hexo-config('seo');\n\n// =================================================\n// Desktop layout styles.\n// =================================================\n// Post blocks.\n.content-wrap {\n  padding: initial;\n  background: initial;\n  box-shadow: initial;\n  border-radius: initial;\n}\n\n// Post & Comments blocks.\n.post-block {\n  padding: $content-desktop-padding;\n  background: white;\n  box-shadow: $box-shadow-inner;\n  border-radius: $border-radius-inner;\n}\n\n// When blocks are siblings (homepage).\n#posts > article + article {\n  .post-block {\n    margin-top: sboffset;\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    border-radius: $border-radius;\n  }\n}\n\n// Comments blocks.\n.comments {\n  padding: $content-desktop-padding;\n  margin: initial;\n  margin-top: sboffset;\n  background: white;\n  box-shadow: $box-shadow;\n  border-radius: $border-radius;\n}\n\n// Top main padding from header to posts (default 40px).\n.posts-expand {\n  padding-top: initial;\n}\n\n// Post navigation items.\n.post-nav-divider {\n  width: 4%;\n}\n.post-nav-item {\n  width: 48%;\n}\n\n// Post delimiters.\n.post-eof,\n.post-spread {\n  hide();\n}\n\n// Pagination.\n.pagination {\n  .prev, .next, .page-number {\n    margin-bottom: initial;\n    top: initial;\n  }\n  margin: sboffset 0 0;\n  border-top: initial;\n  background: white;\n  box-shadow: $box-shadow;\n  border-radius: $border-radius;\n  padding: 10px 0 10px;\n}\n\n// Footer alignment.\n.main {\n  padding-bottom: initial;\n}\n.footer {\n  bottom: auto;\n}\n\n// =================================================\n// Headers.\n// =================================================\n// No need anymore?\n.post-header {\n  h1, h2 {\n    margin: initial;\n  }\n}\n.posts-expand .post-title-link {\n  line-height: inherit;\n}\n.posts-expand .post-title {\n  font-size: 1.7em;\n}\n.post-body {\n  h1 {\n    font-size: 1.6em;\n    border-bottom: 1px solid $body-bg-color;\n  }\n  h2 {\n    font-size: 1.45em;\n    border-bottom: 1px solid $body-bg-color;\n  }\n  h3 {\n    font-size: 1.3em;\n    if use_seo {\n      border-bottom: 1px solid $body-bg-color;\n    } else {\n      border-bottom: 1px dotted $body-bg-color;\n    }\n  }\n  h4 {\n    font-size: 1.2em;\n    if use_seo {\n      border-bottom: 1px dotted $body-bg-color;\n    }\n  }\n  h5 {\n    font-size: 1.07em;\n  }\n  h6 {\n    font-size: 1.03em;\n  }\n}\n\n// =================================================\n// > 768px & < 991px\n// =================================================\n+tablet() {\n\n  // Posts in blocks.\n  .content-wrap {\n    padding: $content-tablet-padding;\n  }\n  .posts-expand {\n    margin: initial;\n\n    // Components inside Posts.\n    .post-button {\n      margin-top: ($content-tablet-padding * 2);\n    }\n  }\n\n  .post-block {\n    // Inside posts blocks content padding (default 40px).\n    padding: ($content-tablet-padding * 2);\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    border-radius: $border-radius;\n  }\n\n  // Only if blocks are siblings need bottom margin (homepage).\n  #posts > article + article {\n    .post-block {\n      margin-top: $content-tablet-padding;\n    }\n  }\n\n  .comments {\n    margin-top: $content-tablet-padding;\n    padding: $content-tablet-padding ($content-tablet-padding * 2);\n    //padding: initial;\n    //padding-top: $content-tablet-padding;\n  }\n\n  .pagination {\n    margin: $content-tablet-padding 0 0;\n  }\n\n}\n// =================================================\n// < 767px\n// =================================================\n+mobile() {\n\n  // Posts in blocks.\n  .content-wrap {\n    padding: $content-mobile-padding;\n  }\n  .posts-expand {\n    margin: initial;\n\n    // Components inside Posts.\n    .post-button {\n      margin-top: sboffset;\n      //padding-bottom : 15px;\n    }\n    img {\n      padding: initial !important;\n    }\n  }\n\n  .post-block {\n    // Inside posts blocks content padding (default 40px).\n    padding: sboffset;\n    min-height: auto;\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    border-radius: $border-radius;\n  }\n\n  // Only if blocks are siblings need bottom margin (homepage).\n  #posts > article + article {\n    .post-block {\n      margin-top: $content-mobile-padding;\n    }\n  }\n\n  .comments {\n    margin-top: $content-mobile-padding;\n    padding: 0 sboffset;\n  }\n\n  .pagination {\n    margin: $content-mobile-padding 0 0;\n  }\n\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_base.styl",
    "content": "// Tags\n// --------------------------------------------------\nh1, h2, h3, h4, h5, h6 { margin: 20px 0 10px; }\n\np { margin: 0 0 25px 0; }\n\na { border-bottom-color: $grey-light; }\n\nhr {\n  margin: 20px 0;\n  height: 2px;\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_header.styl",
    "content": "// Header\n// --------------------------------------------------\n.header { background: $whitesmoke; }\n.header-inner {\n  padding: 25px 0 20px;\n  clearfix();\n\n  +mobile() {\n    width: auto;\n    margin-bottom: 50px;\n    padding: 10px;\n  }\n}\n\n.site-meta {\n  float: left;\n  margin-left: -20px;\n  line-height: normal;\n\n  +mobile() {\n    margin-left: 10px;\n  }\n\n  .brand {\n    padding: 2px 1px;\n    background: none;\n\n    +mobile() { display: block; }\n  }\n\n  .logo { display: none; }\n\n  .site-title {\n    font-size: 22px;\n    font-weight: bolder;\n\n    +mobile() { line-height: 34px; }\n  }\n}\n\n\n.logo-line-before,\n.logo-line-after {\n  display: block;\n  overflow: hidden;\n  margin: 0 auto;\n  width: 75%;\n\n  +mobile() { display: none; }\n\n  i {\n    position: relative;\n    display: block;\n    height: 2px;\n    background: $black-deep;\n    +mobile() { height: 3px; }\n  }\n}\n\n.use-motion {\n  .logo-line-before i { left: -100%; }\n  .logo-line-after i { right: -100%; }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_logo.styl",
    "content": ".site-subtitle { display: none; }\n"
  },
  {
    "path": "source/css/_schemes/Mist/_menu.styl",
    "content": "// Menu\n// --------------------------------------------------\n.site-nav-toggle {\n  position: static;\n  float: right;\n}\n\n\n.menu {\n  float: right;\n  margin: 8px 0 0 0;\n\n  +mobile() {\n    margin: 20px 0 0 0;\n    padding: 0;\n  }\n\n  br { display: none; }\n\n  .menu-item {\n    margin: 0;\n    +mobile() { display: block; }\n  }\n\n  .menu-item a {\n    padding: 0 10px;\n    background: none;\n    border: none;\n    border-radius: 2px;\n    transition-property: background;\n\n    +mobile() {\n      text-align: left;\n    }\n\n    &:hover { background: #e1e1e1; }\n  }\n\n  a::before {\n      display: none;\n\n      +mobile() { display: block; }\n    }\n\n  +mobile() { float: none; }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_posts-expanded.styl",
    "content": "// Post Expanded\n// --------------------------------------------------\n.posts-expand {\n  padding-top: 0;\n\n  .post-title,\n  .post-meta {\n    text-align: $site-meta-text-align;\n    +mobile() { text-align: center; }\n  }\n  .post-eof { display: none; }\n\n  .post { margin-top: 120px; }\n  .post:first-child { margin-top: 0; }\n\n  .post-meta {\n    margin-top: 5px;\n    margin-bottom: 20px;\n  }\n\n  .post-title {\n    position: relative;\n    font-size: $font-size-headings-base;\n    font-weight: 400;\n    +mobile() { font-size: $font-size-headings-small; }\n    +desktop-large() { font-size: $font-size-headings-large; }\n  }\n  .post-title:hover:before { background: $black-deep; }\n\n  .post-body {\n    +mobile() { font-size: $font-size-small; }\n  }\n\n  .post-body img { margin: 0; }\n\n  .post-tags {\n    text-align: left;\n    a {\n      padding: 1px 5px;\n      background: $whitesmoke;\n      border-bottom: none;\n    }\n    a:hover { background: $grey-light; }\n  }\n  .post-nav { margin-top: 40px; }\n}\n\n.post-button {\n  margin-top: 20px;\n  text-align: left;\n\n  a {\n    padding: 0;\n    font-size: $font-size-base;\n    //color: $grey-dim;\n    background: none;\n    border: none;\n    border-bottom: 2px solid $grey-dim;\n    transition-property: border;\n\n    +mobile() { font-size: $font-size-small; }\n    +desktop-large() { font-size: $font-size-large; }\n\n\n    &:hover { border-bottom-color: $black-deep; }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_search.styl",
    "content": "// Search\n// --------------------------------------------------\n.site-search form {\n  display: none;\n}"
  },
  {
    "path": "source/css/_schemes/Mist/index.styl",
    "content": "//\n// Mist scheme\n// =================================================\n\n@import \"_base\";\n@import \"outline/outline\";\n@import \"_header\";\n@import \"_logo\";\n@import \"_menu\";\n@import \"_search.styl\";\n@import \"_posts-expanded\";\n@import \"sidebar/sidebar-blogroll\";\n\n\n// Components\n// --------------------------------------------------\n.btn {\n  padding: 0 10px;\n  border-width: 2px;\n  border-radius: 0;\n}\n\n.headband { display: none; }\n\n\n// Search\n// --------------------------------------------------\n.site-search {\n  position: relative;\n  float: right;\n  margin-top: 5px;\n  padding-top: 3px;\n\n  +mobile() {\n    float: none;\n    padding: 0 10px;\n  }\n}\n\n\n// Page - Container\n// --------------------------------------------------\n.container .main-inner {\n  +mobile() { width: auto; }\n}\n\n\n// Page - Post details\n// --------------------------------------------------\n.page-post-detail {\n  .post-title,\n  .post-meta { text-align: center; }\n\n  .post-title:before { display: none; }\n\n  .post-meta { margin-bottom: 60px; }\n}\n\n\n// Pagination\n// --------------------------------------------------\n.pagination {\n  margin: 120px 0 0;\n  text-align: left;\n\n  +mobile() {\n    margin: 80px 10px 0;\n    text-align: center;\n  }\n}\n\n// Footer\n// --------------------------------------------------\n.footer {\n  margin-top: 80px;\n  padding: 10px 0;\n  background: $whitesmoke;\n  color: $grey-dim;\n}\n.footer-inner {\n  margin: 0 auto;\n  text-align: left;\n\n  +mobile() {\n    width: auto;\n    text-align: center;\n  }\n}\n\n// Helpers\n// --------------------------------------------------\n"
  },
  {
    "path": "source/css/_schemes/Mist/outline/outline.styl",
    "content": ".main-inner { margin-top: 80px; }\n"
  },
  {
    "path": "source/css/_schemes/Mist/sidebar/sidebar-blogroll.styl",
    "content": ".links-of-blogroll-inline .links-of-blogroll-item { display: inline-block; }\n"
  },
  {
    "path": "source/css/_schemes/Muse/_layout.styl",
    "content": ".header-inner, .container .main-inner, .footer-inner {\n  +mobile() { width: auto; }\n}\n\n// embed tag\nembed {\n   display: block;\n   margin:  0px auto 25px auto;\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_logo.styl",
    "content": ".custom-logo {\n  .site-meta-headline { text-align: center; }\n\n  .brand { background: none; }\n\n  .site-title {\n    margin: 10px auto 0;\n    font-size: 24px;\n    color: $black-deep;\n    a { border: none; }\n  }\n\n\n}\n\n.custom-logo-image {\n  margin: 0 auto;\n  padding: 5px;\n  max-width: 150px;\n  background: white;\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_menu.styl",
    "content": ".site-nav {\n  +mobile() {\n    position: absolute;\n    left: 0;\n    top: 52px;\n    margin: 0;\n    width: 100%;\n    padding: 0;\n    background: white;\n    border-bottom: 1px solid $gray-lighter;\n    z-index: $zindex-3;\n  }\n}\n\n.menu {\n  +mobile() { text-align: left; }\n}\n.menu .menu-item {\n  +mobile() {\n    display: block;\n    margin: 0 10px;\n    vertical-align: top;\n  }\n\n  br {\n    +mobile() { display: none; }\n  }\n\n  a {\n    +mobile() { padding: 5px 10px; }\n  }\n  .fa { margin-right: 0; }\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_search.styl",
    "content": "// Search\n// --------------------------------------------------\n.site-search form {\n  display: none;\n}"
  },
  {
    "path": "source/css/_schemes/Muse/index.styl",
    "content": "@import \"_layout.styl\";\n@import \"_logo.styl\";\n@import \"_menu.styl\";\n@import \"_search.styl\";\n@import \"sidebar/sidebar-blogroll\";\n"
  },
  {
    "path": "source/css/_schemes/Muse/sidebar/sidebar-blogroll.styl",
    "content": ".links-of-blogroll-inline .links-of-blogroll-item { display: inline-block; }\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_brand.styl",
    "content": ".site-brand-wrapper {\n  position: relative;\n}\n\n.site-meta {\n  padding: 20px 0;\n  color: white;\n  background: $black-deep;\n\n  +tablet() {\n    box-shadow: 0 0 16px rgba(0,0,0,0.5);\n  }\n  +mobile() {\n    box-shadow: 0 0 16px rgba(0,0,0,0.5);\n  }\n}\n\n.brand {\n  padding: 0;\n  background: none;\n\n  &:hover { color: white; }\n}\n\n.site-subtitle {\n  margin: 10px 10px 0;\n  font-weight: initial;\n}\n\n.site-search form { display: none; }\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_layout.styl",
    "content": ".header {\n  position: relative;\n  margin: 0 auto;\n  width: $main-desktop;\n\n  +tablet() {\n    width: auto;\n  }\n  +mobile() {\n    width: auto;\n  }\n}\n\n.header-inner {\n  position: absolute;\n  top: 0;\n  overflow: hidden;\n  padding: 0;\n  width: 240px;\n  background: white;\n  box-shadow: $box-shadow-inner;\n  border-radius: $border-radius-inner;\n\n  +desktop-large() {\n    .container & { width: 240px; }\n  }\n  +tablet() {\n    position: relative;\n    width: auto;\n    border-radius: initial;\n  }\n  +mobile() {\n    position: relative;\n    width: auto;\n    border-radius: initial;\n  }\n}\n\n.main {\n  clearfix();\n  +tablet() {\n    padding-bottom: 100px;\n  }\n  +mobile() {\n    padding-bottom: 100px;\n  }\n}\n\n.container .main-inner {\n  width: $main-desktop;\n\n  +tablet() {\n    width: auto;\n  }\n  +mobile() {\n    width: auto;\n  }\n}\n\n.content-wrap {\n  float: right;\n  box-sizing: border-box;\n  padding: $content-desktop-padding;\n  width: $content-desktop;\n  background: white;\n  min-height: 700px;\n  box-shadow: $box-shadow-inner;\n  border-radius: $border-radius-inner;\n\n  +tablet() {\n    width: 100%;\n    padding: 20px;\n    border-radius: initial;\n  }\n  +mobile() {\n    width: 100%;\n    padding: 20px;\n    min-height: auto;\n    border-radius: initial;\n  }\n}\n\n.sidebar {\n  position: static;\n  float: left;\n  margin-top: 300px;\n  width: $sidebar-desktop;\n  background: $body-bg-color;\n  box-shadow: none;\n\n  +tablet() {\n    display: none;\n  }\n  +mobile() {\n    display: none;\n  }\n}\n\n.sidebar-toggle { display: none; }\n\n\n.footer-inner {\n  width: $main-desktop;\n  padding-left: 260px;\n\n  +tablet() {\n    width: auto;\n    padding-left: 0 !important;\n    padding-right: 0 !important;\n  }\n  +mobile() {\n    width: auto;\n    padding-left: 0 !important;\n    padding-right: 0 !important;\n  }\n}\n\n\n\n.sidebar-position-right {\n  .header-inner { right: 0; }\n  .content-wrap { float: left; }\n  .sidebar { float: right; }\n\n  .footer-inner {\n    padding-left: 0;\n    padding-right: 260px;\n  }\n}\n\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_menu.styl",
    "content": ".site-nav {\n  border-top: none;\n\n  +tablet() {\n    display: none !important;\n  }\n}\n\n.site-nav-on {\n  +tablet() {\n    display: block !important;\n  }\n}\n\n.menu .menu-item {\n  display: block;\n  margin: 0;\n\n  a {\n    position: relative;\n    box-sizing: border-box;\n    padding: 5px 20px;\n    text-align: left;\n    line-height: inherit;\n    transition-property: background-color;\n    the-transition();\n\n    &:hover {\n      background: #f9f9f9;\n      border-bottom-color: white;\n    }\n  }\n\n  br { display: none; }\n}\n\n.menu-item-active a {\n  @extend .menu .menu-item a:hover;\n\n  &:after {\n    content: \" \";\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    right: 15px;\n    width: 6px;\n    height: 6px;\n    border-radius: 50%;\n    background-color: $grey;\n  }\n}\n\n.btn-bar {\n  background-color: white;\n}\n\n.site-nav-toggle {\n  left: 20px;\n  top: 50%;\n\n  -webkit-transform:  translateY(-50%);\n  transform:  translateY(-50%);\n\n  +tablet() {\n    display: block;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_posts.styl",
    "content": ".post-body {\n  +mobile() {\n    text-align: justify;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_sidebar.styl",
    "content": ".use-motion .sidebar .motion-element { opacity: 1; }\n\n.sidebar {\n  margin-left: -100%;\n  right: auto;\n  bottom: auto;\n\n  // Do NOT delete this line\n  // or Affix (position: fixed) will not work in Google Chrome.\n  -webkit-transform: none;\n}\n\n\n.sidebar-inner {\n//padding: 20px 10px 0;\n  box-sizing: border-box;\n  width: 240px;\n  color: $text-color;\n  background: white;\n  box-shadow: $box-shadow;\n  border-radius: $border-radius;\n  if (hexo-config('motion.enable') and hexo-config('motion.transition.sidebar')) { opacity: 0; }\n\n  &.affix {\n    position: fixed;\n    top: $sidebar-offset;\n  }\n\n  &.affix-bottom {\n    position: absolute;\n  }\n\n}\n\n.site-overview {\n  //margin: 0 2px;\n  text-align: left;\n}\n\n.site-author {\n  clearfix();\n}\n\n.sidebar a {\n  color: $black-light;\n\n  &:hover { color: $black-deep; }\n}\n\n.site-state-item {\n  padding: 0 10px;\n}\n\n.links-of-author-item {\n  a:before { display: none; }\n  a {\n    border-bottom: none;\n    text-decoration: underline;\n  }\n}\n\n.feed-link {\n  border-top: 1px dotted $grey-light;\n  border-bottom: 1px dotted $grey-light;\n  text-align: center;\n}\n\n.feed-link a {\n  display: block;\n  color: $orange;\n  border: none;\n\n  &:hover {\n    background: none;\n    color: darken($orange, 20%);\n\n    i { color: darken($orange, 20%); }\n  }\n}\n\n.links-of-author {\n  //clearfix();\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: center;\n}\n.links-of-author-item {\n  sidebar-inline-links-item();\n\n  a {\n    display: block;\n    text-decoration: none;\n\n    &:hover {\n      border-radius: 4px;\n      background: $gainsboro;\n    }\n  }\n\n  .fa {\n    margin-right: 2px;\n    font-size: 16px;\n  }\n  .fa-globe { font-size: 15px; }\n}\n\n\n.links-of-blogroll {\n  text-align: center;\n  margin-top: 20px;\n  padding: 3px 0 0;\n  border-top: 1px dotted $grey-light;\n}\n.links-of-blogroll-title { margin-top: 0; }\n.links-of-blogroll-item { padding: 0; }\n.links-of-blogroll-inline {\n  clearfix();\n\n  .links-of-blogroll-item {\n    sidebar-inline-links-item();\n    display: inline-block;\n    if !hexo-config('social_icons.icons_only') { width: unset; }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/index.styl",
    "content": "@import \"_layout\";\n@import \"_brand\";\n@import \"_menu\";\n@import \"_sidebar\";\n@import \"_posts\";\n"
  },
  {
    "path": "source/css/_variables/Gemini.styl",
    "content": "// Variables of Gemini scheme\n// =================================================\n\n@import \"Pisces.styl\";\n\n// Settings for some of the most global styles.\n// --------------------------------------------------\n$body-bg-color                    = #eee\n$main-desktop                     = 75%\n$sidebar-desktop                  = 240px\n$content-desktop                  = calc(100% - 252px)\n\n// Borders.\n// --------------------------------------------------\n$box-shadow-inner                 = 0 2px 2px 0 rgba(0,0,0,.12), 0 3px 1px -2px rgba(0,0,0,.06), 0 1px 5px 0 rgba(0,0,0,.12)\n$box-shadow                       = 0 2px 2px 0 rgba(0,0,0,.12), 0 3px 1px -2px rgba(0,0,0,.06), 0 1px 5px 0 rgba(0,0,0,.12), 0 -1px .5px 0 rgba(0,0,0,.09)\n\n$border-radius-inner              = initial\n$border-radius                    = initial\n//$border-radius-inner            = 0 0 3px 3px;\n//$border-radius                  = 3px;\n"
  },
  {
    "path": "source/css/_variables/Mist.styl",
    "content": "// Variables of Mist scheme\n// =================================================\n\n$font-size-headings-base = 26px\n\n$brand-color             = $black-deep\n$brand-hover-color       = $brand-color\n\n$site-meta-text-align    = left\n$posts-collapse-left     = 0\n\n$btn-default-color       = $link-color\n$btn-default-bg          = transparent\n"
  },
  {
    "path": "source/css/_variables/Muse.styl",
    "content": ""
  },
  {
    "path": "source/css/_variables/Pisces.styl",
    "content": "// Variables of Pisces scheme\n// =================================================\n\n// Settings for some of the most global styles.\n// --------------------------------------------------\n$body-bg-color                = #f5f7f9\n\n\n// Borders\n// --------------------------------------------------\n$box-shadow-inner                 = initial;\n$box-shadow                       = initial;\n\n$border-radius-inner              = initial;\n$border-radius                    = initial;\n\n\n// Header\n// --------------------------------------------------\n$subtitle-color                   = $gray-lighter\n\n// Sidebar\n// --------------------------------------------------\n$sidebar-offset             = unit(hexo-config('sidebar.offset'), px) if hexo-config('sidebar.offset') is a 'unit'\n\n$sidebar-nav-hover-color          = $orange\n$sidebar-highlight                = $orange\n\n$site-author-image-width          = 120px\n$site-author-image-border-width   = 1px\n$site-author-image-border-color   = $gainsboro\n\n$site-author-name-margin          = 0\n$site-author-name-color           = $black-deep\n$site-author-name-align           = center\n$site-author-name-weight          = $font-weight-bold\n\n$site-description-font-size       = 13px\n$site-description-color           = $grey-dark\n$site-description-margin-top      = 0\n$site-description-align           = center\n\n$site-state-item-count-font-size  = 16px\n$site-state-item-name-font-size   = 13px\n$site-state-item-name-color       = $grey-dark\n$site-state-item-border-color     = $gainsboro\n\n$toc-link-color                       = $grey-dim\n$toc-link-border-color                = $grey-light\n$toc-link-hover-color                 = black\n$toc-link-hover-border-color          = black\n$toc-link-active-color                = $sidebar-highlight\n$toc-link-active-border-color         = $sidebar-highlight\n$toc-link-active-current-color        = $sidebar-highlight\n$toc-link-active-current-border-color = $sidebar-highlight\n\n\n// Components\n// --------------------------------------------------\n\n// Button\n$btn-default-radius           = 2px\n$btn-default-bg               = white\n$btn-default-color            = $text-color\n$btn-default-border-color     = $text-color\n$btn-default-hover-color      = white\n$btn-default-hover-bg         = $black-deep\n\n// Full Image Tag\n$full-image-width             = 118%\n$full-image-margin-horizontal = -9%\n$full-image-margin-vertical   = 0\n\n// Back to top\n$b2t-opacity                  = .6\n$b2t-position-bottom          = -100px\n$b2t-position-bottom-on       = 30px\n"
  },
  {
    "path": "source/css/_variables/base.styl",
    "content": "//\n// Variables\n// =================================================\n\n\n\n// Colors\n// colors for use across theme.\n// --------------------------------------------------\n\n$whitesmoke   = #f5f5f5\n$gainsboro    = #eee\n$gray-lighter = #ddd\n$grey-light   = #ccc\n$grey         = #bbb\n$grey-dark    = #999\n$grey-dim     = #666\n$black-light  = #555\n$black-dim    = #333\n$black-deep   = #222\n$red          = #ff2a2a\n$blue-bright  = #87daff\n$blue         = #0684bd\n$blue-deep    = #262a30\n$orange       = #fc6423\n\n\n\n// Scaffolding\n// Settings for some of the most global styles.\n// --------------------------------------------------\n\n// Global text color on <body>\n$text-color                   = $black-light\n\n// Global link color.\n$link-color                   = $black-light\n$link-hover-color             = $black-deep\n$link-decoration-color        = $grey-light\n$link-decoration-hover-color  = $black-deep\n\n// Global border color.\n$border-color                 = $grey-light\n\n// Background color for <body>\n$body-bg-color                = white\n\n// Selection\n$selection-bg                 = $blue-deep\n$selection-color              = white\n\n\n\n// Typography\n// Font, line-height, and elements colors.\n// --------------------------------------------------\n\n\nget_font_family(config) {\n  custom_family = hexo-config('font.' + config + '.family')\n  return custom_family is a 'string' ? custom_family : null\n}\n\n// Font families.\n$font-family-chinese      = \"PingFang SC\", \"Microsoft YaHei\"\n\n$font-family-base         = $font-family-chinese, sans-serif\n$font-family-base         = get_font_family('global'), $font-family-chinese, sans-serif if get_font_family('global')\n\n$font-family-logo         = $font-family-base\n$font-family-logo         = get_font_family('logo'), $font-family-base if get_font_family('logo')\n\n$font-family-headings     = $font-family-base\n$font-family-headings     = get_font_family('headings'), $font-family-base if get_font_family('headings')\n\n$font-family-posts        = $font-family-base\n$font-family-posts        = get_font_family('posts'), $font-family-base if get_font_family('posts')\n\n$font-family-monospace    = consolas, Menlo, $font-family-chinese, monospace\n$font-family-monospace    = get_font_family('codes'), consolas, Menlo, $font-family-chinese, monospace if get_font_family('codes')\n\n$font-family-icons        = 'FontAwesome'\n\n\n// Font Weight\n$font-weight-lighter      = 200\n$font-weight-light        = 300\n$font-weight-normal       = 400\n$font-weight-bold         = 600\n$font-weight-bolder       = 700\n\n\n// Font size\n$font-size-base           = 14px\n$font-size-base           = unit(hexo-config('font.global.size'), px) if hexo-config('font.global.size') is a 'unit'\n$font-size-small          = $font-size-base - 2px\n$font-size-smaller        = $font-size-base - 4px\n$font-size-large          = $font-size-base + 2px\n$font-size-larger         = $font-size-base + 4px\n\n\n// Headings font size\n$font-size-headings-step    = 2px\n$font-size-headings-base    = 24px\n$font-size-headings-base    = unit(hexo-config('font.headings.size'), px) if hexo-config('font.headings.size') is a 'unit'\n$font-size-headings-small   = $font-size-headings-base - $font-size-headings-step\n$font-size-headings-smaller = $font-size-headings-small - $font-size-headings-step\n$font-size-headings-large   = $font-size-headings-base + $font-size-headings-step\n$font-size-headings-larger  = $font-size-headings-large + $font-size-headings-step\n\n// Global line height\n$line-height-base           = 2\n$line-height-code-block     = 1.6  // Can't be less than 1.3\n\n\n\n// Z-index master list\n// --------------------------------------------------\n$zindex-bottom  = -1\n$zindex-1       = 1010\n$zindex-2       = 1020\n$zindex-3       = 1030\n$zindex-4       = 1040\n$zindex-5       = 1050\n\n\n\n// Table\n// --------------------------------------------------\n$table-width                    = 100%\n$table-border-color             = $gray-lighter\n$table-font-size                = 14px\n$table-content-alignment        = left\n$table-content-vertical         = middle\n$table-th-font-weight           = 700\n$table-cell-padding             = 8px\n$table-cell-border-right-color  = $gainsboro\n$table-cell-border-bottom-color = $gray-lighter\n$table-row-odd-bg-color         = #f9f9f9\n$table-row-hover-bg-color       = $whitesmoke\n\n\n\n// Code & Code Blocks\n// --------------------------------------------------\n$code-font-family               = $font-family-monospace\n$code-font-size                 = 13px\n$code-font-size                 = unit(hexo-config('font.codes.size'), px) if hexo-config('font.codes.size') is a 'unit'\n$code-border-radius             = 3px\n$code-foreground                = $black-light\n$code-background                = $gainsboro\n\n\n\n// Buttons\n// --------------------------------------------------\n\n$btn-font-weight                = normal\n\n$btn-default-radius             = 0\n$btn-default-bg                 = $black-deep\n$btn-default-color              = white\n$btn-default-font-size          = 14px\n$btn-default-border-width       = 2px\n$btn-default-border-color       = $black-deep\n$btn-default-hover-bg           = white\n$btn-default-hover-color        = $black-deep\n$btn-default-hover-border-color = $black-deep\n\n\n\n// Pagination\n// --------------------------------------------------\n\n$pagination-border              = $gainsboro\n\n$pagination-link-bg             = transparent\n$pagination-link-color          = $link-color\n$pagination-link-border         = $gainsboro\n\n$pagination-link-hover-bg       = transparent\n$pagination-link-hover-color    = $link-color\n$pagination-link-hover-border   = $black-deep\n\n$pagination-active-bg           = $grey-light\n$pagination-active-color        = white\n$pagination-active-border       = $grey-light\n\n\n\n// Layout sizes\n// --------------------------------------------------\n\n$main-desktop                   = 960px\n$main-desktop-large             = 1200px\n\n$content-desktop                = 700px\n$content-desktop-large          = 900px\n\n$content-desktop-padding        = 40px\n$content-tablet-padding         = 10px\n$content-mobile-padding         = 8px\n\n$sidebar-desktop                = 240px\n\n$footer-height                  = 50px\n\n$gap-between-main-and-footer    = 100px\n\n\n\n// Headband\n// --------------------------------------------------\n$headband-height                = 3px\n$headband-bg                    = $black-deep\n\n\n\n// Section Header\n// Variables for header section elements.\n// --------------------------------------------------\n\n$head-bg                        = transparent\n\n// Site Meta\n$site-meta-text-align           = center\n$brand-color                    = white\n$brand-hover-color              = white\n$brand-bg                       = $black-deep\n\n$logo-font-size                 = 20px\n$logo-font-size                 = unit(hexo-config('font.logo.size'), px) if hexo-config('font.logo.size') is a 'unit'\n\n$site-subtitle-color            = $grey-dark\n$subtitle-font-size             = 13px\n$subtitle-color                 = $grey-dark\n\n// Menu\n$menu-link-border               = transparent\n$menu-link-hover-border         = $black-deep\n\n\n\n// Posts Expand\n// --------------------------------------------------\n$posts-expand-title-font-weight = $font-weight-normal\n$post-copyright = {\n  margin: 2em 0 0,\n  padding: .5em 1em,\n  bg: #f9f9f9,\n  border: {\n    width: 3px,\n    style: solid,\n    color: #ff1700\n  }\n}\n\n\n// Posts Collpase\n// --------------------------------------------------\n$posts-collapse-left            = 55px\n$posts-collapse-left-mobile     = 5px\n\n\n// Sidebar\n// Variables for sidebar section elements.\n// --------------------------------------------------\n$sidebar-nav-color                    = $black-light\n$sidebar-nav-hover-color              = $whitesmoke\n$sidebar-highlight                    = $blue-bright\n\n$site-author-image-padding            = 2px\n$site-author-image-width              = 96px\n$site-author-image-height             = auto\n$site-author-image-border-width       = 2px\n$site-author-image-border-color       = $black-dim\n\n$site-author-name-margin              = 5px 0 0\n$site-author-name-color               = $whitesmoke\n$site-author-name-align               = center\n$site-author-name-weight              = normal\n\n$site-description-font-size           = 14px\n$site-description-color               = $grey-dark\n$site-description-margin-top          = 5px\n$site-description-align               = center\n\n$site-state-align                     = center\n$site-state-item-count-font-size      = 18px\n$site-state-item-count-color          = inherit\n$site-state-item-name-font-size       = 13px\n$site-state-item-name-color           = inherit\n$site-state-item-border-color         = $black-dim\n\n$toc-link-color                       = $grey-dark\n$toc-link-border-color                = $black-light\n$toc-link-hover-color                 = $grey-light\n$toc-link-hover-border-color          = $grey-light\n$toc-link-active-color                = $sidebar-highlight\n$toc-link-active-border-color         = $sidebar-highlight\n$toc-link-active-current-color        = $sidebar-highlight\n$toc-link-active-current-border-color = $sidebar-highlight\n\n\n// Components\n// --------------------------------------------------\n\n// Back to top\n$b2t-opacity                  = 1\n$b2t-position-bottom          = -100px\n$b2t-position-bottom-on       = 19px\n$b2t-position-right           = 30px\n$b2t-font-size                = 12px\n$b2t-color                    = white\n$b2t-bg-color                 = $black-deep\n\n// full-image\n$full-image-width             = 110%\n$full-image-margin-horizontal = -5%\n$full-image-margin-vertical   = 25px\n\n//  .post-expand .post-eof\n//  In Muse scheme, margin above and below the post separator\n$post-eof-margin-top          = 80px  //  or 160px for more white space\n$post-eof-margin-bottom       = 60px  //  or 120px for less white space\n\n\n// Iconography\n// Icons SVG Base64\n// --------------------------------------------------\n\n// blockquote-center icon\n$center-quote-left            = '../images/quote-l.svg'\n$center-quote-right           = '../images/quote-r.svg'\n\n\n// Note colors\n// --------------------------------------------------\n// Read note light_bg_offset from NexT config and set in \"lbg%\" to use it as string variable.\nhexo-config('note.light_bg_offset') is a 'unit' ? (lbg = unit(hexo-config('note.light_bg_offset'),\"%\")) : (lbg = 0)\n\n// Default\n$note-default-border        = #777\n$note-default-bg            = lighten(spin($note-default-border, 0), 94% + lbg)\n$note-default-text          = $note-default-border\n$note-default-icon          = \"\\f0a9\"\n\n$note-modern-default-border = #e1e1e1\n$note-modern-default-bg     = lighten(spin($note-modern-default-border, 10), 60% + (lbg * 4))\n$note-modern-default-text   = $grey-dim\n$note-modern-default-hover  = darken(spin($note-modern-default-text, -10), 32%)\n\n// Primary\n$note-primary-border        = #6f42c1\n$note-primary-bg            = lighten(spin($note-primary-border, 10), 92% + lbg)\n$note-primary-text          = $note-primary-border\n$note-primary-icon          = \"\\f055\"\n\n$note-modern-primary-border = #e1c2ff\n$note-modern-primary-bg     = lighten(spin($note-modern-primary-border, 10), 40% + (lbg * 4))\n$note-modern-primary-text   = #6f42c1\n$note-modern-primary-hover  = darken(spin($note-modern-primary-text, -10), 22%)\n\n// Info\n$note-info-border           = #428bca\n$note-info-bg               = lighten(spin($note-info-border, -10), 91% + lbg)\n$note-info-text             = $note-info-border\n$note-info-icon             = \"\\f05a\"\n\n$note-modern-info-border    = #b3e5ef\n$note-modern-info-bg        = lighten(spin($note-modern-info-border, 10), 50% + (lbg * 4))\n$note-modern-info-text      = #31708f\n$note-modern-info-hover     = darken(spin($note-modern-info-text, -10), 32%)\n\n// Success\n$note-success-border        = #5cb85c\n$note-success-bg            = lighten(spin($note-success-border, 10), 90% + lbg)\n$note-success-text          = $note-success-border\n$note-success-icon          = \"\\f058\"\n\n$note-modern-success-border = #d0e6be\n$note-modern-success-bg     = lighten(spin($note-modern-success-border, 10), 40% + (lbg * 4))\n$note-modern-success-text   = #3c763d\n$note-modern-success-hover  = darken(spin($note-modern-success-text, -10), 27%)\n\n// Warning\n$note-warning-border        = #f0ad4e\n$note-warning-bg            = lighten(spin($note-warning-border, 10), 88% + lbg)\n$note-warning-text          = $note-warning-border\n$note-warning-icon          = \"\\f06a\"\n\n$note-modern-warning-border = #fae4cd\n$note-modern-warning-bg     = lighten(spin($note-modern-warning-border, 10), 43% + (lbg * 4))\n$note-modern-warning-text   = #8a6d3b\n$note-modern-warning-hover  = darken(spin($note-modern-warning-text, -10), 18%)\n\n// Danger\n$note-danger-border         = #d9534f\n$note-danger-bg             = lighten(spin($note-danger-border, -10), 92% + lbg)\n$note-danger-text           = $note-danger-border\n$note-danger-icon           = \"\\f056\"\n\n$note-modern-danger-border  = #ebcdd2\n$note-modern-danger-bg      = lighten(spin($note-modern-danger-border, 10), 35% + (lbg * 4))\n$note-modern-danger-text    = #a94442\n$note-modern-danger-hover   = darken(spin($note-modern-danger-text, -10), 22%)\n\n\n// Label colors\n// --------------------------------------------------\n$label-default              = lighten(spin($note-default-border, 0), 89% + lbg)\n$label-primary              = lighten(spin($note-primary-border, 10), 87% + lbg)\n$label-info                 = lighten(spin($note-info-border, -10), 86% + lbg)\n$label-success              = lighten(spin($note-success-border, 10), 85% + lbg)\n$label-warning              = lighten(spin($note-warning-border, 10), 83% + lbg)\n$label-danger               = lighten(spin($note-danger-border, -10), 87% + lbg)\n"
  },
  {
    "path": "source/css/_variables/custom.styl",
    "content": ""
  },
  {
    "path": "source/css/main.styl",
    "content": "// CSS Style Guide: http://codeguide.co/#css\n\n\n\n$scheme    = hexo-config('scheme') ? hexo-config('scheme') : 'Muse';\n$variables = base $scheme custom;\n$mixins    = base $scheme custom;\n\n\n\n// Variables Layer\n// --------------------------------------------------\nfor $variable in $variables\n  @import \"_variables/\" + $variable\n\n\n// Mixins Layer\n// --------------------------------------------------\nfor $mixin in $mixins\n  @import \"_mixins/\" + $mixin;\n\n\n\n// Common Layer\n// --------------------------------------------------\n\n// Scaffolding\n@import \"_common/scaffolding\";\n\n// Layout\n@import \"_common/outline\";\n\n// Components\n@import \"_common/components\";\n\n\n// Schemes Layer\n// --------------------------------------------------\n@import \"_schemes/\" + $scheme;\n\n\n\n// Custom Layer\n// --------------------------------------------------\n@import \"_custom/custom\";\n"
  },
  {
    "path": "source/fonts/.gitkeep",
    "content": ""
  },
  {
    "path": "source/js/src/affix.js",
    "content": "/* ========================================================================\n * Bootstrap: affix.js v3.3.5\n * http://getbootstrap.com/javascript/#affix\n * ========================================================================\n * Copyright 2011-2015 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * ======================================================================== */\n\n\n+function ($) {\n  'use strict';\n\n  // AFFIX CLASS DEFINITION\n  // ======================\n\n  var Affix = function (element, options) {\n    this.options = $.extend({}, Affix.DEFAULTS, options)\n\n    this.$target = $(this.options.target)\n      .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))\n      .on('click.bs.affix.data-api',  $.proxy(this.checkPositionWithEventLoop, this))\n\n    this.$element     = $(element)\n    this.affixed      = null\n    this.unpin        = null\n    this.pinnedOffset = null\n\n    this.checkPosition()\n  }\n\n  Affix.VERSION  = '3.3.5'\n\n  Affix.RESET    = 'affix affix-top affix-bottom'\n\n  Affix.DEFAULTS = {\n    offset: 0,\n    target: window\n  }\n\n  Affix.prototype.getState = function (scrollHeight, height, offsetTop, offsetBottom) {\n    var scrollTop    = this.$target.scrollTop()\n    var position     = this.$element.offset()\n    var targetHeight = this.$target.height()\n\n    if (offsetTop != null && this.affixed == 'top') return scrollTop < offsetTop ? 'top' : false\n\n    if (this.affixed == 'bottom') {\n      if (offsetTop != null) return (scrollTop + this.unpin <= position.top) ? false : 'bottom'\n      return (scrollTop + targetHeight <= scrollHeight - offsetBottom) ? false : 'bottom'\n    }\n\n    var initializing   = this.affixed == null\n    var colliderTop    = initializing ? scrollTop : position.top\n    var colliderHeight = initializing ? targetHeight : height\n\n    if (offsetTop != null && scrollTop <= offsetTop) return 'top'\n    if (offsetBottom != null && (colliderTop + colliderHeight >= scrollHeight - offsetBottom)) return 'bottom'\n\n    return false\n  }\n\n  Affix.prototype.getPinnedOffset = function () {\n    if (this.pinnedOffset) return this.pinnedOffset\n    this.$element.removeClass(Affix.RESET).addClass('affix')\n    var scrollTop = this.$target.scrollTop()\n    var position  = this.$element.offset()\n    return (this.pinnedOffset = position.top - scrollTop)\n  }\n\n  Affix.prototype.checkPositionWithEventLoop = function () {\n    setTimeout($.proxy(this.checkPosition, this), 1)\n  }\n\n  Affix.prototype.checkPosition = function () {\n    if (!this.$element.is(':visible')) return\n\n    var height       = this.$element.height()\n    var offset       = this.options.offset\n    var offsetTop    = offset.top\n    var offsetBottom = offset.bottom\n    var scrollHeight = Math.max($(document).height(), $(document.body).height())\n\n    if (typeof offset != 'object')         offsetBottom = offsetTop = offset\n    if (typeof offsetTop == 'function')    offsetTop    = offset.top(this.$element)\n    if (typeof offsetBottom == 'function') offsetBottom = offset.bottom(this.$element)\n\n    var affix = this.getState(scrollHeight, height, offsetTop, offsetBottom)\n\n    if (this.affixed != affix) {\n      if (this.unpin != null) this.$element.css('top', '')\n\n      var affixType = 'affix' + (affix ? '-' + affix : '')\n      var e         = $.Event(affixType + '.bs.affix')\n\n      this.$element.trigger(e)\n\n      if (e.isDefaultPrevented()) return\n\n      this.affixed = affix\n      this.unpin = affix == 'bottom' ? this.getPinnedOffset() : null\n\n      this.$element\n        .removeClass(Affix.RESET)\n        .addClass(affixType)\n        .trigger(affixType.replace('affix', 'affixed') + '.bs.affix')\n    }\n\n    if (affix == 'bottom') {\n      this.$element.offset({\n        top: scrollHeight - height - offsetBottom\n      })\n    }\n  }\n\n\n  // AFFIX PLUGIN DEFINITION\n  // =======================\n\n  function Plugin(option) {\n    return this.each(function () {\n      var $this   = $(this)\n      var data    = $this.data('bs.affix')\n      var options = typeof option == 'object' && option\n\n      if (!data) $this.data('bs.affix', (data = new Affix(this, options)))\n      if (typeof option == 'string') data[option]()\n    })\n  }\n\n  var old = $.fn.affix\n\n  $.fn.affix             = Plugin\n  $.fn.affix.Constructor = Affix\n\n\n  // AFFIX NO CONFLICT\n  // =================\n\n  $.fn.affix.noConflict = function () {\n    $.fn.affix = old\n    return this\n  }\n\n\n  // AFFIX DATA-API\n  // ==============\n\n  $(window).on('load', function () {\n    $('[data-spy=\"affix\"]').each(function () {\n      var $spy = $(this)\n      var data = $spy.data()\n\n      data.offset = data.offset || {}\n\n      if (data.offsetBottom != null) data.offset.bottom = data.offsetBottom\n      if (data.offsetTop    != null) data.offset.top    = data.offsetTop\n\n      Plugin.call($spy, data)\n    })\n  })\n\n}(jQuery);\n"
  },
  {
    "path": "source/js/src/algolia-search.js",
    "content": "/* global instantsearch: true */\n/*jshint camelcase: false */\n\n$(document).ready(function () {\n  var algoliaSettings = CONFIG.algolia;\n  var isAlgoliaSettingsValid = algoliaSettings.applicationID &&\n                               algoliaSettings.apiKey &&\n                               algoliaSettings.indexName;\n\n  if (!isAlgoliaSettingsValid) {\n    window.console.error('Algolia Settings are invalid.');\n    return;\n  }\n\n  var search = instantsearch({\n    appId: algoliaSettings.applicationID,\n    apiKey: algoliaSettings.apiKey,\n    indexName: algoliaSettings.indexName,\n    searchFunction: function (helper) {\n      var searchInput = $('#algolia-search-input').find('input');\n\n      if (searchInput.val()) {\n        helper.search();\n      }\n    }\n  });\n\n  // Registering Widgets\n  [\n    instantsearch.widgets.searchBox({\n      container: '#algolia-search-input',\n      placeholder: algoliaSettings.labels.input_placeholder\n    }),\n\n    instantsearch.widgets.hits({\n      container: '#algolia-hits',\n      hitsPerPage: algoliaSettings.hits.per_page || 10,\n      templates: {\n        item: function (data) {\n          var link = data.permalink ? data.permalink : (CONFIG.root + data.path);\n          return (\n            '<a href=\"' + link + '\" class=\"algolia-hit-item-link\">' +\n              data._highlightResult.title.value +\n            '</a>'\n          );\n        },\n        empty: function (data) {\n          return (\n            '<div id=\"algolia-hits-empty\">' +\n              algoliaSettings.labels.hits_empty.replace(/\\$\\{query}/, data.query) +\n            '</div>'\n          );\n        }\n      },\n      cssClasses: {\n        item: 'algolia-hit-item'\n      }\n    }),\n\n    instantsearch.widgets.stats({\n      container: '#algolia-stats',\n      templates: {\n        body: function (data) {\n          var stats = algoliaSettings.labels.hits_stats\n                        .replace(/\\$\\{hits}/, data.nbHits)\n                        .replace(/\\$\\{time}/, data.processingTimeMS);\n          return (\n            stats +\n            '<span class=\"algolia-powered\">' +\n            '  <img src=\"' + CONFIG.root + 'images/algolia_logo.svg\" alt=\"Algolia\" />' +\n            '</span>' +\n            '<hr />'\n          );\n        }\n      }\n    }),\n\n    instantsearch.widgets.pagination({\n      container: '#algolia-pagination',\n      scrollTo: false,\n      showFirstLast: false,\n      labels: {\n        first: '<i class=\"fa fa-angle-double-left\"></i>',\n        last: '<i class=\"fa fa-angle-double-right\"></i>',\n        previous: '<i class=\"fa fa-angle-left\"></i>',\n        next: '<i class=\"fa fa-angle-right\"></i>'\n      },\n      cssClasses: {\n        root: 'pagination',\n        item: 'pagination-item',\n        link: 'page-number',\n        active: 'current',\n        disabled: 'disabled-item'\n      }\n    })\n  ].forEach(search.addWidget, search);\n\n  search.start();\n\n  $('.popup-trigger').on('click', function(e) {\n    e.stopPropagation();\n    $('body')\n      .append('<div class=\"search-popup-overlay algolia-pop-overlay\"></div>')\n      .css('overflow', 'hidden');\n    $('.popup').toggle();\n    $('#algolia-search-input').find('input').focus();\n  });\n\n  $('.popup-btn-close').click(function(){\n    $('.popup').hide();\n    $('.algolia-pop-overlay').remove();\n    $('body').css('overflow', '');\n  });\n\n});\n"
  },
  {
    "path": "source/js/src/bootstrap.js",
    "content": "/* global NexT: true */\n\n$(document).ready(function () {\n\n  $(document).trigger('bootstrap:before');\n\n  NexT.utils.isMobile() && window.FastClick.attach(document.body);\n\n  NexT.utils.lazyLoadPostsImages();\n\n  NexT.utils.registerESCKeyEvent();\n\n  NexT.utils.registerBackToTop();\n\n  // Mobile top menu bar.\n  $('.site-nav-toggle button').on('click', function () {\n    var $siteNav = $('.site-nav');\n    var ON_CLASS_NAME = 'site-nav-on';\n    var isSiteNavOn = $siteNav.hasClass(ON_CLASS_NAME);\n    var animateAction = isSiteNavOn ? 'slideUp' : 'slideDown';\n    var animateCallback = isSiteNavOn ? 'removeClass' : 'addClass';\n\n    $siteNav.stop()[animateAction]('fast', function () {\n      $siteNav[animateCallback](ON_CLASS_NAME);\n    });\n  });\n\n  /**\n   * Register JS handlers by condition option.\n   * Need to add config option in Front-End at 'layout/_partials/head.swig' file.\n   */\n  CONFIG.fancybox && NexT.utils.wrapImageWithFancyBox();\n  CONFIG.tabs && NexT.utils.registerTabsTag();\n\n  NexT.utils.embeddedVideoTransformer();\n  NexT.utils.addActiveClassToMenuItem();\n\n\n  // Define Motion Sequence.\n  NexT.motion.integrator\n    .add(NexT.motion.middleWares.logo)\n    .add(NexT.motion.middleWares.menu)\n    .add(NexT.motion.middleWares.postList)\n    .add(NexT.motion.middleWares.sidebar);\n\n  $(document).trigger('motion:before');\n\n  // Bootstrap Motion.\n  CONFIG.motion.enable && NexT.motion.integrator.bootstrap();\n\n  $(document).trigger('bootstrap:after');\n});\n"
  },
  {
    "path": "source/js/src/exturl.js",
    "content": "/* global NexT: true */\n\n$(document).ready(function () {\n\n  // Create Base64 Object\n  var Base64={_keyStr:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\",encode:function(e){var t=\"\";var n,r,i,s,o,u,a;var f=0;e=Base64._utf8_encode(e);while(f<e.length){n=e.charCodeAt(f++);r=e.charCodeAt(f++);i=e.charCodeAt(f++);s=n>>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t=\"\";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9+/=]/g,\"\");while(f<e.length){s=this._keyStr.indexOf(e.charAt(f++));o=this._keyStr.indexOf(e.charAt(f++));u=this._keyStr.indexOf(e.charAt(f++));a=this._keyStr.indexOf(e.charAt(f++));n=s<<2|o>>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/rn/g,\"n\");var t=\"\";for(var n=0;n<e.length;n++){var r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r)}else if(r>127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t=\"\";var n=0;var r=c1=c2=0;while(n<e.length){r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r);n++}else if(r>191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}};\n\n  $('.exturl').on('click', function () {\n    var $exturl = $(this).attr('data-url');\n    var $decurl = Base64.decode($exturl);\n    window.open($decurl, '_blank');\n    return false;\n  });\n\n});\n"
  },
  {
    "path": "source/js/src/hook-duoshuo.js",
    "content": "/* global DUOSHUO: true */\n/* jshint camelcase: false */\n\ntypeof DUOSHUO !== 'undefined' ?\n  hookTemplate() :\n  ($('#duoshuo-script')[0].onload = hookTemplate);\n\n\nfunction hookTemplate() {\n  var post = DUOSHUO.templates.post;\n\n  DUOSHUO.templates.post = function (e, t) {\n    var rs = post(e, t);\n    var agent = e.post.agent;\n    var userId = e.post.author.user_id;\n    var admin = '';\n\n    if (userId && (userId == CONFIG.duoshuo.userId)) {\n      admin = '<span class=\"duoshuo-ua-admin\">' + CONFIG.duoshuo.author + '</span>';\n    }\n\n    if (agent && /^Mozilla/.test(agent)) {\n      rs = rs.replace(/<\\/div><p>/, admin + getAgentInfo(agent) + '</div><p>');\n    }\n\n    return rs;\n  };\n}\n\nfunction getAgentInfo(string) {\n  $.ua.set(string);\n\n  var UNKNOWN = 'Unknown';\n  var sua = $.ua;\n  var separator = isMobile() ? '<br><br>' : '<span class=\"duoshuo-ua-separator\"></span>';\n  var osName = sua.os.name || UNKNOWN;\n  var osVersion = sua.os.version  || UNKNOWN;\n  var browserName = sua.browser.name || UNKNOWN;\n  var browserVersion = sua.browser.version || UNKNOWN;\n  var iconMapping = {\n    os: {\n      android : 'android',\n      linux   : 'linux',\n      windows : 'windows',\n      ios     : 'apple',\n      'mac os': 'apple',\n      unknown : 'desktop'\n    },\n    browser: {\n      chrome   : 'chrome',\n      chromium : 'chrome',\n      firefox  : 'firefox',\n      opera    : 'opera',\n      safari   : 'safari',\n      ie       : 'internet-explorer',\n      wechat   : 'wechat',\n      qq       : 'qq',\n      unknown  : 'globe'\n    }\n  };\n  var osIcon = iconMapping.os[osName.toLowerCase()];\n  var browserIcon =  iconMapping.browser[getBrowserKey()];\n\n  return separator +\n    '<span class=\"duoshuo-ua-platform duoshuo-ua-platform-' + osName.toLowerCase() + '\">' +\n       '<i class=\"fa fa-' + osIcon + '\"></i>' +\n       osName + ' ' + osVersion +\n    '</span>' + separator +\n    '<span class=\"duoshuo-ua-browser duoshuo-ua-browser-' + browserName.toLowerCase() + '\">' +\n      '<i class=\"fa fa-' + browserIcon + '\"></i>' +\n      browserName + ' ' + browserVersion +\n    '</span>';\n\n  function getBrowserKey () {\n    var key = browserName.toLowerCase();\n\n    if (key.match(/WeChat/i)) {\n      return 'wechat';\n    }\n\n    if (key.match(/QQBrowser/i)) {\n      return 'qq';\n    }\n\n    return key;\n  }\n\n  function isMobile() {\n    var userAgent = window.navigator.userAgent;\n\n    var isiPad = userAgent.match(/iPad/i) !== null;\n    var mobileUA = [\n      'iphone', 'android', 'phone', 'mobile',\n      'wap', 'netfront', 'x11', 'java', 'opera mobi',\n      'opera mini', 'ucweb', 'windows ce', 'symbian',\n      'symbianos', 'series', 'webos', 'sony',\n      'blackberry', 'dopod', 'nokia', 'samsung',\n      'palmsource', 'xda', 'pieplus', 'meizu',\n      'midp' ,'cldc' , 'motorola', 'foma',\n      'docomo', 'up.browser', 'up.link', 'blazer',\n      'helio', 'hosin', 'huawei', 'novarra',\n      'coolpad', 'webos', 'techfaith', 'palmsource',\n      'alcatel', 'amoi', 'ktouch', 'nexian',\n      'ericsson', 'philips', 'sagem', 'wellcom',\n      'bunjalloo', 'maui', 'smartphone', 'iemobile',\n      'spice', 'bird', 'zte-', 'longcos',\n      'pantech', 'gionee', 'portalmmm', 'jig browser',\n      'hiptop', 'benq', 'haier', '^lct',\n      '320x320', '240x320', '176x220'\n    ];\n    var pattern = new RegExp(mobileUA.join('|'), 'i');\n\n    return !isiPad && userAgent.match(pattern);\n  }\n}\n"
  },
  {
    "path": "source/js/src/js.cookie.js",
    "content": "/*!\n * JavaScript Cookie v2.1.4\n * https://github.com/js-cookie/js-cookie\n *\n * Copyright 2006, 2015 Klaus Hartl & Fagner Brack\n * Released under the MIT license\n */\n;(function (factory) {\n\tvar registeredInModuleLoader = false;\n\tif (typeof define === 'function' && define.amd) {\n\t\tdefine(factory);\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (typeof exports === 'object') {\n\t\tmodule.exports = factory();\n\t\tregisteredInModuleLoader = true;\n\t}\n\tif (!registeredInModuleLoader) {\n\t\tvar OldCookies = window.Cookies;\n\t\tvar api = window.Cookies = factory();\n\t\tapi.noConflict = function () {\n\t\t\twindow.Cookies = OldCookies;\n\t\t\treturn api;\n\t\t};\n\t}\n}(function () {\n\tfunction extend () {\n\t\tvar i = 0;\n\t\tvar result = {};\n\t\tfor (; i < arguments.length; i++) {\n\t\t\tvar attributes = arguments[ i ];\n\t\t\tfor (var key in attributes) {\n\t\t\t\tresult[key] = attributes[key];\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction init (converter) {\n\t\tfunction api (key, value, attributes) {\n\t\t\tvar result;\n\t\t\tif (typeof document === 'undefined') {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Write\n\n\t\t\tif (arguments.length > 1) {\n\t\t\t\tattributes = extend({\n\t\t\t\t\tpath: '/'\n\t\t\t\t}, api.defaults, attributes);\n\n\t\t\t\tif (typeof attributes.expires === 'number') {\n\t\t\t\t\tvar expires = new Date();\n\t\t\t\t\texpires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5);\n\t\t\t\t\tattributes.expires = expires;\n\t\t\t\t}\n\n\t\t\t\t// We're using \"expires\" because \"max-age\" is not supported by IE\n\t\t\t\tattributes.expires = attributes.expires ? attributes.expires.toUTCString() : '';\n\n\t\t\t\ttry {\n\t\t\t\t\tresult = JSON.stringify(value);\n\t\t\t\t\tif (/^[\\{\\[]/.test(result)) {\n\t\t\t\t\t\tvalue = result;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\n\t\t\t\tif (!converter.write) {\n\t\t\t\t\tvalue = encodeURIComponent(String(value))\n\t\t\t\t\t\t.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent);\n\t\t\t\t} else {\n\t\t\t\t\tvalue = converter.write(value, key);\n\t\t\t\t}\n\n\t\t\t\tkey = encodeURIComponent(String(key));\n\t\t\t\tkey = key.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent);\n\t\t\t\tkey = key.replace(/[\\(\\)]/g, escape);\n\n\t\t\t\tvar stringifiedAttributes = '';\n\n\t\t\t\tfor (var attributeName in attributes) {\n\t\t\t\t\tif (!attributes[attributeName]) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t\tstringifiedAttributes += '; ' + attributeName;\n\t\t\t\t\tif (attributes[attributeName] === true) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t\tstringifiedAttributes += '=' + attributes[attributeName];\n\t\t\t\t}\n\t\t\t\treturn (document.cookie = key + '=' + value + stringifiedAttributes);\n\t\t\t}\n\n\t\t\t// Read\n\n\t\t\tif (!key) {\n\t\t\t\tresult = {};\n\t\t\t}\n\n\t\t\t// To prevent the for loop in the first place assign an empty array\n\t\t\t// in case there are no cookies at all. Also prevents odd result when\n\t\t\t// calling \"get()\"\n\t\t\tvar cookies = document.cookie ? document.cookie.split('; ') : [];\n\t\t\tvar rdecode = /(%[0-9A-Z]{2})+/g;\n\t\t\tvar i = 0;\n\n\t\t\tfor (; i < cookies.length; i++) {\n\t\t\t\tvar parts = cookies[i].split('=');\n\t\t\t\tvar cookie = parts.slice(1).join('=');\n\n\t\t\t\tif (cookie.charAt(0) === '\"') {\n\t\t\t\t\tcookie = cookie.slice(1, -1);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tvar name = parts[0].replace(rdecode, decodeURIComponent);\n\t\t\t\t\tcookie = converter.read ?\n\t\t\t\t\t\tconverter.read(cookie, name) : converter(cookie, name) ||\n\t\t\t\t\t\tcookie.replace(rdecode, decodeURIComponent);\n\n\t\t\t\t\tif (this.json) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tcookie = JSON.parse(cookie);\n\t\t\t\t\t\t} catch (e) {}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (key === name) {\n\t\t\t\t\t\tresult = cookie;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!key) {\n\t\t\t\t\t\tresult[name] = cookie;\n\t\t\t\t\t}\n\t\t\t\t} catch (e) {}\n\t\t\t}\n\n\t\t\treturn result;\n\t\t}\n\n\t\tapi.set = api;\n\t\tapi.get = function (key) {\n\t\t\treturn api.call(api, key);\n\t\t};\n\t\tapi.getJSON = function () {\n\t\t\treturn api.apply({\n\t\t\t\tjson: true\n\t\t\t}, [].slice.call(arguments));\n\t\t};\n\t\tapi.defaults = {};\n\n\t\tapi.remove = function (key, attributes) {\n\t\t\tapi(key, '', extend(attributes, {\n\t\t\t\texpires: -1\n\t\t\t}));\n\t\t};\n\n\t\tapi.withConverter = init;\n\n\t\treturn api;\n\t}\n\n\treturn init(function () {});\n}));\n"
  },
  {
    "path": "source/js/src/motion.js",
    "content": "/* global NexT: true */\n\n$(document).ready(function () {\n  NexT.motion = {};\n\n  var sidebarToggleLines = {\n    lines: [],\n    push: function (line) {\n      this.lines.push(line);\n    },\n    init: function () {\n      this.lines.forEach(function (line) {\n        line.init();\n      });\n    },\n    arrow: function () {\n      this.lines.forEach(function (line) {\n        line.arrow();\n      });\n    },\n    close: function () {\n      this.lines.forEach(function (line) {\n        line.close();\n      });\n    }\n  };\n\n  function SidebarToggleLine(settings) {\n    this.el = $(settings.el);\n    this.status = $.extend({}, {\n      init: {\n        width: '100%',\n        opacity: 1,\n        left: 0,\n        rotateZ: 0,\n        top: 0\n      }\n    }, settings.status);\n  }\n\n  SidebarToggleLine.prototype.init = function () {\n    this.transform('init');\n  };\n  SidebarToggleLine.prototype.arrow = function () {\n    this.transform('arrow');\n  };\n  SidebarToggleLine.prototype.close = function () {\n    this.transform('close');\n  };\n  SidebarToggleLine.prototype.transform = function (status) {\n    this.el.velocity('stop').velocity(this.status[status]);\n  };\n\n  var sidebarToggleLine1st = new SidebarToggleLine({\n    el: '.sidebar-toggle-line-first',\n    status: {\n      arrow: {width: '50%', rotateZ: '-45deg', top: '2px'},\n      close: {width: '100%', rotateZ: '-45deg', top: '5px'}\n    }\n  });\n  var sidebarToggleLine2nd = new SidebarToggleLine({\n    el: '.sidebar-toggle-line-middle',\n    status: {\n      arrow: {width: '90%'},\n      close: {opacity: 0}\n    }\n  });\n  var sidebarToggleLine3rd = new SidebarToggleLine({\n    el: '.sidebar-toggle-line-last',\n    status: {\n      arrow: {width: '50%', rotateZ: '45deg', top: '-2px'},\n      close: {width: '100%', rotateZ: '45deg', top: '-5px'}\n    }\n  });\n\n  sidebarToggleLines.push(sidebarToggleLine1st);\n  sidebarToggleLines.push(sidebarToggleLine2nd);\n  sidebarToggleLines.push(sidebarToggleLine3rd);\n\n  var SIDEBAR_WIDTH = '320px';\n  var SIDEBAR_DISPLAY_DURATION = 200;\n  var xPos, yPos;\n\n  var sidebarToggleMotion = {\n    toggleEl: $('.sidebar-toggle'),\n    dimmerEl: $('#sidebar-dimmer'),\n    sidebarEl: $('.sidebar'),\n    isSidebarVisible: false,\n    init: function () {\n      this.toggleEl.on('click', this.clickHandler.bind(this));\n      this.dimmerEl.on('click', this.clickHandler.bind(this));\n      this.toggleEl.on('mouseenter', this.mouseEnterHandler.bind(this));\n      this.toggleEl.on('mouseleave', this.mouseLeaveHandler.bind(this));\n      this.sidebarEl.on('touchstart', this.touchstartHandler.bind(this));\n      this.sidebarEl.on('touchend', this.touchendHandler.bind(this));\n      this.sidebarEl.on('touchmove', function(e){e.preventDefault();});\n\n      $(document)\n        .on('sidebar.isShowing', function () {\n          NexT.utils.isDesktop() && $('body').velocity('stop').velocity(\n            {paddingRight: SIDEBAR_WIDTH},\n            SIDEBAR_DISPLAY_DURATION\n          );\n        })\n        .on('sidebar.isHiding', function () {\n        });\n    },\n    clickHandler: function () {\n      this.isSidebarVisible ? this.hideSidebar() : this.showSidebar();\n      this.isSidebarVisible = !this.isSidebarVisible;\n    },\n    mouseEnterHandler: function () {\n      if (this.isSidebarVisible) {\n        return;\n      }\n      sidebarToggleLines.arrow();\n    },\n    mouseLeaveHandler: function () {\n      if (this.isSidebarVisible) {\n        return;\n      }\n      sidebarToggleLines.init();\n    },\n    touchstartHandler: function(e) {\n      xPos = e.originalEvent.touches[0].clientX;\n      yPos = e.originalEvent.touches[0].clientY;\n    },\n    touchendHandler: function(e) {\n      var _xPos = e.originalEvent.changedTouches[0].clientX;\n      var _yPos = e.originalEvent.changedTouches[0].clientY;\n      if (_xPos-xPos > 30 && Math.abs(_yPos-yPos) < 20) {\n          this.clickHandler();\n      }\n    },\n    showSidebar: function () {\n      var self = this;\n\n      sidebarToggleLines.close();\n\n      this.sidebarEl.velocity('stop').velocity({\n          width: SIDEBAR_WIDTH\n        }, {\n          display: 'block',\n          duration: SIDEBAR_DISPLAY_DURATION,\n          begin: function () {\n            $('.sidebar .motion-element').velocity(\n              'transition.slideRightIn',\n              {\n                stagger: 50,\n                drag: true,\n                complete: function () {\n                  self.sidebarEl.trigger('sidebar.motion.complete');\n                }\n              }\n            );\n          },\n          complete: function () {\n            self.sidebarEl.addClass('sidebar-active');\n            self.sidebarEl.trigger('sidebar.didShow');\n          }\n        }\n      );\n\n      this.sidebarEl.trigger('sidebar.isShowing');\n    },\n    hideSidebar: function () {\n      NexT.utils.isDesktop() && $('body').velocity('stop').velocity({paddingRight: 0});\n      this.sidebarEl.find('.motion-element').velocity('stop').css('display', 'none');\n      this.sidebarEl.velocity('stop').velocity({width: 0}, {display: 'none'});\n\n      sidebarToggleLines.init();\n\n      this.sidebarEl.removeClass('sidebar-active');\n      this.sidebarEl.trigger('sidebar.isHiding');\n\n      // Prevent adding TOC to Overview if Overview was selected when close & open sidebar.\n      if (!!$('.post-toc-wrap')) {\n        if ($('.site-overview-wrap').css('display') === 'block') {\n          $('.post-toc-wrap').removeClass('motion-element');\n        } else {\n          $('.post-toc-wrap').addClass('motion-element');\n        }\n      }\n    }\n  };\n  sidebarToggleMotion.init();\n\n  NexT.motion.integrator = {\n    queue: [],\n    cursor: -1,\n    add: function (fn) {\n      this.queue.push(fn);\n      return this;\n    },\n    next: function () {\n      this.cursor++;\n      var fn = this.queue[this.cursor];\n      $.isFunction(fn) && fn(NexT.motion.integrator);\n    },\n    bootstrap: function () {\n      this.next();\n    }\n  };\n\n  NexT.motion.middleWares =  {\n    logo: function (integrator) {\n      var sequence = [];\n      var $brand = $('.brand');\n      var $title = $('.site-title');\n      var $subtitle = $('.site-subtitle');\n      var $logoLineTop = $('.logo-line-before i');\n      var $logoLineBottom = $('.logo-line-after i');\n\n      $brand.size() > 0 && sequence.push({\n        e: $brand,\n        p: {opacity: 1},\n        o: {duration: 200}\n      });\n\n      NexT.utils.isMist() && hasElement([$logoLineTop, $logoLineBottom]) &&\n      sequence.push(\n        getMistLineSettings($logoLineTop, '100%'),\n        getMistLineSettings($logoLineBottom, '-100%')\n      );\n\n      hasElement($title) && sequence.push({\n        e: $title,\n        p: {opacity: 1, top: 0},\n        o: { duration: 200 }\n      });\n\n      hasElement($subtitle) && sequence.push({\n        e: $subtitle,\n        p: {opacity: 1, top: 0},\n        o: {duration: 200}\n      });\n\n      if (CONFIG.motion.async) {\n        integrator.next();\n      }\n\n      if (sequence.length > 0) {\n        sequence[sequence.length - 1].o.complete = function () {\n          integrator.next();\n        };\n        $.Velocity.RunSequence(sequence);\n      } else {\n        integrator.next();\n      }\n\n\n      function getMistLineSettings (element, translateX) {\n        return {\n          e: $(element),\n          p: {translateX: translateX},\n          o: {\n            duration: 500,\n            sequenceQueue: false\n          }\n        };\n      }\n\n      /**\n       * Check if $elements exist.\n       * @param {jQuery|Array} $elements\n       * @returns {boolean}\n       */\n      function hasElement ($elements) {\n        $elements = Array.isArray($elements) ? $elements : [$elements];\n        return $elements.every(function ($element) {\n          return $.isFunction($element.size) && $element.size() > 0;\n        });\n      }\n    },\n\n    menu: function (integrator) {\n\n      if (CONFIG.motion.async) {\n        integrator.next();\n      }\n\n      $('.menu-item').velocity('transition.slideDownIn', {\n        display: null,\n        duration: 200,\n        complete: function () {\n          integrator.next();\n        }\n      });\n    },\n\n    postList: function (integrator) {\n      //var $post = $('.post');\n      var $postBlock = $('.post-block, .pagination, .comments');\n      var $postBlockTransition = CONFIG.motion.transition.post_block;\n      var $postHeader = $('.post-header');\n      var $postHeaderTransition = CONFIG.motion.transition.post_header;\n      var $postBody = $('.post-body');\n      var $postBodyTransition = CONFIG.motion.transition.post_body;\n      var $collHeader = $('.collection-title, .archive-year');\n      var $collHeaderTransition = CONFIG.motion.transition.coll_header;\n      var $sidebarAffix = $('.sidebar-inner');\n      var $sidebarAffixTransition = CONFIG.motion.transition.sidebar;\n      var hasPost = $postBlock.size() > 0;\n\n      hasPost ? postMotion() : integrator.next();\n\n      if (CONFIG.motion.async) {\n        integrator.next();\n      }\n\n      function postMotion () {\n        var postMotionOptions = window.postMotionOptions || {\n            stagger: 100,\n            drag: true\n          };\n        postMotionOptions.complete = function () {\n          // After motion complete need to remove transform from sidebar to let affix work on Pisces | Gemini.\n          if (CONFIG.motion.transition.sidebar && (NexT.utils.isPisces() || NexT.utils.isGemini())) {\n            $sidebarAffix.css({ 'transform': 'initial' });\n          }\n          integrator.next();\n        };\n\n        //$post.velocity('transition.slideDownIn', postMotionOptions);\n        if (CONFIG.motion.transition.post_block) {\n          $postBlock.velocity('transition.' + $postBlockTransition, postMotionOptions);\n        }\n        if (CONFIG.motion.transition.post_header) {\n          $postHeader.velocity('transition.' + $postHeaderTransition, postMotionOptions);\n        }\n        if (CONFIG.motion.transition.post_body) {\n          $postBody.velocity('transition.' + $postBodyTransition, postMotionOptions);\n        }\n        if (CONFIG.motion.transition.coll_header) {\n          $collHeader.velocity('transition.' + $collHeaderTransition, postMotionOptions);\n        }\n        // Only for Pisces | Gemini.\n        if (CONFIG.motion.transition.sidebar && (NexT.utils.isPisces() || NexT.utils.isGemini())) {\n          $sidebarAffix.velocity('transition.' + $sidebarAffixTransition, postMotionOptions);\n        }\n      }\n    },\n\n    sidebar: function (integrator) {\n      if (CONFIG.sidebar.display === 'always') {\n        NexT.utils.displaySidebar();\n      }\n      integrator.next();\n    }\n  };\n\n});\n"
  },
  {
    "path": "source/js/src/post-details.js",
    "content": "/* global NexT: true */\n\n$(document).ready(function () {\n\n  initScrollSpy();\n\n  function initScrollSpy () {\n    var tocSelector = '.post-toc';\n    var $tocElement = $(tocSelector);\n    var activeCurrentSelector = '.active-current';\n\n    $tocElement\n      .on('activate.bs.scrollspy', function () {\n        var $currentActiveElement = $(tocSelector + ' .active').last();\n\n        removeCurrentActiveClass();\n        $currentActiveElement.addClass('active-current');\n\n        // Scrolling to center active TOC element if TOC content is taller then viewport.\n        $tocElement.scrollTop($currentActiveElement.offset().top - $tocElement.offset().top + $tocElement.scrollTop() - ($tocElement.height() / 2));\n      })\n      .on('clear.bs.scrollspy', removeCurrentActiveClass);\n\n    $('body').scrollspy({ target: tocSelector });\n\n    function removeCurrentActiveClass () {\n      $(tocSelector + ' ' + activeCurrentSelector)\n        .removeClass(activeCurrentSelector.substring(1));\n    }\n  }\n\n});\n\n$(document).ready(function () {\n  var html = $('html');\n  var TAB_ANIMATE_DURATION = 200;\n  var hasVelocity = $.isFunction(html.velocity);\n\n  $('.sidebar-nav li').on('click', function () {\n    var item = $(this);\n    var activeTabClassName = 'sidebar-nav-active';\n    var activePanelClassName = 'sidebar-panel-active';\n    if (item.hasClass(activeTabClassName)) {\n      return;\n    }\n\n    var currentTarget = $('.' + activePanelClassName);\n    var target = $('.' + item.data('target'));\n\n    hasVelocity ?\n      currentTarget.velocity('transition.slideUpOut', TAB_ANIMATE_DURATION, function () {\n        target\n          .velocity('stop')\n          .velocity('transition.slideDownIn', TAB_ANIMATE_DURATION)\n          .addClass(activePanelClassName);\n      }) :\n      currentTarget.animate({ opacity: 0 }, TAB_ANIMATE_DURATION, function () {\n        currentTarget.hide();\n        target\n          .stop()\n          .css({'opacity': 0, 'display': 'block'})\n          .animate({ opacity: 1 }, TAB_ANIMATE_DURATION, function () {\n            currentTarget.removeClass(activePanelClassName);\n            target.addClass(activePanelClassName);\n          });\n      });\n\n    item.siblings().removeClass(activeTabClassName);\n    item.addClass(activeTabClassName);\n  });\n\n  // TOC item animation navigate & prevent #item selector in adress bar.\n  $('.post-toc a').on('click', function (e) {\n    e.preventDefault();\n    var targetSelector = NexT.utils.escapeSelector(this.getAttribute('href'));\n    var offset = $(targetSelector).offset().top;\n\n    hasVelocity ?\n      html.velocity('stop').velocity('scroll', {\n        offset: offset  + 'px',\n        mobileHA: false\n      }) :\n      $('html, body').stop().animate({\n        scrollTop: offset\n      }, 500);\n  });\n\n  // Expand sidebar on post detail page by default, when post has a toc.\n  var $tocContent = $('.post-toc-content');\n  var isSidebarCouldDisplay = CONFIG.sidebar.display === 'post' ||\n      CONFIG.sidebar.display === 'always';\n  var hasTOC = $tocContent.length > 0 && $tocContent.html().trim().length > 0;\n  if (isSidebarCouldDisplay && hasTOC) {\n    CONFIG.motion.enable ?\n      (NexT.motion.middleWares.sidebar = function () {\n          NexT.utils.displaySidebar();\n      }) : NexT.utils.displaySidebar();\n  }\n});\n"
  },
  {
    "path": "source/js/src/schemes/pisces.js",
    "content": "$(document).ready(function () {\n\n  var sidebarInner = $('.sidebar-inner');\n\n  initAffix();\n  resizeListener();\n\n  function initAffix () {\n    var headerOffset = getHeaderOffset(),\n        footerOffset = getFooterOffset(),\n        sidebarHeight = $('#sidebar').height() + NexT.utils.getSidebarb2tHeight(),\n        contentHeight = $('#content').height();\n\n    // Not affix if sidebar taller then content (to prevent bottom jumping).\n    if (headerOffset + sidebarHeight < contentHeight) {\n      sidebarInner.affix({\n        offset: {\n          top: headerOffset - CONFIG.sidebar.offset,\n          bottom: footerOffset\n        }\n      });\n    }\n\n    setSidebarMarginTop(headerOffset).css({ 'margin-left': 'initial' });\n  }\n\n  function resizeListener () {\n    var mql = window.matchMedia('(min-width: 991px)');\n    mql.addListener(function(e){\n      if(e.matches){\n        recalculateAffixPosition();\n      }\n    });\n  }\n\n  function getHeaderOffset () {\n    return $('.header-inner').height() + CONFIG.sidebar.offset;\n  }\n\n  function getFooterOffset () {\n    var footerInner = $('.footer-inner'),\n        footerMargin = footerInner.outerHeight(true) - footerInner.outerHeight(),\n        footerOffset = footerInner.outerHeight(true) + footerMargin;\n    return footerOffset;\n  }\n\n  function setSidebarMarginTop (headerOffset) {\n    return $('#sidebar').css({ 'margin-top': headerOffset });\n  }\n\n  function recalculateAffixPosition () {\n    $(window).off('.affix');\n    sidebarInner.removeData('bs.affix').removeClass('affix affix-top affix-bottom');\n    initAffix();\n  }\n\n});\n"
  },
  {
    "path": "source/js/src/scroll-cookie.js",
    "content": "$(document).ready(function() {\n\n  // Set relative link path (without domain)\n  var rpath = window.location.href.replace(window.location.origin, \"\");\n\n  // Write position in cookie\n  var timeout;\n  $(window).on(\"scroll\", function() {\n    clearTimeout(timeout);\n    timeout = setTimeout(function () {\n      Cookies.set(\"scroll-cookie\", ($(window).scrollTop() + \"|\" + rpath), { expires: 365, path: '' });\n    }, 250);\n  });\n\n  // Read position from cookie\n  if (Cookies.get(\"scroll-cookie\") !== undefined) {\n    var cvalues = Cookies.get(\"scroll-cookie\").split('|');\n      if (cvalues[1] == rpath) {\n        $(window).scrollTop(cvalues[0]);\n      }\n  }\n\n});\n"
  },
  {
    "path": "source/js/src/scrollspy.js",
    "content": "/* ========================================================================\n* Bootstrap: scrollspy.js v3.3.2\n* http://getbootstrap.com/javascript/#scrollspy\n* ========================================================================\n* Copyright 2011-2015 Twitter, Inc.\n* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n* ======================================================================== */\n\n/**\n * Custom by iissnan\n *\n * - Add a `clear.bs.scrollspy` event.\n * - Esacpe targets selector.\n */\n\n\n+function ($) {\n  'use strict';\n\n  // SCROLLSPY CLASS DEFINITION\n  // ==========================\n\n  function ScrollSpy(element, options) {\n    this.$body          = $(document.body)\n    this.$scrollElement = $(element).is(document.body) ? $(window) : $(element)\n    this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)\n    this.selector       = (this.options.target || '') + ' .nav li > a'\n    this.offsets        = []\n    this.targets        = []\n    this.activeTarget   = null\n    this.scrollHeight   = 0\n\n    this.$scrollElement.on('scroll.bs.scrollspy', $.proxy(this.process, this))\n    this.refresh()\n    this.process()\n  }\n\n  ScrollSpy.VERSION  = '3.3.2'\n\n  ScrollSpy.DEFAULTS = {\n    offset: 10\n  }\n\n  ScrollSpy.prototype.getScrollHeight = function () {\n    return this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)\n  }\n\n  ScrollSpy.prototype.refresh = function () {\n    var that          = this\n    var offsetMethod  = 'offset'\n    var offsetBase    = 0\n\n    this.offsets      = []\n    this.targets      = []\n    this.scrollHeight = this.getScrollHeight()\n\n    if (!$.isWindow(this.$scrollElement[0])) {\n      offsetMethod = 'position'\n      offsetBase   = this.$scrollElement.scrollTop()\n    }\n\n    this.$body\n      .find(this.selector)\n      .map(function () {\n        var $el   = $(this)\n        var href  = $el.data('target') || $el.attr('href')\n        var $href = /^#./.test(href) && $(NexT.utils.escapeSelector(href)) // Need to escape selector.\n\n        return ($href\n          && $href.length\n          && $href.is(':visible')\n          && [[$href[offsetMethod]().top + offsetBase, href]]) || null\n      })\n      .sort(function (a, b) { return a[0] - b[0] })\n      .each(function () {\n        that.offsets.push(this[0])\n        that.targets.push(this[1])\n      })\n\n\n  }\n\n  ScrollSpy.prototype.process = function () {\n    var scrollTop    = this.$scrollElement.scrollTop() + this.options.offset\n    var scrollHeight = this.getScrollHeight()\n    var maxScroll    = this.options.offset + scrollHeight - this.$scrollElement.height()\n    var offsets      = this.offsets\n    var targets      = this.targets\n    var activeTarget = this.activeTarget\n    var i\n\n    if (this.scrollHeight != scrollHeight) {\n      this.refresh()\n    }\n\n    if (scrollTop >= maxScroll) {\n      return activeTarget != (i = targets[targets.length - 1]) && this.activate(i)\n    }\n\n    if (activeTarget && scrollTop < offsets[0]) {\n      $(this.selector).trigger('clear.bs.scrollspy')  // Add a custom event.\n      this.activeTarget = null\n      return this.clear()\n    }\n\n    for (i = offsets.length; i--;) {\n      activeTarget != targets[i]\n        && scrollTop >= offsets[i]\n        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])\n        && this.activate(targets[i])\n    }\n  }\n\n  ScrollSpy.prototype.activate = function (target) {\n    this.activeTarget = target\n\n    this.clear()\n\n    var selector = this.selector +\n      '[data-target=\"' + target + '\"],' +\n      this.selector + '[href=\"' + target + '\"]'\n\n    var active = $(selector)\n      .parents('li')\n      .addClass('active')\n\n    if (active.parent('.dropdown-menu').length) {\n      active = active\n        .closest('li.dropdown')\n        .addClass('active')\n    }\n\n    active.trigger('activate.bs.scrollspy')\n  }\n\n  ScrollSpy.prototype.clear = function () {\n    $(this.selector)\n      .parentsUntil(this.options.target, '.active')\n      .removeClass('active')\n  }\n\n\n  // SCROLLSPY PLUGIN DEFINITION\n  // ===========================\n\n  function Plugin(option) {\n    return this.each(function () {\n      var $this   = $(this)\n      var data    = $this.data('bs.scrollspy')\n      var options = typeof option == 'object' && option\n\n      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))\n      if (typeof option == 'string') data[option]()\n    })\n  }\n\n  var old = $.fn.scrollspy\n\n  $.fn.scrollspy             = Plugin\n  $.fn.scrollspy.Constructor = ScrollSpy\n\n\n  // SCROLLSPY NO CONFLICT\n  // =====================\n\n  $.fn.scrollspy.noConflict = function () {\n    $.fn.scrollspy = old\n    return this\n  }\n\n\n  // SCROLLSPY DATA-API\n  // ==================\n\n  $(window).on('load.bs.scrollspy.data-api', function () {\n    $('[data-spy=\"scroll\"]').each(function () {\n      var $spy = $(this)\n      Plugin.call($spy, $spy.data())\n    })\n  })\n\n}(jQuery);\n"
  },
  {
    "path": "source/js/src/utils.js",
    "content": "/* global NexT: true */\n\nNexT.utils = NexT.$u = {\n  /**\n   * Wrap images with fancybox support.\n   */\n  wrapImageWithFancyBox: function () {\n    $('.content img')\n      .not('[hidden]')\n      .not('.group-picture img, .post-gallery img')\n      .each(function () {\n        var $image = $(this);\n        var imageTitle = $image.attr('title');\n        var $imageWrapLink = $image.parent('a');\n\n        if ($imageWrapLink.size() < 1) {\n\t        var imageLink = ($image.attr('data-original')) ? this.getAttribute('data-original') : this.getAttribute('src');\n          $imageWrapLink = $image.wrap('<a href=\"' + imageLink + '\"></a>').parent('a');\n        }\n\n        $imageWrapLink.addClass('fancybox fancybox.image');\n        $imageWrapLink.attr('rel', 'group');\n\n        if (imageTitle) {\n          $imageWrapLink.append('<p class=\"image-caption\">' + imageTitle + '</p>');\n\n          //make sure img title tag will show correctly in fancybox\n          $imageWrapLink.attr('title', imageTitle);\n        }\n      });\n\n    $('.fancybox').fancybox({\n      helpers: {\n        overlay: {\n          locked: false\n        }\n      }\n    });\n  },\n\n  lazyLoadPostsImages: function () {\n    $('#posts').find('img').lazyload({\n      //placeholder: '/images/loading.gif',\n      effect: 'fadeIn',\n      threshold : 0\n    });\n  },\n\n  /**\n   * Tabs tag listener (without twitter bootstrap).\n   */\n  registerTabsTag: function () {\n    var tNav = '.tabs ul.nav-tabs ';\n\n    // Binding `nav-tabs` & `tab-content` by real time permalink changing.\n    $(function() {\n      $(window).bind('hashchange', function() {\n        var tHash = location.hash;\n        if (tHash !== '') {\n          $(tNav + 'li:has(a[href=\"' + tHash + '\"])').addClass('active').siblings().removeClass('active');\n          $(tHash).addClass('active').siblings().removeClass('active');\n        }\n      }).trigger('hashchange');\n    });\n\n    $(tNav + '.tab').on('click', function (href) {\n      href.preventDefault();\n      // Prevent selected tab to select again.\n      if(!$(this).hasClass('active')){\n\n        // Add & Remove active class on `nav-tabs` & `tab-content`.\n        $(this).addClass('active').siblings().removeClass('active');\n        var tActive = $(this).find('a').attr('href');\n        $(tActive).addClass('active').siblings().removeClass('active');\n\n        // Clear location hash in browser if #permalink exists.\n        if (location.hash !== '') {\n          history.pushState('', document.title, window.location.pathname + window.location.search);\n        }\n      }\n    });\n\n  },\n\n  registerESCKeyEvent: function () {\n    $(document).on('keyup', function (event) {\n      var shouldDismissSearchPopup = event.which === 27 &&\n        $('.search-popup').is(':visible');\n      if (shouldDismissSearchPopup) {\n        $('.search-popup').hide();\n        $('.search-popup-overlay').remove();\n        $('body').css('overflow', '');\n      }\n    });\n  },\n\n  registerBackToTop: function () {\n    var THRESHOLD = 50;\n    var $top = $('.back-to-top');\n\n    $(window).on('scroll', function () {\n      $top.toggleClass('back-to-top-on', window.pageYOffset > THRESHOLD);\n\n      var scrollTop = $(window).scrollTop();\n      var contentVisibilityHeight = NexT.utils.getContentVisibilityHeight();\n      var scrollPercent = (scrollTop) / (contentVisibilityHeight);\n      var scrollPercentRounded = Math.round(scrollPercent*100);\n      var scrollPercentMaxed = (scrollPercentRounded > 100) ? 100 : scrollPercentRounded;\n      $('#scrollpercent>span').html(scrollPercentMaxed);\n    });\n\n    $top.on('click', function () {\n      $('body').velocity('scroll');\n    });\n  },\n\n  /**\n   * Transform embedded video to support responsive layout.\n   * @see http://toddmotto.com/fluid-and-responsive-youtube-and-vimeo-videos-with-fluidvids-js/\n   */\n  embeddedVideoTransformer: function () {\n    var $iframes = $('iframe');\n\n    // Supported Players. Extend this if you need more players.\n    var SUPPORTED_PLAYERS = [\n      'www.youtube.com',\n      'player.vimeo.com',\n      'player.youku.com',\n      'music.163.com',\n      'www.tudou.com'\n    ];\n    var pattern = new RegExp( SUPPORTED_PLAYERS.join('|') );\n\n    $iframes.each(function () {\n      var iframe = this;\n      var $iframe = $(this);\n      var oldDimension = getDimension($iframe);\n      var newDimension;\n\n      if (this.src.search(pattern) > 0) {\n\n        // Calculate the video ratio based on the iframe's w/h dimensions\n        var videoRatio = getAspectRadio(oldDimension.width, oldDimension.height);\n\n        // Replace the iframe's dimensions and position the iframe absolute\n        // This is the trick to emulate the video ratio\n        $iframe.width('100%').height('100%')\n          .css({\n            position: 'absolute',\n            top: '0',\n            left: '0'\n          });\n\n\n        // Wrap the iframe in a new <div> which uses a dynamically fetched padding-top property\n        // based on the video's w/h dimensions\n        var wrap = document.createElement('div');\n        wrap.className = 'fluid-vids';\n        wrap.style.position = 'relative';\n        wrap.style.marginBottom = '20px';\n        wrap.style.width = '100%';\n        wrap.style.paddingTop = videoRatio + '%';\n        // Fix for appear inside tabs tag.\n        (wrap.style.paddingTop === '') && (wrap.style.paddingTop = '50%');\n\n        // Add the iframe inside our newly created <div>\n        var iframeParent = iframe.parentNode;\n        iframeParent.insertBefore(wrap, iframe);\n        wrap.appendChild(iframe);\n\n        // Additional adjustments for 163 Music\n        if (this.src.search('music.163.com') > 0) {\n          newDimension = getDimension($iframe);\n          var shouldRecalculateAspect = newDimension.width > oldDimension.width ||\n                                        newDimension.height < oldDimension.height;\n\n          // 163 Music Player has a fixed height, so we need to reset the aspect radio\n          if (shouldRecalculateAspect) {\n            wrap.style.paddingTop = getAspectRadio(newDimension.width, oldDimension.height) + '%';\n          }\n        }\n      }\n    });\n\n    function getDimension($element) {\n      return {\n        width: $element.width(),\n        height: $element.height()\n      };\n    }\n\n    function getAspectRadio(width, height) {\n      return height / width * 100;\n    }\n  },\n\n  /**\n   * Add `menu-item-active` class name to menu item\n   * via comparing location.path with menu item's href.\n   */\n  addActiveClassToMenuItem: function () {\n    var path = window.location.pathname;\n    path = path === '/' ? path : path.substring(0, path.length - 1);\n    $('.menu-item a[href^=\"' + path + '\"]:first').parent().addClass('menu-item-active');\n  },\n\n  hasMobileUA: function () {\n    var nav = window.navigator;\n    var ua = nav.userAgent;\n    var pa = /iPad|iPhone|Android|Opera Mini|BlackBerry|webOS|UCWEB|Blazer|PSP|IEMobile|Symbian/g;\n\n    return pa.test(ua);\n  },\n\n  isTablet: function () {\n    return window.screen.width < 992 && window.screen.width > 767 && this.hasMobileUA();\n  },\n\n  isMobile: function () {\n    return window.screen.width < 767 && this.hasMobileUA();\n  },\n\n  isDesktop: function () {\n    return !this.isTablet() && !this.isMobile();\n  },\n\n  /**\n   * Escape meta symbols in jQuery selectors.\n   *\n   * @param selector\n   * @returns {string|void|XML|*}\n   */\n  escapeSelector: function (selector) {\n    return selector.replace(/[!\"$%&'()*+,.\\/:;<=>?@[\\\\\\]^`{|}~]/g, '\\\\$&');\n  },\n\n  displaySidebar: function () {\n    if (!this.isDesktop() || this.isPisces() || this.isGemini()) {\n      return;\n    }\n    $('.sidebar-toggle').trigger('click');\n  },\n\n  isMist: function () {\n    return CONFIG.scheme === 'Mist';\n  },\n\n  isPisces: function () {\n    return CONFIG.scheme === 'Pisces';\n  },\n\n  isGemini: function () {\n    return CONFIG.scheme === 'Gemini';\n  },\n\n  getScrollbarWidth: function () {\n    var $div = $('<div />').addClass('scrollbar-measure').prependTo('body');\n    var div = $div[0];\n    var scrollbarWidth = div.offsetWidth - div.clientWidth;\n\n    $div.remove();\n\n    return scrollbarWidth;\n  },\n\n  getContentVisibilityHeight: function () {\n    var docHeight = $('#content').height(),\n        winHeight = $(window).height(),\n        contentVisibilityHeight = (docHeight > winHeight) ? (docHeight - winHeight) : ($(document).height() - winHeight);\n    return contentVisibilityHeight;\n  },\n\n  getSidebarb2tHeight: function () {\n    //var sidebarb2tHeight = (CONFIG.sidebar.b2t) ? document.getElementsByClassName('back-to-top')[0].clientHeight : 0;\n    var sidebarb2tHeight = (CONFIG.sidebar.b2t) ? $('.back-to-top').height() : 0;\n    //var sidebarb2tHeight = (CONFIG.sidebar.b2t) ? 24 : 0;\n    return sidebarb2tHeight;\n  },\n\n  getSidebarSchemePadding: function () {\n    var sidebarNavHeight = ($('.sidebar-nav').css('display') == 'block') ? $('.sidebar-nav').outerHeight(true) : 0,\n        sidebarInner = $('.sidebar-inner'),\n        sidebarPadding = sidebarInner.innerWidth() - sidebarInner.width(),\n        sidebarSchemePadding = this.isPisces() || this.isGemini() ?\n          ((sidebarPadding * 2) + sidebarNavHeight + (CONFIG.sidebar.offset * 2) + this.getSidebarb2tHeight()) :\n          ((sidebarPadding * 2) + (sidebarNavHeight / 2));\n    return sidebarSchemePadding;\n  }\n\n  /**\n   * Affix behaviour for Sidebar.\n   *\n   * @returns {Boolean}\n   */\n//  needAffix: function () {\n//    return this.isPisces() || this.isGemini();\n//  }\n};\n\n$(document).ready(function () {\n\n  initSidebarDimension();\n\n  /**\n   * Init Sidebar & TOC inner dimensions on all pages and for all schemes.\n   * Need for Sidebar/TOC inner scrolling if content taller then viewport.\n   */\n  function initSidebarDimension () {\n    var updateSidebarHeightTimer;\n\n    $(window).on('resize', function () {\n      updateSidebarHeightTimer && clearTimeout(updateSidebarHeightTimer);\n\n      updateSidebarHeightTimer = setTimeout(function () {\n        var sidebarWrapperHeight = document.body.clientHeight - NexT.utils.getSidebarSchemePadding();\n\n        updateSidebarHeight(sidebarWrapperHeight);\n      }, 0);\n    });\n\n    // Initialize Sidebar & TOC Width.\n    var scrollbarWidth = NexT.utils.getScrollbarWidth();\n      if ($('.site-overview-wrap').height() > (document.body.clientHeight - NexT.utils.getSidebarSchemePadding())) {\n        $('.site-overview').css('width', 'calc(100% + ' + scrollbarWidth + 'px)');\n      }\n      if ($('.post-toc-wrap').height() > (document.body.clientHeight - NexT.utils.getSidebarSchemePadding())) {\n        $('.post-toc').css('width', 'calc(100% + ' + scrollbarWidth + 'px)');\n      }\n\n    // Initialize Sidebar & TOC Height.\n    updateSidebarHeight(document.body.clientHeight - NexT.utils.getSidebarSchemePadding());\n  }\n\n  function updateSidebarHeight (height) {\n    height = height || 'auto';\n    $('.site-overview, .post-toc').css('max-height', height);\n  }\n\n});\n"
  },
  {
    "path": "source/lib/canvas-ribbon/canvas-ribbon.js",
    "content": "/**\n * Created by zproo on 2017/4/8.\n */\n!function () {\n  function getAttr(script, attr, default_val) {\n      return Number(script.getAttribute(attr)) || default_val;\n  }\n\n  // 获取自定义配置\n  var ribbon = document.getElementById('ribbon');  // 当前加载的script\n  config = {\n      zIndex: getAttr(ribbon, \"zIndex\", -1), // z-index\n      alpha: getAttr(ribbon, \"alpha\", 0.6), // alpha\n      ribbon_width: getAttr(ribbon, \"size\", 90), // size\n  };\n\n  var canvas = document.createElement(\"canvas\");\n  canvas.style.cssText = \"position:fixed;top:0;left:0;z-index:\"+config.zIndex;\n  document.getElementsByTagName(\"body\")[0].appendChild(canvas);\n\n  var canvasRibbon = canvas,\n      ctx = canvasRibbon.getContext('2d'),    // 获取canvas 2d上下文\n      dpr = window.devicePixelRatio || 1, // the size of one CSS pixel to the size of one physical pixel.\n      width = window.innerWidth,     // 返回窗口的文档显示区的宽高\n      height = window.innerHeight,\n      RIBBON_WIDTH = config.ribbon_width,\n      path,\n      math = Math,\n      r = 0,\n      PI_2 = math.PI * 2,    // 圆周率*2\n      cos = math.cos,   // cos函数返回一个数值的余弦值（-1~1）\n      random = math.random;   // 返回0-1随机数\n\n  canvasRibbon.width = width * dpr;     // 返回实际宽高\n  canvasRibbon.height = height * dpr;\n  ctx.scale(dpr, dpr);    // 水平、竖直方向缩放\n  ctx.globalAlpha = config.alpha;  // 图形透明度\n\n  function init() {\n      ctx.clearRect(0, 0, width, height);     // 擦除之前绘制内容\n      path = [{x: 0, y: height * 0.7 + RIBBON_WIDTH}, {x: 0, y: height * 0.7 - RIBBON_WIDTH}];\n      // 路径没有填满屏幕宽度时，绘制路径\n      while (path[1].x < width + RIBBON_WIDTH) {\n          draw(path[0], path[1])\n      }\n  }\n\n  function draw(start, end) {\n      ctx.beginPath();    // 创建一个新的路径\n      ctx.moveTo(start.x, start.y);   // path起点\n      ctx.lineTo(end.x, end.y);   // path终点\n      var nextX = end.x + (random() * 2 - 0.25) * RIBBON_WIDTH,\n          nextY = geneY(end.y);\n      ctx.lineTo(nextX, nextY);\n      ctx.closePath();\n\n      r -= PI_2 / -50;\n      // 随机生成并设置canvas路径16进制颜色\n      ctx.fillStyle = '#' + (cos(r) * 127 + 128 << 16 | cos(r + PI_2 / 3) * 127 + 128 << 8 | cos(r + PI_2 / 3 * 2) * 127 + 128).toString(16);\n      ctx.fill();     // 根据当前样式填充路径\n      path[0] = path[1];    // 起点更新为当前终点\n      path[1] = {x: nextX, y: nextY}     // 更新终点\n  }\n\n  function geneY(y) {\n      var temp = y + (random() * 2 - 1.1) * RIBBON_WIDTH;\n      return (temp > height || temp < 0) ? geneY(y) : temp;\n  }\n\n  document.onclick = init;\n  document.ontouchstart = init;\n  init();\n}();\n"
  },
  {
    "path": "source/lib/fastclick/.bower.json",
    "content": "{\n  \"name\": \"fastclick\",\n  \"main\": \"lib/fastclick.js\",\n  \"ignore\": [\n    \"**/.*\",\n    \"component.json\",\n    \"package.json\",\n    \"Makefile\",\n    \"tests\",\n    \"examples\"\n  ],\n  \"homepage\": \"https://github.com/ftlabs/fastclick\",\n  \"version\": \"1.0.6\",\n  \"_release\": \"1.0.6\",\n  \"_resolution\": {\n    \"type\": \"version\",\n    \"tag\": \"v1.0.6\",\n    \"commit\": \"2ac7258407619398005ca720596f0d36ce66a6c8\"\n  },\n  \"_source\": \"git://github.com/ftlabs/fastclick.git\",\n  \"_target\": \"~1.0.6\",\n  \"_originalSource\": \"fastclick\",\n  \"_direct\": true\n}"
  },
  {
    "path": "source/lib/fastclick/LICENSE",
    "content": "Copyright (c) 2014 The Financial Times Ltd.\n\nPermission is hereby granted, free of charge, to any person\nobtaining a copy of this software and associated documentation\nfiles (the \"Software\"), to deal in the Software without\nrestriction, including without limitation the rights to use,\ncopy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the\nSoftware is furnished to do so, subject to the following\nconditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES\nOF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\nNONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\nHOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\nWHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\nFROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR\nOTHER DEALINGS IN THE SOFTWARE.\n"
  },
  {
    "path": "source/lib/fastclick/README.md",
    "content": "# FastClick #\n\nFastClick is a simple, easy-to-use library for eliminating the 300ms delay between a physical tap and the firing of a `click` event on mobile browsers. The aim is to make your application feel less laggy and more responsive while avoiding any interference with your current logic.\n\nFastClick is developed by [FT Labs](http://labs.ft.com/), part of the Financial Times.\n\n[Explication en français](http://maxime.sh/2013/02/supprimer-le-lag-des-clics-sur-mobile-avec-fastclick/).\n\n[日本語で説明](https://developer.mozilla.org/ja/docs/Mozilla/Firefox_OS/Apps/Tips_and_techniques#Make_events_immediate)。\n\n## Why does the delay exist? ##\n\nAccording to [Google](https://developers.google.com/mobile/articles/fast_buttons):\n\n> ...mobile browsers will wait approximately 300ms from the time that you tap the button to fire the click event. The reason for this is that the browser is waiting to see if you are actually performing a double tap.\n\n## Compatibility ##\n\nThe library has been deployed as part of the [FT Web App](http://app.ft.com/) and is tried and tested on the following mobile browsers:\n\n* Mobile Safari on iOS 3 and upwards\n* Chrome on iOS 5 and upwards\n* Chrome on Android (ICS)\n* Opera Mobile 11.5 and upwards\n* Android Browser since Android 2\n* PlayBook OS 1 and upwards\n\n## When it isn't needed ##\n\nFastClick doesn't attach any listeners on desktop browsers.\n\nChrome 32+ on Android with `width=device-width` in the [viewport meta tag](https://developer.mozilla.org/en-US/docs/Mobile/Viewport_meta_tag) doesn't have a 300ms delay, therefore listeners aren't attached.\n\n```html\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n```\n\nSame goes for Chrome on Android (all versions) with `user-scalable=no` in the viewport meta tag. But be aware that `user-scalable=no` also disables pinch zooming, which may be an accessibility concern.\n\nFor IE11+, you can use `touch-action: manipulation;` to disable double-tap-to-zoom on certain elements (like links and buttons).  For IE10 use `-ms-touch-action: manipulation`.\n\n## Usage ##\n\nInclude fastclick.js in your JavaScript bundle or add it to your HTML page like this:\n\n```html\n<script type='application/javascript' src='/path/to/fastclick.js'></script>\n```\n\nThe script must be loaded prior to instantiating FastClick on any element of the page.\n\nTo instantiate FastClick on the `body`, which is the recommended method of use:\n\n```js\nif ('addEventListener' in document) {\n\tdocument.addEventListener('DOMContentLoaded', function() {\n\t\tFastClick.attach(document.body);\n\t}, false);\n}\n```\n\nOr, if you're using jQuery:\n\n```js\n$(function() {\n\tFastClick.attach(document.body);\n});\n```\n\nIf you're using Browserify or another CommonJS-style module system, the `FastClick.attach` function will be returned when you call `require('fastclick')`. As a result, the easiest way to use FastClick with these loaders is as follows:\n\n```js\nvar attachFastClick = require('fastclick');\nattachFastClick(document.body);\n```\n\n### Minified ###\n\nRun `make` to build a minified version of FastClick using the Closure Compiler REST API. The minified file is saved to `build/fastclick.min.js` or you can [download a pre-minified version](http://build.origami.ft.com/bundles/js?modules=fastclick).\n\nNote: the pre-minified version is built using [our build service](http://origami.ft.com/docs/developer-guide/build-service/) which exposes the `FastClick` object through `Origami.fastclick` and will have the Browserify/CommonJS API (see above).\n\n```js\nvar attachFastClick = Origami.fastclick;\nattachFastClick(document.body);\n```\n\n### AMD ###\n\nFastClick has AMD (Asynchronous Module Definition) support. This allows it to be lazy-loaded with an AMD loader, such as [RequireJS](http://requirejs.org/). Note that when using the AMD style require, the full `FastClick` object will be returned, _not_ `FastClick.attach`\n\n```js\nvar FastClick = require('fastclick');\nFastClick.attach(document.body, options);\n```\n\n### Package managers ###\n\nYou can install FastClick using [Component](https://github.com/component/component), [npm](https://npmjs.org/package/fastclick) or [Bower](http://bower.io/).\n\nFor Ruby, there's a third-party gem called [fastclick-rails](http://rubygems.org/gems/fastclick-rails). For .NET there's a [NuGet package](http://nuget.org/packages/FastClick).\n\n## Advanced ##\n\n### Ignore certain elements with `needsclick` ###\n\nSometimes you need FastClick to ignore certain elements. You can do this easily by adding the `needsclick` class.\n```html\n<a class=\"needsclick\">Ignored by FastClick</a>\n```\n\n#### Use case 1: non-synthetic click required ####\n\nInternally, FastClick uses `document.createEvent` to fire a synthetic `click` event as soon as `touchend` is fired by the browser. It then suppresses the additional `click` event created by the browser after that. In some cases, the non-synthetic `click` event created by the browser is required, as described in the [triggering focus example](http://ftlabs.github.com/fastclick/examples/focus.html).\n\nThis is where the `needsclick` class comes in. Add the class to any element that requires a non-synthetic click.\n\n#### Use case 2: Twitter Bootstrap 2.2.2 dropdowns ####\n\nAnother example of when to use the `needsclick` class is with dropdowns in Twitter Bootstrap 2.2.2. Bootstrap add its own `touchstart` listener for dropdowns, so you want to tell FastClick to ignore those. If you don't, touch devices will automatically close the dropdown as soon as it is clicked, because both FastClick and Bootstrap execute the synthetic click, one opens the dropdown, the second closes it immediately after.\n\n```html\n<a class=\"dropdown-toggle needsclick\" data-toggle=\"dropdown\">Dropdown</a>\n```\n\n## Examples ##\n\nFastClick is designed to cope with many different browser oddities. Here are some examples to illustrate this:\n\n* [basic use](http://ftlabs.github.com/fastclick/examples/layer.html) showing the increase in perceived responsiveness\n* [triggering focus](http://ftlabs.github.com/fastclick/examples/focus.html) on an input element from a `click` handler\n* [input element](http://ftlabs.github.com/fastclick/examples/input.html) which never receives clicks but gets fast focus\n\n## Tests ##\n\nThere are no automated tests. The files in `tests/` are manual reduced test cases. We've had a think about how best to test these cases, but they tend to be very browser/device specific and sometimes subjective which means it's not so trivial to test.\n\n## Credits and collaboration ##\n\nFastClick is maintained by [Rowan Beentje](http://twitter.com/rowanbeentje), [Matthew Caruana Galizia](http://twitter.com/mcaruanagalizia) and [Matthew Andrews](http://twitter.com/andrewsmatt) at [FT Labs](http://labs.ft.com). All open source code released by FT Labs is licenced under the MIT licence. We welcome comments, feedback and suggestions.  Please feel free to raise an issue or pull request.\n"
  },
  {
    "path": "source/lib/fastclick/bower.json",
    "content": "{\n  \"name\": \"fastclick\",\n  \"main\": \"lib/fastclick.js\",\n  \"ignore\": [\n    \"**/.*\",\n    \"component.json\",\n    \"package.json\",\n    \"Makefile\",\n    \"tests\",\n    \"examples\"\n  ]\n}\n"
  },
  {
    "path": "source/lib/fastclick/lib/fastclick.js",
    "content": ";(function () {\n\t'use strict';\n\n\t/**\n\t * @preserve FastClick: polyfill to remove click delays on browsers with touch UIs.\n\t *\n\t * @codingstandard ftlabs-jsv2\n\t * @copyright The Financial Times Limited [All Rights Reserved]\n\t * @license MIT License (see LICENSE.txt)\n\t */\n\n\t/*jslint browser:true, node:true*/\n\t/*global define, Event, Node*/\n\n\n\t/**\n\t * Instantiate fast-clicking listeners on the specified layer.\n\t *\n\t * @constructor\n\t * @param {Element} layer The layer to listen on\n\t * @param {Object} [options={}] The options to override the defaults\n\t */\n\tfunction FastClick(layer, options) {\n\t\tvar oldOnClick;\n\n\t\toptions = options || {};\n\n\t\t/**\n\t\t * Whether a click is currently being tracked.\n\t\t *\n\t\t * @type boolean\n\t\t */\n\t\tthis.trackingClick = false;\n\n\n\t\t/**\n\t\t * Timestamp for when click tracking started.\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.trackingClickStart = 0;\n\n\n\t\t/**\n\t\t * The element being tracked for a click.\n\t\t *\n\t\t * @type EventTarget\n\t\t */\n\t\tthis.targetElement = null;\n\n\n\t\t/**\n\t\t * X-coordinate of touch start event.\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.touchStartX = 0;\n\n\n\t\t/**\n\t\t * Y-coordinate of touch start event.\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.touchStartY = 0;\n\n\n\t\t/**\n\t\t * ID of the last touch, retrieved from Touch.identifier.\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.lastTouchIdentifier = 0;\n\n\n\t\t/**\n\t\t * Touchmove boundary, beyond which a click will be cancelled.\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.touchBoundary = options.touchBoundary || 10;\n\n\n\t\t/**\n\t\t * The FastClick layer.\n\t\t *\n\t\t * @type Element\n\t\t */\n\t\tthis.layer = layer;\n\n\t\t/**\n\t\t * The minimum time between tap(touchstart and touchend) events\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.tapDelay = options.tapDelay || 200;\n\n\t\t/**\n\t\t * The maximum time for a tap\n\t\t *\n\t\t * @type number\n\t\t */\n\t\tthis.tapTimeout = options.tapTimeout || 700;\n\n\t\tif (FastClick.notNeeded(layer)) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Some old versions of Android don't have Function.prototype.bind\n\t\tfunction bind(method, context) {\n\t\t\treturn function() { return method.apply(context, arguments); };\n\t\t}\n\n\n\t\tvar methods = ['onMouse', 'onClick', 'onTouchStart', 'onTouchMove', 'onTouchEnd', 'onTouchCancel'];\n\t\tvar context = this;\n\t\tfor (var i = 0, l = methods.length; i < l; i++) {\n\t\t\tcontext[methods[i]] = bind(context[methods[i]], context);\n\t\t}\n\n\t\t// Set up event handlers as required\n\t\tif (deviceIsAndroid) {\n\t\t\tlayer.addEventListener('mouseover', this.onMouse, true);\n\t\t\tlayer.addEventListener('mousedown', this.onMouse, true);\n\t\t\tlayer.addEventListener('mouseup', this.onMouse, true);\n\t\t}\n\n\t\tlayer.addEventListener('click', this.onClick, true);\n\t\tlayer.addEventListener('touchstart', this.onTouchStart, false);\n\t\tlayer.addEventListener('touchmove', this.onTouchMove, false);\n\t\tlayer.addEventListener('touchend', this.onTouchEnd, false);\n\t\tlayer.addEventListener('touchcancel', this.onTouchCancel, false);\n\n\t\t// Hack is required for browsers that don't support Event#stopImmediatePropagation (e.g. Android 2)\n\t\t// which is how FastClick normally stops click events bubbling to callbacks registered on the FastClick\n\t\t// layer when they are cancelled.\n\t\tif (!Event.prototype.stopImmediatePropagation) {\n\t\t\tlayer.removeEventListener = function(type, callback, capture) {\n\t\t\t\tvar rmv = Node.prototype.removeEventListener;\n\t\t\t\tif (type === 'click') {\n\t\t\t\t\trmv.call(layer, type, callback.hijacked || callback, capture);\n\t\t\t\t} else {\n\t\t\t\t\trmv.call(layer, type, callback, capture);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tlayer.addEventListener = function(type, callback, capture) {\n\t\t\t\tvar adv = Node.prototype.addEventListener;\n\t\t\t\tif (type === 'click') {\n\t\t\t\t\tadv.call(layer, type, callback.hijacked || (callback.hijacked = function(event) {\n\t\t\t\t\t\tif (!event.propagationStopped) {\n\t\t\t\t\t\t\tcallback(event);\n\t\t\t\t\t\t}\n\t\t\t\t\t}), capture);\n\t\t\t\t} else {\n\t\t\t\t\tadv.call(layer, type, callback, capture);\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\n\t\t// If a handler is already declared in the element's onclick attribute, it will be fired before\n\t\t// FastClick's onClick handler. Fix this by pulling out the user-defined handler function and\n\t\t// adding it as listener.\n\t\tif (typeof layer.onclick === 'function') {\n\n\t\t\t// Android browser on at least 3.2 requires a new reference to the function in layer.onclick\n\t\t\t// - the old one won't work if passed to addEventListener directly.\n\t\t\toldOnClick = layer.onclick;\n\t\t\tlayer.addEventListener('click', function(event) {\n\t\t\t\toldOnClick(event);\n\t\t\t}, false);\n\t\t\tlayer.onclick = null;\n\t\t}\n\t}\n\n\t/**\n\t* Windows Phone 8.1 fakes user agent string to look like Android and iPhone.\n\t*\n\t* @type boolean\n\t*/\n\tvar deviceIsWindowsPhone = navigator.userAgent.indexOf(\"Windows Phone\") >= 0;\n\n\t/**\n\t * Android requires exceptions.\n\t *\n\t * @type boolean\n\t */\n\tvar deviceIsAndroid = navigator.userAgent.indexOf('Android') > 0 && !deviceIsWindowsPhone;\n\n\n\t/**\n\t * iOS requires exceptions.\n\t *\n\t * @type boolean\n\t */\n\tvar deviceIsIOS = /iP(ad|hone|od)/.test(navigator.userAgent) && !deviceIsWindowsPhone;\n\n\n\t/**\n\t * iOS 4 requires an exception for select elements.\n\t *\n\t * @type boolean\n\t */\n\tvar deviceIsIOS4 = deviceIsIOS && (/OS 4_\\d(_\\d)?/).test(navigator.userAgent);\n\n\n\t/**\n\t * iOS 6.0-7.* requires the target element to be manually derived\n\t *\n\t * @type boolean\n\t */\n\tvar deviceIsIOSWithBadTarget = deviceIsIOS && (/OS [6-7]_\\d/).test(navigator.userAgent);\n\n\t/**\n\t * BlackBerry requires exceptions.\n\t *\n\t * @type boolean\n\t */\n\tvar deviceIsBlackBerry10 = navigator.userAgent.indexOf('BB10') > 0;\n\n\t/**\n\t * Determine whether a given element requires a native click.\n\t *\n\t * @param {EventTarget|Element} target Target DOM element\n\t * @returns {boolean} Returns true if the element needs a native click\n\t */\n\tFastClick.prototype.needsClick = function(target) {\n\t\tswitch (target.nodeName.toLowerCase()) {\n\n\t\t// Don't send a synthetic click to disabled inputs (issue #62)\n\t\tcase 'button':\n\t\tcase 'select':\n\t\tcase 'textarea':\n\t\t\tif (target.disabled) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tbreak;\n\t\tcase 'input':\n\n\t\t\t// File inputs need real clicks on iOS 6 due to a browser bug (issue #68)\n\t\t\tif ((deviceIsIOS && target.type === 'file') || target.disabled) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tbreak;\n\t\tcase 'label':\n\t\tcase 'iframe': // iOS8 homescreen apps can prevent events bubbling into frames\n\t\tcase 'video':\n\t\t\treturn true;\n\t\t}\n\n\t\treturn (/\\bneedsclick\\b/).test(target.className);\n\t};\n\n\n\t/**\n\t * Determine whether a given element requires a call to focus to simulate click into element.\n\t *\n\t * @param {EventTarget|Element} target Target DOM element\n\t * @returns {boolean} Returns true if the element requires a call to focus to simulate native click.\n\t */\n\tFastClick.prototype.needsFocus = function(target) {\n\t\tswitch (target.nodeName.toLowerCase()) {\n\t\tcase 'textarea':\n\t\t\treturn true;\n\t\tcase 'select':\n\t\t\treturn !deviceIsAndroid;\n\t\tcase 'input':\n\t\t\tswitch (target.type) {\n\t\t\tcase 'button':\n\t\t\tcase 'checkbox':\n\t\t\tcase 'file':\n\t\t\tcase 'image':\n\t\t\tcase 'radio':\n\t\t\tcase 'submit':\n\t\t\t\treturn false;\n\t\t\t}\n\n\t\t\t// No point in attempting to focus disabled inputs\n\t\t\treturn !target.disabled && !target.readOnly;\n\t\tdefault:\n\t\t\treturn (/\\bneedsfocus\\b/).test(target.className);\n\t\t}\n\t};\n\n\n\t/**\n\t * Send a click event to the specified element.\n\t *\n\t * @param {EventTarget|Element} targetElement\n\t * @param {Event} event\n\t */\n\tFastClick.prototype.sendClick = function(targetElement, event) {\n\t\tvar clickEvent, touch;\n\n\t\t// On some Android devices activeElement needs to be blurred otherwise the synthetic click will have no effect (#24)\n\t\tif (document.activeElement && document.activeElement !== targetElement) {\n\t\t\tdocument.activeElement.blur();\n\t\t}\n\n\t\ttouch = event.changedTouches[0];\n\n\t\t// Synthesise a click event, with an extra attribute so it can be tracked\n\t\tclickEvent = document.createEvent('MouseEvents');\n\t\tclickEvent.initMouseEvent(this.determineEventType(targetElement), true, true, window, 1, touch.screenX, touch.screenY, touch.clientX, touch.clientY, false, false, false, false, 0, null);\n\t\tclickEvent.forwardedTouchEvent = true;\n\t\ttargetElement.dispatchEvent(clickEvent);\n\t};\n\n\tFastClick.prototype.determineEventType = function(targetElement) {\n\n\t\t//Issue #159: Android Chrome Select Box does not open with a synthetic click event\n\t\tif (deviceIsAndroid && targetElement.tagName.toLowerCase() === 'select') {\n\t\t\treturn 'mousedown';\n\t\t}\n\n\t\treturn 'click';\n\t};\n\n\n\t/**\n\t * @param {EventTarget|Element} targetElement\n\t */\n\tFastClick.prototype.focus = function(targetElement) {\n\t\tvar length;\n\n\t\t// Issue #160: on iOS 7, some input elements (e.g. date datetime month) throw a vague TypeError on setSelectionRange. These elements don't have an integer value for the selectionStart and selectionEnd properties, but unfortunately that can't be used for detection because accessing the properties also throws a TypeError. Just check the type instead. Filed as Apple bug #15122724.\n\t\tif (deviceIsIOS && targetElement.setSelectionRange && targetElement.type.indexOf('date') !== 0 && targetElement.type !== 'time' && targetElement.type !== 'month') {\n\t\t\tlength = targetElement.value.length;\n\t\t\ttargetElement.setSelectionRange(length, length);\n\t\t} else {\n\t\t\ttargetElement.focus();\n\t\t}\n\t};\n\n\n\t/**\n\t * Check whether the given target element is a child of a scrollable layer and if so, set a flag on it.\n\t *\n\t * @param {EventTarget|Element} targetElement\n\t */\n\tFastClick.prototype.updateScrollParent = function(targetElement) {\n\t\tvar scrollParent, parentElement;\n\n\t\tscrollParent = targetElement.fastClickScrollParent;\n\n\t\t// Attempt to discover whether the target element is contained within a scrollable layer. Re-check if the\n\t\t// target element was moved to another parent.\n\t\tif (!scrollParent || !scrollParent.contains(targetElement)) {\n\t\t\tparentElement = targetElement;\n\t\t\tdo {\n\t\t\t\tif (parentElement.scrollHeight > parentElement.offsetHeight) {\n\t\t\t\t\tscrollParent = parentElement;\n\t\t\t\t\ttargetElement.fastClickScrollParent = parentElement;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tparentElement = parentElement.parentElement;\n\t\t\t} while (parentElement);\n\t\t}\n\n\t\t// Always update the scroll top tracker if possible.\n\t\tif (scrollParent) {\n\t\t\tscrollParent.fastClickLastScrollTop = scrollParent.scrollTop;\n\t\t}\n\t};\n\n\n\t/**\n\t * @param {EventTarget} targetElement\n\t * @returns {Element|EventTarget}\n\t */\n\tFastClick.prototype.getTargetElementFromEventTarget = function(eventTarget) {\n\n\t\t// On some older browsers (notably Safari on iOS 4.1 - see issue #56) the event target may be a text node.\n\t\tif (eventTarget.nodeType === Node.TEXT_NODE) {\n\t\t\treturn eventTarget.parentNode;\n\t\t}\n\n\t\treturn eventTarget;\n\t};\n\n\n\t/**\n\t * On touch start, record the position and scroll offset.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.onTouchStart = function(event) {\n\t\tvar targetElement, touch, selection;\n\n\t\t// Ignore multiple touches, otherwise pinch-to-zoom is prevented if both fingers are on the FastClick element (issue #111).\n\t\tif (event.targetTouches.length > 1) {\n\t\t\treturn true;\n\t\t}\n\n\t\ttargetElement = this.getTargetElementFromEventTarget(event.target);\n\t\ttouch = event.targetTouches[0];\n\n\t\tif (deviceIsIOS) {\n\n\t\t\t// Only trusted events will deselect text on iOS (issue #49)\n\t\t\tselection = window.getSelection();\n\t\t\tif (selection.rangeCount && !selection.isCollapsed) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tif (!deviceIsIOS4) {\n\n\t\t\t\t// Weird things happen on iOS when an alert or confirm dialog is opened from a click event callback (issue #23):\n\t\t\t\t// when the user next taps anywhere else on the page, new touchstart and touchend events are dispatched\n\t\t\t\t// with the same identifier as the touch event that previously triggered the click that triggered the alert.\n\t\t\t\t// Sadly, there is an issue on iOS 4 that causes some normal touch events to have the same identifier as an\n\t\t\t\t// immediately preceeding touch event (issue #52), so this fix is unavailable on that platform.\n\t\t\t\t// Issue 120: touch.identifier is 0 when Chrome dev tools 'Emulate touch events' is set with an iOS device UA string,\n\t\t\t\t// which causes all touch events to be ignored. As this block only applies to iOS, and iOS identifiers are always long,\n\t\t\t\t// random integers, it's safe to to continue if the identifier is 0 here.\n\t\t\t\tif (touch.identifier && touch.identifier === this.lastTouchIdentifier) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\tthis.lastTouchIdentifier = touch.identifier;\n\n\t\t\t\t// If the target element is a child of a scrollable layer (using -webkit-overflow-scrolling: touch) and:\n\t\t\t\t// 1) the user does a fling scroll on the scrollable layer\n\t\t\t\t// 2) the user stops the fling scroll with another tap\n\t\t\t\t// then the event.target of the last 'touchend' event will be the element that was under the user's finger\n\t\t\t\t// when the fling scroll was started, causing FastClick to send a click event to that layer - unless a check\n\t\t\t\t// is made to ensure that a parent layer was not scrolled before sending a synthetic click (issue #42).\n\t\t\t\tthis.updateScrollParent(targetElement);\n\t\t\t}\n\t\t}\n\n\t\tthis.trackingClick = true;\n\t\tthis.trackingClickStart = event.timeStamp;\n\t\tthis.targetElement = targetElement;\n\n\t\tthis.touchStartX = touch.pageX;\n\t\tthis.touchStartY = touch.pageY;\n\n\t\t// Prevent phantom clicks on fast double-tap (issue #36)\n\t\tif ((event.timeStamp - this.lastClickTime) < this.tapDelay) {\n\t\t\tevent.preventDefault();\n\t\t}\n\n\t\treturn true;\n\t};\n\n\n\t/**\n\t * Based on a touchmove event object, check whether the touch has moved past a boundary since it started.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.touchHasMoved = function(event) {\n\t\tvar touch = event.changedTouches[0], boundary = this.touchBoundary;\n\n\t\tif (Math.abs(touch.pageX - this.touchStartX) > boundary || Math.abs(touch.pageY - this.touchStartY) > boundary) {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t};\n\n\n\t/**\n\t * Update the last position.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.onTouchMove = function(event) {\n\t\tif (!this.trackingClick) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// If the touch has moved, cancel the click tracking\n\t\tif (this.targetElement !== this.getTargetElementFromEventTarget(event.target) || this.touchHasMoved(event)) {\n\t\t\tthis.trackingClick = false;\n\t\t\tthis.targetElement = null;\n\t\t}\n\n\t\treturn true;\n\t};\n\n\n\t/**\n\t * Attempt to find the labelled control for the given label element.\n\t *\n\t * @param {EventTarget|HTMLLabelElement} labelElement\n\t * @returns {Element|null}\n\t */\n\tFastClick.prototype.findControl = function(labelElement) {\n\n\t\t// Fast path for newer browsers supporting the HTML5 control attribute\n\t\tif (labelElement.control !== undefined) {\n\t\t\treturn labelElement.control;\n\t\t}\n\n\t\t// All browsers under test that support touch events also support the HTML5 htmlFor attribute\n\t\tif (labelElement.htmlFor) {\n\t\t\treturn document.getElementById(labelElement.htmlFor);\n\t\t}\n\n\t\t// If no for attribute exists, attempt to retrieve the first labellable descendant element\n\t\t// the list of which is defined here: http://www.w3.org/TR/html5/forms.html#category-label\n\t\treturn labelElement.querySelector('button, input:not([type=hidden]), keygen, meter, output, progress, select, textarea');\n\t};\n\n\n\t/**\n\t * On touch end, determine whether to send a click event at once.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.onTouchEnd = function(event) {\n\t\tvar forElement, trackingClickStart, targetTagName, scrollParent, touch, targetElement = this.targetElement;\n\n\t\tif (!this.trackingClick) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Prevent phantom clicks on fast double-tap (issue #36)\n\t\tif ((event.timeStamp - this.lastClickTime) < this.tapDelay) {\n\t\t\tthis.cancelNextClick = true;\n\t\t\treturn true;\n\t\t}\n\n\t\tif ((event.timeStamp - this.trackingClickStart) > this.tapTimeout) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Reset to prevent wrong click cancel on input (issue #156).\n\t\tthis.cancelNextClick = false;\n\n\t\tthis.lastClickTime = event.timeStamp;\n\n\t\ttrackingClickStart = this.trackingClickStart;\n\t\tthis.trackingClick = false;\n\t\tthis.trackingClickStart = 0;\n\n\t\t// On some iOS devices, the targetElement supplied with the event is invalid if the layer\n\t\t// is performing a transition or scroll, and has to be re-detected manually. Note that\n\t\t// for this to function correctly, it must be called *after* the event target is checked!\n\t\t// See issue #57; also filed as rdar://13048589 .\n\t\tif (deviceIsIOSWithBadTarget) {\n\t\t\ttouch = event.changedTouches[0];\n\n\t\t\t// In certain cases arguments of elementFromPoint can be negative, so prevent setting targetElement to null\n\t\t\ttargetElement = document.elementFromPoint(touch.pageX - window.pageXOffset, touch.pageY - window.pageYOffset) || targetElement;\n\t\t\ttargetElement.fastClickScrollParent = this.targetElement.fastClickScrollParent;\n\t\t}\n\n\t\ttargetTagName = targetElement.tagName.toLowerCase();\n\t\tif (targetTagName === 'label') {\n\t\t\tforElement = this.findControl(targetElement);\n\t\t\tif (forElement) {\n\t\t\t\tthis.focus(targetElement);\n\t\t\t\tif (deviceIsAndroid) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\ttargetElement = forElement;\n\t\t\t}\n\t\t} else if (this.needsFocus(targetElement)) {\n\n\t\t\t// Case 1: If the touch started a while ago (best guess is 100ms based on tests for issue #36) then focus will be triggered anyway. Return early and unset the target element reference so that the subsequent click will be allowed through.\n\t\t\t// Case 2: Without this exception for input elements tapped when the document is contained in an iframe, then any inputted text won't be visible even though the value attribute is updated as the user types (issue #37).\n\t\t\tif ((event.timeStamp - trackingClickStart) > 100 || (deviceIsIOS && window.top !== window && targetTagName === 'input')) {\n\t\t\t\tthis.targetElement = null;\n\t\t\t\treturn false;\n\t\t\t}\n\n\t\t\tthis.focus(targetElement);\n\t\t\tthis.sendClick(targetElement, event);\n\n\t\t\t// Select elements need the event to go through on iOS 4, otherwise the selector menu won't open.\n\t\t\t// Also this breaks opening selects when VoiceOver is active on iOS6, iOS7 (and possibly others)\n\t\t\tif (!deviceIsIOS || targetTagName !== 'select') {\n\t\t\t\tthis.targetElement = null;\n\t\t\t\tevent.preventDefault();\n\t\t\t}\n\n\t\t\treturn false;\n\t\t}\n\n\t\tif (deviceIsIOS && !deviceIsIOS4) {\n\n\t\t\t// Don't send a synthetic click event if the target element is contained within a parent layer that was scrolled\n\t\t\t// and this tap is being used to stop the scrolling (usually initiated by a fling - issue #42).\n\t\t\tscrollParent = targetElement.fastClickScrollParent;\n\t\t\tif (scrollParent && scrollParent.fastClickLastScrollTop !== scrollParent.scrollTop) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\t// Prevent the actual click from going though - unless the target node is marked as requiring\n\t\t// real clicks or if it is in the whitelist in which case only non-programmatic clicks are permitted.\n\t\tif (!this.needsClick(targetElement)) {\n\t\t\tevent.preventDefault();\n\t\t\tthis.sendClick(targetElement, event);\n\t\t}\n\n\t\treturn false;\n\t};\n\n\n\t/**\n\t * On touch cancel, stop tracking the click.\n\t *\n\t * @returns {void}\n\t */\n\tFastClick.prototype.onTouchCancel = function() {\n\t\tthis.trackingClick = false;\n\t\tthis.targetElement = null;\n\t};\n\n\n\t/**\n\t * Determine mouse events which should be permitted.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.onMouse = function(event) {\n\n\t\t// If a target element was never set (because a touch event was never fired) allow the event\n\t\tif (!this.targetElement) {\n\t\t\treturn true;\n\t\t}\n\n\t\tif (event.forwardedTouchEvent) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Programmatically generated events targeting a specific element should be permitted\n\t\tif (!event.cancelable) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Derive and check the target element to see whether the mouse event needs to be permitted;\n\t\t// unless explicitly enabled, prevent non-touch click events from triggering actions,\n\t\t// to prevent ghost/doubleclicks.\n\t\tif (!this.needsClick(this.targetElement) || this.cancelNextClick) {\n\n\t\t\t// Prevent any user-added listeners declared on FastClick element from being fired.\n\t\t\tif (event.stopImmediatePropagation) {\n\t\t\t\tevent.stopImmediatePropagation();\n\t\t\t} else {\n\n\t\t\t\t// Part of the hack for browsers that don't support Event#stopImmediatePropagation (e.g. Android 2)\n\t\t\t\tevent.propagationStopped = true;\n\t\t\t}\n\n\t\t\t// Cancel the event\n\t\t\tevent.stopPropagation();\n\t\t\tevent.preventDefault();\n\n\t\t\treturn false;\n\t\t}\n\n\t\t// If the mouse event is permitted, return true for the action to go through.\n\t\treturn true;\n\t};\n\n\n\t/**\n\t * On actual clicks, determine whether this is a touch-generated click, a click action occurring\n\t * naturally after a delay after a touch (which needs to be cancelled to avoid duplication), or\n\t * an actual click which should be permitted.\n\t *\n\t * @param {Event} event\n\t * @returns {boolean}\n\t */\n\tFastClick.prototype.onClick = function(event) {\n\t\tvar permitted;\n\n\t\t// It's possible for another FastClick-like library delivered with third-party code to fire a click event before FastClick does (issue #44). In that case, set the click-tracking flag back to false and return early. This will cause onTouchEnd to return early.\n\t\tif (this.trackingClick) {\n\t\t\tthis.targetElement = null;\n\t\t\tthis.trackingClick = false;\n\t\t\treturn true;\n\t\t}\n\n\t\t// Very odd behaviour on iOS (issue #18): if a submit element is present inside a form and the user hits enter in the iOS simulator or clicks the Go button on the pop-up OS keyboard the a kind of 'fake' click event will be triggered with the submit-type input element as the target.\n\t\tif (event.target.type === 'submit' && event.detail === 0) {\n\t\t\treturn true;\n\t\t}\n\n\t\tpermitted = this.onMouse(event);\n\n\t\t// Only unset targetElement if the click is not permitted. This will ensure that the check for !targetElement in onMouse fails and the browser's click doesn't go through.\n\t\tif (!permitted) {\n\t\t\tthis.targetElement = null;\n\t\t}\n\n\t\t// If clicks are permitted, return true for the action to go through.\n\t\treturn permitted;\n\t};\n\n\n\t/**\n\t * Remove all FastClick's event listeners.\n\t *\n\t * @returns {void}\n\t */\n\tFastClick.prototype.destroy = function() {\n\t\tvar layer = this.layer;\n\n\t\tif (deviceIsAndroid) {\n\t\t\tlayer.removeEventListener('mouseover', this.onMouse, true);\n\t\t\tlayer.removeEventListener('mousedown', this.onMouse, true);\n\t\t\tlayer.removeEventListener('mouseup', this.onMouse, true);\n\t\t}\n\n\t\tlayer.removeEventListener('click', this.onClick, true);\n\t\tlayer.removeEventListener('touchstart', this.onTouchStart, false);\n\t\tlayer.removeEventListener('touchmove', this.onTouchMove, false);\n\t\tlayer.removeEventListener('touchend', this.onTouchEnd, false);\n\t\tlayer.removeEventListener('touchcancel', this.onTouchCancel, false);\n\t};\n\n\n\t/**\n\t * Check whether FastClick is needed.\n\t *\n\t * @param {Element} layer The layer to listen on\n\t */\n\tFastClick.notNeeded = function(layer) {\n\t\tvar metaViewport;\n\t\tvar chromeVersion;\n\t\tvar blackberryVersion;\n\t\tvar firefoxVersion;\n\n\t\t// Devices that don't support touch don't need FastClick\n\t\tif (typeof window.ontouchstart === 'undefined') {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Chrome version - zero for other browsers\n\t\tchromeVersion = +(/Chrome\\/([0-9]+)/.exec(navigator.userAgent) || [,0])[1];\n\n\t\tif (chromeVersion) {\n\n\t\t\tif (deviceIsAndroid) {\n\t\t\t\tmetaViewport = document.querySelector('meta[name=viewport]');\n\n\t\t\t\tif (metaViewport) {\n\t\t\t\t\t// Chrome on Android with user-scalable=\"no\" doesn't need FastClick (issue #89)\n\t\t\t\t\tif (metaViewport.content.indexOf('user-scalable=no') !== -1) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t\t// Chrome 32 and above with width=device-width or less don't need FastClick\n\t\t\t\t\tif (chromeVersion > 31 && document.documentElement.scrollWidth <= window.outerWidth) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t// Chrome desktop doesn't need FastClick (issue #15)\n\t\t\t} else {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\tif (deviceIsBlackBerry10) {\n\t\t\tblackberryVersion = navigator.userAgent.match(/Version\\/([0-9]*)\\.([0-9]*)/);\n\n\t\t\t// BlackBerry 10.3+ does not require Fastclick library.\n\t\t\t// https://github.com/ftlabs/fastclick/issues/251\n\t\t\tif (blackberryVersion[1] >= 10 && blackberryVersion[2] >= 3) {\n\t\t\t\tmetaViewport = document.querySelector('meta[name=viewport]');\n\n\t\t\t\tif (metaViewport) {\n\t\t\t\t\t// user-scalable=no eliminates click delay.\n\t\t\t\t\tif (metaViewport.content.indexOf('user-scalable=no') !== -1) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t\t// width=device-width (or less than device-width) eliminates click delay.\n\t\t\t\t\tif (document.documentElement.scrollWidth <= window.outerWidth) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// IE10 with -ms-touch-action: none or manipulation, which disables double-tap-to-zoom (issue #97)\n\t\tif (layer.style.msTouchAction === 'none' || layer.style.touchAction === 'manipulation') {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Firefox version - zero for other browsers\n\t\tfirefoxVersion = +(/Firefox\\/([0-9]+)/.exec(navigator.userAgent) || [,0])[1];\n\n\t\tif (firefoxVersion >= 27) {\n\t\t\t// Firefox 27+ does not have tap delay if the content is not zoomable - https://bugzilla.mozilla.org/show_bug.cgi?id=922896\n\n\t\t\tmetaViewport = document.querySelector('meta[name=viewport]');\n\t\t\tif (metaViewport && (metaViewport.content.indexOf('user-scalable=no') !== -1 || document.documentElement.scrollWidth <= window.outerWidth)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\t// IE11: prefixed -ms-touch-action is no longer supported and it's recomended to use non-prefixed version\n\t\t// http://msdn.microsoft.com/en-us/library/windows/apps/Hh767313.aspx\n\t\tif (layer.style.touchAction === 'none' || layer.style.touchAction === 'manipulation') {\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t};\n\n\n\t/**\n\t * Factory method for creating a FastClick object\n\t *\n\t * @param {Element} layer The layer to listen on\n\t * @param {Object} [options={}] The options to override the defaults\n\t */\n\tFastClick.attach = function(layer, options) {\n\t\treturn new FastClick(layer, options);\n\t};\n\n\n\tif (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\n\t\t// AMD. Register as an anonymous module.\n\t\tdefine(function() {\n\t\t\treturn FastClick;\n\t\t});\n\t} else if (typeof module !== 'undefined' && module.exports) {\n\t\tmodule.exports = FastClick.attach;\n\t\tmodule.exports.FastClick = FastClick;\n\t} else {\n\t\twindow.FastClick = FastClick;\n\t}\n}());\n"
  },
  {
    "path": "source/lib/font-awesome/.bower.json",
    "content": "{\n  \"name\": \"font-awesome\",\n  \"description\": \"Font Awesome\",\n  \"keywords\": [],\n  \"homepage\": \"http://fontawesome.io\",\n  \"dependencies\": {},\n  \"devDependencies\": {},\n  \"license\": [\n    \"OFL-1.1\",\n    \"MIT\",\n    \"CC-BY-3.0\"\n  ],\n  \"main\": [\n    \"less/font-awesome.less\",\n    \"scss/font-awesome.scss\"\n  ],\n  \"ignore\": [\n    \"*/.*\",\n    \"*.json\",\n    \"src\",\n    \"*.yml\",\n    \"Gemfile\",\n    \"Gemfile.lock\",\n    \"*.md\"\n  ],\n  \"version\": \"4.7.0\",\n  \"_release\": \"4.7.0\",\n  \"_resolution\": {\n    \"type\": \"version\",\n    \"tag\": \"v4.7.0\",\n    \"commit\": \"a3fe90fa5f6fac55d197f9cbd18e3f57dafb716c\"\n  },\n  \"_source\": \"https://github.com/FortAwesome/Font-Awesome.git\",\n  \"_target\": \"*\",\n  \"_originalSource\": \"fontawesome\"\n}"
  },
  {
    "path": "source/lib/font-awesome/.gitignore",
    "content": "*.pyc\n*.egg-info\n*.db\n*.db.old\n*.swp\n*.db-journal\n\n.coverage\n.DS_Store\n.installed.cfg\n_gh_pages/*\n\n.idea/*\n.svn/*\nsrc/website/static/*\nsrc/website/media/*\n\nbin\ncfcache\ndevelop-eggs\ndist\ndownloads\neggs\nparts\ntmp\n.sass-cache\nnode_modules\n\nsrc/website/settingslocal.py\nstunnel.log\n\n.ruby-version\n.bundle\n"
  },
  {
    "path": "source/lib/font-awesome/.npmignore",
    "content": "*.pyc\n*.egg-info\n*.db\n*.db.old\n*.swp\n*.db-journal\n\n.coverage\n.DS_Store\n.installed.cfg\n_gh_pages/*\n\n.idea/*\n.svn/*\nsrc/website/static/*\nsrc/website/media/*\n\nbin\ncfcache\ndevelop-eggs\ndist\ndownloads\neggs\nparts\ntmp\n.sass-cache\nnode_modules\n\nsrc/website/settingslocal.py\nstunnel.log\n\n.ruby-version\n\n# don't need these in the npm package.\nsrc/\n_config.yml\nbower.json\ncomponent.json\ncomposer.json\nCONTRIBUTING.md\nGemfile\nGemfile.lock\n"
  },
  {
    "path": "source/lib/font-awesome/HELP-US-OUT.txt",
    "content": "I hope you love Font Awesome. If you've found it useful, please do me a favor and check out my latest project,\nFort Awesome (https://fortawesome.com). It makes it easy to put the perfect icons on your website. Choose from our awesome,\ncomprehensive icon sets or copy and paste your own.\n\nPlease. Check it out.\n\n-Dave Gandy\n"
  },
  {
    "path": "source/lib/font-awesome/bower.json",
    "content": "{\n  \"name\": \"font-awesome\",\n  \"description\": \"Font Awesome\",\n  \"keywords\": [],\n  \"homepage\": \"http://fontawesome.io\",\n  \"dependencies\": {},\n  \"devDependencies\": {},\n  \"license\": [\"OFL-1.1\", \"MIT\", \"CC-BY-3.0\"],\n  \"main\": [\n    \"less/font-awesome.less\",\n    \"scss/font-awesome.scss\"\n  ],\n  \"ignore\": [\n    \"*/.*\",\n    \"*.json\",\n    \"src\",\n    \"*.yml\",\n    \"Gemfile\",\n    \"Gemfile.lock\",\n    \"*.md\"\n  ]\n}\n"
  },
  {
    "path": "source/lib/font-awesome/css/font-awesome.css",
    "content": "/*!\n *  Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n/* FONT PATH\n * -------------------------- */\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('../fonts/fontawesome-webfont.eot?v=4.7.0');\n  src: url('../fonts/fontawesome-webfont.eot?#iefix&v=4.7.0') format('embedded-opentype'), url('../fonts/fontawesome-webfont.woff2?v=4.7.0') format('woff2'), url('../fonts/fontawesome-webfont.woff?v=4.7.0') format('woff'), url('../fonts/fontawesome-webfont.ttf?v=4.7.0') format('truetype'), url('../fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.fa {\n  display: inline-block;\n  font: normal normal normal 14px/1 FontAwesome;\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n/* makes the font 33% larger relative to the icon container */\n.fa-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.fa-2x {\n  font-size: 2em;\n}\n.fa-3x {\n  font-size: 3em;\n}\n.fa-4x {\n  font-size: 4em;\n}\n.fa-5x {\n  font-size: 5em;\n}\n.fa-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.fa-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.fa-ul > li {\n  position: relative;\n}\n.fa-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.fa-li.fa-lg {\n  left: -1.85714286em;\n}\n.fa-border {\n  padding: .2em .25em .15em;\n  border: solid 0.08em #eeeeee;\n  border-radius: .1em;\n}\n.fa-pull-left {\n  float: left;\n}\n.fa-pull-right {\n  float: right;\n}\n.fa.fa-pull-left {\n  margin-right: .3em;\n}\n.fa.fa-pull-right {\n  margin-left: .3em;\n}\n/* Deprecated as of 4.4.0 */\n.pull-right {\n  float: right;\n}\n.pull-left {\n  float: left;\n}\n.fa.pull-left {\n  margin-right: .3em;\n}\n.fa.pull-right {\n  margin-left: .3em;\n}\n.fa-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n  animation: fa-spin 2s infinite linear;\n}\n.fa-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n  animation: fa-spin 1s infinite steps(8);\n}\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n.fa-rotate-90 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)\";\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.fa-rotate-180 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)\";\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.fa-rotate-270 {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)\";\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.fa-flip-horizontal {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)\";\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.fa-flip-vertical {\n  -ms-filter: \"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)\";\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n:root .fa-rotate-90,\n:root .fa-rotate-180,\n:root .fa-rotate-270,\n:root .fa-flip-horizontal,\n:root .fa-flip-vertical {\n  filter: none;\n}\n.fa-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.fa-stack-1x,\n.fa-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.fa-stack-1x {\n  line-height: inherit;\n}\n.fa-stack-2x {\n  font-size: 2em;\n}\n.fa-inverse {\n  color: #ffffff;\n}\n/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.fa-glass:before {\n  content: \"\\f000\";\n}\n.fa-music:before {\n  content: \"\\f001\";\n}\n.fa-search:before {\n  content: \"\\f002\";\n}\n.fa-envelope-o:before {\n  content: \"\\f003\";\n}\n.fa-heart:before {\n  content: \"\\f004\";\n}\n.fa-star:before {\n  content: \"\\f005\";\n}\n.fa-star-o:before {\n  content: \"\\f006\";\n}\n.fa-user:before {\n  content: \"\\f007\";\n}\n.fa-film:before {\n  content: \"\\f008\";\n}\n.fa-th-large:before {\n  content: \"\\f009\";\n}\n.fa-th:before {\n  content: \"\\f00a\";\n}\n.fa-th-list:before {\n  content: \"\\f00b\";\n}\n.fa-check:before {\n  content: \"\\f00c\";\n}\n.fa-remove:before,\n.fa-close:before,\n.fa-times:before {\n  content: \"\\f00d\";\n}\n.fa-search-plus:before {\n  content: \"\\f00e\";\n}\n.fa-search-minus:before {\n  content: \"\\f010\";\n}\n.fa-power-off:before {\n  content: \"\\f011\";\n}\n.fa-signal:before {\n  content: \"\\f012\";\n}\n.fa-gear:before,\n.fa-cog:before {\n  content: \"\\f013\";\n}\n.fa-trash-o:before {\n  content: \"\\f014\";\n}\n.fa-home:before {\n  content: \"\\f015\";\n}\n.fa-file-o:before {\n  content: \"\\f016\";\n}\n.fa-clock-o:before {\n  content: \"\\f017\";\n}\n.fa-road:before {\n  content: \"\\f018\";\n}\n.fa-download:before {\n  content: \"\\f019\";\n}\n.fa-arrow-circle-o-down:before {\n  content: \"\\f01a\";\n}\n.fa-arrow-circle-o-up:before {\n  content: \"\\f01b\";\n}\n.fa-inbox:before {\n  content: \"\\f01c\";\n}\n.fa-play-circle-o:before {\n  content: \"\\f01d\";\n}\n.fa-rotate-right:before,\n.fa-repeat:before {\n  content: \"\\f01e\";\n}\n.fa-refresh:before {\n  content: \"\\f021\";\n}\n.fa-list-alt:before {\n  content: \"\\f022\";\n}\n.fa-lock:before {\n  content: \"\\f023\";\n}\n.fa-flag:before {\n  content: \"\\f024\";\n}\n.fa-headphones:before {\n  content: \"\\f025\";\n}\n.fa-volume-off:before {\n  content: \"\\f026\";\n}\n.fa-volume-down:before {\n  content: \"\\f027\";\n}\n.fa-volume-up:before {\n  content: \"\\f028\";\n}\n.fa-qrcode:before {\n  content: \"\\f029\";\n}\n.fa-barcode:before {\n  content: \"\\f02a\";\n}\n.fa-tag:before {\n  content: \"\\f02b\";\n}\n.fa-tags:before {\n  content: \"\\f02c\";\n}\n.fa-book:before {\n  content: \"\\f02d\";\n}\n.fa-bookmark:before {\n  content: \"\\f02e\";\n}\n.fa-print:before {\n  content: \"\\f02f\";\n}\n.fa-camera:before {\n  content: \"\\f030\";\n}\n.fa-font:before {\n  content: \"\\f031\";\n}\n.fa-bold:before {\n  content: \"\\f032\";\n}\n.fa-italic:before {\n  content: \"\\f033\";\n}\n.fa-text-height:before {\n  content: \"\\f034\";\n}\n.fa-text-width:before {\n  content: \"\\f035\";\n}\n.fa-align-left:before {\n  content: \"\\f036\";\n}\n.fa-align-center:before {\n  content: \"\\f037\";\n}\n.fa-align-right:before {\n  content: \"\\f038\";\n}\n.fa-align-justify:before {\n  content: \"\\f039\";\n}\n.fa-list:before {\n  content: \"\\f03a\";\n}\n.fa-dedent:before,\n.fa-outdent:before {\n  content: \"\\f03b\";\n}\n.fa-indent:before {\n  content: \"\\f03c\";\n}\n.fa-video-camera:before {\n  content: \"\\f03d\";\n}\n.fa-photo:before,\n.fa-image:before,\n.fa-picture-o:before {\n  content: \"\\f03e\";\n}\n.fa-pencil:before {\n  content: \"\\f040\";\n}\n.fa-map-marker:before {\n  content: \"\\f041\";\n}\n.fa-adjust:before {\n  content: \"\\f042\";\n}\n.fa-tint:before {\n  content: \"\\f043\";\n}\n.fa-edit:before,\n.fa-pencil-square-o:before {\n  content: \"\\f044\";\n}\n.fa-share-square-o:before {\n  content: \"\\f045\";\n}\n.fa-check-square-o:before {\n  content: \"\\f046\";\n}\n.fa-arrows:before {\n  content: \"\\f047\";\n}\n.fa-step-backward:before {\n  content: \"\\f048\";\n}\n.fa-fast-backward:before {\n  content: \"\\f049\";\n}\n.fa-backward:before {\n  content: \"\\f04a\";\n}\n.fa-play:before {\n  content: \"\\f04b\";\n}\n.fa-pause:before {\n  content: \"\\f04c\";\n}\n.fa-stop:before {\n  content: \"\\f04d\";\n}\n.fa-forward:before {\n  content: \"\\f04e\";\n}\n.fa-fast-forward:before {\n  content: \"\\f050\";\n}\n.fa-step-forward:before {\n  content: \"\\f051\";\n}\n.fa-eject:before {\n  content: \"\\f052\";\n}\n.fa-chevron-left:before {\n  content: \"\\f053\";\n}\n.fa-chevron-right:before {\n  content: \"\\f054\";\n}\n.fa-plus-circle:before {\n  content: \"\\f055\";\n}\n.fa-minus-circle:before {\n  content: \"\\f056\";\n}\n.fa-times-circle:before {\n  content: \"\\f057\";\n}\n.fa-check-circle:before {\n  content: \"\\f058\";\n}\n.fa-question-circle:before {\n  content: \"\\f059\";\n}\n.fa-info-circle:before {\n  content: \"\\f05a\";\n}\n.fa-crosshairs:before {\n  content: \"\\f05b\";\n}\n.fa-times-circle-o:before {\n  content: \"\\f05c\";\n}\n.fa-check-circle-o:before {\n  content: \"\\f05d\";\n}\n.fa-ban:before {\n  content: \"\\f05e\";\n}\n.fa-arrow-left:before {\n  content: \"\\f060\";\n}\n.fa-arrow-right:before {\n  content: \"\\f061\";\n}\n.fa-arrow-up:before {\n  content: \"\\f062\";\n}\n.fa-arrow-down:before {\n  content: \"\\f063\";\n}\n.fa-mail-forward:before,\n.fa-share:before {\n  content: \"\\f064\";\n}\n.fa-expand:before {\n  content: \"\\f065\";\n}\n.fa-compress:before {\n  content: \"\\f066\";\n}\n.fa-plus:before {\n  content: \"\\f067\";\n}\n.fa-minus:before {\n  content: \"\\f068\";\n}\n.fa-asterisk:before {\n  content: \"\\f069\";\n}\n.fa-exclamation-circle:before {\n  content: \"\\f06a\";\n}\n.fa-gift:before {\n  content: \"\\f06b\";\n}\n.fa-leaf:before {\n  content: \"\\f06c\";\n}\n.fa-fire:before {\n  content: \"\\f06d\";\n}\n.fa-eye:before {\n  content: \"\\f06e\";\n}\n.fa-eye-slash:before {\n  content: \"\\f070\";\n}\n.fa-warning:before,\n.fa-exclamation-triangle:before {\n  content: \"\\f071\";\n}\n.fa-plane:before {\n  content: \"\\f072\";\n}\n.fa-calendar:before {\n  content: \"\\f073\";\n}\n.fa-random:before {\n  content: \"\\f074\";\n}\n.fa-comment:before {\n  content: \"\\f075\";\n}\n.fa-magnet:before {\n  content: \"\\f076\";\n}\n.fa-chevron-up:before {\n  content: \"\\f077\";\n}\n.fa-chevron-down:before {\n  content: \"\\f078\";\n}\n.fa-retweet:before {\n  content: \"\\f079\";\n}\n.fa-shopping-cart:before {\n  content: \"\\f07a\";\n}\n.fa-folder:before {\n  content: \"\\f07b\";\n}\n.fa-folder-open:before {\n  content: \"\\f07c\";\n}\n.fa-arrows-v:before {\n  content: \"\\f07d\";\n}\n.fa-arrows-h:before {\n  content: \"\\f07e\";\n}\n.fa-bar-chart-o:before,\n.fa-bar-chart:before {\n  content: \"\\f080\";\n}\n.fa-twitter-square:before {\n  content: \"\\f081\";\n}\n.fa-facebook-square:before {\n  content: \"\\f082\";\n}\n.fa-camera-retro:before {\n  content: \"\\f083\";\n}\n.fa-key:before {\n  content: \"\\f084\";\n}\n.fa-gears:before,\n.fa-cogs:before {\n  content: \"\\f085\";\n}\n.fa-comments:before {\n  content: \"\\f086\";\n}\n.fa-thumbs-o-up:before {\n  content: \"\\f087\";\n}\n.fa-thumbs-o-down:before {\n  content: \"\\f088\";\n}\n.fa-star-half:before {\n  content: \"\\f089\";\n}\n.fa-heart-o:before {\n  content: \"\\f08a\";\n}\n.fa-sign-out:before {\n  content: \"\\f08b\";\n}\n.fa-linkedin-square:before {\n  content: \"\\f08c\";\n}\n.fa-thumb-tack:before {\n  content: \"\\f08d\";\n}\n.fa-external-link:before {\n  content: \"\\f08e\";\n}\n.fa-sign-in:before {\n  content: \"\\f090\";\n}\n.fa-trophy:before {\n  content: \"\\f091\";\n}\n.fa-github-square:before {\n  content: \"\\f092\";\n}\n.fa-upload:before {\n  content: \"\\f093\";\n}\n.fa-lemon-o:before {\n  content: \"\\f094\";\n}\n.fa-phone:before {\n  content: \"\\f095\";\n}\n.fa-square-o:before {\n  content: \"\\f096\";\n}\n.fa-bookmark-o:before {\n  content: \"\\f097\";\n}\n.fa-phone-square:before {\n  content: \"\\f098\";\n}\n.fa-twitter:before {\n  content: \"\\f099\";\n}\n.fa-facebook-f:before,\n.fa-facebook:before {\n  content: \"\\f09a\";\n}\n.fa-github:before {\n  content: \"\\f09b\";\n}\n.fa-unlock:before {\n  content: \"\\f09c\";\n}\n.fa-credit-card:before {\n  content: \"\\f09d\";\n}\n.fa-feed:before,\n.fa-rss:before {\n  content: \"\\f09e\";\n}\n.fa-hdd-o:before {\n  content: \"\\f0a0\";\n}\n.fa-bullhorn:before {\n  content: \"\\f0a1\";\n}\n.fa-bell:before {\n  content: \"\\f0f3\";\n}\n.fa-certificate:before {\n  content: \"\\f0a3\";\n}\n.fa-hand-o-right:before {\n  content: \"\\f0a4\";\n}\n.fa-hand-o-left:before {\n  content: \"\\f0a5\";\n}\n.fa-hand-o-up:before {\n  content: \"\\f0a6\";\n}\n.fa-hand-o-down:before {\n  content: \"\\f0a7\";\n}\n.fa-arrow-circle-left:before {\n  content: \"\\f0a8\";\n}\n.fa-arrow-circle-right:before {\n  content: \"\\f0a9\";\n}\n.fa-arrow-circle-up:before {\n  content: \"\\f0aa\";\n}\n.fa-arrow-circle-down:before {\n  content: \"\\f0ab\";\n}\n.fa-globe:before {\n  content: \"\\f0ac\";\n}\n.fa-wrench:before {\n  content: \"\\f0ad\";\n}\n.fa-tasks:before {\n  content: \"\\f0ae\";\n}\n.fa-filter:before {\n  content: \"\\f0b0\";\n}\n.fa-briefcase:before {\n  content: \"\\f0b1\";\n}\n.fa-arrows-alt:before {\n  content: \"\\f0b2\";\n}\n.fa-group:before,\n.fa-users:before {\n  content: \"\\f0c0\";\n}\n.fa-chain:before,\n.fa-link:before {\n  content: \"\\f0c1\";\n}\n.fa-cloud:before {\n  content: \"\\f0c2\";\n}\n.fa-flask:before {\n  content: \"\\f0c3\";\n}\n.fa-cut:before,\n.fa-scissors:before {\n  content: \"\\f0c4\";\n}\n.fa-copy:before,\n.fa-files-o:before {\n  content: \"\\f0c5\";\n}\n.fa-paperclip:before {\n  content: \"\\f0c6\";\n}\n.fa-save:before,\n.fa-floppy-o:before {\n  content: \"\\f0c7\";\n}\n.fa-square:before {\n  content: \"\\f0c8\";\n}\n.fa-navicon:before,\n.fa-reorder:before,\n.fa-bars:before {\n  content: \"\\f0c9\";\n}\n.fa-list-ul:before {\n  content: \"\\f0ca\";\n}\n.fa-list-ol:before {\n  content: \"\\f0cb\";\n}\n.fa-strikethrough:before {\n  content: \"\\f0cc\";\n}\n.fa-underline:before {\n  content: \"\\f0cd\";\n}\n.fa-table:before {\n  content: \"\\f0ce\";\n}\n.fa-magic:before {\n  content: \"\\f0d0\";\n}\n.fa-truck:before {\n  content: \"\\f0d1\";\n}\n.fa-pinterest:before {\n  content: \"\\f0d2\";\n}\n.fa-pinterest-square:before {\n  content: \"\\f0d3\";\n}\n.fa-google-plus-square:before {\n  content: \"\\f0d4\";\n}\n.fa-google-plus:before {\n  content: \"\\f0d5\";\n}\n.fa-money:before {\n  content: \"\\f0d6\";\n}\n.fa-caret-down:before {\n  content: \"\\f0d7\";\n}\n.fa-caret-up:before {\n  content: \"\\f0d8\";\n}\n.fa-caret-left:before {\n  content: \"\\f0d9\";\n}\n.fa-caret-right:before {\n  content: \"\\f0da\";\n}\n.fa-columns:before {\n  content: \"\\f0db\";\n}\n.fa-unsorted:before,\n.fa-sort:before {\n  content: \"\\f0dc\";\n}\n.fa-sort-down:before,\n.fa-sort-desc:before {\n  content: \"\\f0dd\";\n}\n.fa-sort-up:before,\n.fa-sort-asc:before {\n  content: \"\\f0de\";\n}\n.fa-envelope:before {\n  content: \"\\f0e0\";\n}\n.fa-linkedin:before {\n  content: \"\\f0e1\";\n}\n.fa-rotate-left:before,\n.fa-undo:before {\n  content: \"\\f0e2\";\n}\n.fa-legal:before,\n.fa-gavel:before {\n  content: \"\\f0e3\";\n}\n.fa-dashboard:before,\n.fa-tachometer:before {\n  content: \"\\f0e4\";\n}\n.fa-comment-o:before {\n  content: \"\\f0e5\";\n}\n.fa-comments-o:before {\n  content: \"\\f0e6\";\n}\n.fa-flash:before,\n.fa-bolt:before {\n  content: \"\\f0e7\";\n}\n.fa-sitemap:before {\n  content: \"\\f0e8\";\n}\n.fa-umbrella:before {\n  content: \"\\f0e9\";\n}\n.fa-paste:before,\n.fa-clipboard:before {\n  content: \"\\f0ea\";\n}\n.fa-lightbulb-o:before {\n  content: \"\\f0eb\";\n}\n.fa-exchange:before {\n  content: \"\\f0ec\";\n}\n.fa-cloud-download:before {\n  content: \"\\f0ed\";\n}\n.fa-cloud-upload:before {\n  content: \"\\f0ee\";\n}\n.fa-user-md:before {\n  content: \"\\f0f0\";\n}\n.fa-stethoscope:before {\n  content: \"\\f0f1\";\n}\n.fa-suitcase:before {\n  content: \"\\f0f2\";\n}\n.fa-bell-o:before {\n  content: \"\\f0a2\";\n}\n.fa-coffee:before {\n  content: \"\\f0f4\";\n}\n.fa-cutlery:before {\n  content: \"\\f0f5\";\n}\n.fa-file-text-o:before {\n  content: \"\\f0f6\";\n}\n.fa-building-o:before {\n  content: \"\\f0f7\";\n}\n.fa-hospital-o:before {\n  content: \"\\f0f8\";\n}\n.fa-ambulance:before {\n  content: \"\\f0f9\";\n}\n.fa-medkit:before {\n  content: \"\\f0fa\";\n}\n.fa-fighter-jet:before {\n  content: \"\\f0fb\";\n}\n.fa-beer:before {\n  content: \"\\f0fc\";\n}\n.fa-h-square:before {\n  content: \"\\f0fd\";\n}\n.fa-plus-square:before {\n  content: \"\\f0fe\";\n}\n.fa-angle-double-left:before {\n  content: \"\\f100\";\n}\n.fa-angle-double-right:before {\n  content: \"\\f101\";\n}\n.fa-angle-double-up:before {\n  content: \"\\f102\";\n}\n.fa-angle-double-down:before {\n  content: \"\\f103\";\n}\n.fa-angle-left:before {\n  content: \"\\f104\";\n}\n.fa-angle-right:before {\n  content: \"\\f105\";\n}\n.fa-angle-up:before {\n  content: \"\\f106\";\n}\n.fa-angle-down:before {\n  content: \"\\f107\";\n}\n.fa-desktop:before {\n  content: \"\\f108\";\n}\n.fa-laptop:before {\n  content: \"\\f109\";\n}\n.fa-tablet:before {\n  content: \"\\f10a\";\n}\n.fa-mobile-phone:before,\n.fa-mobile:before {\n  content: \"\\f10b\";\n}\n.fa-circle-o:before {\n  content: \"\\f10c\";\n}\n.fa-quote-left:before {\n  content: \"\\f10d\";\n}\n.fa-quote-right:before {\n  content: \"\\f10e\";\n}\n.fa-spinner:before {\n  content: \"\\f110\";\n}\n.fa-circle:before {\n  content: \"\\f111\";\n}\n.fa-mail-reply:before,\n.fa-reply:before {\n  content: \"\\f112\";\n}\n.fa-github-alt:before {\n  content: \"\\f113\";\n}\n.fa-folder-o:before {\n  content: \"\\f114\";\n}\n.fa-folder-open-o:before {\n  content: \"\\f115\";\n}\n.fa-smile-o:before {\n  content: \"\\f118\";\n}\n.fa-frown-o:before {\n  content: \"\\f119\";\n}\n.fa-meh-o:before {\n  content: \"\\f11a\";\n}\n.fa-gamepad:before {\n  content: \"\\f11b\";\n}\n.fa-keyboard-o:before {\n  content: \"\\f11c\";\n}\n.fa-flag-o:before {\n  content: \"\\f11d\";\n}\n.fa-flag-checkered:before {\n  content: \"\\f11e\";\n}\n.fa-terminal:before {\n  content: \"\\f120\";\n}\n.fa-code:before {\n  content: \"\\f121\";\n}\n.fa-mail-reply-all:before,\n.fa-reply-all:before {\n  content: \"\\f122\";\n}\n.fa-star-half-empty:before,\n.fa-star-half-full:before,\n.fa-star-half-o:before {\n  content: \"\\f123\";\n}\n.fa-location-arrow:before {\n  content: \"\\f124\";\n}\n.fa-crop:before {\n  content: \"\\f125\";\n}\n.fa-code-fork:before {\n  content: \"\\f126\";\n}\n.fa-unlink:before,\n.fa-chain-broken:before {\n  content: \"\\f127\";\n}\n.fa-question:before {\n  content: \"\\f128\";\n}\n.fa-info:before {\n  content: \"\\f129\";\n}\n.fa-exclamation:before {\n  content: \"\\f12a\";\n}\n.fa-superscript:before {\n  content: \"\\f12b\";\n}\n.fa-subscript:before {\n  content: \"\\f12c\";\n}\n.fa-eraser:before {\n  content: \"\\f12d\";\n}\n.fa-puzzle-piece:before {\n  content: \"\\f12e\";\n}\n.fa-microphone:before {\n  content: \"\\f130\";\n}\n.fa-microphone-slash:before {\n  content: \"\\f131\";\n}\n.fa-shield:before {\n  content: \"\\f132\";\n}\n.fa-calendar-o:before {\n  content: \"\\f133\";\n}\n.fa-fire-extinguisher:before {\n  content: \"\\f134\";\n}\n.fa-rocket:before {\n  content: \"\\f135\";\n}\n.fa-maxcdn:before {\n  content: \"\\f136\";\n}\n.fa-chevron-circle-left:before {\n  content: \"\\f137\";\n}\n.fa-chevron-circle-right:before {\n  content: \"\\f138\";\n}\n.fa-chevron-circle-up:before {\n  content: \"\\f139\";\n}\n.fa-chevron-circle-down:before {\n  content: \"\\f13a\";\n}\n.fa-html5:before {\n  content: \"\\f13b\";\n}\n.fa-css3:before {\n  content: \"\\f13c\";\n}\n.fa-anchor:before {\n  content: \"\\f13d\";\n}\n.fa-unlock-alt:before {\n  content: \"\\f13e\";\n}\n.fa-bullseye:before {\n  content: \"\\f140\";\n}\n.fa-ellipsis-h:before {\n  content: \"\\f141\";\n}\n.fa-ellipsis-v:before {\n  content: \"\\f142\";\n}\n.fa-rss-square:before {\n  content: \"\\f143\";\n}\n.fa-play-circle:before {\n  content: \"\\f144\";\n}\n.fa-ticket:before {\n  content: \"\\f145\";\n}\n.fa-minus-square:before {\n  content: \"\\f146\";\n}\n.fa-minus-square-o:before {\n  content: \"\\f147\";\n}\n.fa-level-up:before {\n  content: \"\\f148\";\n}\n.fa-level-down:before {\n  content: \"\\f149\";\n}\n.fa-check-square:before {\n  content: \"\\f14a\";\n}\n.fa-pencil-square:before {\n  content: \"\\f14b\";\n}\n.fa-external-link-square:before {\n  content: \"\\f14c\";\n}\n.fa-share-square:before {\n  content: \"\\f14d\";\n}\n.fa-compass:before {\n  content: \"\\f14e\";\n}\n.fa-toggle-down:before,\n.fa-caret-square-o-down:before {\n  content: \"\\f150\";\n}\n.fa-toggle-up:before,\n.fa-caret-square-o-up:before {\n  content: \"\\f151\";\n}\n.fa-toggle-right:before,\n.fa-caret-square-o-right:before {\n  content: \"\\f152\";\n}\n.fa-euro:before,\n.fa-eur:before {\n  content: \"\\f153\";\n}\n.fa-gbp:before {\n  content: \"\\f154\";\n}\n.fa-dollar:before,\n.fa-usd:before {\n  content: \"\\f155\";\n}\n.fa-rupee:before,\n.fa-inr:before {\n  content: \"\\f156\";\n}\n.fa-cny:before,\n.fa-rmb:before,\n.fa-yen:before,\n.fa-jpy:before {\n  content: \"\\f157\";\n}\n.fa-ruble:before,\n.fa-rouble:before,\n.fa-rub:before {\n  content: \"\\f158\";\n}\n.fa-won:before,\n.fa-krw:before {\n  content: \"\\f159\";\n}\n.fa-bitcoin:before,\n.fa-btc:before {\n  content: \"\\f15a\";\n}\n.fa-file:before {\n  content: \"\\f15b\";\n}\n.fa-file-text:before {\n  content: \"\\f15c\";\n}\n.fa-sort-alpha-asc:before {\n  content: \"\\f15d\";\n}\n.fa-sort-alpha-desc:before {\n  content: \"\\f15e\";\n}\n.fa-sort-amount-asc:before {\n  content: \"\\f160\";\n}\n.fa-sort-amount-desc:before {\n  content: \"\\f161\";\n}\n.fa-sort-numeric-asc:before {\n  content: \"\\f162\";\n}\n.fa-sort-numeric-desc:before {\n  content: \"\\f163\";\n}\n.fa-thumbs-up:before {\n  content: \"\\f164\";\n}\n.fa-thumbs-down:before {\n  content: \"\\f165\";\n}\n.fa-youtube-square:before {\n  content: \"\\f166\";\n}\n.fa-youtube:before {\n  content: \"\\f167\";\n}\n.fa-xing:before {\n  content: \"\\f168\";\n}\n.fa-xing-square:before {\n  content: \"\\f169\";\n}\n.fa-youtube-play:before {\n  content: \"\\f16a\";\n}\n.fa-dropbox:before {\n  content: \"\\f16b\";\n}\n.fa-stack-overflow:before {\n  content: \"\\f16c\";\n}\n.fa-instagram:before {\n  content: \"\\f16d\";\n}\n.fa-flickr:before {\n  content: \"\\f16e\";\n}\n.fa-adn:before {\n  content: \"\\f170\";\n}\n.fa-bitbucket:before {\n  content: \"\\f171\";\n}\n.fa-bitbucket-square:before {\n  content: \"\\f172\";\n}\n.fa-tumblr:before {\n  content: \"\\f173\";\n}\n.fa-tumblr-square:before {\n  content: \"\\f174\";\n}\n.fa-long-arrow-down:before {\n  content: \"\\f175\";\n}\n.fa-long-arrow-up:before {\n  content: \"\\f176\";\n}\n.fa-long-arrow-left:before {\n  content: \"\\f177\";\n}\n.fa-long-arrow-right:before {\n  content: \"\\f178\";\n}\n.fa-apple:before {\n  content: \"\\f179\";\n}\n.fa-windows:before {\n  content: \"\\f17a\";\n}\n.fa-android:before {\n  content: \"\\f17b\";\n}\n.fa-linux:before {\n  content: \"\\f17c\";\n}\n.fa-dribbble:before {\n  content: \"\\f17d\";\n}\n.fa-skype:before {\n  content: \"\\f17e\";\n}\n.fa-foursquare:before {\n  content: \"\\f180\";\n}\n.fa-trello:before {\n  content: \"\\f181\";\n}\n.fa-female:before {\n  content: \"\\f182\";\n}\n.fa-male:before {\n  content: \"\\f183\";\n}\n.fa-gittip:before,\n.fa-gratipay:before {\n  content: \"\\f184\";\n}\n.fa-sun-o:before {\n  content: \"\\f185\";\n}\n.fa-moon-o:before {\n  content: \"\\f186\";\n}\n.fa-archive:before {\n  content: \"\\f187\";\n}\n.fa-bug:before {\n  content: \"\\f188\";\n}\n.fa-vk:before {\n  content: \"\\f189\";\n}\n.fa-weibo:before {\n  content: \"\\f18a\";\n}\n.fa-renren:before {\n  content: \"\\f18b\";\n}\n.fa-pagelines:before {\n  content: \"\\f18c\";\n}\n.fa-stack-exchange:before {\n  content: \"\\f18d\";\n}\n.fa-arrow-circle-o-right:before {\n  content: \"\\f18e\";\n}\n.fa-arrow-circle-o-left:before {\n  content: \"\\f190\";\n}\n.fa-toggle-left:before,\n.fa-caret-square-o-left:before {\n  content: \"\\f191\";\n}\n.fa-dot-circle-o:before {\n  content: \"\\f192\";\n}\n.fa-wheelchair:before {\n  content: \"\\f193\";\n}\n.fa-vimeo-square:before {\n  content: \"\\f194\";\n}\n.fa-turkish-lira:before,\n.fa-try:before {\n  content: \"\\f195\";\n}\n.fa-plus-square-o:before {\n  content: \"\\f196\";\n}\n.fa-space-shuttle:before {\n  content: \"\\f197\";\n}\n.fa-slack:before {\n  content: \"\\f198\";\n}\n.fa-envelope-square:before {\n  content: \"\\f199\";\n}\n.fa-wordpress:before {\n  content: \"\\f19a\";\n}\n.fa-openid:before {\n  content: \"\\f19b\";\n}\n.fa-institution:before,\n.fa-bank:before,\n.fa-university:before {\n  content: \"\\f19c\";\n}\n.fa-mortar-board:before,\n.fa-graduation-cap:before {\n  content: \"\\f19d\";\n}\n.fa-yahoo:before {\n  content: \"\\f19e\";\n}\n.fa-google:before {\n  content: \"\\f1a0\";\n}\n.fa-reddit:before {\n  content: \"\\f1a1\";\n}\n.fa-reddit-square:before {\n  content: \"\\f1a2\";\n}\n.fa-stumbleupon-circle:before {\n  content: \"\\f1a3\";\n}\n.fa-stumbleupon:before {\n  content: \"\\f1a4\";\n}\n.fa-delicious:before {\n  content: \"\\f1a5\";\n}\n.fa-digg:before {\n  content: \"\\f1a6\";\n}\n.fa-pied-piper-pp:before {\n  content: \"\\f1a7\";\n}\n.fa-pied-piper-alt:before {\n  content: \"\\f1a8\";\n}\n.fa-drupal:before {\n  content: \"\\f1a9\";\n}\n.fa-joomla:before {\n  content: \"\\f1aa\";\n}\n.fa-language:before {\n  content: \"\\f1ab\";\n}\n.fa-fax:before {\n  content: \"\\f1ac\";\n}\n.fa-building:before {\n  content: \"\\f1ad\";\n}\n.fa-child:before {\n  content: \"\\f1ae\";\n}\n.fa-paw:before {\n  content: \"\\f1b0\";\n}\n.fa-spoon:before {\n  content: \"\\f1b1\";\n}\n.fa-cube:before {\n  content: \"\\f1b2\";\n}\n.fa-cubes:before {\n  content: \"\\f1b3\";\n}\n.fa-behance:before {\n  content: \"\\f1b4\";\n}\n.fa-behance-square:before {\n  content: \"\\f1b5\";\n}\n.fa-steam:before {\n  content: \"\\f1b6\";\n}\n.fa-steam-square:before {\n  content: \"\\f1b7\";\n}\n.fa-recycle:before {\n  content: \"\\f1b8\";\n}\n.fa-automobile:before,\n.fa-car:before {\n  content: \"\\f1b9\";\n}\n.fa-cab:before,\n.fa-taxi:before {\n  content: \"\\f1ba\";\n}\n.fa-tree:before {\n  content: \"\\f1bb\";\n}\n.fa-spotify:before {\n  content: \"\\f1bc\";\n}\n.fa-deviantart:before {\n  content: \"\\f1bd\";\n}\n.fa-soundcloud:before {\n  content: \"\\f1be\";\n}\n.fa-database:before {\n  content: \"\\f1c0\";\n}\n.fa-file-pdf-o:before {\n  content: \"\\f1c1\";\n}\n.fa-file-word-o:before {\n  content: \"\\f1c2\";\n}\n.fa-file-excel-o:before {\n  content: \"\\f1c3\";\n}\n.fa-file-powerpoint-o:before {\n  content: \"\\f1c4\";\n}\n.fa-file-photo-o:before,\n.fa-file-picture-o:before,\n.fa-file-image-o:before {\n  content: \"\\f1c5\";\n}\n.fa-file-zip-o:before,\n.fa-file-archive-o:before {\n  content: \"\\f1c6\";\n}\n.fa-file-sound-o:before,\n.fa-file-audio-o:before {\n  content: \"\\f1c7\";\n}\n.fa-file-movie-o:before,\n.fa-file-video-o:before {\n  content: \"\\f1c8\";\n}\n.fa-file-code-o:before {\n  content: \"\\f1c9\";\n}\n.fa-vine:before {\n  content: \"\\f1ca\";\n}\n.fa-codepen:before {\n  content: \"\\f1cb\";\n}\n.fa-jsfiddle:before {\n  content: \"\\f1cc\";\n}\n.fa-life-bouy:before,\n.fa-life-buoy:before,\n.fa-life-saver:before,\n.fa-support:before,\n.fa-life-ring:before {\n  content: \"\\f1cd\";\n}\n.fa-circle-o-notch:before {\n  content: \"\\f1ce\";\n}\n.fa-ra:before,\n.fa-resistance:before,\n.fa-rebel:before {\n  content: \"\\f1d0\";\n}\n.fa-ge:before,\n.fa-empire:before {\n  content: \"\\f1d1\";\n}\n.fa-git-square:before {\n  content: \"\\f1d2\";\n}\n.fa-git:before {\n  content: \"\\f1d3\";\n}\n.fa-y-combinator-square:before,\n.fa-yc-square:before,\n.fa-hacker-news:before {\n  content: \"\\f1d4\";\n}\n.fa-tencent-weibo:before {\n  content: \"\\f1d5\";\n}\n.fa-qq:before {\n  content: \"\\f1d6\";\n}\n.fa-wechat:before,\n.fa-weixin:before {\n  content: \"\\f1d7\";\n}\n.fa-send:before,\n.fa-paper-plane:before {\n  content: \"\\f1d8\";\n}\n.fa-send-o:before,\n.fa-paper-plane-o:before {\n  content: \"\\f1d9\";\n}\n.fa-history:before {\n  content: \"\\f1da\";\n}\n.fa-circle-thin:before {\n  content: \"\\f1db\";\n}\n.fa-header:before {\n  content: \"\\f1dc\";\n}\n.fa-paragraph:before {\n  content: \"\\f1dd\";\n}\n.fa-sliders:before {\n  content: \"\\f1de\";\n}\n.fa-share-alt:before {\n  content: \"\\f1e0\";\n}\n.fa-share-alt-square:before {\n  content: \"\\f1e1\";\n}\n.fa-bomb:before {\n  content: \"\\f1e2\";\n}\n.fa-soccer-ball-o:before,\n.fa-futbol-o:before {\n  content: \"\\f1e3\";\n}\n.fa-tty:before {\n  content: \"\\f1e4\";\n}\n.fa-binoculars:before {\n  content: \"\\f1e5\";\n}\n.fa-plug:before {\n  content: \"\\f1e6\";\n}\n.fa-slideshare:before {\n  content: \"\\f1e7\";\n}\n.fa-twitch:before {\n  content: \"\\f1e8\";\n}\n.fa-yelp:before {\n  content: \"\\f1e9\";\n}\n.fa-newspaper-o:before {\n  content: \"\\f1ea\";\n}\n.fa-wifi:before {\n  content: \"\\f1eb\";\n}\n.fa-calculator:before {\n  content: \"\\f1ec\";\n}\n.fa-paypal:before {\n  content: \"\\f1ed\";\n}\n.fa-google-wallet:before {\n  content: \"\\f1ee\";\n}\n.fa-cc-visa:before {\n  content: \"\\f1f0\";\n}\n.fa-cc-mastercard:before {\n  content: \"\\f1f1\";\n}\n.fa-cc-discover:before {\n  content: \"\\f1f2\";\n}\n.fa-cc-amex:before {\n  content: \"\\f1f3\";\n}\n.fa-cc-paypal:before {\n  content: \"\\f1f4\";\n}\n.fa-cc-stripe:before {\n  content: \"\\f1f5\";\n}\n.fa-bell-slash:before {\n  content: \"\\f1f6\";\n}\n.fa-bell-slash-o:before {\n  content: \"\\f1f7\";\n}\n.fa-trash:before {\n  content: \"\\f1f8\";\n}\n.fa-copyright:before {\n  content: \"\\f1f9\";\n}\n.fa-at:before {\n  content: \"\\f1fa\";\n}\n.fa-eyedropper:before {\n  content: \"\\f1fb\";\n}\n.fa-paint-brush:before {\n  content: \"\\f1fc\";\n}\n.fa-birthday-cake:before {\n  content: \"\\f1fd\";\n}\n.fa-area-chart:before {\n  content: \"\\f1fe\";\n}\n.fa-pie-chart:before {\n  content: \"\\f200\";\n}\n.fa-line-chart:before {\n  content: \"\\f201\";\n}\n.fa-lastfm:before {\n  content: \"\\f202\";\n}\n.fa-lastfm-square:before {\n  content: \"\\f203\";\n}\n.fa-toggle-off:before {\n  content: \"\\f204\";\n}\n.fa-toggle-on:before {\n  content: \"\\f205\";\n}\n.fa-bicycle:before {\n  content: \"\\f206\";\n}\n.fa-bus:before {\n  content: \"\\f207\";\n}\n.fa-ioxhost:before {\n  content: \"\\f208\";\n}\n.fa-angellist:before {\n  content: \"\\f209\";\n}\n.fa-cc:before {\n  content: \"\\f20a\";\n}\n.fa-shekel:before,\n.fa-sheqel:before,\n.fa-ils:before {\n  content: \"\\f20b\";\n}\n.fa-meanpath:before {\n  content: \"\\f20c\";\n}\n.fa-buysellads:before {\n  content: \"\\f20d\";\n}\n.fa-connectdevelop:before {\n  content: \"\\f20e\";\n}\n.fa-dashcube:before {\n  content: \"\\f210\";\n}\n.fa-forumbee:before {\n  content: \"\\f211\";\n}\n.fa-leanpub:before {\n  content: \"\\f212\";\n}\n.fa-sellsy:before {\n  content: \"\\f213\";\n}\n.fa-shirtsinbulk:before {\n  content: \"\\f214\";\n}\n.fa-simplybuilt:before {\n  content: \"\\f215\";\n}\n.fa-skyatlas:before {\n  content: \"\\f216\";\n}\n.fa-cart-plus:before {\n  content: \"\\f217\";\n}\n.fa-cart-arrow-down:before {\n  content: \"\\f218\";\n}\n.fa-diamond:before {\n  content: \"\\f219\";\n}\n.fa-ship:before {\n  content: \"\\f21a\";\n}\n.fa-user-secret:before {\n  content: \"\\f21b\";\n}\n.fa-motorcycle:before {\n  content: \"\\f21c\";\n}\n.fa-street-view:before {\n  content: \"\\f21d\";\n}\n.fa-heartbeat:before {\n  content: \"\\f21e\";\n}\n.fa-venus:before {\n  content: \"\\f221\";\n}\n.fa-mars:before {\n  content: \"\\f222\";\n}\n.fa-mercury:before {\n  content: \"\\f223\";\n}\n.fa-intersex:before,\n.fa-transgender:before {\n  content: \"\\f224\";\n}\n.fa-transgender-alt:before {\n  content: \"\\f225\";\n}\n.fa-venus-double:before {\n  content: \"\\f226\";\n}\n.fa-mars-double:before {\n  content: \"\\f227\";\n}\n.fa-venus-mars:before {\n  content: \"\\f228\";\n}\n.fa-mars-stroke:before {\n  content: \"\\f229\";\n}\n.fa-mars-stroke-v:before {\n  content: \"\\f22a\";\n}\n.fa-mars-stroke-h:before {\n  content: \"\\f22b\";\n}\n.fa-neuter:before {\n  content: \"\\f22c\";\n}\n.fa-genderless:before {\n  content: \"\\f22d\";\n}\n.fa-facebook-official:before {\n  content: \"\\f230\";\n}\n.fa-pinterest-p:before {\n  content: \"\\f231\";\n}\n.fa-whatsapp:before {\n  content: \"\\f232\";\n}\n.fa-server:before {\n  content: \"\\f233\";\n}\n.fa-user-plus:before {\n  content: \"\\f234\";\n}\n.fa-user-times:before {\n  content: \"\\f235\";\n}\n.fa-hotel:before,\n.fa-bed:before {\n  content: \"\\f236\";\n}\n.fa-viacoin:before {\n  content: \"\\f237\";\n}\n.fa-train:before {\n  content: \"\\f238\";\n}\n.fa-subway:before {\n  content: \"\\f239\";\n}\n.fa-medium:before {\n  content: \"\\f23a\";\n}\n.fa-yc:before,\n.fa-y-combinator:before {\n  content: \"\\f23b\";\n}\n.fa-optin-monster:before {\n  content: \"\\f23c\";\n}\n.fa-opencart:before {\n  content: \"\\f23d\";\n}\n.fa-expeditedssl:before {\n  content: \"\\f23e\";\n}\n.fa-battery-4:before,\n.fa-battery:before,\n.fa-battery-full:before {\n  content: \"\\f240\";\n}\n.fa-battery-3:before,\n.fa-battery-three-quarters:before {\n  content: \"\\f241\";\n}\n.fa-battery-2:before,\n.fa-battery-half:before {\n  content: \"\\f242\";\n}\n.fa-battery-1:before,\n.fa-battery-quarter:before {\n  content: \"\\f243\";\n}\n.fa-battery-0:before,\n.fa-battery-empty:before {\n  content: \"\\f244\";\n}\n.fa-mouse-pointer:before {\n  content: \"\\f245\";\n}\n.fa-i-cursor:before {\n  content: \"\\f246\";\n}\n.fa-object-group:before {\n  content: \"\\f247\";\n}\n.fa-object-ungroup:before {\n  content: \"\\f248\";\n}\n.fa-sticky-note:before {\n  content: \"\\f249\";\n}\n.fa-sticky-note-o:before {\n  content: \"\\f24a\";\n}\n.fa-cc-jcb:before {\n  content: \"\\f24b\";\n}\n.fa-cc-diners-club:before {\n  content: \"\\f24c\";\n}\n.fa-clone:before {\n  content: \"\\f24d\";\n}\n.fa-balance-scale:before {\n  content: \"\\f24e\";\n}\n.fa-hourglass-o:before {\n  content: \"\\f250\";\n}\n.fa-hourglass-1:before,\n.fa-hourglass-start:before {\n  content: \"\\f251\";\n}\n.fa-hourglass-2:before,\n.fa-hourglass-half:before {\n  content: \"\\f252\";\n}\n.fa-hourglass-3:before,\n.fa-hourglass-end:before {\n  content: \"\\f253\";\n}\n.fa-hourglass:before {\n  content: \"\\f254\";\n}\n.fa-hand-grab-o:before,\n.fa-hand-rock-o:before {\n  content: \"\\f255\";\n}\n.fa-hand-stop-o:before,\n.fa-hand-paper-o:before {\n  content: \"\\f256\";\n}\n.fa-hand-scissors-o:before {\n  content: \"\\f257\";\n}\n.fa-hand-lizard-o:before {\n  content: \"\\f258\";\n}\n.fa-hand-spock-o:before {\n  content: \"\\f259\";\n}\n.fa-hand-pointer-o:before {\n  content: \"\\f25a\";\n}\n.fa-hand-peace-o:before {\n  content: \"\\f25b\";\n}\n.fa-trademark:before {\n  content: \"\\f25c\";\n}\n.fa-registered:before {\n  content: \"\\f25d\";\n}\n.fa-creative-commons:before {\n  content: \"\\f25e\";\n}\n.fa-gg:before {\n  content: \"\\f260\";\n}\n.fa-gg-circle:before {\n  content: \"\\f261\";\n}\n.fa-tripadvisor:before {\n  content: \"\\f262\";\n}\n.fa-odnoklassniki:before {\n  content: \"\\f263\";\n}\n.fa-odnoklassniki-square:before {\n  content: \"\\f264\";\n}\n.fa-get-pocket:before {\n  content: \"\\f265\";\n}\n.fa-wikipedia-w:before {\n  content: \"\\f266\";\n}\n.fa-safari:before {\n  content: \"\\f267\";\n}\n.fa-chrome:before {\n  content: \"\\f268\";\n}\n.fa-firefox:before {\n  content: \"\\f269\";\n}\n.fa-opera:before {\n  content: \"\\f26a\";\n}\n.fa-internet-explorer:before {\n  content: \"\\f26b\";\n}\n.fa-tv:before,\n.fa-television:before {\n  content: \"\\f26c\";\n}\n.fa-contao:before {\n  content: \"\\f26d\";\n}\n.fa-500px:before {\n  content: \"\\f26e\";\n}\n.fa-amazon:before {\n  content: \"\\f270\";\n}\n.fa-calendar-plus-o:before {\n  content: \"\\f271\";\n}\n.fa-calendar-minus-o:before {\n  content: \"\\f272\";\n}\n.fa-calendar-times-o:before {\n  content: \"\\f273\";\n}\n.fa-calendar-check-o:before {\n  content: \"\\f274\";\n}\n.fa-industry:before {\n  content: \"\\f275\";\n}\n.fa-map-pin:before {\n  content: \"\\f276\";\n}\n.fa-map-signs:before {\n  content: \"\\f277\";\n}\n.fa-map-o:before {\n  content: \"\\f278\";\n}\n.fa-map:before {\n  content: \"\\f279\";\n}\n.fa-commenting:before {\n  content: \"\\f27a\";\n}\n.fa-commenting-o:before {\n  content: \"\\f27b\";\n}\n.fa-houzz:before {\n  content: \"\\f27c\";\n}\n.fa-vimeo:before {\n  content: \"\\f27d\";\n}\n.fa-black-tie:before {\n  content: \"\\f27e\";\n}\n.fa-fonticons:before {\n  content: \"\\f280\";\n}\n.fa-reddit-alien:before {\n  content: \"\\f281\";\n}\n.fa-edge:before {\n  content: \"\\f282\";\n}\n.fa-credit-card-alt:before {\n  content: \"\\f283\";\n}\n.fa-codiepie:before {\n  content: \"\\f284\";\n}\n.fa-modx:before {\n  content: \"\\f285\";\n}\n.fa-fort-awesome:before {\n  content: \"\\f286\";\n}\n.fa-usb:before {\n  content: \"\\f287\";\n}\n.fa-product-hunt:before {\n  content: \"\\f288\";\n}\n.fa-mixcloud:before {\n  content: \"\\f289\";\n}\n.fa-scribd:before {\n  content: \"\\f28a\";\n}\n.fa-pause-circle:before {\n  content: \"\\f28b\";\n}\n.fa-pause-circle-o:before {\n  content: \"\\f28c\";\n}\n.fa-stop-circle:before {\n  content: \"\\f28d\";\n}\n.fa-stop-circle-o:before {\n  content: \"\\f28e\";\n}\n.fa-shopping-bag:before {\n  content: \"\\f290\";\n}\n.fa-shopping-basket:before {\n  content: \"\\f291\";\n}\n.fa-hashtag:before {\n  content: \"\\f292\";\n}\n.fa-bluetooth:before {\n  content: \"\\f293\";\n}\n.fa-bluetooth-b:before {\n  content: \"\\f294\";\n}\n.fa-percent:before {\n  content: \"\\f295\";\n}\n.fa-gitlab:before {\n  content: \"\\f296\";\n}\n.fa-wpbeginner:before {\n  content: \"\\f297\";\n}\n.fa-wpforms:before {\n  content: \"\\f298\";\n}\n.fa-envira:before {\n  content: \"\\f299\";\n}\n.fa-universal-access:before {\n  content: \"\\f29a\";\n}\n.fa-wheelchair-alt:before {\n  content: \"\\f29b\";\n}\n.fa-question-circle-o:before {\n  content: \"\\f29c\";\n}\n.fa-blind:before {\n  content: \"\\f29d\";\n}\n.fa-audio-description:before {\n  content: \"\\f29e\";\n}\n.fa-volume-control-phone:before {\n  content: \"\\f2a0\";\n}\n.fa-braille:before {\n  content: \"\\f2a1\";\n}\n.fa-assistive-listening-systems:before {\n  content: \"\\f2a2\";\n}\n.fa-asl-interpreting:before,\n.fa-american-sign-language-interpreting:before {\n  content: \"\\f2a3\";\n}\n.fa-deafness:before,\n.fa-hard-of-hearing:before,\n.fa-deaf:before {\n  content: \"\\f2a4\";\n}\n.fa-glide:before {\n  content: \"\\f2a5\";\n}\n.fa-glide-g:before {\n  content: \"\\f2a6\";\n}\n.fa-signing:before,\n.fa-sign-language:before {\n  content: \"\\f2a7\";\n}\n.fa-low-vision:before {\n  content: \"\\f2a8\";\n}\n.fa-viadeo:before {\n  content: \"\\f2a9\";\n}\n.fa-viadeo-square:before {\n  content: \"\\f2aa\";\n}\n.fa-snapchat:before {\n  content: \"\\f2ab\";\n}\n.fa-snapchat-ghost:before {\n  content: \"\\f2ac\";\n}\n.fa-snapchat-square:before {\n  content: \"\\f2ad\";\n}\n.fa-pied-piper:before {\n  content: \"\\f2ae\";\n}\n.fa-first-order:before {\n  content: \"\\f2b0\";\n}\n.fa-yoast:before {\n  content: \"\\f2b1\";\n}\n.fa-themeisle:before {\n  content: \"\\f2b2\";\n}\n.fa-google-plus-circle:before,\n.fa-google-plus-official:before {\n  content: \"\\f2b3\";\n}\n.fa-fa:before,\n.fa-font-awesome:before {\n  content: \"\\f2b4\";\n}\n.fa-handshake-o:before {\n  content: \"\\f2b5\";\n}\n.fa-envelope-open:before {\n  content: \"\\f2b6\";\n}\n.fa-envelope-open-o:before {\n  content: \"\\f2b7\";\n}\n.fa-linode:before {\n  content: \"\\f2b8\";\n}\n.fa-address-book:before {\n  content: \"\\f2b9\";\n}\n.fa-address-book-o:before {\n  content: \"\\f2ba\";\n}\n.fa-vcard:before,\n.fa-address-card:before {\n  content: \"\\f2bb\";\n}\n.fa-vcard-o:before,\n.fa-address-card-o:before {\n  content: \"\\f2bc\";\n}\n.fa-user-circle:before {\n  content: \"\\f2bd\";\n}\n.fa-user-circle-o:before {\n  content: \"\\f2be\";\n}\n.fa-user-o:before {\n  content: \"\\f2c0\";\n}\n.fa-id-badge:before {\n  content: \"\\f2c1\";\n}\n.fa-drivers-license:before,\n.fa-id-card:before {\n  content: \"\\f2c2\";\n}\n.fa-drivers-license-o:before,\n.fa-id-card-o:before {\n  content: \"\\f2c3\";\n}\n.fa-quora:before {\n  content: \"\\f2c4\";\n}\n.fa-free-code-camp:before {\n  content: \"\\f2c5\";\n}\n.fa-telegram:before {\n  content: \"\\f2c6\";\n}\n.fa-thermometer-4:before,\n.fa-thermometer:before,\n.fa-thermometer-full:before {\n  content: \"\\f2c7\";\n}\n.fa-thermometer-3:before,\n.fa-thermometer-three-quarters:before {\n  content: \"\\f2c8\";\n}\n.fa-thermometer-2:before,\n.fa-thermometer-half:before {\n  content: \"\\f2c9\";\n}\n.fa-thermometer-1:before,\n.fa-thermometer-quarter:before {\n  content: \"\\f2ca\";\n}\n.fa-thermometer-0:before,\n.fa-thermometer-empty:before {\n  content: \"\\f2cb\";\n}\n.fa-shower:before {\n  content: \"\\f2cc\";\n}\n.fa-bathtub:before,\n.fa-s15:before,\n.fa-bath:before {\n  content: \"\\f2cd\";\n}\n.fa-podcast:before {\n  content: \"\\f2ce\";\n}\n.fa-window-maximize:before {\n  content: \"\\f2d0\";\n}\n.fa-window-minimize:before {\n  content: \"\\f2d1\";\n}\n.fa-window-restore:before {\n  content: \"\\f2d2\";\n}\n.fa-times-rectangle:before,\n.fa-window-close:before {\n  content: \"\\f2d3\";\n}\n.fa-times-rectangle-o:before,\n.fa-window-close-o:before {\n  content: \"\\f2d4\";\n}\n.fa-bandcamp:before {\n  content: \"\\f2d5\";\n}\n.fa-grav:before {\n  content: \"\\f2d6\";\n}\n.fa-etsy:before {\n  content: \"\\f2d7\";\n}\n.fa-imdb:before {\n  content: \"\\f2d8\";\n}\n.fa-ravelry:before {\n  content: \"\\f2d9\";\n}\n.fa-eercast:before {\n  content: \"\\f2da\";\n}\n.fa-microchip:before {\n  content: \"\\f2db\";\n}\n.fa-snowflake-o:before {\n  content: \"\\f2dc\";\n}\n.fa-superpowers:before {\n  content: \"\\f2dd\";\n}\n.fa-wpexplorer:before {\n  content: \"\\f2de\";\n}\n.fa-meetup:before {\n  content: \"\\f2e0\";\n}\n.sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  margin: -1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  border: 0;\n}\n.sr-only-focusable:active,\n.sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n"
  },
  {
    "path": "source/lib/jquery/.bower.json",
    "content": "{\n  \"name\": \"jquery\",\n  \"_cacheHeaders\": {\n    \"ETag\": \"\\\"5492efef-14960\\\"\",\n    \"Last-Modified\": \"Thu, 18 Dec 2014 15:17:03 GMT\",\n    \"Content-Length\": \"84320\",\n    \"Content-Type\": \"application/x-javascript\"\n  },\n  \"_release\": \"e-tag:5492efef-\",\n  \"main\": \"index.js\",\n  \"_source\": \"http://code.jquery.com/jquery-2.1.3.min.js\",\n  \"_target\": \"*\",\n  \"_originalSource\": \"http://code.jquery.com/jquery-2.1.3.min.js\",\n  \"_direct\": true\n}"
  },
  {
    "path": "source/lib/jquery/index.js",
    "content": "/*! jQuery v2.1.3 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */\n!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={},l=a.document,m=\"2.1.3\",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!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(n.isPlainObject(d)||(e=n.isArray(d)))?(e?(e=!1,f=c&&n.isArray(c)?c:[]):f=c&&n.isPlainObject(c)?c:{},g[b]=n.extend(j,f,d)):void 0!==d&&(g[b]=d));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,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){return!n.isArray(a)&&a-parseFloat(a)+1>=0},isPlainObject:function(a){return\"object\"!==n.type(a)||a.nodeType||n.isWindow(a)?!1:a.constructor&&!j.call(a.constructor.prototype,\"isPrototypeOf\")?!1:!0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+\"\":\"object\"==typeof a||\"function\"==typeof a?h[i.call(a)]||\"object\":typeof a},globalEval:function(a){var b,c=eval;a=n.trim(a),a&&(1===a.indexOf(\"use strict\")?(b=l.createElement(\"script\"),b.text=a,l.head.appendChild(b).parentNode.removeChild(b)):c(a))},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: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){return null==b?-1:g.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;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&&(c=a[b],b=a,a=c),n.isFunction(a)?(e=d.call(arguments,2),f=function(){return a.apply(b||this,e.concat(d.call(arguments)))},f.guid=a.guid=a.guid||n.guid++,f):void 0},now:Date.now,support:k}),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,t,u=\"sizzle\"+1*new Date,v=a.document,w=0,x=0,y=hb(),z=hb(),A=hb(),B=function(a,b){return a===b&&(l=!0),0},C=1<<31,D={}.hasOwnProperty,E=[],F=E.pop,G=E.push,H=E.push,I=E.slice,J=function(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return c;return-1},K=\"checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped\",L=\"[\\\\x20\\\\t\\\\r\\\\n\\\\f]\",M=\"(?:\\\\\\\\.|[\\\\w-]|[^\\\\x00-\\\\xa0])+\",N=M.replace(\"w\",\"w#\"),O=\"\\\\[\"+L+\"*(\"+M+\")(?:\"+L+\"*([*^$|!~]?=)\"+L+\"*(?:'((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\"|(\"+N+\"))|)\"+L+\"*\\\\]\",P=\":(\"+M+\")(?:\\\\((('((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\")|((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|\"+O+\")*)|.*)\\\\)|)\",Q=new RegExp(L+\"+\",\"g\"),R=new RegExp(\"^\"+L+\"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)\"+L+\"+$\",\"g\"),S=new RegExp(\"^\"+L+\"*,\"+L+\"*\"),T=new RegExp(\"^\"+L+\"*([>+~]|\"+L+\")\"+L+\"*\"),U=new RegExp(\"=\"+L+\"*([^\\\\]'\\\"]*?)\"+L+\"*\\\\]\",\"g\"),V=new RegExp(P),W=new RegExp(\"^\"+N+\"$\"),X={ID:new RegExp(\"^#(\"+M+\")\"),CLASS:new RegExp(\"^\\\\.(\"+M+\")\"),TAG:new RegExp(\"^(\"+M.replace(\"w\",\"w*\")+\")\"),ATTR:new RegExp(\"^\"+O),PSEUDO:new RegExp(\"^\"+P),CHILD:new RegExp(\"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(\"+L+\"*(even|odd|(([+-]|)(\\\\d*)n|)\"+L+\"*(?:([+-]|)\"+L+\"*(\\\\d+)|))\"+L+\"*\\\\)|)\",\"i\"),bool:new RegExp(\"^(?:\"+K+\")$\",\"i\"),needsContext:new RegExp(\"^\"+L+\"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\"+L+\"*((?:-\\\\d)?\\\\d*)\"+L+\"*\\\\)|)(?=[^-]|$)\",\"i\")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\\d$/i,$=/^[^{]+\\{\\s*\\[native \\w/,_=/^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,ab=/[+~]/,bb=/'|\\\\/g,cb=new RegExp(\"\\\\\\\\([\\\\da-f]{1,6}\"+L+\"?|(\"+L+\")|.)\",\"ig\"),db=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)},eb=function(){m()};try{H.apply(E=I.call(v.childNodes),v.childNodes),E[v.childNodes.length].nodeType}catch(fb){H={apply:E.length?function(a,b){G.apply(a,I.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function gb(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],k=b.nodeType,\"string\"!=typeof a||!a||1!==k&&9!==k&&11!==k)return d;if(!e&&p){if(11!==k&&(f=_.exec(a)))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return H.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName)return H.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=1!==k&&a,1===k&&\"object\"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute(\"id\"))?s=r.replace(bb,\"\\\\$&\"):b.setAttribute(\"id\",s),s=\"[id='\"+s+\"'] \",l=o.length;while(l--)o[l]=s+rb(o[l]);w=ab.test(a)&&pb(b.parentNode)||b,x=o.join(\",\")}if(x)try{return H.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute(\"id\")}}}return i(a.replace(R,\"$1\"),b,d,e)}function hb(){var a=[];function b(c,e){return a.push(c+\" \")>d.cacheLength&&delete b[a.shift()],b[c+\" \"]=e}return b}function ib(a){return a[u]=!0,a}function jb(a){var b=n.createElement(\"div\");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function kb(a,b){var c=a.split(\"|\"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function lb(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||C)-(~a.sourceIndex||C);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function mb(a){return function(b){var c=b.nodeName.toLowerCase();return\"input\"===c&&b.type===a}}function nb(a){return function(b){var c=b.nodeName.toLowerCase();return(\"input\"===c||\"button\"===c)&&b.type===a}}function ob(a){return ib(function(b){return b=+b,ib(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 pb(a){return a&&\"undefined\"!=typeof a.getElementsByTagName&&a}c=gb.support={},f=gb.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?\"HTML\"!==b.nodeName:!1},m=gb.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=g.documentElement,e=g.defaultView,e&&e!==e.top&&(e.addEventListener?e.addEventListener(\"unload\",eb,!1):e.attachEvent&&e.attachEvent(\"onunload\",eb)),p=!f(g),c.attributes=jb(function(a){return a.className=\"i\",!a.getAttribute(\"className\")}),c.getElementsByTagName=jb(function(a){return a.appendChild(g.createComment(\"\")),!a.getElementsByTagName(\"*\").length}),c.getElementsByClassName=$.test(g.getElementsByClassName),c.getById=jb(function(a){return o.appendChild(a).id=u,!g.getElementsByName||!g.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if(\"undefined\"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){return a.getAttribute(\"id\")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){var c=\"undefined\"!=typeof a.getAttributeNode&&a.getAttributeNode(\"id\");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return\"undefined\"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(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 p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(g.querySelectorAll))&&(jb(function(a){o.appendChild(a).innerHTML=\"<a id='\"+u+\"'></a><select id='\"+u+\"-\\f]' msallowcapture=''><option selected=''></option></select>\",a.querySelectorAll(\"[msallowcapture^='']\").length&&q.push(\"[*^$]=\"+L+\"*(?:''|\\\"\\\")\"),a.querySelectorAll(\"[selected]\").length||q.push(\"\\\\[\"+L+\"*(?:value|\"+K+\")\"),a.querySelectorAll(\"[id~=\"+u+\"-]\").length||q.push(\"~=\"),a.querySelectorAll(\":checked\").length||q.push(\":checked\"),a.querySelectorAll(\"a#\"+u+\"+*\").length||q.push(\".#.+[+~]\")}),jb(function(a){var b=g.createElement(\"input\");b.setAttribute(\"type\",\"hidden\"),a.appendChild(b).setAttribute(\"name\",\"D\"),a.querySelectorAll(\"[name=d]\").length&&q.push(\"name\"+L+\"*[*^$|!~]?=\"),a.querySelectorAll(\":enabled\").length||q.push(\":enabled\",\":disabled\"),a.querySelectorAll(\"*,:x\"),q.push(\",.*:\")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&jb(function(a){c.disconnectedMatch=s.call(a,\"div\"),s.call(a,\"[s!='']:x\"),r.push(\"!=\",P)}),q=q.length&&new RegExp(q.join(\"|\")),r=r.length&&new RegExp(r.join(\"|\")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.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},B=b?function(a,b){if(a===b)return l=!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===g||a.ownerDocument===v&&t(v,a)?-1:b===g||b.ownerDocument===v&&t(v,b)?1:k?J(k,a)-J(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,h=[a],i=[b];if(!e||!f)return a===g?-1:b===g?1:e?-1:f?1:k?J(k,a)-J(k,b):0;if(e===f)return lb(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);while(h[d]===i[d])d++;return d?lb(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},g):n},gb.matches=function(a,b){return gb(a,null,null,b)},gb.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,\"='$1']\"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return gb(b,n,null,[a]).length>0},gb.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},gb.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&D.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},gb.error=function(a){throw new Error(\"Syntax error, unrecognized expression: \"+a)},gb.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=gb.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=gb.selectors={cacheLength:50,createPseudo:ib,match:X,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(cb,db),a[3]=(a[3]||a[4]||a[5]||\"\").replace(cb,db),\"~=\"===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]||gb.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]&&gb.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||\"\":c&&V.test(c)&&(b=g(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(cb,db).toLowerCase();return\"*\"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+\" \"];return b||(b=new RegExp(\"(^|\"+L+\")\"+a+\"(\"+L+\"|$)\"))&&y(a,function(a){return b.test(\"string\"==typeof a.className&&a.className||\"undefined\"!=typeof a.getAttribute&&a.getAttribute(\"class\")||\"\")})},ATTR:function(a,b,c){return function(d){var e=gb.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.replace(Q,\" \")+\" \").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(),s=!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&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&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]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)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&&(s&&((l[u]||(l[u]={}))[a]=[w,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()]||gb.error(\"unsupported pseudo: \"+a);return e[u]?e(b):e.length>1?(c=[a,a,\"\",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ib(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=J(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ib(function(a){var b=[],c=[],d=h(a.replace(R,\"$1\"));return d[u]?ib(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),b[0]=null,!c.pop()}}),has:ib(function(a){return function(b){return gb(a,b).length>0}}),contains:ib(function(a){return a=a.replace(cb,db),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ib(function(a){return W.test(a||\"\")||gb.error(\"unsupported lang: \"+a),a=a.replace(cb,db).toLowerCase(),function(b){var c;do if(c=p?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===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.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 Z.test(a.nodeName)},input:function(a){return Y.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:ob(function(){return[0]}),last:ob(function(a,b){return[b-1]}),eq:ob(function(a,b,c){return[0>c?c+b:c]}),even:ob(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:ob(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:ob(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:ob(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]=mb(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=nb(b);function qb(){}qb.prototype=d.filters=d.pseudos,d.setFilters=new qb,g=gb.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+\" \"];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R,\" \")}),h=h.slice(c.length));for(g in d.filter)!(e=X[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?gb.error(a):z(a,i).slice(0)};function rb(a){for(var b=0,c=a.length,d=\"\";c>b;b++)d+=a[b].value;return d}function sb(a,b,c){var d=b.dir,e=c&&\"parentNode\"===d,f=x++;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=[w,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[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function tb(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 ub(a,b,c){for(var d=0,e=b.length;e>d;d++)gb(a,b[d],c);return c}function vb(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 wb(a,b,c,d,e,f){return d&&!d[u]&&(d=wb(d)),e&&!e[u]&&(e=wb(e,f)),ib(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||ub(b||\"*\",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:vb(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=vb(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?J(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=vb(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):H.apply(g,r)})}function xb(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[\" \"],i=g?1:0,k=sb(function(a){return a===b},h,!0),l=sb(function(a){return J(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];f>i;i++)if(c=d.relative[a[i].type])m=[sb(tb(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return wb(i>1&&tb(m),i>1&&rb(a.slice(0,i-1).concat({value:\" \"===a[i-2].type?\"*\":\"\"})).replace(R,\"$1\"),c,e>i&&xb(a.slice(i,e)),f>e&&xb(a=a.slice(e)),f>e&&rb(a))}m.push(c)}return tb(m)}function yb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q=\"0\",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG(\"*\",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=F.call(i));s=vb(s)}H.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&gb.uniqueSort(i)}return k&&(w=v,j=t),r};return c?ib(f):f}return h=gb.compile=function(a,b){var c,d=[],e=[],f=A[a+\" \"];if(!f){b||(b=g(a)),c=b.length;while(c--)f=xb(b[c]),f[u]?d.push(f):e.push(f);f=A(a,yb(e,d)),f.selector=a}return f},i=gb.select=function(a,b,e,f){var i,j,k,l,m,n=\"function\"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&\"ID\"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(cb,db),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(cb,db),ab.test(j[0].type)&&pb(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&rb(j),!a)return H.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,ab.test(a)&&pb(b.parentNode)||b),e},c.sortStable=u.split(\"\").sort(B).join(\"\")===u,c.detectDuplicates=!!l,m(),c.sortDetached=jb(function(a){return 1&a.compareDocumentPosition(n.createElement(\"div\"))}),jb(function(a){return a.innerHTML=\"<a href='#'></a>\",\"#\"===a.firstChild.getAttribute(\"href\")})||kb(\"type|href|height|width\",function(a,b,c){return c?void 0:a.getAttribute(b,\"type\"===b.toLowerCase()?1:2)}),c.attributes&&jb(function(a){return a.innerHTML=\"<input/>\",a.firstChild.setAttribute(\"value\",\"\"),\"\"===a.firstChild.getAttribute(\"value\")})||kb(\"value\",function(a,b,c){return c||\"input\"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),jb(function(a){return null==a.getAttribute(\"disabled\")})||kb(K,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),gb}(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 g.call(b,a)>=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=this.length,d=[],e=this;if(\"string\"!=typeof a)return this.pushStack(n(a).filter(function(){for(b=0;c>b;b++)if(n.contains(e[b],this))return!0}));for(b=0;c>b;b++)n.find(a,e[b],d);return d=this.pushStack(c>1?n.unique(d):d),d.selector=this.selector?this.selector+\" \"+a:a,d},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=/^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,A=n.fn.init=function(a,b){var c,d;if(!a)return this;if(\"string\"==typeof a){if(c=\"<\"===a[0]&&\">\"===a[a.length-1]&&a.length>=3?[null,a,null]:z.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:l,!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}return d=l.getElementById(c[2]),d&&d.parentNode&&(this.length=1,this[0]=d),this.context=l,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))};A.prototype=n.fn,y=n(l);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};n.extend({dir:function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&n(a).is(c))break;d.push(a)}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=n(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(n.contains(this,b[a]))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?g.call(n(a),this[0]):g.call(this,a.jquery?a[0]:a):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 D(a,b){while((a=a[b])&&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 D(a,\"nextSibling\")},prev:function(a){return D(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 a.contentDocument||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&&(C[a]||n.unique(e),B.test(a)&&e.reverse()),this.pushStack(e)}});var E=/\\S+/g,F={};function G(a){var b=F[a]={};return n.each(a.match(E)||[],function(a,c){b[c]=!0}),b}n.Callbacks=function(a){a=\"string\"==typeof a?F[a]||G(a):n.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(b=a.memory&&l,c=!0,g=e||0,e=0,f=h.length,d=!0;h&&f>g;g++)if(h[g].apply(l[0],l[1])===!1&&a.stopOnFalse){b=!1;break}d=!1,h&&(i?i.length&&j(i.shift()):b?h=[]:k.disable())},k={add:function(){if(h){var c=h.length;!function g(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&&g(c)})}(arguments),d?f=h.length:b&&(e=c,j(b))}return this},remove:function(){return h&&n.each(arguments,function(a,b){var c;while((c=n.inArray(b,h,c))>-1)h.splice(c,1),d&&(f>=c&&f--,g>=c&&g--)}),this},has:function(a){return a?n.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],f=0,this},disable:function(){return h=i=b=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,b||k.disable(),this},locked:function(){return!i},fireWith:function(a,b){return!h||c&&!i||(b=b||[],b=[a,b.slice?b.slice():b],d?i.push(b):j(b)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!c}};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 H;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){(a===!0?--n.readyWait:n.isReady)||(n.isReady=!0,a!==!0&&--n.readyWait>0||(H.resolveWith(l,[n]),n.fn.triggerHandler&&(n(l).triggerHandler(\"ready\"),n(l).off(\"ready\"))))}});function I(){l.removeEventListener(\"DOMContentLoaded\",I,!1),a.removeEventListener(\"load\",I,!1),n.ready()}n.ready.promise=function(b){return H||(H=n.Deferred(),\"complete\"===l.readyState?setTimeout(n.ready):(l.addEventListener(\"DOMContentLoaded\",I,!1),a.addEventListener(\"load\",I,!1))),H.promise(b)},n.ready.promise();var J=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};n.acceptData=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function K(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=n.expando+K.uid++}K.uid=1,K.accepts=n.acceptData,K.prototype={key:function(a){if(!K.accepts(a))return 0;var b={},c=a[this.expando];if(!c){c=K.uid++;try{b[this.expando]={value:c},Object.defineProperties(a,b)}catch(d){b[this.expando]=c,n.extend(a,b)}}return this.cache[c]||(this.cache[c]={}),c},set:function(a,b,c){var d,e=this.key(a),f=this.cache[e];if(\"string\"==typeof b)f[b]=c;else if(n.isEmptyObject(f))n.extend(this.cache[e],b);else for(d in b)f[d]=b[d];return f},get:function(a,b){var c=this.cache[this.key(a)];return void 0===b?c:c[b]},access:function(a,b,c){var d;return void 0===b||b&&\"string\"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,n.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=this.key(a),g=this.cache[f];if(void 0===b)this.cache[f]={};else{n.isArray(b)?d=b.concat(b.map(n.camelCase)):(e=n.camelCase(b),b in g?d=[b,e]:(d=e,d=d in g?[d]:d.match(E)||[])),c=d.length;while(c--)delete g[d[c]]}},hasData:function(a){return!n.isEmptyObject(this.cache[a[this.expando]]||{})},discard:function(a){a[this.expando]&&delete this.cache[a[this.expando]]}};var L=new K,M=new K,N=/^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,O=/([A-Z])/g;function P(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d=\"data-\"+b.replace(O,\"-$1\").toLowerCase(),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){}M.set(a,b,c)}else c=void 0;return c}n.extend({hasData:function(a){return M.hasData(a)||L.hasData(a)},data:function(a,b,c){return M.access(a,b,c)\n},removeData:function(a,b){M.remove(a,b)},_data:function(a,b,c){return L.access(a,b,c)},_removeData:function(a,b){L.remove(a,b)}}),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=M.get(f),1===f.nodeType&&!L.get(f,\"hasDataAttrs\"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf(\"data-\")&&(d=n.camelCase(d.slice(5)),P(f,d,e[d])));L.set(f,\"hasDataAttrs\",!0)}return e}return\"object\"==typeof a?this.each(function(){M.set(this,a)}):J(this,function(b){var c,d=n.camelCase(a);if(f&&void 0===b){if(c=M.get(f,a),void 0!==c)return c;if(c=M.get(f,d),void 0!==c)return c;if(c=P(f,d,void 0),void 0!==c)return c}else this.each(function(){var c=M.get(this,d);M.set(this,d,b),-1!==a.indexOf(\"-\")&&void 0!==c&&M.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){M.remove(this,a)})}}),n.extend({queue:function(a,b,c){var d;return a?(b=(b||\"fx\")+\"queue\",d=L.get(a,b),c&&(!d||n.isArray(c)?d=L.access(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 L.get(a,c)||L.access(a,c,{empty:n.Callbacks(\"once memory\").add(function(){L.remove(a,[b+\"queue\",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=L.get(f[g],a+\"queueHooks\"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var Q=/[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/.source,R=[\"Top\",\"Right\",\"Bottom\",\"Left\"],S=function(a,b){return a=b||a,\"none\"===n.css(a,\"display\")||!n.contains(a.ownerDocument,a)},T=/^(?:checkbox|radio)$/i;!function(){var a=l.createDocumentFragment(),b=a.appendChild(l.createElement(\"div\")),c=l.createElement(\"input\");c.setAttribute(\"type\",\"radio\"),c.setAttribute(\"checked\",\"checked\"),c.setAttribute(\"name\",\"t\"),b.appendChild(c),k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML=\"<textarea>x</textarea>\",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var U=\"undefined\";k.focusinBubbles=\"onfocusin\"in a;var V=/^key/,W=/^(?:mouse|pointer|contextmenu)|click/,X=/^(?:focusinfocus|focusoutblur)$/,Y=/^([^.]*)(?:\\.(.+)|)$/;function Z(){return!0}function $(){return!1}function _(){try{return l.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=L.get(a);if(r){c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=n.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return typeof n!==U&&n.event.triggered!==b.type?n.event.dispatch.apply(a,arguments):void 0}),b=(b||\"\").match(E)||[\"\"],j=b.length;while(j--)h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||\"\").split(\".\").sort(),o&&(l=n.event.special[o]||{},o=(e?l.delegateType:l.bindType)||o,l=n.event.special[o]||{},k=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(\".\")},f),(m=i[o])||(m=i[o]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(o,g,!1)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),n.event.global[o]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.hasData(a)&&L.get(a);if(r&&(i=r.events)){b=(b||\"\").match(E)||[\"\"],j=b.length;while(j--)if(h=Y.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=i[o]||[],h=h[2]&&new RegExp(\"(^|\\\\.)\"+p.join(\"\\\\.(?:.*\\\\.|)\")+\"(\\\\.|$)\"),g=f=m.length;while(f--)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&(\"**\"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||n.removeEvent(a,o,r.handle),delete i[o])}else for(o in i)n.event.remove(a,o+b[j],c,d,!0);n.isEmptyObject(i)&&(delete r.handle,L.remove(a,\"events\"))}},trigger:function(b,c,d,e){var f,g,h,i,k,m,o,p=[d||l],q=j.call(b,\"type\")?b.type:b,r=j.call(b,\"namespace\")?b.namespace.split(\".\"):[];if(g=h=d=d||l,3!==d.nodeType&&8!==d.nodeType&&!X.test(q+n.event.triggered)&&(q.indexOf(\".\")>=0&&(r=q.split(\".\"),q=r.shift(),r.sort()),k=q.indexOf(\":\")<0&&\"on\"+q,b=b[n.expando]?b:new n.Event(q,\"object\"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=r.join(\".\"),b.namespace_re=b.namespace?new RegExp(\"(^|\\\\.)\"+r.join(\"\\\\.(?:.*\\\\.|)\")+\"(\\\\.|$)\"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:n.makeArray(c,[b]),o=n.event.special[q]||{},e||!o.trigger||o.trigger.apply(d,c)!==!1)){if(!e&&!o.noBubble&&!n.isWindow(d)){for(i=o.delegateType||q,X.test(i+q)||(g=g.parentNode);g;g=g.parentNode)p.push(g),h=g;h===(d.ownerDocument||l)&&p.push(h.defaultView||h.parentWindow||a)}f=0;while((g=p[f++])&&!b.isPropagationStopped())b.type=f>1?i:o.bindType||q,m=(L.get(g,\"events\")||{})[b.type]&&L.get(g,\"handle\"),m&&m.apply(g,c),m=k&&g[k],m&&m.apply&&n.acceptData(g)&&(b.result=m.apply(g,c),b.result===!1&&b.preventDefault());return b.type=q,e||b.isDefaultPrevented()||o._default&&o._default.apply(p.pop(),c)!==!1||!n.acceptData(d)||k&&n.isFunction(d[q])&&!n.isWindow(d)&&(h=d[k],h&&(d[k]=null),n.event.triggered=q,d[q](),n.event.triggered=void 0,h&&(d[k]=h)),b.result}},dispatch:function(a){a=n.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(L.get(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,c=0;while((g=f.handlers[c++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(g.namespace))&&(a.handleObj=g,a.data=g.data,e=((n.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==e&&(a.result=e)===!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(i.disabled!==!0||\"click\"!==a.type){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+\" \",void 0===d[e]&&(d[e]=f.needsContext?n(e,this).index(i)>=0:n.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},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 offsetX offsetY pageX pageY screenX screenY toElement\".split(\" \"),filter:function(a,b){var c,d,e,f=b.button;return null==a.pageX&&null!=b.clientX&&(c=a.target.ownerDocument||l,d=c.documentElement,e=c.body,a.pageX=b.clientX+(d&&d.scrollLeft||e&&e.scrollLeft||0)-(d&&d.clientLeft||e&&e.clientLeft||0),a.pageY=b.clientY+(d&&d.scrollTop||e&&e.scrollTop||0)-(d&&d.clientTop||e&&e.clientTop||0)),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},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=W.test(e)?this.mouseHooks:V.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=l),3===a.target.nodeType&&(a.target=a.target.parentNode),g.filter?g.filter(a,f):a},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==_()&&this.focus?(this.focus(),!1):void 0},delegateType:\"focusin\"},blur:{trigger:function(){return this===_()&&this.blur?(this.blur(),!1):void 0},delegateType:\"focusout\"},click:{trigger:function(){return\"checkbox\"===this.type&&this.click&&n.nodeName(this,\"input\")?(this.click(),!1):void 0},_default:function(a){return n.nodeName(a.target,\"a\")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(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=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)},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?Z:$):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:$,isPropagationStopped:$,isImmediatePropagationStopped:$,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=Z,a&&a.preventDefault&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=Z,a&&a.stopPropagation&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=Z,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},n.each({mouseenter:\"mouseover\",mouseleave:\"mouseout\",pointerenter:\"pointerover\",pointerleave:\"pointerout\"},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}}}),k.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=L.access(d,b);e||d.addEventListener(a,c,!0),L.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=L.access(d,b)-1;e?L.access(d,b,e):(d.removeEventListener(a,c,!0),L.remove(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(g in a)this.on(g,b,c,a[g],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=$;else if(!d)return this;return 1===e&&(f=d,d=function(a){return n().off(a),f.apply(this,arguments)},d.guid=f.guid||(f.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=$),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}});var ab=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\\w:]+)[^>]*)\\/>/gi,bb=/<([\\w:]+)/,cb=/<|&#?\\w+;/,db=/<(?:script|style|link)/i,eb=/checked\\s*(?:[^=]|=\\s*.checked.)/i,fb=/^$|\\/(?:java|ecma)script/i,gb=/^true\\/(.*)/,hb=/^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,ib={option:[1,\"<select multiple='multiple'>\",\"</select>\"],thead:[1,\"<table>\",\"</table>\"],col:[2,\"<table><colgroup>\",\"</colgroup></table>\"],tr:[2,\"<table><tbody>\",\"</tbody></table>\"],td:[3,\"<table><tbody><tr>\",\"</tr></tbody></table>\"],_default:[0,\"\",\"\"]};ib.optgroup=ib.option,ib.tbody=ib.tfoot=ib.colgroup=ib.caption=ib.thead,ib.th=ib.td;function jb(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 kb(a){return a.type=(null!==a.getAttribute(\"type\"))+\"/\"+a.type,a}function lb(a){var b=gb.exec(a.type);return b?a.type=b[1]:a.removeAttribute(\"type\"),a}function mb(a,b){for(var c=0,d=a.length;d>c;c++)L.set(a[c],\"globalEval\",!b||L.get(b[c],\"globalEval\"))}function nb(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(L.hasData(a)&&(f=L.access(a),g=L.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)n.event.add(b,e,j[e][c])}M.hasData(a)&&(h=M.access(a),i=n.extend({},h),M.set(b,i))}}function ob(a,b){var c=a.getElementsByTagName?a.getElementsByTagName(b||\"*\"):a.querySelectorAll?a.querySelectorAll(b||\"*\"):[];return void 0===b||b&&n.nodeName(a,b)?n.merge([a],c):c}function pb(a,b){var c=b.nodeName.toLowerCase();\"input\"===c&&T.test(a.type)?b.checked=a.checked:(\"input\"===c||\"textarea\"===c)&&(b.defaultValue=a.defaultValue)}n.extend({clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=n.contains(a.ownerDocument,a);if(!(k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||n.isXMLDoc(a)))for(g=ob(h),f=ob(a),d=0,e=f.length;e>d;d++)pb(f[d],g[d]);if(b)if(c)for(f=f||ob(a),g=g||ob(h),d=0,e=f.length;e>d;d++)nb(f[d],g[d]);else nb(a,h);return g=ob(h,\"script\"),g.length>0&&mb(g,!i&&ob(a,\"script\")),h},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,k=b.createDocumentFragment(),l=[],m=0,o=a.length;o>m;m++)if(e=a[m],e||0===e)if(\"object\"===n.type(e))n.merge(l,e.nodeType?[e]:e);else if(cb.test(e)){f=f||k.appendChild(b.createElement(\"div\")),g=(bb.exec(e)||[\"\",\"\"])[1].toLowerCase(),h=ib[g]||ib._default,f.innerHTML=h[1]+e.replace(ab,\"<$1></$2>\")+h[2],j=h[0];while(j--)f=f.lastChild;n.merge(l,f.childNodes),f=k.firstChild,f.textContent=\"\"}else l.push(b.createTextNode(e));k.textContent=\"\",m=0;while(e=l[m++])if((!d||-1===n.inArray(e,d))&&(i=n.contains(e.ownerDocument,e),f=ob(k.appendChild(e),\"script\"),i&&mb(f),c)){j=0;while(e=f[j++])fb.test(e.type||\"\")&&c.push(e)}return k},cleanData:function(a){for(var b,c,d,e,f=n.event.special,g=0;void 0!==(c=a[g]);g++){if(n.acceptData(c)&&(e=c[L.expando],e&&(b=L.cache[e]))){if(b.events)for(d in b.events)f[d]?n.event.remove(c,d):n.removeEvent(c,d,b.handle);L.cache[e]&&delete L.cache[e]}delete M.cache[c[M.expando]]}}}),n.fn.extend({text:function(a){return J(this,function(a){return void 0===a?n.text(this):this.empty().each(function(){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&(this.textContent=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=jb(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=jb(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(ob(c)),c.parentNode&&(b&&n.contains(c.ownerDocument,c)&&mb(ob(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(ob(a,!1)),a.textContent=\"\");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 J(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if(\"string\"==typeof a&&!db.test(a)&&!ib[(bb.exec(a)||[\"\",\"\"])[1].toLowerCase()]){a=a.replace(ab,\"<$1></$2>\");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(n.cleanData(ob(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(ob(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,l=this.length,m=this,o=l-1,p=a[0],q=n.isFunction(p);if(q||l>1&&\"string\"==typeof p&&!k.checkClone&&eb.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(l&&(c=n.buildFragment(a,this[0].ownerDocument,!1,this),d=c.firstChild,1===c.childNodes.length&&(c=d),d)){for(f=n.map(ob(c,\"script\"),kb),g=f.length;l>j;j++)h=c,j!==o&&(h=n.clone(h,!0,!0),g&&n.merge(f,ob(h,\"script\"))),b.call(this[j],h,j);if(g)for(i=f[f.length-1].ownerDocument,n.map(f,lb),j=0;g>j;j++)h=f[j],fb.test(h.type||\"\")&&!L.access(h,\"globalEval\")&&n.contains(i,h)&&(h.src?n._evalUrl&&n._evalUrl(h.src):n.globalEval(h.textContent.replace(hb,\"\")))}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=[],e=n(a),g=e.length-1,h=0;g>=h;h++)c=h===g?this:this.clone(!0),n(e[h])[b](c),f.apply(d,c.get());return this.pushStack(d)}});var qb,rb={};function sb(b,c){var d,e=n(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:n.css(e[0],\"display\");return e.detach(),f}function tb(a){var b=l,c=rb[a];return c||(c=sb(a,b),\"none\"!==c&&c||(qb=(qb||n(\"<iframe frameborder='0' width='0' height='0'/>\")).appendTo(b.documentElement),b=qb[0].contentDocument,b.write(),b.close(),c=sb(a,b),qb.detach()),rb[a]=c),c}var ub=/^margin/,vb=new RegExp(\"^(\"+Q+\")(?!px)[a-z%]+$\",\"i\"),wb=function(b){return b.ownerDocument.defaultView.opener?b.ownerDocument.defaultView.getComputedStyle(b,null):a.getComputedStyle(b,null)};function xb(a,b,c){var d,e,f,g,h=a.style;return c=c||wb(a),c&&(g=c.getPropertyValue(b)||c[b]),c&&(\"\"!==g||n.contains(a.ownerDocument,a)||(g=n.style(a,b)),vb.test(g)&&ub.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}function yb(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}!function(){var b,c,d=l.documentElement,e=l.createElement(\"div\"),f=l.createElement(\"div\");if(f.style){f.style.backgroundClip=\"content-box\",f.cloneNode(!0).style.backgroundClip=\"\",k.clearCloneStyle=\"content-box\"===f.style.backgroundClip,e.style.cssText=\"border:0;width:0;height:0;top:0;left:-9999px;margin-top:1px;position:absolute\",e.appendChild(f);function g(){f.style.cssText=\"-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute\",f.innerHTML=\"\",d.appendChild(e);var g=a.getComputedStyle(f,null);b=\"1%\"!==g.top,c=\"4px\"===g.width,d.removeChild(e)}a.getComputedStyle&&n.extend(k,{pixelPosition:function(){return g(),b},boxSizingReliable:function(){return null==c&&g(),c},reliableMarginRight:function(){var b,c=f.appendChild(l.createElement(\"div\"));return c.style.cssText=f.style.cssText=\"-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0\",c.style.marginRight=c.style.width=\"0\",f.style.width=\"1px\",d.appendChild(e),b=!parseFloat(a.getComputedStyle(c,null).marginRight),d.removeChild(e),f.removeChild(c),b}})}}(),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 zb=/^(none|table(?!-c[ea]).+)/,Ab=new RegExp(\"^(\"+Q+\")(.*)$\",\"i\"),Bb=new RegExp(\"^([+-])=(\"+Q+\")\",\"i\"),Cb={position:\"absolute\",visibility:\"hidden\",display:\"block\"},Db={letterSpacing:\"0\",fontWeight:\"400\"},Eb=[\"Webkit\",\"O\",\"Moz\",\"ms\"];function Fb(a,b){if(b in a)return b;var c=b[0].toUpperCase()+b.slice(1),d=b,e=Eb.length;while(e--)if(b=Eb[e]+c,b in a)return b;return d}function Gb(a,b,c){var d=Ab.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||\"px\"):b}function Hb(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+R[f],!0,e)),d?(\"content\"===c&&(g-=n.css(a,\"padding\"+R[f],!0,e)),\"margin\"!==c&&(g-=n.css(a,\"border\"+R[f]+\"Width\",!0,e))):(g+=n.css(a,\"padding\"+R[f],!0,e),\"padding\"!==c&&(g+=n.css(a,\"border\"+R[f]+\"Width\",!0,e)));return g}function Ib(a,b,c){var d=!0,e=\"width\"===b?a.offsetWidth:a.offsetHeight,f=wb(a),g=\"border-box\"===n.css(a,\"boxSizing\",!1,f);if(0>=e||null==e){if(e=xb(a,b,f),(0>e||null==e)&&(e=a.style[b]),vb.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Hb(a,b,c||(g?\"border\":\"content\"),d,f)+\"px\"}function Jb(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=L.get(d,\"olddisplay\"),c=d.style.display,b?(f[g]||\"none\"!==c||(d.style.display=\"\"),\"\"===d.style.display&&S(d)&&(f[g]=L.access(d,\"olddisplay\",tb(d.nodeName)))):(e=S(d),\"none\"===c&&e||L.set(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}n.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=xb(a,\"opacity\");return\"\"===c?\"1\":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{\"float\":\"cssFloat\"},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;return b=n.cssProps[h]||(n.cssProps[h]=Fb(i,h)),g=n.cssHooks[b]||n.cssHooks[h],void 0===c?g&&\"get\"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b]:(f=typeof c,\"string\"===f&&(e=Bb.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\"),k.clearCloneStyle||\"\"!==c||0!==b.indexOf(\"background\")||(i[b]=\"inherit\"),g&&\"set\"in g&&void 0===(c=g.set(a,c,d))||(i[b]=c)),void 0)}},css:function(a,b,c,d){var e,f,g,h=n.camelCase(b);return b=n.cssProps[h]||(n.cssProps[h]=Fb(a.style,h)),g=n.cssHooks[b]||n.cssHooks[h],g&&\"get\"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=xb(a,b,d)),\"normal\"===e&&b in Db&&(e=Db[b]),\"\"===c||c?(f=parseFloat(e),c===!0||n.isNumeric(f)?f||0:e):e}}),n.each([\"height\",\"width\"],function(a,b){n.cssHooks[b]={get:function(a,c,d){return c?zb.test(n.css(a,\"display\"))&&0===a.offsetWidth?n.swap(a,Cb,function(){return Ib(a,b,d)}):Ib(a,b,d):void 0},set:function(a,c,d){var e=d&&wb(a);return Gb(a,c,d?Hb(a,b,d,\"border-box\"===n.css(a,\"boxSizing\",!1,e),e):0)}}}),n.cssHooks.marginRight=yb(k.reliableMarginRight,function(a,b){return b?n.swap(a,{display:\"inline-block\"},xb,[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+R[d]+b]=f[d]||f[d-2]||f[0];return e}},ub.test(a)||(n.cssHooks[a+b].set=Gb)}),n.fn.extend({css:function(a,b){return J(this,function(a,b,c){var d,e,f={},g=0;if(n.isArray(b)){for(d=wb(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 Jb(this,!0)},hide:function(){return Jb(this)},toggle:function(a){return\"boolean\"==typeof a?a?this.show():this.hide():this.each(function(){S(this)?n(this).show():n(this).hide()})}});function Kb(a,b,c,d,e){return new Kb.prototype.init(a,b,c,d,e)}n.Tween=Kb,Kb.prototype={constructor:Kb,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=Kb.propHooks[this.prop];return a&&a.get?a.get(this):Kb.propHooks._default.get(this)},run:function(a){var b,c=Kb.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):Kb.propHooks._default.set(this),this}},Kb.prototype.init.prototype=Kb.prototype,Kb.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}}},Kb.propHooks.scrollTop=Kb.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=Kb.prototype.init,n.fx.step={};var Lb,Mb,Nb=/^(?:toggle|show|hide)$/,Ob=new RegExp(\"^(?:([+-])=|)(\"+Q+\")([a-z%]*)$\",\"i\"),Pb=/queueHooks$/,Qb=[Vb],Rb={\"*\":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=Ob.exec(b),f=e&&e[3]||(n.cssNumber[a]?\"\":\"px\"),g=(n.cssNumber[a]||\"px\"!==f&&+d)&&Ob.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 Sb(){return setTimeout(function(){Lb=void 0}),Lb=n.now()}function Tb(a,b){var c,d=0,e={height:a};for(b=b?1:0;4>d;d+=2-b)c=R[d],e[\"margin\"+c]=e[\"padding\"+c]=a;return b&&(e.opacity=e.width=a),e}function Ub(a,b,c){for(var d,e=(Rb[b]||[]).concat(Rb[\"*\"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function Vb(a,b,c){var d,e,f,g,h,i,j,k,l=this,m={},o=a.style,p=a.nodeType&&S(a),q=L.get(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++,l.always(function(){l.always(function(){h.unqueued--,n.queue(a,\"fx\").length||h.empty.fire()})})),1===a.nodeType&&(\"height\"in b||\"width\"in b)&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=n.css(a,\"display\"),k=\"none\"===j?L.get(a,\"olddisplay\")||tb(a.nodeName):j,\"inline\"===k&&\"none\"===n.css(a,\"float\")&&(o.display=\"inline-block\")),c.overflow&&(o.overflow=\"hidden\",l.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],Nb.exec(e)){if(delete b[d],f=f||\"toggle\"===e,e===(p?\"hide\":\"show\")){if(\"show\"!==e||!q||void 0===q[d])continue;p=!0}m[d]=q&&q[d]||n.style(a,d)}else j=void 0;if(n.isEmptyObject(m))\"inline\"===(\"none\"===j?tb(a.nodeName):j)&&(o.display=j);else{q?\"hidden\"in q&&(p=q.hidden):q=L.access(a,\"fxshow\",{}),f&&(q.hidden=!p),p?n(a).show():l.done(function(){n(a).hide()}),l.done(function(){var b;L.remove(a,\"fxshow\");for(b in m)n.style(a,b,m[b])});for(d in m)g=Ub(p?q[d]:0,d,l),d in q||(q[d]=g.start,p&&(g.end=g.start,g.start=\"width\"===d||\"height\"===d?1:0))}}function Wb(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 Xb(a,b,c){var d,e,f=0,g=Qb.length,h=n.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=Lb||Sb(),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:Lb||Sb(),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(Wb(k,j.opts.specialEasing);g>f;f++)if(d=Qb[f].call(j,a,k,j.opts))return d;return n.map(k,Ub,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(Xb,{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],Rb[c]=Rb[c]||[],Rb[c].unshift(b)},prefilter:function(a,b){b?Qb.unshift(a):Qb.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(S).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=Xb(this,n.extend({},a),f);(e||L.get(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=L.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&Pb.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=L.get(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(Tb(b,!0),a,d,e)}}),n.each({slideDown:Tb(\"show\"),slideUp:Tb(\"hide\"),slideToggle:Tb(\"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=0,c=n.timers;for(Lb=n.now();b<c.length;b++)a=c[b],a()||c[b]!==a||c.splice(b--,1);c.length||n.fx.stop(),Lb=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(){Mb||(Mb=setInterval(n.fx.tick,n.fx.interval))},n.fx.stop=function(){clearInterval(Mb),Mb=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=l.createElement(\"input\"),b=l.createElement(\"select\"),c=b.appendChild(l.createElement(\"option\"));a.type=\"checkbox\",k.checkOn=\"\"!==a.value,k.optSelected=c.selected,b.disabled=!0,k.optDisabled=!c.disabled,a=l.createElement(\"input\"),a.value=\"t\",a.type=\"radio\",k.radioValue=\"t\"===a.value}();var Yb,Zb,$b=n.expr.attrHandle;n.fn.extend({attr:function(a,b){return J(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===U?n.prop(a,b,c):(1===f&&n.isXMLDoc(a)||(b=b.toLowerCase(),d=n.attrHooks[b]||(n.expr.match.bool.test(b)?Zb:Yb)),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))\n},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)while(c=f[e++])d=n.propFix[c]||c,n.expr.match.bool.test(c)&&(a[d]=!1),a.removeAttribute(c)},attrHooks:{type:{set:function(a,b){if(!k.radioValue&&\"radio\"===b&&n.nodeName(a,\"input\")){var c=a.value;return a.setAttribute(\"type\",b),c&&(a.value=c),b}}}}}),Zb={set:function(a,b,c){return b===!1?n.removeAttr(a,c):a.setAttribute(c,c),c}},n.each(n.expr.match.bool.source.match(/\\w+/g),function(a,b){var c=$b[b]||n.find.attr;$b[b]=function(a,b,d){var e,f;return d||(f=$b[b],$b[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,$b[b]=f),e}});var _b=/^(?:input|select|textarea|button)$/i;n.fn.extend({prop:function(a,b){return J(this,n.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[n.propFix[a]||a]})}}),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){return a.hasAttribute(\"tabindex\")||_b.test(a.nodeName)||a.href?a.tabIndex:-1}}}}),k.optSelected||(n.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null}}),n.each([\"tabIndex\",\"readOnly\",\"maxLength\",\"cellSpacing\",\"cellPadding\",\"rowSpan\",\"colSpan\",\"useMap\",\"frameBorder\",\"contentEditable\"],function(){n.propFix[this.toLowerCase()]=this});var ac=/[\\t\\r\\n\\f]/g;n.fn.extend({addClass:function(a){var b,c,d,e,f,g,h=\"string\"==typeof a&&a,i=0,j=this.length;if(n.isFunction(a))return this.each(function(b){n(this).addClass(a.call(this,b,this.className))});if(h)for(b=(a||\"\").match(E)||[];j>i;i++)if(c=this[i],d=1===c.nodeType&&(c.className?(\" \"+c.className+\" \").replace(ac,\" \"):\" \")){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===arguments.length||\"string\"==typeof a&&a,i=0,j=this.length;if(n.isFunction(a))return this.each(function(b){n(this).removeClass(a.call(this,b,this.className))});if(h)for(b=(a||\"\").match(E)||[];j>i;i++)if(c=this[i],d=1===c.nodeType&&(c.className?(\" \"+c.className+\" \").replace(ac,\" \"):\"\")){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(E)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else(c===U||\"boolean\"===c)&&(this.className&&L.set(this,\"__className__\",this.className),this.className=this.className||a===!1?\"\":L.get(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(ac,\" \").indexOf(b)>=0)return!0;return!1}});var bc=/\\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(bc,\"\"):null==c?\"\":c)}}}),n.extend({valHooks:{option:{get:function(a){var b=n.find.attr(a,\"value\");return null!=b?b:n.trim(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||(k.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--)d=e[g],(d.selected=n.inArray(d.value,f)>=0)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),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}},k.checkOn||(n.valHooks[this].get=function(a){return null===a.getAttribute(\"value\")?\"on\":a.value})}),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 cc=n.now(),dc=/\\?/;n.parseJSON=function(a){return JSON.parse(a+\"\")},n.parseXML=function(a){var b,c;if(!a||\"string\"!=typeof a)return null;try{c=new DOMParser,b=c.parseFromString(a,\"text/xml\")}catch(d){b=void 0}return(!b||b.getElementsByTagName(\"parsererror\").length)&&n.error(\"Invalid XML: \"+a),b};var ec=/#.*$/,fc=/([?&])_=[^&]*/,gc=/^(.*?):[ \\t]*([^\\r\\n]*)$/gm,hc=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,ic=/^(?:GET|HEAD)$/,jc=/^\\/\\//,kc=/^([\\w.+-]+:)(?:\\/\\/(?:[^\\/?#]*@|)([^\\/?#:]*)(?::(\\d+)|)|)/,lc={},mc={},nc=\"*/\".concat(\"*\"),oc=a.location.href,pc=kc.exec(oc.toLowerCase())||[];function qc(a){return function(b,c){\"string\"!=typeof b&&(c=b,b=\"*\");var d,e=0,f=b.toLowerCase().match(E)||[];if(n.isFunction(c))while(d=f[e++])\"+\"===d[0]?(d=d.slice(1)||\"*\",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function rc(a,b,c,d){var e={},f=a===mc;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 sc(a,b){var c,d,e=n.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&n.extend(!0,a,d),a}function tc(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while(\"*\"===i[0])i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader(\"Content-Type\"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+\" \"+i[0]]){f=e;break}g||(g=e)}f=f||g}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function uc(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:oc,type:\"GET\",isLocal:hc.test(pc[1]),global:!0,processData:!0,async:!0,contentType:\"application/x-www-form-urlencoded; charset=UTF-8\",accepts:{\"*\":nc,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?sc(sc(a,n.ajaxSettings),b):sc(n.ajaxSettings,a)},ajaxPrefilter:qc(lc),ajaxTransport:qc(mc),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(!f){f={};while(b=gc.exec(e))f[b[1].toLowerCase()]=b[2]}b=f[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?e: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 c&&c.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||oc)+\"\").replace(ec,\"\").replace(jc,pc[1]+\"//\"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=n.trim(k.dataType||\"*\").toLowerCase().match(E)||[\"\"],null==k.crossDomain&&(h=kc.exec(k.url.toLowerCase()),k.crossDomain=!(!h||h[1]===pc[1]&&h[2]===pc[2]&&(h[3]||(\"http:\"===h[1]?\"80\":\"443\"))===(pc[3]||(\"http:\"===pc[1]?\"80\":\"443\")))),k.data&&k.processData&&\"string\"!=typeof k.data&&(k.data=n.param(k.data,k.traditional)),rc(lc,k,b,v),2===t)return v;i=n.event&&k.global,i&&0===n.active++&&n.event.trigger(\"ajaxStart\"),k.type=k.type.toUpperCase(),k.hasContent=!ic.test(k.type),d=k.url,k.hasContent||(k.data&&(d=k.url+=(dc.test(d)?\"&\":\"?\")+k.data,delete k.data),k.cache===!1&&(k.url=fc.test(d)?d.replace(fc,\"$1_=\"+cc++):d+(dc.test(d)?\"&\":\"?\")+\"_=\"+cc++)),k.ifModified&&(n.lastModified[d]&&v.setRequestHeader(\"If-Modified-Since\",n.lastModified[d]),n.etag[d]&&v.setRequestHeader(\"If-None-Match\",n.etag[d])),(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]?\", \"+nc+\"; q=0.01\":\"\"):k.accepts[\"*\"]);for(j in k.headers)v.setRequestHeader(j,k.headers[j]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u=\"abort\";for(j in{success:1,error:1,complete:1})v[j](k[j]);if(c=rc(mc,k,b,v)){v.readyState=1,i&&m.trigger(\"ajaxSend\",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort(\"timeout\")},k.timeout));try{t=1,c.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,\"No Transport\");function x(a,b,f,h){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),c=void 0,e=h||\"\",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,f&&(u=tc(k,v,f)),u=uc(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader(\"Last-Modified\"),w&&(n.lastModified[d]=w),w=v.getResponseHeader(\"etag\"),w&&(n.etag[d]=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,i&&m.trigger(j?\"ajaxSuccess\":\"ajaxError\",[v,k,j?r:s]),p.fireWith(l,[v,x]),i&&(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._evalUrl=function(a){return n.ajax({url:a,type:\"GET\",dataType:\"script\",async:!1,global:!1,\"throws\":!0})},n.fn.extend({wrapAll:function(a){var b;return n.isFunction(a)?this.each(function(b){n(this).wrapAll(a.call(this,b))}):(this[0]&&(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.firstElementChild)a=a.firstElementChild;return a}).append(this)),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},n.expr.filters.visible=function(a){return!n.expr.filters.hidden(a)};var vc=/%20/g,wc=/\\[\\]$/,xc=/\\r?\\n/g,yc=/^(?:submit|button|image|reset|file)$/i,zc=/^(?:input|select|textarea|keygen)/i;function Ac(a,b,c,d){var e;if(n.isArray(b))n.each(b,function(b,e){c||wc.test(a)?d(a,e):Ac(a+\"[\"+(\"object\"==typeof e?b:\"\")+\"]\",e,c,d)});else if(c||\"object\"!==n.type(b))d(a,b);else for(e in b)Ac(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)Ac(c,a[c],b,e);return d.join(\"&\").replace(vc,\"+\")},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\")&&zc.test(this.nodeName)&&!yc.test(a)&&(this.checked||!T.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(xc,\"\\r\\n\")}}):{name:b.name,value:c.replace(xc,\"\\r\\n\")}}).get()}}),n.ajaxSettings.xhr=function(){try{return new XMLHttpRequest}catch(a){}};var Bc=0,Cc={},Dc={0:200,1223:204},Ec=n.ajaxSettings.xhr();a.attachEvent&&a.attachEvent(\"onunload\",function(){for(var a in Cc)Cc[a]()}),k.cors=!!Ec&&\"withCredentials\"in Ec,k.ajax=Ec=!!Ec,n.ajaxTransport(function(a){var b;return k.cors||Ec&&!a.crossDomain?{send:function(c,d){var e,f=a.xhr(),g=++Bc;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)f.setRequestHeader(e,c[e]);b=function(a){return function(){b&&(delete Cc[g],b=f.onload=f.onerror=null,\"abort\"===a?f.abort():\"error\"===a?d(f.status,f.statusText):d(Dc[f.status]||f.status,f.statusText,\"string\"==typeof f.responseText?{text:f.responseText}:void 0,f.getAllResponseHeaders()))}},f.onload=b(),f.onerror=b(\"error\"),b=Cc[g]=b(\"abort\");try{f.send(a.hasContent&&a.data||null)}catch(h){if(b)throw h}},abort:function(){b&&b()}}:void 0}),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\")}),n.ajaxTransport(\"script\",function(a){if(a.crossDomain){var b,c;return{send:function(d,e){b=n(\"<script>\").prop({async:!0,charset:a.scriptCharset,src:a.url}).on(\"load error\",c=function(a){b.remove(),c=null,a&&e(\"error\"===a.type?404:200,a.type)}),l.head.appendChild(b[0])},abort:function(){c&&c()}}}});var Fc=[],Gc=/(=)\\?(?=&|$)|\\?\\?/;n.ajaxSetup({jsonp:\"callback\",jsonpCallback:function(){var a=Fc.pop()||n.expando+\"_\"+cc++;return this[a]=!0,a}}),n.ajaxPrefilter(\"json jsonp\",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(Gc.test(b.url)?\"url\":\"string\"==typeof b.data&&!(b.contentType||\"\").indexOf(\"application/x-www-form-urlencoded\")&&Gc.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(Gc,\"$1\"+e):b.jsonp!==!1&&(b.url+=(dc.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,Fc.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||l;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 Hc=n.fn.load;n.fn.load=function(a,b,c){if(\"string\"!=typeof a&&Hc)return Hc.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(\" \");return h>=0&&(d=n.trim(a.slice(h)),a=a.slice(0,h)),n.isFunction(b)?(c=b,b=void 0):b&&\"object\"==typeof b&&(e=\"POST\"),g.length>0&&n.ajax({url:a,type:e,dataType:\"html\",data:b}).done(function(a){f=arguments,g.html(d?n(\"<div>\").append(n.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,f||[a.responseText,b,a])}),this},n.each([\"ajaxStart\",\"ajaxStop\",\"ajaxComplete\",\"ajaxError\",\"ajaxSuccess\",\"ajaxSend\"],function(a,b){n.fn[b]=function(a){return this.on(b,a)}}),n.expr.filters.animated=function(a){return n.grep(n.timers,function(b){return a===b.elem}).length};var Ic=a.document.documentElement;function Jc(a){return n.isWindow(a)?a:9===a.nodeType&&a.defaultView}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)&&(f+i).indexOf(\"auto\")>-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=this[0],e={top:0,left:0},f=d&&d.ownerDocument;if(f)return b=f.documentElement,n.contains(b,d)?(typeof d.getBoundingClientRect!==U&&(e=d.getBoundingClientRect()),c=Jc(f),{top:e.top+c.pageYOffset-b.clientTop,left:e.left+c.pageXOffset-b.clientLeft}):e},position:function(){if(this[0]){var a,b,c=this[0],d={top:0,left:0};return\"fixed\"===n.css(c,\"position\")?b=c.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),n.nodeName(a[0],\"html\")||(d=a.offset()),d.top+=n.css(a[0],\"borderTopWidth\",!0),d.left+=n.css(a[0],\"borderLeftWidth\",!0)),{top:b.top-d.top-n.css(c,\"marginTop\",!0),left:b.left-d.left-n.css(c,\"marginLeft\",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||Ic;while(a&&!n.nodeName(a,\"html\")&&\"static\"===n.css(a,\"position\"))a=a.offsetParent;return a||Ic})}}),n.each({scrollLeft:\"pageXOffset\",scrollTop:\"pageYOffset\"},function(b,c){var d=\"pageYOffset\"===c;n.fn[b]=function(e){return J(this,function(b,e,f){var g=Jc(b);return void 0===f?g?g[c]:b[e]:void(g?g.scrollTo(d?a.pageXOffset:f,d?f:a.pageYOffset):b[e]=f)},b,e,arguments.length,null)}}),n.each([\"top\",\"left\"],function(a,b){n.cssHooks[b]=yb(k.pixelPosition,function(a,c){return c?(c=xb(a,b),vb.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 J(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 Kc=a.jQuery,Lc=a.$;return n.noConflict=function(b){return a.$===n&&(a.$=Lc),b&&a.jQuery===n&&(a.jQuery=Kc),n},typeof b===U&&(a.jQuery=a.$=n),n});\n"
  },
  {
    "path": "source/lib/jquery_lazyload/.bower.json",
    "content": "{\n  \"name\": \"jquery_lazyload\",\n  \"version\": \"1.9.7\",\n  \"homepage\": \"http://www.appelsiini.net/projects/lazyload\",\n  \"authors\": [\n    \"Mika Tuupola <tuupola@appelsiini.net>\"\n  ],\n  \"description\": \"jQuery plugin for lazy loading images\",\n  \"main\": [\n    \"jquery.lazyload.js\",\n    \"jquery.scrollstop.js\"\n  ],\n  \"license\": \"MIT\",\n  \"ignore\": [\n    \"**/.*\",\n    \"**/*.min.js\",\n    \"**/*.html\",\n    \"**/*.textile\",\n    \"Gruntfile.js\",\n    \"lazyload.jquery.json\",\n    \"package.json\",\n    \"node_modules\",\n    \"bower_components\",\n    \"test\",\n    \"img\"\n  ],\n  \"_release\": \"1.9.7\",\n  \"_resolution\": {\n    \"type\": \"version\",\n    \"tag\": \"1.9.7\",\n    \"commit\": \"218e50eb4999fe59ac94b939a65c8c988d1d420b\"\n  },\n  \"_source\": \"git://github.com/tuupola/jquery_lazyload.git\",\n  \"_target\": \"~1.9.7\",\n  \"_originalSource\": \"jquery.lazyload\",\n  \"_direct\": true\n}"
  },
  {
    "path": "source/lib/jquery_lazyload/CONTRIBUTING.md",
    "content": "# Contributing to Lazy Load\n\n## Only one feature or change per pull request\n\nMake pull requests only one feature or change at the time. For example you have fixed a bug. You also have optimized some code. Optimization is not related to a bug. These should be submitted as separate pull requests. This way I can easily choose what to include. It is also easier to understand the code changes. Commit messages should be descriptive and full sentences.\n\nDo not commit minified versions. Do not touch the version number. Make the pull requests against [1.9.x branch](https://github.com/tuupola/jquery_lazyload/commits/1.9.x).\n\n## Write meaningful commit messages\n\nProper commit message is full sentence. It starts with capital letter but does not end with period. Headlines do not end with period. The GitHub default `Update filename.js` is not enough. When needed include also longer explanation what the commit does.\n\n```\nCapitalized, short (50 chars or less) summary\n\nMore detailed explanatory text, if necessary.  Wrap it to about 72\ncharacters or so.  In some contexts, the first line is treated as the\nsubject of an email and the rest of the text as the body.  The blank\nline separating the summary from the body is critical (unless you omit\nthe body entirely); tools like rebase can get confused if you run the\ntwo together.\n```\n\nWhen in doubt see Tim Pope's blogpost [A Note About Git Commit Messages](http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html)\n\n## Follow the existing coding standards\n\nWhen contributing to open source project it is polite to follow the original authors coding standars. They might be different than yours. It is not a holy war. Just follow then original.\n\n```javascript\nvar snake_case = \"something\";\n\nfunction camelCase(options) {\n}\n\nif (true !== false) {\n    console.log(\"here be dragons\");\n}\n```\n"
  },
  {
    "path": "source/lib/jquery_lazyload/README.md",
    "content": "# Lazy Load Plugin for jQuery\n\nLazy Load delays loading of images in long web pages. Images outside of viewport wont be loaded before user scrolls to them. This is opposite of image preloading.\n\nUsing Lazy Load on long web pages containing many large images makes the page load faster. Browser will be in ready state after loading visible images. In some cases it can also help to reduce server load.\n\nLazy Load is inspired by [YUI ImageLoader](http://developer.yahoo.com/yui/imageloader/) Utility by Matt Mlinac.\n\n## How to Use?\n\nLazy Load depends on jQuery. Include them both in end of your HTML code:\n\n```html\n<script src=\"jquery.js\" type=\"text/javascript\"></script>\n<script src=\"jquery.lazyload.js\" type=\"text/javascript\"></script>\n```\n\nYou must alter your HTML code. URL of the real image must be put into data-original attribute. It is good idea to give Lazy Loaded image a specific class. This way you can easily control which images plugin is binded to. Note that you should have width and height attributes in your image tag.\n\n```html\n<img class=\"lazy\" data-original=\"img/example.jpg\" width=\"640\" height=\"480\">\n```\n\nthen in your code do:\n\n```js\n$(\"img.lazy\").lazyload();\n```\n\nThis causes all images of class lazy to be lazy loaded.\n\nMore information on [Lazy Load](http://www.appelsiini.net/projects/lazyload) project page.\n\n## Install\n\nYou can install with [bower](http://bower.io/) or [npm](https://www.npmjs.com/).\n\n\n```sh\n$ bower install jquery.lazyload\n$ npm install jquery-lazyload\n```\n\n\n# License\n\nAll code licensed under the [MIT License](http://www.opensource.org/licenses/mit-license.php). All images licensed under [Creative Commons Attribution 3.0 Unported License](http://creativecommons.org/licenses/by/3.0/deed.en_US). In other words you are basically free to do whatever you want. Just don't remove my name from the source.\n\n"
  },
  {
    "path": "source/lib/jquery_lazyload/bower.json",
    "content": "{\n  \"name\": \"jquery_lazyload\",\n  \"version\": \"1.9.4\",\n  \"homepage\": \"http://www.appelsiini.net/projects/lazyload\",\n  \"authors\": [\n    \"Mika Tuupola <tuupola@appelsiini.net>\"\n  ],\n  \"description\": \"jQuery plugin for lazy loading images\",\n  \"main\": [\n    \"jquery.lazyload.js\",\n    \"jquery.scrollstop.js\"\n  ],\n  \"license\": \"MIT\",\n  \"ignore\": [\n    \"**/.*\",\n    \"**/*.min.js\",\n    \"**/*.html\",\n    \"**/*.textile\",\n    \"Gruntfile.js\",\n    \"lazyload.jquery.json\",\n    \"package.json\",\n    \"node_modules\",\n    \"bower_components\",\n    \"test\",\n    \"img\"\n  ]\n}\n"
  },
  {
    "path": "source/lib/jquery_lazyload/jquery.lazyload.js",
    "content": "/*!\n * Lazy Load - jQuery plugin for lazy loading images\n *\n * Copyright (c) 2007-2015 Mika Tuupola\n *\n * Licensed under the MIT license:\n *   http://www.opensource.org/licenses/mit-license.php\n *\n * Project home:\n *   http://www.appelsiini.net/projects/lazyload\n *\n * Version:  1.9.7\n *\n */\n\n(function($, window, document, undefined) {\n    var $window = $(window);\n\n    $.fn.lazyload = function(options) {\n        var elements = this;\n        var $container;\n        var settings = {\n            threshold       : 0,\n            failure_limit   : 0,\n            event           : \"scroll\",\n            effect          : \"show\",\n            container       : window,\n            data_attribute  : \"original\",\n            skip_invisible  : false,\n            appear          : null,\n            load            : null,\n            placeholder     : \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC\"\n        };\n\n        function update() {\n            var counter = 0;\n\n            elements.each(function() {\n                var $this = $(this);\n                if (settings.skip_invisible && !$this.is(\":visible\")) {\n                    return;\n                }\n                if ($.abovethetop(this, settings) ||\n                    $.leftofbegin(this, settings)) {\n                        /* Nothing. */\n                } else if (!$.belowthefold(this, settings) &&\n                    !$.rightoffold(this, settings)) {\n                        $this.trigger(\"appear\");\n                        /* if we found an image we'll load, reset the counter */\n                        counter = 0;\n                } else {\n                    if (++counter > settings.failure_limit) {\n                        return false;\n                    }\n                }\n            });\n\n        }\n\n        if(options) {\n            /* Maintain BC for a couple of versions. */\n            if (undefined !== options.failurelimit) {\n                options.failure_limit = options.failurelimit;\n                delete options.failurelimit;\n            }\n            if (undefined !== options.effectspeed) {\n                options.effect_speed = options.effectspeed;\n                delete options.effectspeed;\n            }\n\n            $.extend(settings, options);\n        }\n\n        /* Cache container as jQuery as object. */\n        $container = (settings.container === undefined ||\n                      settings.container === window) ? $window : $(settings.container);\n\n        /* Fire one scroll event per scroll. Not one scroll event per image. */\n        if (0 === settings.event.indexOf(\"scroll\")) {\n            $container.bind(settings.event, function() {\n                return update();\n            });\n        }\n\n        this.each(function() {\n            var self = this;\n            var $self = $(self);\n\n            self.loaded = false;\n\n            /* If no src attribute given use data:uri. */\n            if ($self.attr(\"src\") === undefined || $self.attr(\"src\") === false) {\n                if ($self.is(\"img\")) {\n                    $self.attr(\"src\", settings.placeholder);\n                }\n            }\n\n            /* When appear is triggered load original image. */\n            $self.one(\"appear\", function() {\n                if (!this.loaded) {\n                    if (settings.appear) {\n                        var elements_left = elements.length;\n                        settings.appear.call(self, elements_left, settings);\n                    }\n                    $(\"<img />\")\n                        .bind(\"load\", function() {\n\n                            var original = $self.attr(\"data-\" + settings.data_attribute);\n                            $self.hide();\n                            if ($self.is(\"img\")) {\n                                $self.attr(\"src\", original);\n                            } else {\n                                $self.css(\"background-image\", \"url('\" + original + \"')\");\n                            }\n                            $self[settings.effect](settings.effect_speed);\n\n                            self.loaded = true;\n\n                            /* Remove image from array so it is not looped next time. */\n                            var temp = $.grep(elements, function(element) {\n                                return !element.loaded;\n                            });\n                            elements = $(temp);\n\n                            if (settings.load) {\n                                var elements_left = elements.length;\n                                settings.load.call(self, elements_left, settings);\n                            }\n                        })\n                        .attr(\"src\", $self.attr(\"data-\" + settings.data_attribute));\n                }\n            });\n\n            /* When wanted event is triggered load original image */\n            /* by triggering appear.                              */\n            if (0 !== settings.event.indexOf(\"scroll\")) {\n                $self.bind(settings.event, function() {\n                    if (!self.loaded) {\n                        $self.trigger(\"appear\");\n                    }\n                });\n            }\n        });\n\n        /* Check if something appears when window is resized. */\n        $window.bind(\"resize\", function() {\n            update();\n        });\n\n        /* With IOS5 force loading images when navigating with back button. */\n        /* Non optimal workaround. */\n        if ((/(?:iphone|ipod|ipad).*os 5/gi).test(navigator.appVersion)) {\n            $window.bind(\"pageshow\", function(event) {\n                if (event.originalEvent && event.originalEvent.persisted) {\n                    elements.each(function() {\n                        $(this).trigger(\"appear\");\n                    });\n                }\n            });\n        }\n\n        /* Force initial check if images should appear. */\n        $(document).ready(function() {\n            update();\n        });\n\n        return this;\n    };\n\n    /* Convenience methods in jQuery namespace.           */\n    /* Use as  $.belowthefold(element, {threshold : 100, container : window}) */\n\n    $.belowthefold = function(element, settings) {\n        var fold;\n\n        if (settings.container === undefined || settings.container === window) {\n            fold = (window.innerHeight ? window.innerHeight : $window.height()) + $window.scrollTop();\n        } else {\n            fold = $(settings.container).offset().top + $(settings.container).height();\n        }\n\n        return fold <= $(element).offset().top - settings.threshold;\n    };\n\n    $.rightoffold = function(element, settings) {\n        var fold;\n\n        if (settings.container === undefined || settings.container === window) {\n            fold = $window.width() + $window.scrollLeft();\n        } else {\n            fold = $(settings.container).offset().left + $(settings.container).width();\n        }\n\n        return fold <= $(element).offset().left - settings.threshold;\n    };\n\n    $.abovethetop = function(element, settings) {\n        var fold;\n\n        if (settings.container === undefined || settings.container === window) {\n            fold = $window.scrollTop();\n        } else {\n            fold = $(settings.container).offset().top;\n        }\n\n        return fold >= $(element).offset().top + settings.threshold  + $(element).height();\n    };\n\n    $.leftofbegin = function(element, settings) {\n        var fold;\n\n        if (settings.container === undefined || settings.container === window) {\n            fold = $window.scrollLeft();\n        } else {\n            fold = $(settings.container).offset().left;\n        }\n\n        return fold >= $(element).offset().left + settings.threshold + $(element).width();\n    };\n\n    $.inviewport = function(element, settings) {\n         return !$.rightoffold(element, settings) && !$.leftofbegin(element, settings) &&\n                !$.belowthefold(element, settings) && !$.abovethetop(element, settings);\n     };\n\n    /* Custom selectors for your convenience.   */\n    /* Use as $(\"img:below-the-fold\").something() or */\n    /* $(\"img\").filter(\":below-the-fold\").something() which is faster */\n\n    $.extend($.expr[\":\"], {\n        \"below-the-fold\" : function(a) { return $.belowthefold(a, {threshold : 0}); },\n        \"above-the-top\"  : function(a) { return !$.belowthefold(a, {threshold : 0}); },\n        \"right-of-screen\": function(a) { return $.rightoffold(a, {threshold : 0}); },\n        \"left-of-screen\" : function(a) { return !$.rightoffold(a, {threshold : 0}); },\n        \"in-viewport\"    : function(a) { return $.inviewport(a, {threshold : 0}); },\n        /* Maintain BC for couple of versions. */\n        \"above-the-fold\" : function(a) { return !$.belowthefold(a, {threshold : 0}); },\n        \"right-of-fold\"  : function(a) { return $.rightoffold(a, {threshold : 0}); },\n        \"left-of-fold\"   : function(a) { return !$.rightoffold(a, {threshold : 0}); }\n    });\n\n})(jQuery, window, document);\n"
  },
  {
    "path": "source/lib/jquery_lazyload/jquery.scrollstop.js",
    "content": "/* http://james.padolsey.com/javascript/special-scroll-events-for-jquery/ */\n\n(function(){\n    \n    var special = jQuery.event.special,\n        uid1 = \"D\" + (+new Date()),\n        uid2 = \"D\" + (+new Date() + 1);\n        \n    special.scrollstart = {\n        setup: function() {\n            \n            var timer,\n                handler =  function(evt) {\n                    \n                    var _self = this,\n                        _args = arguments;\n                    \n                    if (timer) {\n                        clearTimeout(timer);\n                    } else {\n                        evt.type = \"scrollstart\";\n                        jQuery.event.dispatch.apply(_self, _args);\n                    }\n                    \n                    timer = setTimeout( function(){\n                        timer = null;\n                    }, special.scrollstop.latency);\n                    \n                };\n            \n            jQuery(this).bind(\"scroll\", handler).data(uid1, handler);\n            \n        },\n        teardown: function(){\n            jQuery(this).unbind( \"scroll\", jQuery(this).data(uid1) );\n        }\n    };\n    \n    special.scrollstop = {\n        latency: 300,\n        setup: function() {\n            \n            var timer,\n                    handler = function(evt) {\n                    \n                    var _self = this,\n                        _args = arguments;\n                    \n                    if (timer) {\n                        clearTimeout(timer);\n                    }\n                    \n                    timer = setTimeout( function(){\n                        \n                        timer = null;\n                        evt.type = \"scrollstop\";\n                        jQuery.event.dispatch.apply(_self, _args);\n                        \n                        \n                    }, special.scrollstop.latency);\n                    \n                };\n            \n            jQuery(this).bind(\"scroll\", handler).data(uid2, handler);\n            \n        },\n        teardown: function() {\n            jQuery(this).unbind( \"scroll\", jQuery(this).data(uid2) );\n        }\n    };\n    \n})();"
  },
  {
    "path": "source/lib/needsharebutton/font-embedded.css",
    "content": "/* SOCIAL ICON */\n\n@font-face {\n    font-family: 'social-icons';\n    font-weight: normal;\n    font-style: normal;\n    src: url('font/social.eot?44259375');\n    src: url('font/social.eot?44259375#iefix') format('embedded-opentype'), url('font/social.woff?44259375') format('woff'), url('font/social.ttf?44259375') format('truetype'), url('font/social.svg?44259375#social') format('svg');\n}\n@font-face {\n    font-family: 'social-icons';\n    src: url('data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAB5QAA4AAAAALUAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABPUy8yAAABRAAAAEQAAABWPjNJdGNtYXAAAAGIAAAAOgAAAUrQJhm3Y3Z0IAAAAcQAAAAKAAAACgAAAABmcGdtAAAB0AAABZQAAAtwiJCQWWdhc3AAAAdkAAAACAAAAAgAAAAQZ2x5ZgAAB2wAABNNAAAZvobjj8xoZWFkAAAavAAAADUAAAA2B4c/xGhoZWEAABr0AAAAIAAAACQIhgRyaG10eAAAGxQAAAAlAAAAXFbCAABsb2NhAAAbPAAAADAAAAAwSzxS321heHAAABtsAAAAIAAAACAAvA3kbmFtZQAAG4wAAAGAAAACtQTZcEJwb3N0AAAdDAAAANkAAAEvXVTY9XByZXAAAB3oAAAAZQAAAHvdawOFeJxjYGQ+xjiBgZWBg6mKaQ8DA0MPhGZ8wGDIyMTAwMTAysyAFQSkuaYwOLxgeCHKHPQ/iyGKOYZhIVCYESQHAAQvDCV4nGNgYGBmgGAZBkYGEHAB8hjBfBYGDSDNBqQZGZgYGF6I/v8PUvCCAURLMELVAwEjG8OIBwB7KAbDAAAAAAAAAAAAAAAAAAB4nK1WaXMTRxCd1WHLNj6CDxI2gVnGcox2VpjLCBDG7EoW4BzylexCjl1Ldu6LT/wG/ZpekVSRb/y0vB4d2GAnVVQoSv2m9+1M9+ueXpPQksReWI+k3HwpprY2aWTnSUg3bFqO4kPZ2QspU0z+LoiCaLXUvu04JCISgap1hSWC2PfI0iTjQ48yWrYlvWpSbulJd9kaD+qt+vbT0FGO3QklNZuhQ+uRLanCqBJFMu2RkjYtw9VfSVrh5yvMfNUMJYLoJJLGm2EMj+Rn44xWGa3GdhxFkU2WG0WKRDM8iCKPslpin1wxQUD5oBlSXvk0onyEH5EVe5TTCnHJdprf9yU/6R3OvyTieouyJQf+QHZkB3unK/ki0toK46adbEehivB0fSfEI5uT6p/sUV7TaOB2RaYnzQiWyleQWPkJZfYPyWrhfMqXPBrVkoOcCFovc2Jf8g60HkdMiWsmyILujk6IoO6XnKHYY/q4+OO9XSwXIQTIOJb1jkq4EEYpYbOaJG0EOYiSskWV1HpHTJzyOi3iLWG/Tu3oS2e0Sag7MZ6th46tnKjkeDSp00ymTu2k5tGUBlFKOhM85tcBlB/RJK+2sZrEyqNpbDNjJJFQoIVzaSqIZSeWNAXRPJrRm7thmmvXokWaPFDPPXpPb26Fmzs9p+3AP2v8Z3UqpoO9MJ2eDshKfJp2uUnRun56hn8m8UPWAiqRLTbDlMVDtn4H5eVjS47CawNs957zK+h99kTIpIH4G/AeL9UpBUyFmFVQC9201rUsy9RqVotUZOq7IU0rX9ZpAk05Dn1jX8Y4/q+ZGUtMCd/vxOnZEZeeufYlyDSH3GZdj+Z1arFdgM5sz+k0y/Z9nebYfqDTPNvzOh1ha+t0lO2HOi2w/UinY2wvaEGT7jsEchGBXMAGEoGwdRAI20sIhK1CIGwXEQjbIgJhu4RA2H6MQNguIxC2l7Wsmn4qaRw7E8sARYgDoznuyGVuKldTyaUSrotGpzbkKXKrpKJ4Vv0rA/3ikTesgbVAukTW/IpJrnxUleOPrmh508S5Ao5Vf3tzXJ8TD2W/WPhT8L/amqqkV6x5ZHIVeSPQk+NE1yYVj67p8rmqR9f/i4oOa4F+A6UQC0VZlg2+mZDwUafTUA1c5RAzGzMP1/W6Zc3P4fybGCEL6H78NxQaC9yDTllJWe1gr9XXj2W5twflsCdYkmK+zOtb4YuMzEr7RWYpez7yecAVMCqVYasNXK3gzXsS85DpTfJMELcVZYOkjceZILGBYx4wb76TICRMXbWB2imcsIG8YMwp2O+EQ1RvlOVwe6F9Ho2Uf2tX7MgZFU0Q+G32Rtjrs1DyW6yBhCe/1NdAVSFNxbipgEsj5YZq8GFcrdtGMk6gr6jYDcuyig8fR9x3So5lIPlIEatHRz+tvUKd1Ln9yihu3zv9CIJBaWL+9r6Z4qCUd7WSZVZtA1O3GpVT15rDxasO3c2j7nvH2Sdy1jTddE/c9L6mVbeDg7lZEO3bHJSlTC6o68MOG6jLzaXQ6mVckt52DzAsMKDfoRUb/1f3cfg8V6oKo+NIvZ2oH6PPYgzyDzh/R/UF6OcxTLmGlOd7lxOfbtzD2TJdxV2sn+LfwKy15mbpGnBD0w2Yh6xaHbrKDXynBjo90tyO9BDwse4K8QBgE8Bi8InuWsbzKYDxfMYcH+Bz5jBoMofBFnMYbDNnDWCHOQx2mcNgjzkMvmDOOsCXzGEQModBxBwGT5gTADxlDoOvmMPga+Yw+IY59wG+ZQ6DmDkMEuYw2Nd0ayhzixd0F6htUBXowPQTFvewONRUGbK/44Vhf28Qs38wiKk/aro9pP7EC0P92SCm/mIQU3/VdGdI/Y0Xhvq7QUz9wyCmPtMvxnKZwV9GvkuFA8ouNp/z98T7B8IaQLYAAQAB//8AD3icfVl7cFxXeb/fOfe9d+++7mO1Wl2t9u7uXVnS7uru3r2yJK+elizZlm3FiWVHkR0ngPEjSRPnQQgxMU4IjvOAIQE6DAOBMIHwBykpoZl2oIBJSZhOmfCc6RD+aScppTNtKTCFrPudK7mTtJ1Kmvs49zy+8z1+3+874siV3145Rf+drnO7uXdx8p/fcDAlkJEhqIFXA0mntkNtq+m3Q09nLV6lQ8K2ZTtgWxK2uDUIUm7Fq7hFEd9tC3/99hTgPWyHbUFMgCjhr8uGtsMONH3Wpx/oP8SOH1z/2cl3PXMq15doLx9pbty880MTY6t/sXbgbM4yDz6wcvC5XTN7ZLXXmU8THlaT6Z2r4ycGZ1zX3bNwqHGolMjVZsdnvG3dxwjhCUlYI9MTh03LqvbMlVvDvQahKnzpxi/umKnZ1r0v/OCm4PjqjOWVSjeM6mX3/LV7P/vY0XS63KyfWz4WBLagVOOwXVcHByudrx7cN7INcrmYK6lOcfeBKqECJWaiH4J6cKaSzeVSWUrjHP5QjrtylH6WruLTBDfPqS/OToUxwlHUoRuaZdy326qg8mxTYjoS07bV9kLUnwN9YIkS00yr7ePUFVFyIGxa7QypUFQW9vEqkHn6VWImb/Le15mftei2b9IG5XfdeXGNB9g9NbUAafckcYjpqDH1EZVuBGe0r2h04kdg9jpjZLJN3v+DZ7bZVeA7PNR7Hx1ujy92/6OQXNRvk9YlGPfW+VEe3HyvCWQfX147MkNiT0AW7Ke7z/MhL+wWYioHuMeT9HO4x12c+LXtMuDewvYEoMyeK6GJmzq6Ckim6HotrxWi/f/Pr0NgNlPNVBhdgs2utKCJMt1rfz6XLtouSfSIAu6M/2uISXIMv6zYX+jJFHqKkMhKaAOg7zn18rldLz/5cYiJ5DMiQRPrvKD36gOGYqrVxwHea6ck8X9/eLZrwBt8dHl2s9PmvsgfcF8HcV8787ivcmg1O9CqoKUMWwre8ZZyTS+sQVE00MdD+/95ab5zILHvTplOtTpZBTh0T8q4+rhzDQCfqk4mcd/VRyPx/rc97nzbwB8cim2288LU5bWtZ0GYgqHPTMc3OylHLk9rW49rr03H+j1vh8ced75t7FWfreG+Q26O24c+u3exM1ZX0GeZv2I0Y6DaLMjxjtEqsdCWrKhF2oIBrxLFNT4HHZgi2NQB5rE6oCLQ3dGV7Q7AdyZODGuq1x8fzCryoVcPJQeLWk9ffapvqiALh67TJVlxjXhGmZlRNHl2rr+UMUGTn5s8+Tihj58+/SilT6RhIQgWgCwErYWPCUVXVr1hQ4nx4jgZ01U9NThQy2oarwrXHUqUUjgeYvLMnEqU+dl8UnEzcUN57kf0iVPRZGdOPfoHnAwWg2AnwALHKVEQv0HOcUkuxzmokeu509yd3P3cpzh72vjEE/fe9Sdn3nNsdXKomu+10wlQRoZSbUQxB0wDleGKnumGVui3W4iBUoa5dstr2mh+hpOmG0TRL4l94JYZZLrFCgt/BqmBi6//rblm2JREU2qhShlQMFdCBA1AB8Nis0s1QJywDDG0RJwk9O1AMhujhogitNlbaDaqSwcqacu1Z6qZ1NKSbm2rD3lO/PUln0zzRK2Xqh2ynHOsPpFfJnMwYk/059tGSh/uRbtDfMgJ54HsbRcHVaDTAMtU6M/2V6HsmgWJvvV8vlweK5fzluMMOw4BkVeJSklOEBQCCqEVMi8P6LX8eMEygf/kD3mo7Czy3S/BQPf1V0fLQ+l+gPG5r3y+gN6cTan6l7cdGTQSWiyU49V6j2HD3qld+wFy6Uox4wxospnzhys+ZA1Nh0Uoj5VKY+U7oQ/XHu4rCmKaQC/v8hKouHxV9DmORDh1McLiBOayuAQc5jIbmlB+m1NuwEvf7C6S0+Tw/PxhEl0fo7/8Y+GpOfY2F105cqV75QJ9k4ZciduOc7VHcoBzZdo+gzMRg4H5P1rOaoemxQLEKwm4SDJTaQs6mOJW+ITtSpRI4fPuoltqC8rKYgqIKrffHd7+jzdDJ8gGue5Puj/Ze4oCvQFWcgVSr1772npznkBrW/3W8em7aZMOv2fi+i9sVyvpa68rLDlWofO98eNZTQIAesteSEFm6Y7bc7Nl/7DTifn5oxOt6/uK/QQam7F+B32d7uEqXICerb54ejWoVTIsPyE2b0IzczE7Skk+y9Ehgy4vYgD4F+X6pCQWvEoSv0RgsNl5kwhIIuuLbaID7Qg42BWb6qwP+ncd0QFekHQnGfaunvHyhpGvnl7dfvihw9u3Xnunq6VTg8UL7584M3Lu3IXuCxfOnVt5uWfvkq/0aClKRNk8V6tOAakX9509MACgFor+0t4dG4/kVZDk4QE7FpeF5GBSs91b6CJQkZqad+Yda1x9bR/sz4eaLO+NT45srnQB9lxY2fETtWIO7CwvpnMJns/E9bwAmmondNtKxBMklhRk1SlpqYzdLwu9zgB9/NQBUaScjPp9H/05nUfkeJD7FhThJLxCDHIj582kyTGyA/4VXoXvw6dhJ7jQz/2ae5Z7iDvP3YBYw+FodKmG5IpFZgb0KFNMMnZkjdoWEqWm1bQHQj9yozAIvaAyGrQY9tah4tq+1XSgnzI6RS0jAfiHFm3gTAkoSi5OWxnCfswQDLHrmI+DSisM/IDNhzkaJ21iovbLDanCFpcMTNLWqGibKEKjHxDi0M4Ny25aEyyjt6cIjkniLEGlTlwmQtP2sVcz8pHoMmpafSAa0qZvRYnDFV2paIqIey5KQVrulm/VoeUFKA9ubwr8IIxcj8nVRDTdlIztQ0IwjHiEMWqK+JdkGyYoEQrZtAphcypyuxBnCNo7gNGKSEEoYcutQySm3Yy0atpMYSYTUjJxr5F8ppggOowiRzWGovXcoucW64DyRoKyuRhZQd21A6aCKaYIP0S8btuoOhRQJ5H6GlfVZ0QUF6X0IxlxI1sqb402GS2eggDVyDTQwMmHYFOTTaa/foIiEpTQR3bI7MGESwgukifsuiVPwwuu6oqpCx+bPpNmlQqAXFgTLJkgNKQkgneiShQGQEgASfTK+Iw/sq1qivFgjOdBMWRVUTMKAGFfKCFaTuXljEQRkCRLBAoEHYOX0qIu06gPT2WcWsj2S4j7MtxJBbGg89EnQLoPAhWEhCiQ+6iwH+JrVkrgY+yT0i/EeVwVUwelAjFR2Fgsno4kQqFxIS0pZ1BkKhIxHaNEQQlSwCu8xstxNj8hCs4v8RTnVwiOEEAikRRvHQQBqSMOIraKM9K4IGFnHMSLogmyhUN0lWJfPpqHijyN6UBERTLvUwQQ+KQuCzElKRAp2gehikkpFZU4CiCyjRNRFFXKU0w5hE8ncaWeGImkEpBpAi8lUikeRaIKiPBhCaXRABmoIm1qBrsSXolLIoAgEzL8bzk+JhDKdi2xGxBUFIlRZMr34XdKVEuhvEgS5pZq+QQvShlVRVPKWO8kMcmKdikmRvoTeaC8ntZRY0ncNY8y0Dn2QaCJnCSY3d+Z2YwIAkGVMWHSuqbvWf6Ah1LRXp15xXEASRAkxejFXYuYX0WdCJJjSbjhrR2gznhdTlsqifFU52WCZrCTaMy0ADeiztU+Gf1I40n63Ed1TWNmJnRzMPYUEykTFIsntJDEgu545Ii4sBSLFwy0ohwjgmgYMrqFrgpyNIwwryQyuiDVhFhvnBJej4tEUUxZIZJABIVGpsGu3T2oIkLiWYWZ1+r+djAliIRVE+yrIGlM3fGkRi4+gRaTeBG9Q5XYx5MouoyWk2UrxmcEnFWUNdy10msx9aADsbjYVAFqGn0MzAIOQA8gmGhI1sSFeEmTxagPTsdKGEXX4hDnIXP/R0UZQ0LWFJ5uCsMzXwCi6LyoonMqZqZfJluS4CSUJzEHMy76ABUMgeSygiQncSeoNWBTyAUrHldIj6wmVdyKoSnoaGxpzPdXrlx5Hvnsd7gezEiLmO/nJkcKJjBun4oAjyDKMUxDdEsZVnPAb2cCfBW9AcY6EfV5u+l36BQgrKQMURpArplqtbGjRT+XNp88nC9N9pJcJ1Vbe8pMayJtSypGC6rpj6/g0+ov+UK6kNVILOcYjvBLp7XYKv/xlVIbWmXaLrdi8BUjdftyNp/L6ZXl21NG96CsqmRV11HxVBM3Zp4ned2SQTWSOfp8djV463PlFrRL5Gi51Yo43itYi04jc9+GvKyckig7rwjrmPVsKbQzmAYzlmkwCJcw6WCGyXjsWg5ZlS1Y5N7nfnXyvf/83OBrr3UTrzYAofAP/xk3NWi8qvdD9v5YQfsAZAtQfMb98Y/dZ351663wZ1ricvdNXs5LFy5IaURHsC8nNFOodm27WxVYCcGjXM/TwzSGjEtHztji4tPq6GAmoYqE40eGsOh1oxIRqf+o34ZmENULzcC1KD5HJyMmbOk7QH2HqO8LDzxwEaqdYagWBqqw+MDq3O5BeICQB3i5mJ0BYWPurTfnNjbmiD23sQM+dE9fpTJeqXSLv7hubWas3H36Z5aaya/BxltvzG7AsRmSZbdNWb9KH0Se3OB2cseQFaKsp9517NqJ0ZKKsoLhUJsVNx7LgUGLEQV2ShGyusNrsWw7gWmdVUA69aIqpVUjHjvdMHFoxu8Qr1UT2aGQTrGFQNN0sRJyg2bQhD8t+a0i9FY/vbb8wX7TH1z6ZDoJWk675jaoukN3Tb25d2lwW65ayR8whxOOUZx0s8OJnJortPoKk36BRalaFKsgp53xTs2pTC/AG3ffPXHXXRPwlFEtNhaG/dr8LDRaRa+2J1dTs8Wskaenrxm5zimXRt2VZnW6WigVDb2wvbC8axux0gNjufGxRq5r607L1XNWVs+JOQKy4bQL3mQhDf80ee+9k++Lzgs2bVzixK9JHDsH8S2TGc1NNUMs9VhmZ0dhWPeZzdRVS5JvMCOduDV5LleZd2d2r8Ntt3V/ytpo7NhMZBzYc/6afgfgDuHIgaPnuy9sGYvbWnMd11zGNRcpW9NgVaSHa7EyEql2i1WMOmUloxXRushoTd+yUTKM3g4JsXwsonFsSbSxYm91AGkbPXz79852JgfU/ti4O3dyEubv2z/x7oWWBcPDiDYIPkrf2aMHN2BloliVeER9J+829FCldzx29tv/8q17YOPO755Nt6p3WYU9Dx2cvmVXsbWwXBlfS0vpVJyPx4r+wXvXl45egIabmW1keivQGa3m3/Qmmz86jyPPfjdiwFiz8T+l13AmMmIPPXIGd3oN92HOnE7fvXFgZWm+E9QHKwN9WYw7BLGo6C56lVZUhDNC6ltlAwO9QyyB3XFzVjkygmG3hVZUm0iisdk3E0WdZbcpKk1k9U4GdYRwwZhgkfErjEV2YbNH5MrHihGpNvsaeGwk6pUuS30nt18KRC0mywPLJ/YUlLTW/Xlj3ofGQg1ONOZ8f9Z/a8PqLbfBcejfPrL49b/8+tLFi7u+8dI3Fh6ZaZXz2ZW+4v5KuwqVsHKu4tAjiyvf/pvvruxa453i/jG/8vG/OyCk4t/X225tlnQ2Zv9q4TuPVpvbVwJZGchNKCld6k0Tq0fSf1hsNOYbpFXYul9ItMrV3pUv3rdeb5Dh0fXfr9drxB9ZB7vcSk7v64UvoB2qAcLE06XptJFaOV9v+n6zfn7FMNIdd2x/8Sh/Jdnsr8Ds+uzsyMjfK9e7+zdr68t8nfyey3MjiLsDfbbCcBdhDCl0iil+B4a5YXWA+bzDzjttfI/a7TD64JEDxVrx0suXXmS3y5fgzC9evPS9S0tnCo0iwOVZu0icnu6Xj1+8dNOTH8viSw6OHH0YHj62p3DkyZsuXbzpqWLhE1Gnzbj4KplADCtiXCCVRNew2XFMjXopN+jwEUiZCDwpBKCwTRLD2nF//PhkLQkb1elKTkOSRB5+6SXRKPUOn76QKUHBn58dgMY9uu9P13KU//Wl7uspJ59maTVa73f0YcyrdVyvGp2BilIEgEXPQvqNALl52wEWxliLHelE2Il+FIpSmz5cDrZdd8+zN37iA5ns/ccn1tOZRDY7tVoZLg/3zH/rNuHk8r5gR2BMtMgtbc9eeuKhm6fJAbqXzIdEjB+fJSbpWTm27ZqbBdPYfQK2a4XpkohyYb7/HT9BbsCqUvzajTaTy4qqERErsqbJChEHIwArKEz6NSpFkBwdy6OuCNbmFGMpKrqw8ICotnKoz7I/NkY1CjsPxNBhBR4xLLEPo4nNiZ3Z/wJY9UbaNjsL4GvxG+P2sKim1BLAvjzSHJIzHo+XYrHUcKGkg6irjLmqxnR1dbaR1BPq5PhKEVsU+1OSRqnCxxK2knSyVhKzOlIbpMUyUs4BOaZofSdqfZqu8hF/B1VWBMMqGQO9BMl5TKaftfKUNEofTDtjKdvS0KGWfAStpI4TSZLWqOR4XjMqPbJOaQxotljV9GRs/9rHVxSNtSBnJ6KWd0aSxUY+idzOSNYczy7JYkYgmorwgHRWTRqFfK5mp1RLM5CW69lWcXxOjOg6MkVZjOJkM0fEuT6Mk1xaZfyknBrAdCDa7IaY8z/yPA2693R/01oG+AjEWsvu2/P6KmjwkeVm9zfdu5fJ7ndm8v8CPKXfDgAAAHicY2BkYGAA4sfVJezx/DZfGbiZXwBFGC6enawFoTN+/f/2P57lOnMMkMvBwAQSBQB/jA5jAAAAeJxjYGRgYA76n8UQxcrKwPD/Nct1BqAIChAHAHiUBQF4nGN+wcDATApeAMSRSDQQs7IyMLDoMzAwWUPEQWyQOABfJw8LAAAAAAAAAACgARIBfgH6AoADZgOMA/AEoAfoCFgIpAj6CZYJ0ApACxQLXAuUC+AMqAzfAAEAAAAXAmIACQAAAAAAAgAAABAAcwAAACgLcAAAAAB4nHWRzUrDQBSFz2htsRUXCq6vG7GI6Q+4UDfFQutKoYuCuJAY0yQlzZTJtNBX8B18CF/IZ/EkGaQKZpjJd889c+dOAuAIX1ConivOihXqjCreQQO3jnep3zmuke8d76GFB8d1jifHTVzgxXELx3hnBVXbZzTHh2OFA9VwvINDdex4l/qp4xr50vEeTtS14zr1R8dNTNWz4xbO1OdQLzcmiWIr58O29Lu9K3ndiKaUZH4q/srG2uQykJnObJim2gv0ItdB4qeTMFqlvqmCap2GJk90Jj2vWwnjMAuNb8O3omq+jvrWzmRm9EJGrp4sjZ6HgfVia5c3nc72ORhCY4kNDBJEiGEhOKfa5ruPLnr8AYJXOoTOypUgg4+Uio8Vd8RlJmc84JwxyqiGdKRkDwHXBfOalJQ7J8xG3JsyMr8y2zylq8gmZUVhLx472naM6chKl1+e+PbTa441T+hTteyo6MqUXQhGf/oT3r/IzakE1L3yK1iqN+hw/HOfb9XvfEF4nG2NXXKDMAyErZQQIGlD+pdTcCgHi0SDkV1LJtPb122nb92n3W92ds3G/Koz/+tsDGzgASrYQg07aKCFDvZwgEd4giP0cIJneIFXeIN3ONeLJZ9ygysmDordlAjZTYSuYbzLSoyH4Dh4K8I0UxWJr42UeHNBO8XxxiFZpUZtJM0J2xhEMYUs1fd4J2rTgEvUz94Tz+iIB/nINqHbXqPP0k92xEsI8x8+lY+ygKLDSGn06OpCHeleNC8XjzkGrn9s2umdtJTbdQ6sdlZsHXoaqfwb8wUOrVVCAAAAeJxj8N7BcCIoYiMjY1/kBsadHAwcDMkFGxlYnTYyMGhBaA4UeicDAwMnMouZwWWjCmNHYMQGh46IjcwpLhvVQLxdHA0MjCwOHckhESAlkUCwkYFHawfj/9YNLL0bmRhcAAfTIrgAAAA=') format('woff'), url('data:application/font-ttf;charset=utf-8;base64,AAEAAAAOAIAAAwBgT1MvMj4zSXQAAADsAAAAVmNtYXDQJhm3AAABRAAAAUpjdnQgAAAAAAAAIUgAAAAKZnBnbYiQkFkAACFUAAALcGdhc3AAAAAQAAAhQAAAAAhnbHlmhuOPzAAAApAAABm+aGVhZAeHP8QAABxQAAAANmhoZWEIhgRyAAAciAAAACRobXR4VsIAAAAAHKwAAABcbG9jYUs8Ut8AAB0IAAAAMG1heHAAvA3kAAAdOAAAACBuYW1lBNlwQgAAHVgAAAK1cG9zdF1U2PUAACAQAAABL3ByZXDdawOFAAAsxAAAAHsAAQPGAZAABQAIAnoCvAAAAIwCegK8AAAB4AAxAQIAAAIABQMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUGZFZABA6ADoFQNS/2oAWgNcAKEAAAABAAAAAAAAAAAAAwAAAAMAAAAcAAEAAAAAAEQAAwABAAAAHAAEACgAAAAGAAQAAQACAADoFf//AAAAAOgA//8AABgBAAEAAAAAAAAAAAEGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAv/2/2sD8wNcAEsAZQAItV1UEQUCLSsBLgEnLgEHDgMXHgMXFjMyNjcnDgEnLgEnJj4CNzYWFx4BFxYHDgEnIy4BNREjJicmIyIGBw4BFxYXFhcyNj8BFhcWNzY3NgUGDwEGBwYHBiMuAScmNjc+ATMyFxYXFh8BA+ULYlRc2GplpWsaHQ82SlozXmRFgzs4UrlYUXQaFhVUgU5Uq0hBTAgKGx5EEgIEAVIQEkVSOmgpQSMjI0xGVzBXJA8aLkI6QScq/o4CAgQCAg8WLUA7WRUWFigZQyU0LBsUAgMKAalhpj1BLhcWerTMYzViUkEWJyQkXTEOJSOCVU2gjl8SEiUzL39KYDU1FwUJKA0BOQ4KKSkmPrBUTy0qARoaCyMHCh4iS1EoAgMFAwIVDx8BNS81bSYYGhoRGAMDDQAAAAADAAD/XwOgA1IAAwA7AEQACrdCPzcLAgADLSsBIzcVJS4BJyM0JicOARcVByMiBgcGEhcWNic3HgEXHgEdARYGByMuASc0NjIfATUmBgceATczFjYTAiYDJjY3HgEXJyYBE6LLAhUQYyd5PkRCFgMqvwMwAwRIdYpYBAEBSz8/RgESI2oCHgIVHgoLCosKA141bQysDAM71AEVGx44Ajw2AnvMpSoXKAEEPgQBLxuNLDY6R/71IBBHDnAHXAcBOidcBDEEASMcGxUBAk8EJVhaQQILkAEYARei/rEENwQFSwULCgABAAD/agOhA1IASAAGszkIAS0rATc2OwEfATUnIwcGDwEzDgEHDgEHFQYjJzQnNDc2PwE2OwEfATUnIwcGDwEzDgEHDgEHFQYrARUzETMRNzMRMxE3NSc0JzQ3NgMgDAYIA00XoxoSIhcjAg8ZBgUEAQEEwQELBwgLBggDThekGRMgGSIBDxgHBQMCAQNna8d/SMeVlAELBgKeBgIKAakOBAUOGw4hFAkVCiiPAQFpFxEHBgYCCgGpDgQFDhsOIRQJFQooj6j+FAHoBP4UAegEqAEBaRcRBwABAAD/agL7A1IAVAAGs0UcAS0rJTcWMz4BNCYiBgcUFwc1NxYzPgE0JiIGBxQXBxEjFSc3LgEiBhQWFzI3FxUnNy4BIgYUFhcyNxcVJzcuASIGFBYXMjcXFTM1NxYzPgE0JiIGBxQXBwIXdxEVHigoPCgBAVd4ERQeKCg8KAEBV0VYAQEoPCgoHhMPfFgBASg8KCgeFA97WAEBKDwoKB4UD3tFdxEVHigoPCgBAVfMVwsBKDwoKB4EBT/FWAsBKDwoKB4FBT8BK55ADR4oKDwoAQlaxUAMHigoPCgBCVjTQAsfJyc9JwEJWNNFVwsBKDwoKB4EBT8AAAMAAP9fAy4DUgA3AEMATwAKt01HPjgvCQMtKyUuAScmJyY3PgEXFhceATc+ARYXFgcGBw4BBxYXFhceAQcOAScuAScmJyYGBwYHBicuATU+AT8CLgEnPgE3HgEXDgE3LgEnDgEHHgEXPgEBwztoLAwKJx8NKRgJCFfLVxApIgwZHS8/HT8gCAVXVg4HCAkjFA0TCUFBCQwIQkMfJBMVAQwIqzxqjwIDj2xsjQMDkBIBRjU1RgECRjU0RpIFIiMICicsFAkLBAY6AjgOCg4RKSEuGAwMBAoFVlcPJBETFQEBCwhBQwoCCURCHBAJIxMNFAmr1AOQa2yNAwOQbWuN+zVGAQFHNTVFAQFGAAAJAAAAAAPoAn8AEAAaAB4ANwBbAGwAdQB+AJkAF0AUl5B6dnFtZ2BSPCsoHBsXEg8BCS0rETYzMhceARUUBw4BIwYnFSM3FjcyNjQmIyIHExEzETc0JzMXMz4BNzYWFxUjNTQmJw4BBwYdASMlFgcOASMiJic3HgEzMjY3NSMOASMuASc+ATceARczNzMHBhUHNCcuASMiBgcUFhcyNjc2NQEOARQWMjY0JgcuATQ2MhYUBjcWBiMiJjcyFzUHFTAxFAYjBic2NzIXNTcVMChJUSYSFiMXQSgTEUlJDhYqLysnHg3fSTICQAQCCi8kKD4CShoeFh0GBEoCQwEtFzsfHDYUEQ4sGyUuAQENKx43RAECTTYiKQoBA0ABAUoDBR8YHygBJSMVIAcD/bEcJSU4JSUcFh4eLB4eAgEGBAoCCgMCGgUFCQIBCQIDJgJECCEOLhw6IBYVAQSY0QQBJkUiBP6pASH+38sxJSsSHwEBOkOsoyAoAQEYEQoOqipaKRQPDAs3CA0oLxkUFwFNP0hQAQEaEiYiEx4hDAgVGjIsJjIBGBQMDgFHASU4JCQ4JXUBHSweHiwdIgUGEgIBGwQjBAcBCgkCASgGMgAAAgAA/2oDigNSAAMADwAItQ0HAQACLSsXATMBJS4BJw4BBx4BFz4BXgG6v/5HAmwCWUREWQICWUREWY4D4PwglkNZAgJZQ0NZAgJZAAL//v+EA+kDNwAkADkACLU2LRoBAi0rEzYyMw4BBwYWFxYGBwYHPgE3FjY3FRYGBw4BJyQFLgEnEBMmNgUOARUGFhceATc+ATc2JicuAQcOAaMjRyMkNgUJTkcRAQIKCDZmN3LmZAE+NRg1Gv7W/tZNawMBA10BThogAi8oVdNcM0QCATQqL286QHcDMwMsZztbpDkKJhJVViBJHhYgPsY6YhgMBwEBAQNuTQERARNJc3IaQiUyWR4+CzIcXzs0Wx0iHwIBMAAAAwAA/3MD3wNMACYANQBsAAq3bFI1LiYTAy0rAQYPAQ4BBw4BBw4BFBYXHgEXHgEyNjc+ATc+ATQmJy4BJy4BJy4BFx4BFxYQBwYgJyYQNz4BBwYHDgEXHgEXHgE3NhYXHgEHBiYnLgEOARcGHgE2Nz4BFxY2Nz4BJy4BLwEXHgEjLgEvAi4BAbQHDh4QNxtSbSccFBQcKGxSOVmGWTlSbSccFBQcG0AoJGspIoR7O20tf3+E/rSEf39OxxlNSTIJGQwRAwIGCBV/Lig/AQIvIk90USEBAQogIjJJTT1eixwKAQcILCEXCw0IBRApEAwXI24DRwEDBgMVDCdtUjlZhlk5Um0nHBQUHCdtUjlZhlk5NlQfHDcMCAhNDTwthP60hH9/hAFMhE491gomFSFFJUcSGg8EBBMNDhwFAQwKFw8OFxYPDQ8CCxAFCAoeJAwRExcfCAUbHiEDj2tRBgYDAAgAAP95A9kDRAA3AIUAwAEiAWoBygIUAmEAJ0ESAmACPQHxAcsByQGcAUUBIwEfAO0AqACGAIIAXQAeAAAACAAtKxMwByMGIgcOAQcGBwYVBhAXFh8BFjEXFjIXFjMWMxchNzI3PgE3Njc1Nyc1JjE1NCcmJyYvASYjFzIWMx4BHwMWFxYfAxYUDwEUDwEGDwEwBw4BDwEiByMwByMmKwEmIy4BLwEuAScmLwE1JzUmNDc1MjU+ATc2PwE2NzY3MzY7ATIlMAcmBwYHBgcUBxUGFjEGFxUWHwEwHwEeARUeARcwFhczFjsBNjsBNj8CNjc2ECc1JjUmLwIjJiMXMjMXMh4BFTMXHgEXFhceARcWMRUWHQEGFAcGDwEOAQcGBw4BByMGIwciFQYiJicjJyYvAjQjJicuAScuAS8BNCc1NDc1Nz4BPwEyNTc2Nz4BNzY/ATYzNzI2NzM2OwEyASIHIwciBgcjBwYPARQxFQYxFQYQFhcWHwIWOwEWHwEzFiA3Mz8BNjc+ATcyNTc1Nj0BJzQnNCcmLwEmLwIjNCMvASMmIxcyFzMXFh8BFhUXHgEfAxUWMRUWBxUHFQYHBgcOARUGDwIOATEHBiMUKwEiByMHIyInIyIvASImJyYnLgEnJi8BJjUnNCc1JjQ2NTY/AjY/ATY/AjI3MzczNhclMAcjByIOAgcGBwYHMAcVBhYxBhcVFBYXFh8BFh8CMhYfATMWOwEyNT4BNzY/ATQxMzc2NzY/ATU2ECcuAS8BMC8BJisBJiMXMjMXMx4BFxYfAh4BHwIWMRUyHQEWFAcVBg8CDgEPBSMGKwEvASYnLgEnJi8BMCc1Nz4BNzY/ATY/ATYzPgE3MzI3MzYXUgMFAQICBAwFFggCAQEDEQcCCAIBAgoHAwEhAQUPAQIPGwgHAwEBAQEIFwoMCRSFCwQEAQkUCAoJChMJAQECAQEBAQMCAgwaCgQIEwcDAwEDBxYGAQMBAgcUBwQHEgYOCAMCAQEBAQQDCBEHAgUYHwcCAQkIAXUDBQYgDgQCAQEBAQEBBgcBBQMFBQ8GBQJ8AwVQAQ1YFhEFBAsBAQEBCR8FDQQUhQsCAQYDAwUCFQUBAgsLDRIDAQEBAQQMBQMBAgwQCBMIAgEDBgIGEgsDAgkBAwcRAQQJBAwECA0CAQEBAgIJBgcBBwQDBQ8GCQIFAwEFAQcCBwIBCQj9VAEFBgUECwMCAhcKAwEBAw0FBwIJBgIBAQQGBhUBCBYDBQ8OCgMHAgEEAQEBAgIDBgQDCw4BAgYJBxV8CQUBBQQQDggFCwkQBQIHAQEBAQECAwkVAwMDBgkNAQQJBgMCAQECBgYGCgMEAwQHAQIEEhADAgIZCwICAQEBAgUOBAUBBAcPEREEAwEFAwkBBgGHBwYFBAwBBAUOCQcCAQEBAQECAgECBAkNBwYBAQUIAgIs8hoECwUCAwMBAgwHAgMDAQECFhEFAgsDAQcVfAgCAgMCChYJAwQGAg8VBAIBAQEBAQQPBAYHEwoKAQUPCAQCAhAVAQQGFyQLBgMBAQEBBgQBAwQOEg4BAwcQBgIBBAkBBgNDAQEBAQUDDxoHBRX+9xUYEwYBBQIBBQEBAQECEg4MDkxKfScCAgEDGw4HAwEBYgEBBwUFBwkUGwMDBgYFBhIGDgIFBx4WBwMEBwIBAQEBAQIGBAMEDggSFgoCCwQDDgQIAgUPBhcQBgMDEgUBYQEBAwodCAkBAQwEAhJ/kQ4MDAEGAwMCAwcCAQEBAQUPBgYPERUBCRYEAgMgEAIEAWIBAQEBCAMBAQcLDSAUAgcCCAsCBQYUFAgFAQIOCgUIAgEBAQECAQIBAQIIAQIHAwwFCxsNAwIEDg0GAgkJFQgJAgcFAgUJAwMCAQECAQEB/kwBAQQCAg0YCQECAgMW/vYpEQUGAgUEAQECAQEBBQcMBAsFAg0QDAKKkAECBQcEBgkGAgoHAQIBAWoBAQMIBAMBCAgWCwQTBQUCBQYIDAMEBwkbFgICAQMEBgYBAQMCAQEBAQECAQEGCwMCARUgCAQDAwICAgMVDAIYFQUGAgQHDAgGAQEBAQFqAQEEAQEECQ4MDQENBAETfpEGCAUDBQgMCQQDAQECAQEBBAICAQIBAgkOBAYKBhUBCRUTHwgCAQIBAWoBAQgGAQMEAgseEAcGAgMCAwUUBQIaGAUHCBAFBAECBAEBAwEBAgggFg0NCQIZCAoQCgIFBxQMCQEEBQEBAQEAAAP///+xA+gCwwAZADcARwAKt0M8LSAVAQMtKyURBgcGBw4CKwEiJi8BJicmJxEUFjMhMjYTNS8BJgYnISIGBxQfAR4EFzMyPgM/AT4BNxEUBgchIiY3ETQ2MyEyFgOhEhWVWRwkPBsCGj4RLliWFRIMBgM2BwoBAgMDBAb8ygcKAVLgBCASIBgMAgsaHhQeBeAeNEc0JfzKJDYBNCUDNiU0CwGsFBFyShgcGhoOJkpyERT+VAgKCgJSDg4FBQIDDAZeQbECHA4WCAEKFBAaA7EYUjX9oSU0ATYkAl8lNDQAAgAA/8oDoQNAAAkAKgAItSURBwMCLSsBNy8BDwEXBzcXExQPARMWFRQjIi8BBwYiJjU0NxMnJjU0NyU3NjIfAQUWAnqr62pp7Ksp09P+D8swARcKDPv6DRUMATDLDh8BGH4LIAx9ARggASKlI9XVI6Xrb28BsgwPxf7pBAgcB4SEBxIKBAgBF8UPDBUFKP4XF/4oBQAAAAAEAAD/sQNZAwsAAwAOACQANAANQAoxKRMPCgYCAAQtKzczESM3LgEiBh4BMzEyNgEzNTQmIyIHMzUjFgMzNTQ3PgEzMhUBERQGByEiJjURNDY3ITIWhIGBigEoPiwBKCAhKAFHgVJDSykBgQICgQQIIhhBAQVeQ/3pQ15eQwIXQ149AYN4HSYmOiYm/iLeVlhBOCX+otgWChMcWAFe/ehCXgFgQQIYQl4BYAAABAAA/7ADhQNSADAARQBgAGwADUAKa2VgVTsxJAoELSsBFB4DFxQHDgEnIiYnJjU0Njc2Ny4BJzQ3BiMiJic0Njc+ATsBByMeARUUDgMnMjY3NjU0LgInIgYHBhUUHgMTMj4CJzQuBicmIyIOAxUUHgIBMxUjFSM1IzUzNTMBmiQyNCIBGyicWEqAHxUyKUmYEhABDBoMU3ABKCMrdj/pTUkpKhooJhxRFSwPHhQiPCMYLA8aChogNB0gPDIgAQgIFgoiBigBCBIeOj4uHiZARgHod3c7dnY7AZYUKCIwRiwyLkRCATA0IicuTBouChgiGBQcA2xTLVYeJSQxI04zKEAoICQiFA4gOSBKSCoCFhIhOBo6ODAa/hcOHjQjDhoWGA4aBhoCAQgUHjYgJzwgEgHqPHp6PHkAAQAA/7EDWQMLACQABrMHAAEtKwEyFhURFAYHIxEzNyM1NDY/ATUmIyIGFxUjFTMRISImNRE0NjcCuENeXkNobxB/GiZEI0FLXAFwcP7XQ15eQwMLYEH96EJeAQFMglMfHgEBcwVaUV+C/rRgQQIYQl4BAAABAAD/sQNcAwsASgAGs0cDAS0rARQOASMiJzY/AR4BMzI+ASc0LgEjIg4DBxQWFxY/ATY3NicmNTQ2MzIWFxQGByImNz4CNzQmByIGFRQXBwYXLgE1ND4BMh4BA1lyxnQ+PCEKHws6I0NqPAFEfFA7ZkY0FgEsLBAFBAMCAwkddF9UXgFOOyIoBwQWCgIeHCMwDjcKA3OOdMLuwHgBXnXEdBI0KHYWIEyGVEBuSCI0RkomOlgSBxIRDQQNCyIyVHpcSV+EATAjE0IwExsmAT4xKBzpJzwz1IJ1xHR0xAAAAAgAAP9qBNcDUwAVAB4AJwAwAEEASgBTAIcAFUASd15RTklEPjUvKSYhHRgKBAgtKyUUBw4BIyInJjQ2MzIXHgI2NzYyFiUUBiImPgIWBRQGIiY0PgEWJSYjIgYXFBc2BTQnLgEOAQcGFBceAjY3NhM0JiMiBxYXNgM0LgEGHgEyNhMUBgcWFRQGBw4BIiYnLgE1NDcuATU0NjMyFzY/ATYzMhc+ARcyFg4BIiY1JwcWFzYzMhYDSgcdajmMNQYMCwgIIUpoTCAJEgz+2TBEMgEwRi4BaDBDMjJCMv1eFhslNgEeHgPOi0e2vLZJiopIuLq4RotBNCUcGE4dIlAmNigBJjcmfyYeA1pHTsLIxE5IWAQeIlA4MiaU0FEFEQ3JDjYjLkICPl5CvUbDjSgzOU41CAkhGjsJEQ4HGxICFhkHDtEiMDBEMAI0ICIwMEQwAjSEDzQlKBtOpnxcLzACLDFc+FwvLgIyLVwBFyU0EEBPGwGkGyYBKDUmJv6iJEASFBFOgi8zMjIzL4JOFBQSPiM4UCJfBP8QMx8mAUJcQkItLdwJWyNQAAACAAD/xQQvAvgAHAAtAAi1IR0XCQItKwE1NCYOARURFAYiJj0BMxUUFj4BNRE0Nh4BFxUHFzMVFAYiJj0BFzcVFBY+AScCUSIuIozHjLciLiKMxYwBbd63jMaMSW0gMCIBAcVCFyICHhn+qmKKjGOVkhgiAh4aAVpfiAGIYEwgWpVjjIpjliIglxciAh4ZAAABAAD/sAI7A1IAIgAGsxUFAS0rJRcOASMGLgMnESM1PgQ3PgE7ARUzFSMRFB4CNzYCDywMYjI6YjwuEAFeKEAmGgwCAQQCiLq6BhQkGyxshBMkASAyREIhATB4DjIyQC4aAwTtjP7fER4cEgEBAAAAAQAA//cDiALDAC8ABrMoCAEtKwEGBxUUDgMnIicWMzI3LgEnFjMyNy4BPQEWFy4BNDceARcmNTQ2NzIXNjcGBzYDiCU1KlZ4qGGXfRMYfmI7XBITDxgYP1ImLCUsGUTAcAVqSk81PTUUOzQCbjYnF0mQhmRAAlEDTQJENwIGDWJCAhUCGU5gKlNkBRUUS2gBOQwgQCQGAAAB////9wQ7Al0AhgAGs2EXAS0rARYHBgcGBwYXFhczFRcWHwEeAQ4BIwcGJi8BLgMHIg4DFRQGDwEGByMGLgIvAi4DJyY0PwE2MzceAR8BFhcWHwIeAzI/AT4BPwE2Jy4BLwEmJyY3Njc2FxYXHgIUFgYdAQcGHwEeAR8BFj4CNzY3PgE/AjYXNzYWFwQuDWENFywGChEKJAEBTxwEAgICGhSPDSQLCxEsICQOAQYOCggEAgIKFEAoUkIwEA4PCjw6TiIEAgIJF5kHDAMDCQQLDxcJEB4YFhAHAwIKAgUDAwEIAwQOIQgLCQwdaC4dDA4KBAQBAQECAQoICQUUFiQUIRsCBgMCCwgDoBYcAwIwJIASHjgRFxYMIgEBSTIHBBYQDgMCCgcHDDAmGgQEDBQmGQgOAwMLAQMYIigMDhALUFiUTgkMAwMLAQEGAQIGDBweLRAiMBwQAwMCFBAuHicXJAgGEwUCDAoHDgEBBgMKEBQgHBouFxEKFgwUBAIBDhg0IjpDBggCAgMCAgEDCAYAAgAA/7EDWQMLAA0AHQAItRoSCgMCLSslESERISIGFxEhESEyNhMRFAYHISImNRE0NjchMhYDNf54/vQ0SgEBiQELNEojXkP96UNeXkMCF0NeUgEMAYlKM/70/ndKAkv96EJeAWBBAhhCXgFgAAAAAAEAAAABAADje3+DXw889QALA+gAAAAA0c2TKgAAAADRzWj6//b/XwTXA1wAAAAIAAIAAAAAAAAAAQAAA1L/agBaBQUAAP/rBNcAAQAAAAAAAAAAAAAAAAAAABcD6AAAA+gAAAPoAAAD6AAAA+gAAAPoAAAD6AAAA+gAAAPoAAAD6AAAA+gAAAPoAAADoAAAA1kAAAOgAAADWQAAA1kAAAUFAAAELwAAAjsAAAOgAAAELwAAA1kAAAAAAAAAoAESAX4B+gKAA2YDjAPwBKAH6AhYCKQI+gmWCdAKQAsUC1wLlAvgDKgM3wABAAAAFwJiAAkAAAAAAAIAAAAQAHMAAAAoC3AAAAAAAAAAEgDeAAEAAAAAAAAANQAAAAEAAAAAAAEABgA1AAEAAAAAAAIABwA7AAEAAAAAAAMABgBCAAEAAAAAAAQABgBIAAEAAAAAAAUACwBOAAEAAAAAAAYABgBZAAEAAAAAAAoAKwBfAAEAAAAAAAsAEwCKAAMAAQQJAAAAagCdAAMAAQQJAAEADAEHAAMAAQQJAAIADgETAAMAAQQJAAMADAEhAAMAAQQJAAQADAEtAAMAAQQJAAUAFgE5AAMAAQQJAAYADAFPAAMAAQQJAAoAVgFbAAMAAQQJAAsAJgGxQ29weXJpZ2h0IChDKSAyMDE1IGJ5IG9yaWdpbmFsIGF1dGhvcnMgQCBmb250ZWxsby5jb21zb2NpYWxSZWd1bGFyc29jaWFsc29jaWFsVmVyc2lvbiAxLjBzb2NpYWxHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuaHR0cDovL2ZvbnRlbGxvLmNvbQBDAG8AcAB5AHIAaQBnAGgAdAAgACgAQwApACAAMgAwADEANQAgAGIAeQAgAG8AcgBpAGcAaQBuAGEAbAAgAGEAdQB0AGgAbwByAHMAIABAACAAZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AcwBvAGMAaQBhAGwAUgBlAGcAdQBsAGEAcgBzAG8AYwBpAGEAbABzAG8AYwBpAGEAbABWAGUAcgBzAGkAbwBuACAAMQAuADAAcwBvAGMAaQBhAGwARwBlAG4AZQByAGEAdABlAGQAIABiAHkAIABzAHYAZwAyAHQAdABmACAAZgByAG8AbQAgAEYAbwBuAHQAZQBsAGwAbwAgAHAAcgBvAGoAZQBjAHQALgBoAHQAdABwADoALwAvAGYAbwBuAHQAZQBsAGwAbwAuAGMAbwBtAAAAAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFwAAAQIBAwEEAQUBBgEHAQgBCQEKAQsBDAENAQ4BDwEQAREBEgETARQBFQEWARcGbWFpbHJ1CGV2ZXJub3RlCmZyaWVuZGZpZWQIbmV3c3ZpbmUMb2Rub2xhc3NuaWtpBHBpbmcIc2xhc2hkb3QKdGVjaG5vcmF0aQh0YXBpdHVyZQlwb3N0ZXJvdXMEbWFpbApzdGFyLWVtcHR5EGxpbmtlZGluLXNxdWFyZWQFZ3BsdXMQZmFjZWJvb2stc3F1YXJlZBFwaW50ZXJlc3QtY2lyY2xlZAZyZWRkaXQLc3R1bWJsZXVwb24GdHVtYmxyB3R3aXR0ZXIJdmtvbnRha3RlCWRlbGljaW91cwAAAAABAAH//wAPAAAAAAAAAAAAAAAAsAAsILAAVVhFWSAgS7gADlFLsAZTWliwNBuwKFlgZiCKVViwAiVhuQgACABjYyNiGyEhsABZsABDI0SyAAEAQ2BCLbABLLAgYGYtsAIsIGQgsMBQsAQmWrIoAQpDRWNFUltYISMhG4pYILBQUFghsEBZGyCwOFBYIbA4WVkgsQEKQ0VjRWFksChQWCGxAQpDRWNFILAwUFghsDBZGyCwwFBYIGYgiophILAKUFhgGyCwIFBYIbAKYBsgsDZQWCGwNmAbYFlZWRuwAStZWSOwAFBYZVlZLbADLCBFILAEJWFkILAFQ1BYsAUjQrAGI0IbISFZsAFgLbAELCMhIyEgZLEFYkIgsAYjQrEBCkNFY7EBCkOwAGBFY7ADKiEgsAZDIIogirABK7EwBSWwBCZRWGBQG2FSWVgjWSEgsEBTWLABKxshsEBZI7AAUFhlWS2wBSywB0MrsgACAENgQi2wBiywByNCIyCwACNCYbACYmawAWOwAWCwBSotsAcsICBFILALQ2O4BABiILAAUFiwQGBZZrABY2BEsAFgLbAILLIHCwBDRUIqIbIAAQBDYEItsAkssABDI0SyAAEAQ2BCLbAKLCAgRSCwASsjsABDsAQlYCBFiiNhIGQgsCBQWCGwABuwMFBYsCAbsEBZWSOwAFBYZVmwAyUjYUREsAFgLbALLCAgRSCwASsjsABDsAQlYCBFiiNhIGSwJFBYsAAbsEBZI7AAUFhlWbADJSNhRESwAWAtsAwsILAAI0KyCwoDRVghGyMhWSohLbANLLECAkWwZGFELbAOLLABYCAgsAxDSrAAUFggsAwjQlmwDUNKsABSWCCwDSNCWS2wDywgsBBiZrABYyC4BABjiiNhsA5DYCCKYCCwDiNCIy2wECxLVFixBGREWSSwDWUjeC2wESxLUVhLU1ixBGREWRshWSSwE2UjeC2wEiyxAA9DVVixDw9DsAFhQrAPK1mwAEOwAiVCsQwCJUKxDQIlQrABFiMgsAMlUFixAQBDYLAEJUKKiiCKI2GwDiohI7ABYSCKI2GwDiohG7EBAENgsAIlQrACJWGwDiohWbAMQ0ewDUNHYLACYiCwAFBYsEBgWWawAWMgsAtDY7gEAGIgsABQWLBAYFlmsAFjYLEAABMjRLABQ7AAPrIBAQFDYEItsBMsALEAAkVUWLAPI0IgRbALI0KwCiOwAGBCIGCwAWG1EBABAA4AQkKKYLESBiuwcisbIlktsBQssQATKy2wFSyxARMrLbAWLLECEystsBcssQMTKy2wGCyxBBMrLbAZLLEFEystsBossQYTKy2wGyyxBxMrLbAcLLEIEystsB0ssQkTKy2wHiwAsA0rsQACRVRYsA8jQiBFsAsjQrAKI7AAYEIgYLABYbUQEAEADgBCQopgsRIGK7ByKxsiWS2wHyyxAB4rLbAgLLEBHistsCEssQIeKy2wIiyxAx4rLbAjLLEEHistsCQssQUeKy2wJSyxBh4rLbAmLLEHHistsCcssQgeKy2wKCyxCR4rLbApLCA8sAFgLbAqLCBgsBBgIEMjsAFgQ7ACJWGwAWCwKSohLbArLLAqK7AqKi2wLCwgIEcgILALQ2O4BABiILAAUFiwQGBZZrABY2AjYTgjIIpVWCBHICCwC0NjuAQAYiCwAFBYsEBgWWawAWNgI2E4GyFZLbAtLACxAAJFVFiwARawLCqwARUwGyJZLbAuLACwDSuxAAJFVFiwARawLCqwARUwGyJZLbAvLCA1sAFgLbAwLACwAUVjuAQAYiCwAFBYsEBgWWawAWOwASuwC0NjuAQAYiCwAFBYsEBgWWawAWOwASuwABa0AAAAAABEPiM4sS8BFSotsDEsIDwgRyCwC0NjuAQAYiCwAFBYsEBgWWawAWNgsABDYTgtsDIsLhc8LbAzLCA8IEcgsAtDY7gEAGIgsABQWLBAYFlmsAFjYLAAQ2GwAUNjOC2wNCyxAgAWJSAuIEewACNCsAIlSYqKRyNHI2EgWGIbIVmwASNCsjMBARUUKi2wNSywABawBCWwBCVHI0cjYbAJQytlii4jICA8ijgtsDYssAAWsAQlsAQlIC5HI0cjYSCwBCNCsAlDKyCwYFBYILBAUVizAiADIBuzAiYDGllCQiMgsAhDIIojRyNHI2EjRmCwBEOwAmIgsABQWLBAYFlmsAFjYCCwASsgiophILACQ2BkI7ADQ2FkUFiwAkNhG7ADQ2BZsAMlsAJiILAAUFiwQGBZZrABY2EjICCwBCYjRmE4GyOwCENGsAIlsAhDRyNHI2FgILAEQ7ACYiCwAFBYsEBgWWawAWNgIyCwASsjsARDYLABK7AFJWGwBSWwAmIgsABQWLBAYFlmsAFjsAQmYSCwBCVgZCOwAyVgZFBYIRsjIVkjICCwBCYjRmE4WS2wNyywABYgICCwBSYgLkcjRyNhIzw4LbA4LLAAFiCwCCNCICAgRiNHsAErI2E4LbA5LLAAFrADJbACJUcjRyNhsABUWC4gPCMhG7ACJbACJUcjRyNhILAFJbAEJUcjRyNhsAYlsAUlSbACJWG5CAAIAGNjIyBYYhshWWO4BABiILAAUFiwQGBZZrABY2AjLiMgIDyKOCMhWS2wOiywABYgsAhDIC5HI0cjYSBgsCBgZrACYiCwAFBYsEBgWWawAWMjICA8ijgtsDssIyAuRrACJUZSWCA8WS6xKwEUKy2wPCwjIC5GsAIlRlBYIDxZLrErARQrLbA9LCMgLkawAiVGUlggPFkjIC5GsAIlRlBYIDxZLrErARQrLbA+LLA1KyMgLkawAiVGUlggPFkusSsBFCstsD8ssDYriiAgPLAEI0KKOCMgLkawAiVGUlggPFkusSsBFCuwBEMusCsrLbBALLAAFrAEJbAEJiAuRyNHI2GwCUMrIyA8IC4jOLErARQrLbBBLLEIBCVCsAAWsAQlsAQlIC5HI0cjYSCwBCNCsAlDKyCwYFBYILBAUVizAiADIBuzAiYDGllCQiMgR7AEQ7ACYiCwAFBYsEBgWWawAWNgILABKyCKimEgsAJDYGQjsANDYWRQWLACQ2EbsANDYFmwAyWwAmIgsABQWLBAYFlmsAFjYbACJUZhOCMgPCM4GyEgIEYjR7ABKyNhOCFZsSsBFCstsEIssDUrLrErARQrLbBDLLA2KyEjICA8sAQjQiM4sSsBFCuwBEMusCsrLbBELLAAFSBHsAAjQrIAAQEVFBMusDEqLbBFLLAAFSBHsAAjQrIAAQEVFBMusDEqLbBGLLEAARQTsDIqLbBHLLA0Ki2wSCywABZFIyAuIEaKI2E4sSsBFCstsEkssAgjQrBIKy2wSiyyAABBKy2wSyyyAAFBKy2wTCyyAQBBKy2wTSyyAQFBKy2wTiyyAABCKy2wTyyyAAFCKy2wUCyyAQBCKy2wUSyyAQFCKy2wUiyyAAA+Ky2wUyyyAAE+Ky2wVCyyAQA+Ky2wVSyyAQE+Ky2wViyyAABAKy2wVyyyAAFAKy2wWCyyAQBAKy2wWSyyAQFAKy2wWiyyAABDKy2wWyyyAAFDKy2wXCyyAQBDKy2wXSyyAQFDKy2wXiyyAAA/Ky2wXyyyAAE/Ky2wYCyyAQA/Ky2wYSyyAQE/Ky2wYiywNysusSsBFCstsGMssDcrsDsrLbBkLLA3K7A8Ky2wZSywABawNyuwPSstsGYssDgrLrErARQrLbBnLLA4K7A7Ky2waCywOCuwPCstsGkssDgrsD0rLbBqLLA5Ky6xKwEUKy2wayywOSuwOystsGwssDkrsDwrLbBtLLA5K7A9Ky2wbiywOisusSsBFCstsG8ssDorsDsrLbBwLLA6K7A8Ky2wcSywOiuwPSstsHIsswkEAgNFWCEbIyFZQiuwCGWwAyRQeLABFTAtAEu4AMhSWLEBAY5ZsAG5CAAIAGNwsQAFQrEAACqxAAVCsQAIKrEABUKxAAgqsQAFQrkAAAAJKrEABUK5AAAACSqxAwBEsSQBiFFYsECIWLEDZESxJgGIUVi6CIAAAQRAiGNUWLEDAERZWVlZsQAMKrgB/4WwBI2xAgBEAA==') format('truetype');\n  }\n\n.need-share-button_dropdown [class^=\"social-\"]:before, .need-share-button_dropdown [class*=\" social-\"]:before {\n    font-family: \"social-icons\";\n    font-style: normal;\n    font-weight: normal;\n    speak: none;\n  \n    display: inline-block;\n    text-decoration: inherit;\n    width: 1em;\n    margin-right: .2em;\n    text-align: center;\n    /* opacity: .8; */\n  \n    /* For safety - reset parent styles, that can break glyph codes*/\n    font-variant: normal;\n    text-transform: none;\n  \n    /* fix buttons height, for twitter bootstrap */\n    line-height: 1em;\n  \n    /* Animation center compensation - margins should be symmetric */\n    /* remove if not needed */\n    margin-left: .2em;\n  \n    /* you can be more comfortable with increased icons size */\n    /* font-size: 120%; */\n  \n    /* Uncomment for 3D effect */\n    /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */\n  }\n\n.social-mailto:before { content: '\\e80a'; }\n.social-twitter:before { content: '\\e813'; }\n.social-pinterest:before { content: '\\e80f'; }\n.social-facebook:before { content: '\\e80e'; }\n.social-googleplus:before { content: '\\e80d'; }\n.social-reddit:before { content: '\\e810'; }\n.social-linkedin:before { content: '\\e80c'; }\n.social-tumblr:before { content: '\\e812'; }\n.social-evernote:before { content: '\\e801'; }\n.social-delicious:before { content: '\\e815'; }\n.social-stumbleupon:before { content: '\\e811'; }\n.social-slashdot:before { content: '\\e806'; }\n.social-technorati:before { content: '\\e807'; }\n.social-posterous:before { content: '\\e809'; }\n.social-googlebookmarks:before { content: '\\e80b'; }\n.social-newsvine:before { content: '\\e803'; }\n.social-friendfeed:before { content: '\\e802'; }\n.social-vkontakte:before { content: '\\e814'; }\n.social-odnoklassniki:before { content: '\\e804'; }\n.social-mailru:before { content: '\\e800'; }\n\n/* FONTELLO ICON */\n\n@font-face {\n  font-family: 'fontello';\n  src: url('../font/fontello.eot?34242489');\n  src: url('../font/fontello.eot?34242489#iefix') format('embedded-opentype'),\n       url('../font/fontello.svg?34242489#fontello') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n@font-face {\n  font-family: 'fontello';\n  src: url('data:application/octet-stream;base64,d09GRgABAAAAAA7IAA8AAAAAGBAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABWAAAADsAAABUIIslek9TLzIAAAGUAAAAQwAAAFY+S1NOY21hcAAAAdgAAABqAAABqkbJ0JZjdnQgAAACRAAAABMAAAAgBtX/BGZwZ20AAAJYAAAFkAAAC3CKkZBZZ2FzcAAAB+gAAAAIAAAACAAAABBnbHlmAAAH8AAABBsAAAToO/jZ62hlYWQAAAwMAAAAMwAAADYPhh2FaGhlYQAADEAAAAAgAAAAJAfKA91obXR4AAAMYAAAABQAAAAUE4f//mxvY2EAAAx0AAAADAAAAAwChAN+bWF4cAAADIAAAAAgAAAAIAETDBZuYW1lAAAMoAAAAXcAAALNzJ0dH3Bvc3QAAA4YAAAAMwAAAEYXwzMzcHJlcAAADkwAAAB6AAAAhuVBK7x4nGNgZGBg4GIwYLBjYHJx8wlh4MtJLMljkGJgYYAAkDwymzEnMz2RgQPGA8qxgGkOIGaDiAIAJjsFSAB4nGNgZH7BOIGBlYGBqYppDwMDQw+EZnzAYMjIBBRlYGVmwAoC0lxTGBxeaH+8zhz0P4shijmIYRpQmBEkBwAenQ0gAHic7ZHLDYAgEERnZTXE2IkW4NFiPNkK/UELXrcC3A9lOOSR2QlwGADMAJJyKAzQA4Lp1pQ8T1g9Z5w6Z10T8O5SpPU+XDXnIj+R3U16195c8Gvz/RoTW2+BtSwlsGalBvYr0gLwBz3aG2gAAHicY2BAAxIQyBz0PwuEARJsA90AeJytVml300YUHXlJnIQsJQstamHExGmwRiZswYAJQbJjIF2crZWgixQ76b7xid/gX/Nk2nPoN35a7xsvJJC053Cak6N3583VzNtlElqS2AvrkZSbL8XU1iaN7DwJ6YZNy1F8KDt7IWWKyd8FURCtltq3HYdERCJQta6wRBD7HlmaZHzoUUbLtqRXTcotPekuW+NBvVXffho6yrE7oaRmM3RoPbIlVRhVokimPVLSpmWo+itJK7y/wsxXzVDCiE4iabwZxtBI3htntMpoNbbjKIpsstwoUiSa4UEUeZTVEufkigkMygfNkPLKpxHlw/yIrNijnFawS7bT/L4vead3OT+xX29RtuRAH8iO7ODsdCVfhFtbYdy0k+0oVBF213dCbNnsVP9mj/KaRgO3KzK90IxgqXyFECs/ocz+IVktnE/5kkejWrKRE0HrZU7sSz6B1uOIKXHNGFnQ3dEJEdT9kjMM9pg+Hvzx3imWCxMCeBzLekclnAgTKWFzNEnaMHJgJWWLKqn1rpg45XVaxFvCfu3a0ZfOaONQd2I8Ww8dWzlRyfFoUqeZTJ3aSc2jKQ2ilHQmeMyvAyg/oklebWM1iZVH0zhmxoREIgIt3EtTQSw7saQpBM2jGb25G6a5di1apMkD9dyj9/TmVri501PaDvSzRn9Wp2I62AvT6WnkL/Fp2uUiRen66Rl+TOJB1gIykS02w5SDB2/9DtLL15YchdcG2O7t8yuofdZE8KQB+xvQHk/VKQlMhZhViFZAYq1rWZbJ1awWqcjUd0OaVr6s0wSKchwXx76Mcf1fMzOWmBK+34nTsyMuPXPtSwjTHHybdT2a16nFcgFxZnlOp1mW7+s0x/IDneZZntfpCEtbp6MsP9RpgeVHOh1jeUELmnTfwZCLMOQCDpAwhKUDQ1hegiEsFQxhuQhDWBZhCMslGMLyYxjCchmGsLysZdXUU0nj2plYBmxCYGKOHrnMReVqKrlUQrtoVGpDnhJulVQUz6p/ZaBePPKGObAWSJfIml8xzpWPRuX41hUtbxo7V8Cx6m8fjvY58VLWi4U/Bf/V1lQlvWLNw5Or8BuGnmwnqjapeHRNl89VPbr+X1RUWAv0G0iFWCjKsmxwZyKEjzqdhmqglUPMbMw8tOt1y5qfw/03MUIWUP34NxQaC9yDTllJWe3grNXX27LcO4NyOBMsSTE38/pW+CIjs9J+kVnKno98HnAFjEpl2GoDrRW82ScxD5neJM8EcVtRNkja2M4EiQ0c84B5850EJmHqqg3kTuGGDfgFYW7BeSdconqjLIfuRezzKKT8W6fiRPaoaIzAs9kbYa/vQspvcQwkNPmlfgxUFaGpGDUV0DRSbqgGX8bZum1Cxg70Iyp2w7Ks4sPHFveVkm0ZhHykiNWjo5/WXqJOqtx+ZhSX752+BcEgNTF/e990cZDKu1rJMkdtA1O3GpVT15pD41WH6uZR9b3j7BM5a5puuiceel/TqtvBxVwssPZtDtJSJhfU9WGFDaLLxaVQ6mU0Se+4BxgWGNDvUIqN/6v62HyeK1WF0XEk307Ut9HnYAz8D9h/R/UD0Pdj6HINLs/3mhOfbvThbJmuohfrp+g3MGutuVm6BtzQdAPiIUetjrjKDXynBnF6pLkc6SHgY90V4gHAJoDF4BPdtYzmUwCj+Yw5PsDnzGHQZA6DLeYw2GbOGsAOcxjsMofBHnMYfMGcdYAvmcMgZA6DiDkMnjAnAHjKHAZfMYfB18xh8A1z7gN8yxwGMXMYJMxhsK/p1jDMLV7QXaC2QVWgA1NPWNzD4lBTZcj+jheG/b1BzP7BIKb+qOn2kPoTLwz1Z4OY+otBTP1V050h9TdeGOrvBjH1D4OY+ky/GMtlBr+MfJcKB5RdbD7n74n3D9vFQLkAAQAB//8AD3icZVPfT9tWFL7nXvvasR3HcYydBGNSxzihQQbSxNYYhRCFH6MhtIwhqBBFFTDUFtiqisLU7WXdVCGKpq7SpgmhCXV7nDRp2tOe9jDtf9jDXvswTer7Bruhe9os697j75x7zvH5vouE87PzX8gr/BeKoRTqQiU0i9bQPsrUzDoggEnE1h2E0MZ4ozyIeaPUEwZABepAGL22LDO0VAhgBCwHogALKjNwNAKRoZKARJWQ2ZbZPjIKYdlkfqcdQRxgZiGAKPQF6hd8ltCMLsA2xhLRoF3EhH1ZKvTJcckPajxVdRJLitp65qMP+ioP3hwJn/OLz64/eiHyN4/mPjz9pjh359nxlw+auDW58nPRy2CO8nJrr5wBTuKEXMUrWqrEp+OKyssDXjyNiaa49UeDtsnbjsppxsTqgJYVda3x5NOUn9SSKd/Q3xE0ngq6iGn1jYq/uVnRtLVL1bmiGH8893qb9VvNsEhzU6ujtWeTK9NF74ZIMZBL4zVBpBxIuWEY6mzkFIWw4vlQZGVVkwjGWHg0mtCUrBaszTgy0R0bJy4jgtD592SJECQiHdnIqCUzHfEYJRSNt9lIAt9R4qlbYGN2gCQNKvjVygiAIQRQSDoY7936bXVmW09t/3r0/vrKKV5av38Iay+Ws9XqwOHs9QP8x9mrw5fR3vHmj7tn9473opeHkEju/YAY4+j8DvmdzKENdLU2dGspK3KA3g7LhABuC4IgIFuIYPbeZc0oUwjj+BTiuDj31tR4fWx4qOD38azBFOspjBixbA2vlC2HdoPZYdAuMMoCY9qgeTfg8wIVHMw0JLQ/oZ/RzzTAzH+1w1RTLbRxl8FC3mVSqVa+4BURJHFjcubda9OdgZs1VZWHbomDUhlMg3lVTgI2/14lcHjAxPukqxbk46LHWauB4dcDH5QkzbEs0FkXCealogWY/Qh8JuuyKyqu0PrW7emWHfdyMQxyuL9HdCgLqL03nK6JiqZqGC8UZCObxioJJUXmMIaMiUU1l7IMHRRgD6abHlYsj3DQnfkKIcpm+5R7SAYYrwa7b71oAi2izdq6l8AEXy3jGGlODxM5RiavgdxAEpJ22PAB7fAAIruJoiLuCEBwDJPYForJOCbfRbK8jRSMlXmkKHiRAlZwc2F+dqZRr17Jd3gpw/NSepzvKkHFd1UwyyEzBJcKhmmVQ8JAavwHLPh5FmkZFuPEb1OSF6ILhVllh6mMClbhgi2GRG2kYfd74Ac2nNimloZswrQ/ZpDXb8NtpyPBENW0P9fNlZNliBt6IqtnhIB/Wjy999PW7e92YblZ796Z95l7+WTl5skqvmHZTsnOnv2dyLKzLGUa+v4H/UkWni/09WLM5itN7N//up1+6vHZw7HdwfVho/Xk5KAJrQP0D0Q/xGYAeJxjYGRgYADiZ4l/fOP5bb4ycDO/AIowXP3x5hOM/v/vfxZLOXMQkMvBwAQSBQDMRxC+AHicY2BkYGAO+p/FwMBS9v/f/+8s5QxAERTACgCiiQauA+gAAAPo//4DWQAAA+gAAAR2AAAAAAAAAMwBCgG4AnQAAQAAAAUAegAHAAAAAAACABoAKgBzAAAAeQtwAAAAAHicdZDdasIwGIbfzJ9tCtvYYKfL0VDG6g8MQRAEh55sJzI8HbXWtlIbSaPgbewedjG7iV3LXts4hrKWNM/35MuXrwFwjW8I5M8TR84CZ4xyPsEpepYL9M+Wi+QXyyVU8Wa5TP9uuYIHBJaruMEHK4jiOaMFPi0LXIlLyye4EHeWC/SPlovknuUSbsWr5TK9Z7mCiUgtV3EvvgZqtdVREBpZG9Rlu9nqyOlWKqoocWPprk2odCr7cq4S48excjy13PPYD9axq/fhfp74Oo1UIltOc69GfuJr1/izXfV0E7SNmcu5Vks5tBlypdXC94wTGrPqNhp/z8MACitsoRHxqkIYSNRo65zbaKKFDmnKDMnMPCtCAhcxjYs1d4TZSsq4zzFnlND6zIjJDjx+l0d+TAq4P2YVfbR6GE9IuzOizEv25bC7w6wRKcky3czOfntPseFpbVrDXbsuddaVxPCghuR97NYWNB69k92Koe2iwfef//sB5m6EUQB4nGNgYoAALgbsgJWRiZGZkYWRlZGNgbU8NTMpn60oNQ+ImAoL2cpTkzMSSxgYAHR0CDwAeJxj8N7BcCIoYiMjY1/kBsadHAwcDMkFGxlYnTYxMDJogRibuZgYOSAsPgYwi81pF9MBoDQnkM3utIvBAcJmZnDZqMLYERixwaEjYiNzistGNRBvF0cDAyOLQ0dySARISSQQbOZhYuTR2sH4v3UDS+9GJgYXAAx2I/QAAA==') format('woff'),\n       url('data:application/octet-stream;base64,AAEAAAAPAIAAAwBwR1NVQiCLJXoAAAD8AAAAVE9TLzI+S1NOAAABUAAAAFZjbWFwRsnQlgAAAagAAAGqY3Z0IAbV/wQAAAv4AAAAIGZwZ22KkZBZAAAMGAAAC3BnYXNwAAAAEAAAC/AAAAAIZ2x5Zjv42esAAANUAAAE6GhlYWQPhh2FAAAIPAAAADZoaGVhB8oD3QAACHQAAAAkaG10eBOH//4AAAiYAAAAFGxvY2EChAN+AAAIrAAAAAxtYXhwARMMFgAACLgAAAAgbmFtZcydHR8AAAjYAAACzXBvc3QXwzMzAAALqAAAAEZwcmVw5UErvAAAF4gAAACGAAEAAAAKADAAPgACREZMVAAObGF0bgAaAAQAAAAAAAAAAQAAAAQAAAAAAAAAAQAAAAFsaWdhAAgAAAABAAAAAQAEAAQAAAABAAgAAQAGAAAAAQAAAAED6AGQAAUAAAJ6ArwAAACMAnoCvAAAAeAAMQECAAACAAUDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFBmRWQAQOgr8dcDUv9qAFoDUgCWAAAAAQAAAAAAAAAAAAUAAAADAAAALAAAAAQAAAFqAAEAAAAAAGQAAwABAAAALAADAAoAAAFqAAQAOAAAAAgACAACAADoK/GL8df//wAA6Cvxi/HW//8AAAAAAAAAAQAIAAgACAAAAAEAAgADAAQAAAEGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAAAAAEAAAAAAAAAABAAA6CsAAOgrAAAAAQAA8YsAAPGLAAAAAgAA8dYAAPHWAAAAAwAA8dcAAPHXAAAABAAAAAf//v/GA/EC/AAJABMAHQArAE8AZAB5ABlAFkIBAAEBRwABAAFvAAAAZkVEMjECBRQrJTYuAQYHBh4BNjc2LgEGBwYXFjYXDgEuAT4BFx4BNy4CBw4BFx4CNz4BNxQOAy4DNzQ2Nz4BFxYHBh4BPwE2MhYHDgEeARceAgMeAQcOAScuATc2JgcGJicmNjc2FjceAQcOAS4BNzYuAgcGLgE2NzYWAXkLCicsCw0KJi5ABQYOEgMJEQgQZRl+eiw0dDs+NpQFWJJQfKQIBVqOUn2ipShSapKcmHRMAk5HXsIoJBkCBAYFC054MhkBBAoEByA0JCgXDgoFGA0MDgULMCQNGAIDEAwiQnwxHBYFHB4OBBAURmAwEBoIEhBEiIYTJhEQERMmFBJVBxAFBgcSCAIGNTk0JmhoNBAQZCE1UigIDYRSNVIoCA2ETyZOTDYoBiBIYD9AkkdeSigkUQgGAgEDIUVABwgGBAEKIDwBOhtEIAwMAwUYDSM2CAMQDA4WAwcUQTaOPw8QDBoQLmRNHgsDEh4cAg8qAAMAAP+xA1kDAwAIABIAHAAUQBEZFQ0JBgMGAEUAAABmEQEFFSsFBiInPgE3HgEDERQGByY1ND4BARQHLgEnER4CAnhf22BNbhITbsiOcWVeogJZZXKMAWSkXBo1NTCMT1CKAuz+8YzoN3icaLZ2/myceDfojAEPEXi0AAABAAD/agPfA1IAZgA9QDpfWRoIBAEAUzYyAwMBAkcAAQADAAEDbQADAgADAmsAAAAMSAACAg1IAAQEDQRJSEVCQTw6JyYsBQUVKxMmNTQ2NyY2NzQ2NzYzMhceBh8BFhUUBh0BFDIHHgEHFAYjIi4FIwcGBx4CFw4BBwYjIi4BLwEuAQcOASMiLgM3NDY3PgE/ATY1Jy4BLwEiBw4BByMiJicmNTSXBQwIAQoIZkdNZ0tKGy4iGhYODgUBHwoEASsyARYUBQwIDgQKAQEDISkMLh4FAQIDJIUdQC4jDQgkBBdgLhQmQi4mAQwRBiAMCAEBG0IIAwIFCigXAQICAg0BkAsSCyIIDCIHTqYiJR8LHiIqKDYuIAIvJQgeBgICAkBwPBhACAwQDhACAlYnCxQaGAIOAzYKDAsEAgIBGRYCCA4gExcUEgEMAQEBAQIGaCQCDBckAwQBHxmaAAAGAAD/jQR3AzAACAAUAB0AKQBGAFgAaEBlJA8CAwI9MgIJA0xKPAMLCQNHSwELRAAKAApvBAEAAQBvBQEBCAFvAAgMCG8HAQMCCQIDCW0ACQsCCQtrAAsLbgAMAgIMVAAMDAJYBgECDAJMVlRPTURCNTMjFSQTFCQkExINBR0rATQmIg4BFjI2ATQmByIGBxQWFzI2AzQmIgYUFjI2ATQmByIGBxQWFzI2JyYjIg4BFxQXBiMiJi8BLgEjBzcmNTQ+ARcyHgEBFAYHFycGIyIuATQ+ATcyHgEBRBwvJAEmLhwBnhwWEBgBGg8WHIMcLyQkLxwBYh4VDxgBGg4WHJMSFl6eXAENFBIPGhIZBy4FjSiibLxtYq52AVxMQh9vVCZenlxcnl5anmACURccHiscGv79DxoBGg4QGAEYASwXHB4rHBr+/Q8aARoOEBgBGO4DVpRWLCkCAgMEAQpGeXKgXp5cAUiE/ndBdjFlPBROiJ6KTAFOigAAAQAAAAEAAOZh/E1fDzz1AAsD6AAAAADV+OzyAAAAANX47PL//v9qBHcDUgAAAAgAAgAAAAAAAAABAAADUv9qAAAEdv/+//cEdwABAAAAAAAAAAAAAAAAAAAABQPoAAAD6P/+A1kAAAPoAAAEdgAAAAAAAADMAQoBuAJ0AAEAAAAFAHoABwAAAAAAAgAaACoAcwAAAHkLcAAAAAAAAAASAN4AAQAAAAAAAAA1AAAAAQAAAAAAAQAIADUAAQAAAAAAAgAHAD0AAQAAAAAAAwAIAEQAAQAAAAAABAAIAEwAAQAAAAAABQALAFQAAQAAAAAABgAIAF8AAQAAAAAACgArAGcAAQAAAAAACwATAJIAAwABBAkAAABqAKUAAwABBAkAAQAQAQ8AAwABBAkAAgAOAR8AAwABBAkAAwAQAS0AAwABBAkABAAQAT0AAwABBAkABQAWAU0AAwABBAkABgAQAWMAAwABBAkACgBWAXMAAwABBAkACwAmAclDb3B5cmlnaHQgKEMpIDIwMTcgYnkgb3JpZ2luYWwgYXV0aG9ycyBAIGZvbnRlbGxvLmNvbWZvbnRlbGxvUmVndWxhcmZvbnRlbGxvZm9udGVsbG9WZXJzaW9uIDEuMGZvbnRlbGxvR2VuZXJhdGVkIGJ5IHN2ZzJ0dGYgZnJvbSBGb250ZWxsbyBwcm9qZWN0Lmh0dHA6Ly9mb250ZWxsby5jb20AQwBvAHAAeQByAGkAZwBoAHQAIAAoAEMAKQAgADIAMAAxADcAIABiAHkAIABvAHIAaQBnAGkAbgBhAGwAIABhAHUAdABoAG8AcgBzACAAQAAgAGYAbwBuAHQAZQBsAGwAbwAuAGMAbwBtAGYAbwBuAHQAZQBsAGwAbwBSAGUAZwB1AGwAYQByAGYAbwBuAHQAZQBsAGwAbwBmAG8AbgB0AGUAbABsAG8AVgBlAHIAcwBpAG8AbgAgADEALgAwAGYAbwBuAHQAZQBsAGwAbwBHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAGgAdAB0AHAAOgAvAC8AZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AAAAAAgAAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFAQIBAwEEAQUBBgAFd2VpYm8GcmVucmVuAnFxBndlY2hhdAAAAAAAAQAB//8ADwAAAAAAAAAAAAAAAAAAAAAAGAAYABgAGANS/2oDUv9qsAAsILAAVVhFWSAgS7gADlFLsAZTWliwNBuwKFlgZiCKVViwAiVhuQgACABjYyNiGyEhsABZsABDI0SyAAEAQ2BCLbABLLAgYGYtsAIsIGQgsMBQsAQmWrIoAQpDRWNFUltYISMhG4pYILBQUFghsEBZGyCwOFBYIbA4WVkgsQEKQ0VjRWFksChQWCGxAQpDRWNFILAwUFghsDBZGyCwwFBYIGYgiophILAKUFhgGyCwIFBYIbAKYBsgsDZQWCGwNmAbYFlZWRuwAStZWSOwAFBYZVlZLbADLCBFILAEJWFkILAFQ1BYsAUjQrAGI0IbISFZsAFgLbAELCMhIyEgZLEFYkIgsAYjQrEBCkNFY7EBCkOwAWBFY7ADKiEgsAZDIIogirABK7EwBSWwBCZRWGBQG2FSWVgjWSEgsEBTWLABKxshsEBZI7AAUFhlWS2wBSywB0MrsgACAENgQi2wBiywByNCIyCwACNCYbACYmawAWOwAWCwBSotsAcsICBFILALQ2O4BABiILAAUFiwQGBZZrABY2BEsAFgLbAILLIHCwBDRUIqIbIAAQBDYEItsAkssABDI0SyAAEAQ2BCLbAKLCAgRSCwASsjsABDsAQlYCBFiiNhIGQgsCBQWCGwABuwMFBYsCAbsEBZWSOwAFBYZVmwAyUjYUREsAFgLbALLCAgRSCwASsjsABDsAQlYCBFiiNhIGSwJFBYsAAbsEBZI7AAUFhlWbADJSNhRESwAWAtsAwsILAAI0KyCwoDRVghGyMhWSohLbANLLECAkWwZGFELbAOLLABYCAgsAxDSrAAUFggsAwjQlmwDUNKsABSWCCwDSNCWS2wDywgsBBiZrABYyC4BABjiiNhsA5DYCCKYCCwDiNCIy2wECxLVFixBGREWSSwDWUjeC2wESxLUVhLU1ixBGREWRshWSSwE2UjeC2wEiyxAA9DVVixDw9DsAFhQrAPK1mwAEOwAiVCsQwCJUKxDQIlQrABFiMgsAMlUFixAQBDYLAEJUKKiiCKI2GwDiohI7ABYSCKI2GwDiohG7EBAENgsAIlQrACJWGwDiohWbAMQ0ewDUNHYLACYiCwAFBYsEBgWWawAWMgsAtDY7gEAGIgsABQWLBAYFlmsAFjYLEAABMjRLABQ7AAPrIBAQFDYEItsBMsALEAAkVUWLAPI0IgRbALI0KwCiOwAWBCIGCwAWG1EBABAA4AQkKKYLESBiuwcisbIlktsBQssQATKy2wFSyxARMrLbAWLLECEystsBcssQMTKy2wGCyxBBMrLbAZLLEFEystsBossQYTKy2wGyyxBxMrLbAcLLEIEystsB0ssQkTKy2wHiwAsA0rsQACRVRYsA8jQiBFsAsjQrAKI7ABYEIgYLABYbUQEAEADgBCQopgsRIGK7ByKxsiWS2wHyyxAB4rLbAgLLEBHistsCEssQIeKy2wIiyxAx4rLbAjLLEEHistsCQssQUeKy2wJSyxBh4rLbAmLLEHHistsCcssQgeKy2wKCyxCR4rLbApLCA8sAFgLbAqLCBgsBBgIEMjsAFgQ7ACJWGwAWCwKSohLbArLLAqK7AqKi2wLCwgIEcgILALQ2O4BABiILAAUFiwQGBZZrABY2AjYTgjIIpVWCBHICCwC0NjuAQAYiCwAFBYsEBgWWawAWNgI2E4GyFZLbAtLACxAAJFVFiwARawLCqwARUwGyJZLbAuLACwDSuxAAJFVFiwARawLCqwARUwGyJZLbAvLCA1sAFgLbAwLACwAUVjuAQAYiCwAFBYsEBgWWawAWOwASuwC0NjuAQAYiCwAFBYsEBgWWawAWOwASuwABa0AAAAAABEPiM4sS8BFSotsDEsIDwgRyCwC0NjuAQAYiCwAFBYsEBgWWawAWNgsABDYTgtsDIsLhc8LbAzLCA8IEcgsAtDY7gEAGIgsABQWLBAYFlmsAFjYLAAQ2GwAUNjOC2wNCyxAgAWJSAuIEewACNCsAIlSYqKRyNHI2EgWGIbIVmwASNCsjMBARUUKi2wNSywABawBCWwBCVHI0cjYbAJQytlii4jICA8ijgtsDYssAAWsAQlsAQlIC5HI0cjYSCwBCNCsAlDKyCwYFBYILBAUVizAiADIBuzAiYDGllCQiMgsAhDIIojRyNHI2EjRmCwBEOwAmIgsABQWLBAYFlmsAFjYCCwASsgiophILACQ2BkI7ADQ2FkUFiwAkNhG7ADQ2BZsAMlsAJiILAAUFiwQGBZZrABY2EjICCwBCYjRmE4GyOwCENGsAIlsAhDRyNHI2FgILAEQ7ACYiCwAFBYsEBgWWawAWNgIyCwASsjsARDYLABK7AFJWGwBSWwAmIgsABQWLBAYFlmsAFjsAQmYSCwBCVgZCOwAyVgZFBYIRsjIVkjICCwBCYjRmE4WS2wNyywABYgICCwBSYgLkcjRyNhIzw4LbA4LLAAFiCwCCNCICAgRiNHsAErI2E4LbA5LLAAFrADJbACJUcjRyNhsABUWC4gPCMhG7ACJbACJUcjRyNhILAFJbAEJUcjRyNhsAYlsAUlSbACJWG5CAAIAGNjIyBYYhshWWO4BABiILAAUFiwQGBZZrABY2AjLiMgIDyKOCMhWS2wOiywABYgsAhDIC5HI0cjYSBgsCBgZrACYiCwAFBYsEBgWWawAWMjICA8ijgtsDssIyAuRrACJUZSWCA8WS6xKwEUKy2wPCwjIC5GsAIlRlBYIDxZLrErARQrLbA9LCMgLkawAiVGUlggPFkjIC5GsAIlRlBYIDxZLrErARQrLbA+LLA1KyMgLkawAiVGUlggPFkusSsBFCstsD8ssDYriiAgPLAEI0KKOCMgLkawAiVGUlggPFkusSsBFCuwBEMusCsrLbBALLAAFrAEJbAEJiAuRyNHI2GwCUMrIyA8IC4jOLErARQrLbBBLLEIBCVCsAAWsAQlsAQlIC5HI0cjYSCwBCNCsAlDKyCwYFBYILBAUVizAiADIBuzAiYDGllCQiMgR7AEQ7ACYiCwAFBYsEBgWWawAWNgILABKyCKimEgsAJDYGQjsANDYWRQWLACQ2EbsANDYFmwAyWwAmIgsABQWLBAYFlmsAFjYbACJUZhOCMgPCM4GyEgIEYjR7ABKyNhOCFZsSsBFCstsEIssDUrLrErARQrLbBDLLA2KyEjICA8sAQjQiM4sSsBFCuwBEMusCsrLbBELLAAFSBHsAAjQrIAAQEVFBMusDEqLbBFLLAAFSBHsAAjQrIAAQEVFBMusDEqLbBGLLEAARQTsDIqLbBHLLA0Ki2wSCywABZFIyAuIEaKI2E4sSsBFCstsEkssAgjQrBIKy2wSiyyAABBKy2wSyyyAAFBKy2wTCyyAQBBKy2wTSyyAQFBKy2wTiyyAABCKy2wTyyyAAFCKy2wUCyyAQBCKy2wUSyyAQFCKy2wUiyyAAA+Ky2wUyyyAAE+Ky2wVCyyAQA+Ky2wVSyyAQE+Ky2wViyyAABAKy2wVyyyAAFAKy2wWCyyAQBAKy2wWSyyAQFAKy2wWiyyAABDKy2wWyyyAAFDKy2wXCyyAQBDKy2wXSyyAQFDKy2wXiyyAAA/Ky2wXyyyAAE/Ky2wYCyyAQA/Ky2wYSyyAQE/Ky2wYiywNysusSsBFCstsGMssDcrsDsrLbBkLLA3K7A8Ky2wZSywABawNyuwPSstsGYssDgrLrErARQrLbBnLLA4K7A7Ky2waCywOCuwPCstsGkssDgrsD0rLbBqLLA5Ky6xKwEUKy2wayywOSuwOystsGwssDkrsDwrLbBtLLA5K7A9Ky2wbiywOisusSsBFCstsG8ssDorsDsrLbBwLLA6K7A8Ky2wcSywOiuwPSstsHIsswkEAgNFWCEbIyFZQiuwCGWwAyRQeLABFTAtAEu4AMhSWLEBAY5ZsAG5CAAIAGNwsQAFQrIAAQAqsQAFQrMKAgEIKrEABUKzDgABCCqxAAZCugLAAAEACSqxAAdCugBAAAEACSqxAwBEsSQBiFFYsECIWLEDZESxJgGIUVi6CIAAAQRAiGNUWLEDAERZWVlZswwCAQwquAH/hbAEjbECAEQAAA==') format('truetype');\n}\n  /* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */\n  /* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */\n  /*\n  @media screen and (-webkit-min-device-pixel-ratio:0) {\n    @font-face {\n      font-family: 'fontello';\n      src: url('../font/fontello.svg?13586373#fontello') format('svg');\n    }\n  }\n  */\n  \n   .need-share-button_dropdown [class^=\"icon-\"]:before, .need-share-button_dropdown [class*=\" icon-\"]:before {\n    font-family: \"fontello\";\n    font-style: normal;\n    font-weight: normal;\n    speak: none;\n  \n    display: inline-block;\n    text-decoration: inherit;\n    width: 1em;\n    margin-right: .2em;\n    text-align: center;\n    /* opacity: .8; */\n  \n    /* For safety - reset parent styles, that can break glyph codes*/\n    font-variant: normal;\n    text-transform: none;\n  \n    /* fix buttons height, for twitter bootstrap */\n    line-height: 1em;\n  \n    /* Animation center compensation - margins should be symmetric */\n    /* remove if not needed */\n    margin-left: .2em;\n  \n    /* you can be more comfortable with increased icons size */\n    /* font-size: 120%; */\n  \n    /* Uncomment for 3D effect */\n    /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */\n  }\n\n  .icon-weibo:before { content: '\\e82b'; } /* '' */\n  .icon-renren:before { content: '\\f18b'; } /* '' */\n  .icon-qqzone:before { content: '\\f1d6'; } /* '' */\n  .icon-wechat:before { content: '\\f1d7'; } /* '' */"
  },
  {
    "path": "source/lib/needsharebutton/needsharebutton.css",
    "content": "/***********************************************\n  needShareButton\n  - Version 1.0.0\n  - Copyright 2015 Dzmitry Vasileuski\n  - Licensed under MIT (http://opensource.org/licenses/MIT)\n***********************************************/\n/* Social icons font\n***********************************************/\n@import url('font-embedded.css');\n.need-share-button {\n  position: relative;\n}\n.need-share-button-opened {\n  position: relative;\n}\n.need-share-button-opened img.need-share-wechat-code-image {\n  display: block;\n\n  width: 100%;\n  max-width: 200px;\n  margin: auto;\n}\n.need-share-button_dropdown {\n  position: absolute;\n  z-index: 10;\n\n  visibility: hidden;\n  overflow: hidden;\n\n  width: 300px;\n\n  font-size: 16px;\n\n  -webkit-transition: .3s;\n          transition: .3s;\n  -webkit-transform: scale(.1);\n      -ms-transform: scale(.1);\n          transform: scale(.1);\n  text-align: center;\n  white-space: normal;\n\n  opacity: 0;\n  -webkit-border-radius: 4px;\n          border-radius: 4px;\n  background-color: #fff;\n  -webkit-box-shadow: 0 0 2px rgba(0, 0, 0, .5);\n          box-shadow: 0 0 2px rgba(0, 0, 0, .5);\n}\n.need-share-button-opened .need-share-button_dropdown {\n  visibility: visible;\n\n  -webkit-transform: scale(1);\n      -ms-transform: scale(1);\n          transform: scale(1);\n\n  opacity: 1;\n}\n.need-share-button_dropdown-box-vertical,\n.need-share-button_dropdown-box-horizontal {\n  -webkit-border-radius: 0;\n          border-radius: 0;\n}\n.need-share-button_dropdown-box-vertical {\n  width: 50px;\n}\n.need-share-button_dropdown-box-horizontal {\n  width: auto;\n\n  white-space: nowrap;\n}\n.need-share-button_link {\n  display: inline-block;\n\n  width: 50px;\n  height: 50px;\n\n  line-height: 50px;\n\n  cursor: pointer;\n  text-align: center;\n}\n.need-share-button_link:hover {\n  -webkit-transition: .3s;\n          transition: .3s;\n\n  opacity: .7;\n}\n/* Dropdown position\n***********************************************/\n.need-share-button_dropdown-top-left {\n  right: 100%;\n  bottom: 100%;\n\n  margin-right: 10px;\n  margin-bottom: 10px;\n}\n.need-share-button_dropdown-top-right {\n  bottom: 100%;\n  left: 100%;\n\n  margin-bottom: 10px;\n  margin-left: 10px;\n}\n.need-share-button_dropdown-top-center {\n  bottom: 100%;\n  left: 50%;\n\n  margin-bottom: 10px;\n}\n.need-share-button_dropdown-middle-left {\n  top: 50%;\n  right: 100%;\n\n  margin-right: 10px;\n}\n.need-share-button_dropdown-middle-right {\n  top: 50%;\n  left: 100%;\n\n  margin-left: 10px;\n}\n.need-share-button_dropdown-bottom-left {\n  top: 100%;\n  right: 100%;\n\n  margin-top: 10px;\n  margin-right: 10px;\n}\n.need-share-button_dropdown-bottom-right {\n  top: 100%;\n  left: 100%;\n\n  margin-top: 10px;\n  margin-left: 10px;\n}\n.need-share-button_dropdown-bottom-center {\n  top: 100%;\n  left: 50%;\n\n  margin-top: 10px;\n}\n/* Default theme\n***********************************************/\n.need-share-button-default {\n  display: inline-block;\n\n  margin-bottom: 0;\n  padding: 6px 12px;\n\n  font-size: 14px;\n  line-height: 1.42857143;\n  font-weight: 400;\n  color: #333;\n\n  cursor: pointer;\n  -webkit-user-select: none;\n     -moz-user-select: none;\n      -ms-user-select: none;\n          user-select: none;\n  text-align: center;\n  vertical-align: middle;\n\n  border: 1px solid #ccc;\n  -webkit-border-radius: 4px;\n          border-radius: 4px;\n  background-color: #fff;\n}\n/* Network buttons\n***********************************************/\n.need-share-button_wechat {\n  color: #a2dc30;\n}\n.need-share-button_wechat.need-share-button_link-box {\n  color: #fff;\n\n  background: #a2dc30;\n}\n.need-share-button_weibo {\n  color: #d52b2b;\n}\n.need-share-button_weibo.need-share-button_link-box {\n  color: #fff;\n\n  background: #d52b2b;\n}\n.need-share-button_douban {\n  color: #072;\n}\n.need-share-button_douban:before {\n  content: '豆';\n}\n.need-share-button_douban.need-share-button_link-box {\n  color: #fff;\n\n  background: #072;\n}\n.need-share-button_qqzone {\n  color: #ffce00;\n}\n.need-share-button_qqzone.need-share-button_link-box {\n  color: #fff;\n\n  background: #ffce00;\n}\n.need-share-button_renren {\n  color: #207cc5;\n}\n.need-share-button_renren.need-share-button_link-box {\n  color: #fff;\n\n  background: #207cc5;\n}\n.need-share-button_mailto {\n  color: #efbe00;\n}\n.need-share-button_mailto.need-share-button_link-box {\n  color: #fff;\n\n  background: #efbe00;\n}\n.need-share-button_twitter {\n  color: #00acec;\n}\n.need-share-button_twitter.need-share-button_link-box {\n  color: #fff;\n\n  background: #00acec;\n}\n.need-share-button_pinterest {\n  color: #cd2027;\n}\n.need-share-button_pinterest.need-share-button_link-box {\n  color: #fff;\n\n  background: #cd2027;\n}\n.need-share-button_facebook {\n  color: #3b5998;\n}\n.need-share-button_facebook.need-share-button_link-box {\n  color: #fff;\n\n  background: #3b5998;\n}\n.need-share-button_googleplus {\n  color: #d44132;\n}\n.need-share-button_googleplus.need-share-button_link-box {\n  color: #fff;\n\n  background: #d44132;\n}\n.need-share-button_reddit {\n  color: #000;\n}\n.need-share-button_reddit.need-share-button_link-box {\n  color: #fff;\n\n  background: #000;\n}\n.need-share-button_delicious {\n  color: #000;\n}\n.need-share-button_delicious.need-share-button_link-box {\n  color: #fff;\n\n  background: #000;\n}\n.need-share-button_stumbleupon {\n  color: #f04e23;\n}\n.need-share-button_stumbleupon.need-share-button_link-box {\n  color: #fff;\n\n  background: #f04e23;\n}\n.need-share-button_linkedin {\n  color: #0085af;\n}\n.need-share-button_linkedin.need-share-button_link-box {\n  color: #fff;\n\n  background: #0085af;\n}\n.need-share-button_slashdot {\n  color: #026664;\n}\n.need-share-button_slashdot.need-share-button_link-box {\n  color: #fff;\n\n  background: #026664;\n}\n.need-share-button_technorati {\n  color: #49ae47;\n}\n.need-share-button_technorati.need-share-button_link-box {\n  color: #fff;\n\n  background: #49ae47;\n}\n.need-share-button_posterous {\n  color: #795d31;\n}\n.need-share-button_posterous.need-share-button_link-box {\n  color: #fff;\n\n  background: #795d31;\n}\n.need-share-button_tumblr {\n  color: #34465d;\n}\n.need-share-button_tumblr.need-share-button_link-box {\n  color: #fff;\n\n  background: #34465d;\n}\n.need-share-button_googlebookmarks {\n  color: #fde331;\n}\n.need-share-button_googlebookmarks.need-share-button_link-box {\n  color: #fff;\n\n  background: #fde331;\n}\n.need-share-button_newsvine {\n  color: #03652c;\n}\n.need-share-button_newsvine.need-share-button_link-box {\n  color: #fff;\n\n  background: #03652c;\n}\n.need-share-button_evernote {\n  color: #79d626;\n}\n.need-share-button_evernote.need-share-button_link-box {\n  color: #fff;\n\n  background: #79d626;\n}\n.need-share-button_friendfeed {\n  color: #b0cbe9;\n}\n.need-share-button_friendfeed.need-share-button_link-box {\n  color: #fff;\n\n  background: #b0cbe9;\n}\n.need-share-button_vkontakte {\n  color: #4c75a3;\n}\n.need-share-button_vkontakte.need-share-button_link-box {\n  color: #fff;\n\n  background: #4c75a3;\n}\n.need-share-button_odnoklassniki {\n  color: #ed812b;\n}\n.need-share-button_odnoklassniki.need-share-button_link-box {\n  color: #fff;\n\n  background: #ed812b;\n}\n.need-share-button_mailru {\n  color: #f89c0e;\n}\n.need-share-button_mailru.need-share-button_link-box {\n  color: #fff;\n\n  background: #f89c0e;\n}\n"
  },
  {
    "path": "source/lib/needsharebutton/needsharebutton.js",
    "content": "/***********************************************\n  needShareButton\n  - Version 1.0.0\n  - Copyright 2015 Dzmitry Vasileuski\n\t- Licensed under MIT (http://opensource.org/licenses/MIT)\n***********************************************/\n\n(function () {\n\n  // find closest\n  function closest(elem, parent) {\n    if (typeof (parent) == \"string\") {\n      var matchesSelector = elem.matches || elem.webkitMatchesSelector ||\n                            elem.mozMatchesSelector || elem.msMatchesSelector;\n\n      if (!!matchesSelector) {\n        while (elem) {\n          if (matchesSelector.bind(elem)(parent)) {\n            return elem;\n          } else {\n            elem = elem.parentElement;\n          }\n        }\n      }\n      return false;\n    } else {\n      while (elem) {\n        if (elem == parent) {\n          return elem;\n        } else {\n          elem = elem.parentElement;\n        }\n      }\n      return false;\n    }\n  }\n\n  // share button class\n  window.needShareButton = function (elem, options) {\n    // create element reference\n    var root = this;\n    root.elem = elem || \"need-share-button\";\n\n    /* Helpers\n     ***********************************************/\n\n    // get title from html\n    root.getTitle = function () {\n      var content;\n      // check querySelector existance for old browsers\n      if (document.querySelector) {\n        content = document.querySelector(\"title\");\n        if (content) {\n          return content.innerText;\n        }\n      }\n      return document.title;\n    };\n\n    // get image from html\n    root.getImage = function () {\n      var content;\n      // check querySelector existance for old browsers\n      if (document.querySelector) {\n        content = document.querySelector(\"meta[property=\\\"og:image\\\"]\") ||\n                  document.querySelector(\"meta[name=\\\"twitter:image\\\"]\");\n        if (content) {\n          return content.getAttribute(\"content\");\n        } else {\n          return \"\";\n        }\n      } else {\n        return \"\";\n      }\n    };\n\n    // get description from html\n    root.getDescription = function () {\n      var content;\n      // check querySelector existance for old browsers\n      if (document.querySelector) {\n        content = document.querySelector(\"meta[property=\\\"og:description\\\"]\") ||\n                  document.querySelector(\"meta[name=\\\"twitter:description\\\"]\") ||\n                  document.querySelector(\"meta[name=\\\"description\\\"]\");\n        if (content) {\n          return content.getAttribute(\"content\");\n        } else {\n          return \"\";\n        }\n      } else {\n        content = document.getElementsByTagName(\"meta\").namedItem(\"description\");\n        if (content) {\n          return content.getAttribute(\"content\");\n        } else {\n          return \"\";\n        }\n      }\n    };\n\n    // share urls for all networks\n    root.share = {\n      \"weibo\": function (el) {\n        var myoptions = getOptions(el);\n        var url = \"http://v.t.sina.com.cn/share/share.php?title=\" +\n          encodeURIComponent(myoptions.title) +\n          \"&url=\" + encodeURIComponent(myoptions.url) +\n          \"&pic=\" + encodeURIComponent(myoptions.image);\n        root.popup(url);\n      },\n      \"wechat\": function (el) {\n        var myoptions = getOptions(el);\n        var imgSrc = \"https://api.qinco.me/api/qr?size=400&content=\" + encodeURIComponent(myoptions.url);\n        var dropdownEl = el.querySelector(\".need-share-button_dropdown\");\n        var img = dropdownEl.getElementsByClassName(\"need-share-wechat-code-image\")[0];\n        if (img) {\n          img.remove();\n        } else {\n          img = document.createElement(\"img\");\n          img.src = imgSrc;\n          img.alt = \"loading wechat image...\";\n          img.setAttribute(\"class\", \"need-share-wechat-code-image\");\n          dropdownEl.appendChild(img);\n        }\n      },\n      \"douban\": function (el) {\n        var myoptions = getOptions(el);\n        var url = \"https://www.douban.com/share/service?name=\" +\n          encodeURIComponent(myoptions.title) +\n          \"&href=\" + encodeURIComponent(myoptions.url) +\n          \"&image=\" + encodeURIComponent(myoptions.image);\n        root.popup(url);\n      },\n      \"qqzone\": function (el) {\n        var myoptions = getOptions(el);\n        var url = \"http://sns.qzone.qq.com/cgi-bin/qzshare/cgi_qzshare_onekey?title=\" +\n          encodeURIComponent(myoptions.title) +\n          \"&url=\" + encodeURIComponent(myoptions.url) +\n          \"&pics=\" + encodeURIComponent(myoptions.image) +\n          \"&desc=\" + encodeURIComponent(myoptions.description);\n        root.popup(url);\n      },\n      \"renren\": function (el) {\n        var myoptions = getOptions(el);\n        var url = \"http://widget.renren.com/dialog/share?title=\" +\n          encodeURIComponent(myoptions.title) +\n          \"&resourceUrl=\" + encodeURIComponent(myoptions.url) +\n          \"&pic=\" + encodeURIComponent(myoptions.image) +\n          \"&description=\" + encodeURIComponent(myoptions.description);\n        root.popup(url);\n      },\n      \"mailto\": function (el) {\n        var myoptions = getOptions(el);\n        var url = \"mailto:?subject=\" + encodeURIComponent(myoptions.title) +\n          \"&body=Thought you might enjoy reading this: \" + encodeURIComponent(myoptions.url) +\n          \" - \" + encodeURIComponent(myoptions.description);\n\n        window.location.href = url;\n      },\n      \"twitter\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"twitter.com/intent/tweet?text=\";\n        url += encodeURIComponent(myoptions.title) + \"&url=\" + encodeURIComponent(myoptions.url);\n\n        root.popup(url);\n      },\n      \"pinterest\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"pinterest.com/pin/create/bookmarklet/?is_video=false\";\n        url += \"&media=\" + encodeURIComponent(myoptions.image);\n        url += \"&url=\" + encodeURIComponent(myoptions.url);\n        url += \"&description=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"facebook\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.facebook.com/share.php?\";\n        url += \"u=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"googleplus\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"plus.google.com/share?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n\n        root.popup(url);\n      },\n      \"reddit\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.reddit.com/submit?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"delicious\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"del.icio.us/post?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n        url += \"&notes=\" + encodeURIComponent(myoptions.description);\n\n        root.popup(url);\n      },\n      \"stumbleupon\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.stumbleupon.com/submit?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"linkedin\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.linkedin.com/shareArticle?mini=true\";\n        url += \"&url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n        url += \"&source=\" + encodeURIComponent(myoptions.source);\n\n        root.popup(url);\n      },\n      \"slashdot\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"slashdot.org/bookmark.pl?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"technorati\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"technorati.com/faves?\";\n        url += \"add=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"posterous\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"posterous.com/share?\";\n        url += \"linkto=\" + encodeURIComponent(myoptions.url);\n\n        root.popup(url);\n      },\n      \"tumblr\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.tumblr.com/share?v=3\";\n        url += \"&u=\" + encodeURIComponent(myoptions.url);\n        url += \"&t=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"googlebookmarks\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.google.com/bookmarks/mark?op=edit\";\n        url += \"&bkmk=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n        url += \"&annotation=\" + encodeURIComponent(myoptions.description);\n\n        root.popup(url);\n      },\n      \"newsvine\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.newsvine.com/_tools/seed&save?\";\n        url += \"u=\" + encodeURIComponent(myoptions.url);\n        url += \"&h=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"evernote\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.evernote.com/clip.action?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"friendfeed\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.friendfeed.com/share?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n\n        root.popup(url);\n      },\n      \"vkontakte\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"vkontakte.ru/share.php?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n        url += \"&description=\" + encodeURIComponent(myoptions.description);\n        url += \"&image=\" + encodeURIComponent(myoptions.image);\n        url += \"&noparse=true\";\n\n        root.popup(url);\n      },\n      \"odnoklassniki\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"www.odnoklassniki.ru/dk?st.cmd=addShare&st.s=1\";\n        url += \"&st.comments=\" + encodeURIComponent(myoptions.description);\n        url += \"&st._surl=\" + encodeURIComponent(myoptions.url);\n\n        root.popup(url);\n      },\n      \"mailru\": function (el) {\n        var myoptions = getOptions(el);\n        var url = myoptions.protocol + \"connect.mail.ru/share?\";\n        url += \"url=\" + encodeURIComponent(myoptions.url);\n        url += \"&title=\" + encodeURIComponent(myoptions.title);\n        url += \"&description=\" + encodeURIComponent(myoptions.description);\n        url += \"&imageurl=\" + encodeURIComponent(myoptions.image);\n\n        root.popup(url);\n      }\n\n    };\n\n    // open share link in a popup\n    root.popup = function (url) {\n      // set left and top position\n      var popupWidth = 600,\n        popupHeight = 500,\n        // fix dual screen mode\n        dualScreenLeft = window.screenLeft !== undefined ? window.screenLeft : screen.left,\n        dualScreenTop = window.screenTop !== undefined ? window.screenTop : screen.top,\n        width = window.innerWidth ?\n                window.innerWidth :\n                document.documentElement.clientWidth ?\n                document.documentElement.clientWidth :\n                screen.width,\n        height = window.innerHeight ?\n                 window.innerHeight :\n                 document.documentElement.clientHeight ?\n                 document.documentElement.clientHeight :\n                 screen.height,\n        // calculate top and left position\n        left = ((width / 2) - (popupWidth / 2)) + dualScreenLeft,\n        top = ((height / 2) - (popupHeight / 2)) + dualScreenTop,\n\n        // show popup\n        shareWindow = window.open(url, \"targetWindow\",\n          \"toolbar=no,location=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=\" + popupWidth +\n          \", height=\" + popupHeight + \", top=\" + top + \", left=\" + left);\n\n      // Puts focus on the newWindow\n      if (window.focus) {\n        shareWindow.focus();\n      }\n    };\n\n    /* Set options\n     ***********************************************/\n\n    // create default options\n    root.options = {\n      iconStyle: \"default\", // default or box\n      boxForm: \"horizontal\", // horizontal or vertical\n      position: \"bottomCenter\", // top / middle / bottom + Left / Center / Right\n      protocol: [\"http\", \"https\"].indexOf(window.location.href.split(\":\")[0]) === -1 ? \"https://\" : \"//\",\n      networks: \"Weibo,Wechat,Douban,QQZone,Twitter,Pinterest,Facebook,GooglePlus,Reddit,Linkedin,Tumblr,Evernote\"\n    };\n\n    // integrate custom options\n    for (var i in options) {\n      if (options.hasOwnProperty(i)) {\n        root.options[i] = options[i];\n      }\n    }\n    // convert networks string into array\n    //root.options.networks = root.options.networks.toLowerCase().split(\",\");\n    root.options.networks = root.options.networks.split(\",\");\n\n    function getOptions(el) {\n      // integrate data attribute options\n      var ret = {};\n      for (var i in root.options) {\n        if (root.options.hasOwnProperty(i)) {\n          ret[i] = root.options[i];\n        }\n      }\n\n      // these attrs must get dynamically.\n      ret.url = window.location.href;\n      ret.title = root.getTitle();\n      ret.image = root.getImage();\n      ret.description = root.getDescription();\n\n      for (var option in el.dataset) {\n        // replace only 'share-' prefixed data-attributes\n        if (option.match(/share/)) {\n          var newOption = option.replace(/share/, \"\");\n          if (!newOption.length) {\n            continue;\n          }\n          newOption = newOption.charAt(0).toLowerCase() + newOption.slice(1);\n          var val = el.dataset[option];\n          if (newOption === \"networks\") {\n            //val = val.toLowerCase().split(\",\");\n            val = val.split(\",\");\n          } else if (newOption === \"url\" && val && val[0] === \"/\") {\n            // fix relative url problem.\n            val = location.origin + val;\n          }\n          ret[newOption] = val;\n        }\n      }\n      return ret;\n    }\n\n    function createDropdown(el) {\n      // create dropdown\n      var dropdownEl = document.createElement(\"span\");\n      dropdownEl.className = \"need-share-button_dropdown\";\n      if (el.querySelector(\".need-share-button_dropdown\")) {\n        return;\n      }\n      var myoptions = getOptions(el);\n\n      // set dropdown row length\n      if (myoptions.iconStyle == \"box\" && myoptions.boxForm == \"horizontal\") {\n        dropdownEl.className += \" need-share-button_dropdown-box-horizontal\";\n      } else if (myoptions.iconStyle == \"box\" && myoptions.boxForm == \"vertical\") {\n        dropdownEl.className += \" need-share-button_dropdown-box-vertical\";\n      }\n\n      // set dropdown position\n      setTimeout(function () {\n        switch (myoptions.position) {\n          case \"topLeft\":\n            dropdownEl.className += \" need-share-button_dropdown-top-left\";\n            break;\n          case \"topRight\":\n            dropdownEl.className += \" need-share-button_dropdown-top-right\";\n            break;\n          case \"topCenter\":\n            dropdownEl.className += \" need-share-button_dropdown-top-center\";\n            dropdownEl.style.marginLeft = -dropdownEl.offsetWidth / 2 + \"px\";\n            break;\n          case \"middleLeft\":\n            dropdownEl.className += \" need-share-button_dropdown-middle-left\";\n            dropdownEl.style.marginTop = -dropdownEl.offsetHeight / 2 + \"px\";\n            break;\n          case \"middleRight\":\n            dropdownEl.className += \" need-share-button_dropdown-middle-right\";\n            dropdownEl.style.marginTop = -dropdownEl.offsetHeight / 2 + \"px\";\n            break;\n          case \"bottomLeft\":\n            dropdownEl.className += \" need-share-button_dropdown-bottom-left\";\n            break;\n          case \"bottomRight\":\n            dropdownEl.className += \" need-share-button_dropdown-bottom-right\";\n            break;\n          case \"bottomCenter\":\n            dropdownEl.className += \" need-share-button_dropdown-bottom-center\";\n            dropdownEl.style.marginLeft = -dropdownEl.offsetWidth / 2 + \"px\";\n            break;\n          default:\n            dropdownEl.className += \" need-share-button_dropdown-bottom-center\";\n            dropdownEl.style.marginLeft = -dropdownEl.offsetWidth / 2 + \"px\";\n            break;\n        }\n      }, 1);\n\n\n      // fill fropdown with buttons\n      var iconClass = myoptions.iconStyle == \"default\" ? \n                      \"need-share-button_link need-share-button_\" : \n                      \"need-share-button_link-\" + myoptions.iconStyle + \" need-share-button_link need-share-button_\";\n      for (var network in myoptions.networks) {\n        if (myoptions.networks.hasOwnProperty(network)) {\n          var link = document.createElement(\"span\");\n          network = myoptions.networks[network].trim();\n          var networkLC = network.toLowerCase();\n          link.className = iconClass + networkLC;\n          var fontello = [\"weibo\", \"wechat\", \"douban\", \"qqzone\", \"renren\"];\n          if (fontello.indexOf(networkLC) === -1) {\n            link.className += \" social-\" + networkLC;\n          } else {\n            link.className += \" icon-\" + networkLC;\n          }\n          link.dataset.network = networkLC;\n          link.title = network;\n          dropdownEl.appendChild(link);\n        }\n      }\n\n      dropdownEl.addEventListener(\"click\", function (event) {\n        if (closest(event.target, \".need-share-button_link\")) {\n          event.preventDefault();\n          event.stopPropagation();\n\n          root.share[event.target.dataset.network](el);\n          return false;\n        }\n      });\n\n      el.appendChild(dropdownEl);\n    }\n\n    // close on click outside\n    document.addEventListener(\"click\", function (event) {\n      var openedEl = document.querySelector(\".need-share-button-opened\");\n      if (!closest(event.target, \".need-share-button-opened\")) {\n        if (openedEl) {\n          openedEl.classList.remove(\"need-share-button-opened\");\n\n          // hide wechat code image when close the dropdown.\n          if (openedEl.querySelector(\".need-share-wechat-code-image\")) {\n            openedEl.querySelector(\".need-share-wechat-code-image\").remove();\n          }\n        } else {\n          var el = closest(event.target, root.elem);\n          if (el) {\n            if (!el.classList.contains(\"need-share-button-opened\")) {\n              createDropdown(el);\n              setTimeout(function () {\n                el.classList.add(\"need-share-button-opened\");\n              }, 1);\n            }\n          }\n        }\n      } else {\n        setTimeout(function () {\n          openedEl.classList.remove(\"need-share-button-opened\");\n\n          // hide wechat code image when close the dropdown.\n          if (openedEl.querySelector(\".need-share-wechat-code-image\")) {\n            openedEl.querySelector(\".need-share-wechat-code-image\").remove();\n          }\n        }, 1);\n      }\n    });\n\n  };\n})();"
  },
  {
    "path": "source/lib/velocity/.bower.json",
    "content": "{\n  \"name\": \"velocity\",\n  \"version\": \"1.2.2\",\n  \"homepage\": \"http://velocityjs.org\",\n  \"authors\": [\n    {\n      \"name\": \"Julian Shapiro\",\n      \"homepage\": \"http://julian.com/\"\n    }\n  ],\n  \"description\": \"Accelerated JavaScript animation.\",\n  \"main\": [\n    \"./velocity.js\",\n    \"./velocity.ui.js\"\n  ],\n  \"keywords\": [\n    \"animation\",\n    \"jquery\",\n    \"animate\",\n    \"lightweight\",\n    \"smooth\",\n    \"ui\",\n    \"velocity.js\",\n    \"velocityjs\",\n    \"javascript\"\n  ],\n  \"license\": \"MIT\",\n  \"ignore\": [\n    \"*.json\",\n    \"!/bower.json\",\n    \"LICENSE\",\n    \"*.md\"\n  ],\n  \"dependencies\": {\n    \"jquery\": \"*\"\n  },\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"http://github.com/julianshapiro/velocity.git\"\n  },\n  \"_release\": \"1.2.2\",\n  \"_resolution\": {\n    \"type\": \"version\",\n    \"tag\": \"1.2.2\",\n    \"commit\": \"6b227928631aab5694255df3c219736c4c02449d\"\n  },\n  \"_source\": \"git://github.com/julianshapiro/velocity.git\",\n  \"_target\": \"~1.2.1\",\n  \"_originalSource\": \"velocity\"\n}"
  },
  {
    "path": "source/lib/velocity/bower.json",
    "content": "{\n  \"name\": \"velocity\",\n  \"version\": \"1.2.2\",\n  \"homepage\": \"http://velocityjs.org\",\n  \"authors\": [\n    { \"name\" : \"Julian Shapiro\",\n      \"homepage\" : \"http://julian.com/\"\n    }\n  ],\n  \"description\": \"Accelerated JavaScript animation.\",\n  \"main\": [ \"./velocity.js\", \"./velocity.ui.js\"],\n  \"keywords\": [\n    \"animation\",\n    \"jquery\",\n    \"animate\",\n    \"lightweight\",\n    \"smooth\",\n    \"ui\",\n    \"velocity.js\",\n    \"velocityjs\",\n    \"javascript\"\n  ],\n  \"license\": \"MIT\",\n  \"ignore\": [\n    \"*.json\",\n    \"!/bower.json\",\n    \"LICENSE\",\n    \"*.md\"\n  ],\n  \"dependencies\": {\n    \"jquery\": \"*\"\n  },\n  \"repository\" :\n  { \n    \"type\" : \"git\",\n    \"url\" : \"http://github.com/julianshapiro/velocity.git\"\n  }\n}"
  },
  {
    "path": "source/lib/velocity/velocity.js",
    "content": "/*! VelocityJS.org (1.2.2). (C) 2014 Julian Shapiro. MIT @license: en.wikipedia.org/wiki/MIT_License */\n\n/*************************\n   Velocity jQuery Shim\n*************************/\n\n/*! VelocityJS.org jQuery Shim (1.0.1). (C) 2014 The jQuery Foundation. MIT @license: en.wikipedia.org/wiki/MIT_License. */\n\n/* This file contains the jQuery functions that Velocity relies on, thereby removing Velocity's dependency on a full copy of jQuery, and allowing it to work in any environment. */\n/* These shimmed functions are only used if jQuery isn't present. If both this shim and jQuery are loaded, Velocity defaults to jQuery proper. */\n/* Browser support: Using this shim instead of jQuery proper removes support for IE8. */\n\n;(function (window) {\n    /***************\n         Setup\n    ***************/\n\n    /* If jQuery is already loaded, there's no point in loading this shim. */\n    if (window.jQuery) {\n        return;\n    }\n\n    /* jQuery base. */\n    var $ = function (selector, context) {\n        return new $.fn.init(selector, context);\n    };\n\n    /********************\n       Private Methods\n    ********************/\n\n    /* jQuery */\n    $.isWindow = function (obj) {\n        /* jshint eqeqeq: false */\n        return obj != null && obj == obj.window;\n    };\n\n    /* jQuery */\n    $.type = function (obj) {\n        if (obj == null) {\n            return obj + \"\";\n        }\n\n        return typeof obj === \"object\" || typeof obj === \"function\" ?\n            class2type[toString.call(obj)] || \"object\" :\n            typeof obj;\n    };\n\n    /* jQuery */\n    $.isArray = Array.isArray || function (obj) {\n        return $.type(obj) === \"array\";\n    };\n\n    /* jQuery */\n    function isArraylike (obj) {\n        var length = obj.length,\n            type = $.type(obj);\n\n        if (type === \"function\" || $.isWindow(obj)) {\n            return false;\n        }\n\n        if (obj.nodeType === 1 && length) {\n            return true;\n        }\n\n        return type === \"array\" || length === 0 || typeof length === \"number\" && length > 0 && (length - 1) in obj;\n    }\n\n    /***************\n       $ Methods\n    ***************/\n\n    /* jQuery: Support removed for IE<9. */\n    $.isPlainObject = function (obj) {\n        var key;\n\n        if (!obj || $.type(obj) !== \"object\" || obj.nodeType || $.isWindow(obj)) {\n            return false;\n        }\n\n        try {\n            if (obj.constructor &&\n                !hasOwn.call(obj, \"constructor\") &&\n                !hasOwn.call(obj.constructor.prototype, \"isPrototypeOf\")) {\n                return false;\n            }\n        } catch (e) {\n            return false;\n        }\n\n        for (key in obj) {}\n\n        return key === undefined || hasOwn.call(obj, key);\n    };\n\n    /* jQuery */\n    $.each = function(obj, callback, args) {\n        var value,\n            i = 0,\n            length = obj.length,\n            isArray = isArraylike(obj);\n\n        if (args) {\n            if (isArray) {\n                for (; i < length; i++) {\n                    value = callback.apply(obj[i], args);\n\n                    if (value === false) {\n                        break;\n                    }\n                }\n            } else {\n                for (i in obj) {\n                    value = callback.apply(obj[i], args);\n\n                    if (value === false) {\n                        break;\n                    }\n                }\n            }\n\n        } else {\n            if (isArray) {\n                for (; i < length; i++) {\n                    value = callback.call(obj[i], i, obj[i]);\n\n                    if (value === false) {\n                        break;\n                    }\n                }\n            } else {\n                for (i in obj) {\n                    value = callback.call(obj[i], i, obj[i]);\n\n                    if (value === false) {\n                        break;\n                    }\n                }\n            }\n        }\n\n        return obj;\n    };\n\n    /* Custom */\n    $.data = function (node, key, value) {\n        /* $.getData() */\n        if (value === undefined) {\n            var id = node[$.expando],\n                store = id && cache[id];\n\n            if (key === undefined) {\n                return store;\n            } else if (store) {\n                if (key in store) {\n                    return store[key];\n                }\n            }\n        /* $.setData() */\n        } else if (key !== undefined) {\n            var id = node[$.expando] || (node[$.expando] = ++$.uuid);\n\n            cache[id] = cache[id] || {};\n            cache[id][key] = value;\n\n            return value;\n        }\n    };\n\n    /* Custom */\n    $.removeData = function (node, keys) {\n        var id = node[$.expando],\n            store = id && cache[id];\n\n        if (store) {\n            $.each(keys, function(_, key) {\n                delete store[key];\n            });\n        }\n    };\n\n    /* jQuery */\n    $.extend = function () {\n        var src, copyIsArray, copy, name, options, clone,\n            target = arguments[0] || {},\n            i = 1,\n            length = arguments.length,\n            deep = false;\n\n        if (typeof target === \"boolean\") {\n            deep = target;\n\n            target = arguments[i] || {};\n            i++;\n        }\n\n        if (typeof target !== \"object\" && $.type(target) !== \"function\") {\n            target = {};\n        }\n\n        if (i === length) {\n            target = this;\n            i--;\n        }\n\n        for (; i < length; i++) {\n            if ((options = arguments[i]) != null) {\n                for (name in options) {\n                    src = target[name];\n                    copy = options[name];\n\n                    if (target === copy) {\n                        continue;\n                    }\n\n                    if (deep && copy && ($.isPlainObject(copy) || (copyIsArray = $.isArray(copy)))) {\n                        if (copyIsArray) {\n                            copyIsArray = false;\n                            clone = src && $.isArray(src) ? src : [];\n\n                        } else {\n                            clone = src && $.isPlainObject(src) ? src : {};\n                        }\n\n                        target[name] = $.extend(deep, clone, copy);\n\n                    } else if (copy !== undefined) {\n                        target[name] = copy;\n                    }\n                }\n            }\n        }\n\n        return target;\n    };\n\n    /* jQuery 1.4.3 */\n    $.queue = function (elem, type, data) {\n        function $makeArray (arr, results) {\n            var ret = results || [];\n\n            if (arr != null) {\n                if (isArraylike(Object(arr))) {\n                    /* $.merge */\n                    (function(first, second) {\n                        var len = +second.length,\n                            j = 0,\n                            i = first.length;\n\n                        while (j < len) {\n                            first[i++] = second[j++];\n                        }\n\n                        if (len !== len) {\n                            while (second[j] !== undefined) {\n                                first[i++] = second[j++];\n                            }\n                        }\n\n                        first.length = i;\n\n                        return first;\n                    })(ret, typeof arr === \"string\" ? [arr] : arr);\n                } else {\n                    [].push.call(ret, arr);\n                }\n            }\n\n            return ret;\n        }\n\n        if (!elem) {\n            return;\n        }\n\n        type = (type || \"fx\") + \"queue\";\n\n        var q = $.data(elem, type);\n\n        if (!data) {\n            return q || [];\n        }\n\n        if (!q || $.isArray(data)) {\n            q = $.data(elem, type, $makeArray(data));\n        } else {\n            q.push(data);\n        }\n\n        return q;\n    };\n\n    /* jQuery 1.4.3 */\n    $.dequeue = function (elems, type) {\n        /* Custom: Embed element iteration. */\n        $.each(elems.nodeType ? [ elems ] : elems, function(i, elem) {\n            type = type || \"fx\";\n\n            var queue = $.queue(elem, type),\n                fn = queue.shift();\n\n            if (fn === \"inprogress\") {\n                fn = queue.shift();\n            }\n\n            if (fn) {\n                if (type === \"fx\") {\n                    queue.unshift(\"inprogress\");\n                }\n\n                fn.call(elem, function() {\n                    $.dequeue(elem, type);\n                });\n            }\n        });\n    };\n\n    /******************\n       $.fn Methods\n    ******************/\n\n    /* jQuery */\n    $.fn = $.prototype = {\n        init: function (selector) {\n            /* Just return the element wrapped inside an array; don't proceed with the actual jQuery node wrapping process. */\n            if (selector.nodeType) {\n                this[0] = selector;\n\n                return this;\n            } else {\n                throw new Error(\"Not a DOM node.\");\n            }\n        },\n\n        offset: function () {\n            /* jQuery altered code: Dropped disconnected DOM node checking. */\n            var box = this[0].getBoundingClientRect ? this[0].getBoundingClientRect() : { top: 0, left: 0 };\n\n            return {\n                top: box.top + (window.pageYOffset || document.scrollTop  || 0)  - (document.clientTop  || 0),\n                left: box.left + (window.pageXOffset || document.scrollLeft  || 0) - (document.clientLeft || 0)\n            };\n        },\n\n        position: function () {\n            /* jQuery */\n            function offsetParent() {\n                var offsetParent = this.offsetParent || document;\n\n                while (offsetParent && (!offsetParent.nodeType.toLowerCase === \"html\" && offsetParent.style.position === \"static\")) {\n                    offsetParent = offsetParent.offsetParent;\n                }\n\n                return offsetParent || document;\n            }\n\n            /* Zepto */\n            var elem = this[0],\n                offsetParent = offsetParent.apply(elem),\n                offset = this.offset(),\n                parentOffset = /^(?:body|html)$/i.test(offsetParent.nodeName) ? { top: 0, left: 0 } : $(offsetParent).offset()\n\n            offset.top -= parseFloat(elem.style.marginTop) || 0;\n            offset.left -= parseFloat(elem.style.marginLeft) || 0;\n\n            if (offsetParent.style) {\n                parentOffset.top += parseFloat(offsetParent.style.borderTopWidth) || 0\n                parentOffset.left += parseFloat(offsetParent.style.borderLeftWidth) || 0\n            }\n\n            return {\n                top: offset.top - parentOffset.top,\n                left: offset.left - parentOffset.left\n            };\n        }\n    };\n\n    /**********************\n       Private Variables\n    **********************/\n\n    /* For $.data() */\n    var cache = {};\n    $.expando = \"velocity\" + (new Date().getTime());\n    $.uuid = 0;\n\n    /* For $.queue() */\n    var class2type = {},\n        hasOwn = class2type.hasOwnProperty,\n        toString = class2type.toString;\n\n    var types = \"Boolean Number String Function Array Date RegExp Object Error\".split(\" \");\n    for (var i = 0; i < types.length; i++) {\n        class2type[\"[object \" + types[i] + \"]\"] = types[i].toLowerCase();\n    }\n\n    /* Makes $(node) possible, without having to call init. */\n    $.fn.init.prototype = $.fn;\n\n    /* Globalize Velocity onto the window, and assign its Utilities property. */\n    window.Velocity = { Utilities: $ };\n})(window);\n\n/******************\n    Velocity.js\n******************/\n\n;(function (factory) {\n    /* CommonJS module. */\n    if (typeof module === \"object\" && typeof module.exports === \"object\") {\n        module.exports = factory();\n    /* AMD module. */\n    } else if (typeof define === \"function\" && define.amd) {\n        define(factory);\n    /* Browser globals. */\n    } else {\n        factory();\n    }\n}(function() {\nreturn function (global, window, document, undefined) {\n\n    /***************\n        Summary\n    ***************/\n\n    /*\n    - CSS: CSS stack that works independently from the rest of Velocity.\n    - animate(): Core animation method that iterates over the targeted elements and queues the incoming call onto each element individually.\n      - Pre-Queueing: Prepare the element for animation by instantiating its data cache and processing the call's options.\n      - Queueing: The logic that runs once the call has reached its point of execution in the element's $.queue() stack.\n                  Most logic is placed here to avoid risking it becoming stale (if the element's properties have changed).\n      - Pushing: Consolidation of the tween data followed by its push onto the global in-progress calls container.\n    - tick(): The single requestAnimationFrame loop responsible for tweening all in-progress calls.\n    - completeCall(): Handles the cleanup process for each Velocity call.\n    */\n\n    /*********************\n       Helper Functions\n    *********************/\n\n    /* IE detection. Gist: https://gist.github.com/julianshapiro/9098609 */\n    var IE = (function() {\n        if (document.documentMode) {\n            return document.documentMode;\n        } else {\n            for (var i = 7; i > 4; i--) {\n                var div = document.createElement(\"div\");\n\n                div.innerHTML = \"<!--[if IE \" + i + \"]><span></span><![endif]-->\";\n\n                if (div.getElementsByTagName(\"span\").length) {\n                    div = null;\n\n                    return i;\n                }\n            }\n        }\n\n        return undefined;\n    })();\n\n    /* rAF shim. Gist: https://gist.github.com/julianshapiro/9497513 */\n    var rAFShim = (function() {\n        var timeLast = 0;\n\n        return window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function(callback) {\n            var timeCurrent = (new Date()).getTime(),\n                timeDelta;\n\n            /* Dynamically set delay on a per-tick basis to match 60fps. */\n            /* Technique by Erik Moller. MIT license: https://gist.github.com/paulirish/1579671 */\n            timeDelta = Math.max(0, 16 - (timeCurrent - timeLast));\n            timeLast = timeCurrent + timeDelta;\n\n            return setTimeout(function() { callback(timeCurrent + timeDelta); }, timeDelta);\n        };\n    })();\n\n    /* Array compacting. Copyright Lo-Dash. MIT License: https://github.com/lodash/lodash/blob/master/LICENSE.txt */\n    function compactSparseArray (array) {\n        var index = -1,\n            length = array ? array.length : 0,\n            result = [];\n\n        while (++index < length) {\n            var value = array[index];\n\n            if (value) {\n                result.push(value);\n            }\n        }\n\n        return result;\n    }\n\n    function sanitizeElements (elements) {\n        /* Unwrap jQuery/Zepto objects. */\n        if (Type.isWrapped(elements)) {\n            elements = [].slice.call(elements);\n        /* Wrap a single element in an array so that $.each() can iterate with the element instead of its node's children. */\n        } else if (Type.isNode(elements)) {\n            elements = [ elements ];\n        }\n\n        return elements;\n    }\n\n    var Type = {\n        isString: function (variable) {\n            return (typeof variable === \"string\");\n        },\n        isArray: Array.isArray || function (variable) {\n            return Object.prototype.toString.call(variable) === \"[object Array]\";\n        },\n        isFunction: function (variable) {\n            return Object.prototype.toString.call(variable) === \"[object Function]\";\n        },\n        isNode: function (variable) {\n            return variable && variable.nodeType;\n        },\n        /* Copyright Martin Bohm. MIT License: https://gist.github.com/Tomalak/818a78a226a0738eaade */\n        isNodeList: function (variable) {\n            return typeof variable === \"object\" &&\n                /^\\[object (HTMLCollection|NodeList|Object)\\]$/.test(Object.prototype.toString.call(variable)) &&\n                variable.length !== undefined &&\n                (variable.length === 0 || (typeof variable[0] === \"object\" && variable[0].nodeType > 0));\n        },\n        /* Determine if variable is a wrapped jQuery or Zepto element. */\n        isWrapped: function (variable) {\n            return variable && (variable.jquery || (window.Zepto && window.Zepto.zepto.isZ(variable)));\n        },\n        isSVG: function (variable) {\n            return window.SVGElement && (variable instanceof window.SVGElement);\n        },\n        isEmptyObject: function (variable) {\n            for (var name in variable) {\n                return false;\n            }\n\n            return true;\n        }\n    };\n\n    /*****************\n       Dependencies\n    *****************/\n\n    var $,\n        isJQuery = false;\n\n    if (global.fn && global.fn.jquery) {\n        $ = global;\n        isJQuery = true;\n    } else {\n        $ = window.Velocity.Utilities;\n    }\n\n    if (IE <= 8 && !isJQuery) {\n        throw new Error(\"Velocity: IE8 and below require jQuery to be loaded before Velocity.\");\n    } else if (IE <= 7) {\n        /* Revert to jQuery's $.animate(), and lose Velocity's extra features. */\n        jQuery.fn.velocity = jQuery.fn.animate;\n\n        /* Now that $.fn.velocity is aliased, abort this Velocity declaration. */\n        return;\n    }\n\n    /*****************\n        Constants\n    *****************/\n\n    var DURATION_DEFAULT = 400,\n        EASING_DEFAULT = \"swing\";\n\n    /*************\n        State\n    *************/\n\n    var Velocity = {\n        /* Container for page-wide Velocity state data. */\n        State: {\n            /* Detect mobile devices to determine if mobileHA should be turned on. */\n            isMobile: /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),\n            /* The mobileHA option's behavior changes on older Android devices (Gingerbread, versions 2.3.3-2.3.7). */\n            isAndroid: /Android/i.test(navigator.userAgent),\n            isGingerbread: /Android 2\\.3\\.[3-7]/i.test(navigator.userAgent),\n            isChrome: window.chrome,\n            isFirefox: /Firefox/i.test(navigator.userAgent),\n            /* Create a cached element for re-use when checking for CSS property prefixes. */\n            prefixElement: document.createElement(\"div\"),\n            /* Cache every prefix match to avoid repeating lookups. */\n            prefixMatches: {},\n            /* Cache the anchor used for animating window scrolling. */\n            scrollAnchor: null,\n            /* Cache the browser-specific property names associated with the scroll anchor. */\n            scrollPropertyLeft: null,\n            scrollPropertyTop: null,\n            /* Keep track of whether our RAF tick is running. */\n            isTicking: false,\n            /* Container for every in-progress call to Velocity. */\n            calls: []\n        },\n        /* Velocity's custom CSS stack. Made global for unit testing. */\n        CSS: { /* Defined below. */ },\n        /* A shim of the jQuery utility functions used by Velocity -- provided by Velocity's optional jQuery shim. */\n        Utilities: $,\n        /* Container for the user's custom animation redirects that are referenced by name in place of the properties map argument. */\n        Redirects: { /* Manually registered by the user. */ },\n        Easings: { /* Defined below. */ },\n        /* Attempt to use ES6 Promises by default. Users can override this with a third-party promises library. */\n        Promise: window.Promise,\n        /* Velocity option defaults, which can be overriden by the user. */\n        defaults: {\n            queue: \"\",\n            duration: DURATION_DEFAULT,\n            easing: EASING_DEFAULT,\n            begin: undefined,\n            complete: undefined,\n            progress: undefined,\n            display: undefined,\n            visibility: undefined,\n            loop: false,\n            delay: false,\n            mobileHA: true,\n            /* Advanced: Set to false to prevent property values from being cached between consecutive Velocity-initiated chain calls. */\n            _cacheValues: true\n        },\n        /* A design goal of Velocity is to cache data wherever possible in order to avoid DOM requerying. Accordingly, each element has a data cache. */\n        init: function (element) {\n            $.data(element, \"velocity\", {\n                /* Store whether this is an SVG element, since its properties are retrieved and updated differently than standard HTML elements. */\n                isSVG: Type.isSVG(element),\n                /* Keep track of whether the element is currently being animated by Velocity.\n                   This is used to ensure that property values are not transferred between non-consecutive (stale) calls. */\n                isAnimating: false,\n                /* A reference to the element's live computedStyle object. Learn more here: https://developer.mozilla.org/en/docs/Web/API/window.getComputedStyle */\n                computedStyle: null,\n                /* Tween data is cached for each animation on the element so that data can be passed across calls --\n                   in particular, end values are used as subsequent start values in consecutive Velocity calls. */\n                tweensContainer: null,\n                /* The full root property values of each CSS hook being animated on this element are cached so that:\n                   1) Concurrently-animating hooks sharing the same root can have their root values' merged into one while tweening.\n                   2) Post-hook-injection root values can be transferred over to consecutively chained Velocity calls as starting root values. */\n                rootPropertyValueCache: {},\n                /* A cache for transform updates, which must be manually flushed via CSS.flushTransformCache(). */\n                transformCache: {}\n            });\n        },\n        /* A parallel to jQuery's $.css(), used for getting/setting Velocity's hooked CSS properties. */\n        hook: null, /* Defined below. */\n        /* Velocity-wide animation time remapping for testing purposes. */\n        mock: false,\n        version: { major: 1, minor: 2, patch: 2 },\n        /* Set to 1 or 2 (most verbose) to output debug info to console. */\n        debug: false\n    };\n\n    /* Retrieve the appropriate scroll anchor and property name for the browser: https://developer.mozilla.org/en-US/docs/Web/API/Window.scrollY */\n    if (window.pageYOffset !== undefined) {\n        Velocity.State.scrollAnchor = window;\n        Velocity.State.scrollPropertyLeft = \"pageXOffset\";\n        Velocity.State.scrollPropertyTop = \"pageYOffset\";\n    } else {\n        Velocity.State.scrollAnchor = document.documentElement || document.body.parentNode || document.body;\n        Velocity.State.scrollPropertyLeft = \"scrollLeft\";\n        Velocity.State.scrollPropertyTop = \"scrollTop\";\n    }\n\n    /* Shorthand alias for jQuery's $.data() utility. */\n    function Data (element) {\n        /* Hardcode a reference to the plugin name. */\n        var response = $.data(element, \"velocity\");\n\n        /* jQuery <=1.4.2 returns null instead of undefined when no match is found. We normalize this behavior. */\n        return response === null ? undefined : response;\n    };\n\n    /**************\n        Easing\n    **************/\n\n    /* Step easing generator. */\n    function generateStep (steps) {\n        return function (p) {\n            return Math.round(p * steps) * (1 / steps);\n        };\n    }\n\n    /* Bezier curve function generator. Copyright Gaetan Renaudeau. MIT License: http://en.wikipedia.org/wiki/MIT_License */\n    function generateBezier (mX1, mY1, mX2, mY2) {\n        var NEWTON_ITERATIONS = 4,\n            NEWTON_MIN_SLOPE = 0.001,\n            SUBDIVISION_PRECISION = 0.0000001,\n            SUBDIVISION_MAX_ITERATIONS = 10,\n            kSplineTableSize = 11,\n            kSampleStepSize = 1.0 / (kSplineTableSize - 1.0),\n            float32ArraySupported = \"Float32Array\" in window;\n\n        /* Must contain four arguments. */\n        if (arguments.length !== 4) {\n            return false;\n        }\n\n        /* Arguments must be numbers. */\n        for (var i = 0; i < 4; ++i) {\n            if (typeof arguments[i] !== \"number\" || isNaN(arguments[i]) || !isFinite(arguments[i])) {\n                return false;\n            }\n        }\n\n        /* X values must be in the [0, 1] range. */\n        mX1 = Math.min(mX1, 1);\n        mX2 = Math.min(mX2, 1);\n        mX1 = Math.max(mX1, 0);\n        mX2 = Math.max(mX2, 0);\n\n        var mSampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize);\n\n        function A (aA1, aA2) { return 1.0 - 3.0 * aA2 + 3.0 * aA1; }\n        function B (aA1, aA2) { return 3.0 * aA2 - 6.0 * aA1; }\n        function C (aA1)      { return 3.0 * aA1; }\n\n        function calcBezier (aT, aA1, aA2) {\n            return ((A(aA1, aA2)*aT + B(aA1, aA2))*aT + C(aA1))*aT;\n        }\n\n        function getSlope (aT, aA1, aA2) {\n            return 3.0 * A(aA1, aA2)*aT*aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n        }\n\n        function newtonRaphsonIterate (aX, aGuessT) {\n            for (var i = 0; i < NEWTON_ITERATIONS; ++i) {\n                var currentSlope = getSlope(aGuessT, mX1, mX2);\n\n                if (currentSlope === 0.0) return aGuessT;\n\n                var currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n                aGuessT -= currentX / currentSlope;\n            }\n\n            return aGuessT;\n        }\n\n        function calcSampleValues () {\n            for (var i = 0; i < kSplineTableSize; ++i) {\n                mSampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n            }\n        }\n\n        function binarySubdivide (aX, aA, aB) {\n            var currentX, currentT, i = 0;\n\n            do {\n                currentT = aA + (aB - aA) / 2.0;\n                currentX = calcBezier(currentT, mX1, mX2) - aX;\n                if (currentX > 0.0) {\n                  aB = currentT;\n                } else {\n                  aA = currentT;\n                }\n            } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS);\n\n            return currentT;\n        }\n\n        function getTForX (aX) {\n            var intervalStart = 0.0,\n                currentSample = 1,\n                lastSample = kSplineTableSize - 1;\n\n            for (; currentSample != lastSample && mSampleValues[currentSample] <= aX; ++currentSample) {\n                intervalStart += kSampleStepSize;\n            }\n\n            --currentSample;\n\n            var dist = (aX - mSampleValues[currentSample]) / (mSampleValues[currentSample+1] - mSampleValues[currentSample]),\n                guessForT = intervalStart + dist * kSampleStepSize,\n                initialSlope = getSlope(guessForT, mX1, mX2);\n\n            if (initialSlope >= NEWTON_MIN_SLOPE) {\n                return newtonRaphsonIterate(aX, guessForT);\n            } else if (initialSlope == 0.0) {\n                return guessForT;\n            } else {\n                return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize);\n            }\n        }\n\n        var _precomputed = false;\n\n        function precompute() {\n            _precomputed = true;\n            if (mX1 != mY1 || mX2 != mY2) calcSampleValues();\n        }\n\n        var f = function (aX) {\n            if (!_precomputed) precompute();\n            if (mX1 === mY1 && mX2 === mY2) return aX;\n            if (aX === 0) return 0;\n            if (aX === 1) return 1;\n\n            return calcBezier(getTForX(aX), mY1, mY2);\n        };\n\n        f.getControlPoints = function() { return [{ x: mX1, y: mY1 }, { x: mX2, y: mY2 }]; };\n\n        var str = \"generateBezier(\" + [mX1, mY1, mX2, mY2] + \")\";\n        f.toString = function () { return str; };\n\n        return f;\n    }\n\n    /* Runge-Kutta spring physics function generator. Adapted from Framer.js, copyright Koen Bok. MIT License: http://en.wikipedia.org/wiki/MIT_License */\n    /* Given a tension, friction, and duration, a simulation at 60FPS will first run without a defined duration in order to calculate the full path. A second pass\n       then adjusts the time delta -- using the relation between actual time and duration -- to calculate the path for the duration-constrained animation. */\n    var generateSpringRK4 = (function () {\n        function springAccelerationForState (state) {\n            return (-state.tension * state.x) - (state.friction * state.v);\n        }\n\n        function springEvaluateStateWithDerivative (initialState, dt, derivative) {\n            var state = {\n                x: initialState.x + derivative.dx * dt,\n                v: initialState.v + derivative.dv * dt,\n                tension: initialState.tension,\n                friction: initialState.friction\n            };\n\n            return { dx: state.v, dv: springAccelerationForState(state) };\n        }\n\n        function springIntegrateState (state, dt) {\n            var a = {\n                    dx: state.v,\n                    dv: springAccelerationForState(state)\n                },\n                b = springEvaluateStateWithDerivative(state, dt * 0.5, a),\n                c = springEvaluateStateWithDerivative(state, dt * 0.5, b),\n                d = springEvaluateStateWithDerivative(state, dt, c),\n                dxdt = 1.0 / 6.0 * (a.dx + 2.0 * (b.dx + c.dx) + d.dx),\n                dvdt = 1.0 / 6.0 * (a.dv + 2.0 * (b.dv + c.dv) + d.dv);\n\n            state.x = state.x + dxdt * dt;\n            state.v = state.v + dvdt * dt;\n\n            return state;\n        }\n\n        return function springRK4Factory (tension, friction, duration) {\n\n            var initState = {\n                    x: -1,\n                    v: 0,\n                    tension: null,\n                    friction: null\n                },\n                path = [0],\n                time_lapsed = 0,\n                tolerance = 1 / 10000,\n                DT = 16 / 1000,\n                have_duration, dt, last_state;\n\n            tension = parseFloat(tension) || 500;\n            friction = parseFloat(friction) || 20;\n            duration = duration || null;\n\n            initState.tension = tension;\n            initState.friction = friction;\n\n            have_duration = duration !== null;\n\n            /* Calculate the actual time it takes for this animation to complete with the provided conditions. */\n            if (have_duration) {\n                /* Run the simulation without a duration. */\n                time_lapsed = springRK4Factory(tension, friction);\n                /* Compute the adjusted time delta. */\n                dt = time_lapsed / duration * DT;\n            } else {\n                dt = DT;\n            }\n\n            while (true) {\n                /* Next/step function .*/\n                last_state = springIntegrateState(last_state || initState, dt);\n                /* Store the position. */\n                path.push(1 + last_state.x);\n                time_lapsed += 16;\n                /* If the change threshold is reached, break. */\n                if (!(Math.abs(last_state.x) > tolerance && Math.abs(last_state.v) > tolerance)) {\n                    break;\n                }\n            }\n\n            /* If duration is not defined, return the actual time required for completing this animation. Otherwise, return a closure that holds the\n               computed path and returns a snapshot of the position according to a given percentComplete. */\n            return !have_duration ? time_lapsed : function(percentComplete) { return path[ (percentComplete * (path.length - 1)) | 0 ]; };\n        };\n    }());\n\n    /* jQuery easings. */\n    Velocity.Easings = {\n        linear: function(p) { return p; },\n        swing: function(p) { return 0.5 - Math.cos( p * Math.PI ) / 2 },\n        /* Bonus \"spring\" easing, which is a less exaggerated version of easeInOutElastic. */\n        spring: function(p) { return 1 - (Math.cos(p * 4.5 * Math.PI) * Math.exp(-p * 6)); }\n    };\n\n    /* CSS3 and Robert Penner easings. */\n    $.each(\n        [\n            [ \"ease\", [ 0.25, 0.1, 0.25, 1.0 ] ],\n            [ \"ease-in\", [ 0.42, 0.0, 1.00, 1.0 ] ],\n            [ \"ease-out\", [ 0.00, 0.0, 0.58, 1.0 ] ],\n            [ \"ease-in-out\", [ 0.42, 0.0, 0.58, 1.0 ] ],\n            [ \"easeInSine\", [ 0.47, 0, 0.745, 0.715 ] ],\n            [ \"easeOutSine\", [ 0.39, 0.575, 0.565, 1 ] ],\n            [ \"easeInOutSine\", [ 0.445, 0.05, 0.55, 0.95 ] ],\n            [ \"easeInQuad\", [ 0.55, 0.085, 0.68, 0.53 ] ],\n            [ \"easeOutQuad\", [ 0.25, 0.46, 0.45, 0.94 ] ],\n            [ \"easeInOutQuad\", [ 0.455, 0.03, 0.515, 0.955 ] ],\n            [ \"easeInCubic\", [ 0.55, 0.055, 0.675, 0.19 ] ],\n            [ \"easeOutCubic\", [ 0.215, 0.61, 0.355, 1 ] ],\n            [ \"easeInOutCubic\", [ 0.645, 0.045, 0.355, 1 ] ],\n            [ \"easeInQuart\", [ 0.895, 0.03, 0.685, 0.22 ] ],\n            [ \"easeOutQuart\", [ 0.165, 0.84, 0.44, 1 ] ],\n            [ \"easeInOutQuart\", [ 0.77, 0, 0.175, 1 ] ],\n            [ \"easeInQuint\", [ 0.755, 0.05, 0.855, 0.06 ] ],\n            [ \"easeOutQuint\", [ 0.23, 1, 0.32, 1 ] ],\n            [ \"easeInOutQuint\", [ 0.86, 0, 0.07, 1 ] ],\n            [ \"easeInExpo\", [ 0.95, 0.05, 0.795, 0.035 ] ],\n            [ \"easeOutExpo\", [ 0.19, 1, 0.22, 1 ] ],\n            [ \"easeInOutExpo\", [ 1, 0, 0, 1 ] ],\n            [ \"easeInCirc\", [ 0.6, 0.04, 0.98, 0.335 ] ],\n            [ \"easeOutCirc\", [ 0.075, 0.82, 0.165, 1 ] ],\n            [ \"easeInOutCirc\", [ 0.785, 0.135, 0.15, 0.86 ] ]\n        ], function(i, easingArray) {\n            Velocity.Easings[easingArray[0]] = generateBezier.apply(null, easingArray[1]);\n        });\n\n    /* Determine the appropriate easing type given an easing input. */\n    function getEasing(value, duration) {\n        var easing = value;\n\n        /* The easing option can either be a string that references a pre-registered easing,\n           or it can be a two-/four-item array of integers to be converted into a bezier/spring function. */\n        if (Type.isString(value)) {\n            /* Ensure that the easing has been assigned to jQuery's Velocity.Easings object. */\n            if (!Velocity.Easings[value]) {\n                easing = false;\n            }\n        } else if (Type.isArray(value) && value.length === 1) {\n            easing = generateStep.apply(null, value);\n        } else if (Type.isArray(value) && value.length === 2) {\n            /* springRK4 must be passed the animation's duration. */\n            /* Note: If the springRK4 array contains non-numbers, generateSpringRK4() returns an easing\n               function generated with default tension and friction values. */\n            easing = generateSpringRK4.apply(null, value.concat([ duration ]));\n        } else if (Type.isArray(value) && value.length === 4) {\n            /* Note: If the bezier array contains non-numbers, generateBezier() returns false. */\n            easing = generateBezier.apply(null, value);\n        } else {\n            easing = false;\n        }\n\n        /* Revert to the Velocity-wide default easing type, or fall back to \"swing\" (which is also jQuery's default)\n           if the Velocity-wide default has been incorrectly modified. */\n        if (easing === false) {\n            if (Velocity.Easings[Velocity.defaults.easing]) {\n                easing = Velocity.defaults.easing;\n            } else {\n                easing = EASING_DEFAULT;\n            }\n        }\n\n        return easing;\n    }\n\n    /*****************\n        CSS Stack\n    *****************/\n\n    /* The CSS object is a highly condensed and performant CSS stack that fully replaces jQuery's.\n       It handles the validation, getting, and setting of both standard CSS properties and CSS property hooks. */\n    /* Note: A \"CSS\" shorthand is aliased so that our code is easier to read. */\n    var CSS = Velocity.CSS = {\n\n        /*************\n            RegEx\n        *************/\n\n        RegEx: {\n            isHex: /^#([A-f\\d]{3}){1,2}$/i,\n            /* Unwrap a property value's surrounding text, e.g. \"rgba(4, 3, 2, 1)\" ==> \"4, 3, 2, 1\" and \"rect(4px 3px 2px 1px)\" ==> \"4px 3px 2px 1px\". */\n            valueUnwrap: /^[A-z]+\\((.*)\\)$/i,\n            wrappedValueAlreadyExtracted: /[0-9.]+ [0-9.]+ [0-9.]+( [0-9.]+)?/,\n            /* Split a multi-value property into an array of subvalues, e.g. \"rgba(4, 3, 2, 1) 4px 3px 2px 1px\" ==> [ \"rgba(4, 3, 2, 1)\", \"4px\", \"3px\", \"2px\", \"1px\" ]. */\n            valueSplit: /([A-z]+\\(.+\\))|(([A-z0-9#-.]+?)(?=\\s|$))/ig\n        },\n\n        /************\n            Lists\n        ************/\n\n        Lists: {\n            colors: [ \"fill\", \"stroke\", \"stopColor\", \"color\", \"backgroundColor\", \"borderColor\", \"borderTopColor\", \"borderRightColor\", \"borderBottomColor\", \"borderLeftColor\", \"outlineColor\" ],\n            transformsBase: [ \"translateX\", \"translateY\", \"scale\", \"scaleX\", \"scaleY\", \"skewX\", \"skewY\", \"rotateZ\" ],\n            transforms3D: [ \"transformPerspective\", \"translateZ\", \"scaleZ\", \"rotateX\", \"rotateY\" ]\n        },\n\n        /************\n            Hooks\n        ************/\n\n        /* Hooks allow a subproperty (e.g. \"boxShadowBlur\") of a compound-value CSS property\n           (e.g. \"boxShadow: X Y Blur Spread Color\") to be animated as if it were a discrete property. */\n        /* Note: Beyond enabling fine-grained property animation, hooking is necessary since Velocity only\n           tweens properties with single numeric values; unlike CSS transitions, Velocity does not interpolate compound-values. */\n        Hooks: {\n            /********************\n                Registration\n            ********************/\n\n            /* Templates are a concise way of indicating which subproperties must be individually registered for each compound-value CSS property. */\n            /* Each template consists of the compound-value's base name, its constituent subproperty names, and those subproperties' default values. */\n            templates: {\n                \"textShadow\": [ \"Color X Y Blur\", \"black 0px 0px 0px\" ],\n                \"boxShadow\": [ \"Color X Y Blur Spread\", \"black 0px 0px 0px 0px\" ],\n                \"clip\": [ \"Top Right Bottom Left\", \"0px 0px 0px 0px\" ],\n                \"backgroundPosition\": [ \"X Y\", \"0% 0%\" ],\n                \"transformOrigin\": [ \"X Y Z\", \"50% 50% 0px\" ],\n                \"perspectiveOrigin\": [ \"X Y\", \"50% 50%\" ]\n            },\n\n            /* A \"registered\" hook is one that has been converted from its template form into a live,\n               tweenable property. It contains data to associate it with its root property. */\n            registered: {\n                /* Note: A registered hook looks like this ==> textShadowBlur: [ \"textShadow\", 3 ],\n                   which consists of the subproperty's name, the associated root property's name,\n                   and the subproperty's position in the root's value. */\n            },\n            /* Convert the templates into individual hooks then append them to the registered object above. */\n            register: function () {\n                /* Color hooks registration: Colors are defaulted to white -- as opposed to black -- since colors that are\n                   currently set to \"transparent\" default to their respective template below when color-animated,\n                   and white is typically a closer match to transparent than black is. An exception is made for text (\"color\"),\n                   which is almost always set closer to black than white. */\n                for (var i = 0; i < CSS.Lists.colors.length; i++) {\n                    var rgbComponents = (CSS.Lists.colors[i] === \"color\") ? \"0 0 0 1\" : \"255 255 255 1\";\n                    CSS.Hooks.templates[CSS.Lists.colors[i]] = [ \"Red Green Blue Alpha\", rgbComponents ];\n                }\n\n                var rootProperty,\n                    hookTemplate,\n                    hookNames;\n\n                /* In IE, color values inside compound-value properties are positioned at the end the value instead of at the beginning.\n                   Thus, we re-arrange the templates accordingly. */\n                if (IE) {\n                    for (rootProperty in CSS.Hooks.templates) {\n                        hookTemplate = CSS.Hooks.templates[rootProperty];\n                        hookNames = hookTemplate[0].split(\" \");\n\n                        var defaultValues = hookTemplate[1].match(CSS.RegEx.valueSplit);\n\n                        if (hookNames[0] === \"Color\") {\n                            /* Reposition both the hook's name and its default value to the end of their respective strings. */\n                            hookNames.push(hookNames.shift());\n                            defaultValues.push(defaultValues.shift());\n\n                            /* Replace the existing template for the hook's root property. */\n                            CSS.Hooks.templates[rootProperty] = [ hookNames.join(\" \"), defaultValues.join(\" \") ];\n                        }\n                    }\n                }\n\n                /* Hook registration. */\n                for (rootProperty in CSS.Hooks.templates) {\n                    hookTemplate = CSS.Hooks.templates[rootProperty];\n                    hookNames = hookTemplate[0].split(\" \");\n\n                    for (var i in hookNames) {\n                        var fullHookName = rootProperty + hookNames[i],\n                            hookPosition = i;\n\n                        /* For each hook, register its full name (e.g. textShadowBlur) with its root property (e.g. textShadow)\n                           and the hook's position in its template's default value string. */\n                        CSS.Hooks.registered[fullHookName] = [ rootProperty, hookPosition ];\n                    }\n                }\n            },\n\n            /*****************************\n               Injection and Extraction\n            *****************************/\n\n            /* Look up the root property associated with the hook (e.g. return \"textShadow\" for \"textShadowBlur\"). */\n            /* Since a hook cannot be set directly (the browser won't recognize it), style updating for hooks is routed through the hook's root property. */\n            getRoot: function (property) {\n                var hookData = CSS.Hooks.registered[property];\n\n                if (hookData) {\n                    return hookData[0];\n                } else {\n                    /* If there was no hook match, return the property name untouched. */\n                    return property;\n                }\n            },\n            /* Convert any rootPropertyValue, null or otherwise, into a space-delimited list of hook values so that\n               the targeted hook can be injected or extracted at its standard position. */\n            cleanRootPropertyValue: function(rootProperty, rootPropertyValue) {\n                /* If the rootPropertyValue is wrapped with \"rgb()\", \"clip()\", etc., remove the wrapping to normalize the value before manipulation. */\n                if (CSS.RegEx.valueUnwrap.test(rootPropertyValue)) {\n                    rootPropertyValue = rootPropertyValue.match(CSS.RegEx.valueUnwrap)[1];\n                }\n\n                /* If rootPropertyValue is a CSS null-value (from which there's inherently no hook value to extract),\n                   default to the root's default value as defined in CSS.Hooks.templates. */\n                /* Note: CSS null-values include \"none\", \"auto\", and \"transparent\". They must be converted into their\n                   zero-values (e.g. textShadow: \"none\" ==> textShadow: \"0px 0px 0px black\") for hook manipulation to proceed. */\n                if (CSS.Values.isCSSNullValue(rootPropertyValue)) {\n                    rootPropertyValue = CSS.Hooks.templates[rootProperty][1];\n                }\n\n                return rootPropertyValue;\n            },\n            /* Extracted the hook's value from its root property's value. This is used to get the starting value of an animating hook. */\n            extractValue: function (fullHookName, rootPropertyValue) {\n                var hookData = CSS.Hooks.registered[fullHookName];\n\n                if (hookData) {\n                    var hookRoot = hookData[0],\n                        hookPosition = hookData[1];\n\n                    rootPropertyValue = CSS.Hooks.cleanRootPropertyValue(hookRoot, rootPropertyValue);\n\n                    /* Split rootPropertyValue into its constituent hook values then grab the desired hook at its standard position. */\n                    return rootPropertyValue.toString().match(CSS.RegEx.valueSplit)[hookPosition];\n                } else {\n                    /* If the provided fullHookName isn't a registered hook, return the rootPropertyValue that was passed in. */\n                    return rootPropertyValue;\n                }\n            },\n            /* Inject the hook's value into its root property's value. This is used to piece back together the root property\n               once Velocity has updated one of its individually hooked values through tweening. */\n            injectValue: function (fullHookName, hookValue, rootPropertyValue) {\n                var hookData = CSS.Hooks.registered[fullHookName];\n\n                if (hookData) {\n                    var hookRoot = hookData[0],\n                        hookPosition = hookData[1],\n                        rootPropertyValueParts,\n                        rootPropertyValueUpdated;\n\n                    rootPropertyValue = CSS.Hooks.cleanRootPropertyValue(hookRoot, rootPropertyValue);\n\n                    /* Split rootPropertyValue into its individual hook values, replace the targeted value with hookValue,\n                       then reconstruct the rootPropertyValue string. */\n                    rootPropertyValueParts = rootPropertyValue.toString().match(CSS.RegEx.valueSplit);\n                    rootPropertyValueParts[hookPosition] = hookValue;\n                    rootPropertyValueUpdated = rootPropertyValueParts.join(\" \");\n\n                    return rootPropertyValueUpdated;\n                } else {\n                    /* If the provided fullHookName isn't a registered hook, return the rootPropertyValue that was passed in. */\n                    return rootPropertyValue;\n                }\n            }\n        },\n\n        /*******************\n           Normalizations\n        *******************/\n\n        /* Normalizations standardize CSS property manipulation by pollyfilling browser-specific implementations (e.g. opacity)\n           and reformatting special properties (e.g. clip, rgba) to look like standard ones. */\n        Normalizations: {\n            /* Normalizations are passed a normalization target (either the property's name, its extracted value, or its injected value),\n               the targeted element (which may need to be queried), and the targeted property value. */\n            registered: {\n                clip: function (type, element, propertyValue) {\n                    switch (type) {\n                        case \"name\":\n                            return \"clip\";\n                        /* Clip needs to be unwrapped and stripped of its commas during extraction. */\n                        case \"extract\":\n                            var extracted;\n\n                            /* If Velocity also extracted this value, skip extraction. */\n                            if (CSS.RegEx.wrappedValueAlreadyExtracted.test(propertyValue)) {\n                                extracted = propertyValue;\n                            } else {\n                                /* Remove the \"rect()\" wrapper. */\n                                extracted = propertyValue.toString().match(CSS.RegEx.valueUnwrap);\n\n                                /* Strip off commas. */\n                                extracted = extracted ? extracted[1].replace(/,(\\s+)?/g, \" \") : propertyValue;\n                            }\n\n                            return extracted;\n                        /* Clip needs to be re-wrapped during injection. */\n                        case \"inject\":\n                            return \"rect(\" + propertyValue + \")\";\n                    }\n                },\n\n                blur: function(type, element, propertyValue) {\n                    switch (type) {\n                        case \"name\":\n                            return Velocity.State.isFirefox ? \"filter\" : \"-webkit-filter\";\n                        case \"extract\":\n                            var extracted = parseFloat(propertyValue);\n\n                            /* If extracted is NaN, meaning the value isn't already extracted. */\n                            if (!(extracted || extracted === 0)) {\n                                var blurComponent = propertyValue.toString().match(/blur\\(([0-9]+[A-z]+)\\)/i);\n\n                                /* If the filter string had a blur component, return just the blur value and unit type. */\n                                if (blurComponent) {\n                                    extracted = blurComponent[1];\n                                /* If the component doesn't exist, default blur to 0. */\n                                } else {\n                                    extracted = 0;\n                                }\n                            }\n\n                            return extracted;\n                        /* Blur needs to be re-wrapped during injection. */\n                        case \"inject\":\n                            /* For the blur effect to be fully de-applied, it needs to be set to \"none\" instead of 0. */\n                            if (!parseFloat(propertyValue)) {\n                                return \"none\";\n                            } else {\n                                return \"blur(\" + propertyValue + \")\";\n                            }\n                    }\n                },\n\n                /* <=IE8 do not support the standard opacity property. They use filter:alpha(opacity=INT) instead. */\n                opacity: function (type, element, propertyValue) {\n                    if (IE <= 8) {\n                        switch (type) {\n                            case \"name\":\n                                return \"filter\";\n                            case \"extract\":\n                                /* <=IE8 return a \"filter\" value of \"alpha(opacity=\\d{1,3})\".\n                                   Extract the value and convert it to a decimal value to match the standard CSS opacity property's formatting. */\n                                var extracted = propertyValue.toString().match(/alpha\\(opacity=(.*)\\)/i);\n\n                                if (extracted) {\n                                    /* Convert to decimal value. */\n                                    propertyValue = extracted[1] / 100;\n                                } else {\n                                    /* When extracting opacity, default to 1 since a null value means opacity hasn't been set. */\n                                    propertyValue = 1;\n                                }\n\n                                return propertyValue;\n                            case \"inject\":\n                                /* Opacified elements are required to have their zoom property set to a non-zero value. */\n                                element.style.zoom = 1;\n\n                                /* Setting the filter property on elements with certain font property combinations can result in a\n                                   highly unappealing ultra-bolding effect. There's no way to remedy this throughout a tween, but dropping the\n                                   value altogether (when opacity hits 1) at leasts ensures that the glitch is gone post-tweening. */\n                                if (parseFloat(propertyValue) >= 1) {\n                                    return \"\";\n                                } else {\n                                  /* As per the filter property's spec, convert the decimal value to a whole number and wrap the value. */\n                                  return \"alpha(opacity=\" + parseInt(parseFloat(propertyValue) * 100, 10) + \")\";\n                                }\n                        }\n                    /* With all other browsers, normalization is not required; return the same values that were passed in. */\n                    } else {\n                        switch (type) {\n                            case \"name\":\n                                return \"opacity\";\n                            case \"extract\":\n                                return propertyValue;\n                            case \"inject\":\n                                return propertyValue;\n                        }\n                    }\n                }\n            },\n\n            /*****************************\n                Batched Registrations\n            *****************************/\n\n            /* Note: Batched normalizations extend the CSS.Normalizations.registered object. */\n            register: function () {\n\n                /*****************\n                    Transforms\n                *****************/\n\n                /* Transforms are the subproperties contained by the CSS \"transform\" property. Transforms must undergo normalization\n                   so that they can be referenced in a properties map by their individual names. */\n                /* Note: When transforms are \"set\", they are actually assigned to a per-element transformCache. When all transform\n                   setting is complete complete, CSS.flushTransformCache() must be manually called to flush the values to the DOM.\n                   Transform setting is batched in this way to improve performance: the transform style only needs to be updated\n                   once when multiple transform subproperties are being animated simultaneously. */\n                /* Note: IE9 and Android Gingerbread have support for 2D -- but not 3D -- transforms. Since animating unsupported\n                   transform properties results in the browser ignoring the *entire* transform string, we prevent these 3D values\n                   from being normalized for these browsers so that tweening skips these properties altogether\n                   (since it will ignore them as being unsupported by the browser.) */\n                if (!(IE <= 9) && !Velocity.State.isGingerbread) {\n                    /* Note: Since the standalone CSS \"perspective\" property and the CSS transform \"perspective\" subproperty\n                    share the same name, the latter is given a unique token within Velocity: \"transformPerspective\". */\n                    CSS.Lists.transformsBase = CSS.Lists.transformsBase.concat(CSS.Lists.transforms3D);\n                }\n\n                for (var i = 0; i < CSS.Lists.transformsBase.length; i++) {\n                    /* Wrap the dynamically generated normalization function in a new scope so that transformName's value is\n                    paired with its respective function. (Otherwise, all functions would take the final for loop's transformName.) */\n                    (function() {\n                        var transformName = CSS.Lists.transformsBase[i];\n\n                        CSS.Normalizations.registered[transformName] = function (type, element, propertyValue) {\n                            switch (type) {\n                                /* The normalized property name is the parent \"transform\" property -- the property that is actually set in CSS. */\n                                case \"name\":\n                                    return \"transform\";\n                                /* Transform values are cached onto a per-element transformCache object. */\n                                case \"extract\":\n                                    /* If this transform has yet to be assigned a value, return its null value. */\n                                    if (Data(element) === undefined || Data(element).transformCache[transformName] === undefined) {\n                                        /* Scale CSS.Lists.transformsBase default to 1 whereas all other transform properties default to 0. */\n                                        return /^scale/i.test(transformName) ? 1 : 0;\n                                    /* When transform values are set, they are wrapped in parentheses as per the CSS spec.\n                                       Thus, when extracting their values (for tween calculations), we strip off the parentheses. */\n                                    } else {\n                                        return Data(element).transformCache[transformName].replace(/[()]/g, \"\");\n                                    }\n                                case \"inject\":\n                                    var invalid = false;\n\n                                    /* If an individual transform property contains an unsupported unit type, the browser ignores the *entire* transform property.\n                                       Thus, protect users from themselves by skipping setting for transform values supplied with invalid unit types. */\n                                    /* Switch on the base transform type; ignore the axis by removing the last letter from the transform's name. */\n                                    switch (transformName.substr(0, transformName.length - 1)) {\n                                        /* Whitelist unit types for each transform. */\n                                        case \"translate\":\n                                            invalid = !/(%|px|em|rem|vw|vh|\\d)$/i.test(propertyValue);\n                                            break;\n                                        /* Since an axis-free \"scale\" property is supported as well, a little hack is used here to detect it by chopping off its last letter. */\n                                        case \"scal\":\n                                        case \"scale\":\n                                            /* Chrome on Android has a bug in which scaled elements blur if their initial scale\n                                               value is below 1 (which can happen with forcefeeding). Thus, we detect a yet-unset scale property\n                                               and ensure that its first value is always 1. More info: http://stackoverflow.com/questions/10417890/css3-animations-with-transform-causes-blurred-elements-on-webkit/10417962#10417962 */\n                                            if (Velocity.State.isAndroid && Data(element).transformCache[transformName] === undefined && propertyValue < 1) {\n                                                propertyValue = 1;\n                                            }\n\n                                            invalid = !/(\\d)$/i.test(propertyValue);\n                                            break;\n                                        case \"skew\":\n                                            invalid = !/(deg|\\d)$/i.test(propertyValue);\n                                            break;\n                                        case \"rotate\":\n                                            invalid = !/(deg|\\d)$/i.test(propertyValue);\n                                            break;\n                                    }\n\n                                    if (!invalid) {\n                                        /* As per the CSS spec, wrap the value in parentheses. */\n                                        Data(element).transformCache[transformName] = \"(\" + propertyValue + \")\";\n                                    }\n\n                                    /* Although the value is set on the transformCache object, return the newly-updated value for the calling code to process as normal. */\n                                    return Data(element).transformCache[transformName];\n                            }\n                        };\n                    })();\n                }\n\n                /*************\n                    Colors\n                *************/\n\n                /* Since Velocity only animates a single numeric value per property, color animation is achieved by hooking the individual RGBA components of CSS color properties.\n                   Accordingly, color values must be normalized (e.g. \"#ff0000\", \"red\", and \"rgb(255, 0, 0)\" ==> \"255 0 0 1\") so that their components can be injected/extracted by CSS.Hooks logic. */\n                for (var i = 0; i < CSS.Lists.colors.length; i++) {\n                    /* Wrap the dynamically generated normalization function in a new scope so that colorName's value is paired with its respective function.\n                       (Otherwise, all functions would take the final for loop's colorName.) */\n                    (function () {\n                        var colorName = CSS.Lists.colors[i];\n\n                        /* Note: In IE<=8, which support rgb but not rgba, color properties are reverted to rgb by stripping off the alpha component. */\n                        CSS.Normalizations.registered[colorName] = function(type, element, propertyValue) {\n                            switch (type) {\n                                case \"name\":\n                                    return colorName;\n                                /* Convert all color values into the rgb format. (Old IE can return hex values and color names instead of rgb/rgba.) */\n                                case \"extract\":\n                                    var extracted;\n\n                                    /* If the color is already in its hookable form (e.g. \"255 255 255 1\") due to having been previously extracted, skip extraction. */\n                                    if (CSS.RegEx.wrappedValueAlreadyExtracted.test(propertyValue)) {\n                                        extracted = propertyValue;\n                                    } else {\n                                        var converted,\n                                            colorNames = {\n                                                black: \"rgb(0, 0, 0)\",\n                                                blue: \"rgb(0, 0, 255)\",\n                                                gray: \"rgb(128, 128, 128)\",\n                                                green: \"rgb(0, 128, 0)\",\n                                                red: \"rgb(255, 0, 0)\",\n                                                white: \"rgb(255, 255, 255)\"\n                                            };\n\n                                        /* Convert color names to rgb. */\n                                        if (/^[A-z]+$/i.test(propertyValue)) {\n                                            if (colorNames[propertyValue] !== undefined) {\n                                                converted = colorNames[propertyValue]\n                                            } else {\n                                                /* If an unmatched color name is provided, default to black. */\n                                                converted = colorNames.black;\n                                            }\n                                        /* Convert hex values to rgb. */\n                                        } else if (CSS.RegEx.isHex.test(propertyValue)) {\n                                            converted = \"rgb(\" + CSS.Values.hexToRgb(propertyValue).join(\" \") + \")\";\n                                        /* If the provided color doesn't match any of the accepted color formats, default to black. */\n                                        } else if (!(/^rgba?\\(/i.test(propertyValue))) {\n                                            converted = colorNames.black;\n                                        }\n\n                                        /* Remove the surrounding \"rgb/rgba()\" string then replace commas with spaces and strip\n                                           repeated spaces (in case the value included spaces to begin with). */\n                                        extracted = (converted || propertyValue).toString().match(CSS.RegEx.valueUnwrap)[1].replace(/,(\\s+)?/g, \" \");\n                                    }\n\n                                    /* So long as this isn't <=IE8, add a fourth (alpha) component if it's missing and default it to 1 (visible). */\n                                    if (!(IE <= 8) && extracted.split(\" \").length === 3) {\n                                        extracted += \" 1\";\n                                    }\n\n                                    return extracted;\n                                case \"inject\":\n                                    /* If this is IE<=8 and an alpha component exists, strip it off. */\n                                    if (IE <= 8) {\n                                        if (propertyValue.split(\" \").length === 4) {\n                                            propertyValue = propertyValue.split(/\\s+/).slice(0, 3).join(\" \");\n                                        }\n                                    /* Otherwise, add a fourth (alpha) component if it's missing and default it to 1 (visible). */\n                                    } else if (propertyValue.split(\" \").length === 3) {\n                                        propertyValue += \" 1\";\n                                    }\n\n                                    /* Re-insert the browser-appropriate wrapper(\"rgb/rgba()\"), insert commas, and strip off decimal units\n                                       on all values but the fourth (R, G, and B only accept whole numbers). */\n                                    return (IE <= 8 ? \"rgb\" : \"rgba\") + \"(\" + propertyValue.replace(/\\s+/g, \",\").replace(/\\.(\\d)+(?=,)/g, \"\") + \")\";\n                            }\n                        };\n                    })();\n                }\n            }\n        },\n\n        /************************\n           CSS Property Names\n        ************************/\n\n        Names: {\n            /* Camelcase a property name into its JavaScript notation (e.g. \"background-color\" ==> \"backgroundColor\").\n               Camelcasing is used to normalize property names between and across calls. */\n            camelCase: function (property) {\n                return property.replace(/-(\\w)/g, function (match, subMatch) {\n                    return subMatch.toUpperCase();\n                });\n            },\n\n            /* For SVG elements, some properties (namely, dimensional ones) are GET/SET via the element's HTML attributes (instead of via CSS styles). */\n            SVGAttribute: function (property) {\n                var SVGAttributes = \"width|height|x|y|cx|cy|r|rx|ry|x1|x2|y1|y2\";\n\n                /* Certain browsers require an SVG transform to be applied as an attribute. (Otherwise, application via CSS is preferable due to 3D support.) */\n                if (IE || (Velocity.State.isAndroid && !Velocity.State.isChrome)) {\n                    SVGAttributes += \"|transform\";\n                }\n\n                return new RegExp(\"^(\" + SVGAttributes + \")$\", \"i\").test(property);\n            },\n\n            /* Determine whether a property should be set with a vendor prefix. */\n            /* If a prefixed version of the property exists, return it. Otherwise, return the original property name.\n               If the property is not at all supported by the browser, return a false flag. */\n            prefixCheck: function (property) {\n                /* If this property has already been checked, return the cached value. */\n                if (Velocity.State.prefixMatches[property]) {\n                    return [ Velocity.State.prefixMatches[property], true ];\n                } else {\n                    var vendors = [ \"\", \"Webkit\", \"Moz\", \"ms\", \"O\" ];\n\n                    for (var i = 0, vendorsLength = vendors.length; i < vendorsLength; i++) {\n                        var propertyPrefixed;\n\n                        if (i === 0) {\n                            propertyPrefixed = property;\n                        } else {\n                            /* Capitalize the first letter of the property to conform to JavaScript vendor prefix notation (e.g. webkitFilter). */\n                            propertyPrefixed = vendors[i] + property.replace(/^\\w/, function(match) { return match.toUpperCase(); });\n                        }\n\n                        /* Check if the browser supports this property as prefixed. */\n                        if (Type.isString(Velocity.State.prefixElement.style[propertyPrefixed])) {\n                            /* Cache the match. */\n                            Velocity.State.prefixMatches[property] = propertyPrefixed;\n\n                            return [ propertyPrefixed, true ];\n                        }\n                    }\n\n                    /* If the browser doesn't support this property in any form, include a false flag so that the caller can decide how to proceed. */\n                    return [ property, false ];\n                }\n            }\n        },\n\n        /************************\n           CSS Property Values\n        ************************/\n\n        Values: {\n            /* Hex to RGB conversion. Copyright Tim Down: http://stackoverflow.com/questions/5623838/rgb-to-hex-and-hex-to-rgb */\n            hexToRgb: function (hex) {\n                var shortformRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i,\n                    longformRegex = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i,\n                    rgbParts;\n\n                hex = hex.replace(shortformRegex, function (m, r, g, b) {\n                    return r + r + g + g + b + b;\n                });\n\n                rgbParts = longformRegex.exec(hex);\n\n                return rgbParts ? [ parseInt(rgbParts[1], 16), parseInt(rgbParts[2], 16), parseInt(rgbParts[3], 16) ] : [ 0, 0, 0 ];\n            },\n\n            isCSSNullValue: function (value) {\n                /* The browser defaults CSS values that have not been set to either 0 or one of several possible null-value strings.\n                   Thus, we check for both falsiness and these special strings. */\n                /* Null-value checking is performed to default the special strings to 0 (for the sake of tweening) or their hook\n                   templates as defined as CSS.Hooks (for the sake of hook injection/extraction). */\n                /* Note: Chrome returns \"rgba(0, 0, 0, 0)\" for an undefined color whereas IE returns \"transparent\". */\n                return (value == 0 || /^(none|auto|transparent|(rgba\\(0, ?0, ?0, ?0\\)))$/i.test(value));\n            },\n\n            /* Retrieve a property's default unit type. Used for assigning a unit type when one is not supplied by the user. */\n            getUnitType: function (property) {\n                if (/^(rotate|skew)/i.test(property)) {\n                    return \"deg\";\n                } else if (/(^(scale|scaleX|scaleY|scaleZ|alpha|flexGrow|flexHeight|zIndex|fontWeight)$)|((opacity|red|green|blue|alpha)$)/i.test(property)) {\n                    /* The above properties are unitless. */\n                    return \"\";\n                } else {\n                    /* Default to px for all other properties. */\n                    return \"px\";\n                }\n            },\n\n            /* HTML elements default to an associated display type when they're not set to display:none. */\n            /* Note: This function is used for correctly setting the non-\"none\" display value in certain Velocity redirects, such as fadeIn/Out. */\n            getDisplayType: function (element) {\n                var tagName = element && element.tagName.toString().toLowerCase();\n\n                if (/^(b|big|i|small|tt|abbr|acronym|cite|code|dfn|em|kbd|strong|samp|var|a|bdo|br|img|map|object|q|script|span|sub|sup|button|input|label|select|textarea)$/i.test(tagName)) {\n                    return \"inline\";\n                } else if (/^(li)$/i.test(tagName)) {\n                    return \"list-item\";\n                } else if (/^(tr)$/i.test(tagName)) {\n                    return \"table-row\";\n                } else if (/^(table)$/i.test(tagName)) {\n                    return \"table\";\n                } else if (/^(tbody)$/i.test(tagName)) {\n                    return \"table-row-group\";\n                /* Default to \"block\" when no match is found. */\n                } else {\n                    return \"block\";\n                }\n            },\n\n            /* The class add/remove functions are used to temporarily apply a \"velocity-animating\" class to elements while they're animating. */\n            addClass: function (element, className) {\n                if (element.classList) {\n                    element.classList.add(className);\n                } else {\n                    element.className += (element.className.length ? \" \" : \"\") + className;\n                }\n            },\n\n            removeClass: function (element, className) {\n                if (element.classList) {\n                    element.classList.remove(className);\n                } else {\n                    element.className = element.className.toString().replace(new RegExp(\"(^|\\\\s)\" + className.split(\" \").join(\"|\") + \"(\\\\s|$)\", \"gi\"), \" \");\n                }\n            }\n        },\n\n        /****************************\n           Style Getting & Setting\n        ****************************/\n\n        /* The singular getPropertyValue, which routes the logic for all normalizations, hooks, and standard CSS properties. */\n        getPropertyValue: function (element, property, rootPropertyValue, forceStyleLookup) {\n            /* Get an element's computed property value. */\n            /* Note: Retrieving the value of a CSS property cannot simply be performed by checking an element's\n               style attribute (which only reflects user-defined values). Instead, the browser must be queried for a property's\n               *computed* value. You can read more about getComputedStyle here: https://developer.mozilla.org/en/docs/Web/API/window.getComputedStyle */\n            function computePropertyValue (element, property) {\n                /* When box-sizing isn't set to border-box, height and width style values are incorrectly computed when an\n                   element's scrollbars are visible (which expands the element's dimensions). Thus, we defer to the more accurate\n                   offsetHeight/Width property, which includes the total dimensions for interior, border, padding, and scrollbar.\n                   We subtract border and padding to get the sum of interior + scrollbar. */\n                var computedValue = 0;\n\n                /* IE<=8 doesn't support window.getComputedStyle, thus we defer to jQuery, which has an extensive array\n                   of hacks to accurately retrieve IE8 property values. Re-implementing that logic here is not worth bloating the\n                   codebase for a dying browser. The performance repercussions of using jQuery here are minimal since\n                   Velocity is optimized to rarely (and sometimes never) query the DOM. Further, the $.css() codepath isn't that slow. */\n                if (IE <= 8) {\n                    computedValue = $.css(element, property); /* GET */\n                /* All other browsers support getComputedStyle. The returned live object reference is cached onto its\n                   associated element so that it does not need to be refetched upon every GET. */\n                } else {\n                    /* Browsers do not return height and width values for elements that are set to display:\"none\". Thus, we temporarily\n                       toggle display to the element type's default value. */\n                    var toggleDisplay = false;\n\n                    if (/^(width|height)$/.test(property) && CSS.getPropertyValue(element, \"display\") === 0) {\n                        toggleDisplay = true;\n                        CSS.setPropertyValue(element, \"display\", CSS.Values.getDisplayType(element));\n                    }\n\n                    function revertDisplay () {\n                        if (toggleDisplay) {\n                            CSS.setPropertyValue(element, \"display\", \"none\");\n                        }\n                    }\n\n                    if (!forceStyleLookup) {\n                        if (property === \"height\" && CSS.getPropertyValue(element, \"boxSizing\").toString().toLowerCase() !== \"border-box\") {\n                            var contentBoxHeight = element.offsetHeight - (parseFloat(CSS.getPropertyValue(element, \"borderTopWidth\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"borderBottomWidth\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"paddingTop\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"paddingBottom\")) || 0);\n                            revertDisplay();\n\n                            return contentBoxHeight;\n                        } else if (property === \"width\" && CSS.getPropertyValue(element, \"boxSizing\").toString().toLowerCase() !== \"border-box\") {\n                            var contentBoxWidth = element.offsetWidth - (parseFloat(CSS.getPropertyValue(element, \"borderLeftWidth\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"borderRightWidth\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"paddingLeft\")) || 0) - (parseFloat(CSS.getPropertyValue(element, \"paddingRight\")) || 0);\n                            revertDisplay();\n\n                            return contentBoxWidth;\n                        }\n                    }\n\n                    var computedStyle;\n\n                    /* For elements that Velocity hasn't been called on directly (e.g. when Velocity queries the DOM on behalf\n                       of a parent of an element its animating), perform a direct getComputedStyle lookup since the object isn't cached. */\n                    if (Data(element) === undefined) {\n                        computedStyle = window.getComputedStyle(element, null); /* GET */\n                    /* If the computedStyle object has yet to be cached, do so now. */\n                    } else if (!Data(element).computedStyle) {\n                        computedStyle = Data(element).computedStyle = window.getComputedStyle(element, null); /* GET */\n                    /* If computedStyle is cached, use it. */\n                    } else {\n                        computedStyle = Data(element).computedStyle;\n                    }\n\n                    /* IE and Firefox do not return a value for the generic borderColor -- they only return individual values for each border side's color.\n                       Also, in all browsers, when border colors aren't all the same, a compound value is returned that Velocity isn't setup to parse.\n                       So, as a polyfill for querying individual border side colors, we just return the top border's color and animate all borders from that value. */\n                    if (property === \"borderColor\") {\n                        property = \"borderTopColor\";\n                    }\n\n                    /* IE9 has a bug in which the \"filter\" property must be accessed from computedStyle using the getPropertyValue method\n                       instead of a direct property lookup. The getPropertyValue method is slower than a direct lookup, which is why we avoid it by default. */\n                    if (IE === 9 && property === \"filter\") {\n                        computedValue = computedStyle.getPropertyValue(property); /* GET */\n                    } else {\n                        computedValue = computedStyle[property];\n                    }\n\n                    /* Fall back to the property's style value (if defined) when computedValue returns nothing,\n                       which can happen when the element hasn't been painted. */\n                    if (computedValue === \"\" || computedValue === null) {\n                        computedValue = element.style[property];\n                    }\n\n                    revertDisplay();\n                }\n\n                /* For top, right, bottom, and left (TRBL) values that are set to \"auto\" on elements of \"fixed\" or \"absolute\" position,\n                   defer to jQuery for converting \"auto\" to a numeric value. (For elements with a \"static\" or \"relative\" position, \"auto\" has the same\n                   effect as being set to 0, so no conversion is necessary.) */\n                /* An example of why numeric conversion is necessary: When an element with \"position:absolute\" has an untouched \"left\"\n                   property, which reverts to \"auto\", left's value is 0 relative to its parent element, but is often non-zero relative\n                   to its *containing* (not parent) element, which is the nearest \"position:relative\" ancestor or the viewport (and always the viewport in the case of \"position:fixed\"). */\n                if (computedValue === \"auto\" && /^(top|right|bottom|left)$/i.test(property)) {\n                    var position = computePropertyValue(element, \"position\"); /* GET */\n\n                    /* For absolute positioning, jQuery's $.position() only returns values for top and left;\n                       right and bottom will have their \"auto\" value reverted to 0. */\n                    /* Note: A jQuery object must be created here since jQuery doesn't have a low-level alias for $.position().\n                       Not a big deal since we're currently in a GET batch anyway. */\n                    if (position === \"fixed\" || (position === \"absolute\" && /top|left/i.test(property))) {\n                        /* Note: jQuery strips the pixel unit from its returned values; we re-add it here to conform with computePropertyValue's behavior. */\n                        computedValue = $(element).position()[property] + \"px\"; /* GET */\n                    }\n                }\n\n                return computedValue;\n            }\n\n            var propertyValue;\n\n            /* If this is a hooked property (e.g. \"clipLeft\" instead of the root property of \"clip\"),\n               extract the hook's value from a normalized rootPropertyValue using CSS.Hooks.extractValue(). */\n            if (CSS.Hooks.registered[property]) {\n                var hook = property,\n                    hookRoot = CSS.Hooks.getRoot(hook);\n\n                /* If a cached rootPropertyValue wasn't passed in (which Velocity always attempts to do in order to avoid requerying the DOM),\n                   query the DOM for the root property's value. */\n                if (rootPropertyValue === undefined) {\n                    /* Since the browser is now being directly queried, use the official post-prefixing property name for this lookup. */\n                    rootPropertyValue = CSS.getPropertyValue(element, CSS.Names.prefixCheck(hookRoot)[0]); /* GET */\n                }\n\n                /* If this root has a normalization registered, peform the associated normalization extraction. */\n                if (CSS.Normalizations.registered[hookRoot]) {\n                    rootPropertyValue = CSS.Normalizations.registered[hookRoot](\"extract\", element, rootPropertyValue);\n                }\n\n                /* Extract the hook's value. */\n                propertyValue = CSS.Hooks.extractValue(hook, rootPropertyValue);\n\n            /* If this is a normalized property (e.g. \"opacity\" becomes \"filter\" in <=IE8) or \"translateX\" becomes \"transform\"),\n               normalize the property's name and value, and handle the special case of transforms. */\n            /* Note: Normalizing a property is mutually exclusive from hooking a property since hook-extracted values are strictly\n               numerical and therefore do not require normalization extraction. */\n            } else if (CSS.Normalizations.registered[property]) {\n                var normalizedPropertyName,\n                    normalizedPropertyValue;\n\n                normalizedPropertyName = CSS.Normalizations.registered[property](\"name\", element);\n\n                /* Transform values are calculated via normalization extraction (see below), which checks against the element's transformCache.\n                   At no point do transform GETs ever actually query the DOM; initial stylesheet values are never processed.\n                   This is because parsing 3D transform matrices is not always accurate and would bloat our codebase;\n                   thus, normalization extraction defaults initial transform values to their zero-values (e.g. 1 for scaleX and 0 for translateX). */\n                if (normalizedPropertyName !== \"transform\") {\n                    normalizedPropertyValue = computePropertyValue(element, CSS.Names.prefixCheck(normalizedPropertyName)[0]); /* GET */\n\n                    /* If the value is a CSS null-value and this property has a hook template, use that zero-value template so that hooks can be extracted from it. */\n                    if (CSS.Values.isCSSNullValue(normalizedPropertyValue) && CSS.Hooks.templates[property]) {\n                        normalizedPropertyValue = CSS.Hooks.templates[property][1];\n                    }\n                }\n\n                propertyValue = CSS.Normalizations.registered[property](\"extract\", element, normalizedPropertyValue);\n            }\n\n            /* If a (numeric) value wasn't produced via hook extraction or normalization, query the DOM. */\n            if (!/^[\\d-]/.test(propertyValue)) {\n                /* For SVG elements, dimensional properties (which SVGAttribute() detects) are tweened via\n                   their HTML attribute values instead of their CSS style values. */\n                if (Data(element) && Data(element).isSVG && CSS.Names.SVGAttribute(property)) {\n                    /* Since the height/width attribute values must be set manually, they don't reflect computed values.\n                       Thus, we use use getBBox() to ensure we always get values for elements with undefined height/width attributes. */\n                    if (/^(height|width)$/i.test(property)) {\n                        /* Firefox throws an error if .getBBox() is called on an SVG that isn't attached to the DOM. */\n                        try {\n                            propertyValue = element.getBBox()[property];\n                        } catch (error) {\n                            propertyValue = 0;\n                        }\n                    /* Otherwise, access the attribute value directly. */\n                    } else {\n                        propertyValue = element.getAttribute(property);\n                    }\n                } else {\n                    propertyValue = computePropertyValue(element, CSS.Names.prefixCheck(property)[0]); /* GET */\n                }\n            }\n\n            /* Since property lookups are for animation purposes (which entails computing the numeric delta between start and end values),\n               convert CSS null-values to an integer of value 0. */\n            if (CSS.Values.isCSSNullValue(propertyValue)) {\n                propertyValue = 0;\n            }\n\n            if (Velocity.debug >= 2) console.log(\"Get \" + property + \": \" + propertyValue);\n\n            return propertyValue;\n        },\n\n        /* The singular setPropertyValue, which routes the logic for all normalizations, hooks, and standard CSS properties. */\n        setPropertyValue: function(element, property, propertyValue, rootPropertyValue, scrollData) {\n            var propertyName = property;\n\n            /* In order to be subjected to call options and element queueing, scroll animation is routed through Velocity as if it were a standard CSS property. */\n            if (property === \"scroll\") {\n                /* If a container option is present, scroll the container instead of the browser window. */\n                if (scrollData.container) {\n                    scrollData.container[\"scroll\" + scrollData.direction] = propertyValue;\n                /* Otherwise, Velocity defaults to scrolling the browser window. */\n                } else {\n                    if (scrollData.direction === \"Left\") {\n                        window.scrollTo(propertyValue, scrollData.alternateValue);\n                    } else {\n                        window.scrollTo(scrollData.alternateValue, propertyValue);\n                    }\n                }\n            } else {\n                /* Transforms (translateX, rotateZ, etc.) are applied to a per-element transformCache object, which is manually flushed via flushTransformCache().\n                   Thus, for now, we merely cache transforms being SET. */\n                if (CSS.Normalizations.registered[property] && CSS.Normalizations.registered[property](\"name\", element) === \"transform\") {\n                    /* Perform a normalization injection. */\n                    /* Note: The normalization logic handles the transformCache updating. */\n                    CSS.Normalizations.registered[property](\"inject\", element, propertyValue);\n\n                    propertyName = \"transform\";\n                    propertyValue = Data(element).transformCache[property];\n                } else {\n                    /* Inject hooks. */\n                    if (CSS.Hooks.registered[property]) {\n                        var hookName = property,\n                            hookRoot = CSS.Hooks.getRoot(property);\n\n                        /* If a cached rootPropertyValue was not provided, query the DOM for the hookRoot's current value. */\n                        rootPropertyValue = rootPropertyValue || CSS.getPropertyValue(element, hookRoot); /* GET */\n\n                        propertyValue = CSS.Hooks.injectValue(hookName, propertyValue, rootPropertyValue);\n                        property = hookRoot;\n                    }\n\n                    /* Normalize names and values. */\n                    if (CSS.Normalizations.registered[property]) {\n                        propertyValue = CSS.Normalizations.registered[property](\"inject\", element, propertyValue);\n                        property = CSS.Normalizations.registered[property](\"name\", element);\n                    }\n\n                    /* Assign the appropriate vendor prefix before performing an official style update. */\n                    propertyName = CSS.Names.prefixCheck(property)[0];\n\n                    /* A try/catch is used for IE<=8, which throws an error when \"invalid\" CSS values are set, e.g. a negative width.\n                       Try/catch is avoided for other browsers since it incurs a performance overhead. */\n                    if (IE <= 8) {\n                        try {\n                            element.style[propertyName] = propertyValue;\n                        } catch (error) { if (Velocity.debug) console.log(\"Browser does not support [\" + propertyValue + \"] for [\" + propertyName + \"]\"); }\n                    /* SVG elements have their dimensional properties (width, height, x, y, cx, etc.) applied directly as attributes instead of as styles. */\n                    /* Note: IE8 does not support SVG elements, so it's okay that we skip it for SVG animation. */\n                    } else if (Data(element) && Data(element).isSVG && CSS.Names.SVGAttribute(property)) {\n                        /* Note: For SVG attributes, vendor-prefixed property names are never used. */\n                        /* Note: Not all CSS properties can be animated via attributes, but the browser won't throw an error for unsupported properties. */\n                        element.setAttribute(property, propertyValue);\n                    } else {\n                        element.style[propertyName] = propertyValue;\n                    }\n\n                    if (Velocity.debug >= 2) console.log(\"Set \" + property + \" (\" + propertyName + \"): \" + propertyValue);\n                }\n            }\n\n            /* Return the normalized property name and value in case the caller wants to know how these values were modified before being applied to the DOM. */\n            return [ propertyName, propertyValue ];\n        },\n\n        /* To increase performance by batching transform updates into a single SET, transforms are not directly applied to an element until flushTransformCache() is called. */\n        /* Note: Velocity applies transform properties in the same order that they are chronogically introduced to the element's CSS styles. */\n        flushTransformCache: function(element) {\n            var transformString = \"\";\n\n            /* Certain browsers require that SVG transforms be applied as an attribute. However, the SVG transform attribute takes a modified version of CSS's transform string\n               (units are dropped and, except for skewX/Y, subproperties are merged into their master property -- e.g. scaleX and scaleY are merged into scale(X Y). */\n            if ((IE || (Velocity.State.isAndroid && !Velocity.State.isChrome)) && Data(element).isSVG) {\n                /* Since transform values are stored in their parentheses-wrapped form, we use a helper function to strip out their numeric values.\n                   Further, SVG transform properties only take unitless (representing pixels) values, so it's okay that parseFloat() strips the unit suffixed to the float value. */\n                function getTransformFloat (transformProperty) {\n                    return parseFloat(CSS.getPropertyValue(element, transformProperty));\n                }\n\n                /* Create an object to organize all the transforms that we'll apply to the SVG element. To keep the logic simple,\n                   we process *all* transform properties -- even those that may not be explicitly applied (since they default to their zero-values anyway). */\n                var SVGTransforms = {\n                    translate: [ getTransformFloat(\"translateX\"), getTransformFloat(\"translateY\") ],\n                    skewX: [ getTransformFloat(\"skewX\") ], skewY: [ getTransformFloat(\"skewY\") ],\n                    /* If the scale property is set (non-1), use that value for the scaleX and scaleY values\n                       (this behavior mimics the result of animating all these properties at once on HTML elements). */\n                    scale: getTransformFloat(\"scale\") !== 1 ? [ getTransformFloat(\"scale\"), getTransformFloat(\"scale\") ] : [ getTransformFloat(\"scaleX\"), getTransformFloat(\"scaleY\") ],\n                    /* Note: SVG's rotate transform takes three values: rotation degrees followed by the X and Y values\n                       defining the rotation's origin point. We ignore the origin values (default them to 0). */\n                    rotate: [ getTransformFloat(\"rotateZ\"), 0, 0 ]\n                };\n\n                /* Iterate through the transform properties in the user-defined property map order.\n                   (This mimics the behavior of non-SVG transform animation.) */\n                $.each(Data(element).transformCache, function(transformName) {\n                    /* Except for with skewX/Y, revert the axis-specific transform subproperties to their axis-free master\n                       properties so that they match up with SVG's accepted transform properties. */\n                    if (/^translate/i.test(transformName)) {\n                        transformName = \"translate\";\n                    } else if (/^scale/i.test(transformName)) {\n                        transformName = \"scale\";\n                    } else if (/^rotate/i.test(transformName)) {\n                        transformName = \"rotate\";\n                    }\n\n                    /* Check that we haven't yet deleted the property from the SVGTransforms container. */\n                    if (SVGTransforms[transformName]) {\n                        /* Append the transform property in the SVG-supported transform format. As per the spec, surround the space-delimited values in parentheses. */\n                        transformString += transformName + \"(\" + SVGTransforms[transformName].join(\" \") + \")\" + \" \";\n\n                        /* After processing an SVG transform property, delete it from the SVGTransforms container so we don't\n                           re-insert the same master property if we encounter another one of its axis-specific properties. */\n                        delete SVGTransforms[transformName];\n                    }\n                });\n            } else {\n                var transformValue,\n                    perspective;\n\n                /* Transform properties are stored as members of the transformCache object. Concatenate all the members into a string. */\n                $.each(Data(element).transformCache, function(transformName) {\n                    transformValue = Data(element).transformCache[transformName];\n\n                    /* Transform's perspective subproperty must be set first in order to take effect. Store it temporarily. */\n                    if (transformName === \"transformPerspective\") {\n                        perspective = transformValue;\n                        return true;\n                    }\n\n                    /* IE9 only supports one rotation type, rotateZ, which it refers to as \"rotate\". */\n                    if (IE === 9 && transformName === \"rotateZ\") {\n                        transformName = \"rotate\";\n                    }\n\n                    transformString += transformName + transformValue + \" \";\n                });\n\n                /* If present, set the perspective subproperty first. */\n                if (perspective) {\n                    transformString = \"perspective\" + perspective + \" \" + transformString;\n                }\n            }\n\n            CSS.setPropertyValue(element, \"transform\", transformString);\n        }\n    };\n\n    /* Register hooks and normalizations. */\n    CSS.Hooks.register();\n    CSS.Normalizations.register();\n\n    /* Allow hook setting in the same fashion as jQuery's $.css(). */\n    Velocity.hook = function (elements, arg2, arg3) {\n        var value = undefined;\n\n        elements = sanitizeElements(elements);\n\n        $.each(elements, function(i, element) {\n            /* Initialize Velocity's per-element data cache if this element hasn't previously been animated. */\n            if (Data(element) === undefined) {\n                Velocity.init(element);\n            }\n\n            /* Get property value. If an element set was passed in, only return the value for the first element. */\n            if (arg3 === undefined) {\n                if (value === undefined) {\n                    value = Velocity.CSS.getPropertyValue(element, arg2);\n                }\n            /* Set property value. */\n            } else {\n                /* sPV returns an array of the normalized propertyName/propertyValue pair used to update the DOM. */\n                var adjustedSet = Velocity.CSS.setPropertyValue(element, arg2, arg3);\n\n                /* Transform properties don't automatically set. They have to be flushed to the DOM. */\n                if (adjustedSet[0] === \"transform\") {\n                    Velocity.CSS.flushTransformCache(element);\n                }\n\n                value = adjustedSet;\n            }\n        });\n\n        return value;\n    };\n\n    /*****************\n        Animation\n    *****************/\n\n    var animate = function() {\n\n        /******************\n            Call Chain\n        ******************/\n\n        /* Logic for determining what to return to the call stack when exiting out of Velocity. */\n        function getChain () {\n            /* If we are using the utility function, attempt to return this call's promise. If no promise library was detected,\n               default to null instead of returning the targeted elements so that utility function's return value is standardized. */\n            if (isUtility) {\n                return promiseData.promise || null;\n            /* Otherwise, if we're using $.fn, return the jQuery-/Zepto-wrapped element set. */\n            } else {\n                return elementsWrapped;\n            }\n        }\n\n        /*************************\n           Arguments Assignment\n        *************************/\n\n        /* To allow for expressive CoffeeScript code, Velocity supports an alternative syntax in which \"elements\" (or \"e\"), \"properties\" (or \"p\"), and \"options\" (or \"o\")\n           objects are defined on a container object that's passed in as Velocity's sole argument. */\n        /* Note: Some browsers automatically populate arguments with a \"properties\" object. We detect it by checking for its default \"names\" property. */\n        var syntacticSugar = (arguments[0] && (arguments[0].p || (($.isPlainObject(arguments[0].properties) && !arguments[0].properties.names) || Type.isString(arguments[0].properties)))),\n            /* Whether Velocity was called via the utility function (as opposed to on a jQuery/Zepto object). */\n            isUtility,\n            /* When Velocity is called via the utility function ($.Velocity()/Velocity()), elements are explicitly\n               passed in as the first parameter. Thus, argument positioning varies. We normalize them here. */\n            elementsWrapped,\n            argumentIndex;\n\n        var elements,\n            propertiesMap,\n            options;\n\n        /* Detect jQuery/Zepto elements being animated via the $.fn method. */\n        if (Type.isWrapped(this)) {\n            isUtility = false;\n\n            argumentIndex = 0;\n            elements = this;\n            elementsWrapped = this;\n        /* Otherwise, raw elements are being animated via the utility function. */\n        } else {\n            isUtility = true;\n\n            argumentIndex = 1;\n            elements = syntacticSugar ? (arguments[0].elements || arguments[0].e) : arguments[0];\n        }\n\n        elements = sanitizeElements(elements);\n\n        if (!elements) {\n            return;\n        }\n\n        if (syntacticSugar) {\n            propertiesMap = arguments[0].properties || arguments[0].p;\n            options = arguments[0].options || arguments[0].o;\n        } else {\n            propertiesMap = arguments[argumentIndex];\n            options = arguments[argumentIndex + 1];\n        }\n\n        /* The length of the element set (in the form of a nodeList or an array of elements) is defaulted to 1 in case a\n           single raw DOM element is passed in (which doesn't contain a length property). */\n        var elementsLength = elements.length,\n            elementsIndex = 0;\n\n        /***************************\n            Argument Overloading\n        ***************************/\n\n        /* Support is included for jQuery's argument overloading: $.animate(propertyMap [, duration] [, easing] [, complete]).\n           Overloading is detected by checking for the absence of an object being passed into options. */\n        /* Note: The stop and finish actions do not accept animation options, and are therefore excluded from this check. */\n        if (!/^(stop|finish)$/i.test(propertiesMap) && !$.isPlainObject(options)) {\n            /* The utility function shifts all arguments one position to the right, so we adjust for that offset. */\n            var startingArgumentPosition = argumentIndex + 1;\n\n            options = {};\n\n            /* Iterate through all options arguments */\n            for (var i = startingArgumentPosition; i < arguments.length; i++) {\n                /* Treat a number as a duration. Parse it out. */\n                /* Note: The following RegEx will return true if passed an array with a number as its first item.\n                   Thus, arrays are skipped from this check. */\n                if (!Type.isArray(arguments[i]) && (/^(fast|normal|slow)$/i.test(arguments[i]) || /^\\d/.test(arguments[i]))) {\n                    options.duration = arguments[i];\n                /* Treat strings and arrays as easings. */\n                } else if (Type.isString(arguments[i]) || Type.isArray(arguments[i])) {\n                    options.easing = arguments[i];\n                /* Treat a function as a complete callback. */\n                } else if (Type.isFunction(arguments[i])) {\n                    options.complete = arguments[i];\n                }\n            }\n        }\n\n        /***************\n            Promises\n        ***************/\n\n        var promiseData = {\n                promise: null,\n                resolver: null,\n                rejecter: null\n            };\n\n        /* If this call was made via the utility function (which is the default method of invocation when jQuery/Zepto are not being used), and if\n           promise support was detected, create a promise object for this call and store references to its resolver and rejecter methods. The resolve\n           method is used when a call completes naturally or is prematurely stopped by the user. In both cases, completeCall() handles the associated\n           call cleanup and promise resolving logic. The reject method is used when an invalid set of arguments is passed into a Velocity call. */\n        /* Note: Velocity employs a call-based queueing architecture, which means that stopping an animating element actually stops the full call that\n           triggered it -- not that one element exclusively. Similarly, there is one promise per call, and all elements targeted by a Velocity call are\n           grouped together for the purposes of resolving and rejecting a promise. */\n        if (isUtility && Velocity.Promise) {\n            promiseData.promise = new Velocity.Promise(function (resolve, reject) {\n                promiseData.resolver = resolve;\n                promiseData.rejecter = reject;\n            });\n        }\n\n        /*********************\n           Action Detection\n        *********************/\n\n        /* Velocity's behavior is categorized into \"actions\": Elements can either be specially scrolled into view,\n           or they can be started, stopped, or reversed. If a literal or referenced properties map is passed in as Velocity's\n           first argument, the associated action is \"start\". Alternatively, \"scroll\", \"reverse\", or \"stop\" can be passed in instead of a properties map. */\n        var action;\n\n        switch (propertiesMap) {\n            case \"scroll\":\n                action = \"scroll\";\n                break;\n\n            case \"reverse\":\n                action = \"reverse\";\n                break;\n\n            case \"finish\":\n            case \"stop\":\n                /*******************\n                    Action: Stop\n                *******************/\n\n                /* Clear the currently-active delay on each targeted element. */\n                $.each(elements, function(i, element) {\n                    if (Data(element) && Data(element).delayTimer) {\n                        /* Stop the timer from triggering its cached next() function. */\n                        clearTimeout(Data(element).delayTimer.setTimeout);\n\n                        /* Manually call the next() function so that the subsequent queue items can progress. */\n                        if (Data(element).delayTimer.next) {\n                            Data(element).delayTimer.next();\n                        }\n\n                        delete Data(element).delayTimer;\n                    }\n                });\n\n                var callsToStop = [];\n\n                /* When the stop action is triggered, the elements' currently active call is immediately stopped. The active call might have\n                   been applied to multiple elements, in which case all of the call's elements will be stopped. When an element\n                   is stopped, the next item in its animation queue is immediately triggered. */\n                /* An additional argument may be passed in to clear an element's remaining queued calls. Either true (which defaults to the \"fx\" queue)\n                   or a custom queue string can be passed in. */\n                /* Note: The stop command runs prior to Velocity's Queueing phase since its behavior is intended to take effect *immediately*,\n                   regardless of the element's current queue state. */\n\n                /* Iterate through every active call. */\n                $.each(Velocity.State.calls, function(i, activeCall) {\n                    /* Inactive calls are set to false by the logic inside completeCall(). Skip them. */\n                    if (activeCall) {\n                        /* Iterate through the active call's targeted elements. */\n                        $.each(activeCall[1], function(k, activeElement) {\n                            /* If true was passed in as a secondary argument, clear absolutely all calls on this element. Otherwise, only\n                               clear calls associated with the relevant queue. */\n                            /* Call stopping logic works as follows:\n                               - options === true --> stop current default queue calls (and queue:false calls), including remaining queued ones.\n                               - options === undefined --> stop current queue:\"\" call and all queue:false calls.\n                               - options === false --> stop only queue:false calls.\n                               - options === \"custom\" --> stop current queue:\"custom\" call, including remaining queued ones (there is no functionality to only clear the currently-running queue:\"custom\" call). */\n                            var queueName = (options === undefined) ? \"\" : options;\n\n                            if (queueName !== true && (activeCall[2].queue !== queueName) && !(options === undefined && activeCall[2].queue === false)) {\n                                return true;\n                            }\n\n                            /* Iterate through the calls targeted by the stop command. */\n                            $.each(elements, function(l, element) {                                \n                                /* Check that this call was applied to the target element. */\n                                if (element === activeElement) {\n                                    /* Optionally clear the remaining queued calls. */\n                                    if (options === true || Type.isString(options)) {\n                                        /* Iterate through the items in the element's queue. */\n                                        $.each($.queue(element, Type.isString(options) ? options : \"\"), function(_, item) {\n                                            /* The queue array can contain an \"inprogress\" string, which we skip. */\n                                            if (Type.isFunction(item)) {\n                                                /* Pass the item's callback a flag indicating that we want to abort from the queue call.\n                                                   (Specifically, the queue will resolve the call's associated promise then abort.)  */\n                                                item(null, true);\n                                            }\n                                        });\n\n                                        /* Clearing the $.queue() array is achieved by resetting it to []. */\n                                        $.queue(element, Type.isString(options) ? options : \"\", []);\n                                    }\n\n                                    if (propertiesMap === \"stop\") {\n                                        /* Since \"reverse\" uses cached start values (the previous call's endValues), these values must be\n                                           changed to reflect the final value that the elements were actually tweened to. */\n                                        /* Note: If only queue:false animations are currently running on an element, it won't have a tweensContainer\n                                           object. Also, queue:false animations can't be reversed. */\n                                        if (Data(element) && Data(element).tweensContainer && queueName !== false) {\n                                            $.each(Data(element).tweensContainer, function(m, activeTween) {\n                                                activeTween.endValue = activeTween.currentValue;\n                                            });\n                                        }\n\n                                        callsToStop.push(i);\n                                    } else if (propertiesMap === \"finish\") {\n                                        /* To get active tweens to finish immediately, we forcefully shorten their durations to 1ms so that\n                                        they finish upon the next rAf tick then proceed with normal call completion logic. */\n                                        activeCall[2].duration = 1;\n                                    }\n                                }\n                            });\n                        });\n                    }\n                });\n\n                /* Prematurely call completeCall() on each matched active call. Pass an additional flag for \"stop\" to indicate\n                   that the complete callback and display:none setting should be skipped since we're completing prematurely. */\n                if (propertiesMap === \"stop\") {\n                    $.each(callsToStop, function(i, j) {\n                        completeCall(j, true);\n                    });\n\n                    if (promiseData.promise) {\n                        /* Immediately resolve the promise associated with this stop call since stop runs synchronously. */\n                        promiseData.resolver(elements);\n                    }\n                }\n\n                /* Since we're stopping, and not proceeding with queueing, exit out of Velocity. */\n                return getChain();\n\n            default:\n                /* Treat a non-empty plain object as a literal properties map. */\n                if ($.isPlainObject(propertiesMap) && !Type.isEmptyObject(propertiesMap)) {\n                    action = \"start\";\n\n                /****************\n                    Redirects\n                ****************/\n\n                /* Check if a string matches a registered redirect (see Redirects above). */\n                } else if (Type.isString(propertiesMap) && Velocity.Redirects[propertiesMap]) {\n                    var opts = $.extend({}, options),\n                        durationOriginal = opts.duration,\n                        delayOriginal = opts.delay || 0;\n\n                    /* If the backwards option was passed in, reverse the element set so that elements animate from the last to the first. */\n                    if (opts.backwards === true) {\n                        elements = $.extend(true, [], elements).reverse();\n                    }\n\n                    /* Individually trigger the redirect for each element in the set to prevent users from having to handle iteration logic in their redirect. */\n                    $.each(elements, function(elementIndex, element) {\n                        /* If the stagger option was passed in, successively delay each element by the stagger value (in ms). Retain the original delay value. */\n                        if (parseFloat(opts.stagger)) {\n                            opts.delay = delayOriginal + (parseFloat(opts.stagger) * elementIndex);\n                        } else if (Type.isFunction(opts.stagger)) {\n                            opts.delay = delayOriginal + opts.stagger.call(element, elementIndex, elementsLength);\n                        }\n\n                        /* If the drag option was passed in, successively increase/decrease (depending on the presense of opts.backwards)\n                           the duration of each element's animation, using floors to prevent producing very short durations. */\n                        if (opts.drag) {\n                            /* Default the duration of UI pack effects (callouts and transitions) to 1000ms instead of the usual default duration of 400ms. */\n                            opts.duration = parseFloat(durationOriginal) || (/^(callout|transition)/.test(propertiesMap) ? 1000 : DURATION_DEFAULT);\n\n                            /* For each element, take the greater duration of: A) animation completion percentage relative to the original duration,\n                               B) 75% of the original duration, or C) a 200ms fallback (in case duration is already set to a low value).\n                               The end result is a baseline of 75% of the redirect's duration that increases/decreases as the end of the element set is approached. */\n                            opts.duration = Math.max(opts.duration * (opts.backwards ? 1 - elementIndex/elementsLength : (elementIndex + 1) / elementsLength), opts.duration * 0.75, 200);\n                        }\n\n                        /* Pass in the call's opts object so that the redirect can optionally extend it. It defaults to an empty object instead of null to\n                           reduce the opts checking logic required inside the redirect. */\n                        Velocity.Redirects[propertiesMap].call(element, element, opts || {}, elementIndex, elementsLength, elements, promiseData.promise ? promiseData : undefined);\n                    });\n\n                    /* Since the animation logic resides within the redirect's own code, abort the remainder of this call.\n                       (The performance overhead up to this point is virtually non-existant.) */\n                    /* Note: The jQuery call chain is kept intact by returning the complete element set. */\n                    return getChain();\n                } else {\n                    var abortError = \"Velocity: First argument (\" + propertiesMap + \") was not a property map, a known action, or a registered redirect. Aborting.\";\n\n                    if (promiseData.promise) {\n                        promiseData.rejecter(new Error(abortError));\n                    } else {\n                        console.log(abortError);\n                    }\n\n                    return getChain();\n                }\n        }\n\n        /**************************\n            Call-Wide Variables\n        **************************/\n\n        /* A container for CSS unit conversion ratios (e.g. %, rem, and em ==> px) that is used to cache ratios across all elements\n           being animated in a single Velocity call. Calculating unit ratios necessitates DOM querying and updating, and is therefore\n           avoided (via caching) wherever possible. This container is call-wide instead of page-wide to avoid the risk of using stale\n           conversion metrics across Velocity animations that are not immediately consecutively chained. */\n        var callUnitConversionData = {\n                lastParent: null,\n                lastPosition: null,\n                lastFontSize: null,\n                lastPercentToPxWidth: null,\n                lastPercentToPxHeight: null,\n                lastEmToPx: null,\n                remToPx: null,\n                vwToPx: null,\n                vhToPx: null\n            };\n\n        /* A container for all the ensuing tween data and metadata associated with this call. This container gets pushed to the page-wide\n           Velocity.State.calls array that is processed during animation ticking. */\n        var call = [];\n\n        /************************\n           Element Processing\n        ************************/\n\n        /* Element processing consists of three parts -- data processing that cannot go stale and data processing that *can* go stale (i.e. third-party style modifications):\n           1) Pre-Queueing: Element-wide variables, including the element's data storage, are instantiated. Call options are prepared. If triggered, the Stop action is executed.\n           2) Queueing: The logic that runs once this call has reached its point of execution in the element's $.queue() stack. Most logic is placed here to avoid risking it becoming stale.\n           3) Pushing: Consolidation of the tween data followed by its push onto the global in-progress calls container.\n        */\n\n        function processElement () {\n\n            /*************************\n               Part I: Pre-Queueing\n            *************************/\n\n            /***************************\n               Element-Wide Variables\n            ***************************/\n\n            var element = this,\n                /* The runtime opts object is the extension of the current call's options and Velocity's page-wide option defaults. */\n                opts = $.extend({}, Velocity.defaults, options),\n                /* A container for the processed data associated with each property in the propertyMap.\n                   (Each property in the map produces its own \"tween\".) */\n                tweensContainer = {},\n                elementUnitConversionData;\n\n            /******************\n               Element Init\n            ******************/\n\n            if (Data(element) === undefined) {\n                Velocity.init(element);\n            }\n\n            /******************\n               Option: Delay\n            ******************/\n\n            /* Since queue:false doesn't respect the item's existing queue, we avoid injecting its delay here (it's set later on). */\n            /* Note: Velocity rolls its own delay function since jQuery doesn't have a utility alias for $.fn.delay()\n               (and thus requires jQuery element creation, which we avoid since its overhead includes DOM querying). */\n            if (parseFloat(opts.delay) && opts.queue !== false) {\n                $.queue(element, opts.queue, function(next) {\n                    /* This is a flag used to indicate to the upcoming completeCall() function that this queue entry was initiated by Velocity. See completeCall() for further details. */\n                    Velocity.velocityQueueEntryFlag = true;\n\n                    /* The ensuing queue item (which is assigned to the \"next\" argument that $.queue() automatically passes in) will be triggered after a setTimeout delay.\n                       The setTimeout is stored so that it can be subjected to clearTimeout() if this animation is prematurely stopped via Velocity's \"stop\" command. */\n                    Data(element).delayTimer = {\n                        setTimeout: setTimeout(next, parseFloat(opts.delay)),\n                        next: next\n                    };\n                });\n            }\n\n            /*********************\n               Option: Duration\n            *********************/\n\n            /* Support for jQuery's named durations. */\n            switch (opts.duration.toString().toLowerCase()) {\n                case \"fast\":\n                    opts.duration = 200;\n                    break;\n\n                case \"normal\":\n                    opts.duration = DURATION_DEFAULT;\n                    break;\n\n                case \"slow\":\n                    opts.duration = 600;\n                    break;\n\n                default:\n                    /* Remove the potential \"ms\" suffix and default to 1 if the user is attempting to set a duration of 0 (in order to produce an immediate style change). */\n                    opts.duration = parseFloat(opts.duration) || 1;\n            }\n\n            /************************\n               Global Option: Mock\n            ************************/\n\n            if (Velocity.mock !== false) {\n                /* In mock mode, all animations are forced to 1ms so that they occur immediately upon the next rAF tick.\n                   Alternatively, a multiplier can be passed in to time remap all delays and durations. */\n                if (Velocity.mock === true) {\n                    opts.duration = opts.delay = 1;\n                } else {\n                    opts.duration *= parseFloat(Velocity.mock) || 1;\n                    opts.delay *= parseFloat(Velocity.mock) || 1;\n                }\n            }\n\n            /*******************\n               Option: Easing\n            *******************/\n\n            opts.easing = getEasing(opts.easing, opts.duration);\n\n            /**********************\n               Option: Callbacks\n            **********************/\n\n            /* Callbacks must functions. Otherwise, default to null. */\n            if (opts.begin && !Type.isFunction(opts.begin)) {\n                opts.begin = null;\n            }\n\n            if (opts.progress && !Type.isFunction(opts.progress)) {\n                opts.progress = null;\n            }\n\n            if (opts.complete && !Type.isFunction(opts.complete)) {\n                opts.complete = null;\n            }\n\n            /*********************************\n               Option: Display & Visibility\n            *********************************/\n\n            /* Refer to Velocity's documentation (VelocityJS.org/#displayAndVisibility) for a description of the display and visibility options' behavior. */\n            /* Note: We strictly check for undefined instead of falsiness because display accepts an empty string value. */\n            if (opts.display !== undefined && opts.display !== null) {\n                opts.display = opts.display.toString().toLowerCase();\n\n                /* Users can pass in a special \"auto\" value to instruct Velocity to set the element to its default display value. */\n                if (opts.display === \"auto\") {\n                    opts.display = Velocity.CSS.Values.getDisplayType(element);\n                }\n            }\n\n            if (opts.visibility !== undefined && opts.visibility !== null) {\n                opts.visibility = opts.visibility.toString().toLowerCase();\n            }\n\n            /**********************\n               Option: mobileHA\n            **********************/\n\n            /* When set to true, and if this is a mobile device, mobileHA automatically enables hardware acceleration (via a null transform hack)\n               on animating elements. HA is removed from the element at the completion of its animation. */\n            /* Note: Android Gingerbread doesn't support HA. If a null transform hack (mobileHA) is in fact set, it will prevent other tranform subproperties from taking effect. */\n            /* Note: You can read more about the use of mobileHA in Velocity's documentation: VelocityJS.org/#mobileHA. */\n            opts.mobileHA = (opts.mobileHA && Velocity.State.isMobile && !Velocity.State.isGingerbread);\n\n            /***********************\n               Part II: Queueing\n            ***********************/\n\n            /* When a set of elements is targeted by a Velocity call, the set is broken up and each element has the current Velocity call individually queued onto it.\n               In this way, each element's existing queue is respected; some elements may already be animating and accordingly should not have this current Velocity call triggered immediately. */\n            /* In each queue, tween data is processed for each animating property then pushed onto the call-wide calls array. When the last element in the set has had its tweens processed,\n               the call array is pushed to Velocity.State.calls for live processing by the requestAnimationFrame tick. */\n            function buildQueue (next) {\n\n                /*******************\n                   Option: Begin\n                *******************/\n\n                /* The begin callback is fired once per call -- not once per elemenet -- and is passed the full raw DOM element set as both its context and its first argument. */\n                if (opts.begin && elementsIndex === 0) {\n                    /* We throw callbacks in a setTimeout so that thrown errors don't halt the execution of Velocity itself. */\n                    try {\n                        opts.begin.call(elements, elements);\n                    } catch (error) {\n                        setTimeout(function() { throw error; }, 1);\n                    }\n                }\n\n                /*****************************************\n                   Tween Data Construction (for Scroll)\n                *****************************************/\n\n                /* Note: In order to be subjected to chaining and animation options, scroll's tweening is routed through Velocity as if it were a standard CSS property animation. */\n                if (action === \"scroll\") {\n                    /* The scroll action uniquely takes an optional \"offset\" option -- specified in pixels -- that offsets the targeted scroll position. */\n                    var scrollDirection = (/^x$/i.test(opts.axis) ? \"Left\" : \"Top\"),\n                        scrollOffset = parseFloat(opts.offset) || 0,\n                        scrollPositionCurrent,\n                        scrollPositionCurrentAlternate,\n                        scrollPositionEnd;\n\n                    /* Scroll also uniquely takes an optional \"container\" option, which indicates the parent element that should be scrolled --\n                       as opposed to the browser window itself. This is useful for scrolling toward an element that's inside an overflowing parent element. */\n                    if (opts.container) {\n                        /* Ensure that either a jQuery object or a raw DOM element was passed in. */\n                        if (Type.isWrapped(opts.container) || Type.isNode(opts.container)) {\n                            /* Extract the raw DOM element from the jQuery wrapper. */\n                            opts.container = opts.container[0] || opts.container;\n                            /* Note: Unlike other properties in Velocity, the browser's scroll position is never cached since it so frequently changes\n                               (due to the user's natural interaction with the page). */\n                            scrollPositionCurrent = opts.container[\"scroll\" + scrollDirection]; /* GET */\n\n                            /* $.position() values are relative to the container's currently viewable area (without taking into account the container's true dimensions\n                               -- say, for example, if the container was not overflowing). Thus, the scroll end value is the sum of the child element's position *and*\n                               the scroll container's current scroll position. */\n                            scrollPositionEnd = (scrollPositionCurrent + $(element).position()[scrollDirection.toLowerCase()]) + scrollOffset; /* GET */\n                        /* If a value other than a jQuery object or a raw DOM element was passed in, default to null so that this option is ignored. */\n                        } else {\n                            opts.container = null;\n                        }\n                    } else {\n                        /* If the window itself is being scrolled -- not a containing element -- perform a live scroll position lookup using\n                           the appropriate cached property names (which differ based on browser type). */\n                        scrollPositionCurrent = Velocity.State.scrollAnchor[Velocity.State[\"scrollProperty\" + scrollDirection]]; /* GET */\n                        /* When scrolling the browser window, cache the alternate axis's current value since window.scrollTo() doesn't let us change only one value at a time. */\n                        scrollPositionCurrentAlternate = Velocity.State.scrollAnchor[Velocity.State[\"scrollProperty\" + (scrollDirection === \"Left\" ? \"Top\" : \"Left\")]]; /* GET */\n\n                        /* Unlike $.position(), $.offset() values are relative to the browser window's true dimensions -- not merely its currently viewable area --\n                           and therefore end values do not need to be compounded onto current values. */\n                        scrollPositionEnd = $(element).offset()[scrollDirection.toLowerCase()] + scrollOffset; /* GET */\n                    }\n\n                    /* Since there's only one format that scroll's associated tweensContainer can take, we create it manually. */\n                    tweensContainer = {\n                        scroll: {\n                            rootPropertyValue: false,\n                            startValue: scrollPositionCurrent,\n                            currentValue: scrollPositionCurrent,\n                            endValue: scrollPositionEnd,\n                            unitType: \"\",\n                            easing: opts.easing,\n                            scrollData: {\n                                container: opts.container,\n                                direction: scrollDirection,\n                                alternateValue: scrollPositionCurrentAlternate\n                            }\n                        },\n                        element: element\n                    };\n\n                    if (Velocity.debug) console.log(\"tweensContainer (scroll): \", tweensContainer.scroll, element);\n\n                /******************************************\n                   Tween Data Construction (for Reverse)\n                ******************************************/\n\n                /* Reverse acts like a \"start\" action in that a property map is animated toward. The only difference is\n                   that the property map used for reverse is the inverse of the map used in the previous call. Thus, we manipulate\n                   the previous call to construct our new map: use the previous map's end values as our new map's start values. Copy over all other data. */\n                /* Note: Reverse can be directly called via the \"reverse\" parameter, or it can be indirectly triggered via the loop option. (Loops are composed of multiple reverses.) */\n                /* Note: Reverse calls do not need to be consecutively chained onto a currently-animating element in order to operate on cached values;\n                   there is no harm to reverse being called on a potentially stale data cache since reverse's behavior is simply defined\n                   as reverting to the element's values as they were prior to the previous *Velocity* call. */\n                } else if (action === \"reverse\") {\n                    /* Abort if there is no prior animation data to reverse to. */\n                    if (!Data(element).tweensContainer) {\n                        /* Dequeue the element so that this queue entry releases itself immediately, allowing subsequent queue entries to run. */\n                        $.dequeue(element, opts.queue);\n\n                        return;\n                    } else {\n                        /*********************\n                           Options Parsing\n                        *********************/\n\n                        /* If the element was hidden via the display option in the previous call,\n                           revert display to \"auto\" prior to reversal so that the element is visible again. */\n                        if (Data(element).opts.display === \"none\") {\n                            Data(element).opts.display = \"auto\";\n                        }\n\n                        if (Data(element).opts.visibility === \"hidden\") {\n                            Data(element).opts.visibility = \"visible\";\n                        }\n\n                        /* If the loop option was set in the previous call, disable it so that \"reverse\" calls aren't recursively generated.\n                           Further, remove the previous call's callback options; typically, users do not want these to be refired. */\n                        Data(element).opts.loop = false;\n                        Data(element).opts.begin = null;\n                        Data(element).opts.complete = null;\n\n                        /* Since we're extending an opts object that has already been extended with the defaults options object,\n                           we remove non-explicitly-defined properties that are auto-assigned values. */\n                        if (!options.easing) {\n                            delete opts.easing;\n                        }\n\n                        if (!options.duration) {\n                            delete opts.duration;\n                        }\n\n                        /* The opts object used for reversal is an extension of the options object optionally passed into this\n                           reverse call plus the options used in the previous Velocity call. */\n                        opts = $.extend({}, Data(element).opts, opts);\n\n                        /*************************************\n                           Tweens Container Reconstruction\n                        *************************************/\n\n                        /* Create a deepy copy (indicated via the true flag) of the previous call's tweensContainer. */\n                        var lastTweensContainer = $.extend(true, {}, Data(element).tweensContainer);\n\n                        /* Manipulate the previous tweensContainer by replacing its end values and currentValues with its start values. */\n                        for (var lastTween in lastTweensContainer) {\n                            /* In addition to tween data, tweensContainers contain an element property that we ignore here. */\n                            if (lastTween !== \"element\") {\n                                var lastStartValue = lastTweensContainer[lastTween].startValue;\n\n                                lastTweensContainer[lastTween].startValue = lastTweensContainer[lastTween].currentValue = lastTweensContainer[lastTween].endValue;\n                                lastTweensContainer[lastTween].endValue = lastStartValue;\n\n                                /* Easing is the only option that embeds into the individual tween data (since it can be defined on a per-property basis).\n                                   Accordingly, every property's easing value must be updated when an options object is passed in with a reverse call.\n                                   The side effect of this extensibility is that all per-property easing values are forcefully reset to the new value. */\n                                if (!Type.isEmptyObject(options)) {\n                                    lastTweensContainer[lastTween].easing = opts.easing;\n                                }\n\n                                if (Velocity.debug) console.log(\"reverse tweensContainer (\" + lastTween + \"): \" + JSON.stringify(lastTweensContainer[lastTween]), element);\n                            }\n                        }\n\n                        tweensContainer = lastTweensContainer;\n                    }\n\n                /*****************************************\n                   Tween Data Construction (for Start)\n                *****************************************/\n\n                } else if (action === \"start\") {\n\n                    /*************************\n                        Value Transferring\n                    *************************/\n\n                    /* If this queue entry follows a previous Velocity-initiated queue entry *and* if this entry was created\n                       while the element was in the process of being animated by Velocity, then this current call is safe to use\n                       the end values from the prior call as its start values. Velocity attempts to perform this value transfer\n                       process whenever possible in order to avoid requerying the DOM. */\n                    /* If values aren't transferred from a prior call and start values were not forcefed by the user (more on this below),\n                       then the DOM is queried for the element's current values as a last resort. */\n                    /* Note: Conversely, animation reversal (and looping) *always* perform inter-call value transfers; they never requery the DOM. */\n                    var lastTweensContainer;\n\n                    /* The per-element isAnimating flag is used to indicate whether it's safe (i.e. the data isn't stale)\n                       to transfer over end values to use as start values. If it's set to true and there is a previous\n                       Velocity call to pull values from, do so. */\n                    if (Data(element).tweensContainer && Data(element).isAnimating === true) {\n                        lastTweensContainer = Data(element).tweensContainer;\n                    }\n\n                    /***************************\n                       Tween Data Calculation\n                    ***************************/\n\n                    /* This function parses property data and defaults endValue, easing, and startValue as appropriate. */\n                    /* Property map values can either take the form of 1) a single value representing the end value,\n                       or 2) an array in the form of [ endValue, [, easing] [, startValue] ].\n                       The optional third parameter is a forcefed startValue to be used instead of querying the DOM for\n                       the element's current value. Read Velocity's docmentation to learn more about forcefeeding: VelocityJS.org/#forcefeeding */\n                    function parsePropertyValue (valueData, skipResolvingEasing) {\n                        var endValue = undefined,\n                            easing = undefined,\n                            startValue = undefined;\n\n                        /* Handle the array format, which can be structured as one of three potential overloads:\n                           A) [ endValue, easing, startValue ], B) [ endValue, easing ], or C) [ endValue, startValue ] */\n                        if (Type.isArray(valueData)) {\n                            /* endValue is always the first item in the array. Don't bother validating endValue's value now\n                               since the ensuing property cycling logic does that. */\n                            endValue = valueData[0];\n\n                            /* Two-item array format: If the second item is a number, function, or hex string, treat it as a\n                               start value since easings can only be non-hex strings or arrays. */\n                            if ((!Type.isArray(valueData[1]) && /^[\\d-]/.test(valueData[1])) || Type.isFunction(valueData[1]) || CSS.RegEx.isHex.test(valueData[1])) {\n                                startValue = valueData[1];\n                            /* Two or three-item array: If the second item is a non-hex string or an array, treat it as an easing. */\n                            } else if ((Type.isString(valueData[1]) && !CSS.RegEx.isHex.test(valueData[1])) || Type.isArray(valueData[1])) {\n                                easing = skipResolvingEasing ? valueData[1] : getEasing(valueData[1], opts.duration);\n\n                                /* Don't bother validating startValue's value now since the ensuing property cycling logic inherently does that. */\n                                if (valueData[2] !== undefined) {\n                                    startValue = valueData[2];\n                                }\n                            }\n                        /* Handle the single-value format. */\n                        } else {\n                            endValue = valueData;\n                        }\n\n                        /* Default to the call's easing if a per-property easing type was not defined. */\n                        if (!skipResolvingEasing) {\n                            easing = easing || opts.easing;\n                        }\n\n                        /* If functions were passed in as values, pass the function the current element as its context,\n                           plus the element's index and the element set's size as arguments. Then, assign the returned value. */\n                        if (Type.isFunction(endValue)) {\n                            endValue = endValue.call(element, elementsIndex, elementsLength);\n                        }\n\n                        if (Type.isFunction(startValue)) {\n                            startValue = startValue.call(element, elementsIndex, elementsLength);\n                        }\n\n                        /* Allow startValue to be left as undefined to indicate to the ensuing code that its value was not forcefed. */\n                        return [ endValue || 0, easing, startValue ];\n                    }\n\n                    /* Cycle through each property in the map, looking for shorthand color properties (e.g. \"color\" as opposed to \"colorRed\"). Inject the corresponding\n                       colorRed, colorGreen, and colorBlue RGB component tweens into the propertiesMap (which Velocity understands) and remove the shorthand property. */\n                    $.each(propertiesMap, function(property, value) {\n                        /* Find shorthand color properties that have been passed a hex string. */\n                        if (RegExp(\"^\" + CSS.Lists.colors.join(\"$|^\") + \"$\").test(property)) {\n                            /* Parse the value data for each shorthand. */\n                            var valueData = parsePropertyValue(value, true),\n                                endValue = valueData[0],\n                                easing = valueData[1],\n                                startValue = valueData[2];\n\n                            if (CSS.RegEx.isHex.test(endValue)) {\n                                /* Convert the hex strings into their RGB component arrays. */\n                                var colorComponents = [ \"Red\", \"Green\", \"Blue\" ],\n                                    endValueRGB = CSS.Values.hexToRgb(endValue),\n                                    startValueRGB = startValue ? CSS.Values.hexToRgb(startValue) : undefined;\n\n                                /* Inject the RGB component tweens into propertiesMap. */\n                                for (var i = 0; i < colorComponents.length; i++) {\n                                    var dataArray = [ endValueRGB[i] ];\n\n                                    if (easing) {\n                                        dataArray.push(easing);\n                                    }\n\n                                    if (startValueRGB !== undefined) {\n                                        dataArray.push(startValueRGB[i]);\n                                    }\n\n                                    propertiesMap[property + colorComponents[i]] = dataArray;\n                                }\n\n                                /* Remove the intermediary shorthand property entry now that we've processed it. */\n                                delete propertiesMap[property];\n                            }\n                        }\n                    });\n\n                    /* Create a tween out of each property, and append its associated data to tweensContainer. */\n                    for (var property in propertiesMap) {\n\n                        /**************************\n                           Start Value Sourcing\n                        **************************/\n\n                        /* Parse out endValue, easing, and startValue from the property's data. */\n                        var valueData = parsePropertyValue(propertiesMap[property]),\n                            endValue = valueData[0],\n                            easing = valueData[1],\n                            startValue = valueData[2];\n\n                        /* Now that the original property name's format has been used for the parsePropertyValue() lookup above,\n                           we force the property to its camelCase styling to normalize it for manipulation. */\n                        property = CSS.Names.camelCase(property);\n\n                        /* In case this property is a hook, there are circumstances where we will intend to work on the hook's root property and not the hooked subproperty. */\n                        var rootProperty = CSS.Hooks.getRoot(property),\n                            rootPropertyValue = false;\n\n                        /* Other than for the dummy tween property, properties that are not supported by the browser (and do not have an associated normalization) will\n                           inherently produce no style changes when set, so they are skipped in order to decrease animation tick overhead.\n                           Property support is determined via prefixCheck(), which returns a false flag when no supported is detected. */\n                        /* Note: Since SVG elements have some of their properties directly applied as HTML attributes,\n                           there is no way to check for their explicit browser support, and so we skip skip this check for them. */\n                        if (!Data(element).isSVG && rootProperty !== \"tween\" && CSS.Names.prefixCheck(rootProperty)[1] === false && CSS.Normalizations.registered[rootProperty] === undefined) {\n                            if (Velocity.debug) console.log(\"Skipping [\" + rootProperty + \"] due to a lack of browser support.\");\n\n                            continue;\n                        }\n\n                        /* If the display option is being set to a non-\"none\" (e.g. \"block\") and opacity (filter on IE<=8) is being\n                           animated to an endValue of non-zero, the user's intention is to fade in from invisible, thus we forcefeed opacity\n                           a startValue of 0 if its startValue hasn't already been sourced by value transferring or prior forcefeeding. */\n                        if (((opts.display !== undefined && opts.display !== null && opts.display !== \"none\") || (opts.visibility !== undefined && opts.visibility !== \"hidden\")) && /opacity|filter/.test(property) && !startValue && endValue !== 0) {\n                            startValue = 0;\n                        }\n\n                        /* If values have been transferred from the previous Velocity call, extract the endValue and rootPropertyValue\n                           for all of the current call's properties that were *also* animated in the previous call. */\n                        /* Note: Value transferring can optionally be disabled by the user via the _cacheValues option. */\n                        if (opts._cacheValues && lastTweensContainer && lastTweensContainer[property]) {\n                            if (startValue === undefined) {\n                                startValue = lastTweensContainer[property].endValue + lastTweensContainer[property].unitType;\n                            }\n\n                            /* The previous call's rootPropertyValue is extracted from the element's data cache since that's the\n                               instance of rootPropertyValue that gets freshly updated by the tweening process, whereas the rootPropertyValue\n                               attached to the incoming lastTweensContainer is equal to the root property's value prior to any tweening. */\n                            rootPropertyValue = Data(element).rootPropertyValueCache[rootProperty];\n                        /* If values were not transferred from a previous Velocity call, query the DOM as needed. */\n                        } else {\n                            /* Handle hooked properties. */\n                            if (CSS.Hooks.registered[property]) {\n                               if (startValue === undefined) {\n                                    rootPropertyValue = CSS.getPropertyValue(element, rootProperty); /* GET */\n                                    /* Note: The following getPropertyValue() call does not actually trigger a DOM query;\n                                       getPropertyValue() will extract the hook from rootPropertyValue. */\n                                    startValue = CSS.getPropertyValue(element, property, rootPropertyValue);\n                                /* If startValue is already defined via forcefeeding, do not query the DOM for the root property's value;\n                                   just grab rootProperty's zero-value template from CSS.Hooks. This overwrites the element's actual\n                                   root property value (if one is set), but this is acceptable since the primary reason users forcefeed is\n                                   to avoid DOM queries, and thus we likewise avoid querying the DOM for the root property's value. */\n                                } else {\n                                    /* Grab this hook's zero-value template, e.g. \"0px 0px 0px black\". */\n                                    rootPropertyValue = CSS.Hooks.templates[rootProperty][1];\n                                }\n                            /* Handle non-hooked properties that haven't already been defined via forcefeeding. */\n                            } else if (startValue === undefined) {\n                                startValue = CSS.getPropertyValue(element, property); /* GET */\n                            }\n                        }\n\n                        /**************************\n                           Value Data Extraction\n                        **************************/\n\n                        var separatedValue,\n                            endValueUnitType,\n                            startValueUnitType,\n                            operator = false;\n\n                        /* Separates a property value into its numeric value and its unit type. */\n                        function separateValue (property, value) {\n                            var unitType,\n                                numericValue;\n\n                            numericValue = (value || \"0\")\n                                .toString()\n                                .toLowerCase()\n                                /* Match the unit type at the end of the value. */\n                                .replace(/[%A-z]+$/, function(match) {\n                                    /* Grab the unit type. */\n                                    unitType = match;\n\n                                    /* Strip the unit type off of value. */\n                                    return \"\";\n                                });\n\n                            /* If no unit type was supplied, assign one that is appropriate for this property (e.g. \"deg\" for rotateZ or \"px\" for width). */\n                            if (!unitType) {\n                                unitType = CSS.Values.getUnitType(property);\n                            }\n\n                            return [ numericValue, unitType ];\n                        }\n\n                        /* Separate startValue. */\n                        separatedValue = separateValue(property, startValue);\n                        startValue = separatedValue[0];\n                        startValueUnitType = separatedValue[1];\n\n                        /* Separate endValue, and extract a value operator (e.g. \"+=\", \"-=\") if one exists. */\n                        separatedValue = separateValue(property, endValue);\n                        endValue = separatedValue[0].replace(/^([+-\\/*])=/, function(match, subMatch) {\n                            operator = subMatch;\n\n                            /* Strip the operator off of the value. */\n                            return \"\";\n                        });\n                        endValueUnitType = separatedValue[1];\n\n                        /* Parse float values from endValue and startValue. Default to 0 if NaN is returned. */\n                        startValue = parseFloat(startValue) || 0;\n                        endValue = parseFloat(endValue) || 0;\n\n                        /***************************************\n                           Property-Specific Value Conversion\n                        ***************************************/\n\n                        /* Custom support for properties that don't actually accept the % unit type, but where pollyfilling is trivial and relatively foolproof. */\n                        if (endValueUnitType === \"%\") {\n                            /* A %-value fontSize/lineHeight is relative to the parent's fontSize (as opposed to the parent's dimensions),\n                               which is identical to the em unit's behavior, so we piggyback off of that. */\n                            if (/^(fontSize|lineHeight)$/.test(property)) {\n                                /* Convert % into an em decimal value. */\n                                endValue = endValue / 100;\n                                endValueUnitType = \"em\";\n                            /* For scaleX and scaleY, convert the value into its decimal format and strip off the unit type. */\n                            } else if (/^scale/.test(property)) {\n                                endValue = endValue / 100;\n                                endValueUnitType = \"\";\n                            /* For RGB components, take the defined percentage of 255 and strip off the unit type. */\n                            } else if (/(Red|Green|Blue)$/i.test(property)) {\n                                endValue = (endValue / 100) * 255;\n                                endValueUnitType = \"\";\n                            }\n                        }\n\n                        /***************************\n                           Unit Ratio Calculation\n                        ***************************/\n\n                        /* When queried, the browser returns (most) CSS property values in pixels. Therefore, if an endValue with a unit type of\n                           %, em, or rem is animated toward, startValue must be converted from pixels into the same unit type as endValue in order\n                           for value manipulation logic (increment/decrement) to proceed. Further, if the startValue was forcefed or transferred\n                           from a previous call, startValue may also not be in pixels. Unit conversion logic therefore consists of two steps:\n                           1) Calculating the ratio of %/em/rem/vh/vw relative to pixels\n                           2) Converting startValue into the same unit of measurement as endValue based on these ratios. */\n                        /* Unit conversion ratios are calculated by inserting a sibling node next to the target node, copying over its position property,\n                           setting values with the target unit type then comparing the returned pixel value. */\n                        /* Note: Even if only one of these unit types is being animated, all unit ratios are calculated at once since the overhead\n                           of batching the SETs and GETs together upfront outweights the potential overhead\n                           of layout thrashing caused by re-querying for uncalculated ratios for subsequently-processed properties. */\n                        /* Todo: Shift this logic into the calls' first tick instance so that it's synced with RAF. */\n                        function calculateUnitRatios () {\n\n                            /************************\n                                Same Ratio Checks\n                            ************************/\n\n                            /* The properties below are used to determine whether the element differs sufficiently from this call's\n                               previously iterated element to also differ in its unit conversion ratios. If the properties match up with those\n                               of the prior element, the prior element's conversion ratios are used. Like most optimizations in Velocity,\n                               this is done to minimize DOM querying. */\n                            var sameRatioIndicators = {\n                                    myParent: element.parentNode || document.body, /* GET */\n                                    position: CSS.getPropertyValue(element, \"position\"), /* GET */\n                                    fontSize: CSS.getPropertyValue(element, \"fontSize\") /* GET */\n                                },\n                                /* Determine if the same % ratio can be used. % is based on the element's position value and its parent's width and height dimensions. */\n                                samePercentRatio = ((sameRatioIndicators.position === callUnitConversionData.lastPosition) && (sameRatioIndicators.myParent === callUnitConversionData.lastParent)),\n                                /* Determine if the same em ratio can be used. em is relative to the element's fontSize. */\n                                sameEmRatio = (sameRatioIndicators.fontSize === callUnitConversionData.lastFontSize);\n\n                            /* Store these ratio indicators call-wide for the next element to compare against. */\n                            callUnitConversionData.lastParent = sameRatioIndicators.myParent;\n                            callUnitConversionData.lastPosition = sameRatioIndicators.position;\n                            callUnitConversionData.lastFontSize = sameRatioIndicators.fontSize;\n\n                            /***************************\n                               Element-Specific Units\n                            ***************************/\n\n                            /* Note: IE8 rounds to the nearest pixel when returning CSS values, thus we perform conversions using a measurement\n                               of 100 (instead of 1) to give our ratios a precision of at least 2 decimal values. */\n                            var measurement = 100,\n                                unitRatios = {};\n\n                            if (!sameEmRatio || !samePercentRatio) {\n                                var dummy = Data(element).isSVG ? document.createElementNS(\"http://www.w3.org/2000/svg\", \"rect\") : document.createElement(\"div\");\n\n                                Velocity.init(dummy);\n                                sameRatioIndicators.myParent.appendChild(dummy);\n\n                                /* To accurately and consistently calculate conversion ratios, the element's cascaded overflow and box-sizing are stripped.\n                                   Similarly, since width/height can be artificially constrained by their min-/max- equivalents, these are controlled for as well. */\n                                /* Note: Overflow must be also be controlled for per-axis since the overflow property overwrites its per-axis values. */\n                                $.each([ \"overflow\", \"overflowX\", \"overflowY\" ], function(i, property) {\n                                    Velocity.CSS.setPropertyValue(dummy, property, \"hidden\");\n                                });\n                                Velocity.CSS.setPropertyValue(dummy, \"position\", sameRatioIndicators.position);\n                                Velocity.CSS.setPropertyValue(dummy, \"fontSize\", sameRatioIndicators.fontSize);\n                                Velocity.CSS.setPropertyValue(dummy, \"boxSizing\", \"content-box\");\n\n                                /* width and height act as our proxy properties for measuring the horizontal and vertical % ratios. */\n                                $.each([ \"minWidth\", \"maxWidth\", \"width\", \"minHeight\", \"maxHeight\", \"height\" ], function(i, property) {\n                                    Velocity.CSS.setPropertyValue(dummy, property, measurement + \"%\");\n                                });\n                                /* paddingLeft arbitrarily acts as our proxy property for the em ratio. */\n                                Velocity.CSS.setPropertyValue(dummy, \"paddingLeft\", measurement + \"em\");\n\n                                /* Divide the returned value by the measurement to get the ratio between 1% and 1px. Default to 1 since working with 0 can produce Infinite. */\n                                unitRatios.percentToPxWidth = callUnitConversionData.lastPercentToPxWidth = (parseFloat(CSS.getPropertyValue(dummy, \"width\", null, true)) || 1) / measurement; /* GET */\n                                unitRatios.percentToPxHeight = callUnitConversionData.lastPercentToPxHeight = (parseFloat(CSS.getPropertyValue(dummy, \"height\", null, true)) || 1) / measurement; /* GET */\n                                unitRatios.emToPx = callUnitConversionData.lastEmToPx = (parseFloat(CSS.getPropertyValue(dummy, \"paddingLeft\")) || 1) / measurement; /* GET */\n\n                                sameRatioIndicators.myParent.removeChild(dummy);\n                            } else {\n                                unitRatios.emToPx = callUnitConversionData.lastEmToPx;\n                                unitRatios.percentToPxWidth = callUnitConversionData.lastPercentToPxWidth;\n                                unitRatios.percentToPxHeight = callUnitConversionData.lastPercentToPxHeight;\n                            }\n\n                            /***************************\n                               Element-Agnostic Units\n                            ***************************/\n\n                            /* Whereas % and em ratios are determined on a per-element basis, the rem unit only needs to be checked\n                               once per call since it's exclusively dependant upon document.body's fontSize. If this is the first time\n                               that calculateUnitRatios() is being run during this call, remToPx will still be set to its default value of null,\n                               so we calculate it now. */\n                            if (callUnitConversionData.remToPx === null) {\n                                /* Default to browsers' default fontSize of 16px in the case of 0. */\n                                callUnitConversionData.remToPx = parseFloat(CSS.getPropertyValue(document.body, \"fontSize\")) || 16; /* GET */\n                            }\n\n                            /* Similarly, viewport units are %-relative to the window's inner dimensions. */\n                            if (callUnitConversionData.vwToPx === null) {\n                                callUnitConversionData.vwToPx = parseFloat(window.innerWidth) / 100; /* GET */\n                                callUnitConversionData.vhToPx = parseFloat(window.innerHeight) / 100; /* GET */\n                            }\n\n                            unitRatios.remToPx = callUnitConversionData.remToPx;\n                            unitRatios.vwToPx = callUnitConversionData.vwToPx;\n                            unitRatios.vhToPx = callUnitConversionData.vhToPx;\n\n                            if (Velocity.debug >= 1) console.log(\"Unit ratios: \" + JSON.stringify(unitRatios), element);\n\n                            return unitRatios;\n                        }\n\n                        /********************\n                           Unit Conversion\n                        ********************/\n\n                        /* The * and / operators, which are not passed in with an associated unit, inherently use startValue's unit. Skip value and unit conversion. */\n                        if (/[\\/*]/.test(operator)) {\n                            endValueUnitType = startValueUnitType;\n                        /* If startValue and endValue differ in unit type, convert startValue into the same unit type as endValue so that if endValueUnitType\n                           is a relative unit (%, em, rem), the values set during tweening will continue to be accurately relative even if the metrics they depend\n                           on are dynamically changing during the course of the animation. Conversely, if we always normalized into px and used px for setting values, the px ratio\n                           would become stale if the original unit being animated toward was relative and the underlying metrics change during the animation. */\n                        /* Since 0 is 0 in any unit type, no conversion is necessary when startValue is 0 -- we just start at 0 with endValueUnitType. */\n                        } else if ((startValueUnitType !== endValueUnitType) && startValue !== 0) {\n                            /* Unit conversion is also skipped when endValue is 0, but *startValueUnitType* must be used for tween values to remain accurate. */\n                            /* Note: Skipping unit conversion here means that if endValueUnitType was originally a relative unit, the animation won't relatively\n                               match the underlying metrics if they change, but this is acceptable since we're animating toward invisibility instead of toward visibility,\n                               which remains past the point of the animation's completion. */\n                            if (endValue === 0) {\n                                endValueUnitType = startValueUnitType;\n                            } else {\n                                /* By this point, we cannot avoid unit conversion (it's undesirable since it causes layout thrashing).\n                                   If we haven't already, we trigger calculateUnitRatios(), which runs once per element per call. */\n                                elementUnitConversionData = elementUnitConversionData || calculateUnitRatios();\n\n                                /* The following RegEx matches CSS properties that have their % values measured relative to the x-axis. */\n                                /* Note: W3C spec mandates that all of margin and padding's properties (even top and bottom) are %-relative to the *width* of the parent element. */\n                                var axis = (/margin|padding|left|right|width|text|word|letter/i.test(property) || /X$/.test(property) || property === \"x\") ? \"x\" : \"y\";\n\n                                /* In order to avoid generating n^2 bespoke conversion functions, unit conversion is a two-step process:\n                                   1) Convert startValue into pixels. 2) Convert this new pixel value into endValue's unit type. */\n                                switch (startValueUnitType) {\n                                    case \"%\":\n                                        /* Note: translateX and translateY are the only properties that are %-relative to an element's own dimensions -- not its parent's dimensions.\n                                           Velocity does not include a special conversion process to account for this behavior. Therefore, animating translateX/Y from a % value\n                                           to a non-% value will produce an incorrect start value. Fortunately, this sort of cross-unit conversion is rarely done by users in practice. */\n                                        startValue *= (axis === \"x\" ? elementUnitConversionData.percentToPxWidth : elementUnitConversionData.percentToPxHeight);\n                                        break;\n\n                                    case \"px\":\n                                        /* px acts as our midpoint in the unit conversion process; do nothing. */\n                                        break;\n\n                                    default:\n                                        startValue *= elementUnitConversionData[startValueUnitType + \"ToPx\"];\n                                }\n\n                                /* Invert the px ratios to convert into to the target unit. */\n                                switch (endValueUnitType) {\n                                    case \"%\":\n                                        startValue *= 1 / (axis === \"x\" ? elementUnitConversionData.percentToPxWidth : elementUnitConversionData.percentToPxHeight);\n                                        break;\n\n                                    case \"px\":\n                                        /* startValue is already in px, do nothing; we're done. */\n                                        break;\n\n                                    default:\n                                        startValue *= 1 / elementUnitConversionData[endValueUnitType + \"ToPx\"];\n                                }\n                            }\n                        }\n\n                        /*********************\n                           Relative Values\n                        *********************/\n\n                        /* Operator logic must be performed last since it requires unit-normalized start and end values. */\n                        /* Note: Relative *percent values* do not behave how most people think; while one would expect \"+=50%\"\n                           to increase the property 1.5x its current value, it in fact increases the percent units in absolute terms:\n                           50 points is added on top of the current % value. */\n                        switch (operator) {\n                            case \"+\":\n                                endValue = startValue + endValue;\n                                break;\n\n                            case \"-\":\n                                endValue = startValue - endValue;\n                                break;\n\n                            case \"*\":\n                                endValue = startValue * endValue;\n                                break;\n\n                            case \"/\":\n                                endValue = startValue / endValue;\n                                break;\n                        }\n\n                        /**************************\n                           tweensContainer Push\n                        **************************/\n\n                        /* Construct the per-property tween object, and push it to the element's tweensContainer. */\n                        tweensContainer[property] = {\n                            rootPropertyValue: rootPropertyValue,\n                            startValue: startValue,\n                            currentValue: startValue,\n                            endValue: endValue,\n                            unitType: endValueUnitType,\n                            easing: easing\n                        };\n\n                        if (Velocity.debug) console.log(\"tweensContainer (\" + property + \"): \" + JSON.stringify(tweensContainer[property]), element);\n                    }\n\n                    /* Along with its property data, store a reference to the element itself onto tweensContainer. */\n                    tweensContainer.element = element;\n                }\n\n                /*****************\n                    Call Push\n                *****************/\n\n                /* Note: tweensContainer can be empty if all of the properties in this call's property map were skipped due to not\n                   being supported by the browser. The element property is used for checking that the tweensContainer has been appended to. */\n                if (tweensContainer.element) {\n                    /* Apply the \"velocity-animating\" indicator class. */\n                    CSS.Values.addClass(element, \"velocity-animating\");\n\n                    /* The call array houses the tweensContainers for each element being animated in the current call. */\n                    call.push(tweensContainer);\n\n                    /* Store the tweensContainer and options if we're working on the default effects queue, so that they can be used by the reverse command. */\n                    if (opts.queue === \"\") {\n                        Data(element).tweensContainer = tweensContainer;\n                        Data(element).opts = opts;\n                    }\n\n                    /* Switch on the element's animating flag. */\n                    Data(element).isAnimating = true;\n\n                    /* Once the final element in this call's element set has been processed, push the call array onto\n                       Velocity.State.calls for the animation tick to immediately begin processing. */\n                    if (elementsIndex === elementsLength - 1) {\n                        /* Add the current call plus its associated metadata (the element set and the call's options) onto the global call container.\n                           Anything on this call container is subjected to tick() processing. */\n                        Velocity.State.calls.push([ call, elements, opts, null, promiseData.resolver ]);\n\n                        /* If the animation tick isn't running, start it. (Velocity shuts it off when there are no active calls to process.) */\n                        if (Velocity.State.isTicking === false) {\n                            Velocity.State.isTicking = true;\n\n                            /* Start the tick loop. */\n                            tick();\n                        }\n                    } else {\n                        elementsIndex++;\n                    }\n                }\n            }\n\n            /* When the queue option is set to false, the call skips the element's queue and fires immediately. */\n            if (opts.queue === false) {\n                /* Since this buildQueue call doesn't respect the element's existing queue (which is where a delay option would have been appended),\n                   we manually inject the delay property here with an explicit setTimeout. */\n                if (opts.delay) {\n                    setTimeout(buildQueue, opts.delay);\n                } else {\n                    buildQueue();\n                }\n            /* Otherwise, the call undergoes element queueing as normal. */\n            /* Note: To interoperate with jQuery, Velocity uses jQuery's own $.queue() stack for queuing logic. */\n            } else {\n                $.queue(element, opts.queue, function(next, clearQueue) {\n                    /* If the clearQueue flag was passed in by the stop command, resolve this call's promise. (Promises can only be resolved once,\n                       so it's fine if this is repeatedly triggered for each element in the associated call.) */\n                    if (clearQueue === true) {\n                        if (promiseData.promise) {\n                            promiseData.resolver(elements);\n                        }\n\n                        /* Do not continue with animation queueing. */\n                        return true;\n                    }\n\n                    /* This flag indicates to the upcoming completeCall() function that this queue entry was initiated by Velocity.\n                       See completeCall() for further details. */\n                    Velocity.velocityQueueEntryFlag = true;\n\n                    buildQueue(next);\n                });\n            }\n\n            /*********************\n                Auto-Dequeuing\n            *********************/\n\n            /* As per jQuery's $.queue() behavior, to fire the first non-custom-queue entry on an element, the element\n               must be dequeued if its queue stack consists *solely* of the current call. (This can be determined by checking\n               for the \"inprogress\" item that jQuery prepends to active queue stack arrays.) Regardless, whenever the element's\n               queue is further appended with additional items -- including $.delay()'s or even $.animate() calls, the queue's\n               first entry is automatically fired. This behavior contrasts that of custom queues, which never auto-fire. */\n            /* Note: When an element set is being subjected to a non-parallel Velocity call, the animation will not begin until\n               each one of the elements in the set has reached the end of its individually pre-existing queue chain. */\n            /* Note: Unfortunately, most people don't fully grasp jQuery's powerful, yet quirky, $.queue() function.\n               Lean more here: http://stackoverflow.com/questions/1058158/can-somebody-explain-jquery-queue-to-me */\n            if ((opts.queue === \"\" || opts.queue === \"fx\") && $.queue(element)[0] !== \"inprogress\") {\n                $.dequeue(element);\n            }\n        }\n\n        /**************************\n           Element Set Iteration\n        **************************/\n\n        /* If the \"nodeType\" property exists on the elements variable, we're animating a single element.\n           Place it in an array so that $.each() can iterate over it. */\n        $.each(elements, function(i, element) {\n            /* Ensure each element in a set has a nodeType (is a real element) to avoid throwing errors. */\n            if (Type.isNode(element)) {\n                processElement.call(element);\n            }\n        });\n\n        /******************\n           Option: Loop\n        ******************/\n\n        /* The loop option accepts an integer indicating how many times the element should loop between the values in the\n           current call's properties map and the element's property values prior to this call. */\n        /* Note: The loop option's logic is performed here -- after element processing -- because the current call needs\n           to undergo its queue insertion prior to the loop option generating its series of constituent \"reverse\" calls,\n           which chain after the current call. Two reverse calls (two \"alternations\") constitute one loop. */\n        var opts = $.extend({}, Velocity.defaults, options),\n            reverseCallsCount;\n\n        opts.loop = parseInt(opts.loop);\n        reverseCallsCount = (opts.loop * 2) - 1;\n\n        if (opts.loop) {\n            /* Double the loop count to convert it into its appropriate number of \"reverse\" calls.\n               Subtract 1 from the resulting value since the current call is included in the total alternation count. */\n            for (var x = 0; x < reverseCallsCount; x++) {\n                /* Since the logic for the reverse action occurs inside Queueing and therefore this call's options object\n                   isn't parsed until then as well, the current call's delay option must be explicitly passed into the reverse\n                   call so that the delay logic that occurs inside *Pre-Queueing* can process it. */\n                var reverseOptions = {\n                    delay: opts.delay,\n                    progress: opts.progress\n                };\n\n                /* If a complete callback was passed into this call, transfer it to the loop redirect's final \"reverse\" call\n                   so that it's triggered when the entire redirect is complete (and not when the very first animation is complete). */\n                if (x === reverseCallsCount - 1) {\n                    reverseOptions.display = opts.display;\n                    reverseOptions.visibility = opts.visibility;\n                    reverseOptions.complete = opts.complete;\n                }\n\n                animate(elements, \"reverse\", reverseOptions);\n            }\n        }\n\n        /***************\n            Chaining\n        ***************/\n\n        /* Return the elements back to the call chain, with wrapped elements taking precedence in case Velocity was called via the $.fn. extension. */\n        return getChain();\n    };\n\n    /* Turn Velocity into the animation function, extended with the pre-existing Velocity object. */\n    Velocity = $.extend(animate, Velocity);\n    /* For legacy support, also expose the literal animate method. */\n    Velocity.animate = animate;\n\n    /**************\n        Timing\n    **************/\n\n    /* Ticker function. */\n    var ticker = window.requestAnimationFrame || rAFShim;\n\n    /* Inactive browser tabs pause rAF, which results in all active animations immediately sprinting to their completion states when the tab refocuses.\n       To get around this, we dynamically switch rAF to setTimeout (which the browser *doesn't* pause) when the tab loses focus. We skip this for mobile\n       devices to avoid wasting battery power on inactive tabs. */\n    /* Note: Tab focus detection doesn't work on older versions of IE, but that's okay since they don't support rAF to begin with. */\n    if (!Velocity.State.isMobile && document.hidden !== undefined) {\n        document.addEventListener(\"visibilitychange\", function() {\n            /* Reassign the rAF function (which the global tick() function uses) based on the tab's focus state. */\n            if (document.hidden) {\n                ticker = function(callback) {\n                    /* The tick function needs a truthy first argument in order to pass its internal timestamp check. */\n                    return setTimeout(function() { callback(true) }, 16);\n                };\n\n                /* The rAF loop has been paused by the browser, so we manually restart the tick. */\n                tick();\n            } else {\n                ticker = window.requestAnimationFrame || rAFShim;\n            }\n        });\n    }\n\n    /************\n        Tick\n    ************/\n\n    /* Note: All calls to Velocity are pushed to the Velocity.State.calls array, which is fully iterated through upon each tick. */\n    function tick (timestamp) {\n        /* An empty timestamp argument indicates that this is the first tick occurence since ticking was turned on.\n           We leverage this metadata to fully ignore the first tick pass since RAF's initial pass is fired whenever\n           the browser's next tick sync time occurs, which results in the first elements subjected to Velocity\n           calls being animated out of sync with any elements animated immediately thereafter. In short, we ignore\n           the first RAF tick pass so that elements being immediately consecutively animated -- instead of simultaneously animated\n           by the same Velocity call -- are properly batched into the same initial RAF tick and consequently remain in sync thereafter. */\n        if (timestamp) {\n            /* We ignore RAF's high resolution timestamp since it can be significantly offset when the browser is\n               under high stress; we opt for choppiness over allowing the browser to drop huge chunks of frames. */\n            var timeCurrent = (new Date).getTime();\n\n            /********************\n               Call Iteration\n            ********************/\n\n            var callsLength = Velocity.State.calls.length;\n\n            /* To speed up iterating over this array, it is compacted (falsey items -- calls that have completed -- are removed)\n               when its length has ballooned to a point that can impact tick performance. This only becomes necessary when animation\n               has been continuous with many elements over a long period of time; whenever all active calls are completed, completeCall() clears Velocity.State.calls. */\n            if (callsLength > 10000) {\n                Velocity.State.calls = compactSparseArray(Velocity.State.calls);\n            }\n\n            /* Iterate through each active call. */\n            for (var i = 0; i < callsLength; i++) {\n                /* When a Velocity call is completed, its Velocity.State.calls entry is set to false. Continue on to the next call. */\n                if (!Velocity.State.calls[i]) {\n                    continue;\n                }\n\n                /************************\n                   Call-Wide Variables\n                ************************/\n\n                var callContainer = Velocity.State.calls[i],\n                    call = callContainer[0],\n                    opts = callContainer[2],\n                    timeStart = callContainer[3],\n                    firstTick = !!timeStart,\n                    tweenDummyValue = null;\n\n                /* If timeStart is undefined, then this is the first time that this call has been processed by tick().\n                   We assign timeStart now so that its value is as close to the real animation start time as possible.\n                   (Conversely, had timeStart been defined when this call was added to Velocity.State.calls, the delay\n                   between that time and now would cause the first few frames of the tween to be skipped since\n                   percentComplete is calculated relative to timeStart.) */\n                /* Further, subtract 16ms (the approximate resolution of RAF) from the current time value so that the\n                   first tick iteration isn't wasted by animating at 0% tween completion, which would produce the\n                   same style value as the element's current value. */\n                if (!timeStart) {\n                    timeStart = Velocity.State.calls[i][3] = timeCurrent - 16;\n                }\n\n                /* The tween's completion percentage is relative to the tween's start time, not the tween's start value\n                   (which would result in unpredictable tween durations since JavaScript's timers are not particularly accurate).\n                   Accordingly, we ensure that percentComplete does not exceed 1. */\n                var percentComplete = Math.min((timeCurrent - timeStart) / opts.duration, 1);\n\n                /**********************\n                   Element Iteration\n                **********************/\n\n                /* For every call, iterate through each of the elements in its set. */\n                for (var j = 0, callLength = call.length; j < callLength; j++) {\n                    var tweensContainer = call[j],\n                        element = tweensContainer.element;\n\n                    /* Check to see if this element has been deleted midway through the animation by checking for the\n                       continued existence of its data cache. If it's gone, skip animating this element. */\n                    if (!Data(element)) {\n                        continue;\n                    }\n\n                    var transformPropertyExists = false;\n\n                    /**********************************\n                       Display & Visibility Toggling\n                    **********************************/\n\n                    /* If the display option is set to non-\"none\", set it upfront so that the element can become visible before tweening begins.\n                       (Otherwise, display's \"none\" value is set in completeCall() once the animation has completed.) */\n                    if (opts.display !== undefined && opts.display !== null && opts.display !== \"none\") {\n                        if (opts.display === \"flex\") {\n                            var flexValues = [ \"-webkit-box\", \"-moz-box\", \"-ms-flexbox\", \"-webkit-flex\" ];\n\n                            $.each(flexValues, function(i, flexValue) {\n                                CSS.setPropertyValue(element, \"display\", flexValue);\n                            });\n                        }\n\n                        CSS.setPropertyValue(element, \"display\", opts.display);\n                    }\n\n                    /* Same goes with the visibility option, but its \"none\" equivalent is \"hidden\". */\n                    if (opts.visibility !== undefined && opts.visibility !== \"hidden\") {\n                        CSS.setPropertyValue(element, \"visibility\", opts.visibility);\n                    }\n\n                    /************************\n                       Property Iteration\n                    ************************/\n\n                    /* For every element, iterate through each property. */\n                    for (var property in tweensContainer) {\n                        /* Note: In addition to property tween data, tweensContainer contains a reference to its associated element. */\n                        if (property !== \"element\") {\n                            var tween = tweensContainer[property],\n                                currentValue,\n                                /* Easing can either be a pre-genereated function or a string that references a pre-registered easing\n                                   on the Velocity.Easings object. In either case, return the appropriate easing *function*. */\n                                easing = Type.isString(tween.easing) ? Velocity.Easings[tween.easing] : tween.easing;\n\n                            /******************************\n                               Current Value Calculation\n                            ******************************/\n\n                            /* If this is the last tick pass (if we've reached 100% completion for this tween),\n                               ensure that currentValue is explicitly set to its target endValue so that it's not subjected to any rounding. */\n                            if (percentComplete === 1) {\n                                currentValue = tween.endValue;\n                            /* Otherwise, calculate currentValue based on the current delta from startValue. */\n                            } else {\n                                var tweenDelta = tween.endValue - tween.startValue;\n                                currentValue = tween.startValue + (tweenDelta * easing(percentComplete, opts, tweenDelta));\n\n                                /* If no value change is occurring, don't proceed with DOM updating. */\n                                if (!firstTick && (currentValue === tween.currentValue)) {\n                                    continue;\n                                }\n                            }\n\n                            tween.currentValue = currentValue;\n\n                            /* If we're tweening a fake 'tween' property in order to log transition values, update the one-per-call variable so that\n                               it can be passed into the progress callback. */ \n                            if (property === \"tween\") {\n                                tweenDummyValue = currentValue;\n                            } else {\n                                /******************\n                                   Hooks: Part I\n                                ******************/\n\n                                /* For hooked properties, the newly-updated rootPropertyValueCache is cached onto the element so that it can be used\n                                   for subsequent hooks in this call that are associated with the same root property. If we didn't cache the updated\n                                   rootPropertyValue, each subsequent update to the root property in this tick pass would reset the previous hook's\n                                   updates to rootPropertyValue prior to injection. A nice performance byproduct of rootPropertyValue caching is that\n                                   subsequently chained animations using the same hookRoot but a different hook can use this cached rootPropertyValue. */\n                                if (CSS.Hooks.registered[property]) {\n                                    var hookRoot = CSS.Hooks.getRoot(property),\n                                        rootPropertyValueCache = Data(element).rootPropertyValueCache[hookRoot];\n\n                                    if (rootPropertyValueCache) {\n                                        tween.rootPropertyValue = rootPropertyValueCache;\n                                    }\n                                }\n\n                                /*****************\n                                    DOM Update\n                                *****************/\n\n                                /* setPropertyValue() returns an array of the property name and property value post any normalization that may have been performed. */\n                                /* Note: To solve an IE<=8 positioning bug, the unit type is dropped when setting a property value of 0. */\n                                var adjustedSetData = CSS.setPropertyValue(element, /* SET */\n                                                                           property,\n                                                                           tween.currentValue + (parseFloat(currentValue) === 0 ? \"\" : tween.unitType),\n                                                                           tween.rootPropertyValue,\n                                                                           tween.scrollData);\n\n                                /*******************\n                                   Hooks: Part II\n                                *******************/\n\n                                /* Now that we have the hook's updated rootPropertyValue (the post-processed value provided by adjustedSetData), cache it onto the element. */\n                                if (CSS.Hooks.registered[property]) {\n                                    /* Since adjustedSetData contains normalized data ready for DOM updating, the rootPropertyValue needs to be re-extracted from its normalized form. ?? */\n                                    if (CSS.Normalizations.registered[hookRoot]) {\n                                        Data(element).rootPropertyValueCache[hookRoot] = CSS.Normalizations.registered[hookRoot](\"extract\", null, adjustedSetData[1]);\n                                    } else {\n                                        Data(element).rootPropertyValueCache[hookRoot] = adjustedSetData[1];\n                                    }\n                                }\n\n                                /***************\n                                   Transforms\n                                ***************/\n\n                                /* Flag whether a transform property is being animated so that flushTransformCache() can be triggered once this tick pass is complete. */\n                                if (adjustedSetData[0] === \"transform\") {\n                                    transformPropertyExists = true;\n                                }\n\n                            }\n                        }\n                    }\n\n                    /****************\n                        mobileHA\n                    ****************/\n\n                    /* If mobileHA is enabled, set the translate3d transform to null to force hardware acceleration.\n                       It's safe to override this property since Velocity doesn't actually support its animation (hooks are used in its place). */\n                    if (opts.mobileHA) {\n                        /* Don't set the null transform hack if we've already done so. */\n                        if (Data(element).transformCache.translate3d === undefined) {\n                            /* All entries on the transformCache object are later concatenated into a single transform string via flushTransformCache(). */\n                            Data(element).transformCache.translate3d = \"(0px, 0px, 0px)\";\n\n                            transformPropertyExists = true;\n                        }\n                    }\n\n                    if (transformPropertyExists) {\n                        CSS.flushTransformCache(element);\n                    }\n                }\n\n                /* The non-\"none\" display value is only applied to an element once -- when its associated call is first ticked through.\n                   Accordingly, it's set to false so that it isn't re-processed by this call in the next tick. */\n                if (opts.display !== undefined && opts.display !== \"none\") {\n                    Velocity.State.calls[i][2].display = false;\n                }\n                if (opts.visibility !== undefined && opts.visibility !== \"hidden\") {\n                    Velocity.State.calls[i][2].visibility = false;\n                }\n\n                /* Pass the elements and the timing data (percentComplete, msRemaining, timeStart, tweenDummyValue) into the progress callback. */\n                if (opts.progress) {\n                    opts.progress.call(callContainer[1],\n                                       callContainer[1],\n                                       percentComplete,\n                                       Math.max(0, (timeStart + opts.duration) - timeCurrent),\n                                       timeStart,\n                                       tweenDummyValue);\n                }\n\n                /* If this call has finished tweening, pass its index to completeCall() to handle call cleanup. */\n                if (percentComplete === 1) {\n                    completeCall(i);\n                }\n            }\n        }\n\n        /* Note: completeCall() sets the isTicking flag to false when the last call on Velocity.State.calls has completed. */\n        if (Velocity.State.isTicking) {\n            ticker(tick);\n        }\n    }\n\n    /**********************\n        Call Completion\n    **********************/\n\n    /* Note: Unlike tick(), which processes all active calls at once, call completion is handled on a per-call basis. */\n    function completeCall (callIndex, isStopped) {\n        /* Ensure the call exists. */\n        if (!Velocity.State.calls[callIndex]) {\n            return false;\n        }\n\n        /* Pull the metadata from the call. */\n        var call = Velocity.State.calls[callIndex][0],\n            elements = Velocity.State.calls[callIndex][1],\n            opts = Velocity.State.calls[callIndex][2],\n            resolver = Velocity.State.calls[callIndex][4];\n\n        var remainingCallsExist = false;\n\n        /*************************\n           Element Finalization\n        *************************/\n\n        for (var i = 0, callLength = call.length; i < callLength; i++) {\n            var element = call[i].element;\n\n            /* If the user set display to \"none\" (intending to hide the element), set it now that the animation has completed. */\n            /* Note: display:none isn't set when calls are manually stopped (via Velocity(\"stop\"). */\n            /* Note: Display gets ignored with \"reverse\" calls and infinite loops, since this behavior would be undesirable. */\n            if (!isStopped && !opts.loop) {\n                if (opts.display === \"none\") {\n                    CSS.setPropertyValue(element, \"display\", opts.display);\n                }\n\n                if (opts.visibility === \"hidden\") {\n                    CSS.setPropertyValue(element, \"visibility\", opts.visibility);\n                }\n            }\n\n            /* If the element's queue is empty (if only the \"inprogress\" item is left at position 0) or if its queue is about to run\n               a non-Velocity-initiated entry, turn off the isAnimating flag. A non-Velocity-initiatied queue entry's logic might alter\n               an element's CSS values and thereby cause Velocity's cached value data to go stale. To detect if a queue entry was initiated by Velocity,\n               we check for the existence of our special Velocity.queueEntryFlag declaration, which minifiers won't rename since the flag\n               is assigned to jQuery's global $ object and thus exists out of Velocity's own scope. */\n            if (opts.loop !== true && ($.queue(element)[1] === undefined || !/\\.velocityQueueEntryFlag/i.test($.queue(element)[1]))) {\n                /* The element may have been deleted. Ensure that its data cache still exists before acting on it. */\n                if (Data(element)) {\n                    Data(element).isAnimating = false;\n                    /* Clear the element's rootPropertyValueCache, which will become stale. */\n                    Data(element).rootPropertyValueCache = {};\n\n                    var transformHAPropertyExists = false;\n                    /* If any 3D transform subproperty is at its default value (regardless of unit type), remove it. */\n                    $.each(CSS.Lists.transforms3D, function(i, transformName) {\n                        var defaultValue = /^scale/.test(transformName) ? 1 : 0,\n                            currentValue = Data(element).transformCache[transformName];\n\n                        if (Data(element).transformCache[transformName] !== undefined && new RegExp(\"^\\\\(\" + defaultValue + \"[^.]\").test(currentValue)) {\n                            transformHAPropertyExists = true;\n\n                            delete Data(element).transformCache[transformName];\n                        }\n                    });\n\n                    /* Mobile devices have hardware acceleration removed at the end of the animation in order to avoid hogging the GPU's memory. */\n                    if (opts.mobileHA) {\n                        transformHAPropertyExists = true;\n                        delete Data(element).transformCache.translate3d;\n                    }\n\n                    /* Flush the subproperty removals to the DOM. */\n                    if (transformHAPropertyExists) {\n                        CSS.flushTransformCache(element);\n                    }\n\n                    /* Remove the \"velocity-animating\" indicator class. */\n                    CSS.Values.removeClass(element, \"velocity-animating\");\n                }\n            }\n\n            /*********************\n               Option: Complete\n            *********************/\n\n            /* Complete is fired once per call (not once per element) and is passed the full raw DOM element set as both its context and its first argument. */\n            /* Note: Callbacks aren't fired when calls are manually stopped (via Velocity(\"stop\"). */\n            if (!isStopped && opts.complete && !opts.loop && (i === callLength - 1)) {\n                /* We throw callbacks in a setTimeout so that thrown errors don't halt the execution of Velocity itself. */\n                try {\n                    opts.complete.call(elements, elements);\n                } catch (error) {\n                    setTimeout(function() { throw error; }, 1);\n                }\n            }\n\n            /**********************\n               Promise Resolving\n            **********************/\n\n            /* Note: Infinite loops don't return promises. */\n            if (resolver && opts.loop !== true) {\n                resolver(elements);\n            }\n\n            /****************************\n               Option: Loop (Infinite)\n            ****************************/\n\n            if (Data(element) && opts.loop === true && !isStopped) {\n                /* If a rotateX/Y/Z property is being animated to 360 deg with loop:true, swap tween start/end values to enable\n                   continuous iterative rotation looping. (Otherise, the element would just rotate back and forth.) */\n                $.each(Data(element).tweensContainer, function(propertyName, tweenContainer) {\n                    if (/^rotate/.test(propertyName) && parseFloat(tweenContainer.endValue) === 360) {\n                        tweenContainer.endValue = 0;\n                        tweenContainer.startValue = 360;\n                    }\n\n                    if (/^backgroundPosition/.test(propertyName) && parseFloat(tweenContainer.endValue) === 100 && tweenContainer.unitType === \"%\") {\n                        tweenContainer.endValue = 0;\n                        tweenContainer.startValue = 100;\n                    }\n                });\n\n                Velocity(element, \"reverse\", { loop: true, delay: opts.delay });\n            }\n\n            /***************\n               Dequeueing\n            ***************/\n\n            /* Fire the next call in the queue so long as this call's queue wasn't set to false (to trigger a parallel animation),\n               which would have already caused the next call to fire. Note: Even if the end of the animation queue has been reached,\n               $.dequeue() must still be called in order to completely clear jQuery's animation queue. */\n            if (opts.queue !== false) {\n                $.dequeue(element, opts.queue);\n            }\n        }\n\n        /************************\n           Calls Array Cleanup\n        ************************/\n\n        /* Since this call is complete, set it to false so that the rAF tick skips it. This array is later compacted via compactSparseArray().\n          (For performance reasons, the call is set to false instead of being deleted from the array: http://www.html5rocks.com/en/tutorials/speed/v8/) */\n        Velocity.State.calls[callIndex] = false;\n\n        /* Iterate through the calls array to determine if this was the final in-progress animation.\n           If so, set a flag to end ticking and clear the calls array. */\n        for (var j = 0, callsLength = Velocity.State.calls.length; j < callsLength; j++) {\n            if (Velocity.State.calls[j] !== false) {\n                remainingCallsExist = true;\n\n                break;\n            }\n        }\n\n        if (remainingCallsExist === false) {\n            /* tick() will detect this flag upon its next iteration and subsequently turn itself off. */\n            Velocity.State.isTicking = false;\n\n            /* Clear the calls array so that its length is reset. */\n            delete Velocity.State.calls;\n            Velocity.State.calls = [];\n        }\n    }\n\n    /******************\n        Frameworks\n    ******************/\n\n    /* Both jQuery and Zepto allow their $.fn object to be extended to allow wrapped elements to be subjected to plugin calls.\n       If either framework is loaded, register a \"velocity\" extension pointing to Velocity's core animate() method.  Velocity\n       also registers itself onto a global container (window.jQuery || window.Zepto || window) so that certain features are\n       accessible beyond just a per-element scope. This master object contains an .animate() method, which is later assigned to $.fn\n       (if jQuery or Zepto are present). Accordingly, Velocity can both act on wrapped DOM elements and stand alone for targeting raw DOM elements. */\n    global.Velocity = Velocity;\n\n    if (global !== window) {\n        /* Assign the element function to Velocity's core animate() method. */\n        global.fn.velocity = animate;\n        /* Assign the object function's defaults to Velocity's global defaults object. */\n        global.fn.velocity.defaults = Velocity.defaults;\n    }\n\n    /***********************\n       Packaged Redirects\n    ***********************/\n\n    /* slideUp, slideDown */\n    $.each([ \"Down\", \"Up\" ], function(i, direction) {\n        Velocity.Redirects[\"slide\" + direction] = function (element, options, elementsIndex, elementsSize, elements, promiseData) {\n            var opts = $.extend({}, options),\n                begin = opts.begin,\n                complete = opts.complete,\n                computedValues = { height: \"\", marginTop: \"\", marginBottom: \"\", paddingTop: \"\", paddingBottom: \"\" },\n                inlineValues = {};\n\n            if (opts.display === undefined) {\n                /* Show the element before slideDown begins and hide the element after slideUp completes. */\n                /* Note: Inline elements cannot have dimensions animated, so they're reverted to inline-block. */\n                opts.display = (direction === \"Down\" ? (Velocity.CSS.Values.getDisplayType(element) === \"inline\" ? \"inline-block\" : \"block\") : \"none\");\n            }\n\n            opts.begin = function() {\n                /* If the user passed in a begin callback, fire it now. */\n                begin && begin.call(elements, elements);\n\n                /* Cache the elements' original vertical dimensional property values so that we can animate back to them. */\n                for (var property in computedValues) {\n                    inlineValues[property] = element.style[property];\n\n                    /* For slideDown, use forcefeeding to animate all vertical properties from 0. For slideUp,\n                       use forcefeeding to start from computed values and animate down to 0. */\n                    var propertyValue = Velocity.CSS.getPropertyValue(element, property);\n                    computedValues[property] = (direction === \"Down\") ? [ propertyValue, 0 ] : [ 0, propertyValue ];\n                }\n\n                /* Force vertical overflow content to clip so that sliding works as expected. */\n                inlineValues.overflow = element.style.overflow;\n                element.style.overflow = \"hidden\";\n            }\n\n            opts.complete = function() {\n                /* Reset element to its pre-slide inline values once its slide animation is complete. */\n                for (var property in inlineValues) {\n                    element.style[property] = inlineValues[property];\n                }\n\n                /* If the user passed in a complete callback, fire it now. */\n                complete && complete.call(elements, elements);\n                promiseData && promiseData.resolver(elements);\n            };\n\n            Velocity(element, computedValues, opts);\n        };\n    });\n\n    /* fadeIn, fadeOut */\n    $.each([ \"In\", \"Out\" ], function(i, direction) {\n        Velocity.Redirects[\"fade\" + direction] = function (element, options, elementsIndex, elementsSize, elements, promiseData) {\n            var opts = $.extend({}, options),\n                propertiesMap = { opacity: (direction === \"In\") ? 1 : 0 },\n                originalComplete = opts.complete;\n\n            /* Since redirects are triggered individually for each element in the animated set, avoid repeatedly triggering\n               callbacks by firing them only when the final element has been reached. */\n            if (elementsIndex !== elementsSize - 1) {\n                opts.complete = opts.begin = null;\n            } else {\n                opts.complete = function() {\n                    if (originalComplete) {\n                        originalComplete.call(elements, elements);\n                    }\n\n                    promiseData && promiseData.resolver(elements);\n                }\n            }\n\n            /* If a display was passed in, use it. Otherwise, default to \"none\" for fadeOut or the element-specific default for fadeIn. */\n            /* Note: We allow users to pass in \"null\" to skip display setting altogether. */\n            if (opts.display === undefined) {\n                opts.display = (direction === \"In\" ? \"auto\" : \"none\");\n            }\n\n            Velocity(this, propertiesMap, opts);\n        };\n    });\n\n    return Velocity;\n}((window.jQuery || window.Zepto || window), window, document);\n}));\n\n/******************\n   Known Issues\n******************/\n\n/* The CSS spec mandates that the translateX/Y/Z transforms are %-relative to the element itself -- not its parent.\nVelocity, however, doesn't make this distinction. Thus, converting to or from the % unit with these subproperties\nwill produce an inaccurate conversion value. The same issue exists with the cx/cy attributes of SVG circles and ellipses. */"
  },
  {
    "path": "source/lib/velocity/velocity.ui.js",
    "content": "/**********************\n   Velocity UI Pack\n**********************/\n\n/* VelocityJS.org UI Pack (5.0.4). (C) 2014 Julian Shapiro. MIT @license: en.wikipedia.org/wiki/MIT_License. Portions copyright Daniel Eden, Christian Pucci. */\n\n;(function (factory) {\n    /* CommonJS module. */\n    if (typeof require === \"function\" && typeof exports === \"object\" ) {\n        module.exports = factory();\n    /* AMD module. */\n    } else if (typeof define === \"function\" && define.amd) {\n        define([ \"velocity\" ], factory);\n    /* Browser globals. */\n    } else {\n        factory();\n    }\n}(function() {\nreturn function (global, window, document, undefined) {\n\n    /*************\n        Checks\n    *************/\n\n    if (!global.Velocity || !global.Velocity.Utilities) {\n        window.console && console.log(\"Velocity UI Pack: Velocity must be loaded first. Aborting.\");\n        return;\n    } else {\n        var Velocity = global.Velocity,\n            $ = Velocity.Utilities;\n    }\n\n    var velocityVersion = Velocity.version,\n        requiredVersion = { major: 1, minor: 1, patch: 0 };\n\n    function greaterSemver (primary, secondary) {\n        var versionInts = [];\n\n        if (!primary || !secondary) { return false; }\n\n        $.each([ primary, secondary ], function(i, versionObject) {\n            var versionIntsComponents = [];\n\n            $.each(versionObject, function(component, value) {\n                while (value.toString().length < 5) {\n                    value = \"0\" + value;\n                }\n                versionIntsComponents.push(value);\n            });\n\n            versionInts.push(versionIntsComponents.join(\"\"))\n        });\n\n        return (parseFloat(versionInts[0]) > parseFloat(versionInts[1]));\n    }\n\n    if (greaterSemver(requiredVersion, velocityVersion)){\n        var abortError = \"Velocity UI Pack: You need to update Velocity (jquery.velocity.js) to a newer version. Visit http://github.com/julianshapiro/velocity.\";\n        alert(abortError);\n        throw new Error(abortError);\n    }\n\n    /************************\n       Effect Registration\n    ************************/\n\n    /* Note: RegisterUI is a legacy name. */\n    Velocity.RegisterEffect = Velocity.RegisterUI = function (effectName, properties) {\n        /* Animate the expansion/contraction of the elements' parent's height for In/Out effects. */\n        function animateParentHeight (elements, direction, totalDuration, stagger) {\n            var totalHeightDelta = 0,\n                parentNode;\n\n            /* Sum the total height (including padding and margin) of all targeted elements. */\n            $.each(elements.nodeType ? [ elements ] : elements, function(i, element) {\n                if (stagger) {\n                    /* Increase the totalDuration by the successive delay amounts produced by the stagger option. */\n                    totalDuration += i * stagger;\n                }\n\n                parentNode = element.parentNode;\n\n                $.each([ \"height\", \"paddingTop\", \"paddingBottom\", \"marginTop\", \"marginBottom\"], function(i, property) {\n                    totalHeightDelta += parseFloat(Velocity.CSS.getPropertyValue(element, property));\n                });\n            });\n\n            /* Animate the parent element's height adjustment (with a varying duration multiplier for aesthetic benefits). */\n            Velocity.animate(\n                parentNode,\n                { height: (direction === \"In\" ? \"+\" : \"-\") + \"=\" + totalHeightDelta },\n                { queue: false, easing: \"ease-in-out\", duration: totalDuration * (direction === \"In\" ? 0.6 : 1) }\n            );\n        }\n\n        /* Register a custom redirect for each effect. */\n        Velocity.Redirects[effectName] = function (element, redirectOptions, elementsIndex, elementsSize, elements, promiseData) {\n            var finalElement = (elementsIndex === elementsSize - 1);\n\n            if (typeof properties.defaultDuration === \"function\") {\n                properties.defaultDuration = properties.defaultDuration.call(elements, elements);\n            } else {\n                properties.defaultDuration = parseFloat(properties.defaultDuration);\n            }\n\n            /* Iterate through each effect's call array. */\n            for (var callIndex = 0; callIndex < properties.calls.length; callIndex++) {\n                var call = properties.calls[callIndex],\n                    propertyMap = call[0],\n                    redirectDuration = (redirectOptions.duration || properties.defaultDuration || 1000),\n                    durationPercentage = call[1],\n                    callOptions = call[2] || {},\n                    opts = {};\n\n                /* Assign the whitelisted per-call options. */\n                opts.duration = redirectDuration * (durationPercentage || 1);\n                opts.queue = redirectOptions.queue || \"\";\n                opts.easing = callOptions.easing || \"ease\";\n                opts.delay = parseFloat(callOptions.delay) || 0;\n                opts._cacheValues = callOptions._cacheValues || true;\n\n                /* Special processing for the first effect call. */\n                if (callIndex === 0) {\n                    /* If a delay was passed into the redirect, combine it with the first call's delay. */\n                    opts.delay += (parseFloat(redirectOptions.delay) || 0);\n\n                    if (elementsIndex === 0) {\n                        opts.begin = function() {\n                            /* Only trigger a begin callback on the first effect call with the first element in the set. */\n                            redirectOptions.begin && redirectOptions.begin.call(elements, elements);\n\n                            var direction = effectName.match(/(In|Out)$/);\n\n                            /* Make \"in\" transitioning elements invisible immediately so that there's no FOUC between now\n                               and the first RAF tick. */\n                            if ((direction && direction[0] === \"In\") && propertyMap.opacity !== undefined) {\n                                $.each(elements.nodeType ? [ elements ] : elements, function(i, element) {\n                                    Velocity.CSS.setPropertyValue(element, \"opacity\", 0);\n                                });\n                            }\n\n                            /* Only trigger animateParentHeight() if we're using an In/Out transition. */\n                            if (redirectOptions.animateParentHeight && direction) {\n                                animateParentHeight(elements, direction[0], redirectDuration + opts.delay, redirectOptions.stagger);\n                            }\n                        }\n                    }\n\n                    /* If the user isn't overriding the display option, default to \"auto\" for \"In\"-suffixed transitions. */\n                    if (redirectOptions.display !== null) {\n                        if (redirectOptions.display !== undefined && redirectOptions.display !== \"none\") {\n                            opts.display = redirectOptions.display;\n                        } else if (/In$/.test(effectName)) {\n                            /* Inline elements cannot be subjected to transforms, so we switch them to inline-block. */\n                            var defaultDisplay = Velocity.CSS.Values.getDisplayType(element);\n                            opts.display = (defaultDisplay === \"inline\") ? \"inline-block\" : defaultDisplay;\n                        }\n                    }\n\n                    if (redirectOptions.visibility && redirectOptions.visibility !== \"hidden\") {\n                        opts.visibility = redirectOptions.visibility;\n                    }\n                }\n\n                /* Special processing for the last effect call. */\n                if (callIndex === properties.calls.length - 1) {\n                    /* Append promise resolving onto the user's redirect callback. */\n                    function injectFinalCallbacks () {\n                        if ((redirectOptions.display === undefined || redirectOptions.display === \"none\") && /Out$/.test(effectName)) {\n                            $.each(elements.nodeType ? [ elements ] : elements, function(i, element) {\n                                Velocity.CSS.setPropertyValue(element, \"display\", \"none\");\n                            });\n                        }\n\n                        redirectOptions.complete && redirectOptions.complete.call(elements, elements);\n\n                        if (promiseData) {\n                            promiseData.resolver(elements || element);\n                        }\n                    }\n\n                    opts.complete = function() {\n                        if (properties.reset) {\n                            for (var resetProperty in properties.reset) {\n                                var resetValue = properties.reset[resetProperty];\n\n                                /* Format each non-array value in the reset property map to [ value, value ] so that changes apply\n                                   immediately and DOM querying is avoided (via forcefeeding). */\n                                /* Note: Don't forcefeed hooks, otherwise their hook roots will be defaulted to their null values. */\n                                if (Velocity.CSS.Hooks.registered[resetProperty] === undefined && (typeof resetValue === \"string\" || typeof resetValue === \"number\")) {\n                                    properties.reset[resetProperty] = [ properties.reset[resetProperty], properties.reset[resetProperty] ];\n                                }\n                            }\n\n                            /* So that the reset values are applied instantly upon the next rAF tick, use a zero duration and parallel queueing. */\n                            var resetOptions = { duration: 0, queue: false };\n\n                            /* Since the reset option uses up the complete callback, we trigger the user's complete callback at the end of ours. */\n                            if (finalElement) {\n                                resetOptions.complete = injectFinalCallbacks;\n                            }\n\n                            Velocity.animate(element, properties.reset, resetOptions);\n                        /* Only trigger the user's complete callback on the last effect call with the last element in the set. */\n                        } else if (finalElement) {\n                            injectFinalCallbacks();\n                        }\n                    };\n\n                    if (redirectOptions.visibility === \"hidden\") {\n                        opts.visibility = redirectOptions.visibility;\n                    }\n                }\n\n                Velocity.animate(element, propertyMap, opts);\n            }\n        };\n\n        /* Return the Velocity object so that RegisterUI calls can be chained. */\n        return Velocity;\n    };\n\n    /*********************\n       Packaged Effects\n    *********************/\n\n    /* Externalize the packagedEffects data so that they can optionally be modified and re-registered. */\n    /* Support: <=IE8: Callouts will have no effect, and transitions will simply fade in/out. IE9/Android 2.3: Most effects are fully supported, the rest fade in/out. All other browsers: full support. */\n    Velocity.RegisterEffect.packagedEffects =\n        {\n            /* Animate.css */\n            \"callout.bounce\": {\n                defaultDuration: 550,\n                calls: [\n                    [ { translateY: -30 }, 0.25 ],\n                    [ { translateY: 0 }, 0.125 ],\n                    [ { translateY: -15 }, 0.125 ],\n                    [ { translateY: 0 }, 0.25 ]\n                ]\n            },\n            /* Animate.css */\n            \"callout.shake\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { translateX: -11 }, 0.125 ],\n                    [ { translateX: 11 }, 0.125 ],\n                    [ { translateX: -11 }, 0.125 ],\n                    [ { translateX: 11 }, 0.125 ],\n                    [ { translateX: -11 }, 0.125 ],\n                    [ { translateX: 11 }, 0.125 ],\n                    [ { translateX: -11 }, 0.125 ],\n                    [ { translateX: 0 }, 0.125 ]\n                ]\n            },\n            /* Animate.css */\n            \"callout.flash\": {\n                defaultDuration: 1100,\n                calls: [\n                    [ { opacity: [ 0, \"easeInOutQuad\", 1 ] }, 0.25 ],\n                    [ { opacity: [ 1, \"easeInOutQuad\" ] }, 0.25 ],\n                    [ { opacity: [ 0, \"easeInOutQuad\" ] }, 0.25 ],\n                    [ { opacity: [ 1, \"easeInOutQuad\" ] }, 0.25 ]\n                ]\n            },\n            /* Animate.css */\n            \"callout.pulse\": {\n                defaultDuration: 825,\n                calls: [\n                    [ { scaleX: 1.1, scaleY: 1.1 }, 0.50, { easing: \"easeInExpo\" } ],\n                    [ { scaleX: 1, scaleY: 1 }, 0.50 ]\n                ]\n            },\n            /* Animate.css */\n            \"callout.swing\": {\n                defaultDuration: 950,\n                calls: [\n                    [ { rotateZ: 15 }, 0.20 ],\n                    [ { rotateZ: -10 }, 0.20 ],\n                    [ { rotateZ: 5 }, 0.20 ],\n                    [ { rotateZ: -5 }, 0.20 ],\n                    [ { rotateZ: 0 }, 0.20 ]\n                ]\n            },\n            /* Animate.css */\n            \"callout.tada\": {\n                defaultDuration: 1000,\n                calls: [\n                    [ { scaleX: 0.9, scaleY: 0.9, rotateZ: -3 }, 0.10 ],\n                    [ { scaleX: 1.1, scaleY: 1.1, rotateZ: 3 }, 0.10 ],\n                    [ { scaleX: 1.1, scaleY: 1.1, rotateZ: -3 }, 0.10 ],\n                    [ \"reverse\", 0.125 ],\n                    [ \"reverse\", 0.125 ],\n                    [ \"reverse\", 0.125 ],\n                    [ \"reverse\", 0.125 ],\n                    [ \"reverse\", 0.125 ],\n                    [ { scaleX: 1, scaleY: 1, rotateZ: 0 }, 0.20 ]\n                ]\n            },\n            \"transition.fadeIn\": {\n                defaultDuration: 500,\n                calls: [\n                    [ { opacity: [ 1, 0 ] } ]\n                ]\n            },\n            \"transition.fadeOut\": {\n                defaultDuration: 500,\n                calls: [\n                    [ { opacity: [ 0, 1 ] } ]\n                ]\n            },\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipXIn\": {\n                defaultDuration: 700,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 800, 800 ], rotateY: [ 0, -55 ] } ]\n                ],\n                reset: { transformPerspective: 0 }\n            },\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipXOut\": {\n                defaultDuration: 700,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 800, 800 ], rotateY: 55 } ]\n                ],\n                reset: { transformPerspective: 0, rotateY: 0 }\n            },\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipYIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 800, 800 ], rotateX: [ 0, -45 ] } ]\n                ],\n                reset: { transformPerspective: 0 }\n            },\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipYOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 800, 800 ], rotateX: 25 } ]\n                ],\n                reset: { transformPerspective: 0, rotateX: 0 }\n            },\n            /* Animate.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipBounceXIn\": {\n                defaultDuration: 900,\n                calls: [\n                    [ { opacity: [ 0.725, 0 ], transformPerspective: [ 400, 400 ], rotateY: [ -10, 90 ] }, 0.50 ],\n                    [ { opacity: 0.80, rotateY: 10 }, 0.25 ],\n                    [ { opacity: 1, rotateY: 0 }, 0.25 ]\n                ],\n                reset: { transformPerspective: 0 }\n            },\n            /* Animate.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipBounceXOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 0.9, 1 ], transformPerspective: [ 400, 400 ], rotateY: -10 }, 0.50 ],\n                    [ { opacity: 0, rotateY: 90 }, 0.50 ]\n                ],\n                reset: { transformPerspective: 0, rotateY: 0 }\n            },\n            /* Animate.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipBounceYIn\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 0.725, 0 ], transformPerspective: [ 400, 400 ], rotateX: [ -10, 90 ] }, 0.50 ],\n                    [ { opacity: 0.80, rotateX: 10 }, 0.25 ],\n                    [ { opacity: 1, rotateX: 0 }, 0.25 ]\n                ],\n                reset: { transformPerspective: 0 }\n            },\n            /* Animate.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.flipBounceYOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 0.9, 1 ], transformPerspective: [ 400, 400 ], rotateX: -15 }, 0.50 ],\n                    [ { opacity: 0, rotateX: 90 }, 0.50 ]\n                ],\n                reset: { transformPerspective: 0, rotateX: 0 }\n            },\n            /* Magic.css */\n            \"transition.swoopIn\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformOriginX: [ \"100%\", \"50%\" ], transformOriginY: [ \"100%\", \"100%\" ], scaleX: [ 1, 0 ], scaleY: [ 1, 0 ], translateX: [ 0, -700 ], translateZ: 0 } ]\n                ],\n                reset: { transformOriginX: \"50%\", transformOriginY: \"50%\" }\n            },\n            /* Magic.css */\n            \"transition.swoopOut\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformOriginX: [ \"50%\", \"100%\" ], transformOriginY: [ \"100%\", \"100%\" ], scaleX: 0, scaleY: 0, translateX: -700, translateZ: 0 } ]\n                ],\n                reset: { transformOriginX: \"50%\", transformOriginY: \"50%\", scaleX: 1, scaleY: 1, translateX: 0 }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3. (Fades and scales only.) */\n            \"transition.whirlIn\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: [ 1, 0 ], scaleY: [ 1, 0 ], rotateY: [ 0, 160 ] }, 1, { easing: \"easeInOutSine\" } ]\n                ]\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3. (Fades and scales only.) */\n            \"transition.whirlOut\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 0, \"easeInOutQuint\", 1 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: 0, scaleY: 0, rotateY: 160 }, 1, { easing: \"swing\" } ]\n                ],\n                reset: { scaleX: 1, scaleY: 1, rotateY: 0 }\n            },\n            \"transition.shrinkIn\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: [ 1, 1.5 ], scaleY: [ 1, 1.5 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.shrinkOut\": {\n                defaultDuration: 600,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: 1.3, scaleY: 1.3, translateZ: 0 } ]\n                ],\n                reset: { scaleX: 1, scaleY: 1 }\n            },\n            \"transition.expandIn\": {\n                defaultDuration: 700,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: [ 1, 0.625 ], scaleY: [ 1, 0.625 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.expandOut\": {\n                defaultDuration: 700,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformOriginX: [ \"50%\", \"50%\" ], transformOriginY: [ \"50%\", \"50%\" ], scaleX: 0.5, scaleY: 0.5, translateZ: 0 } ]\n                ],\n                reset: { scaleX: 1, scaleY: 1 }\n            },\n            /* Animate.css */\n            \"transition.bounceIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], scaleX: [ 1.05, 0.3 ], scaleY: [ 1.05, 0.3 ] }, 0.40 ],\n                    [ { scaleX: 0.9, scaleY: 0.9, translateZ: 0 }, 0.20 ],\n                    [ { scaleX: 1, scaleY: 1 }, 0.50 ]\n                ]\n            },\n            /* Animate.css */\n            \"transition.bounceOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { scaleX: 0.95, scaleY: 0.95 }, 0.35 ],\n                    [ { scaleX: 1.1, scaleY: 1.1, translateZ: 0 }, 0.35 ],\n                    [ { opacity: [ 0, 1 ], scaleX: 0.3, scaleY: 0.3 }, 0.30 ]\n                ],\n                reset: { scaleX: 1, scaleY: 1 }\n            },\n            /* Animate.css */\n            \"transition.bounceUpIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ -30, 1000 ] }, 0.60, { easing: \"easeOutCirc\" } ],\n                    [ { translateY: 10 }, 0.20 ],\n                    [ { translateY: 0 }, 0.20 ]\n                ]\n            },\n            /* Animate.css */\n            \"transition.bounceUpOut\": {\n                defaultDuration: 1000,\n                calls: [\n                    [ { translateY: 20 }, 0.20 ],\n                    [ { opacity: [ 0, \"easeInCirc\", 1 ], translateY: -1000 }, 0.80 ]\n                ],\n                reset: { translateY: 0 }\n            },\n            /* Animate.css */\n            \"transition.bounceDownIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ 30, -1000 ] }, 0.60, { easing: \"easeOutCirc\" } ],\n                    [ { translateY: -10 }, 0.20 ],\n                    [ { translateY: 0 }, 0.20 ]\n                ]\n            },\n            /* Animate.css */\n            \"transition.bounceDownOut\": {\n                defaultDuration: 1000,\n                calls: [\n                    [ { translateY: -20 }, 0.20 ],\n                    [ { opacity: [ 0, \"easeInCirc\", 1 ], translateY: 1000 }, 0.80 ]\n                ],\n                reset: { translateY: 0 }\n            },\n            /* Animate.css */\n            \"transition.bounceLeftIn\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ 30, -1250 ] }, 0.60, { easing: \"easeOutCirc\" } ],\n                    [ { translateX: -10 }, 0.20 ],\n                    [ { translateX: 0 }, 0.20 ]\n                ]\n            },\n            /* Animate.css */\n            \"transition.bounceLeftOut\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { translateX: 30 }, 0.20 ],\n                    [ { opacity: [ 0, \"easeInCirc\", 1 ], translateX: -1250 }, 0.80 ]\n                ],\n                reset: { translateX: 0 }\n            },\n            /* Animate.css */\n            \"transition.bounceRightIn\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ -30, 1250 ] }, 0.60, { easing: \"easeOutCirc\" } ],\n                    [ { translateX: 10 }, 0.20 ],\n                    [ { translateX: 0 }, 0.20 ]\n                ]\n            },\n            /* Animate.css */\n            \"transition.bounceRightOut\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { translateX: -30 }, 0.20 ],\n                    [ { opacity: [ 0, \"easeInCirc\", 1 ], translateX: 1250 }, 0.80 ]\n                ],\n                reset: { translateX: 0 }\n            },\n            \"transition.slideUpIn\": {\n                defaultDuration: 900,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ 0, 20 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideUpOut\": {\n                defaultDuration: 900,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateY: -20, translateZ: 0 } ]\n                ],\n                reset: { translateY: 0 }\n            },\n            \"transition.slideDownIn\": {\n                defaultDuration: 900,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ 0, -20 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideDownOut\": {\n                defaultDuration: 900,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateY: 20, translateZ: 0 } ]\n                ],\n                reset: { translateY: 0 }\n            },\n            \"transition.slideLeftIn\": {\n                defaultDuration: 1000,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ 0, -20 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideLeftOut\": {\n                defaultDuration: 1050,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateX: -20, translateZ: 0 } ]\n                ],\n                reset: { translateX: 0 }\n            },\n            \"transition.slideRightIn\": {\n                defaultDuration: 1000,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ 0, 20 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideRightOut\": {\n                defaultDuration: 1050,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateX: 20, translateZ: 0 } ]\n                ],\n                reset: { translateX: 0 }\n            },\n            \"transition.slideUpBigIn\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ 0, 75 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideUpBigOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateY: -75, translateZ: 0 } ]\n                ],\n                reset: { translateY: 0 }\n            },\n            \"transition.slideDownBigIn\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateY: [ 0, -75 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideDownBigOut\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateY: 75, translateZ: 0 } ]\n                ],\n                reset: { translateY: 0 }\n            },\n            \"transition.slideLeftBigIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ 0, -75 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideLeftBigOut\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateX: -75, translateZ: 0 } ]\n                ],\n                reset: { translateX: 0 }\n            },\n            \"transition.slideRightBigIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], translateX: [ 0, 75 ], translateZ: 0 } ]\n                ]\n            },\n            \"transition.slideRightBigOut\": {\n                defaultDuration: 750,\n                calls: [\n                    [ { opacity: [ 0, 1 ], translateX: 75, translateZ: 0 } ]\n                ],\n                reset: { translateX: 0 }\n            },\n            /* Magic.css */\n            \"transition.perspectiveUpIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 800, 800 ], transformOriginX: [ 0, 0 ], transformOriginY: [ \"100%\", \"100%\" ], rotateX: [ 0, -180 ] } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\" }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveUpOut\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 800, 800 ], transformOriginX: [ 0, 0 ], transformOriginY: [ \"100%\", \"100%\" ], rotateX: -180 } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\", rotateX: 0 }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveDownIn\": {\n                defaultDuration: 800,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 800, 800 ], transformOriginX: [ 0, 0 ], transformOriginY: [ 0, 0 ], rotateX: [ 0, 180 ] } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\" }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveDownOut\": {\n                defaultDuration: 850,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 800, 800 ], transformOriginX: [ 0, 0 ], transformOriginY: [ 0, 0 ], rotateX: 180 } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\", rotateX: 0 }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveLeftIn\": {\n                defaultDuration: 950,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 2000, 2000 ], transformOriginX: [ 0, 0 ], transformOriginY: [ 0, 0 ], rotateY: [ 0, -180 ] } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\" }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveLeftOut\": {\n                defaultDuration: 950,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 2000, 2000 ], transformOriginX: [ 0, 0 ], transformOriginY: [ 0, 0 ], rotateY: -180 } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\", rotateY: 0 }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveRightIn\": {\n                defaultDuration: 950,\n                calls: [\n                    [ { opacity: [ 1, 0 ], transformPerspective: [ 2000, 2000 ], transformOriginX: [ \"100%\", \"100%\" ], transformOriginY: [ 0, 0 ], rotateY: [ 0, 180 ] } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\" }\n            },\n            /* Magic.css */\n            /* Support: Loses rotation in IE9/Android 2.3 (fades only). */\n            \"transition.perspectiveRightOut\": {\n                defaultDuration: 950,\n                calls: [\n                    [ { opacity: [ 0, 1 ], transformPerspective: [ 2000, 2000 ], transformOriginX: [ \"100%\", \"100%\" ], transformOriginY: [ 0, 0 ], rotateY: 180 } ]\n                ],\n                reset: { transformPerspective: 0, transformOriginX: \"50%\", transformOriginY: \"50%\", rotateY: 0 }\n            }\n        };\n\n    /* Register the packaged effects. */\n    for (var effectName in Velocity.RegisterEffect.packagedEffects) {\n        Velocity.RegisterEffect(effectName, Velocity.RegisterEffect.packagedEffects[effectName]);\n    }\n\n    /*********************\n       Sequence Running\n    **********************/\n\n    /* Note: Sequence calls must use Velocity's single-object arguments syntax. */\n    Velocity.RunSequence = function (originalSequence) {\n        var sequence = $.extend(true, [], originalSequence);\n\n        if (sequence.length > 1) {\n            $.each(sequence.reverse(), function(i, currentCall) {\n                var nextCall = sequence[i + 1];\n\n                if (nextCall) {\n                    /* Parallel sequence calls (indicated via sequenceQueue:false) are triggered\n                       in the previous call's begin callback. Otherwise, chained calls are normally triggered\n                       in the previous call's complete callback. */\n                    var currentCallOptions = currentCall.o || currentCall.options,\n                        nextCallOptions = nextCall.o || nextCall.options;\n\n                    var timing = (currentCallOptions && currentCallOptions.sequenceQueue === false) ? \"begin\" : \"complete\",\n                        callbackOriginal = nextCallOptions && nextCallOptions[timing],\n                        options = {};\n\n                    options[timing] = function() {\n                        var nextCallElements = nextCall.e || nextCall.elements;\n                        var elements = nextCallElements.nodeType ? [ nextCallElements ] : nextCallElements;\n\n                        callbackOriginal && callbackOriginal.call(elements, elements);\n                        Velocity(currentCall);\n                    }\n\n                    if (nextCall.o) {\n                        nextCall.o = $.extend({}, nextCallOptions, options);\n                    } else {\n                        nextCall.options = $.extend({}, nextCallOptions, options);\n                    }\n                }\n            });\n\n            sequence.reverse();\n        }\n\n        Velocity(sequence[0]);\n    };\n}((window.jQuery || window.Zepto || window), window, document);\n}));"
  },
  {
    "path": "test/.jshintrc",
    "content": "{\n  \"curly\": true,\n  \"eqnull\": true,\n  \"eqeqeq\": true,\n  \"undef\": true,\n  \"newcap\": true,\n  \"unused\": true,\n  \"laxcomma\": false,\n  \"asi\": false,\n  \"expr\": true,\n  \"loopfunc\": false,\n  \"strict\": false,\n\n  \"globals\": {\n    \"define\": true,\n    \"require\": true,\n    \"it\": true,\n    \"module\": true,\n    \"describe\": true,\n    \"window\": true,\n    \"$\": true\n  }\n}\n"
  },
  {
    "path": "test/helpers.js",
    "content": "define([\n  'intern!object',\n  'intern/chai!assert',\n  'intern/order!source/js/helpers.js'\n], function (registerSuite, assert) {\n  registerSuite({\n    name: 'helpers',\n\n    beforeEach: function () {\n      window = {\n        navigator: {\n          userAgent: ''\n        }\n      };\n      screen = {\n        width: 0\n      };\n\n      minic = {\n        desktop: function (screenWidth) {\n          window.navigator.userAgent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.130 Safari/537.36';\n          screen.width = screenWidth || 992;\n        },\n        tablet: function (screenWidth) {\n          window.navigator.userAgent = 'Mozilla/5.0 (iPad; CPU OS 4_3_5 like Mac OS X; en-us) AppleWebKit/533.17.9 (KHTML, like Gecko) Version/5.0.2 Mobile/8L1 Safari/6533.18.5';\n          screen.width = screenWidth || 750;\n        },\n        mobile: function (screenWidth) {\n          window.navigator.userAgent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 8_0 like Mac OS X) AppleWebKit/600.1.3 (KHTML, like Gecko) Version/8.0 Mobile/12A4345d Safari/600.1.4';\n          screen.width = screenWidth || 767;\n        }\n      };\n    },\n\n    '#hasMobileUA': {\n      'should be true': function () {\n        minic.mobile();\n        assert.isTrue( hasMobileUA() );\n        minic.tablet();\n        assert.isTrue( hasMobileUA() );\n      },\n\n      'should be false': function () {\n        minic.desktop();\n        assert.isFalse( hasMobileUA() );\n      }\n    },\n\n\n    '#isDesktop': {\n      'should be true': function () {\n        minic.desktop(992);\n        assert.isTrue( isDesktop() );\n\n        minic.desktop(1200);\n        assert.isTrue( isDesktop() );\n      },\n      'should be false': function () {\n        minic.mobile();\n        assert.isFalse( isDesktop() );\n\n        minic.tablet(992);\n        assert.isFalse( isDesktop() );\n      }\n    },\n\n    '#isTablet': {\n      'should be true': function () {\n        minic.tablet(900);\n        assert.isTrue( isTablet() );\n\n        minic.tablet(780);\n        assert.isTrue( isTablet() );\n      },\n      'should be false': function () {\n        minic.desktop(500);\n        assert.isFalse( isTablet() );\n\n        minic.tablet(1000);\n        assert.isFalse( isTablet() );\n\n        minic.tablet(500);\n        assert.isFalse( isTablet() );\n      }\n    },\n\n    '#isMobile': {\n      'should be true': function () {\n        minic.mobile();\n        assert.isTrue( isMobile() );\n\n        minic.mobile(700);\n        assert.isTrue( isMobile() );\n      },\n      'should be false': function () {\n        minic.desktop();\n        assert.isFalse( isMobile() );\n\n        minic.tablet();\n        assert.isFalse( isMobile() );\n\n        minic.mobile(1000);\n        assert.isFalse( isMobile() );\n      }\n    },\n\n    '#escapeSelector': function () {\n      var selectors = ['(something', '.something', '$something'];\n      selectors.forEach(function (s) {\n        assert.equal( escapeSelector(s), '\\\\' + s );\n      });\n    },\n\n    '#displaySidebar': function () {},\n\n    '#isMist': {\n      beforeEach: function () {\n        CONFIG = {\n          scheme: ''\n        };\n      },\n      'should be true': function () {\n        CONFIG.scheme = 'Mist';\n        assert.isTrue( isMist() );\n      },\n      'should be false': function () {\n        CONFIG.scheme = 'Minimal';\n        assert.isFalse( isMist() );\n      }\n    }\n\n  });\n});\n"
  },
  {
    "path": "test/intern.js",
    "content": "// Learn more about configuring this file at <https://github.com/theintern/intern/wiki/Configuring-Intern>.\n// These default settings work OK for most people. The options that *must* be changed below are the\n// packages, suites, excludeInstrumentation, and (if you want functional tests) functionalSuites.\ndefine({\n\t// The port on which the instrumenting proxy will listen\n\tproxyPort: 9000,\n\n\t// A fully qualified URL to the Intern proxy\n\tproxyUrl: 'http://localhost:9000/',\n\n\t// Default desired capabilities for all environments. Individual capabilities can be overridden by any of the\n\t// specified browser environments in the `environments` array below as well. See\n\t// https://code.google.com/p/selenium/wiki/DesiredCapabilities for standard Selenium capabilities and\n\t// https://saucelabs.com/docs/additional-config#desired-capabilities for Sauce Labs capabilities.\n\t// Note that the `build` capability will be filled in with the current commit ID from the Travis CI environment\n\t// automatically\n\tcapabilities: {\n\t\t'selenium-version': '2.41.0'\n\t},\n\n\t// Browsers to run integration testing against. Note that version numbers must be strings if used with Sauce\n\t// OnDemand. Options that will be permutated are browserName, version, platform, and platformVersion; any other\n\t// capabilities options specified for an environment will be copied as-is\n\tenvironments: [\n\t\t{ browserName: 'internet explorer', version: '11', platform: 'Windows 8.1' },\n\t\t{ browserName: 'internet explorer', version: '10', platform: 'Windows 8' },\n\t\t{ browserName: 'internet explorer', version: '9', platform: 'Windows 7' },\n\t\t{ browserName: 'firefox', version: '28', platform: [ 'OS X 10.9', 'Windows 7', 'Linux' ] },\n\t\t{ browserName: 'chrome', version: '34', platform: [ 'OS X 10.9', 'Windows 7', 'Linux' ] },\n\t\t{ browserName: 'safari', version: '6', platform: 'OS X 10.8' },\n\t\t{ browserName: 'safari', version: '7', platform: 'OS X 10.9' }\n\t],\n\n\t// Maximum number of simultaneous integration tests that should be executed on the remote WebDriver service\n\tmaxConcurrency: 3,\n\n\t// Name of the tunnel class to use for WebDriver tests\n\ttunnel: 'SauceLabsTunnel',\n\n\t// The desired AMD loader to use when running unit tests (client.html/client.js). Omit to use the default Dojo\n\t// loader\n\tuseLoader: {\n\t\t'host-node': 'dojo/dojo',\n\t\t'host-browser': 'node_modules/dojo/dojo.js'\n\t},\n\n\t// Configuration options for the module loader; any AMD configuration options supported by the specified AMD loader\n\t// can be used here\n\tloader: {\n\t\t// Packages that should be registered with the loader in each testing environment\n\t\tpackages: [ { name: 'next', location: '.' } ]\n\t},\n\n\t// Non-functional test suite(s) to run in each browser\n\tsuites: [\n\t\t/* 'myPackage/tests/foo', 'myPackage/tests/bar' */\n\t\t'tests/helpers'\n\t],\n\n\t// Functional test suite(s) to run in each browser once non-functional tests are completed\n\tfunctionalSuites: [ /* 'myPackage/tests/functional' */ ],\n\n\t// A regular expression matching URLs to files that should not be included in code coverage analysis\n\texcludeInstrumentation: /^(?:tests|node_modules)\\//\n});\n"
  }
]