diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..c5d8f9b --- /dev/null +++ b/.gitignore @@ -0,0 +1,5 @@ +_site +.sass-cache +.jekyll-metadata +*.DS_Store +Gemfile.lock \ No newline at end of file diff --git a/404.html b/404.html new file mode 100755 index 0000000..8620e8c --- /dev/null +++ b/404.html @@ -0,0 +1,12 @@ +--- +layout: page +title: Página não encontrada +image: banner-404.jpg +permalink: /404.html +--- + +
+

404

+

A página solicitada não pôde ser encontrada.

+

Voltar para a Página inicial

+
\ No newline at end of file diff --git a/CNAME b/CNAME new file mode 100644 index 0000000..8faae29 --- /dev/null +++ b/CNAME @@ -0,0 +1 @@ +hugojunior.com \ No newline at end of file diff --git a/Gemfile b/Gemfile new file mode 100755 index 0000000..fe9882c --- /dev/null +++ b/Gemfile @@ -0,0 +1,6 @@ +source 'https://rubygems.org' +gem "bundler" +gem "jekyll" +gem "jekyll-paginate" +gem 'jekyll-tagging' +gem "jekyll-sitemap" \ No newline at end of file diff --git a/_config.yml b/_config.yml new file mode 100755 index 0000000..f39e856 --- /dev/null +++ b/_config.yml @@ -0,0 +1,36 @@ +baseurl: "" +url: "https://hugojunior.com" +timezone: America/Fortaleza + + +# Build settings +markdown: kramdown +permalink: pretty +plugins: + - jekyll-paginate + - jekyll-sitemap + - jekyll/tagging + +paginate: 5 +paginate_path: "/page/:num" + + +# Pages Path +defaults: + - scope: + path: '_pages' + values: + permalink: /:basename:output_ext + +include: + - _pages + + +# Tags +tag_page_dir: tag +tag_page_layout: tag_page +tag_permalink_style: pretty + +sass: + sass_dir: _sass + style: compressed \ No newline at end of file diff --git a/_data/settings.yml b/_data/settings.yml new file mode 100644 index 0000000..7143791 --- /dev/null +++ b/_data/settings.yml @@ -0,0 +1,33 @@ +#------------------------------- +# General Site Settings +title: Hugo Júnior +logo: logo.png +description: Um entusiasta de tecnologia, estudante, desenvolvedor e gamer, estou sempre explorando esse mundo de bits. + + +#------------------------------- +# Author Settings +author: + name: Hugo Júnior + image: banner-home.jpg + say-hello: Olá! Sou Hugo Júnior, + bio: Um entusiasta de tecnologia, estudante, desenvolvedor e gamer, estou sempre explorando esse mundo de bits. Este é o espaço onde compartilho o que me inspira. + + +#------------------------------- +# Contact links +github: https://github.com/hugojunior +linkedin: https://linkedin.com/in/hugojunior +twitter: https://twitter.com/hugojuniior +instagram: https://instagram.com/hugojunior +email: contato@hugojunior.com + + +#------------------------------- +# Comment Section (Disqus) +disqus-identifier: hugojuniior + + +#------------------------------- +# Google Analytics +google-analytics: G-WMBHW3QS2C diff --git a/_includes/article-content.html b/_includes/article-content.html new file mode 100755 index 0000000..0360ef5 --- /dev/null +++ b/_includes/article-content.html @@ -0,0 +1,47 @@ +{% assign without-image = nil %} + +
+
+ +
+ + {% if post.image %} + + + {% else %} + {% assign without-image = 'article-without-image' %} + {% endif %} + +
+ + +

+ {{post.title}} +

+ +

{% if post.description %}{{ post.description }}{% else %}{{ post.content | strip_html | truncate: 185 }}{% endif %}

+ + + +
+ +
+ +
+
+ \ No newline at end of file diff --git a/_includes/contact-link.html b/_includes/contact-link.html new file mode 100755 index 0000000..cafd7ac --- /dev/null +++ b/_includes/contact-link.html @@ -0,0 +1,23 @@ +
+ +
\ No newline at end of file diff --git a/_includes/disqus-comments.html b/_includes/disqus-comments.html new file mode 100755 index 0000000..6edb5bb --- /dev/null +++ b/_includes/disqus-comments.html @@ -0,0 +1,16 @@ + +
+
+ + +
+ \ No newline at end of file diff --git a/_includes/footer.html b/_includes/footer.html new file mode 100755 index 0000000..f1d0721 --- /dev/null +++ b/_includes/footer.html @@ -0,0 +1,10 @@ + + + diff --git a/_includes/google-analytics.html b/_includes/google-analytics.html new file mode 100755 index 0000000..a5d4f4c --- /dev/null +++ b/_includes/google-analytics.html @@ -0,0 +1,9 @@ + + + \ No newline at end of file diff --git a/_includes/head.html b/_includes/head.html new file mode 100755 index 0000000..d6dd84e --- /dev/null +++ b/_includes/head.html @@ -0,0 +1,23 @@ + + + + + + {% if page.title %}{{ page.title }}{% else %}{{ site.data.settings.title }}{% endif %} + + + + + + + + + + + + \ No newline at end of file diff --git a/_includes/header.html b/_includes/header.html new file mode 100755 index 0000000..7a96abe --- /dev/null +++ b/_includes/header.html @@ -0,0 +1,55 @@ +
+
+
+ +
+ + + + + + + +
+
+ +
+
+
\ No newline at end of file diff --git a/_includes/hero.html b/_includes/hero.html new file mode 100755 index 0000000..c3a99c3 --- /dev/null +++ b/_includes/hero.html @@ -0,0 +1,23 @@ + +
+
+
+
+
+

{{ site.data.settings.author.say-hello }}

+

{{ site.data.settings.author.bio }}

+ +
+
+
+
+ +
+
+
+
+
+ \ No newline at end of file diff --git a/_includes/javascripts.html b/_includes/javascripts.html new file mode 100755 index 0000000..3ccdaa1 --- /dev/null +++ b/_includes/javascripts.html @@ -0,0 +1,16 @@ + + + + + + + + \ No newline at end of file diff --git a/_includes/main.scss b/_includes/main.scss new file mode 100755 index 0000000..7c42916 --- /dev/null +++ b/_includes/main.scss @@ -0,0 +1,110 @@ +/* >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> +:: Template name: Zolan +:: Description: +:: Template Author: Artem Sheludko +:: Version: 1.0 +<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< */ + +/* >>>>>>>>>>>>>>>>>>>>>>>>>>> +:: 1 Tools and Libs + 1.1 Normalize + 1.2 Reset + 1.3 Shared + 1.4 Syntax Highlighting + 1.5 Grid + 1.6 Zoom + +:: 2 Base Styles + 2.1 Base + +:: 3 Modules + 3.1 Scroll Button Top + 3.2 Header + 3.3 Hero + 3.4 Search + 3.5 Contact Link + 3.6 Pagination + 3.7 Subscribe + 3.8 Instagram + 3.9 Footer + +:: 4-Layouts + 4.1 Page-home + 4.2 Page + 4.3 Article + 4.4 Post + 4.5 Tag Page +<<<<<<<<<<<<<<<<<<<<<<<<<<<< */ + + +@import '0-settings/variables'; +@import '0-settings/mixins'; +@import '0-settings/helpers'; + + +/* >>>>>>>>>>>>>> :: 1-Tools and Libs <<<<<<<<<<<<<<< */ + +// 1.1 Normalize +@import '1-tools/normalize'; + +// 1.2 Reset +@import '1-tools/reset'; + +// 1.3 Shared +@import '1-tools/shared'; + +// 1.4 Syntax Highlighting +@import '1-tools/syntax-highlighting'; + +// 1.5 Grid +@import '1-tools/grid'; + +// 1.6 Zoom +@import '1-tools/zoom'; + + +/* >>>>>>>>>>>>>> :: 2-Base Styles <<<<<<<<<<<<<<< */ + +// 2.1 Base +@import '2-base/base'; + + +/* >>>>>>>>>>>>>> :: 3-Modules <<<<<<<<<<<<<<< */ + +// 3.1 Scroll Button Top +@import '3-modules/scroll-button-top'; + +// 3.2 Header +@import '3-modules/header'; + +// 3.3 Hero +@import '3-modules/hero'; + +// 3.4 Search +@import '3-modules/search'; + +// 3.5 Contact Link +@import '3-modules/contact-link'; + +// 3.6 Pagination +@import '3-modules/pagination'; + +// 3.7 Footer +@import '3-modules/footer'; + +/* >>>>>>>>>>>>>> :: 4-Layouts <<<<<<<<<<<<<<< */ + +// 4.1 Page-home +@import '4-layouts/page-home'; + +// 4.2 Page +@import '4-layouts/page'; + +// 4.3 Article +@import '4-layouts/article'; + +// 4.4 Post +@import '4-layouts/post'; + +// 4.5 Tag Page +@import '4-layouts/tag-page'; \ No newline at end of file diff --git a/_includes/pagination.html b/_includes/pagination.html new file mode 100755 index 0000000..35976b1 --- /dev/null +++ b/_includes/pagination.html @@ -0,0 +1,44 @@ + \ No newline at end of file diff --git a/_includes/search.html b/_includes/search.html new file mode 100755 index 0000000..1fa2afe --- /dev/null +++ b/_includes/search.html @@ -0,0 +1,20 @@ + + + \ No newline at end of file diff --git a/_layouts/default.html b/_layouts/default.html new file mode 100755 index 0000000..f1419fb --- /dev/null +++ b/_layouts/default.html @@ -0,0 +1,29 @@ + + + +{% include head.html %} + + + + {% if site.data.settings.google-analytics %} + {% include google-analytics.html %} + {% endif %} + + {% include header.html %} + + +
+ {{ content }} +
+ + +
+ + {% include search.html %} + + {% include footer.html %} + + {% include javascripts.html %} + + + \ No newline at end of file diff --git a/_layouts/page.html b/_layouts/page.html new file mode 100755 index 0000000..33fd2e9 --- /dev/null +++ b/_layouts/page.html @@ -0,0 +1,31 @@ +--- +layout: default +--- +
+
+
+
+

{{ page.title | escape }}

+
+
+
+ + {% if page.image %} +
+
+
+ {% endif %} +
+ + +
+
+ +
+
+ {{ content }} +
+
+ +
+
\ No newline at end of file diff --git a/_layouts/post.html b/_layouts/post.html new file mode 100755 index 0000000..6d0b1ee --- /dev/null +++ b/_layouts/post.html @@ -0,0 +1,81 @@ +--- +layout: default +--- +
+
+
+
+ + +

{{ page.title | escape }}

+ + +
+
+
+ + {% assign no-image = nil %} + {% if page.image %} +
+
+
+ {% else %} + {% assign no-image = 'post-no-image' %} + {% endif %} + +
+ + +
+
+ +
+ +
+ {{ content }} +
+ + +
+ +
+
+ +
+ {% if site.data.settings.disqus-identifier %} {% include disqus-comments.html %} {% endif %} +
diff --git a/_layouts/tag_page.html b/_layouts/tag_page.html new file mode 100755 index 0000000..ef38eb3 --- /dev/null +++ b/_layouts/tag_page.html @@ -0,0 +1,14 @@ +--- +layout: default +--- + +
+
+

Tag: {{ page.tag }}

+
+
+ + +{% for post in page.posts %} + {% include article-content.html %} +{% endfor %} diff --git a/_pages/projetos.md b/_pages/projetos.md new file mode 100755 index 0000000..e992470 --- /dev/null +++ b/_pages/projetos.md @@ -0,0 +1,11 @@ +--- +layout: page +title: Projetos +permalink: /projetos/ +image: banner-projetos.jpg +order: 2 +--- + +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. + +*** \ No newline at end of file diff --git a/_pages/sobre-mim.md b/_pages/sobre-mim.md new file mode 100755 index 0000000..9b2a6f8 --- /dev/null +++ b/_pages/sobre-mim.md @@ -0,0 +1,11 @@ +--- +layout: page +title: Quem sou +permalink: /quem-sou/ +image: banner-sobre-mim.jpg +order: 1 +--- + +Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. + +*** \ No newline at end of file diff --git a/_posts/2024-04-18-finalmente-um-blog.md b/_posts/2024-04-18-finalmente-um-blog.md new file mode 100644 index 0000000..e8232a1 --- /dev/null +++ b/_posts/2024-04-18-finalmente-um-blog.md @@ -0,0 +1,14 @@ +--- +layout: post +title: Finalmente um Blog +date: 2024-04-17 19:00:00 -0300 +image: banner-finalmente-um-blog.jpg +tags: blog +--- +Criar um blog pessoal é algo que sempre quis fazer desde que conheci a internet, e já fiz muitos, mas sempre achava que não eram bons o suficiente e acabava nem publicando. + +No entanto, hoje, depois de ter insônia devido àquelas duas xícaras de café que tomei à tarde, fiquei pensando e resgatei essa ideia. A maior dificuldade que sempre tive em escrever sobre algo foi porque não achava que os textos estavam bons ou que estava sendo muito técnico, ou talvez não tanto. + +Mas com o avanço das tecnologias e na era da IA, tudo ficou muito fácil. Agora posso escrever do meu jeito e pedir para uma IA generativa sugerir melhorias, revisar, e assim por diante. + +Falando em IAs, esse é um assunto que pretendo abordar muito aqui, já que é algo que venho estudando e utilizando bastante, tanto para trabalho como para atividades no meu dia a dia, mas isso são assuntos para os próximos capítulos. diff --git a/_sass/0-settings/_helpers.scss b/_sass/0-settings/_helpers.scss new file mode 100755 index 0000000..555ce84 --- /dev/null +++ b/_sass/0-settings/_helpers.scss @@ -0,0 +1,89 @@ +// Text Alignment +.text-left { + text-align: left; +} + +.text-right { + text-align: right; +} + +.text-center { + text-align: center; +} + +.text-justify { + text-align: justify; +} + + +// Display +.block { + display: block; +} + +.inline-block { + display: inline-block; +} + +.inline { + display: inline; +} + + +// Vertical Center +.vertical-center { + display: flex; + align-items: center; + justify-content: center; +} + + +// Display State +.show { + display: block; +} + +.hide { + display: none; +} + +.invisible { + visibility: hidden; +} + + +// Floats +.float-left { + float: left; +} + +.float-right { + float: right; +} + + +// Padding +.no-padding { + padding: 0; +} + + +// Margins +.no-margin { + margin: 0; +} + +// Lists Reset +.list-reset { + @include list-reset(); +} + +// Clearfix +.clearfix { + @include clearfix(); +} + +// Screen Reader +.screen-reader-text { + @include screen-reader(); +} \ No newline at end of file diff --git a/_sass/0-settings/_mixins.scss b/_sass/0-settings/_mixins.scss new file mode 100755 index 0000000..9f0d7f0 --- /dev/null +++ b/_sass/0-settings/_mixins.scss @@ -0,0 +1,26 @@ +// Clearfix +@mixin clearfix() { + &::after, + ::before { + content: ""; + display: table; + clear: both; + } +} + +// Reset list +@mixin list-reset() { + list-style-type: none; + margin: 0; + padding: 0; +} + +// Screen reader text +@mixin screen-reader() { + clip: rect(1px, 1px, 1px, 1px); + height: 1px; + overflow: hidden; + position: absolute !important; + width: 1px; + word-wrap: normal !important; +} diff --git a/_sass/0-settings/_variables.scss b/_sass/0-settings/_variables.scss new file mode 100755 index 0000000..511ebf1 --- /dev/null +++ b/_sass/0-settings/_variables.scss @@ -0,0 +1,67 @@ +// ***************** +// Global Variables +// ***************** + +// Spaces +$base-spacing-unit: 20px; + +// Border radius +$global-radius: 3px; + +// Transition +$global-transition: all .35s; + + +// ***************** +// Color Variables +// ***************** +$brand-color: #f6b141; +$dark: #393e46; +$gray: #bbbbbb; +$light-gray: #e6eef0; +$white: #ffffff; +$black: #000000; + +// Background Colors +$background-color: $white; + +// Body Color +$text-color: $dark; + +// Headings +$heading-font-color: $dark; + +// Links +$link-color: $brand-color; +$link-color-hover: darken($dark, 15%); + +// Button +$button-color: $white; +$button-background-color: $brand-color; + +// Border +$border-color: $light-gray; + + +// ***************** +// Typography +// ***************** +$base-font-size: 16px; +$base-font-style: normal; +$base-font-variant: normal; +$base-font-weight: normal; +$base-font-family: 'Roboto', Helvetica Neue, Helvetica, Arial, sans-serif; +$base-line-height: 26px; + +// Headings +$heading-font-weight: 700; +$heading-font-family: 'Roboto', Helvetica Neue, Helvetica, Arial, sans-serif; + +$font-size-h1: 36px; +$font-size-h2: 28px; +$font-size-h3: 24px; +$font-size-h4: 20px; +$font-size-h5: 18px; +$font-size-h6: 16px; + +$heading-line-height: 1.2; \ No newline at end of file diff --git a/_sass/1-tools/_grid.scss b/_sass/1-tools/_grid.scss new file mode 100755 index 0000000..a5d5eab --- /dev/null +++ b/_sass/1-tools/_grid.scss @@ -0,0 +1,135 @@ +@use "sass:math"; + +$columns: 12; +$container-base-width: 1200px; +$container-offset: $base-spacing-unit; + +$desktop: 992px; +$tablet: 768px; +$mobile: 576px; + +$mq: ( $mobile:$columns, $tablet:$columns, $desktop:$columns ); + +.container { + max-width: $container-base-width; + padding-left: $container-offset; + padding-right: $container-offset; + margin: 0 auto; +} + +.container-full { + max-width: 100%; + padding-left: $container-offset; + padding-right: $container-offset; + margin: 0 auto; +} + +.row { + display: flex; + flex-wrap: wrap; + flex: 0 1 auto; + flex-direction: row; + box-sizing: border-box; + margin-left: ($base-spacing-unit * -1); + margin-right: ($base-spacing-unit * -1); +} + +.col { + padding-left: $base-spacing-unit; + padding-right: $base-spacing-unit; +} + +[class^="col-"] { + flex: auto; +} + + +@for $i from 0 through $columns { + .col-#{$i} { + width: percentage(math.div($i, $columns)); + } +} + +@for $i from 0 through $columns { + .push-#{$i} { + margin-left: percentage(math.div($i, $columns)); + } +} + +@for $i from 0 through $columns { + .pull-#{$i} { + margin-right: percentage(math.div($i, $columns)); + } +} + + +@each $key, $val in $mq { + + // DESKTOP + @media(max-width: $desktop) { + + @for $i from 0 through $columns { + .col-d-#{$i} { + width: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .push-d-#{$i} { + margin-left: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .pull-d-#{$i} { + margin-right: percentage(math.div($i, $columns)); + } + } + } + + + // TABLET + @media(max-width: $tablet) { + + @for $i from 0 through $columns { + .col-t-#{$i} { + width: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .push-t-#{$i} { + margin-left: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .pull-t-#{$i} { + margin-right: percentage(math.div($i, $columns)); + } + } + } + + // MOBILE + @media(max-width: $mobile) { + + @for $i from 0 through $columns { + .col-m-#{$i} { + width: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .push-m-#{$i} { + margin-left: percentage(math.div($i, $columns)); + } + } + + @for $i from 0 through $columns { + .pull-m-#{$i} { + margin-right: percentage(math.div($i, $columns)); + } + } + } + +} \ No newline at end of file diff --git a/_sass/1-tools/_ionicons.scss b/_sass/1-tools/_ionicons.scss new file mode 100755 index 0000000..c38efcd --- /dev/null +++ b/_sass/1-tools/_ionicons.scss @@ -0,0 +1,3513 @@ +@charset "UTF-8"; +/*! + Ionicons, v4.2.1 + Created by Ben Sperry for the Ionic Framework, http://ionicons.com/ + https://twitter.com/benjsperry https://twitter.com/ionicframework + MIT License: https://github.com/driftyco/ionicons + + Android-style icons originally built by Google’s + Material Design Icons: https://github.com/google/material-design-icons + used under CC BY http://creativecommons.org/licenses/by/4.0/ + Modified icons to fit ionicon’s grid from original. +*/ +@font-face { + font-family: "Ionicons"; + src: url("/../fonts/ionicons.eot?v=4.2.1"); + src: url("/../fonts/ionicons.eot?v=4.2.1#iefix") format("embedded-opentype"), url("/../fonts/ionicons.woff2?v=4.2.1") format("woff2"), url("/../fonts/ionicons.woff?v=4.2.1") format("woff"), url("/../fonts/ionicons.ttf?v=4.2.1") format("truetype"), url("/../fonts/ionicons.svg?v=4.2.1#Ionicons") format("svg"); + font-weight: normal; + font-style: normal; +} + +.ion, .ionicons, +.ion-ios-add:before, +.ion-ios-add-circle:before, +.ion-ios-add-circle-outline:before, +.ion-ios-airplane:before, +.ion-ios-alarm:before, +.ion-ios-albums:before, +.ion-ios-alert:before, +.ion-ios-american-football:before, +.ion-ios-analytics:before, +.ion-ios-aperture:before, +.ion-ios-apps:before, +.ion-ios-appstore:before, +.ion-ios-archive:before, +.ion-ios-arrow-back:before, +.ion-ios-arrow-down:before, +.ion-ios-arrow-dropdown:before, +.ion-ios-arrow-dropdown-circle:before, +.ion-ios-arrow-dropleft:before, +.ion-ios-arrow-dropleft-circle:before, +.ion-ios-arrow-dropright:before, +.ion-ios-arrow-dropright-circle:before, +.ion-ios-arrow-dropup:before, +.ion-ios-arrow-dropup-circle:before, +.ion-ios-arrow-forward:before, +.ion-ios-arrow-round-back:before, +.ion-ios-arrow-round-down:before, +.ion-ios-arrow-round-forward:before, +.ion-ios-arrow-round-up:before, +.ion-ios-arrow-up:before, +.ion-ios-at:before, +.ion-ios-attach:before, +.ion-ios-backspace:before, +.ion-ios-barcode:before, +.ion-ios-baseball:before, +.ion-ios-basket:before, +.ion-ios-basketball:before, +.ion-ios-battery-charging:before, +.ion-ios-battery-dead:before, +.ion-ios-battery-full:before, +.ion-ios-beaker:before, +.ion-ios-bed:before, +.ion-ios-beer:before, +.ion-ios-bicycle:before, +.ion-ios-bluetooth:before, +.ion-ios-boat:before, +.ion-ios-body:before, +.ion-ios-bonfire:before, +.ion-ios-book:before, +.ion-ios-bookmark:before, +.ion-ios-bookmarks:before, +.ion-ios-bowtie:before, +.ion-ios-briefcase:before, +.ion-ios-browsers:before, +.ion-ios-brush:before, +.ion-ios-bug:before, +.ion-ios-build:before, +.ion-ios-bulb:before, +.ion-ios-bus:before, +.ion-ios-business:before, +.ion-ios-cafe:before, +.ion-ios-calculator:before, +.ion-ios-calendar:before, +.ion-ios-call:before, +.ion-ios-camera:before, +.ion-ios-car:before, +.ion-ios-card:before, +.ion-ios-cart:before, +.ion-ios-cash:before, +.ion-ios-cellular:before, +.ion-ios-chatboxes:before, +.ion-ios-chatbubbles:before, +.ion-ios-checkbox:before, +.ion-ios-checkbox-outline:before, +.ion-ios-checkmark:before, +.ion-ios-checkmark-circle:before, +.ion-ios-checkmark-circle-outline:before, +.ion-ios-clipboard:before, +.ion-ios-clock:before, +.ion-ios-close:before, +.ion-ios-close-circle:before, +.ion-ios-close-circle-outline:before, +.ion-ios-cloud:before, +.ion-ios-cloud-circle:before, +.ion-ios-cloud-done:before, +.ion-ios-cloud-download:before, +.ion-ios-cloud-outline:before, +.ion-ios-cloud-upload:before, +.ion-ios-cloudy:before, +.ion-ios-cloudy-night:before, +.ion-ios-code:before, +.ion-ios-code-download:before, +.ion-ios-code-working:before, +.ion-ios-cog:before, +.ion-ios-color-fill:before, +.ion-ios-color-filter:before, +.ion-ios-color-palette:before, +.ion-ios-color-wand:before, +.ion-ios-compass:before, +.ion-ios-construct:before, +.ion-ios-contact:before, +.ion-ios-contacts:before, +.ion-ios-contract:before, +.ion-ios-contrast:before, +.ion-ios-copy:before, +.ion-ios-create:before, +.ion-ios-crop:before, +.ion-ios-cube:before, +.ion-ios-cut:before, +.ion-ios-desktop:before, +.ion-ios-disc:before, +.ion-ios-document:before, +.ion-ios-done-all:before, +.ion-ios-download:before, +.ion-ios-easel:before, +.ion-ios-egg:before, +.ion-ios-exit:before, +.ion-ios-expand:before, +.ion-ios-eye:before, +.ion-ios-eye-off:before, +.ion-ios-fastforward:before, +.ion-ios-female:before, +.ion-ios-filing:before, +.ion-ios-film:before, +.ion-ios-finger-print:before, +.ion-ios-fitness:before, +.ion-ios-flag:before, +.ion-ios-flame:before, +.ion-ios-flash:before, +.ion-ios-flash-off:before, +.ion-ios-flashlight:before, +.ion-ios-flask:before, +.ion-ios-flower:before, +.ion-ios-folder:before, +.ion-ios-folder-open:before, +.ion-ios-football:before, +.ion-ios-funnel:before, +.ion-ios-gift:before, +.ion-ios-git-branch:before, +.ion-ios-git-commit:before, +.ion-ios-git-compare:before, +.ion-ios-git-merge:before, +.ion-ios-git-network:before, +.ion-ios-git-pull-request:before, +.ion-ios-glasses:before, +.ion-ios-globe:before, +.ion-ios-grid:before, +.ion-ios-hammer:before, +.ion-ios-hand:before, +.ion-ios-happy:before, +.ion-ios-headset:before, +.ion-ios-heart:before, +.ion-ios-heart-dislike:before, +.ion-ios-heart-empty:before, +.ion-ios-heart-half:before, +.ion-ios-help:before, +.ion-ios-help-buoy:before, +.ion-ios-help-circle:before, +.ion-ios-help-circle-outline:before, +.ion-ios-home:before, +.ion-ios-hourglass:before, +.ion-ios-ice-cream:before, +.ion-ios-image:before, +.ion-ios-images:before, +.ion-ios-infinite:before, +.ion-ios-information:before, +.ion-ios-information-circle:before, +.ion-ios-information-circle-outline:before, +.ion-ios-jet:before, +.ion-ios-journal:before, +.ion-ios-key:before, +.ion-ios-keypad:before, +.ion-ios-laptop:before, +.ion-ios-leaf:before, +.ion-ios-link:before, +.ion-ios-list:before, +.ion-ios-list-box:before, +.ion-ios-locate:before, +.ion-ios-lock:before, +.ion-ios-log-in:before, +.ion-ios-log-out:before, +.ion-ios-magnet:before, +.ion-ios-mail:before, +.ion-ios-mail-open:before, +.ion-ios-mail-unread:before, +.ion-ios-male:before, +.ion-ios-man:before, +.ion-ios-map:before, +.ion-ios-medal:before, +.ion-ios-medical:before, +.ion-ios-medkit:before, +.ion-ios-megaphone:before, +.ion-ios-menu:before, +.ion-ios-mic:before, +.ion-ios-mic-off:before, +.ion-ios-microphone:before, +.ion-ios-moon:before, +.ion-ios-more:before, +.ion-ios-move:before, +.ion-ios-musical-note:before, +.ion-ios-musical-notes:before, +.ion-ios-navigate:before, +.ion-ios-notifications:before, +.ion-ios-notifications-off:before, +.ion-ios-notifications-outline:before, +.ion-ios-nuclear:before, +.ion-ios-nutrition:before, +.ion-ios-open:before, +.ion-ios-options:before, +.ion-ios-outlet:before, +.ion-ios-paper:before, +.ion-ios-paper-plane:before, +.ion-ios-partly-sunny:before, +.ion-ios-pause:before, +.ion-ios-paw:before, +.ion-ios-people:before, +.ion-ios-person:before, +.ion-ios-person-add:before, +.ion-ios-phone-landscape:before, +.ion-ios-phone-portrait:before, +.ion-ios-photos:before, +.ion-ios-pie:before, +.ion-ios-pin:before, +.ion-ios-pint:before, +.ion-ios-pizza:before, +.ion-ios-planet:before, +.ion-ios-play:before, +.ion-ios-play-circle:before, +.ion-ios-podium:before, +.ion-ios-power:before, +.ion-ios-pricetag:before, +.ion-ios-pricetags:before, +.ion-ios-print:before, +.ion-ios-pulse:before, +.ion-ios-qr-scanner:before, +.ion-ios-quote:before, +.ion-ios-radio:before, +.ion-ios-radio-button-off:before, +.ion-ios-radio-button-on:before, +.ion-ios-rainy:before, +.ion-ios-recording:before, +.ion-ios-redo:before, +.ion-ios-refresh:before, +.ion-ios-refresh-circle:before, +.ion-ios-remove:before, +.ion-ios-remove-circle:before, +.ion-ios-remove-circle-outline:before, +.ion-ios-reorder:before, +.ion-ios-repeat:before, +.ion-ios-resize:before, +.ion-ios-restaurant:before, +.ion-ios-return-left:before, +.ion-ios-return-right:before, +.ion-ios-reverse-camera:before, +.ion-ios-rewind:before, +.ion-ios-ribbon:before, +.ion-ios-rocket:before, +.ion-ios-rose:before, +.ion-ios-sad:before, +.ion-ios-save:before, +.ion-ios-school:before, +.ion-ios-search:before, +.ion-ios-send:before, +.ion-ios-settings:before, +.ion-ios-share:before, +.ion-ios-share-alt:before, +.ion-ios-shirt:before, +.ion-ios-shuffle:before, +.ion-ios-skip-backward:before, +.ion-ios-skip-forward:before, +.ion-ios-snow:before, +.ion-ios-speedometer:before, +.ion-ios-square:before, +.ion-ios-square-outline:before, +.ion-ios-star:before, +.ion-ios-star-half:before, +.ion-ios-star-outline:before, +.ion-ios-stats:before, +.ion-ios-stopwatch:before, +.ion-ios-subway:before, +.ion-ios-sunny:before, +.ion-ios-swap:before, +.ion-ios-switch:before, +.ion-ios-sync:before, +.ion-ios-tablet-landscape:before, +.ion-ios-tablet-portrait:before, +.ion-ios-tennisball:before, +.ion-ios-text:before, +.ion-ios-thermometer:before, +.ion-ios-thumbs-down:before, +.ion-ios-thumbs-up:before, +.ion-ios-thunderstorm:before, +.ion-ios-time:before, +.ion-ios-timer:before, +.ion-ios-today:before, +.ion-ios-train:before, +.ion-ios-transgender:before, +.ion-ios-trash:before, +.ion-ios-trending-down:before, +.ion-ios-trending-up:before, +.ion-ios-trophy:before, +.ion-ios-tv:before, +.ion-ios-umbrella:before, +.ion-ios-undo:before, +.ion-ios-unlock:before, +.ion-ios-videocam:before, +.ion-ios-volume-high:before, +.ion-ios-volume-low:before, +.ion-ios-volume-mute:before, +.ion-ios-volume-off:before, +.ion-ios-walk:before, +.ion-ios-wallet:before, +.ion-ios-warning:before, +.ion-ios-watch:before, +.ion-ios-water:before, +.ion-ios-wifi:before, +.ion-ios-wine:before, +.ion-ios-woman:before, +.ion-logo-android:before, +.ion-logo-angular:before, +.ion-logo-apple:before, +.ion-logo-bitbucket:before, +.ion-logo-bitcoin:before, +.ion-logo-buffer:before, +.ion-logo-chrome:before, +.ion-logo-closed-captioning:before, +.ion-logo-codepen:before, +.ion-logo-css3:before, +.ion-logo-designernews:before, +.ion-logo-dribbble:before, +.ion-logo-dropbox:before, +.ion-logo-euro:before, +.ion-logo-facebook:before, +.ion-logo-flickr:before, +.ion-logo-foursquare:before, +.ion-logo-freebsd-devil:before, +.ion-logo-game-controller-a:before, +.ion-logo-game-controller-b:before, +.ion-logo-github:before, +.ion-logo-google:before, +.ion-logo-googleplus:before, +.ion-logo-hackernews:before, +.ion-logo-html5:before, +.ion-logo-instagram:before, +.ion-logo-ionic:before, +.ion-logo-ionitron:before, +.ion-logo-javascript:before, +.ion-logo-linkedin:before, +.ion-logo-markdown:before, +.ion-logo-model-s:before, +.ion-logo-no-smoking:before, +.ion-logo-nodejs:before, +.ion-logo-npm:before, +.ion-logo-octocat:before, +.ion-logo-pinterest:before, +.ion-logo-playstation:before, +.ion-logo-polymer:before, +.ion-logo-python:before, +.ion-logo-reddit:before, +.ion-logo-rss:before, +.ion-logo-sass:before, +.ion-logo-skype:before, +.ion-logo-slack:before, +.ion-logo-snapchat:before, +.ion-logo-steam:before, +.ion-logo-tumblr:before, +.ion-logo-tux:before, +.ion-logo-twitch:before, +.ion-logo-twitter:before, +.ion-logo-usd:before, +.ion-logo-vimeo:before, +.ion-logo-vk:before, +.ion-logo-whatsapp:before, +.ion-logo-windows:before, +.ion-logo-wordpress:before, +.ion-logo-xbox:before, +.ion-logo-xing:before, +.ion-logo-yahoo:before, +.ion-logo-yen:before, +.ion-logo-youtube:before, +.ion-md-add:before, +.ion-md-add-circle:before, +.ion-md-add-circle-outline:before, +.ion-md-airplane:before, +.ion-md-alarm:before, +.ion-md-albums:before, +.ion-md-alert:before, +.ion-md-american-football:before, +.ion-md-analytics:before, +.ion-md-aperture:before, +.ion-md-apps:before, +.ion-md-appstore:before, +.ion-md-archive:before, +.ion-md-arrow-back:before, +.ion-md-arrow-down:before, +.ion-md-arrow-dropdown:before, +.ion-md-arrow-dropdown-circle:before, +.ion-md-arrow-dropleft:before, +.ion-md-arrow-dropleft-circle:before, +.ion-md-arrow-dropright:before, +.ion-md-arrow-dropright-circle:before, +.ion-md-arrow-dropup:before, +.ion-md-arrow-dropup-circle:before, +.ion-md-arrow-forward:before, +.ion-md-arrow-round-back:before, +.ion-md-arrow-round-down:before, +.ion-md-arrow-round-forward:before, +.ion-md-arrow-round-up:before, +.ion-md-arrow-up:before, +.ion-md-at:before, +.ion-md-attach:before, +.ion-md-backspace:before, +.ion-md-barcode:before, +.ion-md-baseball:before, +.ion-md-basket:before, +.ion-md-basketball:before, +.ion-md-battery-charging:before, +.ion-md-battery-dead:before, +.ion-md-battery-full:before, +.ion-md-beaker:before, +.ion-md-bed:before, +.ion-md-beer:before, +.ion-md-bicycle:before, +.ion-md-bluetooth:before, +.ion-md-boat:before, +.ion-md-body:before, +.ion-md-bonfire:before, +.ion-md-book:before, +.ion-md-bookmark:before, +.ion-md-bookmarks:before, +.ion-md-bowtie:before, +.ion-md-briefcase:before, +.ion-md-browsers:before, +.ion-md-brush:before, +.ion-md-bug:before, +.ion-md-build:before, +.ion-md-bulb:before, +.ion-md-bus:before, +.ion-md-business:before, +.ion-md-cafe:before, +.ion-md-calculator:before, +.ion-md-calendar:before, +.ion-md-call:before, +.ion-md-camera:before, +.ion-md-car:before, +.ion-md-card:before, +.ion-md-cart:before, +.ion-md-cash:before, +.ion-md-cellular:before, +.ion-md-chatboxes:before, +.ion-md-chatbubbles:before, +.ion-md-checkbox:before, +.ion-md-checkbox-outline:before, +.ion-md-checkmark:before, +.ion-md-checkmark-circle:before, +.ion-md-checkmark-circle-outline:before, +.ion-md-clipboard:before, +.ion-md-clock:before, +.ion-md-close:before, +.ion-md-close-circle:before, +.ion-md-close-circle-outline:before, +.ion-md-cloud:before, +.ion-md-cloud-circle:before, +.ion-md-cloud-done:before, +.ion-md-cloud-download:before, +.ion-md-cloud-outline:before, +.ion-md-cloud-upload:before, +.ion-md-cloudy:before, +.ion-md-cloudy-night:before, +.ion-md-code:before, +.ion-md-code-download:before, +.ion-md-code-working:before, +.ion-md-cog:before, +.ion-md-color-fill:before, +.ion-md-color-filter:before, +.ion-md-color-palette:before, +.ion-md-color-wand:before, +.ion-md-compass:before, +.ion-md-construct:before, +.ion-md-contact:before, +.ion-md-contacts:before, +.ion-md-contract:before, +.ion-md-contrast:before, +.ion-md-copy:before, +.ion-md-create:before, +.ion-md-crop:before, +.ion-md-cube:before, +.ion-md-cut:before, +.ion-md-desktop:before, +.ion-md-disc:before, +.ion-md-document:before, +.ion-md-done-all:before, +.ion-md-download:before, +.ion-md-easel:before, +.ion-md-egg:before, +.ion-md-exit:before, +.ion-md-expand:before, +.ion-md-eye:before, +.ion-md-eye-off:before, +.ion-md-fastforward:before, +.ion-md-female:before, +.ion-md-filing:before, +.ion-md-film:before, +.ion-md-finger-print:before, +.ion-md-fitness:before, +.ion-md-flag:before, +.ion-md-flame:before, +.ion-md-flash:before, +.ion-md-flash-off:before, +.ion-md-flashlight:before, +.ion-md-flask:before, +.ion-md-flower:before, +.ion-md-folder:before, +.ion-md-folder-open:before, +.ion-md-football:before, +.ion-md-funnel:before, +.ion-md-gift:before, +.ion-md-git-branch:before, +.ion-md-git-commit:before, +.ion-md-git-compare:before, +.ion-md-git-merge:before, +.ion-md-git-network:before, +.ion-md-git-pull-request:before, +.ion-md-glasses:before, +.ion-md-globe:before, +.ion-md-grid:before, +.ion-md-hammer:before, +.ion-md-hand:before, +.ion-md-happy:before, +.ion-md-headset:before, +.ion-md-heart:before, +.ion-md-heart-dislike:before, +.ion-md-heart-empty:before, +.ion-md-heart-half:before, +.ion-md-help:before, +.ion-md-help-buoy:before, +.ion-md-help-circle:before, +.ion-md-help-circle-outline:before, +.ion-md-home:before, +.ion-md-hourglass:before, +.ion-md-ice-cream:before, +.ion-md-image:before, +.ion-md-images:before, +.ion-md-infinite:before, +.ion-md-information:before, +.ion-md-information-circle:before, +.ion-md-information-circle-outline:before, +.ion-md-jet:before, +.ion-md-journal:before, +.ion-md-key:before, +.ion-md-keypad:before, +.ion-md-laptop:before, +.ion-md-leaf:before, +.ion-md-link:before, +.ion-md-list:before, +.ion-md-list-box:before, +.ion-md-locate:before, +.ion-md-lock:before, +.ion-md-log-in:before, +.ion-md-log-out:before, +.ion-md-magnet:before, +.ion-md-mail:before, +.ion-md-mail-open:before, +.ion-md-mail-unread:before, +.ion-md-male:before, +.ion-md-man:before, +.ion-md-map:before, +.ion-md-medal:before, +.ion-md-medical:before, +.ion-md-medkit:before, +.ion-md-megaphone:before, +.ion-md-menu:before, +.ion-md-mic:before, +.ion-md-mic-off:before, +.ion-md-microphone:before, +.ion-md-moon:before, +.ion-md-more:before, +.ion-md-move:before, +.ion-md-musical-note:before, +.ion-md-musical-notes:before, +.ion-md-navigate:before, +.ion-md-notifications:before, +.ion-md-notifications-off:before, +.ion-md-notifications-outline:before, +.ion-md-nuclear:before, +.ion-md-nutrition:before, +.ion-md-open:before, +.ion-md-options:before, +.ion-md-outlet:before, +.ion-md-paper:before, +.ion-md-paper-plane:before, +.ion-md-partly-sunny:before, +.ion-md-pause:before, +.ion-md-paw:before, +.ion-md-people:before, +.ion-md-person:before, +.ion-md-person-add:before, +.ion-md-phone-landscape:before, +.ion-md-phone-portrait:before, +.ion-md-photos:before, +.ion-md-pie:before, +.ion-md-pin:before, +.ion-md-pint:before, +.ion-md-pizza:before, +.ion-md-planet:before, +.ion-md-play:before, +.ion-md-play-circle:before, +.ion-md-podium:before, +.ion-md-power:before, +.ion-md-pricetag:before, +.ion-md-pricetags:before, +.ion-md-print:before, +.ion-md-pulse:before, +.ion-md-qr-scanner:before, +.ion-md-quote:before, +.ion-md-radio:before, +.ion-md-radio-button-off:before, +.ion-md-radio-button-on:before, +.ion-md-rainy:before, +.ion-md-recording:before, +.ion-md-redo:before, +.ion-md-refresh:before, +.ion-md-refresh-circle:before, +.ion-md-remove:before, +.ion-md-remove-circle:before, +.ion-md-remove-circle-outline:before, +.ion-md-reorder:before, +.ion-md-repeat:before, +.ion-md-resize:before, +.ion-md-restaurant:before, +.ion-md-return-left:before, +.ion-md-return-right:before, +.ion-md-reverse-camera:before, +.ion-md-rewind:before, +.ion-md-ribbon:before, +.ion-md-rocket:before, +.ion-md-rose:before, +.ion-md-sad:before, +.ion-md-save:before, +.ion-md-school:before, +.ion-md-search:before, +.ion-md-send:before, +.ion-md-settings:before, +.ion-md-share:before, +.ion-md-share-alt:before, +.ion-md-shirt:before, +.ion-md-shuffle:before, +.ion-md-skip-backward:before, +.ion-md-skip-forward:before, +.ion-md-snow:before, +.ion-md-speedometer:before, +.ion-md-square:before, +.ion-md-square-outline:before, +.ion-md-star:before, +.ion-md-star-half:before, +.ion-md-star-outline:before, +.ion-md-stats:before, +.ion-md-stopwatch:before, +.ion-md-subway:before, +.ion-md-sunny:before, +.ion-md-swap:before, +.ion-md-switch:before, +.ion-md-sync:before, +.ion-md-tablet-landscape:before, +.ion-md-tablet-portrait:before, +.ion-md-tennisball:before, +.ion-md-text:before, +.ion-md-thermometer:before, +.ion-md-thumbs-down:before, +.ion-md-thumbs-up:before, +.ion-md-thunderstorm:before, +.ion-md-time:before, +.ion-md-timer:before, +.ion-md-today:before, +.ion-md-train:before, +.ion-md-transgender:before, +.ion-md-trash:before, +.ion-md-trending-down:before, +.ion-md-trending-up:before, +.ion-md-trophy:before, +.ion-md-tv:before, +.ion-md-umbrella:before, +.ion-md-undo:before, +.ion-md-unlock:before, +.ion-md-videocam:before, +.ion-md-volume-high:before, +.ion-md-volume-low:before, +.ion-md-volume-mute:before, +.ion-md-volume-off:before, +.ion-md-walk:before, +.ion-md-wallet:before, +.ion-md-warning:before, +.ion-md-watch:before, +.ion-md-water:before, +.ion-md-wifi:before, +.ion-md-wine:before, +.ion-md-woman:before { + display: inline-block; + font-family: "Ionicons"; + speak: none; + font-style: normal; + font-weight: normal; + font-variant: normal; + text-transform: none; + text-rendering: auto; + line-height: 1; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +.ion-ios-add:before { + content: "\f102"; +} + +.ion-ios-add-circle:before { + content: "\f101"; +} + +.ion-ios-add-circle-outline:before { + content: "\f100"; +} + +.ion-ios-airplane:before { + content: "\f137"; +} + +.ion-ios-alarm:before { + content: "\f3c8"; +} + +.ion-ios-albums:before { + content: "\f3ca"; +} + +.ion-ios-alert:before { + content: "\f104"; +} + +.ion-ios-american-football:before { + content: "\f106"; +} + +.ion-ios-analytics:before { + content: "\f3ce"; +} + +.ion-ios-aperture:before { + content: "\f108"; +} + +.ion-ios-apps:before { + content: "\f10a"; +} + +.ion-ios-appstore:before { + content: "\f10c"; +} + +.ion-ios-archive:before { + content: "\f10e"; +} + +.ion-ios-arrow-back:before { + content: "\f3cf"; +} + +.ion-ios-arrow-down:before { + content: "\f3d0"; +} + +.ion-ios-arrow-dropdown:before { + content: "\f110"; +} + +.ion-ios-arrow-dropdown-circle:before { + content: "\f125"; +} + +.ion-ios-arrow-dropleft:before { + content: "\f112"; +} + +.ion-ios-arrow-dropleft-circle:before { + content: "\f129"; +} + +.ion-ios-arrow-dropright:before { + content: "\f114"; +} + +.ion-ios-arrow-dropright-circle:before { + content: "\f12b"; +} + +.ion-ios-arrow-dropup:before { + content: "\f116"; +} + +.ion-ios-arrow-dropup-circle:before { + content: "\f12d"; +} + +.ion-ios-arrow-forward:before { + content: "\f3d1"; +} + +.ion-ios-arrow-round-back:before { + content: "\f117"; +} + +.ion-ios-arrow-round-down:before { + content: "\f118"; +} + +.ion-ios-arrow-round-forward:before { + content: "\f119"; +} + +.ion-ios-arrow-round-up:before { + content: "\f11a"; +} + +.ion-ios-arrow-up:before { + content: "\f3d8"; +} + +.ion-ios-at:before { + content: "\f3da"; +} + +.ion-ios-attach:before { + content: "\f11b"; +} + +.ion-ios-backspace:before { + content: "\f11d"; +} + +.ion-ios-barcode:before { + content: "\f3dc"; +} + +.ion-ios-baseball:before { + content: "\f3de"; +} + +.ion-ios-basket:before { + content: "\f11f"; +} + +.ion-ios-basketball:before { + content: "\f3e0"; +} + +.ion-ios-battery-charging:before { + content: "\f120"; +} + +.ion-ios-battery-dead:before { + content: "\f121"; +} + +.ion-ios-battery-full:before { + content: "\f122"; +} + +.ion-ios-beaker:before { + content: "\f124"; +} + +.ion-ios-bed:before { + content: "\f139"; +} + +.ion-ios-beer:before { + content: "\f126"; +} + +.ion-ios-bicycle:before { + content: "\f127"; +} + +.ion-ios-bluetooth:before { + content: "\f128"; +} + +.ion-ios-boat:before { + content: "\f12a"; +} + +.ion-ios-body:before { + content: "\f3e4"; +} + +.ion-ios-bonfire:before { + content: "\f12c"; +} + +.ion-ios-book:before { + content: "\f3e8"; +} + +.ion-ios-bookmark:before { + content: "\f12e"; +} + +.ion-ios-bookmarks:before { + content: "\f3ea"; +} + +.ion-ios-bowtie:before { + content: "\f130"; +} + +.ion-ios-briefcase:before { + content: "\f3ee"; +} + +.ion-ios-browsers:before { + content: "\f3f0"; +} + +.ion-ios-brush:before { + content: "\f132"; +} + +.ion-ios-bug:before { + content: "\f134"; +} + +.ion-ios-build:before { + content: "\f136"; +} + +.ion-ios-bulb:before { + content: "\f138"; +} + +.ion-ios-bus:before { + content: "\f13a"; +} + +.ion-ios-business:before { + content: "\f1a3"; +} + +.ion-ios-cafe:before { + content: "\f13c"; +} + +.ion-ios-calculator:before { + content: "\f3f2"; +} + +.ion-ios-calendar:before { + content: "\f3f4"; +} + +.ion-ios-call:before { + content: "\f13e"; +} + +.ion-ios-camera:before { + content: "\f3f6"; +} + +.ion-ios-car:before { + content: "\f140"; +} + +.ion-ios-card:before { + content: "\f142"; +} + +.ion-ios-cart:before { + content: "\f3f8"; +} + +.ion-ios-cash:before { + content: "\f144"; +} + +.ion-ios-cellular:before { + content: "\f13d"; +} + +.ion-ios-chatboxes:before { + content: "\f3fa"; +} + +.ion-ios-chatbubbles:before { + content: "\f146"; +} + +.ion-ios-checkbox:before { + content: "\f148"; +} + +.ion-ios-checkbox-outline:before { + content: "\f147"; +} + +.ion-ios-checkmark:before { + content: "\f3ff"; +} + +.ion-ios-checkmark-circle:before { + content: "\f14a"; +} + +.ion-ios-checkmark-circle-outline:before { + content: "\f149"; +} + +.ion-ios-clipboard:before { + content: "\f14c"; +} + +.ion-ios-clock:before { + content: "\f403"; +} + +.ion-ios-close:before { + content: "\f406"; +} + +.ion-ios-close-circle:before { + content: "\f14e"; +} + +.ion-ios-close-circle-outline:before { + content: "\f14d"; +} + +.ion-ios-cloud:before { + content: "\f40c"; +} + +.ion-ios-cloud-circle:before { + content: "\f152"; +} + +.ion-ios-cloud-done:before { + content: "\f154"; +} + +.ion-ios-cloud-download:before { + content: "\f408"; +} + +.ion-ios-cloud-outline:before { + content: "\f409"; +} + +.ion-ios-cloud-upload:before { + content: "\f40b"; +} + +.ion-ios-cloudy:before { + content: "\f410"; +} + +.ion-ios-cloudy-night:before { + content: "\f40e"; +} + +.ion-ios-code:before { + content: "\f157"; +} + +.ion-ios-code-download:before { + content: "\f155"; +} + +.ion-ios-code-working:before { + content: "\f156"; +} + +.ion-ios-cog:before { + content: "\f412"; +} + +.ion-ios-color-fill:before { + content: "\f159"; +} + +.ion-ios-color-filter:before { + content: "\f414"; +} + +.ion-ios-color-palette:before { + content: "\f15b"; +} + +.ion-ios-color-wand:before { + content: "\f416"; +} + +.ion-ios-compass:before { + content: "\f15d"; +} + +.ion-ios-construct:before { + content: "\f15f"; +} + +.ion-ios-contact:before { + content: "\f41a"; +} + +.ion-ios-contacts:before { + content: "\f161"; +} + +.ion-ios-contract:before { + content: "\f162"; +} + +.ion-ios-contrast:before { + content: "\f163"; +} + +.ion-ios-copy:before { + content: "\f41c"; +} + +.ion-ios-create:before { + content: "\f165"; +} + +.ion-ios-crop:before { + content: "\f41e"; +} + +.ion-ios-cube:before { + content: "\f168"; +} + +.ion-ios-cut:before { + content: "\f16a"; +} + +.ion-ios-desktop:before { + content: "\f16c"; +} + +.ion-ios-disc:before { + content: "\f16e"; +} + +.ion-ios-document:before { + content: "\f170"; +} + +.ion-ios-done-all:before { + content: "\f171"; +} + +.ion-ios-download:before { + content: "\f420"; +} + +.ion-ios-easel:before { + content: "\f173"; +} + +.ion-ios-egg:before { + content: "\f175"; +} + +.ion-ios-exit:before { + content: "\f177"; +} + +.ion-ios-expand:before { + content: "\f178"; +} + +.ion-ios-eye:before { + content: "\f425"; +} + +.ion-ios-eye-off:before { + content: "\f17a"; +} + +.ion-ios-fastforward:before { + content: "\f427"; +} + +.ion-ios-female:before { + content: "\f17b"; +} + +.ion-ios-filing:before { + content: "\f429"; +} + +.ion-ios-film:before { + content: "\f42b"; +} + +.ion-ios-finger-print:before { + content: "\f17c"; +} + +.ion-ios-fitness:before { + content: "\f1ab"; +} + +.ion-ios-flag:before { + content: "\f42d"; +} + +.ion-ios-flame:before { + content: "\f42f"; +} + +.ion-ios-flash:before { + content: "\f17e"; +} + +.ion-ios-flash-off:before { + content: "\f12f"; +} + +.ion-ios-flashlight:before { + content: "\f141"; +} + +.ion-ios-flask:before { + content: "\f431"; +} + +.ion-ios-flower:before { + content: "\f433"; +} + +.ion-ios-folder:before { + content: "\f435"; +} + +.ion-ios-folder-open:before { + content: "\f180"; +} + +.ion-ios-football:before { + content: "\f437"; +} + +.ion-ios-funnel:before { + content: "\f182"; +} + +.ion-ios-gift:before { + content: "\f191"; +} + +.ion-ios-git-branch:before { + content: "\f183"; +} + +.ion-ios-git-commit:before { + content: "\f184"; +} + +.ion-ios-git-compare:before { + content: "\f185"; +} + +.ion-ios-git-merge:before { + content: "\f186"; +} + +.ion-ios-git-network:before { + content: "\f187"; +} + +.ion-ios-git-pull-request:before { + content: "\f188"; +} + +.ion-ios-glasses:before { + content: "\f43f"; +} + +.ion-ios-globe:before { + content: "\f18a"; +} + +.ion-ios-grid:before { + content: "\f18c"; +} + +.ion-ios-hammer:before { + content: "\f18e"; +} + +.ion-ios-hand:before { + content: "\f190"; +} + +.ion-ios-happy:before { + content: "\f192"; +} + +.ion-ios-headset:before { + content: "\f194"; +} + +.ion-ios-heart:before { + content: "\f443"; +} + +.ion-ios-heart-dislike:before { + content: "\f13f"; +} + +.ion-ios-heart-empty:before { + content: "\f19b"; +} + +.ion-ios-heart-half:before { + content: "\f19d"; +} + +.ion-ios-help:before { + content: "\f446"; +} + +.ion-ios-help-buoy:before { + content: "\f196"; +} + +.ion-ios-help-circle:before { + content: "\f198"; +} + +.ion-ios-help-circle-outline:before { + content: "\f197"; +} + +.ion-ios-home:before { + content: "\f448"; +} + +.ion-ios-hourglass:before { + content: "\f103"; +} + +.ion-ios-ice-cream:before { + content: "\f19a"; +} + +.ion-ios-image:before { + content: "\f19c"; +} + +.ion-ios-images:before { + content: "\f19e"; +} + +.ion-ios-infinite:before { + content: "\f44a"; +} + +.ion-ios-information:before { + content: "\f44d"; +} + +.ion-ios-information-circle:before { + content: "\f1a0"; +} + +.ion-ios-information-circle-outline:before { + content: "\f19f"; +} + +.ion-ios-jet:before { + content: "\f1a5"; +} + +.ion-ios-journal:before { + content: "\f189"; +} + +.ion-ios-key:before { + content: "\f1a7"; +} + +.ion-ios-keypad:before { + content: "\f450"; +} + +.ion-ios-laptop:before { + content: "\f1a8"; +} + +.ion-ios-leaf:before { + content: "\f1aa"; +} + +.ion-ios-link:before { + content: "\f22a"; +} + +.ion-ios-list:before { + content: "\f454"; +} + +.ion-ios-list-box:before { + content: "\f143"; +} + +.ion-ios-locate:before { + content: "\f1ae"; +} + +.ion-ios-lock:before { + content: "\f1b0"; +} + +.ion-ios-log-in:before { + content: "\f1b1"; +} + +.ion-ios-log-out:before { + content: "\f1b2"; +} + +.ion-ios-magnet:before { + content: "\f1b4"; +} + +.ion-ios-mail:before { + content: "\f1b8"; +} + +.ion-ios-mail-open:before { + content: "\f1b6"; +} + +.ion-ios-mail-unread:before { + content: "\f145"; +} + +.ion-ios-male:before { + content: "\f1b9"; +} + +.ion-ios-man:before { + content: "\f1bb"; +} + +.ion-ios-map:before { + content: "\f1bd"; +} + +.ion-ios-medal:before { + content: "\f1bf"; +} + +.ion-ios-medical:before { + content: "\f45c"; +} + +.ion-ios-medkit:before { + content: "\f45e"; +} + +.ion-ios-megaphone:before { + content: "\f1c1"; +} + +.ion-ios-menu:before { + content: "\f1c3"; +} + +.ion-ios-mic:before { + content: "\f461"; +} + +.ion-ios-mic-off:before { + content: "\f45f"; +} + +.ion-ios-microphone:before { + content: "\f1c6"; +} + +.ion-ios-moon:before { + content: "\f468"; +} + +.ion-ios-more:before { + content: "\f1c8"; +} + +.ion-ios-move:before { + content: "\f1cb"; +} + +.ion-ios-musical-note:before { + content: "\f46b"; +} + +.ion-ios-musical-notes:before { + content: "\f46c"; +} + +.ion-ios-navigate:before { + content: "\f46e"; +} + +.ion-ios-notifications:before { + content: "\f1d3"; +} + +.ion-ios-notifications-off:before { + content: "\f1d1"; +} + +.ion-ios-notifications-outline:before { + content: "\f133"; +} + +.ion-ios-nuclear:before { + content: "\f1d5"; +} + +.ion-ios-nutrition:before { + content: "\f470"; +} + +.ion-ios-open:before { + content: "\f1d7"; +} + +.ion-ios-options:before { + content: "\f1d9"; +} + +.ion-ios-outlet:before { + content: "\f1db"; +} + +.ion-ios-paper:before { + content: "\f472"; +} + +.ion-ios-paper-plane:before { + content: "\f1dd"; +} + +.ion-ios-partly-sunny:before { + content: "\f1df"; +} + +.ion-ios-pause:before { + content: "\f478"; +} + +.ion-ios-paw:before { + content: "\f47a"; +} + +.ion-ios-people:before { + content: "\f47c"; +} + +.ion-ios-person:before { + content: "\f47e"; +} + +.ion-ios-person-add:before { + content: "\f1e1"; +} + +.ion-ios-phone-landscape:before { + content: "\f1e2"; +} + +.ion-ios-phone-portrait:before { + content: "\f1e3"; +} + +.ion-ios-photos:before { + content: "\f482"; +} + +.ion-ios-pie:before { + content: "\f484"; +} + +.ion-ios-pin:before { + content: "\f1e5"; +} + +.ion-ios-pint:before { + content: "\f486"; +} + +.ion-ios-pizza:before { + content: "\f1e7"; +} + +.ion-ios-planet:before { + content: "\f1eb"; +} + +.ion-ios-play:before { + content: "\f488"; +} + +.ion-ios-play-circle:before { + content: "\f113"; +} + +.ion-ios-podium:before { + content: "\f1ed"; +} + +.ion-ios-power:before { + content: "\f1ef"; +} + +.ion-ios-pricetag:before { + content: "\f48d"; +} + +.ion-ios-pricetags:before { + content: "\f48f"; +} + +.ion-ios-print:before { + content: "\f1f1"; +} + +.ion-ios-pulse:before { + content: "\f493"; +} + +.ion-ios-qr-scanner:before { + content: "\f1f3"; +} + +.ion-ios-quote:before { + content: "\f1f5"; +} + +.ion-ios-radio:before { + content: "\f1f9"; +} + +.ion-ios-radio-button-off:before { + content: "\f1f6"; +} + +.ion-ios-radio-button-on:before { + content: "\f1f7"; +} + +.ion-ios-rainy:before { + content: "\f495"; +} + +.ion-ios-recording:before { + content: "\f497"; +} + +.ion-ios-redo:before { + content: "\f499"; +} + +.ion-ios-refresh:before { + content: "\f49c"; +} + +.ion-ios-refresh-circle:before { + content: "\f135"; +} + +.ion-ios-remove:before { + content: "\f1fc"; +} + +.ion-ios-remove-circle:before { + content: "\f1fb"; +} + +.ion-ios-remove-circle-outline:before { + content: "\f1fa"; +} + +.ion-ios-reorder:before { + content: "\f1fd"; +} + +.ion-ios-repeat:before { + content: "\f1fe"; +} + +.ion-ios-resize:before { + content: "\f1ff"; +} + +.ion-ios-restaurant:before { + content: "\f201"; +} + +.ion-ios-return-left:before { + content: "\f202"; +} + +.ion-ios-return-right:before { + content: "\f203"; +} + +.ion-ios-reverse-camera:before { + content: "\f49f"; +} + +.ion-ios-rewind:before { + content: "\f4a1"; +} + +.ion-ios-ribbon:before { + content: "\f205"; +} + +.ion-ios-rocket:before { + content: "\f14b"; +} + +.ion-ios-rose:before { + content: "\f4a3"; +} + +.ion-ios-sad:before { + content: "\f207"; +} + +.ion-ios-save:before { + content: "\f1a6"; +} + +.ion-ios-school:before { + content: "\f209"; +} + +.ion-ios-search:before { + content: "\f4a5"; +} + +.ion-ios-send:before { + content: "\f20c"; +} + +.ion-ios-settings:before { + content: "\f4a7"; +} + +.ion-ios-share:before { + content: "\f211"; +} + +.ion-ios-share-alt:before { + content: "\f20f"; +} + +.ion-ios-shirt:before { + content: "\f213"; +} + +.ion-ios-shuffle:before { + content: "\f4a9"; +} + +.ion-ios-skip-backward:before { + content: "\f215"; +} + +.ion-ios-skip-forward:before { + content: "\f217"; +} + +.ion-ios-snow:before { + content: "\f218"; +} + +.ion-ios-speedometer:before { + content: "\f4b0"; +} + +.ion-ios-square:before { + content: "\f21a"; +} + +.ion-ios-square-outline:before { + content: "\f15c"; +} + +.ion-ios-star:before { + content: "\f4b3"; +} + +.ion-ios-star-half:before { + content: "\f4b1"; +} + +.ion-ios-star-outline:before { + content: "\f4b2"; +} + +.ion-ios-stats:before { + content: "\f21c"; +} + +.ion-ios-stopwatch:before { + content: "\f4b5"; +} + +.ion-ios-subway:before { + content: "\f21e"; +} + +.ion-ios-sunny:before { + content: "\f4b7"; +} + +.ion-ios-swap:before { + content: "\f21f"; +} + +.ion-ios-switch:before { + content: "\f221"; +} + +.ion-ios-sync:before { + content: "\f222"; +} + +.ion-ios-tablet-landscape:before { + content: "\f223"; +} + +.ion-ios-tablet-portrait:before { + content: "\f24e"; +} + +.ion-ios-tennisball:before { + content: "\f4bb"; +} + +.ion-ios-text:before { + content: "\f250"; +} + +.ion-ios-thermometer:before { + content: "\f252"; +} + +.ion-ios-thumbs-down:before { + content: "\f254"; +} + +.ion-ios-thumbs-up:before { + content: "\f256"; +} + +.ion-ios-thunderstorm:before { + content: "\f4bd"; +} + +.ion-ios-time:before { + content: "\f4bf"; +} + +.ion-ios-timer:before { + content: "\f4c1"; +} + +.ion-ios-today:before { + content: "\f14f"; +} + +.ion-ios-train:before { + content: "\f258"; +} + +.ion-ios-transgender:before { + content: "\f259"; +} + +.ion-ios-trash:before { + content: "\f4c5"; +} + +.ion-ios-trending-down:before { + content: "\f25a"; +} + +.ion-ios-trending-up:before { + content: "\f25b"; +} + +.ion-ios-trophy:before { + content: "\f25d"; +} + +.ion-ios-tv:before { + content: "\f115"; +} + +.ion-ios-umbrella:before { + content: "\f25f"; +} + +.ion-ios-undo:before { + content: "\f4c7"; +} + +.ion-ios-unlock:before { + content: "\f261"; +} + +.ion-ios-videocam:before { + content: "\f4cd"; +} + +.ion-ios-volume-high:before { + content: "\f11c"; +} + +.ion-ios-volume-low:before { + content: "\f11e"; +} + +.ion-ios-volume-mute:before { + content: "\f263"; +} + +.ion-ios-volume-off:before { + content: "\f264"; +} + +.ion-ios-walk:before { + content: "\f266"; +} + +.ion-ios-wallet:before { + content: "\f18b"; +} + +.ion-ios-warning:before { + content: "\f268"; +} + +.ion-ios-watch:before { + content: "\f269"; +} + +.ion-ios-water:before { + content: "\f26b"; +} + +.ion-ios-wifi:before { + content: "\f26d"; +} + +.ion-ios-wine:before { + content: "\f26f"; +} + +.ion-ios-woman:before { + content: "\f271"; +} + +.ion-logo-android:before { + content: "\f225"; +} + +.ion-logo-angular:before { + content: "\f227"; +} + +.ion-logo-apple:before { + content: "\f229"; +} + +.ion-logo-bitbucket:before { + content: "\f193"; +} + +.ion-logo-bitcoin:before { + content: "\f22b"; +} + +.ion-logo-buffer:before { + content: "\f22d"; +} + +.ion-logo-chrome:before { + content: "\f22f"; +} + +.ion-logo-closed-captioning:before { + content: "\f105"; +} + +.ion-logo-codepen:before { + content: "\f230"; +} + +.ion-logo-css3:before { + content: "\f231"; +} + +.ion-logo-designernews:before { + content: "\f232"; +} + +.ion-logo-dribbble:before { + content: "\f233"; +} + +.ion-logo-dropbox:before { + content: "\f234"; +} + +.ion-logo-euro:before { + content: "\f235"; +} + +.ion-logo-facebook:before { + content: "\f236"; +} + +.ion-logo-flickr:before { + content: "\f107"; +} + +.ion-logo-foursquare:before { + content: "\f237"; +} + +.ion-logo-freebsd-devil:before { + content: "\f238"; +} + +.ion-logo-game-controller-a:before { + content: "\f13b"; +} + +.ion-logo-game-controller-b:before { + content: "\f181"; +} + +.ion-logo-github:before { + content: "\f239"; +} + +.ion-logo-google:before { + content: "\f23a"; +} + +.ion-logo-googleplus:before { + content: "\f23b"; +} + +.ion-logo-hackernews:before { + content: "\f23c"; +} + +.ion-logo-html5:before { + content: "\f23d"; +} + +.ion-logo-instagram:before { + content: "\f23e"; +} + +.ion-logo-ionic:before { + content: "\f150"; +} + +.ion-logo-ionitron:before { + content: "\f151"; +} + +.ion-logo-javascript:before { + content: "\f23f"; +} + +.ion-logo-linkedin:before { + content: "\f240"; +} + +.ion-logo-markdown:before { + content: "\f241"; +} + +.ion-logo-model-s:before { + content: "\f153"; +} + +.ion-logo-no-smoking:before { + content: "\f109"; +} + +.ion-logo-nodejs:before { + content: "\f242"; +} + +.ion-logo-npm:before { + content: "\f195"; +} + +.ion-logo-octocat:before { + content: "\f243"; +} + +.ion-logo-pinterest:before { + content: "\f244"; +} + +.ion-logo-playstation:before { + content: "\f245"; +} + +.ion-logo-polymer:before { + content: "\f15e"; +} + +.ion-logo-python:before { + content: "\f246"; +} + +.ion-logo-reddit:before { + content: "\f247"; +} + +.ion-logo-rss:before { + content: "\f248"; +} + +.ion-logo-sass:before { + content: "\f249"; +} + +.ion-logo-skype:before { + content: "\f24a"; +} + +.ion-logo-slack:before { + content: "\f10b"; +} + +.ion-logo-snapchat:before { + content: "\f24b"; +} + +.ion-logo-steam:before { + content: "\f24c"; +} + +.ion-logo-tumblr:before { + content: "\f24d"; +} + +.ion-logo-tux:before { + content: "\f2ae"; +} + +.ion-logo-twitch:before { + content: "\f2af"; +} + +.ion-logo-twitter:before { + content: "\f2b0"; +} + +.ion-logo-usd:before { + content: "\f2b1"; +} + +.ion-logo-vimeo:before { + content: "\f2c4"; +} + +.ion-logo-vk:before { + content: "\f10d"; +} + +.ion-logo-whatsapp:before { + content: "\f2c5"; +} + +.ion-logo-windows:before { + content: "\f32f"; +} + +.ion-logo-wordpress:before { + content: "\f330"; +} + +.ion-logo-xbox:before { + content: "\f34c"; +} + +.ion-logo-xing:before { + content: "\f10f"; +} + +.ion-logo-yahoo:before { + content: "\f34d"; +} + +.ion-logo-yen:before { + content: "\f34e"; +} + +.ion-logo-youtube:before { + content: "\f34f"; +} + +.ion-md-add:before { + content: "\f273"; +} + +.ion-md-add-circle:before { + content: "\f272"; +} + +.ion-md-add-circle-outline:before { + content: "\f158"; +} + +.ion-md-airplane:before { + content: "\f15a"; +} + +.ion-md-alarm:before { + content: "\f274"; +} + +.ion-md-albums:before { + content: "\f275"; +} + +.ion-md-alert:before { + content: "\f276"; +} + +.ion-md-american-football:before { + content: "\f277"; +} + +.ion-md-analytics:before { + content: "\f278"; +} + +.ion-md-aperture:before { + content: "\f279"; +} + +.ion-md-apps:before { + content: "\f27a"; +} + +.ion-md-appstore:before { + content: "\f27b"; +} + +.ion-md-archive:before { + content: "\f27c"; +} + +.ion-md-arrow-back:before { + content: "\f27d"; +} + +.ion-md-arrow-down:before { + content: "\f27e"; +} + +.ion-md-arrow-dropdown:before { + content: "\f280"; +} + +.ion-md-arrow-dropdown-circle:before { + content: "\f27f"; +} + +.ion-md-arrow-dropleft:before { + content: "\f282"; +} + +.ion-md-arrow-dropleft-circle:before { + content: "\f281"; +} + +.ion-md-arrow-dropright:before { + content: "\f284"; +} + +.ion-md-arrow-dropright-circle:before { + content: "\f283"; +} + +.ion-md-arrow-dropup:before { + content: "\f286"; +} + +.ion-md-arrow-dropup-circle:before { + content: "\f285"; +} + +.ion-md-arrow-forward:before { + content: "\f287"; +} + +.ion-md-arrow-round-back:before { + content: "\f288"; +} + +.ion-md-arrow-round-down:before { + content: "\f289"; +} + +.ion-md-arrow-round-forward:before { + content: "\f28a"; +} + +.ion-md-arrow-round-up:before { + content: "\f28b"; +} + +.ion-md-arrow-up:before { + content: "\f28c"; +} + +.ion-md-at:before { + content: "\f28d"; +} + +.ion-md-attach:before { + content: "\f28e"; +} + +.ion-md-backspace:before { + content: "\f28f"; +} + +.ion-md-barcode:before { + content: "\f290"; +} + +.ion-md-baseball:before { + content: "\f291"; +} + +.ion-md-basket:before { + content: "\f292"; +} + +.ion-md-basketball:before { + content: "\f293"; +} + +.ion-md-battery-charging:before { + content: "\f294"; +} + +.ion-md-battery-dead:before { + content: "\f295"; +} + +.ion-md-battery-full:before { + content: "\f296"; +} + +.ion-md-beaker:before { + content: "\f297"; +} + +.ion-md-bed:before { + content: "\f160"; +} + +.ion-md-beer:before { + content: "\f298"; +} + +.ion-md-bicycle:before { + content: "\f299"; +} + +.ion-md-bluetooth:before { + content: "\f29a"; +} + +.ion-md-boat:before { + content: "\f29b"; +} + +.ion-md-body:before { + content: "\f29c"; +} + +.ion-md-bonfire:before { + content: "\f29d"; +} + +.ion-md-book:before { + content: "\f29e"; +} + +.ion-md-bookmark:before { + content: "\f29f"; +} + +.ion-md-bookmarks:before { + content: "\f2a0"; +} + +.ion-md-bowtie:before { + content: "\f2a1"; +} + +.ion-md-briefcase:before { + content: "\f2a2"; +} + +.ion-md-browsers:before { + content: "\f2a3"; +} + +.ion-md-brush:before { + content: "\f2a4"; +} + +.ion-md-bug:before { + content: "\f2a5"; +} + +.ion-md-build:before { + content: "\f2a6"; +} + +.ion-md-bulb:before { + content: "\f2a7"; +} + +.ion-md-bus:before { + content: "\f2a8"; +} + +.ion-md-business:before { + content: "\f1a4"; +} + +.ion-md-cafe:before { + content: "\f2a9"; +} + +.ion-md-calculator:before { + content: "\f2aa"; +} + +.ion-md-calendar:before { + content: "\f2ab"; +} + +.ion-md-call:before { + content: "\f2ac"; +} + +.ion-md-camera:before { + content: "\f2ad"; +} + +.ion-md-car:before { + content: "\f2b2"; +} + +.ion-md-card:before { + content: "\f2b3"; +} + +.ion-md-cart:before { + content: "\f2b4"; +} + +.ion-md-cash:before { + content: "\f2b5"; +} + +.ion-md-cellular:before { + content: "\f164"; +} + +.ion-md-chatboxes:before { + content: "\f2b6"; +} + +.ion-md-chatbubbles:before { + content: "\f2b7"; +} + +.ion-md-checkbox:before { + content: "\f2b9"; +} + +.ion-md-checkbox-outline:before { + content: "\f2b8"; +} + +.ion-md-checkmark:before { + content: "\f2bc"; +} + +.ion-md-checkmark-circle:before { + content: "\f2bb"; +} + +.ion-md-checkmark-circle-outline:before { + content: "\f2ba"; +} + +.ion-md-clipboard:before { + content: "\f2bd"; +} + +.ion-md-clock:before { + content: "\f2be"; +} + +.ion-md-close:before { + content: "\f2c0"; +} + +.ion-md-close-circle:before { + content: "\f2bf"; +} + +.ion-md-close-circle-outline:before { + content: "\f166"; +} + +.ion-md-cloud:before { + content: "\f2c9"; +} + +.ion-md-cloud-circle:before { + content: "\f2c2"; +} + +.ion-md-cloud-done:before { + content: "\f2c3"; +} + +.ion-md-cloud-download:before { + content: "\f2c6"; +} + +.ion-md-cloud-outline:before { + content: "\f2c7"; +} + +.ion-md-cloud-upload:before { + content: "\f2c8"; +} + +.ion-md-cloudy:before { + content: "\f2cb"; +} + +.ion-md-cloudy-night:before { + content: "\f2ca"; +} + +.ion-md-code:before { + content: "\f2ce"; +} + +.ion-md-code-download:before { + content: "\f2cc"; +} + +.ion-md-code-working:before { + content: "\f2cd"; +} + +.ion-md-cog:before { + content: "\f2cf"; +} + +.ion-md-color-fill:before { + content: "\f2d0"; +} + +.ion-md-color-filter:before { + content: "\f2d1"; +} + +.ion-md-color-palette:before { + content: "\f2d2"; +} + +.ion-md-color-wand:before { + content: "\f2d3"; +} + +.ion-md-compass:before { + content: "\f2d4"; +} + +.ion-md-construct:before { + content: "\f2d5"; +} + +.ion-md-contact:before { + content: "\f2d6"; +} + +.ion-md-contacts:before { + content: "\f2d7"; +} + +.ion-md-contract:before { + content: "\f2d8"; +} + +.ion-md-contrast:before { + content: "\f2d9"; +} + +.ion-md-copy:before { + content: "\f2da"; +} + +.ion-md-create:before { + content: "\f2db"; +} + +.ion-md-crop:before { + content: "\f2dc"; +} + +.ion-md-cube:before { + content: "\f2dd"; +} + +.ion-md-cut:before { + content: "\f2de"; +} + +.ion-md-desktop:before { + content: "\f2df"; +} + +.ion-md-disc:before { + content: "\f2e0"; +} + +.ion-md-document:before { + content: "\f2e1"; +} + +.ion-md-done-all:before { + content: "\f2e2"; +} + +.ion-md-download:before { + content: "\f2e3"; +} + +.ion-md-easel:before { + content: "\f2e4"; +} + +.ion-md-egg:before { + content: "\f2e5"; +} + +.ion-md-exit:before { + content: "\f2e6"; +} + +.ion-md-expand:before { + content: "\f2e7"; +} + +.ion-md-eye:before { + content: "\f2e9"; +} + +.ion-md-eye-off:before { + content: "\f2e8"; +} + +.ion-md-fastforward:before { + content: "\f2ea"; +} + +.ion-md-female:before { + content: "\f2eb"; +} + +.ion-md-filing:before { + content: "\f2ec"; +} + +.ion-md-film:before { + content: "\f2ed"; +} + +.ion-md-finger-print:before { + content: "\f2ee"; +} + +.ion-md-fitness:before { + content: "\f1ac"; +} + +.ion-md-flag:before { + content: "\f2ef"; +} + +.ion-md-flame:before { + content: "\f2f0"; +} + +.ion-md-flash:before { + content: "\f2f1"; +} + +.ion-md-flash-off:before { + content: "\f169"; +} + +.ion-md-flashlight:before { + content: "\f16b"; +} + +.ion-md-flask:before { + content: "\f2f2"; +} + +.ion-md-flower:before { + content: "\f2f3"; +} + +.ion-md-folder:before { + content: "\f2f5"; +} + +.ion-md-folder-open:before { + content: "\f2f4"; +} + +.ion-md-football:before { + content: "\f2f6"; +} + +.ion-md-funnel:before { + content: "\f2f7"; +} + +.ion-md-gift:before { + content: "\f199"; +} + +.ion-md-git-branch:before { + content: "\f2fa"; +} + +.ion-md-git-commit:before { + content: "\f2fb"; +} + +.ion-md-git-compare:before { + content: "\f2fc"; +} + +.ion-md-git-merge:before { + content: "\f2fd"; +} + +.ion-md-git-network:before { + content: "\f2fe"; +} + +.ion-md-git-pull-request:before { + content: "\f2ff"; +} + +.ion-md-glasses:before { + content: "\f300"; +} + +.ion-md-globe:before { + content: "\f301"; +} + +.ion-md-grid:before { + content: "\f302"; +} + +.ion-md-hammer:before { + content: "\f303"; +} + +.ion-md-hand:before { + content: "\f304"; +} + +.ion-md-happy:before { + content: "\f305"; +} + +.ion-md-headset:before { + content: "\f306"; +} + +.ion-md-heart:before { + content: "\f308"; +} + +.ion-md-heart-dislike:before { + content: "\f167"; +} + +.ion-md-heart-empty:before { + content: "\f1a1"; +} + +.ion-md-heart-half:before { + content: "\f1a2"; +} + +.ion-md-help:before { + content: "\f30b"; +} + +.ion-md-help-buoy:before { + content: "\f309"; +} + +.ion-md-help-circle:before { + content: "\f30a"; +} + +.ion-md-help-circle-outline:before { + content: "\f16d"; +} + +.ion-md-home:before { + content: "\f30c"; +} + +.ion-md-hourglass:before { + content: "\f111"; +} + +.ion-md-ice-cream:before { + content: "\f30d"; +} + +.ion-md-image:before { + content: "\f30e"; +} + +.ion-md-images:before { + content: "\f30f"; +} + +.ion-md-infinite:before { + content: "\f310"; +} + +.ion-md-information:before { + content: "\f312"; +} + +.ion-md-information-circle:before { + content: "\f311"; +} + +.ion-md-information-circle-outline:before { + content: "\f16f"; +} + +.ion-md-jet:before { + content: "\f315"; +} + +.ion-md-journal:before { + content: "\f18d"; +} + +.ion-md-key:before { + content: "\f316"; +} + +.ion-md-keypad:before { + content: "\f317"; +} + +.ion-md-laptop:before { + content: "\f318"; +} + +.ion-md-leaf:before { + content: "\f319"; +} + +.ion-md-link:before { + content: "\f22e"; +} + +.ion-md-list:before { + content: "\f31b"; +} + +.ion-md-list-box:before { + content: "\f31a"; +} + +.ion-md-locate:before { + content: "\f31c"; +} + +.ion-md-lock:before { + content: "\f31d"; +} + +.ion-md-log-in:before { + content: "\f31e"; +} + +.ion-md-log-out:before { + content: "\f31f"; +} + +.ion-md-magnet:before { + content: "\f320"; +} + +.ion-md-mail:before { + content: "\f322"; +} + +.ion-md-mail-open:before { + content: "\f321"; +} + +.ion-md-mail-unread:before { + content: "\f172"; +} + +.ion-md-male:before { + content: "\f323"; +} + +.ion-md-man:before { + content: "\f324"; +} + +.ion-md-map:before { + content: "\f325"; +} + +.ion-md-medal:before { + content: "\f326"; +} + +.ion-md-medical:before { + content: "\f327"; +} + +.ion-md-medkit:before { + content: "\f328"; +} + +.ion-md-megaphone:before { + content: "\f329"; +} + +.ion-md-menu:before { + content: "\f32a"; +} + +.ion-md-mic:before { + content: "\f32c"; +} + +.ion-md-mic-off:before { + content: "\f32b"; +} + +.ion-md-microphone:before { + content: "\f32d"; +} + +.ion-md-moon:before { + content: "\f32e"; +} + +.ion-md-more:before { + content: "\f1c9"; +} + +.ion-md-move:before { + content: "\f331"; +} + +.ion-md-musical-note:before { + content: "\f332"; +} + +.ion-md-musical-notes:before { + content: "\f333"; +} + +.ion-md-navigate:before { + content: "\f334"; +} + +.ion-md-notifications:before { + content: "\f338"; +} + +.ion-md-notifications-off:before { + content: "\f336"; +} + +.ion-md-notifications-outline:before { + content: "\f337"; +} + +.ion-md-nuclear:before { + content: "\f339"; +} + +.ion-md-nutrition:before { + content: "\f33a"; +} + +.ion-md-open:before { + content: "\f33b"; +} + +.ion-md-options:before { + content: "\f33c"; +} + +.ion-md-outlet:before { + content: "\f33d"; +} + +.ion-md-paper:before { + content: "\f33f"; +} + +.ion-md-paper-plane:before { + content: "\f33e"; +} + +.ion-md-partly-sunny:before { + content: "\f340"; +} + +.ion-md-pause:before { + content: "\f341"; +} + +.ion-md-paw:before { + content: "\f342"; +} + +.ion-md-people:before { + content: "\f343"; +} + +.ion-md-person:before { + content: "\f345"; +} + +.ion-md-person-add:before { + content: "\f344"; +} + +.ion-md-phone-landscape:before { + content: "\f346"; +} + +.ion-md-phone-portrait:before { + content: "\f347"; +} + +.ion-md-photos:before { + content: "\f348"; +} + +.ion-md-pie:before { + content: "\f349"; +} + +.ion-md-pin:before { + content: "\f34a"; +} + +.ion-md-pint:before { + content: "\f34b"; +} + +.ion-md-pizza:before { + content: "\f354"; +} + +.ion-md-planet:before { + content: "\f356"; +} + +.ion-md-play:before { + content: "\f357"; +} + +.ion-md-play-circle:before { + content: "\f174"; +} + +.ion-md-podium:before { + content: "\f358"; +} + +.ion-md-power:before { + content: "\f359"; +} + +.ion-md-pricetag:before { + content: "\f35a"; +} + +.ion-md-pricetags:before { + content: "\f35b"; +} + +.ion-md-print:before { + content: "\f35c"; +} + +.ion-md-pulse:before { + content: "\f35d"; +} + +.ion-md-qr-scanner:before { + content: "\f35e"; +} + +.ion-md-quote:before { + content: "\f35f"; +} + +.ion-md-radio:before { + content: "\f362"; +} + +.ion-md-radio-button-off:before { + content: "\f360"; +} + +.ion-md-radio-button-on:before { + content: "\f361"; +} + +.ion-md-rainy:before { + content: "\f363"; +} + +.ion-md-recording:before { + content: "\f364"; +} + +.ion-md-redo:before { + content: "\f365"; +} + +.ion-md-refresh:before { + content: "\f366"; +} + +.ion-md-refresh-circle:before { + content: "\f228"; +} + +.ion-md-remove:before { + content: "\f368"; +} + +.ion-md-remove-circle:before { + content: "\f367"; +} + +.ion-md-remove-circle-outline:before { + content: "\f176"; +} + +.ion-md-reorder:before { + content: "\f369"; +} + +.ion-md-repeat:before { + content: "\f36a"; +} + +.ion-md-resize:before { + content: "\f36b"; +} + +.ion-md-restaurant:before { + content: "\f36c"; +} + +.ion-md-return-left:before { + content: "\f36d"; +} + +.ion-md-return-right:before { + content: "\f36e"; +} + +.ion-md-reverse-camera:before { + content: "\f36f"; +} + +.ion-md-rewind:before { + content: "\f370"; +} + +.ion-md-ribbon:before { + content: "\f371"; +} + +.ion-md-rocket:before { + content: "\f179"; +} + +.ion-md-rose:before { + content: "\f372"; +} + +.ion-md-sad:before { + content: "\f373"; +} + +.ion-md-save:before { + content: "\f1a9"; +} + +.ion-md-school:before { + content: "\f374"; +} + +.ion-md-search:before { + content: "\f375"; +} + +.ion-md-send:before { + content: "\f376"; +} + +.ion-md-settings:before { + content: "\f377"; +} + +.ion-md-share:before { + content: "\f379"; +} + +.ion-md-share-alt:before { + content: "\f378"; +} + +.ion-md-shirt:before { + content: "\f37a"; +} + +.ion-md-shuffle:before { + content: "\f37b"; +} + +.ion-md-skip-backward:before { + content: "\f37c"; +} + +.ion-md-skip-forward:before { + content: "\f37d"; +} + +.ion-md-snow:before { + content: "\f37e"; +} + +.ion-md-speedometer:before { + content: "\f37f"; +} + +.ion-md-square:before { + content: "\f381"; +} + +.ion-md-square-outline:before { + content: "\f380"; +} + +.ion-md-star:before { + content: "\f384"; +} + +.ion-md-star-half:before { + content: "\f382"; +} + +.ion-md-star-outline:before { + content: "\f383"; +} + +.ion-md-stats:before { + content: "\f385"; +} + +.ion-md-stopwatch:before { + content: "\f386"; +} + +.ion-md-subway:before { + content: "\f387"; +} + +.ion-md-sunny:before { + content: "\f388"; +} + +.ion-md-swap:before { + content: "\f389"; +} + +.ion-md-switch:before { + content: "\f38a"; +} + +.ion-md-sync:before { + content: "\f38b"; +} + +.ion-md-tablet-landscape:before { + content: "\f38c"; +} + +.ion-md-tablet-portrait:before { + content: "\f38d"; +} + +.ion-md-tennisball:before { + content: "\f38e"; +} + +.ion-md-text:before { + content: "\f38f"; +} + +.ion-md-thermometer:before { + content: "\f390"; +} + +.ion-md-thumbs-down:before { + content: "\f391"; +} + +.ion-md-thumbs-up:before { + content: "\f392"; +} + +.ion-md-thunderstorm:before { + content: "\f393"; +} + +.ion-md-time:before { + content: "\f394"; +} + +.ion-md-timer:before { + content: "\f395"; +} + +.ion-md-today:before { + content: "\f17d"; +} + +.ion-md-train:before { + content: "\f396"; +} + +.ion-md-transgender:before { + content: "\f397"; +} + +.ion-md-trash:before { + content: "\f398"; +} + +.ion-md-trending-down:before { + content: "\f399"; +} + +.ion-md-trending-up:before { + content: "\f39a"; +} + +.ion-md-trophy:before { + content: "\f39b"; +} + +.ion-md-tv:before { + content: "\f17f"; +} + +.ion-md-umbrella:before { + content: "\f39c"; +} + +.ion-md-undo:before { + content: "\f39d"; +} + +.ion-md-unlock:before { + content: "\f39e"; +} + +.ion-md-videocam:before { + content: "\f39f"; +} + +.ion-md-volume-high:before { + content: "\f123"; +} + +.ion-md-volume-low:before { + content: "\f131"; +} + +.ion-md-volume-mute:before { + content: "\f3a1"; +} + +.ion-md-volume-off:before { + content: "\f3a2"; +} + +.ion-md-walk:before { + content: "\f3a4"; +} + +.ion-md-wallet:before { + content: "\f18f"; +} + +.ion-md-warning:before { + content: "\f3a5"; +} + +.ion-md-watch:before { + content: "\f3a6"; +} + +.ion-md-water:before { + content: "\f3a7"; +} + +.ion-md-wifi:before { + content: "\f3a8"; +} + +.ion-md-wine:before { + content: "\f3a9"; +} + +.ion-md-woman:before { + content: "\f3aa"; +} \ No newline at end of file diff --git a/_sass/1-tools/_normalize.scss b/_sass/1-tools/_normalize.scss new file mode 100755 index 0000000..47b010e --- /dev/null +++ b/_sass/1-tools/_normalize.scss @@ -0,0 +1,341 @@ +/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */ + +/* Document + ========================================================================== */ + +/** + * 1. Correct the line height in all browsers. + * 2. Prevent adjustments of font size after orientation changes in iOS. + */ + +html { + line-height: 1.15; /* 1 */ + -webkit-text-size-adjust: 100%; /* 2 */ +} + +/* Sections + ========================================================================== */ + +/** + * Remove the margin in all browsers. + */ + +body { + margin: 0; +} + +/** + * Correct the font size and margin on `h1` elements within `section` and + * `article` contexts in Chrome, Firefox, and Safari. + */ + +h1 { + font-size: 2em; + margin: 0.67em 0; +} + +/* Grouping content + ========================================================================== */ + +/** + * 1. Add the correct box sizing in Firefox. + * 2. Show the overflow in Edge and IE. + */ + +hr { + box-sizing: content-box; /* 1 */ + height: 0; /* 1 */ + overflow: visible; /* 2 */ +} + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ + +pre { + font-family: monospace, monospace; /* 1 */ + font-size: 1em; /* 2 */ +} + +/* Text-level semantics + ========================================================================== */ + +/** + * Remove the gray background on active links in IE 10. + */ + +a { + background-color: transparent; +} + +/** + * 1. Remove the bottom border in Chrome 57- + * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. + */ + +abbr[title] { + border-bottom: none; /* 1 */ + text-decoration: underline; /* 2 */ + text-decoration: underline dotted; /* 2 */ +} + +/** + * Add the correct font weight in Chrome, Edge, and Safari. + */ + +b, +strong { + font-weight: bolder; +} + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ + +code, +kbd, +samp { + font-family: monospace, monospace; /* 1 */ + font-size: 1em; /* 2 */ +} + +/** + * Add the correct font size in all browsers. + */ + +small { + font-size: 80%; +} + +/** + * Prevent `sub` and `sup` elements from affecting the line height in + * all browsers. + */ + +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} + +sub { + bottom: -0.25em; +} + +sup { + top: -0.5em; +} + +/* Embedded content + ========================================================================== */ + +/** + * Remove the border on images inside links in IE 10. + */ + +img { + border-style: none; +} + +/* Forms + ========================================================================== */ + +/** + * 1. Change the font styles in all browsers. + * 2. Remove the margin in Firefox and Safari. + */ + +button, +input, +optgroup, +select, +textarea { + font-family: inherit; /* 1 */ + font-size: 100%; /* 1 */ + line-height: 1.15; /* 1 */ + margin: 0; /* 2 */ +} + +/** + * Show the overflow in IE. + * 1. Show the overflow in Edge. + */ + +button, +input { /* 1 */ + overflow: visible; +} + +/** + * Remove the inheritance of text transform in Edge, Firefox, and IE. + * 1. Remove the inheritance of text transform in Firefox. + */ + +button, +select { /* 1 */ + text-transform: none; +} + +/** + * Correct the inability to style clickable types in iOS and Safari. + */ + +button, +[type="button"], +[type="reset"], +[type="submit"] { + -webkit-appearance: button; +} + +/** + * Remove the inner border and padding in Firefox. + */ + +button::-moz-focus-inner, +[type="button"]::-moz-focus-inner, +[type="reset"]::-moz-focus-inner, +[type="submit"]::-moz-focus-inner { + border-style: none; + padding: 0; +} + +/** + * Restore the focus styles unset by the previous rule. + */ + +button:-moz-focusring, +[type="button"]:-moz-focusring, +[type="reset"]:-moz-focusring, +[type="submit"]:-moz-focusring { + outline: 1px dotted ButtonText; +} + +/** + * Correct the padding in Firefox. + */ + +fieldset { + padding: 0.35em 0.75em 0.625em; +} + +/** + * 1. Correct the text wrapping in Edge and IE. + * 2. Correct the color inheritance from `fieldset` elements in IE. + * 3. Remove the padding so developers are not caught out when they zero out + * `fieldset` elements in all browsers. + */ + +legend { + box-sizing: border-box; /* 1 */ + color: inherit; /* 2 */ + display: table; /* 1 */ + max-width: 100%; /* 1 */ + padding: 0; /* 3 */ + white-space: normal; /* 1 */ +} + +/** + * Add the correct vertical alignment in Chrome, Firefox, and Opera. + */ + +progress { + vertical-align: baseline; +} + +/** + * Remove the default vertical scrollbar in IE 10+. + */ + +textarea { + overflow: auto; +} + +/** + * 1. Add the correct box sizing in IE 10. + * 2. Remove the padding in IE 10. + */ + +[type="checkbox"], +[type="radio"] { + box-sizing: border-box; /* 1 */ + padding: 0; /* 2 */ +} + +/** + * Correct the cursor style of increment and decrement buttons in Chrome. + */ + +[type="number"]::-webkit-inner-spin-button, +[type="number"]::-webkit-outer-spin-button { + height: auto; +} + +/** + * 1. Correct the odd appearance in Chrome and Safari. + * 2. Correct the outline style in Safari. + */ + +[type="search"] { + -webkit-appearance: textfield; /* 1 */ + outline-offset: -2px; /* 2 */ +} + +/** + * Remove the inner padding in Chrome and Safari on macOS. + */ + +[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; +} + +/** + * 1. Correct the inability to style clickable types in iOS and Safari. + * 2. Change font properties to `inherit` in Safari. + */ + +::-webkit-file-upload-button { + -webkit-appearance: button; /* 1 */ + font: inherit; /* 2 */ +} + +/* Interactive + ========================================================================== */ + +/* + * Add the correct display in Edge, IE 10+, and Firefox. + */ + +details { + display: block; +} + +/* + * Add the correct display in all browsers. + */ + +summary { + display: list-item; +} + +/* Misc + ========================================================================== */ + +/** + * Add the correct display in IE 10+. + */ + +template { + display: none; +} + +/** + * Add the correct display in IE 10. + */ + +[hidden] { + display: none; +} diff --git a/_sass/1-tools/_reset.scss b/_sass/1-tools/_reset.scss new file mode 100755 index 0000000..c3b0932 --- /dev/null +++ b/_sass/1-tools/_reset.scss @@ -0,0 +1,38 @@ +/** + * A very simple reset that sits on top of Normalize.css. +*/ + +body, +h1, h2, h3, h4, h5, h6, +p, blockquote, pre, +dl, dd, ol, ul, +fieldset, legend, +figure, +hr { + margin: 0; + padding: 0; +} + + +/** + * Remove trailing margins from nested lists. + */ + +li > { + + ul, + ol { + margin-bottom: 0; + } + +} + + +/** + * Remove default table spacing. + */ + +table { + border-collapse: collapse; + border-spacing: 0; +} diff --git a/_sass/1-tools/_shared.scss b/_sass/1-tools/_shared.scss new file mode 100755 index 0000000..d1a567f --- /dev/null +++ b/_sass/1-tools/_shared.scss @@ -0,0 +1,23 @@ +/** + * Shared declarations for certain elements. + */ + +h1, h2, h3, h4, h5, h6, +ul, ol, dl, +blockquote, p, address, +hr, +table, +fieldset, figure, +pre { + margin-bottom: $base-spacing-unit; +} + + +/** + * Consistent indentation for lists. + */ + +ul, ol, +dd { + margin-left: $base-spacing-unit; +} \ No newline at end of file diff --git a/_sass/1-tools/_syntax-highlighting.scss b/_sass/1-tools/_syntax-highlighting.scss new file mode 100755 index 0000000..303429f --- /dev/null +++ b/_sass/1-tools/_syntax-highlighting.scss @@ -0,0 +1,71 @@ +/* + Syntax Highlighting +*/ + +.highlight { + background: #f8f8f8; + + .highlighter-rouge & { + background: #eef; + } + + .c { color: #998; font-style: italic } // Comment + .err { color: #a61717; background-color: #e3d2d2 } // Error + .k { font-weight: bold } // Keyword + .o { font-weight: bold } // Operator + .cm { color: #998; font-style: italic } // Comment.Multiline + .cp { color: #999; font-weight: bold } // Comment.Preproc + .c1 { color: #998; font-style: italic } // Comment.Single + .cs { color: #999; font-weight: bold; font-style: italic } // Comment.Special + .gd { color: #000; background-color: #fdd } // Generic.Deleted + .gd .x { color: #000; background-color: #faa } // Generic.Deleted.Specific + .ge { font-style: italic } // Generic.Emph + .gr { color: #a00 } // Generic.Error + .gh { color: #999 } // Generic.Heading + .gi { color: #000; background-color: #dfd } // Generic.Inserted + .gi .x { color: #000; background-color: #afa } // Generic.Inserted.Specific + .go { color: #888 } // Generic.Output + .gp { color: #555 } // Generic.Prompt + .gs { font-weight: bold } // Generic.Strong + .gu { color: #aaa } // Generic.Subheading + .gt { color: #a00 } // Generic.Traceback + .kc { font-weight: bold } // Keyword.Constant + .kd { font-weight: bold } // Keyword.Declaration + .kp { font-weight: bold } // Keyword.Pseudo + .kr { font-weight: bold } // Keyword.Reserved + .kt { color: #458; font-weight: bold } // Keyword.Type + .m { color: #099 } // Literal.Number + .s { color: #d14 } // Literal.String + .na { color: #008080 } // Name.Attribute + .nb { color: #0086B3 } // Name.Builtin + .nc { color: #458; font-weight: bold } // Name.Class + .no { color: #008080 } // Name.Constant + .ni { color: #800080 } // Name.Entity + .ne { color: #900; font-weight: bold } // Name.Exception + .nf { color: #900; font-weight: bold } // Name.Function + .nn { color: #555 } // Name.Namespace + .nt { color: #000080 } // Name.Tag + .nv { color: #008080 } // Name.Variable + .ow { font-weight: bold } // Operator.Word + .w { color: #bbb } // Text.Whitespace + .mf { color: #099 } // Literal.Number.Float + .mh { color: #099 } // Literal.Number.Hex + .mi { color: #099 } // Literal.Number.Integer + .mo { color: #099 } // Literal.Number.Oct + .sb { color: #d14 } // Literal.String.Backtick + .sc { color: #d14 } // Literal.String.Char + .sd { color: #d14 } // Literal.String.Doc + .s2 { color: #d14 } // Literal.String.Double + .se { color: #d14 } // Literal.String.Escape + .sh { color: #d14 } // Literal.String.Heredoc + .si { color: #d14 } // Literal.String.Interpol + .sx { color: #d14 } // Literal.String.Other + .sr { color: #009926 } // Literal.String.Regex + .s1 { color: #d14 } // Literal.String.Single + .ss { color: #990073 } // Literal.String.Symbol + .bp { color: #999 } // Name.Builtin.Pseudo + .vc { color: #008080 } // Name.Variable.Class + .vg { color: #008080 } // Name.Variable.Global + .vi { color: #008080 } // Name.Variable.Instance + .il { color: #099 } // Literal.Number.Integer.Long +} diff --git a/_sass/1-tools/_zoom.scss b/_sass/1-tools/_zoom.scss new file mode 100755 index 0000000..89d2b87 --- /dev/null +++ b/_sass/1-tools/_zoom.scss @@ -0,0 +1,39 @@ +img[data-action="zoom"] { + cursor: pointer; + cursor: -webkit-zoom-in; + cursor: -moz-zoom-in; +} +.zoom-img, +.zoom-img-wrap { + position: relative; + z-index: 666; + -webkit-transition: all 300ms; + -o-transition: all 300ms; + transition: all 300ms; +} +img.zoom-img { + cursor: pointer; + cursor: -webkit-zoom-out; + cursor: -moz-zoom-out; +} +.zoom-overlay { + z-index: 420; + background: #fff; + position: fixed; + top: 0; + left: 0; + right: 0; + bottom: 0; + pointer-events: none; + opacity: 0; + -webkit-transition: opacity 300ms; + -o-transition: opacity 300ms; + transition: opacity 300ms; +} +.zoom-overlay-open .zoom-overlay { + opacity: 1; +} +.zoom-overlay-open, +.zoom-overlay-transitioning { + cursor: default; +} \ No newline at end of file diff --git a/_sass/2-base/_base.scss b/_sass/2-base/_base.scss new file mode 100755 index 0000000..cac9127 --- /dev/null +++ b/_sass/2-base/_base.scss @@ -0,0 +1,127 @@ +*, *::after, *::before { + box-sizing: border-box; +} + +body { + font-family: $base-font-family; + font-size: $base-font-size; + line-height: $base-line-height; + color: $text-color; + background-color: $background-color; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + input, textarea { + border: 1px solid $border-color; + outline: none; + &:focus:required:invalid { + border-color: #e02f40; + } + &:required:valid { + border-color: #34a74e; + } + } +} + +::placeholder { + color: #666; +} + +*::selection { + color: $white; + background-color: $dark; +} + +h1, +h2, +h3, +h4, +h5, +h6 { + font-family: $heading-font-family; + line-height: initial; + letter-spacing: 0.5px; +} + +h1 { + font-size: $font-size-h1; +} + +h2 { + font-size: $font-size-h2; +} + +h3 { + font-size: $font-size-h3; +} + +h4 { + font-size: $font-size-h4; +} + +h5 { + font-size: $font-size-h5; +} + +h6 { + font-size: $font-size-h6; +} + +blockquote { + margin: 30px -100px; + font-size: 28px; + line-height: 45px; + letter-spacing: 0.5px; + font-style: normal; + text-align: center; + + @media only screen and (max-width: $tablet) { + margin: 30px 0; + font-size: 24px; + line-height: 38px; + } +} + +pre { + overflow: auto; + padding: 15px; + margin-bottom: 0; + font-size: 14px; + white-space: pre-wrap; + word-wrap: break-word; + word-break: break-all; +} + +img, +.zoom-img-wrap { + max-width: 100%; + height: auto; + vertical-align: middle; + &+em { + text-align: center; + display: block; + font-style: normal; + font-weight: normal; + font-size: 14px; + color: $gray; + } +} + +a { + text-decoration: none; + color: $link-color; + transition: $global-transition; + &:hover { + color: darken($link-color, 10%); + } + &:active { + color: darken($link-color, 20%); + } +} + +hr { + display: block; + height: 1px; + margin: 40px 0; + border: 0; + background: $light-gray; +} \ No newline at end of file diff --git a/_sass/3-modules/_contact-link.scss b/_sass/3-modules/_contact-link.scss new file mode 100644 index 0000000..7095621 --- /dev/null +++ b/_sass/3-modules/_contact-link.scss @@ -0,0 +1,16 @@ +.contact { + .contact__list { + li { + margin-left: 15px; + display: inline-block; + + a { + font-size: 28px; + color: $gray; + &:hover { + color: $dark; + } + } + } + } +} \ No newline at end of file diff --git a/_sass/3-modules/_footer.scss b/_sass/3-modules/_footer.scss new file mode 100644 index 0000000..69f4e78 --- /dev/null +++ b/_sass/3-modules/_footer.scss @@ -0,0 +1,24 @@ +.footer { + position: relative; + padding: 40px 0 40px; + text-align: center; + border-top: 1px solid $light-gray; + background: #f5f5f5; + + .contact { + margin-bottom: 20px; + } + + .copyright { + a { + color: $dark; + &:hover { + color: $brand-color; + } + } + } + + @media only screen and (max-width: $mobile) { + padding: 40px 0 20px; + } +} \ No newline at end of file diff --git a/_sass/3-modules/_header.scss b/_sass/3-modules/_header.scss new file mode 100644 index 0000000..9c3ce0f --- /dev/null +++ b/_sass/3-modules/_header.scss @@ -0,0 +1,154 @@ +.header { + position: relative; + height: 100px; + + .header__overlay { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 10; + background-color: rgba(17,17,17,0.7); + cursor: pointer; + opacity: 0; + visibility: hidden; + transition: all 0.5s ease; + + @media only screen and (max-width: $desktop) { + &.is-visible { + opacity: 1; + visibility: visible; + } + } + } +} + +.logo { + position: absolute; + top: 50%; + left: 0; + transform: translateY(-50%); + + .logo__link { + font-size: 30px; + font-weight: 700; + letter-spacing: 0.5px; + color: $dark; + text-decoration: none; + &:hover { + color: $black; + } + } + + .logo__image { + max-height: 65px; + } +} + +.main-nav { + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + + .nav-icon__close { + display: none; + font-size: 24px; + text-align: right; + cursor: pointer; + &:hover { + color: $black; + } + } + + .nav__title { + display: none; + } + + .nav__list { + white-space: nowrap; + + .nav__item { + display: inline-block; + + .nav__link { + display: inline-block; + padding: 10px 30px; + font-size: 14px; + font-weight: 700; + letter-spacing: 0.5px; + text-transform: uppercase; + color: $dark; + &:hover { + color: $black; + } + } + } + } + + @media only screen and (max-width: $desktop) { + position: fixed; + top: 0; + left: inherit; + right: -300px; + bottom: 0; + transform: none; + z-index: 100; + width: 300px; + height: 100vh; + padding: 40px 30px 30px; + transition: right 0.5s cubic-bezier(0.7, 0.4, 0, 1); + background: $white; + &.is-open { + right: 0; + } + + .nav-icon__close { + display: block; + } + + .nav__title { + display: block; + padding-left: 30px; + padding-bottom: 7px; + margin-bottom: 10px; + color: $gray; + border-bottom: 1px solid $light-gray; + } + + .nav__list { + .nav__item { + display: block; + } + } + } +} + +.nav-buttons { + position: absolute; + top: 50%; + right: 0; + transform: translateY(-50%); + font-size: 21px; + + .nav__icon { + color: $dark; + cursor: pointer; + &:hover { + color: $black; + } + } + + .nav__icon-menu { + display: none; + margin-right: 10px; + &:hover { + color: $black; + } + + @media only screen and (max-width: $desktop) { + display: inline-block; + } + } +} \ No newline at end of file diff --git a/_sass/3-modules/_hero.scss b/_sass/3-modules/_hero.scss new file mode 100644 index 0000000..1001bba --- /dev/null +++ b/_sass/3-modules/_hero.scss @@ -0,0 +1,71 @@ +.hero { + padding: 80px 0; + margin-bottom: 80px; + background: #f5f5f5; + + .last-item { + display: flex; + } + + .hero__content { + display: flex; + flex-direction: column; + justify-content: center; + width: 100%; + padding: 0 40px 0 0; + + .hero__title { + font-size: 38px; + font-weight: normal; + } + + .hero__subtitle { + font-size: 18px; + line-height: 32px; + letter-spacing: 0.5px; + } + + .hero__social { + display: flex; + } + + .hero__social-title { + font-weight: 700; + } + + } + + @media only screen and (max-width: $desktop) { + .hero__content { + padding: 0; + + .hero__subtitle { + font-size: 16px; + line-height: 28px; + } + } + } + + @media only screen and (max-width: $tablet) { + margin-bottom: 40px; + + .last-item { + order: 1; + } + + .hero__content { + .hero__title { + margin-bottom: 20px; + font-size: 27px; + } + } + + .hero__image { + margin-bottom: 20px; + } + } + + @media only screen and (max-width: $mobile) { + padding: 40px 0; + } +} \ No newline at end of file diff --git a/_sass/3-modules/_pagination.scss b/_sass/3-modules/_pagination.scss new file mode 100644 index 0000000..3f3a796 --- /dev/null +++ b/_sass/3-modules/_pagination.scss @@ -0,0 +1,69 @@ +.pagination { + margin: 20px 0 40px; + padding: 40px 0; + text-align: center; + + @media only screen and (max-width: $mobile) { + margin: 0 0 20px; + } +} + +.pagination__list { + display: flex; + justify-content: space-between; + align-items: center; + + .next-link, + .previous-link, + .disabled { + display: inline-block; + width: 140px; + height: 50px; + line-height: 50px; + font-size: 12px; + letter-spacing: 1px; + text-transform: uppercase; + transition: all .35s; + box-shadow: 0 1px 3px 0 rgba(0, 0, 0, .15); + background: $white; + } + + .next-link, + .previous-link { + color: $dark; + + &:hover { + color: $black; + } + } + + .disabled { + color: $gray; + cursor: not-allowed; + } + + .counter-box { + + a, span { + padding: 0 5px; + font-size: 15px; + color: $dark; + } + + .active-link { + font-weight: 700; + } + } + + @media only screen and (max-width: $mobile) { + flex-direction: column; + + .next-link, + .previous-link, + .disabled { + margin: 10px 0; + } + + } + +} \ No newline at end of file diff --git a/_sass/3-modules/_scroll-button-top.scss b/_sass/3-modules/_scroll-button-top.scss new file mode 100755 index 0000000..0dff6ba --- /dev/null +++ b/_sass/3-modules/_scroll-button-top.scss @@ -0,0 +1,32 @@ +.top { + position: fixed; + bottom: 40px; + right: -100px; + z-index: 1; + width: 35px; + height: 35px; + text-align: center; + line-height: 35px; + background-color: $dark; + color: $white; + cursor: pointer; + transition: all .25s ease; + + &.is-active { + right: 40px; + } + + &:hover { + background-color: $black; + } + +} + +@media only screen and (max-width: $tablet) { + .top { + bottom: 25px; + &.is-active { + right: 30px; + } + } +} \ No newline at end of file diff --git a/_sass/3-modules/_search.scss b/_sass/3-modules/_search.scss new file mode 100644 index 0000000..ef2fe43 --- /dev/null +++ b/_sass/3-modules/_search.scss @@ -0,0 +1,108 @@ +.search { + position: fixed; + top: 0; + left: 0; + right: 0; + bottom: 0; + z-index: -1; + transform: scale(0.95); + opacity: 0; + background: $white; + transition: all 250ms ease; + &.is-visible { + transform: scale(1); + z-index: 100; + opacity: 1; + transition: all 250ms ease; + } +} + +.search__box { + width: 50%; + margin: 0 auto; + padding-top: 100px; + + @media only screen and (max-width: $desktop) { + width: 70%; + padding-top: 70px; + } + + @media only screen and (max-width: $mobile) { + width: 100%; + padding-top: 30px; + } +} + +.search__group { + margin-bottom: 50px; + + .search__close { + margin-bottom: 30px; + font-size: 27px; + text-align: right; + cursor: pointer; + &:hover { + color: $black; + } + } + + .search__text { + width: 100%; + padding: 20px 20px 20px 30px; + letter-spacing: 0.5px; + border-radius: 30px; + border: 1px solid #f8f8f8; + color: $dark; + background: #f8f8f8; + &::placeholder { + letter-spacing: 0.5px; + color: rgba($dark, 0.7); + } + } +} + +.search-results-list { + height: 65vh; + margin: 0; + padding: 0 20px; + list-style: decimal; + overflow: auto; + white-space: normal; + + .search-results__item { + margin-bottom: 10px; + padding-left: 10px; + padding-bottom: 10px; + font-weight: 700; + border-bottom: 1px solid #f5efef; + &:first-child { + padding-top: 20px; + border-top: 1px solid #f5efef; + } + } + + .search-results__link { + font-size: 18px; + font-weight: 700; + letter-spacing: 0.5px; + color: $dark; + &:hover { + color: $black; + } + } + + .search-results__date { + font-size: 12px; + color: $gray; + } + + .no-results { + list-style: none; + padding: 20px 0; + font-size: 18px; + font-weight: 700; + letter-spacing: 0.5px; + border-top: 1px solid #f5efef; + border-bottom: 1px solid #f5efef; + } +} \ No newline at end of file diff --git a/_sass/4-layouts/_article.scss b/_sass/4-layouts/_article.scss new file mode 100644 index 0000000..1696269 --- /dev/null +++ b/_sass/4-layouts/_article.scss @@ -0,0 +1,124 @@ +.article { + margin-bottom: 40px; + + .article__wrapper { + display: flex; + align-items: center; + } + + .article__image { + width: 50%; + display: block; + background-position: center; + background-size: cover; + background-repeat: no-repeat; + background-color: $light-gray; + &:hover { + opacity: 0.9; + } + + &:after { + content: ""; + display: table; + width: 100%; + padding-bottom: 70%; + } + } + + .article__content { + width: 60%; + padding: 50px; + margin-left: -10%; + z-index: 1; + border-radius: 3px; + background: rgba(255, 255, 255, 0.98); + box-shadow: 0 1px 4px rgba(0,0,0,0.15); + + .article__tag { + font-size: 12px; + letter-spacing: 0.5px; + font-weight: 700; + text-transform: uppercase; + } + + .article__title { + margin-bottom: 20px; + font-size: 30px; + + a { + color: $dark; + &:hover { + color: $black; + } + } + } + + .article__excerpt { + margin-bottom: 20px; + font-size: 16px; + line-height: 26px; + } + + .article__meta { + font-size: 12px; + line-height: 18px; + text-transform: uppercase; + color: $gray; + } + + .article__footer { + display: flex; + align-items: center; + + .read-more { + margin-left: auto; + padding-bottom: 5px; + font-size: 12px; + line-height: 18px; + letter-spacing: 1px; + text-transform: uppercase; + border-bottom: 1px solid transparent; + color: $gray; + &:hover { + color: $dark; + border-color: $brand-color; + } + } + } + } + + .article-without-image { + width: 100%; + margin-left: auto; + } + + @media only screen and (max-width: $tablet) { + .article__wrapper { + flex-direction: column; + } + + .article__image { + width: 100%; + } + + .article__content { + width: 90%; + padding: 20px; + margin: -10% 0 0 0; + } + + .article-without-image { + width: 90%; + margin: 0; + } + } + + @media only screen and (max-width: $mobile) { + .article__content { + + .article__title { + font-size: 27px; + } + } + } +} \ No newline at end of file diff --git a/_sass/4-layouts/_page-home.scss b/_sass/4-layouts/_page-home.scss new file mode 100644 index 0000000..846d880 --- /dev/null +++ b/_sass/4-layouts/_page-home.scss @@ -0,0 +1,39 @@ +.lates-title { + position: relative; + margin-bottom: 80px; + font-size: 14px; + line-height: 24px; + letter-spacing: 1px; + text-transform: uppercase; + font-weight: normal; + text-align: center; + &:after, + &:before { + content: ""; + display: block; + position: absolute; + top: 50%; + transform: translateY(-50%); + height: 1px; + background: $light-gray; + } + + &:after { + width: calc(50% - 90px); + left: 0; + } + + &:before { + width: calc(50% - 90px); + right: 0; + } + + @media only screen and (max-width: $tablet) { + margin-bottom: 40px; + + &:after, + &:before { + width: calc(50% - 70px); + } + } +} \ No newline at end of file diff --git a/_sass/4-layouts/_page.scss b/_sass/4-layouts/_page.scss new file mode 100644 index 0000000..1227ff3 --- /dev/null +++ b/_sass/4-layouts/_page.scss @@ -0,0 +1,64 @@ +.page-title-box { + padding: 80px 0; + border-top: 1px solid $light-gray; + + .page-title { + font-size: 57px; + line-height: 70px; + margin: 0; + } + + @media only screen and (max-width: $mobile) { + padding: 40px 0; + + .page-title { + font-size: 47px; + line-height: 53px; + } + } +} + +.page__head { + + .page-image { + background-size: cover; + background-position: center; + background-repeat: no-repeat; + background-color: $light-gray; + &:after { + content: ""; + display: table; + width: 100%; + min-height: 300px; + padding-top: 50%; + } + } +} + +.page { + margin: 80px auto; + + img { + margin: 30px 0; + } + + @media only screen and (max-width: $tablet) { + margin: 40px auto; + } +} + +.page-box { + text-align: center; + + .back-arrow { + a { + display: inline-block; + margin-left: 10px; + color: $dark; + font-weight: 700; + &:hover { + color: $black; + } + } + } +} \ No newline at end of file diff --git a/_sass/4-layouts/_post.scss b/_sass/4-layouts/_post.scss new file mode 100644 index 0000000..3d9ebe2 --- /dev/null +++ b/_sass/4-layouts/_post.scss @@ -0,0 +1,235 @@ +.post-title-box { + padding: 80px 0; + border-top: 1px solid $light-gray; + + .post-title { + margin-bottom: 10px; + width: 500px; + max-width: 100%; + font-size: 57px; + line-height: 70px; + } + + .post__date { + font-weight: 700; + } + + @media only screen and (max-width: $mobile) { + padding: 40px 0; + + .post-title { + margin: 10px 0; + font-size: 47px; + line-height: 53px; + } + } +} + +.post__info { + display: flex; + align-items: center; + + .post__author { + margin-right: 10px; + font-weight: 700; + + .author-name { + color: $gray; + border-bottom: 1px solid transparent; + &:hover { + border-bottom: 1px solid $gray; + } + } + } + + .post__tags { + .post__tags-tag { + position: relative; + padding-left: 15px; + padding-right: 5px; + font-weight: 700; + &:before { + content: ""; + position: absolute; + top: 50%; + left: 0; + transform: translateY(-50%); + width: 5px; + height: 5px; + border-radius: 50%; + background: $dark; + } + } + } +} + +.post-image { + background-size: cover; + background-position: center; + background-repeat: no-repeat; + background-color: $light-gray; + &:after { + content: ""; + display: table; + width: 100%; + min-height: 300px; + padding-top: 50%; + } +} + +.post { + margin: 80px auto; + + &.post-no-image { + margin: 0 auto 80px; + } + + @media only screen and (max-width: $mobile) { + margin: 40px auto; + + &.post-no-image { + margin: 0 auto 40px; + } + } + + img { + margin: 30px 0; + } +} + +.post__content { + margin-bottom: 40px; +} + +.post__share { + display: flex; + + .share__title { + margin-right: 10px; + font-size: 18px; + font-weight: 700; + letter-spacing: 0.5px; + } + + .share__list { + .share__item { + display: inline-block; + margin: 0 10px; + + a { + font-size: 18px; + color: $gray; + &:hover { + color: $dark; + } + } + } + } +} + +.post__navigation { + display: flex; + align-items: baseline; + margin-bottom: 80px; + padding-bottom: 80px; + border-bottom: 1px solid $light-gray; + + .prev, + .next { + flex: 1 0 50%; + &:last-child { + padding-right: 0; + } + + .post__nav__image { + display: block; + margin-bottom: 40px; + background-position: center; + background-size: cover; + background-repeat: no-repeat; + background-color: $light-gray; + transition: .35s ease-in-out; + &:hover { + opacity: 0.9; + } + &:after { + content: ""; + display: table; + width: 100%; + padding-bottom: 65%; + } + } + + .post__nav__title { + margin-bottom: 20px; + font-size: 27px; + line-height: 37px; + text-transform: uppercase; + letter-spacing: 2px; + text-align: center; + + a { + display: inline-block; + max-width: 250px; + padding: 0 10px; + vertical-align: middle; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + color: $dark; + &:hover { + color: $black; + } + } + } + } + + .prev { + padding-right: 10px; + } + + .next { + padding-left: 10px; + } + + .prev__excerpt, + .next__excerpt { + width: 100%; + max-width: 400px; + margin: 0 auto; + text-align: center; + } + + @media only screen and (max-width: $tablet) { + flex-wrap: wrap; + + .prev, + .next { + flex: 1 0 100%; + padding: 0; + } + + .next { + margin-top: 40px; + } + } + + @media only screen and (max-width: $mobile) { + margin-bottom: 40px; + padding-bottom: 40px; + .prev, + .next { + .post__nav__image { + margin-bottom: 20px; + } + } + } +} + +.comments { + margin-bottom: 80px; + + @media only screen and (max-width: $mobile) { + margin-bottom: 40px; + } +} diff --git a/_sass/4-layouts/_tag-page.scss b/_sass/4-layouts/_tag-page.scss new file mode 100644 index 0000000..616a27d --- /dev/null +++ b/_sass/4-layouts/_tag-page.scss @@ -0,0 +1,18 @@ +.arhive-head { + padding: 80px 0; + margin-bottom: 40px; + background: #f5f5f5; + + .archive-title { + text-align: center; + font-weight: normal; + + span { + font-weight: 700; + } + } + + @media only screen and (max-width: $mobile) { + margin-bottom: 40px; + } +} \ No newline at end of file diff --git a/favicon.ico b/favicon.ico new file mode 100644 index 0000000..bef6f21 Binary files /dev/null and b/favicon.ico differ diff --git a/images/banner-404.jpg b/images/banner-404.jpg new file mode 100644 index 0000000..98072b2 Binary files /dev/null and b/images/banner-404.jpg differ diff --git a/images/banner-finalmente-um-blog.jpg b/images/banner-finalmente-um-blog.jpg new file mode 100644 index 0000000..9455489 Binary files /dev/null and b/images/banner-finalmente-um-blog.jpg differ diff --git a/images/banner-home.jpg b/images/banner-home.jpg new file mode 100644 index 0000000..caed374 Binary files /dev/null and b/images/banner-home.jpg differ diff --git a/images/banner-projetos.jpg b/images/banner-projetos.jpg new file mode 100644 index 0000000..ea17518 Binary files /dev/null and b/images/banner-projetos.jpg differ diff --git a/images/banner-sobre-mim.jpg b/images/banner-sobre-mim.jpg new file mode 100644 index 0000000..baa0135 Binary files /dev/null and b/images/banner-sobre-mim.jpg differ diff --git a/images/logo.png b/images/logo.png new file mode 100644 index 0000000..2df8bfd Binary files /dev/null and b/images/logo.png differ diff --git a/index.html b/index.html new file mode 100755 index 0000000..850af9d --- /dev/null +++ b/index.html @@ -0,0 +1,25 @@ +--- +layout: default +--- +{% include hero.html %} + +
+
+
+ {% if site.posts.size > 0 %} +

Últimas Publicações

+ {% endif %} +
+
+
+ +
+
+ {% if site.posts.size > 0 %} + {% for post in paginator.posts %} + {% include article-content.html %} + {% endfor %} + {% endif %} +
+
+{% include pagination.html %} diff --git a/js/common.js b/js/common.js new file mode 100755 index 0000000..5b0d4aa --- /dev/null +++ b/js/common.js @@ -0,0 +1,102 @@ +$(document).ready(function() { + 'use strict'; + + var headerOverlay = $(".header__overlay"), + menuOpenIcon = $(".nav__icon-menu"), + menuCloseIcon = $(".nav-icon__close"), + menuList = $(".main-nav"), + searchOpenIcon = $(".nav__icon-search"), + searchCloseIcon = $(".search__close"), + searchBox = $(".search"); + + /* ======================= + // Menu and Search + ======================= */ + menuOpenIcon.click(function() { + menuOpen(); + }) + + menuCloseIcon.click(function () { + menuClose(); + }) + + searchOpenIcon.click(function () { + searchOpen(); + }); + + searchCloseIcon.click(function () { + searchClose(); + }); + + headerOverlay.click(function () { + menuClose(); + searchClose(); + }); + + function menuOpen() { + menuList.addClass("is-open"); + headerOverlay.addClass("is-visible"); + } + + function menuClose() { + menuList.removeClass("is-open"); + headerOverlay.removeClass("is-visible"); + } + + function searchOpen() { + searchBox.addClass("is-visible"); + } + + function searchClose() { + searchBox.removeClass("is-visible"); + } + + /* ======================= + // Responsive Videos + ======================= */ + $(".post__content, .page__content").fitVids({ + customSelector: ['iframe[src*="ted.com"]'] + }); + + /* ======================= + // Zoom Image + ======================= */ + $(".page img, .post img").attr("data-action", "zoom"); + $(".page a img, .post a img").removeAttr("data-action", "zoom"); + + /* ======================= + // Instagram Feed + ======================= */ + // userId and accessToken from Matthew Elsom (https://codepen.io/matthewelsom/pen/zrrrLN) for example, for which he thanks a lot! + var instagramFeed = new Instafeed({ + get: 'user', + limit: 6, + resolution: 'standard_resolution', + userId: '8987997106', + accessToken: '8987997106.924f677.8555ecbd52584f41b9b22ec1a16dafb9', + template: + '
  • {{caption}}
  • ' + }); + + if ($('#instafeed').length) { + instagramFeed.run(); + } + + /* ======================= + // Scroll Top Button + ======================= */ + $(".top").click(function() { + $("html, body") + .stop() + .animate({ scrollTop: 0 }, "slow", "swing"); + }); + $(window).scroll(function() { + if ($(this).scrollTop() > $(window).height()) { + $(".top").addClass("is-active"); + } else { + $(".top").removeClass("is-active"); + } + }); + + +}); \ No newline at end of file diff --git a/js/vendors/instafeed.min.js b/js/vendors/instafeed.min.js new file mode 100755 index 0000000..62d8662 --- /dev/null +++ b/js/vendors/instafeed.min.js @@ -0,0 +1,2 @@ +// Generated by CoffeeScript 1.9.3 +(function(){var e;e=function(){function e(e,t){var n,r;this.options={target:"instafeed",get:"popular",resolution:"thumbnail",sortBy:"none",links:!0,mock:!1,useHttp:!1};if(typeof e=="object")for(n in e)r=e[n],this.options[n]=r;this.context=t!=null?t:this,this.unique=this._genKey()}return e.prototype.hasNext=function(){return typeof this.context.nextUrl=="string"&&this.context.nextUrl.length>0},e.prototype.next=function(){return this.hasNext()?this.run(this.context.nextUrl):!1},e.prototype.run=function(t){var n,r,i;if(typeof this.options.clientId!="string"&&typeof this.options.accessToken!="string")throw new Error("Missing clientId or accessToken.");if(typeof this.options.accessToken!="string"&&typeof this.options.clientId!="string")throw new Error("Missing clientId or accessToken.");return this.options.before!=null&&typeof this.options.before=="function"&&this.options.before.call(this),typeof document!="undefined"&&document!==null&&(i=document.createElement("script"),i.id="instafeed-fetcher",i.src=t||this._buildUrl(),n=document.getElementsByTagName("head"),n[0].appendChild(i),r="instafeedCache"+this.unique,window[r]=new e(this.options,this),window[r].unique=this.unique),!0},e.prototype.parse=function(e){var t,n,r,i,s,o,u,a,f,l,c,h,p,d,v,m,g,y,b,w,E,S,x,T,N,C,k,L,A,O,M,_,D;if(typeof e!="object"){if(this.options.error!=null&&typeof this.options.error=="function")return this.options.error.call(this,"Invalid JSON data"),!1;throw new Error("Invalid JSON response")}if(e.meta.code!==200){if(this.options.error!=null&&typeof this.options.error=="function")return this.options.error.call(this,e.meta.error_message),!1;throw new Error("Error from Instagram: "+e.meta.error_message)}if(e.data.length===0){if(this.options.error!=null&&typeof this.options.error=="function")return this.options.error.call(this,"No images were returned from Instagram"),!1;throw new Error("No images were returned from Instagram")}this.options.success!=null&&typeof this.options.success=="function"&&this.options.success.call(this,e),this.context.nextUrl="",e.pagination!=null&&(this.context.nextUrl=e.pagination.next_url);if(this.options.sortBy!=="none"){this.options.sortBy==="random"?M=["","random"]:M=this.options.sortBy.split("-"),O=M[0]==="least"?!0:!1;switch(M[1]){case"random":e.data.sort(function(){return.5-Math.random()});break;case"recent":e.data=this._sortBy(e.data,"created_time",O);break;case"liked":e.data=this._sortBy(e.data,"likes.count",O);break;case"commented":e.data=this._sortBy(e.data,"comments.count",O);break;default:throw new Error("Invalid option for sortBy: '"+this.options.sortBy+"'.")}}if(typeof document!="undefined"&&document!==null&&this.options.mock===!1){m=e.data,A=parseInt(this.options.limit,10),this.options.limit!=null&&m.length>A&&(m=m.slice(0,A)),u=document.createDocumentFragment(),this.options.filter!=null&&typeof this.options.filter=="function"&&(m=this._filter(m,this.options.filter));if(this.options.template!=null&&typeof this.options.template=="string"){f="",d="",w="",D=document.createElement("div");for(c=0,N=m.length;cy&&(b="landscape"),E=0,l&&!this.options.useHttp&&(v=v.replace(/https?:\/\//,"//")),d=this._makeTemplate(this.options.template,{model:h,id:h.id,link:h.link,type:h.type,image:v,width:E,height:y,orientation:b,caption:this._getObjectProperty(h,"caption.text"),likes:h.likes.count,comments:h.comments.count,location:this._getObjectProperty(h,"location.name")}),f+=d}D.innerHTML=f,i=[],r=0,n=D.childNodes.length;while(r=0,l&&!this.options.useHttp&&(v=v.replace(/https?:\/\//,"//")),g.src=v,this.options.links===!0?(t=document.createElement("a"),t.href=h.link,t.appendChild(g),u.appendChild(t)):u.appendChild(g)}_=this.options.target,typeof _=="string"&&(_=document.getElementById(_));if(_==null)throw o='No element with id="'+this.options.target+'" on page.',new Error(o);_.appendChild(u),a=document.getElementsByTagName("head")[0],a.removeChild(document.getElementById("instafeed-fetcher")),S="instafeedCache"+this.unique,window[S]=void 0;try{delete window[S]}catch(P){s=P}}return this.options.after!=null&&typeof this.options.after=="function"&&this.options.after.call(this),!0},e.prototype._buildUrl=function(){var e,t,n;e="https://api.instagram.com/v1";switch(this.options.get){case"popular":t="media/popular";break;case"tagged":if(!this.options.tagName)throw new Error("No tag name specified. Use the 'tagName' option.");t="tags/"+this.options.tagName+"/media/recent";break;case"location":if(!this.options.locationId)throw new Error("No location specified. Use the 'locationId' option.");t="locations/"+this.options.locationId+"/media/recent";break;case"user":if(!this.options.userId)throw new Error("No user specified. Use the 'userId' option.");t="users/"+this.options.userId+"/media/recent";break;default:throw new Error("Invalid option for get: '"+this.options.get+"'.")}return n=e+"/"+t,this.options.accessToken!=null?n+="?access_token="+this.options.accessToken:n+="?client_id="+this.options.clientId,this.options.limit!=null&&(n+="&count="+this.options.limit),n+="&callback=instafeedCache"+this.unique+".parse",n},e.prototype._genKey=function(){var e;return e=function(){return((1+Math.random())*65536|0).toString(16).substring(1)},""+e()+e()+e()+e()},e.prototype._makeTemplate=function(e,t){var n,r,i,s,o;r=/(?:\{{2})([\w\[\]\.]+)(?:\}{2})/,n=e;while(r.test(n))s=n.match(r)[1],o=(i=this._getObjectProperty(t,s))!=null?i:"",n=n.replace(r,function(){return""+o});return n},e.prototype._getObjectProperty=function(e,t){var n,r;t=t.replace(/\[(\w+)\]/g,".$1"),r=t.split(".");while(r.length){n=r.shift();if(!(e!=null&&n in e))return null;e=e[n]}return e},e.prototype._sortBy=function(e,t,n){var r;return r=function(e,r){var i,s;return i=this._getObjectProperty(e,t),s=this._getObjectProperty(r,t),n?i>s?1:-1:i=0&&n0&&t-1 in e)}var E=function(e){var t,n,r,i,o,a,s,u,l,c,f,p,d,h,g,y,v,m,x,b="sizzle"+1*new Date,w=e.document,T=0,C=0,E=ae(),k=ae(),S=ae(),D=function(e,t){return e===t&&(f=!0),0},N={}.hasOwnProperty,A=[],j=A.pop,q=A.push,L=A.push,H=A.slice,O=function(e,t){for(var n=0,r=e.length;n+~]|"+M+")"+M+"*"),z=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),X=new RegExp(W),U=new RegExp("^"+R+"$"),V={ID:new RegExp("^#("+R+")"),CLASS:new RegExp("^\\.("+R+")"),TAG:new RegExp("^("+R+"|[*])"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Q=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/[+~]/,Z=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ee=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},te=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ne=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},re=function(){p()},ie=me(function(e){return!0===e.disabled&&("form"in e||"label"in e)},{dir:"parentNode",next:"legend"});try{L.apply(A=H.call(w.childNodes),w.childNodes),A[w.childNodes.length].nodeType}catch(e){L={apply:A.length?function(e,t){q.apply(e,H.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function oe(e,t,r,i){var o,s,l,c,f,h,v,m=t&&t.ownerDocument,T=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==T&&9!==T&&11!==T)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&p(t),t=t||d,g)){if(11!==T&&(f=J.exec(e)))if(o=f[1]){if(9===T){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return L.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!S[e+" "]&&(!y||!y.test(e))){if(1!==T)m=t,v=e;else if("object"!==t.nodeName.toLowerCase()){(c=t.getAttribute("id"))?c=c.replace(te,ne):t.setAttribute("id",c=b),s=(h=a(e)).length;while(s--)h[s]="#"+c+" "+ve(h[s]);v=h.join(","),m=K.test(e)&&ge(t.parentNode)||t}if(v)try{return L.apply(r,m.querySelectorAll(v)),r}catch(e){}finally{c===b&&t.removeAttribute("id")}}}return u(e.replace(B,"$1"),t,r,i)}function ae(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[b]=!0,e}function ue(e){var t=d.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function le(e,t){var n=e.split("|"),i=n.length;while(i--)r.attrHandle[n[i]]=t}function ce(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function de(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ie(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function he(e){return se(function(t){return t=+t,se(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}function ge(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}n=oe.support={},o=oe.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},p=oe.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!==d&&9===a.nodeType&&a.documentElement?(d=a,h=d.documentElement,g=!o(d),w!==d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ue(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ue(function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=Q.test(d.getElementsByClassName),n.getById=ue(function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length}),n.getById?(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){return e.getAttribute("id")===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){var n="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&g)return t.getElementsByClassName(e)},v=[],y=[],(n.qsa=Q.test(d.querySelectorAll))&&(ue(function(e){h.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+P+")"),e.querySelectorAll("[id~="+b+"-]").length||y.push("~="),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+b+"+*").length||y.push(".#.+[+~]")}),ue(function(e){e.innerHTML="";var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(n.matchesSelector=Q.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ue(function(e){n.disconnectedMatch=m.call(e,"*"),m.call(e,"[s!='']:x"),v.push("!=",W)}),y=y.length&&new RegExp(y.join("|")),v=v.length&&new RegExp(v.join("|")),t=Q.test(h.compareDocumentPosition),x=t||Q.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&x(w,e)?-1:t===d||t.ownerDocument===w&&x(w,t)?1:c?O(c,e)-O(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?O(c,e)-O(c,t):0;if(i===o)return ce(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?ce(a[r],s[r]):a[r]===w?-1:s[r]===w?1:0},d):d},oe.matches=function(e,t){return oe(e,null,null,t)},oe.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&p(e),t=t.replace(z,"='$1']"),n.matchesSelector&&g&&!S[t+" "]&&(!v||!v.test(t))&&(!y||!y.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){}return oe(t,d,null,[e]).length>0},oe.contains=function(e,t){return(e.ownerDocument||e)!==d&&p(e),x(e,t)},oe.attr=function(e,t){(e.ownerDocument||e)!==d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&N.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},oe.escape=function(e){return(e+"").replace(te,ne)},oe.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},oe.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(D),f){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return c=null,e},i=oe.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else while(t=e[r++])n+=i(t);return n},(r=oe.selectors={cacheLength:50,createPseudo:se,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(Z,ee),e[3]=(e[3]||e[4]||e[5]||"").replace(Z,ee),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||oe.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&oe.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return V.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(Z,ee).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&E(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=oe.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace($," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?"nextSibling":"previousSibling",y=t.parentNode,v=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(y){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===v:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?y.firstChild:y.lastChild],a&&m){x=(d=(l=(c=(f=(p=y)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&y.childNodes[d];while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===v:1===p.nodeType)&&++x&&(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p===t))break;return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||oe.error("unsupported pseudo: "+e);return i[b]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se(function(e,n){var r,o=i(e,t),a=o.length;while(a--)e[r=O(e,o[a])]=!(n[r]=o[a])}):function(e){return i(e,0,n)}):i}},pseudos:{not:se(function(e){var t=[],n=[],r=s(e.replace(B,"$1"));return r[b]?se(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}}),has:se(function(e){return function(t){return oe(e,t).length>0}}),contains:se(function(e){return e=e.replace(Z,ee),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:se(function(e){return U.test(e||"")||oe.error("unsupported lang: "+e),e=e.replace(Z,ee).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:de(!1),disabled:de(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Y.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he(function(){return[0]}),last:he(function(e,t){return[t-1]}),eq:he(function(e,t,n){return[n<0?n+t:n]}),even:he(function(e,t){for(var n=0;n=0;)e.push(r);return e}),gt:he(function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function be(e,t,n){for(var r=0,i=t.length;r-1&&(o[l]=!(a[l]=f))}}else v=we(v===a?v.splice(h,v.length):v),i?i(null,a,v,u):L.apply(a,v)})}function Ce(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[" "],u=a?1:0,c=me(function(e){return e===t},s,!0),f=me(function(e){return O(t,e)>-1},s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&xe(p),u>1&&ve(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(B,"$1"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,y,v=0,m="0",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG("*",c),E=T+=null==w?1:Math.random()||.1,k=C.length;for(c&&(l=a===d||a||c);m!==k&&null!=(f=C[m]);m++){if(i&&f){h=0,a||f.ownerDocument===d||(p(f),s=!g);while(y=e[h++])if(y(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!y&&f)&&v--,o&&x.push(f))}if(v+=m,n&&m!==v){h=0;while(y=t[h++])y(x,b,a,s);if(o){if(v>0)while(m--)x[m]||b[m]||(b[m]=j.call(u));b=we(b)}L.apply(u,b),c&&!o&&b.length>0&&v+t.length>1&&oe.uniqueSort(u)}return c&&(T=E,l=w),x};return n?se(o):o}return s=oe.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=a(e)),n=t.length;while(n--)(o=Ce(t[n]))[b]?r.push(o):i.push(o);(o=S(e,Ee(i,r))).selector=e}return o},u=oe.select=function(e,t,n,i){var o,u,l,c,f,p="function"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&"ID"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(Z,ee),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}o=V.needsContext.test(e)?0:u.length;while(o--){if(l=u[o],r.relative[c=l.type])break;if((f=r.find[c])&&(i=f(l.matches[0].replace(Z,ee),K.test(u[0].type)&&ge(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&ve(u)))return L.apply(n,i),n;break}}}return(p||s(e,d))(i,t,!g,n,!t||K.test(e)&&ge(t.parentNode)||t),n},n.sortStable=b.split("").sort(D).join("")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ue(function(e){return 1&e.compareDocumentPosition(d.createElement("fieldset"))}),ue(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||le("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ue(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||le("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ue(function(e){return null==e.getAttribute("disabled")})||le(P,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),oe}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var k=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},D=w.expr.match.needsContext;function N(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var A=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,t,n){return g(t)?w.grep(e,function(e,r){return!!t.call(e,r,e)!==n}):t.nodeType?w.grep(e,function(e){return e===t!==n}):"string"!=typeof t?w.grep(e,function(e){return u.call(t,e)>-1!==n}):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,function(e){return 1===e.nodeType}))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(w(e).filter(function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&D.test(e)?w(e):e||[],!1).length}});var q,L=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:L.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),A.test(i[1])&&w.isPlainObject(t))for(i in t)g(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):g(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,q=w(r);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter(function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?u.call(w(e),this[0]):u.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return k(e,"parentNode")},parentsUntil:function(e,t,n){return k(e,"parentNode",n)},next:function(e){return P(e,"nextSibling")},prev:function(e){return P(e,"previousSibling")},nextAll:function(e){return k(e,"nextSibling")},prevAll:function(e){return k(e,"previousSibling")},nextUntil:function(e,t,n){return k(e,"nextSibling",n)},prevUntil:function(e,t,n){return k(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return N(e,"iframe")?e.contentDocument:(N(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=w.filter(r,i)),this.length>1&&(O[e]||w.uniqueSort(i),H.test(e)&&i.reverse()),this.pushStack(i)}});var M=/[^\x20\t\r\n\f]+/g;function R(e){var t={};return w.each(e.match(M)||[],function(e,n){t[n]=!0}),t}w.Callbacks=function(e){e="string"==typeof e?R(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1){n=a.shift();while(++s-1)o.splice(n,1),n<=s&&s--}),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l};function I(e){return e}function W(e){throw e}function $(e,t,n,r){var i;try{e&&g(i=e.promise)?i.call(e).done(t).fail(n):e&&g(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},"catch":function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred(function(t){w.each(n,function(n,r){var i=g(e[r[4]])&&e[r[4]];o[r[1]](function(){var e=i&&i.apply(this,arguments);e&&g(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+"With"](this,i?[e]:arguments)})}),e=null}).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==W&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred(function(e){n[0][3].add(a(0,e,g(i)?i:I,e.notifyWith)),n[1][3].add(a(0,e,g(t)?t:I)),n[2][3].add(a(0,e,g(r)?r:W))}).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add(function(){r=s},n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+"With"](this===o?void 0:this,arguments),this},o[t[0]+"With"]=a.fireWith}),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=o.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?o.call(arguments):n,--t||a.resolveWith(r,i)}};if(t<=1&&($(e,a.done(s(n)).resolve,a.reject,!t),"pending"===a.state()||g(i[n]&&i[n].then)))return a.then();while(n--)$(i[n],s(n),a.reject);return a.promise()}});var B=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&B.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout(function(){throw t})};var F=w.Deferred();w.fn.ready=function(e){return F.then(e)["catch"](function(e){w.readyException(e)}),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(r,[w]))}}),w.ready.then=F.then;function _(){r.removeEventListener("DOMContentLoaded",_),e.removeEventListener("load",_),w.ready()}"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(w.ready):(r.addEventListener("DOMContentLoaded",_),e.addEventListener("load",_));var z=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===x(n)){i=!0;for(s in n)z(e,t,s,n[s],!0,o,a)}else if(void 0!==r&&(i=!0,g(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each(function(){K.remove(this,e)})}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=J.get(e,t),n&&(!r||Array.isArray(n)?r=J.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t),a=function(){w.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return J.get(e,n)||J.access(e,n,{empty:w.Callbacks("once memory").add(function(){J.remove(e,[t+"queue",n])})})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]+)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""],thead:[1,"","
    "],col:[2,"","
    "],tr:[2,"","
    "],td:[3,"","
    "],_default:[0,"",""]};ge.optgroup=ge.option,ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td;function ye(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&N(e,t)?w.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n-1)i&&i.push(o);else if(l=w.contains(o.ownerDocument,o),a=ye(f.appendChild(o),"script"),l&&ve(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}!function(){var e=r.createDocumentFragment().appendChild(r.createElement("div")),t=r.createElement("input");t.setAttribute("type","radio"),t.setAttribute("checked","checked"),t.setAttribute("name","t"),e.appendChild(t),h.checkClone=e.cloneNode(!0).cloneNode(!0).lastChild.checked,e.innerHTML="",h.noCloneChecked=!!e.cloneNode(!0).lastChild.defaultValue}();var be=r.documentElement,we=/^key/,Te=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ce=/^([^.]*)(?:\.(.+)|)/;function Ee(){return!0}function ke(){return!1}function Se(){try{return r.activeElement}catch(e){}}function De(e,t,n,r,i,o){var a,s;if("object"==typeof t){"string"!=typeof n&&(r=r||n,n=void 0);for(s in t)De(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=ke;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return w().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=w.guid++)),e.each(function(){w.event.add(this,t,i,r,n)})}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.get(e);if(y){n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(be,i),n.guid||(n.guid=w.guid++),(u=y.events)||(u=y.events={}),(a=y.handle)||(a=y.handle=function(t){return"undefined"!=typeof w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||"").match(M)||[""]).length;while(l--)d=g=(s=Ce.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.hasData(e)&&J.get(e);if(y&&(u=y.events)){l=(t=(t||"").match(M)||[""]).length;while(l--)if(s=Ce.exec(t[l])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,y.handle)||w.removeEvent(e,d,y.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&J.remove(e,"handle events")}},dispatch:function(e){var t=w.event.fix(e),n,r,i,o,a,s,u=new Array(arguments.length),l=(J.get(this,"events")||{})[t.type]||[],c=w.event.special[t.type]||{};for(u[0]=t,n=1;n=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\x20\t\r\n\f]*)[^>]*)\/>/gi,Ae=/\s*$/g;function Le(e,t){return N(e,"table")&&N(11!==t.nodeType?t:t.firstChild,"tr")?w(e).children("tbody")[0]||e:e}function He(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function Oe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Pe(e,t){var n,r,i,o,a,s,u,l;if(1===t.nodeType){if(J.hasData(e)&&(o=J.access(e),a=J.set(t,o),l=o.events)){delete a.handle,a.events={};for(i in l)for(n=0,r=l[i].length;n1&&"string"==typeof y&&!h.checkClone&&je.test(y))return e.each(function(i){var o=e.eq(i);v&&(t[0]=y.call(this,i,o.html())),Re(o,t,n,r)});if(p&&(i=xe(t,e[0].ownerDocument,!1,e,r),o=i.firstChild,1===i.childNodes.length&&(i=o),o||r)){for(u=(s=w.map(ye(i,"script"),He)).length;f")},clone:function(e,t,n){var r,i,o,a,s=e.cloneNode(!0),u=w.contains(e.ownerDocument,e);if(!(h.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||w.isXMLDoc(e)))for(a=ye(s),r=0,i=(o=ye(e)).length;r0&&ve(a,!u&&ye(e,"script")),s},cleanData:function(e){for(var t,n,r,i=w.event.special,o=0;void 0!==(n=e[o]);o++)if(Y(n)){if(t=n[J.expando]){if(t.events)for(r in t.events)i[r]?w.event.remove(n,r):w.removeEvent(n,r,t.handle);n[J.expando]=void 0}n[K.expando]&&(n[K.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Ie(this,e,!0)},remove:function(e){return Ie(this,e)},text:function(e){return z(this,function(e){return void 0===e?w.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Re(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||Le(this,e).appendChild(e)})},prepend:function(){return Re(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Le(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ye(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return w.clone(this,e,t)})},html:function(e){return z(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ae.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))),u}function et(e,t,n){var r=$e(e),i=Fe(e,t,r),o="border-box"===w.css(e,"boxSizing",!1,r),a=o;if(We.test(i)){if(!n)return i;i="auto"}return a=a&&(h.boxSizingReliable()||i===e.style[t]),("auto"===i||!parseFloat(i)&&"inline"===w.css(e,"display",!1,r))&&(i=e["offset"+t[0].toUpperCase()+t.slice(1)],a=!0),(i=parseFloat(i)||0)+Ze(e,t,n||(o?"border":"content"),a,r,i)+"px"}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Fe(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,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:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=G(t),u=Xe.test(t),l=e.style;if(u||(t=Je(s)),a=w.cssHooks[t]||w.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"==(o=typeof n)&&(i=ie.exec(n))&&i[1]&&(n=ue(e,t,i),o="number"),null!=n&&n===n&&("number"===o&&(n+=i&&i[3]||(w.cssNumber[s]?"":"px")),h.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=G(t);return Xe.test(t)||(t=Je(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Fe(e,t,r)),"normal"===i&&t in Ve&&(i=Ve[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),w.each(["height","width"],function(e,t){w.cssHooks[t]={get:function(e,n,r){if(n)return!ze.test(w.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?et(e,t,r):se(e,Ue,function(){return et(e,t,r)})},set:function(e,n,r){var i,o=$e(e),a="border-box"===w.css(e,"boxSizing",!1,o),s=r&&Ze(e,t,r,a,o);return a&&h.scrollboxSize()===o.position&&(s-=Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-Ze(e,t,"border",!1,o)-.5)),s&&(i=ie.exec(n))&&"px"!==(i[3]||"px")&&(e.style[t]=n,n=w.css(e,t)),Ke(e,n,s)}}}),w.cssHooks.marginLeft=_e(h.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Fe(e,"marginLeft"))||e.getBoundingClientRect().left-se(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),w.each({margin:"",padding:"",border:"Width"},function(e,t){w.cssHooks[e+t]={expand:function(n){for(var r=0,i={},o="string"==typeof n?n.split(" "):[n];r<4;r++)i[e+oe[r]+t]=o[r]||o[r-2]||o[0];return i}},"margin"!==e&&(w.cssHooks[e+t].set=Ke)}),w.fn.extend({css:function(e,t){return z(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=$e(e),i=t.length;a1)}});function tt(e,t,n,r,i){return new tt.prototype.init(e,t,n,r,i)}w.Tween=tt,tt.prototype={constructor:tt,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||w.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(w.cssNumber[n]?"":"px")},cur:function(){var e=tt.propHooks[this.prop];return e&&e.get?e.get(this):tt.propHooks._default.get(this)},run:function(e){var t,n=tt.propHooks[this.prop];return this.options.duration?this.pos=t=w.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):tt.propHooks._default.set(this),this}},tt.prototype.init.prototype=tt.prototype,tt.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=w.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){w.fx.step[e.prop]?w.fx.step[e.prop](e):1!==e.elem.nodeType||null==e.elem.style[w.cssProps[e.prop]]&&!w.cssHooks[e.prop]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},tt.propHooks.scrollTop=tt.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},w.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},w.fx=tt.prototype.init,w.fx.step={};var nt,rt,it=/^(?:toggle|show|hide)$/,ot=/queueHooks$/;function at(){rt&&(!1===r.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(at):e.setTimeout(at,w.fx.interval),w.fx.tick())}function st(){return e.setTimeout(function(){nt=void 0}),nt=Date.now()}function ut(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=oe[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function lt(e,t,n){for(var r,i=(pt.tweeners[t]||[]).concat(pt.tweeners["*"]),o=0,a=i.length;o1)},removeAttr:function(e){return this.each(function(){w.removeAttr(this,e)})}}),w.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?w.prop(e,t,n):(1===o&&w.isXMLDoc(e)||(i=w.attrHooks[t.toLowerCase()]||(w.expr.match.bool.test(t)?dt:void 0)),void 0!==n?null===n?void w.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=w.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!h.radioValue&&"radio"===t&&N(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(M);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),dt={set:function(e,t,n){return!1===t?w.removeAttr(e,n):e.setAttribute(n,n),n}},w.each(w.expr.match.bool.source.match(/\w+/g),function(e,t){var n=ht[t]||w.find.attr;ht[t]=function(e,t,r){var i,o,a=t.toLowerCase();return r||(o=ht[a],ht[a]=i,i=null!=n(e,t,r)?a:null,ht[a]=o),i}});var gt=/^(?:input|select|textarea|button)$/i,yt=/^(?:a|area)$/i;w.fn.extend({prop:function(e,t){return z(this,w.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[w.propFix[e]||e]})}}),w.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&w.isXMLDoc(e)||(t=w.propFix[t]||t,i=w.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=w.find.attr(e,"tabindex");return t?parseInt(t,10):gt.test(e.nodeName)||yt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),h.optSelected||(w.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),w.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){w.propFix[this.toLowerCase()]=this});function vt(e){return(e.match(M)||[]).join(" ")}function mt(e){return e.getAttribute&&e.getAttribute("class")||""}function xt(e){return Array.isArray(e)?e:"string"==typeof e?e.match(M)||[]:[]}w.fn.extend({addClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).addClass(e.call(this,t,mt(this)))});if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).removeClass(e.call(this,t,mt(this)))});if(!arguments.length)return this.attr("class","");if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])while(r.indexOf(" "+o+" ")>-1)r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(e,t){var n=typeof e,r="string"===n||Array.isArray(e);return"boolean"==typeof t&&r?t?this.addClass(e):this.removeClass(e):g(e)?this.each(function(n){w(this).toggleClass(e.call(this,n,mt(this),t),t)}):this.each(function(){var t,i,o,a;if(r){i=0,o=w(this),a=xt(e);while(t=a[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else void 0!==e&&"boolean"!==n||((t=mt(this))&&J.set(this,"__className__",t),this.setAttribute&&this.setAttribute("class",t||!1===e?"":J.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&(" "+vt(mt(n))+" ").indexOf(t)>-1)return!0;return!1}});var bt=/\r/g;w.fn.extend({val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=g(e),this.each(function(n){var i;1===this.nodeType&&(null==(i=r?e.call(this,n,w(this).val()):e)?i="":"number"==typeof i?i+="":Array.isArray(i)&&(i=w.map(i,function(e){return null==e?"":e+""})),(t=w.valHooks[this.type]||w.valHooks[this.nodeName.toLowerCase()])&&"set"in t&&void 0!==t.set(this,i,"value")||(this.value=i))});if(i)return(t=w.valHooks[i.type]||w.valHooks[i.nodeName.toLowerCase()])&&"get"in t&&void 0!==(n=t.get(i,"value"))?n:"string"==typeof(n=i.value)?n.replace(bt,""):null==n?"":n}}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,"value");return null!=t?t:vt(w.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),w.each(["radio","checkbox"],function(){w.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=w.inArray(w(e).val(),t)>-1}},h.checkOn||(w.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),h.focusin="onfocusin"in e;var wt=/^(?:focusinfocus|focusoutblur)$/,Tt=function(e){e.stopPropagation()};w.extend(w.event,{trigger:function(t,n,i,o){var a,s,u,l,c,p,d,h,v=[i||r],m=f.call(t,"type")?t.type:t,x=f.call(t,"namespace")?t.namespace.split("."):[];if(s=h=u=i=i||r,3!==i.nodeType&&8!==i.nodeType&&!wt.test(m+w.event.triggered)&&(m.indexOf(".")>-1&&(m=(x=m.split(".")).shift(),x.sort()),c=m.indexOf(":")<0&&"on"+m,t=t[w.expando]?t:new w.Event(m,"object"==typeof t&&t),t.isTrigger=o?2:3,t.namespace=x.join("."),t.rnamespace=t.namespace?new RegExp("(^|\\.)"+x.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=void 0,t.target||(t.target=i),n=null==n?[t]:w.makeArray(n,[t]),d=w.event.special[m]||{},o||!d.trigger||!1!==d.trigger.apply(i,n))){if(!o&&!d.noBubble&&!y(i)){for(l=d.delegateType||m,wt.test(l+m)||(s=s.parentNode);s;s=s.parentNode)v.push(s),u=s;u===(i.ownerDocument||r)&&v.push(u.defaultView||u.parentWindow||e)}a=0;while((s=v[a++])&&!t.isPropagationStopped())h=s,t.type=a>1?l:d.bindType||m,(p=(J.get(s,"events")||{})[t.type]&&J.get(s,"handle"))&&p.apply(s,n),(p=c&&s[c])&&p.apply&&Y(s)&&(t.result=p.apply(s,n),!1===t.result&&t.preventDefault());return t.type=m,o||t.isDefaultPrevented()||d._default&&!1!==d._default.apply(v.pop(),n)||!Y(i)||c&&g(i[m])&&!y(i)&&((u=i[c])&&(i[c]=null),w.event.triggered=m,t.isPropagationStopped()&&h.addEventListener(m,Tt),i[m](),t.isPropagationStopped()&&h.removeEventListener(m,Tt),w.event.triggered=void 0,u&&(i[c]=u)),t.result}},simulate:function(e,t,n){var r=w.extend(new w.Event,n,{type:e,isSimulated:!0});w.event.trigger(r,null,t)}}),w.fn.extend({trigger:function(e,t){return this.each(function(){w.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return w.event.trigger(e,t,n,!0)}}),h.focusin||w.each({focus:"focusin",blur:"focusout"},function(e,t){var n=function(e){w.event.simulate(t,e.target,w.event.fix(e))};w.event.special[t]={setup:function(){var r=this.ownerDocument||this,i=J.access(r,t);i||r.addEventListener(e,n,!0),J.access(r,t,(i||0)+1)},teardown:function(){var r=this.ownerDocument||this,i=J.access(r,t)-1;i?J.access(r,t,i):(r.removeEventListener(e,n,!0),J.remove(r,t))}}});var Ct=e.location,Et=Date.now(),kt=/\?/;w.parseXML=function(t){var n;if(!t||"string"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,"text/xml")}catch(e){n=void 0}return n&&!n.getElementsByTagName("parsererror").length||w.error("Invalid XML: "+t),n};var St=/\[\]$/,Dt=/\r?\n/g,Nt=/^(?:submit|button|image|reset|file)$/i,At=/^(?:input|select|textarea|keygen)/i;function jt(e,t,n,r){var i;if(Array.isArray(t))w.each(t,function(t,i){n||St.test(e)?r(e,i):jt(e+"["+("object"==typeof i&&null!=i?t:"")+"]",i,n,r)});else if(n||"object"!==x(t))r(e,t);else for(i in t)jt(e+"["+i+"]",t[i],n,r)}w.param=function(e,t){var n,r=[],i=function(e,t){var n=g(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(Array.isArray(e)||e.jquery&&!w.isPlainObject(e))w.each(e,function(){i(this.name,this.value)});else for(n in e)jt(n,e[n],t,i);return r.join("&")},w.fn.extend({serialize:function(){return w.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=w.prop(this,"elements");return e?w.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!w(this).is(":disabled")&&At.test(this.nodeName)&&!Nt.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=w(this).val();return null==n?null:Array.isArray(n)?w.map(n,function(e){return{name:t.name,value:e.replace(Dt,"\r\n")}}):{name:t.name,value:n.replace(Dt,"\r\n")}}).get()}});var qt=/%20/g,Lt=/#.*$/,Ht=/([?&])_=[^&]*/,Ot=/^(.*?):[ \t]*([^\r\n]*)$/gm,Pt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Mt=/^(?:GET|HEAD)$/,Rt=/^\/\//,It={},Wt={},$t="*/".concat("*"),Bt=r.createElement("a");Bt.href=Ct.href;function Ft(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(M)||[];if(g(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function _t(e,t,n,r){var i={},o=e===Wt;function a(s){var u;return i[s]=!0,w.each(e[s]||[],function(e,s){var l=s(t,n,r);return"string"!=typeof l||o||i[l]?o?!(u=l):void 0:(t.dataTypes.unshift(l),a(l),!1)}),u}return a(t.dataTypes[0])||!i["*"]&&a("*")}function zt(e,t){var n,r,i=w.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&w.extend(!0,e,r),e}function Xt(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}function Ut(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Ct.href,type:"GET",isLocal:Pt.test(Ct.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":$t,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":w.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?zt(zt(e,w.ajaxSettings),t):zt(w.ajaxSettings,e)},ajaxPrefilter:Ft(It),ajaxTransport:Ft(Wt),ajax:function(t,n){"object"==typeof t&&(n=t,t=void 0),n=n||{};var i,o,a,s,u,l,c,f,p,d,h=w.ajaxSetup({},n),g=h.context||h,y=h.context&&(g.nodeType||g.jquery)?w(g):w.event,v=w.Deferred(),m=w.Callbacks("once memory"),x=h.statusCode||{},b={},T={},C="canceled",E={readyState:0,getResponseHeader:function(e){var t;if(c){if(!s){s={};while(t=Ot.exec(a))s[t[1].toLowerCase()]=t[2]}t=s[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return c?a:null},setRequestHeader:function(e,t){return null==c&&(e=T[e.toLowerCase()]=T[e.toLowerCase()]||e,b[e]=t),this},overrideMimeType:function(e){return null==c&&(h.mimeType=e),this},statusCode:function(e){var t;if(e)if(c)E.always(e[E.status]);else for(t in e)x[t]=[x[t],e[t]];return this},abort:function(e){var t=e||C;return i&&i.abort(t),k(0,t),this}};if(v.promise(E),h.url=((t||h.url||Ct.href)+"").replace(Rt,Ct.protocol+"//"),h.type=n.method||n.type||h.method||h.type,h.dataTypes=(h.dataType||"*").toLowerCase().match(M)||[""],null==h.crossDomain){l=r.createElement("a");try{l.href=h.url,l.href=l.href,h.crossDomain=Bt.protocol+"//"+Bt.host!=l.protocol+"//"+l.host}catch(e){h.crossDomain=!0}}if(h.data&&h.processData&&"string"!=typeof h.data&&(h.data=w.param(h.data,h.traditional)),_t(It,h,n,E),c)return E;(f=w.event&&h.global)&&0==w.active++&&w.event.trigger("ajaxStart"),h.type=h.type.toUpperCase(),h.hasContent=!Mt.test(h.type),o=h.url.replace(Lt,""),h.hasContent?h.data&&h.processData&&0===(h.contentType||"").indexOf("application/x-www-form-urlencoded")&&(h.data=h.data.replace(qt,"+")):(d=h.url.slice(o.length),h.data&&(h.processData||"string"==typeof h.data)&&(o+=(kt.test(o)?"&":"?")+h.data,delete h.data),!1===h.cache&&(o=o.replace(Ht,"$1"),d=(kt.test(o)?"&":"?")+"_="+Et+++d),h.url=o+d),h.ifModified&&(w.lastModified[o]&&E.setRequestHeader("If-Modified-Since",w.lastModified[o]),w.etag[o]&&E.setRequestHeader("If-None-Match",w.etag[o])),(h.data&&h.hasContent&&!1!==h.contentType||n.contentType)&&E.setRequestHeader("Content-Type",h.contentType),E.setRequestHeader("Accept",h.dataTypes[0]&&h.accepts[h.dataTypes[0]]?h.accepts[h.dataTypes[0]]+("*"!==h.dataTypes[0]?", "+$t+"; q=0.01":""):h.accepts["*"]);for(p in h.headers)E.setRequestHeader(p,h.headers[p]);if(h.beforeSend&&(!1===h.beforeSend.call(g,E,h)||c))return E.abort();if(C="abort",m.add(h.complete),E.done(h.success),E.fail(h.error),i=_t(Wt,h,n,E)){if(E.readyState=1,f&&y.trigger("ajaxSend",[E,h]),c)return E;h.async&&h.timeout>0&&(u=e.setTimeout(function(){E.abort("timeout")},h.timeout));try{c=!1,i.send(b,k)}catch(e){if(c)throw e;k(-1,e)}}else k(-1,"No Transport");function k(t,n,r,s){var l,p,d,b,T,C=n;c||(c=!0,u&&e.clearTimeout(u),i=void 0,a=s||"",E.readyState=t>0?4:0,l=t>=200&&t<300||304===t,r&&(b=Xt(h,E,r)),b=Ut(h,b,E,l),l?(h.ifModified&&((T=E.getResponseHeader("Last-Modified"))&&(w.lastModified[o]=T),(T=E.getResponseHeader("etag"))&&(w.etag[o]=T)),204===t||"HEAD"===h.type?C="nocontent":304===t?C="notmodified":(C=b.state,p=b.data,l=!(d=b.error))):(d=C,!t&&C||(C="error",t<0&&(t=0))),E.status=t,E.statusText=(n||C)+"",l?v.resolveWith(g,[p,C,E]):v.rejectWith(g,[E,C,d]),E.statusCode(x),x=void 0,f&&y.trigger(l?"ajaxSuccess":"ajaxError",[E,h,l?p:d]),m.fireWith(g,[E,C]),f&&(y.trigger("ajaxComplete",[E,h]),--w.active||w.event.trigger("ajaxStop")))}return E},getJSON:function(e,t,n){return w.get(e,t,n,"json")},getScript:function(e,t){return w.get(e,void 0,t,"script")}}),w.each(["get","post"],function(e,t){w[t]=function(e,n,r,i){return g(n)&&(i=i||r,r=n,n=void 0),w.ajax(w.extend({url:e,type:t,dataType:i,data:n,success:r},w.isPlainObject(e)&&e))}}),w._evalUrl=function(e){return w.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},w.fn.extend({wrapAll:function(e){var t;return this[0]&&(g(e)&&(e=e.call(this[0])),t=w(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(e){return g(e)?this.each(function(t){w(this).wrapInner(e.call(this,t))}):this.each(function(){var t=w(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=g(e);return this.each(function(n){w(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(e){return this.parent(e).not("body").each(function(){w(this).replaceWith(this.childNodes)}),this}}),w.expr.pseudos.hidden=function(e){return!w.expr.pseudos.visible(e)},w.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},w.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(e){}};var Vt={0:200,1223:204},Gt=w.ajaxSettings.xhr();h.cors=!!Gt&&"withCredentials"in Gt,h.ajax=Gt=!!Gt,w.ajaxTransport(function(t){var n,r;if(h.cors||Gt&&!t.crossDomain)return{send:function(i,o){var a,s=t.xhr();if(s.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(a in t.xhrFields)s[a]=t.xhrFields[a];t.mimeType&&s.overrideMimeType&&s.overrideMimeType(t.mimeType),t.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");for(a in i)s.setRequestHeader(a,i[a]);n=function(e){return function(){n&&(n=r=s.onload=s.onerror=s.onabort=s.ontimeout=s.onreadystatechange=null,"abort"===e?s.abort():"error"===e?"number"!=typeof s.status?o(0,"error"):o(s.status,s.statusText):o(Vt[s.status]||s.status,s.statusText,"text"!==(s.responseType||"text")||"string"!=typeof s.responseText?{binary:s.response}:{text:s.responseText},s.getAllResponseHeaders()))}},s.onload=n(),r=s.onerror=s.ontimeout=n("error"),void 0!==s.onabort?s.onabort=r:s.onreadystatechange=function(){4===s.readyState&&e.setTimeout(function(){n&&r()})},n=n("abort");try{s.send(t.hasContent&&t.data||null)}catch(e){if(n)throw e}},abort:function(){n&&n()}}}),w.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),w.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return w.globalEval(e),e}}}),w.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),w.ajaxTransport("script",function(e){if(e.crossDomain){var t,n;return{send:function(i,o){t=w("