More movement toward a better organized static asset pipeline
authorCharles Connell <charles@connells.org>
Thu, 24 Apr 2014 02:13:29 +0000 (22:13 -0400)
committerCharles Connell <charles@connells.org>
Thu, 24 Apr 2014 02:13:29 +0000 (22:13 -0400)
78 files changed:
karmaworld/assets/css/datatables-css/jquery.dataTables.css [deleted file]
karmaworld/assets/css/font-awesome.css
karmaworld/assets/css/font-awesome/css/font-awesome.css [deleted file]
karmaworld/assets/css/font-awesome/css/font-awesome.min.css [deleted file]
karmaworld/assets/css/font-awesome/fonts/FontAwesome.otf [deleted file]
karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.eot [deleted file]
karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.svg [deleted file]
karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.ttf [deleted file]
karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.woff [deleted file]
karmaworld/assets/css/fontface.css [new file with mode: 0644]
karmaworld/assets/css/fontface/fontface.css [deleted file]
karmaworld/assets/css/fontface/museo300-regular-webfont.eot [deleted file]
karmaworld/assets/css/fontface/museo300-regular-webfont.svg [deleted file]
karmaworld/assets/css/fontface/museo300-regular-webfont.ttf [deleted file]
karmaworld/assets/css/fontface/museo300-regular-webfont.woff [deleted file]
karmaworld/assets/css/fontface/museo700-regular-webfont.eot [deleted file]
karmaworld/assets/css/fontface/museo700-regular-webfont.svg [deleted file]
karmaworld/assets/css/fontface/museo700-regular-webfont.ttf [deleted file]
karmaworld/assets/css/fontface/museo700-regular-webfont.woff [deleted file]
karmaworld/assets/css/fonts/FontAwesome.otf [new file with mode: 0644]
karmaworld/assets/css/fonts/fontawesome-webfont.eot [new file with mode: 0755]
karmaworld/assets/css/fonts/fontawesome-webfont.svg [new file with mode: 0755]
karmaworld/assets/css/fonts/fontawesome-webfont.ttf [new file with mode: 0755]
karmaworld/assets/css/fonts/fontawesome-webfont.woff [new file with mode: 0755]
karmaworld/assets/css/fonts/museo300-regular-webfont.eot [new file with mode: 0644]
karmaworld/assets/css/fonts/museo300-regular-webfont.svg [new file with mode: 0644]
karmaworld/assets/css/fonts/museo300-regular-webfont.ttf [new file with mode: 0644]
karmaworld/assets/css/fonts/museo300-regular-webfont.woff [new file with mode: 0644]
karmaworld/assets/css/fonts/museo700-regular-webfont.eot [new file with mode: 0644]
karmaworld/assets/css/fonts/museo700-regular-webfont.svg [new file with mode: 0644]
karmaworld/assets/css/fonts/museo700-regular-webfont.ttf [new file with mode: 0644]
karmaworld/assets/css/fonts/museo700-regular-webfont.woff [new file with mode: 0644]
karmaworld/assets/css/foundation.css [new file with mode: 0644]
karmaworld/assets/css/foundation.min.css [deleted file]
karmaworld/assets/css/home.css
karmaworld/assets/css/images/animated-overlay.gif [new file with mode: 0644]
karmaworld/assets/css/images/back_disabled.png [new file with mode: 0644]
karmaworld/assets/css/images/back_enabled.png [new file with mode: 0644]
karmaworld/assets/css/images/back_enabled_hover.png [new file with mode: 0644]
karmaworld/assets/css/images/forward_disabled.png [new file with mode: 0644]
karmaworld/assets/css/images/forward_enabled.png [new file with mode: 0644]
karmaworld/assets/css/images/forward_enabled_hover.png [new file with mode: 0644]
karmaworld/assets/css/images/sort_asc.png [new file with mode: 0644]
karmaworld/assets/css/images/sort_asc_disabled.png [new file with mode: 0644]
karmaworld/assets/css/images/sort_both.png [new file with mode: 0644]
karmaworld/assets/css/images/sort_desc.png [new file with mode: 0644]
karmaworld/assets/css/images/sort_desc_disabled.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_diagonals-thick_20_666666_40x40.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_flat_10_000000_40x100.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_glass_100_f6f6f6_1x400.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_glass_100_fdf5ce_1x400.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_glass_65_ffffff_1x400.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-icons_222222_256x240.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-icons_228ef1_256x240.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-icons_ef8c08_256x240.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-icons_ffd27a_256x240.png [new file with mode: 0644]
karmaworld/assets/css/images/ui-icons_ffffff_256x240.png [new file with mode: 0644]
karmaworld/assets/css/jquery-ui.css
karmaworld/assets/css/jquery.dataTables.css [new file with mode: 0644]
karmaworld/assets/js/add-course.js
karmaworld/assets/js/course.js
karmaworld/assets/js/foundation.reveal.js [new file with mode: 0644]
karmaworld/assets/js/jquery-ui-1.10.4.js
karmaworld/assets/js/jquery.dataTables.js [new file with mode: 0644]
karmaworld/settings/prod.py
karmaworld/templates/about.html
karmaworld/templates/base.html
karmaworld/templates/courses/course_detail.html
karmaworld/templates/courses/course_list.html
karmaworld/templates/notes/note_detail.html
karmaworld/templates/notes/search_results.html
karmaworld/templates/partial/add_course.html
karmaworld/templates/terms.html
karmaworld/templates/user_profile.html

diff --git a/karmaworld/assets/css/datatables-css/jquery.dataTables.css b/karmaworld/assets/css/datatables-css/jquery.dataTables.css
deleted file mode 100644 (file)
index 93bed84..0000000
+++ /dev/null
@@ -1,210 +0,0 @@
-
-/*
- * Table
- */
-table.dataTable {
-       clear: both;
-       width: 100%;
-}
-
-table.dataTable tfoot th {
-       padding: 3px 18px 3px 10px;
-       border-top: 1px solid black;
-       font-weight: bold;
-}
-
-table.dataTable td {
-       padding: 3px 10px;
-}
-
-table.dataTable td.center,
-table.dataTable td.dataTables_empty {
-       text-align: center;
-}
-
-/*table.dataTable tr.odd { background-color: #E2E4FF; }
-table.dataTable tr.even { background-color: white; }
-
-table.dataTable tr.odd td.sorting_1 { background-color: #D3D6FF; }
-table.dataTable tr.odd td.sorting_2 { background-color: #DADCFF; }
-table.dataTable tr.odd td.sorting_3 { background-color: #E0E2FF; }
-table.dataTable tr.even td.sorting_1 { background-color: #EAEBFF; }
-table.dataTable tr.even td.sorting_2 { background-color: #F2F3FF; }
-table.dataTable tr.even td.sorting_3 { background-color: #F9F9FF; }*/
-
-
-/*
- * Table wrapper
- */
-.dataTables_wrapper {
-       position: relative;
-       clear: both;
-       *zoom: 1;
-}
-
-
-/*
- * Page length menu
- */
-.dataTables_length {
-       float: left;
-}
-
-
-/*
- * Filter
- */
-.dataTables_filter {
-       margin: 10px;
-       text-align: right;
-}
-
-
-/*
- * Table information
- */
-.dataTables_info {
-       clear: both;
-       float: left;
-}
-
-
-/*
- * Pagination
- */
-.dataTables_paginate {
-       text-align: center;
-}
-
-/* Two button pagination - previous / next */
-.paginate_disabled_previous,
-.paginate_enabled_previous,
-.paginate_disabled_next,
-.paginate_enabled_next {
-       height: 19px;
-       cursor: pointer;
-       *cursor: hand;
-       color: #111 !important;
-}
-.paginate_disabled_previous:hover,
-.paginate_enabled_previous:hover,
-.paginate_disabled_next:hover,
-.paginate_enabled_next:hover {
-       text-decoration: none !important;
-}
-.paginate_disabled_previous:active,
-.paginate_enabled_previous:active,
-.paginate_disabled_next:active,
-.paginate_enabled_next:active {
-       outline: none;
-}
-
-.paginate_disabled_previous,
-.paginate_disabled_next {
-       color: #666 !important;
-}
-.paginate_disabled_previous,
-.paginate_enabled_previous {
-       padding-left: 23px;
-}
-.paginate_disabled_next,
-.paginate_enabled_next {
-       padding-right: 23px;
-       margin-left: 10px;
-}
-
-.paginate_enabled_previous { background: url('../../img/datatables-images/back_enabled.png') no-repeat top left; }
-.paginate_enabled_previous:hover { background: url('../../img/datatables-images/back_enabled_hover.png') no-repeat top left; }
-.paginate_disabled_previous { background: url('../../img/datatables-images/back_disabled.png') no-repeat top left; }
-
-.paginate_enabled_next { background: url('../../img/datatables-images/forward_enabled.png') no-repeat top right; }
-.paginate_enabled_next:hover { background: url('../../img/datatables-images/forward_enabled_hover.png') no-repeat top right; }
-.paginate_disabled_next { background: url('../../img/datatables-images/forward_disabled.png') no-repeat top right; }
-
-/* Full number pagination */
-.paging_full_numbers {
-       height: 22px;
-       line-height: 22px;
-}
-.paging_full_numbers a:active {
-       outline: none
-}
-.paging_full_numbers a:hover {
-       text-decoration: none;
-}
-
-.paging_full_numbers a.paginate_button,
-.paging_full_numbers a.paginate_active {
-       border: 1px solid #aaa;
-       -webkit-border-radius: 5px;
-       -moz-border-radius: 5px;
-       border-radius: 5px;
-       padding: 2px 5px;
-       margin: 0 3px;
-       cursor: pointer;
-       *cursor: hand;
-       color: #333 !important;
-}
-
-.paging_full_numbers a.paginate_button {
-       background-color: #ddd;
-}
-
-.paging_full_numbers a.paginate_button:hover {
-       background-color: #ccc;
-       text-decoration: none !important;
-}
-
-.paging_full_numbers a.paginate_active {
-       background-color: #99B3FF;
-}
-
-
-/*
- * Processing indicator
- */
-.dataTables_processing {
-       position: absolute;
-       top: 50%;
-       left: 50%;
-       width: 250px;
-       height: 30px;
-       margin-left: -125px;
-       margin-top: -15px;
-       padding: 14px 0 2px 0;
-       border: 1px solid #ddd;
-       text-align: center;
-       color: #999;
-       font-size: 14px;
-       background-color: white;
-}
-
-
-/*
- * Sorting
- */
-.sorting { background: url('../../img/datatables-images/sort_both.png') no-repeat center right; }
-.sorting_asc { background: url('../../img/datatables-images/sort_asc.png') no-repeat center right; }
-.sorting_desc { background: url('../../img/datatables-images/sort_desc.png') no-repeat center right; }
-
-.sorting_asc_disabled { background: url('../../img/datatables-images/sort_asc_disabled.png') no-repeat center right; }
-.sorting_desc_disabled { background: url('../../img/datatables-images/sort_desc_disabled.png') no-repeat center right; }
-table.dataTable thead th:active,
-table.dataTable thead td:active {
-       outline: none;
-}
-
-
-/*
- * Scrolling
- */
-.dataTables_scroll {
-       clear: both;
-}
-
-.dataTables_scrollBody {
-       *margin-top: -1px;
-       -webkit-overflow-scrolling: touch;
-}
-
index 048cff973981e8dd4ed8e73c4ca532ffcf02e1e8..4da18eb136c4d1dee09ffc9473b05e4a7ac1b9c1 100644 (file)
@@ -6,8 +6,11 @@
  * -------------------------- */
 @font-face {
   font-family: 'FontAwesome';
-  src: url('../fonts/fontawesome-webfont.eot?v=4.0.3');
-  src: url('../fonts/fontawesome-webfont.eot?#iefix&v=4.0.3') format('embedded-opentype'), url('../fonts/fontawesome-webfont.woff?v=4.0.3') format('woff'), url('../fonts/fontawesome-webfont.ttf?v=4.0.3') format('truetype'), url('../fonts/fontawesome-webfont.svg?v=4.0.3#fontawesomeregular') format('svg');
+  src: url('//karma-prod.s3.amazonaws.com/css/fonts/fontawesome-webfont.eot?v=4.0.3');
+  src: url('//karma-prod.s3.amazonaws.com/css/fonts/fontawesome-webfont.eot?#iefix&v=4.0.3') format('embedded-opentype'),
+    url('//karma-prod.s3.amazonaws.com/css/fonts/fontawesome-webfont.woff?v=4.0.3') format('woff'),
+    url('//karma-prod.s3.amazonaws.com/css/fonts/fontawesome-webfont.ttf?v=4.0.3') format('truetype'),
+    url('//karma-prod.s3.amazonaws.com/css/fonts/fontawesome-webfont.svg?v=4.0.3#fontawesomeregular') format('svg');
   font-weight: normal;
   font-style: normal;
 }
diff --git a/karmaworld/assets/css/font-awesome/css/font-awesome.css b/karmaworld/assets/css/font-awesome/css/font-awesome.css
deleted file mode 100644 (file)
index 92a516c..0000000
+++ /dev/null
@@ -1,1341 +0,0 @@
-/*!
- *  Font Awesome 4.0.3 by @davegandy - http://fontawesome.io - @fontawesome
- *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
- */
-/* FONT PATH
- * -------------------------- */
-@font-face {
-  font-family: 'FontAwesome';
-  src: url('/css/font-awesome/fonts/fontawesome-webfont.eot?v=4.0.3');
-  src: url('/css/font-awesome/fonts/fontawesome-webfont.eot?#iefix&v=4.0.3') format('embedded-opentype'),
-    url('/css/font-awesome/fonts/fontawesome-webfont.woff?v=4.0.3') format('woff'),
-    url('/css/font-awesome/fonts/fontawesome-webfont.ttf?v=4.0.3') format('truetype'),
-    url('/css/font-awesome/fonts/fontawesome-webfont.svg?v=4.0.3#fontawesomeregular') format('svg');
-  font-weight: normal;
-  font-style: normal;
-}
-.fa {
-  display: inline-block;
-  font-family: FontAwesome;
-  font-style: normal;
-  font-weight: normal;
-  line-height: 1;
-  -webkit-font-smoothing: antialiased;
-  -moz-osx-font-smoothing: grayscale;
-}
-/* makes the font 33% larger relative to the icon container */
-.fa-lg {
-  font-size: 1.3333333333333333em;
-  line-height: 0.75em;
-  vertical-align: -15%;
-}
-.fa-2x {
-  font-size: 2em;
-}
-.fa-3x {
-  font-size: 3em;
-}
-.fa-4x {
-  font-size: 4em;
-}
-.fa-5x {
-  font-size: 5em;
-}
-.fa-fw {
-  width: 1.2857142857142858em;
-  text-align: center;
-}
-.fa-ul {
-  padding-left: 0;
-  margin-left: 2.142857142857143em;
-  list-style-type: none;
-}
-.fa-ul > li {
-  position: relative;
-}
-.fa-li {
-  position: absolute;
-  left: -2.142857142857143em;
-  width: 2.142857142857143em;
-  top: 0.14285714285714285em;
-  text-align: center;
-}
-.fa-li.fa-lg {
-  left: -1.8571428571428572em;
-}
-.fa-border {
-  padding: .2em .25em .15em;
-  border: solid 0.08em #eeeeee;
-  border-radius: .1em;
-}
-.pull-right {
-  float: right;
-}
-.pull-left {
-  float: left;
-}
-.fa.pull-left {
-  margin-right: .3em;
-}
-.fa.pull-right {
-  margin-left: .3em;
-}
-.fa-spin {
-  -webkit-animation: spin 2s infinite linear;
-  -moz-animation: spin 2s infinite linear;
-  -o-animation: spin 2s infinite linear;
-  animation: spin 2s infinite linear;
-}
-@-moz-keyframes spin {
-  0% {
-    -moz-transform: rotate(0deg);
-  }
-  100% {
-    -moz-transform: rotate(359deg);
-  }
-}
-@-webkit-keyframes spin {
-  0% {
-    -webkit-transform: rotate(0deg);
-  }
-  100% {
-    -webkit-transform: rotate(359deg);
-  }
-}
-@-o-keyframes spin {
-  0% {
-    -o-transform: rotate(0deg);
-  }
-  100% {
-    -o-transform: rotate(359deg);
-  }
-}
-@-ms-keyframes spin {
-  0% {
-    -ms-transform: rotate(0deg);
-  }
-  100% {
-    -ms-transform: rotate(359deg);
-  }
-}
-@keyframes spin {
-  0% {
-    transform: rotate(0deg);
-  }
-  100% {
-    transform: rotate(359deg);
-  }
-}
-.fa-rotate-90 {
-  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);
-  -webkit-transform: rotate(90deg);
-  -moz-transform: rotate(90deg);
-  -ms-transform: rotate(90deg);
-  -o-transform: rotate(90deg);
-  transform: rotate(90deg);
-}
-.fa-rotate-180 {
-  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);
-  -webkit-transform: rotate(180deg);
-  -moz-transform: rotate(180deg);
-  -ms-transform: rotate(180deg);
-  -o-transform: rotate(180deg);
-  transform: rotate(180deg);
-}
-.fa-rotate-270 {
-  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);
-  -webkit-transform: rotate(270deg);
-  -moz-transform: rotate(270deg);
-  -ms-transform: rotate(270deg);
-  -o-transform: rotate(270deg);
-  transform: rotate(270deg);
-}
-.fa-flip-horizontal {
-  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);
-  -webkit-transform: scale(-1, 1);
-  -moz-transform: scale(-1, 1);
-  -ms-transform: scale(-1, 1);
-  -o-transform: scale(-1, 1);
-  transform: scale(-1, 1);
-}
-.fa-flip-vertical {
-  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);
-  -webkit-transform: scale(1, -1);
-  -moz-transform: scale(1, -1);
-  -ms-transform: scale(1, -1);
-  -o-transform: scale(1, -1);
-  transform: scale(1, -1);
-}
-.fa-stack {
-  position: relative;
-  display: inline-block;
-  width: 2em;
-  height: 2em;
-  line-height: 2em;
-  vertical-align: middle;
-}
-.fa-stack-1x,
-.fa-stack-2x {
-  position: absolute;
-  left: 0;
-  width: 100%;
-  text-align: center;
-}
-.fa-stack-1x {
-  line-height: inherit;
-}
-.fa-stack-2x {
-  font-size: 2em;
-}
-.fa-inverse {
-  color: #ffffff;
-}
-/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen
-   readers do not read off random characters that represent icons */
-.fa-glass:before {
-  content: "\f000";
-}
-.fa-music:before {
-  content: "\f001";
-}
-.fa-search:before {
-  content: "\f002";
-}
-.fa-envelope-o:before {
-  content: "\f003";
-}
-.fa-heart:before {
-  content: "\f004";
-}
-.fa-star:before {
-  content: "\f005";
-}
-.fa-star-o:before {
-  content: "\f006";
-}
-.fa-user:before {
-  content: "\f007";
-}
-.fa-film:before {
-  content: "\f008";
-}
-.fa-th-large:before {
-  content: "\f009";
-}
-.fa-th:before {
-  content: "\f00a";
-}
-.fa-th-list:before {
-  content: "\f00b";
-}
-.fa-check:before {
-  content: "\f00c";
-}
-.fa-times:before {
-  content: "\f00d";
-}
-.fa-search-plus:before {
-  content: "\f00e";
-}
-.fa-search-minus:before {
-  content: "\f010";
-}
-.fa-power-off:before {
-  content: "\f011";
-}
-.fa-signal:before {
-  content: "\f012";
-}
-.fa-gear:before,
-.fa-cog:before {
-  content: "\f013";
-}
-.fa-trash-o:before {
-  content: "\f014";
-}
-.fa-home:before {
-  content: "\f015";
-}
-.fa-file-o:before {
-  content: "\f016";
-}
-.fa-clock-o:before {
-  content: "\f017";
-}
-.fa-road:before {
-  content: "\f018";
-}
-.fa-download:before {
-  content: "\f019";
-}
-.fa-arrow-circle-o-down:before {
-  content: "\f01a";
-}
-.fa-arrow-circle-o-up:before {
-  content: "\f01b";
-}
-.fa-inbox:before {
-  content: "\f01c";
-}
-.fa-play-circle-o:before {
-  content: "\f01d";
-}
-.fa-rotate-right:before,
-.fa-repeat:before {
-  content: "\f01e";
-}
-.fa-refresh:before {
-  content: "\f021";
-}
-.fa-list-alt:before {
-  content: "\f022";
-}
-.fa-lock:before {
-  content: "\f023";
-}
-.fa-flag:before {
-  content: "\f024";
-}
-.fa-headphones:before {
-  content: "\f025";
-}
-.fa-volume-off:before {
-  content: "\f026";
-}
-.fa-volume-down:before {
-  content: "\f027";
-}
-.fa-volume-up:before {
-  content: "\f028";
-}
-.fa-qrcode:before {
-  content: "\f029";
-}
-.fa-barcode:before {
-  content: "\f02a";
-}
-.fa-tag:before {
-  content: "\f02b";
-}
-.fa-tags:before {
-  content: "\f02c";
-}
-.fa-book:before {
-  content: "\f02d";
-}
-.fa-bookmark:before {
-  content: "\f02e";
-}
-.fa-print:before {
-  content: "\f02f";
-}
-.fa-camera:before {
-  content: "\f030";
-}
-.fa-font:before {
-  content: "\f031";
-}
-.fa-bold:before {
-  content: "\f032";
-}
-.fa-italic:before {
-  content: "\f033";
-}
-.fa-text-height:before {
-  content: "\f034";
-}
-.fa-text-width:before {
-  content: "\f035";
-}
-.fa-align-left:before {
-  content: "\f036";
-}
-.fa-align-center:before {
-  content: "\f037";
-}
-.fa-align-right:before {
-  content: "\f038";
-}
-.fa-align-justify:before {
-  content: "\f039";
-}
-.fa-list:before {
-  content: "\f03a";
-}
-.fa-dedent:before,
-.fa-outdent:before {
-  content: "\f03b";
-}
-.fa-indent:before {
-  content: "\f03c";
-}
-.fa-video-camera:before {
-  content: "\f03d";
-}
-.fa-picture-o:before {
-  content: "\f03e";
-}
-.fa-pencil:before {
-  content: "\f040";
-}
-.fa-map-marker:before {
-  content: "\f041";
-}
-.fa-adjust:before {
-  content: "\f042";
-}
-.fa-tint:before {
-  content: "\f043";
-}
-.fa-edit:before,
-.fa-pencil-square-o:before {
-  content: "\f044";
-}
-.fa-share-square-o:before {
-  content: "\f045";
-}
-.fa-check-square-o:before {
-  content: "\f046";
-}
-.fa-arrows:before {
-  content: "\f047";
-}
-.fa-step-backward:before {
-  content: "\f048";
-}
-.fa-fast-backward:before {
-  content: "\f049";
-}
-.fa-backward:before {
-  content: "\f04a";
-}
-.fa-play:before {
-  content: "\f04b";
-}
-.fa-pause:before {
-  content: "\f04c";
-}
-.fa-stop:before {
-  content: "\f04d";
-}
-.fa-forward:before {
-  content: "\f04e";
-}
-.fa-fast-forward:before {
-  content: "\f050";
-}
-.fa-step-forward:before {
-  content: "\f051";
-}
-.fa-eject:before {
-  content: "\f052";
-}
-.fa-chevron-left:before {
-  content: "\f053";
-}
-.fa-chevron-right:before {
-  content: "\f054";
-}
-.fa-plus-circle:before {
-  content: "\f055";
-}
-.fa-minus-circle:before {
-  content: "\f056";
-}
-.fa-times-circle:before {
-  content: "\f057";
-}
-.fa-check-circle:before {
-  content: "\f058";
-}
-.fa-question-circle:before {
-  content: "\f059";
-}
-.fa-info-circle:before {
-  content: "\f05a";
-}
-.fa-crosshairs:before {
-  content: "\f05b";
-}
-.fa-times-circle-o:before {
-  content: "\f05c";
-}
-.fa-check-circle-o:before {
-  content: "\f05d";
-}
-.fa-ban:before {
-  content: "\f05e";
-}
-.fa-arrow-left:before {
-  content: "\f060";
-}
-.fa-arrow-right:before {
-  content: "\f061";
-}
-.fa-arrow-up:before {
-  content: "\f062";
-}
-.fa-arrow-down:before {
-  content: "\f063";
-}
-.fa-mail-forward:before,
-.fa-share:before {
-  content: "\f064";
-}
-.fa-expand:before {
-  content: "\f065";
-}
-.fa-compress:before {
-  content: "\f066";
-}
-.fa-plus:before {
-  content: "\f067";
-}
-.fa-minus:before {
-  content: "\f068";
-}
-.fa-asterisk:before {
-  content: "\f069";
-}
-.fa-exclamation-circle:before {
-  content: "\f06a";
-}
-.fa-gift:before {
-  content: "\f06b";
-}
-.fa-leaf:before {
-  content: "\f06c";
-}
-.fa-fire:before {
-  content: "\f06d";
-}
-.fa-eye:before {
-  content: "\f06e";
-}
-.fa-eye-slash:before {
-  content: "\f070";
-}
-.fa-warning:before,
-.fa-exclamation-triangle:before {
-  content: "\f071";
-}
-.fa-plane:before {
-  content: "\f072";
-}
-.fa-calendar:before {
-  content: "\f073";
-}
-.fa-random:before {
-  content: "\f074";
-}
-.fa-comment:before {
-  content: "\f075";
-}
-.fa-magnet:before {
-  content: "\f076";
-}
-.fa-chevron-up:before {
-  content: "\f077";
-}
-.fa-chevron-down:before {
-  content: "\f078";
-}
-.fa-retweet:before {
-  content: "\f079";
-}
-.fa-shopping-cart:before {
-  content: "\f07a";
-}
-.fa-folder:before {
-  content: "\f07b";
-}
-.fa-folder-open:before {
-  content: "\f07c";
-}
-.fa-arrows-v:before {
-  content: "\f07d";
-}
-.fa-arrows-h:before {
-  content: "\f07e";
-}
-.fa-bar-chart-o:before {
-  content: "\f080";
-}
-.fa-twitter-square:before {
-  content: "\f081";
-}
-.fa-facebook-square:before {
-  content: "\f082";
-}
-.fa-camera-retro:before {
-  content: "\f083";
-}
-.fa-key:before {
-  content: "\f084";
-}
-.fa-gears:before,
-.fa-cogs:before {
-  content: "\f085";
-}
-.fa-comments:before {
-  content: "\f086";
-}
-.fa-thumbs-o-up:before {
-  content: "\f087";
-}
-.fa-thumbs-o-down:before {
-  content: "\f088";
-}
-.fa-star-half:before {
-  content: "\f089";
-}
-.fa-heart-o:before {
-  content: "\f08a";
-}
-.fa-sign-out:before {
-  content: "\f08b";
-}
-.fa-linkedin-square:before {
-  content: "\f08c";
-}
-.fa-thumb-tack:before {
-  content: "\f08d";
-}
-.fa-external-link:before {
-  content: "\f08e";
-}
-.fa-sign-in:before {
-  content: "\f090";
-}
-.fa-trophy:before {
-  content: "\f091";
-}
-.fa-github-square:before {
-  content: "\f092";
-}
-.fa-upload:before {
-  content: "\f093";
-}
-.fa-lemon-o:before {
-  content: "\f094";
-}
-.fa-phone:before {
-  content: "\f095";
-}
-.fa-square-o:before {
-  content: "\f096";
-}
-.fa-bookmark-o:before {
-  content: "\f097";
-}
-.fa-phone-square:before {
-  content: "\f098";
-}
-.fa-twitter:before {
-  content: "\f099";
-}
-.fa-facebook:before {
-  content: "\f09a";
-}
-.fa-github:before {
-  content: "\f09b";
-}
-.fa-unlock:before {
-  content: "\f09c";
-}
-.fa-credit-card:before {
-  content: "\f09d";
-}
-.fa-rss:before {
-  content: "\f09e";
-}
-.fa-hdd-o:before {
-  content: "\f0a0";
-}
-.fa-bullhorn:before {
-  content: "\f0a1";
-}
-.fa-bell:before {
-  content: "\f0f3";
-}
-.fa-certificate:before {
-  content: "\f0a3";
-}
-.fa-hand-o-right:before {
-  content: "\f0a4";
-}
-.fa-hand-o-left:before {
-  content: "\f0a5";
-}
-.fa-hand-o-up:before {
-  content: "\f0a6";
-}
-.fa-hand-o-down:before {
-  content: "\f0a7";
-}
-.fa-arrow-circle-left:before {
-  content: "\f0a8";
-}
-.fa-arrow-circle-right:before {
-  content: "\f0a9";
-}
-.fa-arrow-circle-up:before {
-  content: "\f0aa";
-}
-.fa-arrow-circle-down:before {
-  content: "\f0ab";
-}
-.fa-globe:before {
-  content: "\f0ac";
-}
-.fa-wrench:before {
-  content: "\f0ad";
-}
-.fa-tasks:before {
-  content: "\f0ae";
-}
-.fa-filter:before {
-  content: "\f0b0";
-}
-.fa-briefcase:before {
-  content: "\f0b1";
-}
-.fa-arrows-alt:before {
-  content: "\f0b2";
-}
-.fa-group:before,
-.fa-users:before {
-  content: "\f0c0";
-}
-.fa-chain:before,
-.fa-link:before {
-  content: "\f0c1";
-}
-.fa-cloud:before {
-  content: "\f0c2";
-}
-.fa-flask:before {
-  content: "\f0c3";
-}
-.fa-cut:before,
-.fa-scissors:before {
-  content: "\f0c4";
-}
-.fa-copy:before,
-.fa-files-o:before {
-  content: "\f0c5";
-}
-.fa-paperclip:before {
-  content: "\f0c6";
-}
-.fa-save:before,
-.fa-floppy-o:before {
-  content: "\f0c7";
-}
-.fa-square:before {
-  content: "\f0c8";
-}
-.fa-bars:before {
-  content: "\f0c9";
-}
-.fa-list-ul:before {
-  content: "\f0ca";
-}
-.fa-list-ol:before {
-  content: "\f0cb";
-}
-.fa-strikethrough:before {
-  content: "\f0cc";
-}
-.fa-underline:before {
-  content: "\f0cd";
-}
-.fa-table:before {
-  content: "\f0ce";
-}
-.fa-magic:before {
-  content: "\f0d0";
-}
-.fa-truck:before {
-  content: "\f0d1";
-}
-.fa-pinterest:before {
-  content: "\f0d2";
-}
-.fa-pinterest-square:before {
-  content: "\f0d3";
-}
-.fa-google-plus-square:before {
-  content: "\f0d4";
-}
-.fa-google-plus:before {
-  content: "\f0d5";
-}
-.fa-money:before {
-  content: "\f0d6";
-}
-.fa-caret-down:before {
-  content: "\f0d7";
-}
-.fa-caret-up:before {
-  content: "\f0d8";
-}
-.fa-caret-left:before {
-  content: "\f0d9";
-}
-.fa-caret-right:before {
-  content: "\f0da";
-}
-.fa-columns:before {
-  content: "\f0db";
-}
-.fa-unsorted:before,
-.fa-sort:before {
-  content: "\f0dc";
-}
-.fa-sort-down:before,
-.fa-sort-asc:before {
-  content: "\f0dd";
-}
-.fa-sort-up:before,
-.fa-sort-desc:before {
-  content: "\f0de";
-}
-.fa-envelope:before {
-  content: "\f0e0";
-}
-.fa-linkedin:before {
-  content: "\f0e1";
-}
-.fa-rotate-left:before,
-.fa-undo:before {
-  content: "\f0e2";
-}
-.fa-legal:before,
-.fa-gavel:before {
-  content: "\f0e3";
-}
-.fa-dashboard:before,
-.fa-tachometer:before {
-  content: "\f0e4";
-}
-.fa-comment-o:before {
-  content: "\f0e5";
-}
-.fa-comments-o:before {
-  content: "\f0e6";
-}
-.fa-flash:before,
-.fa-bolt:before {
-  content: "\f0e7";
-}
-.fa-sitemap:before {
-  content: "\f0e8";
-}
-.fa-umbrella:before {
-  content: "\f0e9";
-}
-.fa-paste:before,
-.fa-clipboard:before {
-  content: "\f0ea";
-}
-.fa-lightbulb-o:before {
-  content: "\f0eb";
-}
-.fa-exchange:before {
-  content: "\f0ec";
-}
-.fa-cloud-download:before {
-  content: "\f0ed";
-}
-.fa-cloud-upload:before {
-  content: "\f0ee";
-}
-.fa-user-md:before {
-  content: "\f0f0";
-}
-.fa-stethoscope:before {
-  content: "\f0f1";
-}
-.fa-suitcase:before {
-  content: "\f0f2";
-}
-.fa-bell-o:before {
-  content: "\f0a2";
-}
-.fa-coffee:before {
-  content: "\f0f4";
-}
-.fa-cutlery:before {
-  content: "\f0f5";
-}
-.fa-file-text-o:before {
-  content: "\f0f6";
-}
-.fa-building-o:before {
-  content: "\f0f7";
-}
-.fa-hospital-o:before {
-  content: "\f0f8";
-}
-.fa-ambulance:before {
-  content: "\f0f9";
-}
-.fa-medkit:before {
-  content: "\f0fa";
-}
-.fa-fighter-jet:before {
-  content: "\f0fb";
-}
-.fa-beer:before {
-  content: "\f0fc";
-}
-.fa-h-square:before {
-  content: "\f0fd";
-}
-.fa-plus-square:before {
-  content: "\f0fe";
-}
-.fa-angle-double-left:before {
-  content: "\f100";
-}
-.fa-angle-double-right:before {
-  content: "\f101";
-}
-.fa-angle-double-up:before {
-  content: "\f102";
-}
-.fa-angle-double-down:before {
-  content: "\f103";
-}
-.fa-angle-left:before {
-  content: "\f104";
-}
-.fa-angle-right:before {
-  content: "\f105";
-}
-.fa-angle-up:before {
-  content: "\f106";
-}
-.fa-angle-down:before {
-  content: "\f107";
-}
-.fa-desktop:before {
-  content: "\f108";
-}
-.fa-laptop:before {
-  content: "\f109";
-}
-.fa-tablet:before {
-  content: "\f10a";
-}
-.fa-mobile-phone:before,
-.fa-mobile:before {
-  content: "\f10b";
-}
-.fa-circle-o:before {
-  content: "\f10c";
-}
-.fa-quote-left:before {
-  content: "\f10d";
-}
-.fa-quote-right:before {
-  content: "\f10e";
-}
-.fa-spinner:before {
-  content: "\f110";
-}
-.fa-circle:before {
-  content: "\f111";
-}
-.fa-mail-reply:before,
-.fa-reply:before {
-  content: "\f112";
-}
-.fa-github-alt:before {
-  content: "\f113";
-}
-.fa-folder-o:before {
-  content: "\f114";
-}
-.fa-folder-open-o:before {
-  content: "\f115";
-}
-.fa-smile-o:before {
-  content: "\f118";
-}
-.fa-frown-o:before {
-  content: "\f119";
-}
-.fa-meh-o:before {
-  content: "\f11a";
-}
-.fa-gamepad:before {
-  content: "\f11b";
-}
-.fa-keyboard-o:before {
-  content: "\f11c";
-}
-.fa-flag-o:before {
-  content: "\f11d";
-}
-.fa-flag-checkered:before {
-  content: "\f11e";
-}
-.fa-terminal:before {
-  content: "\f120";
-}
-.fa-code:before {
-  content: "\f121";
-}
-.fa-reply-all:before {
-  content: "\f122";
-}
-.fa-mail-reply-all:before {
-  content: "\f122";
-}
-.fa-star-half-empty:before,
-.fa-star-half-full:before,
-.fa-star-half-o:before {
-  content: "\f123";
-}
-.fa-location-arrow:before {
-  content: "\f124";
-}
-.fa-crop:before {
-  content: "\f125";
-}
-.fa-code-fork:before {
-  content: "\f126";
-}
-.fa-unlink:before,
-.fa-chain-broken:before {
-  content: "\f127";
-}
-.fa-question:before {
-  content: "\f128";
-}
-.fa-info:before {
-  content: "\f129";
-}
-.fa-exclamation:before {
-  content: "\f12a";
-}
-.fa-superscript:before {
-  content: "\f12b";
-}
-.fa-subscript:before {
-  content: "\f12c";
-}
-.fa-eraser:before {
-  content: "\f12d";
-}
-.fa-puzzle-piece:before {
-  content: "\f12e";
-}
-.fa-microphone:before {
-  content: "\f130";
-}
-.fa-microphone-slash:before {
-  content: "\f131";
-}
-.fa-shield:before {
-  content: "\f132";
-}
-.fa-calendar-o:before {
-  content: "\f133";
-}
-.fa-fire-extinguisher:before {
-  content: "\f134";
-}
-.fa-rocket:before {
-  content: "\f135";
-}
-.fa-maxcdn:before {
-  content: "\f136";
-}
-.fa-chevron-circle-left:before {
-  content: "\f137";
-}
-.fa-chevron-circle-right:before {
-  content: "\f138";
-}
-.fa-chevron-circle-up:before {
-  content: "\f139";
-}
-.fa-chevron-circle-down:before {
-  content: "\f13a";
-}
-.fa-html5:before {
-  content: "\f13b";
-}
-.fa-css3:before {
-  content: "\f13c";
-}
-.fa-anchor:before {
-  content: "\f13d";
-}
-.fa-unlock-alt:before {
-  content: "\f13e";
-}
-.fa-bullseye:before {
-  content: "\f140";
-}
-.fa-ellipsis-h:before {
-  content: "\f141";
-}
-.fa-ellipsis-v:before {
-  content: "\f142";
-}
-.fa-rss-square:before {
-  content: "\f143";
-}
-.fa-play-circle:before {
-  content: "\f144";
-}
-.fa-ticket:before {
-  content: "\f145";
-}
-.fa-minus-square:before {
-  content: "\f146";
-}
-.fa-minus-square-o:before {
-  content: "\f147";
-}
-.fa-level-up:before {
-  content: "\f148";
-}
-.fa-level-down:before {
-  content: "\f149";
-}
-.fa-check-square:before {
-  content: "\f14a";
-}
-.fa-pencil-square:before {
-  content: "\f14b";
-}
-.fa-external-link-square:before {
-  content: "\f14c";
-}
-.fa-share-square:before {
-  content: "\f14d";
-}
-.fa-compass:before {
-  content: "\f14e";
-}
-.fa-toggle-down:before,
-.fa-caret-square-o-down:before {
-  content: "\f150";
-}
-.fa-toggle-up:before,
-.fa-caret-square-o-up:before {
-  content: "\f151";
-}
-.fa-toggle-right:before,
-.fa-caret-square-o-right:before {
-  content: "\f152";
-}
-.fa-euro:before,
-.fa-eur:before {
-  content: "\f153";
-}
-.fa-gbp:before {
-  content: "\f154";
-}
-.fa-dollar:before,
-.fa-usd:before {
-  content: "\f155";
-}
-.fa-rupee:before,
-.fa-inr:before {
-  content: "\f156";
-}
-.fa-cny:before,
-.fa-rmb:before,
-.fa-yen:before,
-.fa-jpy:before {
-  content: "\f157";
-}
-.fa-ruble:before,
-.fa-rouble:before,
-.fa-rub:before {
-  content: "\f158";
-}
-.fa-won:before,
-.fa-krw:before {
-  content: "\f159";
-}
-.fa-bitcoin:before,
-.fa-btc:before {
-  content: "\f15a";
-}
-.fa-file:before {
-  content: "\f15b";
-}
-.fa-file-text:before {
-  content: "\f15c";
-}
-.fa-sort-alpha-asc:before {
-  content: "\f15d";
-}
-.fa-sort-alpha-desc:before {
-  content: "\f15e";
-}
-.fa-sort-amount-asc:before {
-  content: "\f160";
-}
-.fa-sort-amount-desc:before {
-  content: "\f161";
-}
-.fa-sort-numeric-asc:before {
-  content: "\f162";
-}
-.fa-sort-numeric-desc:before {
-  content: "\f163";
-}
-.fa-thumbs-up:before {
-  content: "\f164";
-}
-.fa-thumbs-down:before {
-  content: "\f165";
-}
-.fa-youtube-square:before {
-  content: "\f166";
-}
-.fa-youtube:before {
-  content: "\f167";
-}
-.fa-xing:before {
-  content: "\f168";
-}
-.fa-xing-square:before {
-  content: "\f169";
-}
-.fa-youtube-play:before {
-  content: "\f16a";
-}
-.fa-dropbox:before {
-  content: "\f16b";
-}
-.fa-stack-overflow:before {
-  content: "\f16c";
-}
-.fa-instagram:before {
-  content: "\f16d";
-}
-.fa-flickr:before {
-  content: "\f16e";
-}
-.fa-adn:before {
-  content: "\f170";
-}
-.fa-bitbucket:before {
-  content: "\f171";
-}
-.fa-bitbucket-square:before {
-  content: "\f172";
-}
-.fa-tumblr:before {
-  content: "\f173";
-}
-.fa-tumblr-square:before {
-  content: "\f174";
-}
-.fa-long-arrow-down:before {
-  content: "\f175";
-}
-.fa-long-arrow-up:before {
-  content: "\f176";
-}
-.fa-long-arrow-left:before {
-  content: "\f177";
-}
-.fa-long-arrow-right:before {
-  content: "\f178";
-}
-.fa-apple:before {
-  content: "\f179";
-}
-.fa-windows:before {
-  content: "\f17a";
-}
-.fa-android:before {
-  content: "\f17b";
-}
-.fa-linux:before {
-  content: "\f17c";
-}
-.fa-dribbble:before {
-  content: "\f17d";
-}
-.fa-skype:before {
-  content: "\f17e";
-}
-.fa-foursquare:before {
-  content: "\f180";
-}
-.fa-trello:before {
-  content: "\f181";
-}
-.fa-female:before {
-  content: "\f182";
-}
-.fa-male:before {
-  content: "\f183";
-}
-.fa-gittip:before {
-  content: "\f184";
-}
-.fa-sun-o:before {
-  content: "\f185";
-}
-.fa-moon-o:before {
-  content: "\f186";
-}
-.fa-archive:before {
-  content: "\f187";
-}
-.fa-bug:before {
-  content: "\f188";
-}
-.fa-vk:before {
-  content: "\f189";
-}
-.fa-weibo:before {
-  content: "\f18a";
-}
-.fa-renren:before {
-  content: "\f18b";
-}
-.fa-pagelines:before {
-  content: "\f18c";
-}
-.fa-stack-exchange:before {
-  content: "\f18d";
-}
-.fa-arrow-circle-o-right:before {
-  content: "\f18e";
-}
-.fa-arrow-circle-o-left:before {
-  content: "\f190";
-}
-.fa-toggle-left:before,
-.fa-caret-square-o-left:before {
-  content: "\f191";
-}
-.fa-dot-circle-o:before {
-  content: "\f192";
-}
-.fa-wheelchair:before {
-  content: "\f193";
-}
-.fa-vimeo-square:before {
-  content: "\f194";
-}
-.fa-turkish-lira:before,
-.fa-try:before {
-  content: "\f195";
-}
-.fa-plus-square-o:before {
-  content: "\f196";
-}
diff --git a/karmaworld/assets/css/font-awesome/css/font-awesome.min.css b/karmaworld/assets/css/font-awesome/css/font-awesome.min.css
deleted file mode 100644 (file)
index 449d6ac..0000000
+++ /dev/null
@@ -1,4 +0,0 @@
-/*!
- *  Font Awesome 4.0.3 by @davegandy - http://fontawesome.io - @fontawesome
- *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
- */@font-face{font-family:'FontAwesome';src:url('../fonts/fontawesome-webfont.eot?v=4.0.3');src:url('../fonts/fontawesome-webfont.eot?#iefix&v=4.0.3') format('embedded-opentype'),url('../fonts/fontawesome-webfont.woff?v=4.0.3') format('woff'),url('../fonts/fontawesome-webfont.ttf?v=4.0.3') format('truetype'),url('../fonts/fontawesome-webfont.svg?v=4.0.3#fontawesomeregular') format('svg');font-weight:normal;font-style:normal}.fa{display:inline-block;font-family:FontAwesome;font-style:normal;font-weight:normal;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.3333333333333333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.2857142857142858em;text-align:center}.fa-ul{padding-left:0;margin-left:2.142857142857143em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.142857142857143em;width:2.142857142857143em;top:.14285714285714285em;text-align:center}.fa-li.fa-lg{left:-1.8571428571428572em}.fa-border{padding:.2em .25em .15em;border:solid .08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:spin 2s infinite linear;-moz-animation:spin 2s infinite linear;-o-animation:spin 2s infinite linear;animation:spin 2s infinite linear}@-moz-keyframes spin{0%{-moz-transform:rotate(0deg)}100%{-moz-transform:rotate(359deg)}}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg)}}@-o-keyframes spin{0%{-o-transform:rotate(0deg)}100%{-o-transform:rotate(359deg)}}@-ms-keyframes spin{0%{-ms-transform:rotate(0deg)}100%{-ms-transform:rotate(359deg)}}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(359deg)}}.fa-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-moz-transform:rotate(90deg);-ms-transform:rotate(90deg);-o-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-moz-transform:rotate(180deg);-ms-transform:rotate(180deg);-o-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-moz-transform:rotate(270deg);-ms-transform:rotate(270deg);-o-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0,mirror=1);-webkit-transform:scale(-1,1);-moz-transform:scale(-1,1);-ms-transform:scale(-1,1);-o-transform:scale(-1,1);transform:scale(-1,1)}.fa-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2,mirror=1);-webkit-transform:scale(1,-1);-moz-transform:scale(1,-1);-ms-transform:scale(1,-1);-o-transform:scale(1,-1);transform:scale(1,-1)}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:"\f000"}.fa-music:before{content:"\f001"}.fa-search:before{content:"\f002"}.fa-envelope-o:before{content:"\f003"}.fa-heart:before{content:"\f004"}.fa-star:before{content:"\f005"}.fa-star-o:before{content:"\f006"}.fa-user:before{content:"\f007"}.fa-film:before{content:"\f008"}.fa-th-large:before{content:"\f009"}.fa-th:before{content:"\f00a"}.fa-th-list:before{content:"\f00b"}.fa-check:before{content:"\f00c"}.fa-times:before{content:"\f00d"}.fa-search-plus:before{content:"\f00e"}.fa-search-minus:before{content:"\f010"}.fa-power-off:before{content:"\f011"}.fa-signal:before{content:"\f012"}.fa-gear:before,.fa-cog:before{content:"\f013"}.fa-trash-o:before{content:"\f014"}.fa-home:before{content:"\f015"}.fa-file-o:before{content:"\f016"}.fa-clock-o:before{content:"\f017"}.fa-road:before{content:"\f018"}.fa-download:before{content:"\f019"}.fa-arrow-circle-o-down:before{content:"\f01a"}.fa-arrow-circle-o-up:before{content:"\f01b"}.fa-inbox:before{content:"\f01c"}.fa-play-circle-o:before{content:"\f01d"}.fa-rotate-right:before,.fa-repeat:before{content:"\f01e"}.fa-refresh:before{content:"\f021"}.fa-list-alt:before{content:"\f022"}.fa-lock:before{content:"\f023"}.fa-flag:before{content:"\f024"}.fa-headphones:before{content:"\f025"}.fa-volume-off:before{content:"\f026"}.fa-volume-down:before{content:"\f027"}.fa-volume-up:before{content:"\f028"}.fa-qrcode:before{content:"\f029"}.fa-barcode:before{content:"\f02a"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-book:before{content:"\f02d"}.fa-bookmark:before{content:"\f02e"}.fa-print:before{content:"\f02f"}.fa-camera:before{content:"\f030"}.fa-font:before{content:"\f031"}.fa-bold:before{content:"\f032"}.fa-italic:before{content:"\f033"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-align-left:before{content:"\f036"}.fa-align-center:before{content:"\f037"}.fa-align-right:before{content:"\f038"}.fa-align-justify:before{content:"\f039"}.fa-list:before{content:"\f03a"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-indent:before{content:"\f03c"}.fa-video-camera:before{content:"\f03d"}.fa-picture-o:before{content:"\f03e"}.fa-pencil:before{content:"\f040"}.fa-map-marker:before{content:"\f041"}.fa-adjust:before{content:"\f042"}.fa-tint:before{content:"\f043"}.fa-edit:before,.fa-pencil-square-o:before{content:"\f044"}.fa-share-square-o:before{content:"\f045"}.fa-check-square-o:before{content:"\f046"}.fa-arrows:before{content:"\f047"}.fa-step-backward:before{content:"\f048"}.fa-fast-backward:before{content:"\f049"}.fa-backward:before{content:"\f04a"}.fa-play:before{content:"\f04b"}.fa-pause:before{content:"\f04c"}.fa-stop:before{content:"\f04d"}.fa-forward:before{content:"\f04e"}.fa-fast-forward:before{content:"\f050"}.fa-step-forward:before{content:"\f051"}.fa-eject:before{content:"\f052"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-plus-circle:before{content:"\f055"}.fa-minus-circle:before{content:"\f056"}.fa-times-circle:before{content:"\f057"}.fa-check-circle:before{content:"\f058"}.fa-question-circle:before{content:"\f059"}.fa-info-circle:before{content:"\f05a"}.fa-crosshairs:before{content:"\f05b"}.fa-times-circle-o:before{content:"\f05c"}.fa-check-circle-o:before{content:"\f05d"}.fa-ban:before{content:"\f05e"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrow-down:before{content:"\f063"}.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-expand:before{content:"\f065"}.fa-compress:before{content:"\f066"}.fa-plus:before{content:"\f067"}.fa-minus:before{content:"\f068"}.fa-asterisk:before{content:"\f069"}.fa-exclamation-circle:before{content:"\f06a"}.fa-gift:before{content:"\f06b"}.fa-leaf:before{content:"\f06c"}.fa-fire:before{content:"\f06d"}.fa-eye:before{content:"\f06e"}.fa-eye-slash:before{content:"\f070"}.fa-warning:before,.fa-exclamation-triangle:before{content:"\f071"}.fa-plane:before{content:"\f072"}.fa-calendar:before{content:"\f073"}.fa-random:before{content:"\f074"}.fa-comment:before{content:"\f075"}.fa-magnet:before{content:"\f076"}.fa-chevron-up:before{content:"\f077"}.fa-chevron-down:before{content:"\f078"}.fa-retweet:before{content:"\f079"}.fa-shopping-cart:before{content:"\f07a"}.fa-folder:before{content:"\f07b"}.fa-folder-open:before{content:"\f07c"}.fa-arrows-v:before{content:"\f07d"}.fa-arrows-h:before{content:"\f07e"}.fa-bar-chart-o:before{content:"\f080"}.fa-twitter-square:before{content:"\f081"}.fa-facebook-square:before{content:"\f082"}.fa-camera-retro:before{content:"\f083"}.fa-key:before{content:"\f084"}.fa-gears:before,.fa-cogs:before{content:"\f085"}.fa-comments:before{content:"\f086"}.fa-thumbs-o-up:before{content:"\f087"}.fa-thumbs-o-down:before{content:"\f088"}.fa-star-half:before{content:"\f089"}.fa-heart-o:before{content:"\f08a"}.fa-sign-out:before{content:"\f08b"}.fa-linkedin-square:before{content:"\f08c"}.fa-thumb-tack:before{content:"\f08d"}.fa-external-link:before{content:"\f08e"}.fa-sign-in:before{content:"\f090"}.fa-trophy:before{content:"\f091"}.fa-github-square:before{content:"\f092"}.fa-upload:before{content:"\f093"}.fa-lemon-o:before{content:"\f094"}.fa-phone:before{content:"\f095"}.fa-square-o:before{content:"\f096"}.fa-bookmark-o:before{content:"\f097"}.fa-phone-square:before{content:"\f098"}.fa-twitter:before{content:"\f099"}.fa-facebook:before{content:"\f09a"}.fa-github:before{content:"\f09b"}.fa-unlock:before{content:"\f09c"}.fa-credit-card:before{content:"\f09d"}.fa-rss:before{content:"\f09e"}.fa-hdd-o:before{content:"\f0a0"}.fa-bullhorn:before{content:"\f0a1"}.fa-bell:before{content:"\f0f3"}.fa-certificate:before{content:"\f0a3"}.fa-hand-o-right:before{content:"\f0a4"}.fa-hand-o-left:before{content:"\f0a5"}.fa-hand-o-up:before{content:"\f0a6"}.fa-hand-o-down:before{content:"\f0a7"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-globe:before{content:"\f0ac"}.fa-wrench:before{content:"\f0ad"}.fa-tasks:before{content:"\f0ae"}.fa-filter:before{content:"\f0b0"}.fa-briefcase:before{content:"\f0b1"}.fa-arrows-alt:before{content:"\f0b2"}.fa-group:before,.fa-users:before{content:"\f0c0"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-cloud:before{content:"\f0c2"}.fa-flask:before{content:"\f0c3"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-copy:before,.fa-files-o:before{content:"\f0c5"}.fa-paperclip:before{content:"\f0c6"}.fa-save:before,.fa-floppy-o:before{content:"\f0c7"}.fa-square:before{content:"\f0c8"}.fa-bars:before{content:"\f0c9"}.fa-list-ul:before{content:"\f0ca"}.fa-list-ol:before{content:"\f0cb"}.fa-strikethrough:before{content:"\f0cc"}.fa-underline:before{content:"\f0cd"}.fa-table:before{content:"\f0ce"}.fa-magic:before{content:"\f0d0"}.fa-truck:before{content:"\f0d1"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-square:before{content:"\f0d3"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-plus:before{content:"\f0d5"}.fa-money:before{content:"\f0d6"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-up:before{content:"\f0d8"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-columns:before{content:"\f0db"}.fa-unsorted:before,.fa-sort:before{content:"\f0dc"}.fa-sort-down:before,.fa-sort-asc:before{content:"\f0dd"}.fa-sort-up:before,.fa-sort-desc:before{content:"\f0de"}.fa-envelope:before{content:"\f0e0"}.fa-linkedin:before{content:"\f0e1"}.fa-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-legal:before,.fa-gavel:before{content:"\f0e3"}.fa-dashboard:before,.fa-tachometer:before{content:"\f0e4"}.fa-comment-o:before{content:"\f0e5"}.fa-comments-o:before{content:"\f0e6"}.fa-flash:before,.fa-bolt:before{content:"\f0e7"}.fa-sitemap:before{content:"\f0e8"}.fa-umbrella:before{content:"\f0e9"}.fa-paste:before,.fa-clipboard:before{content:"\f0ea"}.fa-lightbulb-o:before{content:"\f0eb"}.fa-exchange:before{content:"\f0ec"}.fa-cloud-download:before{content:"\f0ed"}.fa-cloud-upload:before{content:"\f0ee"}.fa-user-md:before{content:"\f0f0"}.fa-stethoscope:before{content:"\f0f1"}.fa-suitcase:before{content:"\f0f2"}.fa-bell-o:before{content:"\f0a2"}.fa-coffee:before{content:"\f0f4"}.fa-cutlery:before{content:"\f0f5"}.fa-file-text-o:before{content:"\f0f6"}.fa-building-o:before{content:"\f0f7"}.fa-hospital-o:before{content:"\f0f8"}.fa-ambulance:before{content:"\f0f9"}.fa-medkit:before{content:"\f0fa"}.fa-fighter-jet:before{content:"\f0fb"}.fa-beer:before{content:"\f0fc"}.fa-h-square:before{content:"\f0fd"}.fa-plus-square:before{content:"\f0fe"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angle-down:before{content:"\f107"}.fa-desktop:before{content:"\f108"}.fa-laptop:before{content:"\f109"}.fa-tablet:before{content:"\f10a"}.fa-mobile-phone:before,.fa-mobile:before{content:"\f10b"}.fa-circle-o:before{content:"\f10c"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-spinner:before{content:"\f110"}.fa-circle:before{content:"\f111"}.fa-mail-reply:before,.fa-reply:before{content:"\f112"}.fa-github-alt:before{content:"\f113"}.fa-folder-o:before{content:"\f114"}.fa-folder-open-o:before{content:"\f115"}.fa-smile-o:before{content:"\f118"}.fa-frown-o:before{content:"\f119"}.fa-meh-o:before{content:"\f11a"}.fa-gamepad:before{content:"\f11b"}.fa-keyboard-o:before{content:"\f11c"}.fa-flag-o:before{content:"\f11d"}.fa-flag-checkered:before{content:"\f11e"}.fa-terminal:before{content:"\f120"}.fa-code:before{content:"\f121"}.fa-reply-all:before{content:"\f122"}.fa-mail-reply-all:before{content:"\f122"}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:"\f123"}.fa-location-arrow:before{content:"\f124"}.fa-crop:before{content:"\f125"}.fa-code-fork:before{content:"\f126"}.fa-unlink:before,.fa-chain-broken:before{content:"\f127"}.fa-question:before{content:"\f128"}.fa-info:before{content:"\f129"}.fa-exclamation:before{content:"\f12a"}.fa-superscript:before{content:"\f12b"}.fa-subscript:before{content:"\f12c"}.fa-eraser:before{content:"\f12d"}.fa-puzzle-piece:before{content:"\f12e"}.fa-microphone:before{content:"\f130"}.fa-microphone-slash:before{content:"\f131"}.fa-shield:before{content:"\f132"}.fa-calendar-o:before{content:"\f133"}.fa-fire-extinguisher:before{content:"\f134"}.fa-rocket:before{content:"\f135"}.fa-maxcdn:before{content:"\f136"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-html5:before{content:"\f13b"}.fa-css3:before{content:"\f13c"}.fa-anchor:before{content:"\f13d"}.fa-unlock-alt:before{content:"\f13e"}.fa-bullseye:before{content:"\f140"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-rss-square:before{content:"\f143"}.fa-play-circle:before{content:"\f144"}.fa-ticket:before{content:"\f145"}.fa-minus-square:before{content:"\f146"}.fa-minus-square-o:before{content:"\f147"}.fa-level-up:before{content:"\f148"}.fa-level-down:before{content:"\f149"}.fa-check-square:before{content:"\f14a"}.fa-pencil-square:before{content:"\f14b"}.fa-external-link-square:before{content:"\f14c"}.fa-share-square:before{content:"\f14d"}.fa-compass:before{content:"\f14e"}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:"\f150"}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:"\f151"}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:"\f152"}.fa-euro:before,.fa-eur:before{content:"\f153"}.fa-gbp:before{content:"\f154"}.fa-dollar:before,.fa-usd:before{content:"\f155"}.fa-rupee:before,.fa-inr:before{content:"\f156"}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:"\f157"}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:"\f158"}.fa-won:before,.fa-krw:before{content:"\f159"}.fa-bitcoin:before,.fa-btc:before{content:"\f15a"}.fa-file:before{content:"\f15b"}.fa-file-text:before{content:"\f15c"}.fa-sort-alpha-asc:before{content:"\f15d"}.fa-sort-alpha-desc:before{content:"\f15e"}.fa-sort-amount-asc:before{content:"\f160"}.fa-sort-amount-desc:before{content:"\f161"}.fa-sort-numeric-asc:before{content:"\f162"}.fa-sort-numeric-desc:before{content:"\f163"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbs-down:before{content:"\f165"}.fa-youtube-square:before{content:"\f166"}.fa-youtube:before{content:"\f167"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-youtube-play:before{content:"\f16a"}.fa-dropbox:before{content:"\f16b"}.fa-stack-overflow:before{content:"\f16c"}.fa-instagram:before{content:"\f16d"}.fa-flickr:before{content:"\f16e"}.fa-adn:before{content:"\f170"}.fa-bitbucket:before{content:"\f171"}.fa-bitbucket-square:before{content:"\f172"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-long-arrow-down:before{content:"\f175"}.fa-long-arrow-up:before{content:"\f176"}.fa-long-arrow-left:before{content:"\f177"}.fa-long-arrow-right:before{content:"\f178"}.fa-apple:before{content:"\f179"}.fa-windows:before{content:"\f17a"}.fa-android:before{content:"\f17b"}.fa-linux:before{content:"\f17c"}.fa-dribbble:before{content:"\f17d"}.fa-skype:before{content:"\f17e"}.fa-foursquare:before{content:"\f180"}.fa-trello:before{content:"\f181"}.fa-female:before{content:"\f182"}.fa-male:before{content:"\f183"}.fa-gittip:before{content:"\f184"}.fa-sun-o:before{content:"\f185"}.fa-moon-o:before{content:"\f186"}.fa-archive:before{content:"\f187"}.fa-bug:before{content:"\f188"}.fa-vk:before{content:"\f189"}.fa-weibo:before{content:"\f18a"}.fa-renren:before{content:"\f18b"}.fa-pagelines:before{content:"\f18c"}.fa-stack-exchange:before{content:"\f18d"}.fa-arrow-circle-o-right:before{content:"\f18e"}.fa-arrow-circle-o-left:before{content:"\f190"}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:"\f191"}.fa-dot-circle-o:before{content:"\f192"}.fa-wheelchair:before{content:"\f193"}.fa-vimeo-square:before{content:"\f194"}.fa-turkish-lira:before,.fa-try:before{content:"\f195"}.fa-plus-square-o:before{content:"\f196"}
\ No newline at end of file
diff --git a/karmaworld/assets/css/font-awesome/fonts/FontAwesome.otf b/karmaworld/assets/css/font-awesome/fonts/FontAwesome.otf
deleted file mode 100644 (file)
index 8b0f54e..0000000
Binary files a/karmaworld/assets/css/font-awesome/fonts/FontAwesome.otf and /dev/null differ
diff --git a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.eot b/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.eot
deleted file mode 100755 (executable)
index 7c79c6a..0000000
Binary files a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.eot and /dev/null differ
diff --git a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.svg b/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.svg
deleted file mode 100755 (executable)
index 45fdf33..0000000
+++ /dev/null
@@ -1,414 +0,0 @@
-<?xml version="1.0" standalone="no"?>
-<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
-<svg xmlns="http://www.w3.org/2000/svg">
-<metadata></metadata>
-<defs>
-<font id="fontawesomeregular" horiz-adv-x="1536" >
-<font-face units-per-em="1792" ascent="1536" descent="-256" />
-<missing-glyph horiz-adv-x="448" />
-<glyph unicode=" "  horiz-adv-x="448" />
-<glyph unicode="&#x09;" horiz-adv-x="448" />
-<glyph unicode="&#xa0;" horiz-adv-x="448" />
-<glyph unicode="&#xa8;" horiz-adv-x="1792" />
-<glyph unicode="&#xa9;" horiz-adv-x="1792" />
-<glyph unicode="&#xae;" horiz-adv-x="1792" />
-<glyph unicode="&#xb4;" horiz-adv-x="1792" />
-<glyph unicode="&#xc6;" horiz-adv-x="1792" />
-<glyph unicode="&#x2000;" horiz-adv-x="768" />
-<glyph unicode="&#x2001;" />
-<glyph unicode="&#x2002;" horiz-adv-x="768" />
-<glyph unicode="&#x2003;" />
-<glyph unicode="&#x2004;" horiz-adv-x="512" />
-<glyph unicode="&#x2005;" horiz-adv-x="384" />
-<glyph unicode="&#x2006;" horiz-adv-x="256" />
-<glyph unicode="&#x2007;" horiz-adv-x="256" />
-<glyph unicode="&#x2008;" horiz-adv-x="192" />
-<glyph unicode="&#x2009;" horiz-adv-x="307" />
-<glyph unicode="&#x200a;" horiz-adv-x="85" />
-<glyph unicode="&#x202f;" horiz-adv-x="307" />
-<glyph unicode="&#x205f;" horiz-adv-x="384" />
-<glyph unicode="&#x2122;" horiz-adv-x="1792" />
-<glyph unicode="&#x221e;" horiz-adv-x="1792" />
-<glyph unicode="&#x2260;" horiz-adv-x="1792" />
-<glyph unicode="&#xe000;" horiz-adv-x="500" d="M0 0z" />
-<glyph unicode="&#xf000;" horiz-adv-x="1792" d="M1699 1350q0 -35 -43 -78l-632 -632v-768h320q26 0 45 -19t19 -45t-19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45t45 19h320v768l-632 632q-43 43 -43 78q0 23 18 36.5t38 17.5t43 4h1408q23 0 43 -4t38 -17.5t18 -36.5z" />
-<glyph unicode="&#xf001;" d="M1536 1312v-1120q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v537l-768 -237v-709q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89 t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v967q0 31 19 56.5t49 35.5l832 256q12 4 28 4q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf002;" horiz-adv-x="1664" d="M1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -52 -38 -90t-90 -38q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5 t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" />
-<glyph unicode="&#xf003;" horiz-adv-x="1792" d="M1664 32v768q-32 -36 -69 -66q-268 -206 -426 -338q-51 -43 -83 -67t-86.5 -48.5t-102.5 -24.5h-1h-1q-48 0 -102.5 24.5t-86.5 48.5t-83 67q-158 132 -426 338q-37 30 -69 66v-768q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1664 1083v11v13.5t-0.5 13 t-3 12.5t-5.5 9t-9 7.5t-14 2.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5q0 -168 147 -284q193 -152 401 -317q6 -5 35 -29.5t46 -37.5t44.5 -31.5t50.5 -27.5t43 -9h1h1q20 0 43 9t50.5 27.5t44.5 31.5t46 37.5t35 29.5q208 165 401 317q54 43 100.5 115.5t46.5 131.5z M1792 1120v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf004;" horiz-adv-x="1792" d="M896 -128q-26 0 -44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5q224 0 351 -124t127 -344q0 -221 -229 -450l-623 -600 q-18 -18 -44 -18z" />
-<glyph unicode="&#xf005;" horiz-adv-x="1664" d="M1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -21 -10.5 -35.5t-30.5 -14.5q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455 l502 -73q56 -9 56 -46z" />
-<glyph unicode="&#xf006;" horiz-adv-x="1664" d="M1137 532l306 297l-422 62l-189 382l-189 -382l-422 -62l306 -297l-73 -421l378 199l377 -199zM1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -50 -41 -50q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500 l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455l502 -73q56 -9 56 -46z" />
-<glyph unicode="&#xf007;" horiz-adv-x="1408" d="M1408 131q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5t43 97.5t62 81t85.5 53.5t111.5 20q9 0 42 -21.5t74.5 -48t108 -48t133.5 -21.5t133.5 21.5t108 48t74.5 48t42 21.5q61 0 111.5 -20t85.5 -53.5t62 -81 t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5z" />
-<glyph unicode="&#xf008;" horiz-adv-x="1920" d="M384 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 320v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 704v128q0 26 -19 45t-45 19h-128 q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 -64v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM384 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45 t45 -19h128q26 0 45 19t19 45zM1792 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 704v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1792 320v128 q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 704v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19 t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1920 1248v-1344q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1344q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf009;" horiz-adv-x="1664" d="M768 512v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM768 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 512v-384q0 -52 -38 -90t-90 -38 h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" />
-<glyph unicode="&#xf00a;" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 288v-192q0 -40 -28 -68t-68 -28h-320 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf00b;" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-960 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h960q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf00c;" horiz-adv-x="1792" d="M1671 970q0 -40 -28 -68l-724 -724l-136 -136q-28 -28 -68 -28t-68 28l-136 136l-362 362q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -295l656 657q28 28 68 28t68 -28l136 -136q28 -28 28 -68z" />
-<glyph unicode="&#xf00d;" horiz-adv-x="1408" d="M1298 214q0 -40 -28 -68l-136 -136q-28 -28 -68 -28t-68 28l-294 294l-294 -294q-28 -28 -68 -28t-68 28l-136 136q-28 28 -28 68t28 68l294 294l-294 294q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -294l294 294q28 28 68 28t68 -28l136 -136q28 -28 28 -68 t-28 -68l-294 -294l294 -294q28 -28 28 -68z" />
-<glyph unicode="&#xf00e;" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-224q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v224h-224q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h224v224q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5v-224h224 q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5 t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" />
-<glyph unicode="&#xf010;" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-576q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h576q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5z M1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z " />
-<glyph unicode="&#xf011;" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61t-298 61t-245 164t-164 245t-61 298q0 182 80.5 343t226.5 270q43 32 95.5 25t83.5 -50q32 -42 24.5 -94.5t-49.5 -84.5q-98 -74 -151.5 -181t-53.5 -228q0 -104 40.5 -198.5t109.5 -163.5t163.5 -109.5 t198.5 -40.5t198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5q0 121 -53.5 228t-151.5 181q-42 32 -49.5 84.5t24.5 94.5q31 43 84 50t95 -25q146 -109 226.5 -270t80.5 -343zM896 1408v-640q0 -52 -38 -90t-90 -38t-90 38t-38 90v640q0 52 38 90t90 38t90 -38t38 -90z" />
-<glyph unicode="&#xf012;" horiz-adv-x="1792" d="M256 96v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM640 224v-320q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1024 480v-576q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23 v576q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1408 864v-960q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v960q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1792 1376v-1472q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1472q0 14 9 23t23 9h192q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf013;" d="M1024 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1536 749v-222q0 -12 -8 -23t-20 -13l-185 -28q-19 -54 -39 -91q35 -50 107 -138q10 -12 10 -25t-9 -23q-27 -37 -99 -108t-94 -71q-12 0 -26 9l-138 108q-44 -23 -91 -38 q-16 -136 -29 -186q-7 -28 -36 -28h-222q-14 0 -24.5 8.5t-11.5 21.5l-28 184q-49 16 -90 37l-141 -107q-10 -9 -25 -9q-14 0 -25 11q-126 114 -165 168q-7 10 -7 23q0 12 8 23q15 21 51 66.5t54 70.5q-27 50 -41 99l-183 27q-13 2 -21 12.5t-8 23.5v222q0 12 8 23t19 13 l186 28q14 46 39 92q-40 57 -107 138q-10 12 -10 24q0 10 9 23q26 36 98.5 107.5t94.5 71.5q13 0 26 -10l138 -107q44 23 91 38q16 136 29 186q7 28 36 28h222q14 0 24.5 -8.5t11.5 -21.5l28 -184q49 -16 90 -37l142 107q9 9 24 9q13 0 25 -10q129 -119 165 -170q7 -8 7 -22 q0 -12 -8 -23q-15 -21 -51 -66.5t-54 -70.5q26 -50 41 -98l183 -28q13 -2 21 -12.5t8 -23.5z" />
-<glyph unicode="&#xf014;" horiz-adv-x="1408" d="M512 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM768 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1024 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1152 76v948h-896v-948q0 -22 7 -40.5t14.5 -27t10.5 -8.5h832q3 0 10.5 8.5t14.5 27t7 40.5zM480 1152h448l-48 117q-7 9 -17 11h-317q-10 -2 -17 -11zM1408 1120v-64q0 -14 -9 -23t-23 -9h-96v-948q0 -83 -47 -143.5t-113 -60.5h-832 q-66 0 -113 58.5t-47 141.5v952h-96q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h309l70 167q15 37 54 63t79 26h320q40 0 79 -26t54 -63l70 -167h309q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf015;" horiz-adv-x="1664" d="M1408 544v-480q0 -26 -19 -45t-45 -19h-384v384h-256v-384h-384q-26 0 -45 19t-19 45v480q0 1 0.5 3t0.5 3l575 474l575 -474q1 -2 1 -6zM1631 613l-62 -74q-8 -9 -21 -11h-3q-13 0 -21 7l-692 577l-692 -577q-12 -8 -24 -7q-13 2 -21 11l-62 74q-8 10 -7 23.5t11 21.5 l719 599q32 26 76 26t76 -26l244 -204v195q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-408l219 -182q10 -8 11 -21.5t-7 -23.5z" />
-<glyph unicode="&#xf016;" horiz-adv-x="1280" d="M128 0h1024v768h-416q-40 0 -68 28t-28 68v416h-512v-1280zM768 896h376q-10 29 -22 41l-313 313q-12 12 -41 22v-376zM1280 864v-896q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h640q40 0 88 -20t76 -48l312 -312q28 -28 48 -76t20 -88z " />
-<glyph unicode="&#xf017;" d="M896 992v-448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h224v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf018;" horiz-adv-x="1920" d="M1111 540v4l-24 320q-1 13 -11 22.5t-23 9.5h-186q-13 0 -23 -9.5t-11 -22.5l-24 -320v-4q-1 -12 8 -20t21 -8h244q12 0 21 8t8 20zM1870 73q0 -73 -46 -73h-704q13 0 22 9.5t8 22.5l-20 256q-1 13 -11 22.5t-23 9.5h-272q-13 0 -23 -9.5t-11 -22.5l-20 -256 q-1 -13 8 -22.5t22 -9.5h-704q-46 0 -46 73q0 54 26 116l417 1044q8 19 26 33t38 14h339q-13 0 -23 -9.5t-11 -22.5l-15 -192q-1 -14 8 -23t22 -9h166q13 0 22 9t8 23l-15 192q-1 13 -11 22.5t-23 9.5h339q20 0 38 -14t26 -33l417 -1044q26 -62 26 -116z" />
-<glyph unicode="&#xf019;" horiz-adv-x="1664" d="M1280 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 416v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h465l135 -136 q58 -56 136 -56t136 56l136 136h464q40 0 68 -28t28 -68zM1339 985q17 -41 -14 -70l-448 -448q-18 -19 -45 -19t-45 19l-448 448q-31 29 -14 70q17 39 59 39h256v448q0 26 19 45t45 19h256q26 0 45 -19t19 -45v-448h256q42 0 59 -39z" />
-<glyph unicode="&#xf01a;" d="M1120 608q0 -12 -10 -24l-319 -319q-11 -9 -23 -9t-23 9l-320 320q-15 16 -7 35q8 20 30 20h192v352q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-352h192q14 0 23 -9t9 -23zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273 t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf01b;" d="M1118 660q-8 -20 -30 -20h-192v-352q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v352h-192q-14 0 -23 9t-9 23q0 12 10 24l319 319q11 9 23 9t23 -9l320 -320q15 -16 7 -35zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198 t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf01c;" d="M1023 576h316q-1 3 -2.5 8t-2.5 8l-212 496h-708l-212 -496q-1 -2 -2.5 -8t-2.5 -8h316l95 -192h320zM1536 546v-482q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v482q0 62 25 123l238 552q10 25 36.5 42t52.5 17h832q26 0 52.5 -17t36.5 -42l238 -552 q25 -61 25 -123z" />
-<glyph unicode="&#xf01d;" d="M1184 640q0 -37 -32 -55l-544 -320q-15 -9 -32 -9q-16 0 -32 8q-32 19 -32 56v640q0 37 32 56q33 18 64 -1l544 -320q32 -18 32 -55zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf01e;" d="M1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l138 138q-148 137 -349 137q-104 0 -198.5 -40.5t-163.5 -109.5t-109.5 -163.5t-40.5 -198.5t40.5 -198.5t109.5 -163.5t163.5 -109.5t198.5 -40.5q119 0 225 52t179 147q7 10 23 12q14 0 25 -9 l137 -138q9 -8 9.5 -20.5t-7.5 -22.5q-109 -132 -264 -204.5t-327 -72.5q-156 0 -298 61t-245 164t-164 245t-61 298t61 298t164 245t245 164t298 61q147 0 284.5 -55.5t244.5 -156.5l130 129q29 31 70 14q39 -17 39 -59z" />
-<glyph unicode="&#xf021;" d="M1511 480q0 -5 -1 -7q-64 -268 -268 -434.5t-478 -166.5q-146 0 -282.5 55t-243.5 157l-129 -129q-19 -19 -45 -19t-45 19t-19 45v448q0 26 19 45t45 19h448q26 0 45 -19t19 -45t-19 -45l-137 -137q71 -66 161 -102t187 -36q134 0 250 65t186 179q11 17 53 117 q8 23 30 23h192q13 0 22.5 -9.5t9.5 -22.5zM1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-26 0 -45 19t-19 45t19 45l138 138q-148 137 -349 137q-134 0 -250 -65t-186 -179q-11 -17 -53 -117q-8 -23 -30 -23h-199q-13 0 -22.5 9.5t-9.5 22.5v7q65 268 270 434.5t480 166.5 q146 0 284 -55.5t245 -156.5l130 129q19 19 45 19t45 -19t19 -45z" />
-<glyph unicode="&#xf022;" horiz-adv-x="1792" d="M384 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M384 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1536 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5z M1536 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5zM1536 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5 t9.5 -22.5zM1664 160v832q0 13 -9.5 22.5t-22.5 9.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1792 1248v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47 t47 -113z" />
-<glyph unicode="&#xf023;" horiz-adv-x="1152" d="M320 768h512v192q0 106 -75 181t-181 75t-181 -75t-75 -181v-192zM1152 672v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v192q0 184 132 316t316 132t316 -132t132 -316v-192h32q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf024;" horiz-adv-x="1792" d="M320 1280q0 -72 -64 -110v-1266q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v1266q-64 38 -64 110q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -25 -12.5 -38.5t-39.5 -27.5q-215 -116 -369 -116q-61 0 -123.5 22t-108.5 48 t-115.5 48t-142.5 22q-192 0 -464 -146q-17 -9 -33 -9q-26 0 -45 19t-19 45v742q0 32 31 55q21 14 79 43q236 120 421 120q107 0 200 -29t219 -88q38 -19 88 -19q54 0 117.5 21t110 47t88 47t54.5 21q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf025;" horiz-adv-x="1664" d="M1664 650q0 -166 -60 -314l-20 -49l-185 -33q-22 -83 -90.5 -136.5t-156.5 -53.5v-32q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-32q71 0 130 -35.5t93 -95.5l68 12q29 95 29 193q0 148 -88 279t-236.5 209t-315.5 78 t-315.5 -78t-236.5 -209t-88 -279q0 -98 29 -193l68 -12q34 60 93 95.5t130 35.5v32q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v32q-88 0 -156.5 53.5t-90.5 136.5l-185 33l-20 49q-60 148 -60 314q0 151 67 291t179 242.5 t266 163.5t320 61t320 -61t266 -163.5t179 -242.5t67 -291z" />
-<glyph unicode="&#xf026;" horiz-adv-x="768" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45z" />
-<glyph unicode="&#xf027;" horiz-adv-x="1152" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142z" />
-<glyph unicode="&#xf028;" horiz-adv-x="1664" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142zM1408 640q0 -153 -85 -282.5t-225 -188.5q-13 -5 -25 -5q-27 0 -46 19t-19 45q0 39 39 59q56 29 76 44q74 54 115.5 135.5t41.5 173.5t-41.5 173.5 t-115.5 135.5q-20 15 -76 44q-39 20 -39 59q0 26 19 45t45 19q13 0 26 -5q140 -59 225 -188.5t85 -282.5zM1664 640q0 -230 -127 -422.5t-338 -283.5q-13 -5 -26 -5q-26 0 -45 19t-19 45q0 36 39 59q7 4 22.5 10.5t22.5 10.5q46 25 82 51q123 91 192 227t69 289t-69 289 t-192 227q-36 26 -82 51q-7 4 -22.5 10.5t-22.5 10.5q-39 23 -39 59q0 26 19 45t45 19q13 0 26 -5q211 -91 338 -283.5t127 -422.5z" />
-<glyph unicode="&#xf029;" horiz-adv-x="1408" d="M384 384v-128h-128v128h128zM384 1152v-128h-128v128h128zM1152 1152v-128h-128v128h128zM128 129h384v383h-384v-383zM128 896h384v384h-384v-384zM896 896h384v384h-384v-384zM640 640v-640h-640v640h640zM1152 128v-128h-128v128h128zM1408 128v-128h-128v128h128z M1408 640v-384h-384v128h-128v-384h-128v640h384v-128h128v128h128zM640 1408v-640h-640v640h640zM1408 1408v-640h-640v640h640z" />
-<glyph unicode="&#xf02a;" horiz-adv-x="1792" d="M63 0h-63v1408h63v-1408zM126 1h-32v1407h32v-1407zM220 1h-31v1407h31v-1407zM377 1h-31v1407h31v-1407zM534 1h-62v1407h62v-1407zM660 1h-31v1407h31v-1407zM723 1h-31v1407h31v-1407zM786 1h-31v1407h31v-1407zM943 1h-63v1407h63v-1407zM1100 1h-63v1407h63v-1407z M1226 1h-63v1407h63v-1407zM1352 1h-63v1407h63v-1407zM1446 1h-63v1407h63v-1407zM1635 1h-94v1407h94v-1407zM1698 1h-32v1407h32v-1407zM1792 0h-63v1408h63v-1408z" />
-<glyph unicode="&#xf02b;" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91z" />
-<glyph unicode="&#xf02c;" horiz-adv-x="1920" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91zM1899 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-36 0 -59 14t-53 45l470 470q37 37 37 90q0 52 -37 91l-715 714q-38 38 -102 64.5t-117 26.5h224q53 0 117 -26.5t102 -64.5l715 -714q37 -39 37 -91z" />
-<glyph unicode="&#xf02d;" horiz-adv-x="1664" d="M1639 1058q40 -57 18 -129l-275 -906q-19 -64 -76.5 -107.5t-122.5 -43.5h-923q-77 0 -148.5 53.5t-99.5 131.5q-24 67 -2 127q0 4 3 27t4 37q1 8 -3 21.5t-3 19.5q2 11 8 21t16.5 23.5t16.5 23.5q23 38 45 91.5t30 91.5q3 10 0.5 30t-0.5 28q3 11 17 28t17 23 q21 36 42 92t25 90q1 9 -2.5 32t0.5 28q4 13 22 30.5t22 22.5q19 26 42.5 84.5t27.5 96.5q1 8 -3 25.5t-2 26.5q2 8 9 18t18 23t17 21q8 12 16.5 30.5t15 35t16 36t19.5 32t26.5 23.5t36 11.5t47.5 -5.5l-1 -3q38 9 51 9h761q74 0 114 -56t18 -130l-274 -906 q-36 -119 -71.5 -153.5t-128.5 -34.5h-869q-27 0 -38 -15q-11 -16 -1 -43q24 -70 144 -70h923q29 0 56 15.5t35 41.5l300 987q7 22 5 57q38 -15 59 -43zM575 1056q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5 t-16.5 -22.5zM492 800q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5t-16.5 -22.5z" />
-<glyph unicode="&#xf02e;" horiz-adv-x="1280" d="M1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289q0 34 19.5 62t52.5 41q21 9 44 9h1048z" />
-<glyph unicode="&#xf02f;" horiz-adv-x="1664" d="M384 0h896v256h-896v-256zM384 640h896v384h-160q-40 0 -68 28t-28 68v160h-640v-640zM1536 576q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 576v-416q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-160q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68 v160h-224q-13 0 -22.5 9.5t-9.5 22.5v416q0 79 56.5 135.5t135.5 56.5h64v544q0 40 28 68t68 28h672q40 0 88 -20t76 -48l152 -152q28 -28 48 -76t20 -88v-256h64q79 0 135.5 -56.5t56.5 -135.5z" />
-<glyph unicode="&#xf030;" horiz-adv-x="1920" d="M960 864q119 0 203.5 -84.5t84.5 -203.5t-84.5 -203.5t-203.5 -84.5t-203.5 84.5t-84.5 203.5t84.5 203.5t203.5 84.5zM1664 1280q106 0 181 -75t75 -181v-896q0 -106 -75 -181t-181 -75h-1408q-106 0 -181 75t-75 181v896q0 106 75 181t181 75h224l51 136 q19 49 69.5 84.5t103.5 35.5h512q53 0 103.5 -35.5t69.5 -84.5l51 -136h224zM960 128q185 0 316.5 131.5t131.5 316.5t-131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5z" />
-<glyph unicode="&#xf031;" horiz-adv-x="1664" d="M725 977l-170 -450q73 -1 153.5 -2t119 -1.5t52.5 -0.5l29 2q-32 95 -92 241q-53 132 -92 211zM21 -128h-21l2 79q22 7 80 18q89 16 110 31q20 16 48 68l237 616l280 724h75h53l11 -21l205 -480q103 -242 124 -297q39 -102 96 -235q26 -58 65 -164q24 -67 65 -149 q22 -49 35 -57q22 -19 69 -23q47 -6 103 -27q6 -39 6 -57q0 -14 -1 -26q-80 0 -192 8q-93 8 -189 8q-79 0 -135 -2l-200 -11l-58 -2q0 45 4 78l131 28q56 13 68 23q12 12 12 27t-6 32l-47 114l-92 228l-450 2q-29 -65 -104 -274q-23 -64 -23 -84q0 -31 17 -43 q26 -21 103 -32q3 0 13.5 -2t30 -5t40.5 -6q1 -28 1 -58q0 -17 -2 -27q-66 0 -349 20l-48 -8q-81 -14 -167 -14z" />
-<glyph unicode="&#xf032;" horiz-adv-x="1408" d="M555 15q76 -32 140 -32q131 0 216 41t122 113q38 70 38 181q0 114 -41 180q-58 94 -141 126q-80 32 -247 32q-74 0 -101 -10v-144l-1 -173l3 -270q0 -15 12 -44zM541 761q43 -7 109 -7q175 0 264 65t89 224q0 112 -85 187q-84 75 -255 75q-52 0 -130 -13q0 -44 2 -77 q7 -122 6 -279l-1 -98q0 -43 1 -77zM0 -128l2 94q45 9 68 12q77 12 123 31q17 27 21 51q9 66 9 194l-2 497q-5 256 -9 404q-1 87 -11 109q-1 4 -12 12q-18 12 -69 15q-30 2 -114 13l-4 83l260 6l380 13l45 1q5 0 14 0.5t14 0.5q1 0 21.5 -0.5t40.5 -0.5h74q88 0 191 -27 q43 -13 96 -39q57 -29 102 -76q44 -47 65 -104t21 -122q0 -70 -32 -128t-95 -105q-26 -20 -150 -77q177 -41 267 -146q92 -106 92 -236q0 -76 -29 -161q-21 -62 -71 -117q-66 -72 -140 -108q-73 -36 -203 -60q-82 -15 -198 -11l-197 4q-84 2 -298 -11q-33 -3 -272 -11z" />
-<glyph unicode="&#xf033;" horiz-adv-x="1024" d="M0 -126l17 85q4 1 77 20q76 19 116 39q29 37 41 101l27 139l56 268l12 64q8 44 17 84.5t16 67t12.5 46.5t9 30.5t3.5 11.5l29 157l16 63l22 135l8 50v38q-41 22 -144 28q-28 2 -38 4l19 103l317 -14q39 -2 73 -2q66 0 214 9q33 2 68 4.5t36 2.5q-2 -19 -6 -38 q-7 -29 -13 -51q-55 -19 -109 -31q-64 -16 -101 -31q-12 -31 -24 -88q-9 -44 -13 -82q-44 -199 -66 -306l-61 -311l-38 -158l-43 -235l-12 -45q-2 -7 1 -27q64 -15 119 -21q36 -5 66 -10q-1 -29 -7 -58q-7 -31 -9 -41q-18 0 -23 -1q-24 -2 -42 -2q-9 0 -28 3q-19 4 -145 17 l-198 2q-41 1 -174 -11q-74 -7 -98 -9z" />
-<glyph unicode="&#xf034;" horiz-adv-x="1792" d="M81 1407l54 -27q20 -5 211 -5h130l19 3l115 1l215 -1h293l34 -2q14 -1 28 7t21 16l7 8l42 1q15 0 28 -1v-104.5t1 -131.5l1 -100l-1 -58q0 -32 -4 -51q-39 -15 -68 -18q-25 43 -54 128q-8 24 -15.5 62.5t-11.5 65.5t-6 29q-13 15 -27 19q-7 2 -42.5 2t-103.5 -1t-111 -1 q-34 0 -67 -5q-10 -97 -8 -136l1 -152v-332l3 -359l-1 -147q-1 -46 11 -85q49 -25 89 -32q2 0 18 -5t44 -13t43 -12q30 -8 50 -18q5 -45 5 -50q0 -10 -3 -29q-14 -1 -34 -1q-110 0 -187 10q-72 8 -238 8q-88 0 -233 -14q-48 -4 -70 -4q-2 22 -2 26l-1 26v9q21 33 79 49 q139 38 159 50q9 21 12 56q8 192 6 433l-5 428q-1 62 -0.5 118.5t0.5 102.5t-2 57t-6 15q-6 5 -14 6q-38 6 -148 6q-43 0 -100 -13.5t-73 -24.5q-13 -9 -22 -33t-22 -75t-24 -84q-6 -19 -19.5 -32t-20.5 -13q-44 27 -56 44v297v86zM1744 128q33 0 42 -18.5t-11 -44.5 l-126 -162q-20 -26 -49 -26t-49 26l-126 162q-20 26 -11 44.5t42 18.5h80v1024h-80q-33 0 -42 18.5t11 44.5l126 162q20 26 49 26t49 -26l126 -162q20 -26 11 -44.5t-42 -18.5h-80v-1024h80z" />
-<glyph unicode="&#xf035;" d="M81 1407l54 -27q20 -5 211 -5h130l19 3l115 1l446 -1h318l34 -2q14 -1 28 7t21 16l7 8l42 1q15 0 28 -1v-104.5t1 -131.5l1 -100l-1 -58q0 -32 -4 -51q-39 -15 -68 -18q-25 43 -54 128q-8 24 -15.5 62.5t-11.5 65.5t-6 29q-13 15 -27 19q-7 2 -58.5 2t-138.5 -1t-128 -1 q-94 0 -127 -5q-10 -97 -8 -136l1 -152v52l3 -359l-1 -147q-1 -46 11 -85q49 -25 89 -32q2 0 18 -5t44 -13t43 -12q30 -8 50 -18q5 -45 5 -50q0 -10 -3 -29q-14 -1 -34 -1q-110 0 -187 10q-72 8 -238 8q-82 0 -233 -13q-45 -5 -70 -5q-2 22 -2 26l-1 26v9q21 33 79 49 q139 38 159 50q9 21 12 56q6 137 6 433l-5 44q0 265 -2 278q-2 11 -6 15q-6 5 -14 6q-38 6 -148 6q-50 0 -168.5 -14t-132.5 -24q-13 -9 -22 -33t-22 -75t-24 -84q-6 -19 -19.5 -32t-20.5 -13q-44 27 -56 44v297v86zM1505 113q26 -20 26 -49t-26 -49l-162 -126 q-26 -20 -44.5 -11t-18.5 42v80h-1024v-80q0 -33 -18.5 -42t-44.5 11l-162 126q-26 20 -26 49t26 49l162 126q26 20 44.5 11t18.5 -42v-80h1024v80q0 33 18.5 42t44.5 -11z" />
-<glyph unicode="&#xf036;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf037;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h896q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45t-45 -19 h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h640q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf038;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf039;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf03a;" horiz-adv-x="1792" d="M256 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM256 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5 t9.5 -22.5zM256 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344 q13 0 22.5 -9.5t9.5 -22.5zM256 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192 q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5z" />
-<glyph unicode="&#xf03b;" horiz-adv-x="1792" d="M384 992v-576q0 -13 -9.5 -22.5t-22.5 -9.5q-14 0 -23 9l-288 288q-9 9 -9 23t9 23l288 288q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" />
-<glyph unicode="&#xf03c;" horiz-adv-x="1792" d="M352 704q0 -14 -9 -23l-288 -288q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v576q0 13 9.5 22.5t22.5 9.5q14 0 23 -9l288 -288q9 -9 9 -23zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" />
-<glyph unicode="&#xf03d;" horiz-adv-x="1792" d="M1792 1184v-1088q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-403 403v-166q0 -119 -84.5 -203.5t-203.5 -84.5h-704q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h704q119 0 203.5 -84.5t84.5 -203.5v-165l403 402q18 19 45 19q12 0 25 -5 q39 -17 39 -59z" />
-<glyph unicode="&#xf03e;" horiz-adv-x="1920" d="M640 960q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1664 576v-448h-1408v192l320 320l160 -160l512 512zM1760 1280h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-1216q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5v1216 q0 13 -9.5 22.5t-22.5 9.5zM1920 1248v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf040;" d="M363 0l91 91l-235 235l-91 -91v-107h128v-128h107zM886 928q0 22 -22 22q-10 0 -17 -7l-542 -542q-7 -7 -7 -17q0 -22 22 -22q10 0 17 7l542 542q7 7 7 17zM832 1120l416 -416l-832 -832h-416v416zM1515 1024q0 -53 -37 -90l-166 -166l-416 416l166 165q36 38 90 38 q53 0 91 -38l235 -234q37 -39 37 -91z" />
-<glyph unicode="&#xf041;" horiz-adv-x="1024" d="M768 896q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1024 896q0 -109 -33 -179l-364 -774q-16 -33 -47.5 -52t-67.5 -19t-67.5 19t-46.5 52l-365 774q-33 70 -33 179q0 212 150 362t362 150t362 -150t150 -362z" />
-<glyph unicode="&#xf042;" d="M768 96v1088q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf043;" horiz-adv-x="1024" d="M512 384q0 36 -20 69q-1 1 -15.5 22.5t-25.5 38t-25 44t-21 50.5q-4 16 -21 16t-21 -16q-7 -23 -21 -50.5t-25 -44t-25.5 -38t-15.5 -22.5q-20 -33 -20 -69q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 512q0 -212 -150 -362t-362 -150t-362 150t-150 362 q0 145 81 275q6 9 62.5 90.5t101 151t99.5 178t83 201.5q9 30 34 47t51 17t51.5 -17t33.5 -47q28 -93 83 -201.5t99.5 -178t101 -151t62.5 -90.5q81 -127 81 -275z" />
-<glyph unicode="&#xf044;" horiz-adv-x="1792" d="M888 352l116 116l-152 152l-116 -116v-56h96v-96h56zM1328 1072q-16 16 -33 -1l-350 -350q-17 -17 -1 -33t33 1l350 350q17 17 1 33zM1408 478v-190q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-14 -14 -32 -8q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v126q0 13 9 22l64 64q15 15 35 7t20 -29zM1312 1216l288 -288l-672 -672h-288v288zM1756 1084l-92 -92 l-288 288l92 92q28 28 68 28t68 -28l152 -152q28 -28 28 -68t-28 -68z" />
-<glyph unicode="&#xf045;" horiz-adv-x="1664" d="M1408 547v-259q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h255v0q13 0 22.5 -9.5t9.5 -22.5q0 -27 -26 -32q-77 -26 -133 -60q-10 -4 -16 -4h-112q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832 q66 0 113 47t47 113v214q0 19 18 29q28 13 54 37q16 16 35 8q21 -9 21 -29zM1645 1043l-384 -384q-18 -19 -45 -19q-12 0 -25 5q-39 17 -39 59v192h-160q-323 0 -438 -131q-119 -137 -74 -473q3 -23 -20 -34q-8 -2 -12 -2q-16 0 -26 13q-10 14 -21 31t-39.5 68.5t-49.5 99.5 t-38.5 114t-17.5 122q0 49 3.5 91t14 90t28 88t47 81.5t68.5 74t94.5 61.5t124.5 48.5t159.5 30.5t196.5 11h160v192q0 42 39 59q13 5 25 5q26 0 45 -19l384 -384q19 -19 19 -45t-19 -45z" />
-<glyph unicode="&#xf046;" horiz-adv-x="1664" d="M1408 606v-318q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-10 -10 -23 -10q-3 0 -9 2q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832 q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v254q0 13 9 22l64 64q10 10 23 10q6 0 12 -3q20 -8 20 -29zM1639 1095l-814 -814q-24 -24 -57 -24t-57 24l-430 430q-24 24 -24 57t24 57l110 110q24 24 57 24t57 -24l263 -263l647 647q24 24 57 24t57 -24l110 -110 q24 -24 24 -57t-24 -57z" />
-<glyph unicode="&#xf047;" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-384v-384h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v384h-384v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45 t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h384v384h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45t-19 -45t-45 -19h-128v-384h384v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" />
-<glyph unicode="&#xf048;" horiz-adv-x="1024" d="M979 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19z" />
-<glyph unicode="&#xf049;" horiz-adv-x="1792" d="M1747 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19l710 710 q19 19 32 13t13 -32v-710q4 11 13 19z" />
-<glyph unicode="&#xf04a;" horiz-adv-x="1664" d="M1619 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-8 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-19 19 -19 45t19 45l710 710q19 19 32 13t13 -32v-710q5 11 13 19z" />
-<glyph unicode="&#xf04b;" horiz-adv-x="1408" d="M1384 609l-1328 -738q-23 -13 -39.5 -3t-16.5 36v1472q0 26 16.5 36t39.5 -3l1328 -738q23 -13 23 -31t-23 -31z" />
-<glyph unicode="&#xf04c;" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45zM640 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf04d;" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf04e;" horiz-adv-x="1664" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q19 -19 19 -45t-19 -45l-710 -710q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" />
-<glyph unicode="&#xf050;" horiz-adv-x="1792" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19l-710 -710 q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" />
-<glyph unicode="&#xf051;" horiz-adv-x="1024" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19z" />
-<glyph unicode="&#xf052;" horiz-adv-x="1538" d="M14 557l710 710q19 19 45 19t45 -19l710 -710q19 -19 13 -32t-32 -13h-1472q-26 0 -32 13t13 32zM1473 0h-1408q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1408q26 0 45 -19t19 -45v-256q0 -26 -19 -45t-45 -19z" />
-<glyph unicode="&#xf053;" horiz-adv-x="1152" d="M742 -37l-652 651q-37 37 -37 90.5t37 90.5l652 651q37 37 90.5 37t90.5 -37l75 -75q37 -37 37 -90.5t-37 -90.5l-486 -486l486 -485q37 -38 37 -91t-37 -90l-75 -75q-37 -37 -90.5 -37t-90.5 37z" />
-<glyph unicode="&#xf054;" horiz-adv-x="1152" d="M1099 704q0 -52 -37 -91l-652 -651q-37 -37 -90 -37t-90 37l-76 75q-37 39 -37 91q0 53 37 90l486 486l-486 485q-37 39 -37 91q0 53 37 90l76 75q36 38 90 38t90 -38l652 -651q37 -37 37 -90z" />
-<glyph unicode="&#xf055;" d="M1216 576v128q0 26 -19 45t-45 19h-256v256q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-256h-256q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h256v-256q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v256h256q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5 t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf056;" d="M1216 576v128q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5 t103 -385.5z" />
-<glyph unicode="&#xf057;" d="M1149 414q0 26 -19 45l-181 181l181 181q19 19 19 45q0 27 -19 46l-90 90q-19 19 -46 19q-26 0 -45 -19l-181 -181l-181 181q-19 19 -45 19q-27 0 -46 -19l-90 -90q-19 -19 -19 -46q0 -26 19 -45l181 -181l-181 -181q-19 -19 -19 -45q0 -27 19 -46l90 -90q19 -19 46 -19 q26 0 45 19l181 181l181 -181q19 -19 45 -19q27 0 46 19l90 90q19 19 19 46zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf058;" d="M1284 802q0 28 -18 46l-91 90q-19 19 -45 19t-45 -19l-408 -407l-226 226q-19 19 -45 19t-45 -19l-91 -90q-18 -18 -18 -46q0 -27 18 -45l362 -362q19 -19 45 -19q27 0 46 19l543 543q18 18 18 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf059;" d="M896 160v192q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h192q14 0 23 9t9 23zM1152 832q0 88 -55.5 163t-138.5 116t-170 41q-243 0 -371 -213q-15 -24 8 -42l132 -100q7 -6 19 -6q16 0 25 12q53 68 86 92q34 24 86 24q48 0 85.5 -26t37.5 -59 q0 -38 -20 -61t-68 -45q-63 -28 -115.5 -86.5t-52.5 -125.5v-36q0 -14 9 -23t23 -9h192q14 0 23 9t9 23q0 19 21.5 49.5t54.5 49.5q32 18 49 28.5t46 35t44.5 48t28 60.5t12.5 81zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf05a;" d="M1024 160v160q0 14 -9 23t-23 9h-96v512q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h96v-320h-96q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h448q14 0 23 9t9 23zM896 1056v160q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23 t23 -9h192q14 0 23 9t9 23zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf05b;" d="M1197 512h-109q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h109q-32 108 -112.5 188.5t-188.5 112.5v-109q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v109q-108 -32 -188.5 -112.5t-112.5 -188.5h109q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-109 q32 -108 112.5 -188.5t188.5 -112.5v109q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-109q108 32 188.5 112.5t112.5 188.5zM1536 704v-128q0 -26 -19 -45t-45 -19h-143q-37 -161 -154.5 -278.5t-278.5 -154.5v-143q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v143 q-161 37 -278.5 154.5t-154.5 278.5h-143q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h143q37 161 154.5 278.5t278.5 154.5v143q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-143q161 -37 278.5 -154.5t154.5 -278.5h143q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf05c;" d="M1097 457l-146 -146q-10 -10 -23 -10t-23 10l-137 137l-137 -137q-10 -10 -23 -10t-23 10l-146 146q-10 10 -10 23t10 23l137 137l-137 137q-10 10 -10 23t10 23l146 146q10 10 23 10t23 -10l137 -137l137 137q10 10 23 10t23 -10l146 -146q10 -10 10 -23t-10 -23 l-137 -137l137 -137q10 -10 10 -23t-10 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5 t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf05d;" d="M1171 723l-422 -422q-19 -19 -45 -19t-45 19l-294 294q-19 19 -19 45t19 45l102 102q19 19 45 19t45 -19l147 -147l275 275q19 19 45 19t45 -19l102 -102q19 -19 19 -45t-19 -45zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198 t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf05e;" d="M1312 643q0 161 -87 295l-754 -753q137 -89 297 -89q111 0 211.5 43.5t173.5 116.5t116 174.5t43 212.5zM313 344l755 754q-135 91 -300 91q-148 0 -273 -73t-198 -199t-73 -274q0 -162 89 -299zM1536 643q0 -157 -61 -300t-163.5 -246t-245 -164t-298.5 -61t-298.5 61 t-245 164t-163.5 246t-61 300t61 299.5t163.5 245.5t245 164t298.5 61t298.5 -61t245 -164t163.5 -245.5t61 -299.5z" />
-<glyph unicode="&#xf060;" d="M1536 640v-128q0 -53 -32.5 -90.5t-84.5 -37.5h-704l293 -294q38 -36 38 -90t-38 -90l-75 -76q-37 -37 -90 -37q-52 0 -91 37l-651 652q-37 37 -37 90q0 52 37 91l651 650q38 38 91 38q52 0 90 -38l75 -74q38 -38 38 -91t-38 -91l-293 -293h704q52 0 84.5 -37.5 t32.5 -90.5z" />
-<glyph unicode="&#xf061;" d="M1472 576q0 -54 -37 -91l-651 -651q-39 -37 -91 -37q-51 0 -90 37l-75 75q-38 38 -38 91t38 91l293 293h-704q-52 0 -84.5 37.5t-32.5 90.5v128q0 53 32.5 90.5t84.5 37.5h704l-293 294q-38 36 -38 90t38 90l75 75q38 38 90 38q53 0 91 -38l651 -651q37 -35 37 -90z" />
-<glyph unicode="&#xf062;" horiz-adv-x="1664" d="M1611 565q0 -51 -37 -90l-75 -75q-38 -38 -91 -38q-54 0 -90 38l-294 293v-704q0 -52 -37.5 -84.5t-90.5 -32.5h-128q-53 0 -90.5 32.5t-37.5 84.5v704l-294 -293q-36 -38 -90 -38t-90 38l-75 75q-38 38 -38 90q0 53 38 91l651 651q35 37 90 37q54 0 91 -37l651 -651 q37 -39 37 -91z" />
-<glyph unicode="&#xf063;" horiz-adv-x="1664" d="M1611 704q0 -53 -37 -90l-651 -652q-39 -37 -91 -37q-53 0 -90 37l-651 652q-38 36 -38 90q0 53 38 91l74 75q39 37 91 37q53 0 90 -37l294 -294v704q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-704l294 294q37 37 90 37q52 0 91 -37l75 -75q37 -39 37 -91z" />
-<glyph unicode="&#xf064;" horiz-adv-x="1792" d="M1792 896q0 -26 -19 -45l-512 -512q-19 -19 -45 -19t-45 19t-19 45v256h-224q-98 0 -175.5 -6t-154 -21.5t-133 -42.5t-105.5 -69.5t-80 -101t-48.5 -138.5t-17.5 -181q0 -55 5 -123q0 -6 2.5 -23.5t2.5 -26.5q0 -15 -8.5 -25t-23.5 -10q-16 0 -28 17q-7 9 -13 22 t-13.5 30t-10.5 24q-127 285 -127 451q0 199 53 333q162 403 875 403h224v256q0 26 19 45t45 19t45 -19l512 -512q19 -19 19 -45z" />
-<glyph unicode="&#xf065;" d="M755 480q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23zM1536 1344v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332 q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf066;" d="M768 576v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45zM1523 1248q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45 t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23z" />
-<glyph unicode="&#xf067;" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-416v-416q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v416h-416q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h416v416q0 40 28 68t68 28h192q40 0 68 -28t28 -68v-416h416q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf068;" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-1216q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h1216q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf069;" horiz-adv-x="1664" d="M1482 486q46 -26 59.5 -77.5t-12.5 -97.5l-64 -110q-26 -46 -77.5 -59.5t-97.5 12.5l-266 153v-307q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v307l-266 -153q-46 -26 -97.5 -12.5t-77.5 59.5l-64 110q-26 46 -12.5 97.5t59.5 77.5l266 154l-266 154 q-46 26 -59.5 77.5t12.5 97.5l64 110q26 46 77.5 59.5t97.5 -12.5l266 -153v307q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-307l266 153q46 26 97.5 12.5t77.5 -59.5l64 -110q26 -46 12.5 -97.5t-59.5 -77.5l-266 -154z" />
-<glyph unicode="&#xf06a;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM896 161v190q0 14 -9 23.5t-22 9.5h-192q-13 0 -23 -10t-10 -23v-190q0 -13 10 -23t23 -10h192 q13 0 22 9.5t9 23.5zM894 505l18 621q0 12 -10 18q-10 8 -24 8h-220q-14 0 -24 -8q-10 -6 -10 -18l17 -621q0 -10 10 -17.5t24 -7.5h185q14 0 23.5 7.5t10.5 17.5z" />
-<glyph unicode="&#xf06b;" d="M928 180v56v468v192h-320v-192v-468v-56q0 -25 18 -38.5t46 -13.5h192q28 0 46 13.5t18 38.5zM472 1024h195l-126 161q-26 31 -69 31q-40 0 -68 -28t-28 -68t28 -68t68 -28zM1160 1120q0 40 -28 68t-68 28q-43 0 -69 -31l-125 -161h194q40 0 68 28t28 68zM1536 864v-320 q0 -14 -9 -23t-23 -9h-96v-416q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v416h-96q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h440q-93 0 -158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5q107 0 168 -77l128 -165l128 165q61 77 168 77q93 0 158.5 -65.5t65.5 -158.5 t-65.5 -158.5t-158.5 -65.5h440q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf06c;" horiz-adv-x="1792" d="M1280 832q0 26 -19 45t-45 19q-172 0 -318 -49.5t-259.5 -134t-235.5 -219.5q-19 -21 -19 -45q0 -26 19 -45t45 -19q24 0 45 19q27 24 74 71t67 66q137 124 268.5 176t313.5 52q26 0 45 19t19 45zM1792 1030q0 -95 -20 -193q-46 -224 -184.5 -383t-357.5 -268 q-214 -108 -438 -108q-148 0 -286 47q-15 5 -88 42t-96 37q-16 0 -39.5 -32t-45 -70t-52.5 -70t-60 -32q-30 0 -51 11t-31 24t-27 42q-2 4 -6 11t-5.5 10t-3 9.5t-1.5 13.5q0 35 31 73.5t68 65.5t68 56t31 48q0 4 -14 38t-16 44q-9 51 -9 104q0 115 43.5 220t119 184.5 t170.5 139t204 95.5q55 18 145 25.5t179.5 9t178.5 6t163.5 24t113.5 56.5l29.5 29.5t29.5 28t27 20t36.5 16t43.5 4.5q39 0 70.5 -46t47.5 -112t24 -124t8 -96z" />
-<glyph unicode="&#xf06d;" horiz-adv-x="1408" d="M1408 -160v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1152 896q0 -78 -24.5 -144t-64 -112.5t-87.5 -88t-96 -77.5t-87.5 -72t-64 -81.5t-24.5 -96.5q0 -96 67 -224l-4 1l1 -1 q-90 41 -160 83t-138.5 100t-113.5 122.5t-72.5 150.5t-27.5 184q0 78 24.5 144t64 112.5t87.5 88t96 77.5t87.5 72t64 81.5t24.5 96.5q0 94 -66 224l3 -1l-1 1q90 -41 160 -83t138.5 -100t113.5 -122.5t72.5 -150.5t27.5 -184z" />
-<glyph unicode="&#xf06e;" horiz-adv-x="1792" d="M1664 576q-152 236 -381 353q61 -104 61 -225q0 -185 -131.5 -316.5t-316.5 -131.5t-316.5 131.5t-131.5 316.5q0 121 61 225q-229 -117 -381 -353q133 -205 333.5 -326.5t434.5 -121.5t434.5 121.5t333.5 326.5zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5 t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1792 576q0 -34 -20 -69q-140 -230 -376.5 -368.5t-499.5 -138.5t-499.5 139t-376.5 368q-20 35 -20 69t20 69q140 229 376.5 368t499.5 139t499.5 -139t376.5 -368q20 -35 20 -69z" />
-<glyph unicode="&#xf070;" horiz-adv-x="1792" d="M555 201l78 141q-87 63 -136 159t-49 203q0 121 61 225q-229 -117 -381 -353q167 -258 427 -375zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1307 1151q0 -7 -1 -9 q-105 -188 -315 -566t-316 -567l-49 -89q-10 -16 -28 -16q-12 0 -134 70q-16 10 -16 28q0 12 44 87q-143 65 -263.5 173t-208.5 245q-20 31 -20 69t20 69q153 235 380 371t496 136q89 0 180 -17l54 97q10 16 28 16q5 0 18 -6t31 -15.5t33 -18.5t31.5 -18.5t19.5 -11.5 q16 -10 16 -27zM1344 704q0 -139 -79 -253.5t-209 -164.5l280 502q8 -45 8 -84zM1792 576q0 -35 -20 -69q-39 -64 -109 -145q-150 -172 -347.5 -267t-419.5 -95l74 132q212 18 392.5 137t301.5 307q-115 179 -282 294l63 112q95 -64 182.5 -153t144.5 -184q20 -34 20 -69z " />
-<glyph unicode="&#xf071;" horiz-adv-x="1792" d="M1024 161v190q0 14 -9.5 23.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -23.5v-190q0 -14 9.5 -23.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 23.5zM1022 535l18 459q0 12 -10 19q-13 11 -24 11h-220q-11 0 -24 -11q-10 -7 -10 -21l17 -457q0 -10 10 -16.5t24 -6.5h185 q14 0 23.5 6.5t10.5 16.5zM1008 1469l768 -1408q35 -63 -2 -126q-17 -29 -46.5 -46t-63.5 -17h-1536q-34 0 -63.5 17t-46.5 46q-37 63 -2 126l768 1408q17 31 47 49t65 18t65 -18t47 -49z" />
-<glyph unicode="&#xf072;" horiz-adv-x="1408" d="M1376 1376q44 -52 12 -148t-108 -172l-161 -161l160 -696q5 -19 -12 -33l-128 -96q-7 -6 -19 -6q-4 0 -7 1q-15 3 -21 16l-279 508l-259 -259l53 -194q5 -17 -8 -31l-96 -96q-9 -9 -23 -9h-2q-15 2 -24 13l-189 252l-252 189q-11 7 -13 23q-1 13 9 25l96 97q9 9 23 9 q6 0 8 -1l194 -53l259 259l-508 279q-14 8 -17 24q-2 16 9 27l128 128q14 13 30 8l665 -159l160 160q76 76 172 108t148 -12z" />
-<glyph unicode="&#xf073;" horiz-adv-x="1664" d="M128 -128h288v288h-288v-288zM480 -128h320v288h-320v-288zM128 224h288v320h-288v-320zM480 224h320v320h-320v-320zM128 608h288v288h-288v-288zM864 -128h320v288h-320v-288zM480 608h320v288h-320v-288zM1248 -128h288v288h-288v-288zM864 224h320v320h-320v-320z M512 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1248 224h288v320h-288v-320zM864 608h320v288h-320v-288zM1248 608h288v288h-288v-288zM1280 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64 q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1664 1152v-1280q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47 h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" />
-<glyph unicode="&#xf074;" horiz-adv-x="1792" d="M666 1055q-60 -92 -137 -273q-22 45 -37 72.5t-40.5 63.5t-51 56.5t-63 35t-81.5 14.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q250 0 410 -225zM1792 256q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192q-32 0 -85 -0.5t-81 -1t-73 1 t-71 5t-64 10.5t-63 18.5t-58 28.5t-59 40t-55 53.5t-56 69.5q59 93 136 273q22 -45 37 -72.5t40.5 -63.5t51 -56.5t63 -35t81.5 -14.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1792 1152q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5 v192h-256q-48 0 -87 -15t-69 -45t-51 -61.5t-45 -77.5q-32 -62 -78 -171q-29 -66 -49.5 -111t-54 -105t-64 -100t-74 -83t-90 -68.5t-106.5 -42t-128 -16.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q48 0 87 15t69 45t51 61.5t45 77.5q32 62 78 171q29 66 49.5 111 t54 105t64 100t74 83t90 68.5t106.5 42t128 16.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" />
-<glyph unicode="&#xf075;" horiz-adv-x="1792" d="M1792 640q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22q-17 -2 -30.5 9t-17.5 29v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281 q0 130 71 248.5t191 204.5t286 136.5t348 50.5q244 0 450 -85.5t326 -233t120 -321.5z" />
-<glyph unicode="&#xf076;" d="M1536 704v-128q0 -201 -98.5 -362t-274 -251.5t-395.5 -90.5t-395.5 90.5t-274 251.5t-98.5 362v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-128q0 -52 23.5 -90t53.5 -57t71 -30t64 -13t44 -2t44 2t64 13t71 30t53.5 57t23.5 90v128q0 26 19 45t45 19h384 q26 0 45 -19t19 -45zM512 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45zM1536 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf077;" horiz-adv-x="1664" d="M1611 320q0 -53 -37 -90l-75 -75q-38 -38 -91 -38q-54 0 -90 38l-486 485l-486 -485q-36 -38 -90 -38t-90 38l-75 75q-38 36 -38 90q0 53 38 91l651 651q37 37 90 37q52 0 91 -37l650 -651q38 -38 38 -91z" />
-<glyph unicode="&#xf078;" horiz-adv-x="1664" d="M1611 832q0 -53 -37 -90l-651 -651q-38 -38 -91 -38q-54 0 -90 38l-651 651q-38 36 -38 90q0 53 38 91l74 75q39 37 91 37q53 0 90 -37l486 -486l486 486q37 37 90 37q52 0 91 -37l75 -75q37 -39 37 -91z" />
-<glyph unicode="&#xf079;" horiz-adv-x="1920" d="M1280 32q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-8 0 -13.5 2t-9 7t-5.5 8t-3 11.5t-1 11.5v13v11v160v416h-192q-26 0 -45 19t-19 45q0 24 15 41l320 384q19 22 49 22t49 -22l320 -384q15 -17 15 -41q0 -26 -19 -45t-45 -19h-192v-384h576q16 0 25 -11l160 -192q7 -11 7 -21 zM1920 448q0 -24 -15 -41l-320 -384q-20 -23 -49 -23t-49 23l-320 384q-15 17 -15 41q0 26 19 45t45 19h192v384h-576q-16 0 -25 12l-160 192q-7 9 -7 20q0 13 9.5 22.5t22.5 9.5h960q8 0 13.5 -2t9 -7t5.5 -8t3 -11.5t1 -11.5v-13v-11v-160v-416h192q26 0 45 -19t19 -45z " />
-<glyph unicode="&#xf07a;" horiz-adv-x="1664" d="M640 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1536 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1664 1088v-512q0 -24 -16 -42.5t-41 -21.5 l-1044 -122q1 -7 4.5 -21.5t6 -26.5t2.5 -22q0 -16 -24 -64h920q26 0 45 -19t19 -45t-19 -45t-45 -19h-1024q-26 0 -45 19t-19 45q0 14 11 39.5t29.5 59.5t20.5 38l-177 823h-204q-26 0 -45 19t-19 45t19 45t45 19h256q16 0 28.5 -6.5t20 -15.5t13 -24.5t7.5 -26.5 t5.5 -29.5t4.5 -25.5h1201q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf07b;" horiz-adv-x="1664" d="M1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" />
-<glyph unicode="&#xf07c;" horiz-adv-x="1920" d="M1879 584q0 -31 -31 -66l-336 -396q-43 -51 -120.5 -86.5t-143.5 -35.5h-1088q-34 0 -60.5 13t-26.5 43q0 31 31 66l336 396q43 51 120.5 86.5t143.5 35.5h1088q34 0 60.5 -13t26.5 -43zM1536 928v-160h-832q-94 0 -197 -47.5t-164 -119.5l-337 -396l-5 -6q0 4 -0.5 12.5 t-0.5 12.5v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158z" />
-<glyph unicode="&#xf07d;" horiz-adv-x="768" d="M704 1216q0 -26 -19 -45t-45 -19h-128v-1024h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v1024h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45z" />
-<glyph unicode="&#xf07e;" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-1024v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h1024v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" />
-<glyph unicode="&#xf080;" horiz-adv-x="1920" d="M512 512v-384h-256v384h256zM896 1024v-896h-256v896h256zM1280 768v-640h-256v640h256zM1664 1152v-1024h-256v1024h256zM1792 32v1216q0 13 -9.5 22.5t-22.5 9.5h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-1216q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5z M1920 1248v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf081;" d="M1280 926q-56 -25 -121 -34q68 40 93 117q-65 -38 -134 -51q-61 66 -153 66q-87 0 -148.5 -61.5t-61.5 -148.5q0 -29 5 -48q-129 7 -242 65t-192 155q-29 -50 -29 -106q0 -114 91 -175q-47 1 -100 26v-2q0 -75 50 -133.5t123 -72.5q-29 -8 -51 -8q-13 0 -39 4 q21 -63 74.5 -104t121.5 -42q-116 -90 -261 -90q-26 0 -50 3q148 -94 322 -94q112 0 210 35.5t168 95t120.5 137t75 162t24.5 168.5q0 18 -1 27q63 45 105 109zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5 t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf082;" d="M1307 618l23 219h-198v109q0 49 15.5 68.5t71.5 19.5h110v219h-175q-152 0 -218 -72t-66 -213v-131h-131v-219h131v-635h262v635h175zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960 q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf083;" horiz-adv-x="1792" d="M928 704q0 14 -9 23t-23 9q-66 0 -113 -47t-47 -113q0 -14 9 -23t23 -9t23 9t9 23q0 40 28 68t68 28q14 0 23 9t9 23zM1152 574q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM128 0h1536v128h-1536v-128zM1280 574q0 159 -112.5 271.5 t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM256 1216h384v128h-384v-128zM128 1024h1536v118v138h-828l-64 -128h-644v-128zM1792 1280v-1280q0 -53 -37.5 -90.5t-90.5 -37.5h-1536q-53 0 -90.5 37.5t-37.5 90.5v1280 q0 53 37.5 90.5t90.5 37.5h1536q53 0 90.5 -37.5t37.5 -90.5z" />
-<glyph unicode="&#xf084;" horiz-adv-x="1792" d="M832 1024q0 80 -56 136t-136 56t-136 -56t-56 -136q0 -42 19 -83q-41 19 -83 19q-80 0 -136 -56t-56 -136t56 -136t136 -56t136 56t56 136q0 42 -19 83q41 -19 83 -19q80 0 136 56t56 136zM1683 320q0 -17 -49 -66t-66 -49q-9 0 -28.5 16t-36.5 33t-38.5 40t-24.5 26 l-96 -96l220 -220q28 -28 28 -68q0 -42 -39 -81t-81 -39q-40 0 -68 28l-671 671q-176 -131 -365 -131q-163 0 -265.5 102.5t-102.5 265.5q0 160 95 313t248 248t313 95q163 0 265.5 -102.5t102.5 -265.5q0 -189 -131 -365l355 -355l96 96q-3 3 -26 24.5t-40 38.5t-33 36.5 t-16 28.5q0 17 49 66t66 49q13 0 23 -10q6 -6 46 -44.5t82 -79.5t86.5 -86t73 -78t28.5 -41z" />
-<glyph unicode="&#xf085;" horiz-adv-x="1920" d="M896 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1664 128q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 1152q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1280 731v-185q0 -10 -7 -19.5t-16 -10.5l-155 -24q-11 -35 -32 -76q34 -48 90 -115q7 -10 7 -20q0 -12 -7 -19q-23 -30 -82.5 -89.5t-78.5 -59.5q-11 0 -21 7l-115 90q-37 -19 -77 -31q-11 -108 -23 -155q-7 -24 -30 -24h-186q-11 0 -20 7.5t-10 17.5 l-23 153q-34 10 -75 31l-118 -89q-7 -7 -20 -7q-11 0 -21 8q-144 133 -144 160q0 9 7 19q10 14 41 53t47 61q-23 44 -35 82l-152 24q-10 1 -17 9.5t-7 19.5v185q0 10 7 19.5t16 10.5l155 24q11 35 32 76q-34 48 -90 115q-7 11 -7 20q0 12 7 20q22 30 82 89t79 59q11 0 21 -7 l115 -90q34 18 77 32q11 108 23 154q7 24 30 24h186q11 0 20 -7.5t10 -17.5l23 -153q34 -10 75 -31l118 89q8 7 20 7q11 0 21 -8q144 -133 144 -160q0 -9 -7 -19q-12 -16 -42 -54t-45 -60q23 -48 34 -82l152 -23q10 -2 17 -10.5t7 -19.5zM1920 198v-140q0 -16 -149 -31 q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20 t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31zM1920 1222v-140q0 -16 -149 -31q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68 q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70 q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31z" />
-<glyph unicode="&#xf086;" horiz-adv-x="1792" d="M1408 768q0 -139 -94 -257t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224 q0 139 94 257t256.5 186.5t353.5 68.5t353.5 -68.5t256.5 -186.5t94 -257zM1792 512q0 -120 -71 -224.5t-195 -176.5q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7 q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230z" />
-<glyph unicode="&#xf087;" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 768q0 51 -39 89.5t-89 38.5h-352q0 58 48 159.5t48 160.5q0 98 -32 145t-128 47q-26 -26 -38 -85t-30.5 -125.5t-59.5 -109.5q-22 -23 -77 -91q-4 -5 -23 -30t-31.5 -41t-34.5 -42.5 t-40 -44t-38.5 -35.5t-40 -27t-35.5 -9h-32v-640h32q13 0 31.5 -3t33 -6.5t38 -11t35 -11.5t35.5 -12.5t29 -10.5q211 -73 342 -73h121q192 0 192 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5q32 1 53.5 47t21.5 81zM1536 769 q0 -89 -49 -163q9 -33 9 -69q0 -77 -38 -144q3 -21 3 -43q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5h-36h-93q-96 0 -189.5 22.5t-216.5 65.5q-116 40 -138 40h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h274q36 24 137 155q58 75 107 128 q24 25 35.5 85.5t30.5 126.5t62 108q39 37 90 37q84 0 151 -32.5t102 -101.5t35 -186q0 -93 -48 -192h176q104 0 180 -76t76 -179z" />
-<glyph unicode="&#xf088;" d="M256 1088q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 512q0 35 -21.5 81t-53.5 47q15 17 25 47.5t10 55.5q0 69 -53 119q18 32 18 69t-17.5 73.5t-47.5 52.5q5 30 5 56q0 85 -49 126t-136 41h-128q-131 0 -342 -73q-5 -2 -29 -10.5 t-35.5 -12.5t-35 -11.5t-38 -11t-33 -6.5t-31.5 -3h-32v-640h32q16 0 35.5 -9t40 -27t38.5 -35.5t40 -44t34.5 -42.5t31.5 -41t23 -30q55 -68 77 -91q41 -43 59.5 -109.5t30.5 -125.5t38 -85q96 0 128 47t32 145q0 59 -48 160.5t-48 159.5h352q50 0 89 38.5t39 89.5z M1536 511q0 -103 -76 -179t-180 -76h-176q48 -99 48 -192q0 -118 -35 -186q-35 -69 -102 -101.5t-151 -32.5q-51 0 -90 37q-34 33 -54 82t-25.5 90.5t-17.5 84.5t-31 64q-48 50 -107 127q-101 131 -137 155h-274q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5 h288q22 0 138 40q128 44 223 66t200 22h112q140 0 226.5 -79t85.5 -216v-5q60 -77 60 -178q0 -22 -3 -43q38 -67 38 -144q0 -36 -9 -69q49 -74 49 -163z" />
-<glyph unicode="&#xf089;" horiz-adv-x="896" d="M832 1504v-1339l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41z" />
-<glyph unicode="&#xf08a;" horiz-adv-x="1792" d="M1664 940q0 81 -21.5 143t-55 98.5t-81.5 59.5t-94 31t-98 8t-112 -25.5t-110.5 -64t-86.5 -72t-60 -61.5q-18 -22 -49 -22t-49 22q-24 28 -60 61.5t-86.5 72t-110.5 64t-112 25.5t-98 -8t-94 -31t-81.5 -59.5t-55 -98.5t-21.5 -143q0 -168 187 -355l581 -560l580 559 q188 188 188 356zM1792 940q0 -221 -229 -450l-623 -600q-18 -18 -44 -18t-44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5 q224 0 351 -124t127 -344z" />
-<glyph unicode="&#xf08b;" horiz-adv-x="1664" d="M640 96q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h320q13 0 22.5 -9.5t9.5 -22.5q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-66 0 -113 -47t-47 -113v-704 q0 -66 47 -113t113 -47h288h11h13t11.5 -1t11.5 -3t8 -5.5t7 -9t2 -13.5zM1568 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45z" />
-<glyph unicode="&#xf08c;" d="M237 122h231v694h-231v-694zM483 1030q-1 52 -36 86t-93 34t-94.5 -34t-36.5 -86q0 -51 35.5 -85.5t92.5 -34.5h1q59 0 95 34.5t36 85.5zM1068 122h231v398q0 154 -73 233t-193 79q-136 0 -209 -117h2v101h-231q3 -66 0 -694h231v388q0 38 7 56q15 35 45 59.5t74 24.5 q116 0 116 -157v-371zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf08d;" horiz-adv-x="1152" d="M480 672v448q0 14 -9 23t-23 9t-23 -9t-9 -23v-448q0 -14 9 -23t23 -9t23 9t9 23zM1152 320q0 -26 -19 -45t-45 -19h-429l-51 -483q-2 -12 -10.5 -20.5t-20.5 -8.5h-1q-27 0 -32 27l-76 485h-404q-26 0 -45 19t-19 45q0 123 78.5 221.5t177.5 98.5v512q-52 0 -90 38 t-38 90t38 90t90 38h640q52 0 90 -38t38 -90t-38 -90t-90 -38v-512q99 0 177.5 -98.5t78.5 -221.5z" />
-<glyph unicode="&#xf08e;" horiz-adv-x="1792" d="M1408 608v-320q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h704q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v320 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1792 1472v-512q0 -26 -19 -45t-45 -19t-45 19l-176 176l-652 -652q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l652 652l-176 176q-19 19 -19 45t19 45t45 19h512q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf090;" d="M1184 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45zM1536 992v-704q0 -119 -84.5 -203.5t-203.5 -84.5h-320q-13 0 -22.5 9.5t-9.5 22.5 q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q66 0 113 47t47 113v704q0 66 -47 113t-113 47h-288h-11h-13t-11.5 1t-11.5 3t-8 5.5t-7 9t-2 13.5q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf091;" horiz-adv-x="1664" d="M458 653q-74 162 -74 371h-256v-96q0 -78 94.5 -162t235.5 -113zM1536 928v96h-256q0 -209 -74 -371q141 29 235.5 113t94.5 162zM1664 1056v-128q0 -71 -41.5 -143t-112 -130t-173 -97.5t-215.5 -44.5q-42 -54 -95 -95q-38 -34 -52.5 -72.5t-14.5 -89.5q0 -54 30.5 -91 t97.5 -37q75 0 133.5 -45.5t58.5 -114.5v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 69 58.5 114.5t133.5 45.5q67 0 97.5 37t30.5 91q0 51 -14.5 89.5t-52.5 72.5q-53 41 -95 95q-113 5 -215.5 44.5t-173 97.5t-112 130t-41.5 143v128q0 40 28 68t68 28h288v96 q0 66 47 113t113 47h576q66 0 113 -47t47 -113v-96h288q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf092;" d="M394 184q-8 -9 -20 3q-13 11 -4 19q8 9 20 -3q12 -11 4 -19zM352 245q9 -12 0 -19q-8 -6 -17 7t0 18q9 7 17 -6zM291 305q-5 -7 -13 -2q-10 5 -7 12q3 5 13 2q10 -5 7 -12zM322 271q-6 -7 -16 3q-9 11 -2 16q6 6 16 -3q9 -11 2 -16zM451 159q-4 -12 -19 -6q-17 4 -13 15 t19 7q16 -5 13 -16zM514 154q0 -11 -16 -11q-17 -2 -17 11q0 11 16 11q17 2 17 -11zM572 164q2 -10 -14 -14t-18 8t14 15q16 2 18 -9zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-224q-16 0 -24.5 1t-19.5 5t-16 14.5t-5 27.5v239q0 97 -52 142q57 6 102.5 18t94 39 t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103 q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -103t0.5 -68q0 -22 -11 -33.5t-22 -13t-33 -1.5 h-224q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf093;" horiz-adv-x="1664" d="M1280 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 288v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h427q21 -56 70.5 -92 t110.5 -36h256q61 0 110.5 36t70.5 92h427q40 0 68 -28t28 -68zM1339 936q-17 -40 -59 -40h-256v-448q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v448h-256q-42 0 -59 40q-17 39 14 69l448 448q18 19 45 19t45 -19l448 -448q31 -30 14 -69z" />
-<glyph unicode="&#xf094;" d="M1407 710q0 44 -7 113.5t-18 96.5q-12 30 -17 44t-9 36.5t-4 48.5q0 23 5 68.5t5 67.5q0 37 -10 55q-4 1 -13 1q-19 0 -58 -4.5t-59 -4.5q-60 0 -176 24t-175 24q-43 0 -94.5 -11.5t-85 -23.5t-89.5 -34q-137 -54 -202 -103q-96 -73 -159.5 -189.5t-88 -236t-24.5 -248.5 q0 -40 12.5 -120t12.5 -121q0 -23 -11 -66.5t-11 -65.5t12 -36.5t34 -14.5q24 0 72.5 11t73.5 11q57 0 169.5 -15.5t169.5 -15.5q181 0 284 36q129 45 235.5 152.5t166 245.5t59.5 275zM1535 712q0 -165 -70 -327.5t-196 -288t-281 -180.5q-124 -44 -326 -44 q-57 0 -170 14.5t-169 14.5q-24 0 -72.5 -14.5t-73.5 -14.5q-73 0 -123.5 55.5t-50.5 128.5q0 24 11 68t11 67q0 40 -12.5 120.5t-12.5 121.5q0 111 18 217.5t54.5 209.5t100.5 194t150 156q78 59 232 120q194 78 316 78q60 0 175.5 -24t173.5 -24q19 0 57 5t58 5 q81 0 118 -50.5t37 -134.5q0 -23 -5 -68t-5 -68q0 -10 1 -18.5t3 -17t4 -13.5t6.5 -16t6.5 -17q16 -40 25 -118.5t9 -136.5z" />
-<glyph unicode="&#xf095;" horiz-adv-x="1408" d="M1408 296q0 -27 -10 -70.5t-21 -68.5q-21 -50 -122 -106q-94 -51 -186 -51q-27 0 -52.5 3.5t-57.5 12.5t-47.5 14.5t-55.5 20.5t-49 18q-98 35 -175 83q-128 79 -264.5 215.5t-215.5 264.5q-48 77 -83 175q-3 9 -18 49t-20.5 55.5t-14.5 47.5t-12.5 57.5t-3.5 52.5 q0 92 51 186q56 101 106 122q25 11 68.5 21t70.5 10q14 0 21 -3q18 -6 53 -76q11 -19 30 -54t35 -63.5t31 -53.5q3 -4 17.5 -25t21.5 -35.5t7 -28.5q0 -20 -28.5 -50t-62 -55t-62 -53t-28.5 -46q0 -9 5 -22.5t8.5 -20.5t14 -24t11.5 -19q76 -137 174 -235t235 -174 q2 -1 19 -11.5t24 -14t20.5 -8.5t22.5 -5q18 0 46 28.5t53 62t55 62t50 28.5q14 0 28.5 -7t35.5 -21.5t25 -17.5q25 -15 53.5 -31t63.5 -35t54 -30q70 -35 76 -53q3 -7 3 -21z" />
-<glyph unicode="&#xf096;" horiz-adv-x="1408" d="M1120 1280h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v832q0 66 -47 113t-113 47zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf097;" horiz-adv-x="1280" d="M1152 1280h-1024v-1242l423 406l89 85l89 -85l423 -406v1242zM1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289 q0 34 19.5 62t52.5 41q21 9 44 9h1048z" />
-<glyph unicode="&#xf098;" d="M1280 343q0 11 -2 16q-3 8 -38.5 29.5t-88.5 49.5l-53 29q-5 3 -19 13t-25 15t-21 5q-18 0 -47 -32.5t-57 -65.5t-44 -33q-7 0 -16.5 3.5t-15.5 6.5t-17 9.5t-14 8.5q-99 55 -170.5 126.5t-126.5 170.5q-2 3 -8.5 14t-9.5 17t-6.5 15.5t-3.5 16.5q0 13 20.5 33.5t45 38.5 t45 39.5t20.5 36.5q0 10 -5 21t-15 25t-13 19q-3 6 -15 28.5t-25 45.5t-26.5 47.5t-25 40.5t-16.5 18t-16 2q-48 0 -101 -22q-46 -21 -80 -94.5t-34 -130.5q0 -16 2.5 -34t5 -30.5t9 -33t10 -29.5t12.5 -33t11 -30q60 -164 216.5 -320.5t320.5 -216.5q6 -2 30 -11t33 -12.5 t29.5 -10t33 -9t30.5 -5t34 -2.5q57 0 130.5 34t94.5 80q22 53 22 101zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf099;" horiz-adv-x="1664" d="M1620 1128q-67 -98 -162 -167q1 -14 1 -42q0 -130 -38 -259.5t-115.5 -248.5t-184.5 -210.5t-258 -146t-323 -54.5q-271 0 -496 145q35 -4 78 -4q225 0 401 138q-105 2 -188 64.5t-114 159.5q33 -5 61 -5q43 0 85 11q-112 23 -185.5 111.5t-73.5 205.5v4q68 -38 146 -41 q-66 44 -105 115t-39 154q0 88 44 163q121 -149 294.5 -238.5t371.5 -99.5q-8 38 -8 74q0 134 94.5 228.5t228.5 94.5q140 0 236 -102q109 21 205 78q-37 -115 -142 -178q93 10 186 50z" />
-<glyph unicode="&#xf09a;" horiz-adv-x="768" d="M511 980h257l-30 -284h-227v-824h-341v824h-170v284h170v171q0 182 86 275.5t283 93.5h227v-284h-142q-39 0 -62.5 -6.5t-34 -23.5t-13.5 -34.5t-3 -49.5v-142z" />
-<glyph unicode="&#xf09b;" d="M1536 640q0 -251 -146.5 -451.5t-378.5 -277.5q-27 -5 -39.5 7t-12.5 30v211q0 97 -52 142q57 6 102.5 18t94 39t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5 q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23 q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -89t0.5 -54q0 -18 -13 -30t-40 -7q-232 77 -378.5 277.5t-146.5 451.5q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf09c;" horiz-adv-x="1664" d="M1664 960v-256q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45v256q0 106 -75 181t-181 75t-181 -75t-75 -181v-192h96q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h672v192q0 185 131.5 316.5t316.5 131.5 t316.5 -131.5t131.5 -316.5z" />
-<glyph unicode="&#xf09d;" horiz-adv-x="1920" d="M1760 1408q66 0 113 -47t47 -113v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600zM160 1280q-13 0 -22.5 -9.5t-9.5 -22.5v-224h1664v224q0 13 -9.5 22.5t-22.5 9.5h-1600zM1760 0q13 0 22.5 9.5t9.5 22.5v608h-1664v-608 q0 -13 9.5 -22.5t22.5 -9.5h1600zM256 128v128h256v-128h-256zM640 128v128h384v-128h-384z" />
-<glyph unicode="&#xf09e;" horiz-adv-x="1408" d="M384 192q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM896 69q2 -28 -17 -48q-18 -21 -47 -21h-135q-25 0 -43 16.5t-20 41.5q-22 229 -184.5 391.5t-391.5 184.5q-25 2 -41.5 20t-16.5 43v135q0 29 21 47q17 17 43 17h5q160 -13 306 -80.5 t259 -181.5q114 -113 181.5 -259t80.5 -306zM1408 67q2 -27 -18 -47q-18 -20 -46 -20h-143q-26 0 -44.5 17.5t-19.5 42.5q-12 215 -101 408.5t-231.5 336t-336 231.5t-408.5 102q-25 1 -42.5 19.5t-17.5 43.5v143q0 28 20 46q18 18 44 18h3q262 -13 501.5 -120t425.5 -294 q187 -186 294 -425.5t120 -501.5z" />
-<glyph unicode="&#xf0a0;" d="M1040 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1296 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1408 160v320q0 13 -9.5 22.5t-22.5 9.5 h-1216q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h1216q13 0 22.5 9.5t9.5 22.5zM178 640h1180l-157 482q-4 13 -16 21.5t-26 8.5h-782q-14 0 -26 -8.5t-16 -21.5zM1536 480v-320q0 -66 -47 -113t-113 -47h-1216q-66 0 -113 47t-47 113v320q0 25 16 75 l197 606q17 53 63 86t101 33h782q55 0 101 -33t63 -86l197 -606q16 -50 16 -75z" />
-<glyph unicode="&#xf0a1;" horiz-adv-x="1792" d="M1664 896q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5v-384q0 -52 -38 -90t-90 -38q-417 347 -812 380q-58 -19 -91 -66t-31 -100.5t40 -92.5q-20 -33 -23 -65.5t6 -58t33.5 -55t48 -50t61.5 -50.5q-29 -58 -111.5 -83t-168.5 -11.5t-132 55.5q-7 23 -29.5 87.5 t-32 94.5t-23 89t-15 101t3.5 98.5t22 110.5h-122q-66 0 -113 47t-47 113v192q0 66 47 113t113 47h480q435 0 896 384q52 0 90 -38t38 -90v-384zM1536 292v954q-394 -302 -768 -343v-270q377 -42 768 -341z" />
-<glyph unicode="&#xf0a2;" horiz-adv-x="1664" d="M848 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM183 128h1298q-164 181 -246.5 411.5t-82.5 484.5q0 256 -320 256t-320 -256q0 -254 -82.5 -484.5t-246.5 -411.5zM1664 128q0 -52 -38 -90t-90 -38 h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q190 161 287 397.5t97 498.5q0 165 96 262t264 117q-8 18 -8 37q0 40 28 68t68 28t68 -28t28 -68q0 -19 -8 -37q168 -20 264 -117t96 -262q0 -262 97 -498.5t287 -397.5z" />
-<glyph unicode="&#xf0a3;" d="M1376 640l138 -135q30 -28 20 -70q-12 -41 -52 -51l-188 -48l53 -186q12 -41 -19 -70q-29 -31 -70 -19l-186 53l-48 -188q-10 -40 -51 -52q-12 -2 -19 -2q-31 0 -51 22l-135 138l-135 -138q-28 -30 -70 -20q-41 11 -51 52l-48 188l-186 -53q-41 -12 -70 19q-31 29 -19 70 l53 186l-188 48q-40 10 -52 51q-10 42 20 70l138 135l-138 135q-30 28 -20 70q12 41 52 51l188 48l-53 186q-12 41 19 70q29 31 70 19l186 -53l48 188q10 41 51 51q41 12 70 -19l135 -139l135 139q29 30 70 19q41 -10 51 -51l48 -188l186 53q41 12 70 -19q31 -29 19 -70 l-53 -186l188 -48q40 -10 52 -51q10 -42 -20 -70z" />
-<glyph unicode="&#xf0a4;" horiz-adv-x="1792" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 768q0 51 -39 89.5t-89 38.5h-576q0 20 15 48.5t33 55t33 68t15 84.5q0 67 -44.5 97.5t-115.5 30.5q-24 0 -90 -139q-24 -44 -37 -65q-40 -64 -112 -145q-71 -81 -101 -106 q-69 -57 -140 -57h-32v-640h32q72 0 167 -32t193.5 -64t179.5 -32q189 0 189 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5h331q52 0 90 38t38 90zM1792 769q0 -105 -75.5 -181t-180.5 -76h-169q-4 -62 -37 -119q3 -21 3 -43 q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5q-133 0 -322 69q-164 59 -223 59h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h288q10 0 21.5 4.5t23.5 14t22.5 18t24 22.5t20.5 21.5t19 21.5t14 17q65 74 100 129q13 21 33 62t37 72t40.5 63t55 49.5 t69.5 17.5q125 0 206.5 -67t81.5 -189q0 -68 -22 -128h374q104 0 180 -76t76 -179z" />
-<glyph unicode="&#xf0a5;" horiz-adv-x="1792" d="M1376 128h32v640h-32q-35 0 -67.5 12t-62.5 37t-50 46t-49 54q-2 3 -3.5 4.5t-4 4.5t-4.5 5q-72 81 -112 145q-14 22 -38 68q-1 3 -10.5 22.5t-18.5 36t-20 35.5t-21.5 30.5t-18.5 11.5q-71 0 -115.5 -30.5t-44.5 -97.5q0 -43 15 -84.5t33 -68t33 -55t15 -48.5h-576 q-50 0 -89 -38.5t-39 -89.5q0 -52 38 -90t90 -38h331q-15 -17 -25 -47.5t-10 -55.5q0 -69 53 -119q-18 -32 -18 -69t17.5 -73.5t47.5 -52.5q-4 -24 -4 -56q0 -85 48.5 -126t135.5 -41q84 0 183 32t194 64t167 32zM1664 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45 t45 -19t45 19t19 45zM1792 768v-640q0 -53 -37.5 -90.5t-90.5 -37.5h-288q-59 0 -223 -59q-190 -69 -317 -69q-142 0 -230 77.5t-87 217.5l1 5q-61 76 -61 178q0 22 3 43q-33 57 -37 119h-169q-105 0 -180.5 76t-75.5 181q0 103 76 179t180 76h374q-22 60 -22 128 q0 122 81.5 189t206.5 67q38 0 69.5 -17.5t55 -49.5t40.5 -63t37 -72t33 -62q35 -55 100 -129q2 -3 14 -17t19 -21.5t20.5 -21.5t24 -22.5t22.5 -18t23.5 -14t21.5 -4.5h288q53 0 90.5 -37.5t37.5 -90.5z" />
-<glyph unicode="&#xf0a6;" d="M1280 -64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 700q0 189 -167 189q-26 0 -56 -5q-16 30 -52.5 47.5t-73.5 17.5t-69 -18q-50 53 -119 53q-25 0 -55.5 -10t-47.5 -25v331q0 52 -38 90t-90 38q-51 0 -89.5 -39t-38.5 -89v-576 q-20 0 -48.5 15t-55 33t-68 33t-84.5 15q-67 0 -97.5 -44.5t-30.5 -115.5q0 -24 139 -90q44 -24 65 -37q64 -40 145 -112q81 -71 106 -101q57 -69 57 -140v-32h640v32q0 72 32 167t64 193.5t32 179.5zM1536 705q0 -133 -69 -322q-59 -164 -59 -223v-288q0 -53 -37.5 -90.5 t-90.5 -37.5h-640q-53 0 -90.5 37.5t-37.5 90.5v288q0 10 -4.5 21.5t-14 23.5t-18 22.5t-22.5 24t-21.5 20.5t-21.5 19t-17 14q-74 65 -129 100q-21 13 -62 33t-72 37t-63 40.5t-49.5 55t-17.5 69.5q0 125 67 206.5t189 81.5q68 0 128 -22v374q0 104 76 180t179 76 q105 0 181 -75.5t76 -180.5v-169q62 -4 119 -37q21 3 43 3q101 0 178 -60q139 1 219.5 -85t80.5 -227z" />
-<glyph unicode="&#xf0a7;" d="M1408 576q0 84 -32 183t-64 194t-32 167v32h-640v-32q0 -35 -12 -67.5t-37 -62.5t-46 -50t-54 -49q-9 -8 -14 -12q-81 -72 -145 -112q-22 -14 -68 -38q-3 -1 -22.5 -10.5t-36 -18.5t-35.5 -20t-30.5 -21.5t-11.5 -18.5q0 -71 30.5 -115.5t97.5 -44.5q43 0 84.5 15t68 33 t55 33t48.5 15v-576q0 -50 38.5 -89t89.5 -39q52 0 90 38t38 90v331q46 -35 103 -35q69 0 119 53q32 -18 69 -18t73.5 17.5t52.5 47.5q24 -4 56 -4q85 0 126 48.5t41 135.5zM1280 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 580 q0 -142 -77.5 -230t-217.5 -87l-5 1q-76 -61 -178 -61q-22 0 -43 3q-54 -30 -119 -37v-169q0 -105 -76 -180.5t-181 -75.5q-103 0 -179 76t-76 180v374q-54 -22 -128 -22q-121 0 -188.5 81.5t-67.5 206.5q0 38 17.5 69.5t49.5 55t63 40.5t72 37t62 33q55 35 129 100 q3 2 17 14t21.5 19t21.5 20.5t22.5 24t18 22.5t14 23.5t4.5 21.5v288q0 53 37.5 90.5t90.5 37.5h640q53 0 90.5 -37.5t37.5 -90.5v-288q0 -59 59 -223q69 -190 69 -317z" />
-<glyph unicode="&#xf0a8;" d="M1280 576v128q0 26 -19 45t-45 19h-502l189 189q19 19 19 45t-19 45l-91 91q-18 18 -45 18t-45 -18l-362 -362l-91 -91q-18 -18 -18 -45t18 -45l91 -91l362 -362q18 -18 45 -18t45 18l91 91q18 18 18 45t-18 45l-189 189h502q26 0 45 19t19 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf0a9;" d="M1285 640q0 27 -18 45l-91 91l-362 362q-18 18 -45 18t-45 -18l-91 -91q-18 -18 -18 -45t18 -45l189 -189h-502q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h502l-189 -189q-19 -19 -19 -45t19 -45l91 -91q18 -18 45 -18t45 18l362 362l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf0aa;" d="M1284 641q0 27 -18 45l-362 362l-91 91q-18 18 -45 18t-45 -18l-91 -91l-362 -362q-18 -18 -18 -45t18 -45l91 -91q18 -18 45 -18t45 18l189 189v-502q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v502l189 -189q19 -19 45 -19t45 19l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf0ab;" d="M1284 639q0 27 -18 45l-91 91q-18 18 -45 18t-45 -18l-189 -189v502q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-502l-189 189q-19 19 -45 19t-45 -19l-91 -91q-18 -18 -18 -45t18 -45l362 -362l91 -91q18 -18 45 -18t45 18l91 91l362 362q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf0ac;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1042 887q-2 -1 -9.5 -9.5t-13.5 -9.5q2 0 4.5 5t5 11t3.5 7q6 7 22 15q14 6 52 12q34 8 51 -11 q-2 2 9.5 13t14.5 12q3 2 15 4.5t15 7.5l2 22q-12 -1 -17.5 7t-6.5 21q0 -2 -6 -8q0 7 -4.5 8t-11.5 -1t-9 -1q-10 3 -15 7.5t-8 16.5t-4 15q-2 5 -9.5 10.5t-9.5 10.5q-1 2 -2.5 5.5t-3 6.5t-4 5.5t-5.5 2.5t-7 -5t-7.5 -10t-4.5 -5q-3 2 -6 1.5t-4.5 -1t-4.5 -3t-5 -3.5 q-3 -2 -8.5 -3t-8.5 -2q15 5 -1 11q-10 4 -16 3q9 4 7.5 12t-8.5 14h5q-1 4 -8.5 8.5t-17.5 8.5t-13 6q-8 5 -34 9.5t-33 0.5q-5 -6 -4.5 -10.5t4 -14t3.5 -12.5q1 -6 -5.5 -13t-6.5 -12q0 -7 14 -15.5t10 -21.5q-3 -8 -16 -16t-16 -12q-5 -8 -1.5 -18.5t10.5 -16.5 q2 -2 1.5 -4t-3.5 -4.5t-5.5 -4t-6.5 -3.5l-3 -2q-11 -5 -20.5 6t-13.5 26q-7 25 -16 30q-23 8 -29 -1q-5 13 -41 26q-25 9 -58 4q6 1 0 15q-7 15 -19 12q3 6 4 17.5t1 13.5q3 13 12 23q1 1 7 8.5t9.5 13.5t0.5 6q35 -4 50 11q5 5 11.5 17t10.5 17q9 6 14 5.5t14.5 -5.5 t14.5 -5q14 -1 15.5 11t-7.5 20q12 -1 3 17q-5 7 -8 9q-12 4 -27 -5q-8 -4 2 -8q-1 1 -9.5 -10.5t-16.5 -17.5t-16 5q-1 1 -5.5 13.5t-9.5 13.5q-8 0 -16 -15q3 8 -11 15t-24 8q19 12 -8 27q-7 4 -20.5 5t-19.5 -4q-5 -7 -5.5 -11.5t5 -8t10.5 -5.5t11.5 -4t8.5 -3 q14 -10 8 -14q-2 -1 -8.5 -3.5t-11.5 -4.5t-6 -4q-3 -4 0 -14t-2 -14q-5 5 -9 17.5t-7 16.5q7 -9 -25 -6l-10 1q-4 0 -16 -2t-20.5 -1t-13.5 8q-4 8 0 20q1 4 4 2q-4 3 -11 9.5t-10 8.5q-46 -15 -94 -41q6 -1 12 1q5 2 13 6.5t10 5.5q34 14 42 7l5 5q14 -16 20 -25 q-7 4 -30 1q-20 -6 -22 -12q7 -12 5 -18q-4 3 -11.5 10t-14.5 11t-15 5q-16 0 -22 -1q-146 -80 -235 -222q7 -7 12 -8q4 -1 5 -9t2.5 -11t11.5 3q9 -8 3 -19q1 1 44 -27q19 -17 21 -21q3 -11 -10 -18q-1 2 -9 9t-9 4q-3 -5 0.5 -18.5t10.5 -12.5q-7 0 -9.5 -16t-2.5 -35.5 t-1 -23.5l2 -1q-3 -12 5.5 -34.5t21.5 -19.5q-13 -3 20 -43q6 -8 8 -9q3 -2 12 -7.5t15 -10t10 -10.5q4 -5 10 -22.5t14 -23.5q-2 -6 9.5 -20t10.5 -23q-1 0 -2.5 -1t-2.5 -1q3 -7 15.5 -14t15.5 -13q1 -3 2 -10t3 -11t8 -2q2 20 -24 62q-15 25 -17 29q-3 5 -5.5 15.5 t-4.5 14.5q2 0 6 -1.5t8.5 -3.5t7.5 -4t2 -3q-3 -7 2 -17.5t12 -18.5t17 -19t12 -13q6 -6 14 -19.5t0 -13.5q9 0 20 -10t17 -20q5 -8 8 -26t5 -24q2 -7 8.5 -13.5t12.5 -9.5l16 -8t13 -7q5 -2 18.5 -10.5t21.5 -11.5q10 -4 16 -4t14.5 2.5t13.5 3.5q15 2 29 -15t21 -21 q36 -19 55 -11q-2 -1 0.5 -7.5t8 -15.5t9 -14.5t5.5 -8.5q5 -6 18 -15t18 -15q6 4 7 9q-3 -8 7 -20t18 -10q14 3 14 32q-31 -15 -49 18q0 1 -2.5 5.5t-4 8.5t-2.5 8.5t0 7.5t5 3q9 0 10 3.5t-2 12.5t-4 13q-1 8 -11 20t-12 15q-5 -9 -16 -8t-16 9q0 -1 -1.5 -5.5t-1.5 -6.5 q-13 0 -15 1q1 3 2.5 17.5t3.5 22.5q1 4 5.5 12t7.5 14.5t4 12.5t-4.5 9.5t-17.5 2.5q-19 -1 -26 -20q-1 -3 -3 -10.5t-5 -11.5t-9 -7q-7 -3 -24 -2t-24 5q-13 8 -22.5 29t-9.5 37q0 10 2.5 26.5t3 25t-5.5 24.5q3 2 9 9.5t10 10.5q2 1 4.5 1.5t4.5 0t4 1.5t3 6q-1 1 -4 3 q-3 3 -4 3q7 -3 28.5 1.5t27.5 -1.5q15 -11 22 2q0 1 -2.5 9.5t-0.5 13.5q5 -27 29 -9q3 -3 15.5 -5t17.5 -5q3 -2 7 -5.5t5.5 -4.5t5 0.5t8.5 6.5q10 -14 12 -24q11 -40 19 -44q7 -3 11 -2t4.5 9.5t0 14t-1.5 12.5l-1 8v18l-1 8q-15 3 -18.5 12t1.5 18.5t15 18.5q1 1 8 3.5 t15.5 6.5t12.5 8q21 19 15 35q7 0 11 9q-1 0 -5 3t-7.5 5t-4.5 2q9 5 2 16q5 3 7.5 11t7.5 10q9 -12 21 -2q7 8 1 16q5 7 20.5 10.5t18.5 9.5q7 -2 8 2t1 12t3 12q4 5 15 9t13 5l17 11q3 4 0 4q18 -2 31 11q10 11 -6 20q3 6 -3 9.5t-15 5.5q3 1 11.5 0.5t10.5 1.5 q15 10 -7 16q-17 5 -43 -12zM879 10q206 36 351 189q-3 3 -12.5 4.5t-12.5 3.5q-18 7 -24 8q1 7 -2.5 13t-8 9t-12.5 8t-11 7q-2 2 -7 6t-7 5.5t-7.5 4.5t-8.5 2t-10 -1l-3 -1q-3 -1 -5.5 -2.5t-5.5 -3t-4 -3t0 -2.5q-21 17 -36 22q-5 1 -11 5.5t-10.5 7t-10 1.5t-11.5 -7 q-5 -5 -6 -15t-2 -13q-7 5 0 17.5t2 18.5q-3 6 -10.5 4.5t-12 -4.5t-11.5 -8.5t-9 -6.5t-8.5 -5.5t-8.5 -7.5q-3 -4 -6 -12t-5 -11q-2 4 -11.5 6.5t-9.5 5.5q2 -10 4 -35t5 -38q7 -31 -12 -48q-27 -25 -29 -40q-4 -22 12 -26q0 -7 -8 -20.5t-7 -21.5q0 -6 2 -16z" />
-<glyph unicode="&#xf0ad;" horiz-adv-x="1664" d="M384 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1028 484l-682 -682q-37 -37 -90 -37q-52 0 -91 37l-106 108q-38 36 -38 90q0 53 38 91l681 681q39 -98 114.5 -173.5t173.5 -114.5zM1662 919q0 -39 -23 -106q-47 -134 -164.5 -217.5 t-258.5 -83.5q-185 0 -316.5 131.5t-131.5 316.5t131.5 316.5t316.5 131.5q58 0 121.5 -16.5t107.5 -46.5q16 -11 16 -28t-16 -28l-293 -169v-224l193 -107q5 3 79 48.5t135.5 81t70.5 35.5q15 0 23.5 -10t8.5 -25z" />
-<glyph unicode="&#xf0ae;" horiz-adv-x="1792" d="M1024 128h640v128h-640v-128zM640 640h1024v128h-1024v-128zM1280 1152h384v128h-384v-128zM1792 320v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 832v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19 t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0b0;" horiz-adv-x="1408" d="M1403 1241q17 -41 -14 -70l-493 -493v-742q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-256 256q-19 19 -19 45v486l-493 493q-31 29 -14 70q17 39 59 39h1280q42 0 59 -39z" />
-<glyph unicode="&#xf0b1;" horiz-adv-x="1792" d="M640 1280h512v128h-512v-128zM1792 640v-480q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v480h672v-160q0 -26 19 -45t45 -19h320q26 0 45 19t19 45v160h672zM1024 640v-128h-256v128h256zM1792 1120v-384h-1792v384q0 66 47 113t113 47h352v160q0 40 28 68 t68 28h576q40 0 68 -28t28 -68v-160h352q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf0b2;" d="M1283 995l-355 -355l355 -355l144 144q29 31 70 14q39 -17 39 -59v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l144 144l-355 355l-355 -355l144 -144q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l144 -144 l355 355l-355 355l-144 -144q-19 -19 -45 -19q-12 0 -24 5q-40 17 -40 59v448q0 26 19 45t45 19h448q42 0 59 -40q17 -39 -14 -69l-144 -144l355 -355l355 355l-144 144q-31 30 -14 69q17 40 59 40h448q26 0 45 -19t19 -45v-448q0 -42 -39 -59q-13 -5 -25 -5q-26 0 -45 19z " />
-<glyph unicode="&#xf0c0;" horiz-adv-x="1920" d="M593 640q-162 -5 -265 -128h-134q-82 0 -138 40.5t-56 118.5q0 353 124 353q6 0 43.5 -21t97.5 -42.5t119 -21.5q67 0 133 23q-5 -37 -5 -66q0 -139 81 -256zM1664 3q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5 t43 97.5t62 81t85.5 53.5t111.5 20q10 0 43 -21.5t73 -48t107 -48t135 -21.5t135 21.5t107 48t73 48t43 21.5q61 0 111.5 -20t85.5 -53.5t62 -81t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM640 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75 t75 -181zM1344 896q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5zM1920 671q0 -78 -56 -118.5t-138 -40.5h-134q-103 123 -265 128q81 117 81 256q0 29 -5 66q66 -23 133 -23q59 0 119 21.5t97.5 42.5 t43.5 21q124 0 124 -353zM1792 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181z" />
-<glyph unicode="&#xf0c1;" horiz-adv-x="1664" d="M1456 320q0 40 -28 68l-208 208q-28 28 -68 28q-42 0 -72 -32q3 -3 19 -18.5t21.5 -21.5t15 -19t13 -25.5t3.5 -27.5q0 -40 -28 -68t-68 -28q-15 0 -27.5 3.5t-25.5 13t-19 15t-21.5 21.5t-18.5 19q-33 -31 -33 -73q0 -40 28 -68l206 -207q27 -27 68 -27q40 0 68 26 l147 146q28 28 28 67zM753 1025q0 40 -28 68l-206 207q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l208 -208q27 -27 68 -27q42 0 72 31q-3 3 -19 18.5t-21.5 21.5t-15 19t-13 25.5t-3.5 27.5q0 40 28 68t68 28q15 0 27.5 -3.5t25.5 -13t19 -15 t21.5 -21.5t18.5 -19q33 31 33 73zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-206 207q-83 83 -83 203q0 123 88 209l-88 88q-86 -88 -208 -88q-120 0 -204 84l-208 208q-84 84 -84 204t85 203l147 146q83 83 203 83q121 0 204 -85l206 -207 q83 -83 83 -203q0 -123 -88 -209l88 -88q86 88 208 88q120 0 204 -84l208 -208q84 -84 84 -204z" />
-<glyph unicode="&#xf0c2;" horiz-adv-x="1920" d="M1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088q-185 0 -316.5 131.5t-131.5 316.5q0 132 71 241.5t187 163.5q-2 28 -2 43q0 212 150 362t362 150q158 0 286.5 -88t187.5 -230q70 62 166 62q106 0 181 -75t75 -181q0 -75 -41 -138q129 -30 213 -134.5t84 -239.5z " />
-<glyph unicode="&#xf0c3;" horiz-adv-x="1664" d="M1527 88q56 -89 21.5 -152.5t-140.5 -63.5h-1152q-106 0 -140.5 63.5t21.5 152.5l503 793v399h-64q-26 0 -45 19t-19 45t19 45t45 19h512q26 0 45 -19t19 -45t-19 -45t-45 -19h-64v-399zM748 813l-272 -429h712l-272 429l-20 31v37v399h-128v-399v-37z" />
-<glyph unicode="&#xf0c4;" horiz-adv-x="1792" d="M960 640q26 0 45 -19t19 -45t-19 -45t-45 -19t-45 19t-19 45t19 45t45 19zM1260 576l507 -398q28 -20 25 -56q-5 -35 -35 -51l-128 -64q-13 -7 -29 -7q-17 0 -31 8l-690 387l-110 -66q-8 -4 -12 -5q14 -49 10 -97q-7 -77 -56 -147.5t-132 -123.5q-132 -84 -277 -84 q-136 0 -222 78q-90 84 -79 207q7 76 56 147t131 124q132 84 278 84q83 0 151 -31q9 13 22 22l122 73l-122 73q-13 9 -22 22q-68 -31 -151 -31q-146 0 -278 84q-82 53 -131 124t-56 147q-5 59 15.5 113t63.5 93q85 79 222 79q145 0 277 -84q83 -52 132 -123t56 -148 q4 -48 -10 -97q4 -1 12 -5l110 -66l690 387q14 8 31 8q16 0 29 -7l128 -64q30 -16 35 -51q3 -36 -25 -56zM579 836q46 42 21 108t-106 117q-92 59 -192 59q-74 0 -113 -36q-46 -42 -21 -108t106 -117q92 -59 192 -59q74 0 113 36zM494 91q81 51 106 117t-21 108 q-39 36 -113 36q-100 0 -192 -59q-81 -51 -106 -117t21 -108q39 -36 113 -36q100 0 192 59zM672 704l96 -58v11q0 36 33 56l14 8l-79 47l-26 -26q-3 -3 -10 -11t-12 -12q-2 -2 -4 -3.5t-3 -2.5zM896 480l96 -32l736 576l-128 64l-768 -431v-113l-160 -96l9 -8q2 -2 7 -6 q4 -4 11 -12t11 -12l26 -26zM1600 64l128 64l-520 408l-177 -138q-2 -3 -13 -7z" />
-<glyph unicode="&#xf0c5;" horiz-adv-x="1792" d="M1696 1152q40 0 68 -28t28 -68v-1216q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v288h-544q-40 0 -68 28t-28 68v672q0 40 20 88t48 76l408 408q28 28 76 48t88 20h416q40 0 68 -28t28 -68v-328q68 40 128 40h416zM1152 939l-299 -299h299v299zM512 1323l-299 -299 h299v299zM708 676l316 316v416h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h512v256q0 40 20 88t48 76zM1664 -128v1152h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h896z" />
-<glyph unicode="&#xf0c6;" horiz-adv-x="1408" d="M1404 151q0 -117 -79 -196t-196 -79q-135 0 -235 100l-777 776q-113 115 -113 271q0 159 110 270t269 111q158 0 273 -113l605 -606q10 -10 10 -22q0 -16 -30.5 -46.5t-46.5 -30.5q-13 0 -23 10l-606 607q-79 77 -181 77q-106 0 -179 -75t-73 -181q0 -105 76 -181 l776 -777q63 -63 145 -63q64 0 106 42t42 106q0 82 -63 145l-581 581q-26 24 -60 24q-29 0 -48 -19t-19 -48q0 -32 25 -59l410 -410q10 -10 10 -22q0 -16 -31 -47t-47 -31q-12 0 -22 10l-410 410q-63 61 -63 149q0 82 57 139t139 57q88 0 149 -63l581 -581q100 -98 100 -235 z" />
-<glyph unicode="&#xf0c7;" d="M384 0h768v384h-768v-384zM1280 0h128v896q0 14 -10 38.5t-20 34.5l-281 281q-10 10 -34 20t-39 10v-416q0 -40 -28 -68t-68 -28h-576q-40 0 -68 28t-28 68v416h-128v-1280h128v416q0 40 28 68t68 28h832q40 0 68 -28t28 -68v-416zM896 928v320q0 13 -9.5 22.5t-22.5 9.5 h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5zM1536 896v-928q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h928q40 0 88 -20t76 -48l280 -280q28 -28 48 -76t20 -88z" />
-<glyph unicode="&#xf0c8;" d="M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf0c9;" d="M1536 192v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 704v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 1216v-128q0 -26 -19 -45 t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0ca;" horiz-adv-x="1792" d="M384 128q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM384 640q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1152q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z M1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" />
-<glyph unicode="&#xf0cb;" horiz-adv-x="1792" d="M381 -84q0 -80 -54.5 -126t-135.5 -46q-106 0 -172 66l57 88q49 -45 106 -45q29 0 50.5 14.5t21.5 42.5q0 64 -105 56l-26 56q8 10 32.5 43.5t42.5 54t37 38.5v1q-16 0 -48.5 -1t-48.5 -1v-53h-106v152h333v-88l-95 -115q51 -12 81 -49t30 -88zM383 543v-159h-362 q-6 36 -6 54q0 51 23.5 93t56.5 68t66 47.5t56.5 43.5t23.5 45q0 25 -14.5 38.5t-39.5 13.5q-46 0 -81 -58l-85 59q24 51 71.5 79.5t105.5 28.5q73 0 123 -41.5t50 -112.5q0 -50 -34 -91.5t-75 -64.5t-75.5 -50.5t-35.5 -52.5h127v60h105zM1792 224v-192q0 -13 -9.5 -22.5 t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1123v-99h-335v99h107q0 41 0.5 122t0.5 121v12h-2q-8 -17 -50 -54l-71 76l136 127h106v-404h108zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5 t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" />
-<glyph unicode="&#xf0cc;" horiz-adv-x="1792" d="M1760 640q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-1728q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h1728zM483 704q-28 35 -51 80q-48 97 -48 188q0 181 134 309q133 127 393 127q50 0 167 -19q66 -12 177 -48q10 -38 21 -118q14 -123 14 -183q0 -18 -5 -45l-12 -3l-84 6 l-14 2q-50 149 -103 205q-88 91 -210 91q-114 0 -182 -59q-67 -58 -67 -146q0 -73 66 -140t279 -129q69 -20 173 -66q58 -28 95 -52h-743zM990 448h411q7 -39 7 -92q0 -111 -41 -212q-23 -55 -71 -104q-37 -35 -109 -81q-80 -48 -153 -66q-80 -21 -203 -21q-114 0 -195 23 l-140 40q-57 16 -72 28q-8 8 -8 22v13q0 108 -2 156q-1 30 0 68l2 37v44l102 2q15 -34 30 -71t22.5 -56t12.5 -27q35 -57 80 -94q43 -36 105 -57q59 -22 132 -22q64 0 139 27q77 26 122 86q47 61 47 129q0 84 -81 157q-34 29 -137 71z" />
-<glyph unicode="&#xf0cd;" d="M48 1313q-37 2 -45 4l-3 88q13 1 40 1q60 0 112 -4q132 -7 166 -7q86 0 168 3q116 4 146 5q56 0 86 2l-1 -14l2 -64v-9q-60 -9 -124 -9q-60 0 -79 -25q-13 -14 -13 -132q0 -13 0.5 -32.5t0.5 -25.5l1 -229l14 -280q6 -124 51 -202q35 -59 96 -92q88 -47 177 -47 q104 0 191 28q56 18 99 51q48 36 65 64q36 56 53 114q21 73 21 229q0 79 -3.5 128t-11 122.5t-13.5 159.5l-4 59q-5 67 -24 88q-34 35 -77 34l-100 -2l-14 3l2 86h84l205 -10q76 -3 196 10l18 -2q6 -38 6 -51q0 -7 -4 -31q-45 -12 -84 -13q-73 -11 -79 -17q-15 -15 -15 -41 q0 -7 1.5 -27t1.5 -31q8 -19 22 -396q6 -195 -15 -304q-15 -76 -41 -122q-38 -65 -112 -123q-75 -57 -182 -89q-109 -33 -255 -33q-167 0 -284 46q-119 47 -179 122q-61 76 -83 195q-16 80 -16 237v333q0 188 -17 213q-25 36 -147 39zM1536 -96v64q0 14 -9 23t-23 9h-1472 q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h1472q14 0 23 9t9 23z" />
-<glyph unicode="&#xf0ce;" horiz-adv-x="1664" d="M512 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23 v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 160v192 q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192 q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1664 1248v-1088q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1344q66 0 113 -47t47 -113 z" />
-<glyph unicode="&#xf0d0;" horiz-adv-x="1664" d="M1190 955l293 293l-107 107l-293 -293zM1637 1248q0 -27 -18 -45l-1286 -1286q-18 -18 -45 -18t-45 18l-198 198q-18 18 -18 45t18 45l1286 1286q18 18 45 18t45 -18l198 -198q18 -18 18 -45zM286 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM636 1276 l196 -60l-196 -60l-60 -196l-60 196l-196 60l196 60l60 196zM1566 798l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM926 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98z" />
-<glyph unicode="&#xf0d1;" horiz-adv-x="1792" d="M640 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM256 640h384v256h-158q-13 0 -22 -9l-195 -195q-9 -9 -9 -22v-30zM1536 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM1792 1216v-1024q0 -15 -4 -26.5t-13.5 -18.5 t-16.5 -11.5t-23.5 -6t-22.5 -2t-25.5 0t-22.5 0.5q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-64q-3 0 -22.5 -0.5t-25.5 0t-22.5 2t-23.5 6t-16.5 11.5t-13.5 18.5t-4 26.5q0 26 19 45t45 19v320q0 8 -0.5 35t0 38 t2.5 34.5t6.5 37t14 30.5t22.5 30l198 198q19 19 50.5 32t58.5 13h160v192q0 26 19 45t45 19h1024q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0d2;" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103q-111 0 -218 32q59 93 78 164q9 34 54 211q20 -39 73 -67.5t114 -28.5q121 0 216 68.5t147 188.5t52 270q0 114 -59.5 214t-172.5 163t-255 63q-105 0 -196 -29t-154.5 -77t-109 -110.5t-67 -129.5t-21.5 -134 q0 -104 40 -183t117 -111q30 -12 38 20q2 7 8 31t8 30q6 23 -11 43q-51 61 -51 151q0 151 104.5 259.5t273.5 108.5q151 0 235.5 -82t84.5 -213q0 -170 -68.5 -289t-175.5 -119q-61 0 -98 43.5t-23 104.5q8 35 26.5 93.5t30 103t11.5 75.5q0 50 -27 83t-77 33 q-62 0 -105 -57t-43 -142q0 -73 25 -122l-99 -418q-17 -70 -13 -177q-206 91 -333 281t-127 423q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf0d3;" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-725q85 122 108 210q9 34 53 209q21 -39 73.5 -67t112.5 -28q181 0 295.5 147.5t114.5 373.5q0 84 -35 162.5t-96.5 139t-152.5 97t-197 36.5q-104 0 -194.5 -28.5t-153 -76.5 t-107.5 -109.5t-66.5 -128t-21.5 -132.5q0 -102 39.5 -180t116.5 -110q13 -5 23.5 0t14.5 19q10 44 15 61q6 23 -11 42q-50 62 -50 150q0 150 103.5 256.5t270.5 106.5q149 0 232.5 -81t83.5 -210q0 -168 -67.5 -286t-173.5 -118q-60 0 -97 43.5t-23 103.5q8 34 26.5 92.5 t29.5 102t11 74.5q0 49 -26.5 81.5t-75.5 32.5q-61 0 -103.5 -56.5t-42.5 -139.5q0 -72 24 -121l-98 -414q-24 -100 -7 -254h-183q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960z" />
-<glyph unicode="&#xf0d4;" d="M678 -57q0 -38 -10 -71h-380q-95 0 -171.5 56.5t-103.5 147.5q24 45 69 77.5t100 49.5t107 24t107 7q32 0 49 -2q6 -4 30.5 -21t33 -23t31 -23t32 -25.5t27.5 -25.5t26.5 -29.5t21 -30.5t17.5 -34.5t9.5 -36t4.5 -40.5zM385 294q-234 -7 -385 -85v433q103 -118 273 -118 q32 0 70 5q-21 -61 -21 -86q0 -67 63 -149zM558 805q0 -100 -43.5 -160.5t-140.5 -60.5q-51 0 -97 26t-78 67.5t-56 93.5t-35.5 104t-11.5 99q0 96 51.5 165t144.5 69q66 0 119 -41t84 -104t47 -130t16 -128zM1536 896v-736q0 -119 -84.5 -203.5t-203.5 -84.5h-468 q39 73 39 157q0 66 -22 122.5t-55.5 93t-72 71t-72 59.5t-55.5 54.5t-22 59.5q0 36 23 68t56 61.5t65.5 64.5t55.5 93t23 131t-26.5 145.5t-75.5 118.5q-6 6 -14 11t-12.5 7.5t-10 9.5t-10.5 17h135l135 64h-437q-138 0 -244.5 -38.5t-182.5 -133.5q0 126 81 213t207 87h960 q119 0 203.5 -84.5t84.5 -203.5v-96h-256v256h-128v-256h-256v-128h256v-256h128v256h256z" />
-<glyph unicode="&#xf0d5;" horiz-adv-x="1664" d="M876 71q0 21 -4.5 40.5t-9.5 36t-17.5 34.5t-21 30.5t-26.5 29.5t-27.5 25.5t-32 25.5t-31 23t-33 23t-30.5 21q-17 2 -50 2q-54 0 -106 -7t-108 -25t-98 -46t-69 -75t-27 -107q0 -68 35.5 -121.5t93 -84t120.5 -45.5t127 -15q59 0 112.5 12.5t100.5 39t74.5 73.5 t27.5 110zM756 933q0 60 -16.5 127.5t-47 130.5t-84 104t-119.5 41q-93 0 -144 -69t-51 -165q0 -47 11.5 -99t35.5 -104t56 -93.5t78 -67.5t97 -26q97 0 140.5 60.5t43.5 160.5zM625 1408h437l-135 -79h-135q71 -45 110 -126t39 -169q0 -74 -23 -131.5t-56 -92.5t-66 -64.5 t-56 -61t-23 -67.5q0 -26 16.5 -51t43 -48t58.5 -48t64 -55.5t58.5 -66t43 -85t16.5 -106.5q0 -160 -140 -282q-152 -131 -420 -131q-59 0 -119.5 10t-122 33.5t-108.5 58t-77 89t-30 121.5q0 61 37 135q32 64 96 110.5t145 71t155 36t150 13.5q-64 83 -64 149q0 12 2 23.5 t5 19.5t8 21.5t7 21.5q-40 -5 -70 -5q-149 0 -255.5 98t-106.5 246q0 140 95 250.5t234 141.5q94 20 187 20zM1664 1152v-128h-256v-256h-128v256h-256v128h256v256h128v-256h256z" />
-<glyph unicode="&#xf0d6;" horiz-adv-x="1920" d="M768 384h384v96h-128v448h-114l-148 -137l77 -80q42 37 55 57h2v-288h-128v-96zM1280 640q0 -70 -21 -142t-59.5 -134t-101.5 -101t-138 -39t-138 39t-101.5 101t-59.5 134t-21 142t21 142t59.5 134t101.5 101t138 39t138 -39t101.5 -101t59.5 -134t21 -142zM1792 384 v512q-106 0 -181 75t-75 181h-1152q0 -106 -75 -181t-181 -75v-512q106 0 181 -75t75 -181h1152q0 106 75 181t181 75zM1920 1216v-1152q0 -26 -19 -45t-45 -19h-1792q-26 0 -45 19t-19 45v1152q0 26 19 45t45 19h1792q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0d7;" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0d8;" horiz-adv-x="1024" d="M1024 320q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
-<glyph unicode="&#xf0d9;" horiz-adv-x="640" d="M640 1088v-896q0 -26 -19 -45t-45 -19t-45 19l-448 448q-19 19 -19 45t19 45l448 448q19 19 45 19t45 -19t19 -45z" />
-<glyph unicode="&#xf0da;" horiz-adv-x="640" d="M576 640q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19t-19 45v896q0 26 19 45t45 19t45 -19l448 -448q19 -19 19 -45z" />
-<glyph unicode="&#xf0db;" horiz-adv-x="1664" d="M160 0h608v1152h-640v-1120q0 -13 9.5 -22.5t22.5 -9.5zM1536 32v1120h-640v-1152h608q13 0 22.5 9.5t9.5 22.5zM1664 1248v-1216q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1344q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf0dc;" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45zM1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
-<glyph unicode="&#xf0dd;" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0de;" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
-<glyph unicode="&#xf0e0;" horiz-adv-x="1792" d="M1792 826v-794q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v794q44 -49 101 -87q362 -246 497 -345q57 -42 92.5 -65.5t94.5 -48t110 -24.5h1h1q51 0 110 24.5t94.5 48t92.5 65.5q170 123 498 345q57 39 100 87zM1792 1120q0 -79 -49 -151t-122 -123 q-376 -261 -468 -325q-10 -7 -42.5 -30.5t-54 -38t-52 -32.5t-57.5 -27t-50 -9h-1h-1q-23 0 -50 9t-57.5 27t-52 32.5t-54 38t-42.5 30.5q-91 64 -262 182.5t-205 142.5q-62 42 -117 115.5t-55 136.5q0 78 41.5 130t118.5 52h1472q65 0 112.5 -47t47.5 -113z" />
-<glyph unicode="&#xf0e1;" d="M349 911v-991h-330v991h330zM370 1217q1 -73 -50.5 -122t-135.5 -49h-2q-82 0 -132 49t-50 122q0 74 51.5 122.5t134.5 48.5t133 -48.5t51 -122.5zM1536 488v-568h-329v530q0 105 -40.5 164.5t-126.5 59.5q-63 0 -105.5 -34.5t-63.5 -85.5q-11 -30 -11 -81v-553h-329 q2 399 2 647t-1 296l-1 48h329v-144h-2q20 32 41 56t56.5 52t87 43.5t114.5 15.5q171 0 275 -113.5t104 -332.5z" />
-<glyph unicode="&#xf0e2;" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61q-172 0 -327 72.5t-264 204.5q-7 10 -6.5 22.5t8.5 20.5l137 138q10 9 25 9q16 -2 23 -12q73 -95 179 -147t225 -52q104 0 198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5t-40.5 198.5t-109.5 163.5 t-163.5 109.5t-198.5 40.5q-98 0 -188 -35.5t-160 -101.5l137 -138q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l130 -129q107 101 244.5 156.5t284.5 55.5q156 0 298 -61t245 -164t164 -245t61 -298z" />
-<glyph unicode="&#xf0e3;" horiz-adv-x="1792" d="M1771 0q0 -53 -37 -90l-107 -108q-39 -37 -91 -37q-53 0 -90 37l-363 364q-38 36 -38 90q0 53 43 96l-256 256l-126 -126q-14 -14 -34 -14t-34 14q2 -2 12.5 -12t12.5 -13t10 -11.5t10 -13.5t6 -13.5t5.5 -16.5t1.5 -18q0 -38 -28 -68q-3 -3 -16.5 -18t-19 -20.5 t-18.5 -16.5t-22 -15.5t-22 -9t-26 -4.5q-40 0 -68 28l-408 408q-28 28 -28 68q0 13 4.5 26t9 22t15.5 22t16.5 18.5t20.5 19t18 16.5q30 28 68 28q10 0 18 -1.5t16.5 -5.5t13.5 -6t13.5 -10t11.5 -10t13 -12.5t12 -12.5q-14 14 -14 34t14 34l348 348q14 14 34 14t34 -14 q-2 2 -12.5 12t-12.5 13t-10 11.5t-10 13.5t-6 13.5t-5.5 16.5t-1.5 18q0 38 28 68q3 3 16.5 18t19 20.5t18.5 16.5t22 15.5t22 9t26 4.5q40 0 68 -28l408 -408q28 -28 28 -68q0 -13 -4.5 -26t-9 -22t-15.5 -22t-16.5 -18.5t-20.5 -19t-18 -16.5q-30 -28 -68 -28 q-10 0 -18 1.5t-16.5 5.5t-13.5 6t-13.5 10t-11.5 10t-13 12.5t-12 12.5q14 -14 14 -34t-14 -34l-126 -126l256 -256q43 43 96 43q52 0 91 -37l363 -363q37 -39 37 -91z" />
-<glyph unicode="&#xf0e4;" horiz-adv-x="1792" d="M384 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM576 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1004 351l101 382q6 26 -7.5 48.5t-38.5 29.5 t-48 -6.5t-30 -39.5l-101 -382q-60 -5 -107 -43.5t-63 -98.5q-20 -77 20 -146t117 -89t146 20t89 117q16 60 -6 117t-72 91zM1664 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 1024q0 53 -37.5 90.5 t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1472 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1792 384q0 -261 -141 -483q-19 -29 -54 -29h-1402q-35 0 -54 29 q-141 221 -141 483q0 182 71 348t191 286t286 191t348 71t348 -71t286 -191t191 -286t71 -348z" />
-<glyph unicode="&#xf0e5;" horiz-adv-x="1792" d="M896 1152q-204 0 -381.5 -69.5t-282 -187.5t-104.5 -255q0 -112 71.5 -213.5t201.5 -175.5l87 -50l-27 -96q-24 -91 -70 -172q152 63 275 171l43 38l57 -6q69 -8 130 -8q204 0 381.5 69.5t282 187.5t104.5 255t-104.5 255t-282 187.5t-381.5 69.5zM1792 640 q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22h-5q-15 0 -27 10.5t-16 27.5v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281q0 174 120 321.5 t326 233t450 85.5t450 -85.5t326 -233t120 -321.5z" />
-<glyph unicode="&#xf0e6;" horiz-adv-x="1792" d="M704 1152q-153 0 -286 -52t-211.5 -141t-78.5 -191q0 -82 53 -158t149 -132l97 -56l-35 -84q34 20 62 39l44 31l53 -10q78 -14 153 -14q153 0 286 52t211.5 141t78.5 191t-78.5 191t-211.5 141t-286 52zM704 1280q191 0 353.5 -68.5t256.5 -186.5t94 -257t-94 -257 t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224q0 139 94 257t256.5 186.5 t353.5 68.5zM1526 111q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129 q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230q0 -120 -71 -224.5t-195 -176.5z" />
-<glyph unicode="&#xf0e7;" horiz-adv-x="896" d="M885 970q18 -20 7 -44l-540 -1157q-13 -25 -42 -25q-4 0 -14 2q-17 5 -25.5 19t-4.5 30l197 808l-406 -101q-4 -1 -12 -1q-18 0 -31 11q-18 15 -13 39l201 825q4 14 16 23t28 9h328q19 0 32 -12.5t13 -29.5q0 -8 -5 -18l-171 -463l396 98q8 2 12 2q19 0 34 -15z" />
-<glyph unicode="&#xf0e8;" horiz-adv-x="1792" d="M1792 288v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192q0 52 38 90t90 38h512v192h-96q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h320q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-96v-192h512q52 0 90 -38t38 -90v-192h96q40 0 68 -28t28 -68 z" />
-<glyph unicode="&#xf0e9;" horiz-adv-x="1664" d="M896 708v-580q0 -104 -76 -180t-180 -76t-180 76t-76 180q0 26 19 45t45 19t45 -19t19 -45q0 -50 39 -89t89 -39t89 39t39 89v580q33 11 64 11t64 -11zM1664 681q0 -13 -9.5 -22.5t-22.5 -9.5q-11 0 -23 10q-49 46 -93 69t-102 23q-68 0 -128 -37t-103 -97 q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -28 -17q-18 0 -29 17q-4 6 -14.5 24t-17.5 28q-43 60 -102.5 97t-127.5 37t-127.5 -37t-102.5 -97q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -29 -17q-17 0 -28 17q-4 6 -14.5 24t-17.5 28q-43 60 -103 97t-128 37q-58 0 -102 -23t-93 -69 q-12 -10 -23 -10q-13 0 -22.5 9.5t-9.5 22.5q0 5 1 7q45 183 172.5 319.5t298 204.5t360.5 68q140 0 274.5 -40t246.5 -113.5t194.5 -187t115.5 -251.5q1 -2 1 -7zM896 1408v-98q-42 2 -64 2t-64 -2v98q0 26 19 45t45 19t45 -19t19 -45z" />
-<glyph unicode="&#xf0ea;" horiz-adv-x="1792" d="M768 -128h896v640h-416q-40 0 -68 28t-28 68v416h-384v-1152zM1024 1312v64q0 13 -9.5 22.5t-22.5 9.5h-704q-13 0 -22.5 -9.5t-9.5 -22.5v-64q0 -13 9.5 -22.5t22.5 -9.5h704q13 0 22.5 9.5t9.5 22.5zM1280 640h299l-299 299v-299zM1792 512v-672q0 -40 -28 -68t-68 -28 h-960q-40 0 -68 28t-28 68v160h-544q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h1088q40 0 68 -28t28 -68v-328q21 -13 36 -28l408 -408q28 -28 48 -76t20 -88z" />
-<glyph unicode="&#xf0eb;" horiz-adv-x="1024" d="M736 960q0 -13 -9.5 -22.5t-22.5 -9.5t-22.5 9.5t-9.5 22.5q0 46 -54 71t-106 25q-13 0 -22.5 9.5t-9.5 22.5t9.5 22.5t22.5 9.5q50 0 99.5 -16t87 -54t37.5 -90zM896 960q0 72 -34.5 134t-90 101.5t-123 62t-136.5 22.5t-136.5 -22.5t-123 -62t-90 -101.5t-34.5 -134 q0 -101 68 -180q10 -11 30.5 -33t30.5 -33q128 -153 141 -298h228q13 145 141 298q10 11 30.5 33t30.5 33q68 79 68 180zM1024 960q0 -155 -103 -268q-45 -49 -74.5 -87t-59.5 -95.5t-34 -107.5q47 -28 47 -82q0 -37 -25 -64q25 -27 25 -64q0 -52 -45 -81q13 -23 13 -47 q0 -46 -31.5 -71t-77.5 -25q-20 -44 -60 -70t-87 -26t-87 26t-60 70q-46 0 -77.5 25t-31.5 71q0 24 13 47q-45 29 -45 81q0 37 25 64q-25 27 -25 64q0 54 47 82q-4 50 -34 107.5t-59.5 95.5t-74.5 87q-103 113 -103 268q0 99 44.5 184.5t117 142t164 89t186.5 32.5 t186.5 -32.5t164 -89t117 -142t44.5 -184.5z" />
-<glyph unicode="&#xf0ec;" horiz-adv-x="1792" d="M1792 352v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5q-12 0 -24 10l-319 320q-9 9 -9 22q0 14 9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h1376q13 0 22.5 -9.5t9.5 -22.5zM1792 896q0 -14 -9 -23l-320 -320q-9 -9 -23 -9 q-13 0 -22.5 9.5t-9.5 22.5v192h-1376q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1376v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" />
-<glyph unicode="&#xf0ed;" horiz-adv-x="1920" d="M1280 608q0 14 -9 23t-23 9h-224v352q0 13 -9.5 22.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-352h-224q-13 0 -22.5 -9.5t-9.5 -22.5q0 -14 9 -23l352 -352q9 -9 23 -9t23 9l351 351q10 12 10 24zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" />
-<glyph unicode="&#xf0ee;" horiz-adv-x="1920" d="M1280 672q0 14 -9 23l-352 352q-9 9 -23 9t-23 -9l-351 -351q-10 -12 -10 -24q0 -14 9 -23t23 -9h224v-352q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5v352h224q13 0 22.5 9.5t9.5 22.5zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" />
-<glyph unicode="&#xf0f0;" horiz-adv-x="1408" d="M384 192q0 -26 -19 -45t-45 -19t-45 19t-19 45t19 45t45 19t45 -19t19 -45zM1408 131q0 -121 -73 -190t-194 -69h-874q-121 0 -194 69t-73 190q0 68 5.5 131t24 138t47.5 132.5t81 103t120 60.5q-22 -52 -22 -120v-203q-58 -20 -93 -70t-35 -111q0 -80 56 -136t136 -56 t136 56t56 136q0 61 -35.5 111t-92.5 70v203q0 62 25 93q132 -104 295 -104t295 104q25 -31 25 -93v-64q-106 0 -181 -75t-75 -181v-89q-32 -29 -32 -71q0 -40 28 -68t68 -28t68 28t28 68q0 42 -32 71v89q0 52 38 90t90 38t90 -38t38 -90v-89q-32 -29 -32 -71q0 -40 28 -68 t68 -28t68 28t28 68q0 42 -32 71v89q0 68 -34.5 127.5t-93.5 93.5q0 10 0.5 42.5t0 48t-2.5 41.5t-7 47t-13 40q68 -15 120 -60.5t81 -103t47.5 -132.5t24 -138t5.5 -131zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5 t271.5 -112.5t112.5 -271.5z" />
-<glyph unicode="&#xf0f1;" horiz-adv-x="1408" d="M1280 832q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 832q0 -62 -35.5 -111t-92.5 -70v-395q0 -159 -131.5 -271.5t-316.5 -112.5t-316.5 112.5t-131.5 271.5v132q-164 20 -274 128t-110 252v512q0 26 19 45t45 19q6 0 16 -2q17 30 47 48 t65 18q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5q-33 0 -64 18v-402q0 -106 94 -181t226 -75t226 75t94 181v402q-31 -18 -64 -18q-53 0 -90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5q35 0 65 -18t47 -48q10 2 16 2q26 0 45 -19t19 -45v-512q0 -144 -110 -252 t-274 -128v-132q0 -106 94 -181t226 -75t226 75t94 181v395q-57 21 -92.5 70t-35.5 111q0 80 56 136t136 56t136 -56t56 -136z" />
-<glyph unicode="&#xf0f2;" horiz-adv-x="1792" d="M640 1152h512v128h-512v-128zM288 1152v-1280h-64q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h64zM1408 1152v-1280h-1024v1280h128v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h128zM1792 928v-832q0 -92 -66 -158t-158 -66h-64v1280h64q92 0 158 -66 t66 -158z" />
-<glyph unicode="&#xf0f3;" horiz-adv-x="1664" d="M848 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM1664 128q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q190 161 287 397.5t97 498.5 q0 165 96 262t264 117q-8 18 -8 37q0 40 28 68t68 28t68 -28t28 -68q0 -19 -8 -37q168 -20 264 -117t96 -262q0 -262 97 -498.5t287 -397.5z" />
-<glyph unicode="&#xf0f4;" horiz-adv-x="1920" d="M1664 896q0 80 -56 136t-136 56h-64v-384h64q80 0 136 56t56 136zM0 128h1792q0 -106 -75 -181t-181 -75h-1280q-106 0 -181 75t-75 181zM1856 896q0 -159 -112.5 -271.5t-271.5 -112.5h-64v-32q0 -92 -66 -158t-158 -66h-704q-92 0 -158 66t-66 158v736q0 26 19 45 t45 19h1152q159 0 271.5 -112.5t112.5 -271.5z" />
-<glyph unicode="&#xf0f5;" horiz-adv-x="1408" d="M640 1472v-640q0 -61 -35.5 -111t-92.5 -70v-779q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v779q-57 20 -92.5 70t-35.5 111v640q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45 t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45zM1408 1472v-1600q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v512h-224q-13 0 -22.5 9.5t-9.5 22.5v800q0 132 94 226t226 94h256q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0f6;" horiz-adv-x="1280" d="M1024 352v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704q14 0 23 -9t9 -23zM1024 608v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704q14 0 23 -9t9 -23zM128 0h1024v768h-416q-40 0 -68 28t-28 68v416h-512v-1280z M768 896h376q-10 29 -22 41l-313 313q-12 12 -41 22v-376zM1280 864v-896q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h640q40 0 88 -20t76 -48l312 -312q28 -28 48 -76t20 -88z" />
-<glyph unicode="&#xf0f7;" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1536h-1152v-1536h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM1408 1472v-1664q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1664q0 26 19 45t45 19h1280q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0f8;" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1152h-256v-32q0 -40 -28 -68t-68 -28h-448q-40 0 -68 28t-28 68v32h-256v-1152h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM896 1056v320q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-96h-128v96q0 13 -9.5 22.5 t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5v96h128v-96q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1408 1088v-1280q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1280q0 26 19 45t45 19h320 v288q0 40 28 68t68 28h448q40 0 68 -28t28 -68v-288h320q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0f9;" horiz-adv-x="1920" d="M640 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM256 640h384v256h-158q-14 -2 -22 -9l-195 -195q-7 -12 -9 -22v-30zM1536 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1664 800v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM1920 1344v-1152 q0 -26 -19 -45t-45 -19h-192q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-128q-26 0 -45 19t-19 45t19 45t45 19v416q0 26 13 58t32 51l198 198q19 19 51 32t58 13h160v320q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf0fa;" horiz-adv-x="1792" d="M1280 416v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM640 1152h512v128h-512v-128zM256 1152v-1280h-32 q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h32zM1440 1152v-1280h-1088v1280h160v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h160zM1792 928v-832q0 -92 -66 -158t-158 -66h-32v1280h32q92 0 158 -66t66 -158z" />
-<glyph unicode="&#xf0fb;" horiz-adv-x="1920" d="M1920 576q-1 -32 -288 -96l-352 -32l-224 -64h-64l-293 -352h69q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-96h-160h-64v32h64v416h-160l-192 -224h-96l-32 32v192h32v32h128v8l-192 24v128l192 24v8h-128v32h-32v192l32 32h96l192 -224h160v416h-64v32h64h160h96 q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-69l293 -352h64l224 -64l352 -32q261 -58 287 -93z" />
-<glyph unicode="&#xf0fc;" horiz-adv-x="1664" d="M640 640v384h-256v-256q0 -53 37.5 -90.5t90.5 -37.5h128zM1664 192v-192h-1152v192l128 192h-128q-159 0 -271.5 112.5t-112.5 271.5v320l-64 64l32 128h480l32 128h960l32 -192l-64 -32v-800z" />
-<glyph unicode="&#xf0fd;" d="M1280 192v896q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-512v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-896q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h512v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf0fe;" d="M1280 576v128q0 26 -19 45t-45 19h-320v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-320q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h320v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h320q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf100;" horiz-adv-x="1024" d="M627 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23zM1011 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23z" />
-<glyph unicode="&#xf101;" horiz-adv-x="1024" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM979 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23 l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
-<glyph unicode="&#xf102;" horiz-adv-x="1152" d="M1075 224q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM1075 608q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393 q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
-<glyph unicode="&#xf103;" horiz-adv-x="1152" d="M1075 672q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23zM1075 1056q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
-<glyph unicode="&#xf104;" horiz-adv-x="640" d="M627 992q0 -13 -10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
-<glyph unicode="&#xf105;" horiz-adv-x="640" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
-<glyph unicode="&#xf106;" horiz-adv-x="1152" d="M1075 352q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
-<glyph unicode="&#xf107;" horiz-adv-x="1152" d="M1075 800q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
-<glyph unicode="&#xf108;" horiz-adv-x="1920" d="M1792 544v832q0 13 -9.5 22.5t-22.5 9.5h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5zM1920 1376v-1088q0 -66 -47 -113t-113 -47h-544q0 -37 16 -77.5t32 -71t16 -43.5q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19 t-19 45q0 14 16 44t32 70t16 78h-544q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf109;" horiz-adv-x="1920" d="M416 256q-66 0 -113 47t-47 113v704q0 66 47 113t113 47h1088q66 0 113 -47t47 -113v-704q0 -66 -47 -113t-113 -47h-1088zM384 1120v-704q0 -13 9.5 -22.5t22.5 -9.5h1088q13 0 22.5 9.5t9.5 22.5v704q0 13 -9.5 22.5t-22.5 9.5h-1088q-13 0 -22.5 -9.5t-9.5 -22.5z M1760 192h160v-96q0 -40 -47 -68t-113 -28h-1600q-66 0 -113 28t-47 68v96h160h1600zM1040 96q16 0 16 16t-16 16h-160q-16 0 -16 -16t16 -16h160z" />
-<glyph unicode="&#xf10a;" horiz-adv-x="1152" d="M640 128q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1024 288v960q0 13 -9.5 22.5t-22.5 9.5h-832q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h832q13 0 22.5 9.5t9.5 22.5zM1152 1248v-1088q0 -66 -47 -113t-113 -47h-832 q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h832q66 0 113 -47t47 -113z" />
-<glyph unicode="&#xf10b;" horiz-adv-x="768" d="M464 128q0 33 -23.5 56.5t-56.5 23.5t-56.5 -23.5t-23.5 -56.5t23.5 -56.5t56.5 -23.5t56.5 23.5t23.5 56.5zM672 288v704q0 13 -9.5 22.5t-22.5 9.5h-512q-13 0 -22.5 -9.5t-9.5 -22.5v-704q0 -13 9.5 -22.5t22.5 -9.5h512q13 0 22.5 9.5t9.5 22.5zM480 1136 q0 16 -16 16h-160q-16 0 -16 -16t16 -16h160q16 0 16 16zM768 1152v-1024q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v1024q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" />
-<glyph unicode="&#xf10c;" d="M768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103 t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf10d;" horiz-adv-x="1664" d="M768 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z M1664 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z" />
-<glyph unicode="&#xf10e;" horiz-adv-x="1664" d="M768 1216v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136zM1664 1216 v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136z" />
-<glyph unicode="&#xf110;" horiz-adv-x="1568" d="M496 192q0 -60 -42.5 -102t-101.5 -42q-60 0 -102 42t-42 102t42 102t102 42q59 0 101.5 -42t42.5 -102zM928 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM320 640q0 -66 -47 -113t-113 -47t-113 47t-47 113 t47 113t113 47t113 -47t47 -113zM1360 192q0 -46 -33 -79t-79 -33t-79 33t-33 79t33 79t79 33t79 -33t33 -79zM528 1088q0 -73 -51.5 -124.5t-124.5 -51.5t-124.5 51.5t-51.5 124.5t51.5 124.5t124.5 51.5t124.5 -51.5t51.5 -124.5zM992 1280q0 -80 -56 -136t-136 -56 t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1536 640q0 -40 -28 -68t-68 -28t-68 28t-28 68t28 68t68 28t68 -28t28 -68zM1328 1088q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5z" />
-<glyph unicode="&#xf111;" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf112;" horiz-adv-x="1792" d="M1792 416q0 -166 -127 -451q-3 -7 -10.5 -24t-13.5 -30t-13 -22q-12 -17 -28 -17q-15 0 -23.5 10t-8.5 25q0 9 2.5 26.5t2.5 23.5q5 68 5 123q0 101 -17.5 181t-48.5 138.5t-80 101t-105.5 69.5t-133 42.5t-154 21.5t-175.5 6h-224v-256q0 -26 -19 -45t-45 -19t-45 19 l-512 512q-19 19 -19 45t19 45l512 512q19 19 45 19t45 -19t19 -45v-256h224q713 0 875 -403q53 -134 53 -333z" />
-<glyph unicode="&#xf113;" horiz-adv-x="1664" d="M640 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1280 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1440 320 q0 120 -69 204t-187 84q-41 0 -195 -21q-71 -11 -157 -11t-157 11q-152 21 -195 21q-118 0 -187 -84t-69 -204q0 -88 32 -153.5t81 -103t122 -60t140 -29.5t149 -7h168q82 0 149 7t140 29.5t122 60t81 103t32 153.5zM1664 496q0 -207 -61 -331q-38 -77 -105.5 -133t-141 -86 t-170 -47.5t-171.5 -22t-167 -4.5q-78 0 -142 3t-147.5 12.5t-152.5 30t-137 51.5t-121 81t-86 115q-62 123 -62 331q0 237 136 396q-27 82 -27 170q0 116 51 218q108 0 190 -39.5t189 -123.5q147 35 309 35q148 0 280 -32q105 82 187 121t189 39q51 -102 51 -218 q0 -87 -27 -168q136 -160 136 -398z" />
-<glyph unicode="&#xf114;" horiz-adv-x="1664" d="M1536 224v704q0 40 -28 68t-68 28h-704q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68v-960q0 -40 28 -68t68 -28h1216q40 0 68 28t28 68zM1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320 q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" />
-<glyph unicode="&#xf115;" horiz-adv-x="1920" d="M1781 605q0 35 -53 35h-1088q-40 0 -85.5 -21.5t-71.5 -52.5l-294 -363q-18 -24 -18 -40q0 -35 53 -35h1088q40 0 86 22t71 53l294 363q18 22 18 39zM640 768h768v160q0 40 -28 68t-68 28h-576q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68 v-853l256 315q44 53 116 87.5t140 34.5zM1909 605q0 -62 -46 -120l-295 -363q-43 -53 -116 -87.5t-140 -34.5h-1088q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158v-160h192q54 0 99 -24.5t67 -70.5q15 -32 15 -68z " />
-<glyph unicode="&#xf116;" horiz-adv-x="1792" />
-<glyph unicode="&#xf117;" horiz-adv-x="1792" />
-<glyph unicode="&#xf118;" d="M1134 461q-37 -121 -138 -195t-228 -74t-228 74t-138 195q-8 25 4 48.5t38 31.5q25 8 48.5 -4t31.5 -38q25 -80 92.5 -129.5t151.5 -49.5t151.5 49.5t92.5 129.5q8 26 32 38t49 4t37 -31.5t4 -48.5zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5 t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5 t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf119;" d="M1134 307q8 -25 -4 -48.5t-37 -31.5t-49 4t-32 38q-25 80 -92.5 129.5t-151.5 49.5t-151.5 -49.5t-92.5 -129.5q-8 -26 -31.5 -38t-48.5 -4q-26 8 -38 31.5t-4 48.5q37 121 138 195t228 74t228 -74t138 -195zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204 t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf11a;" d="M1152 448q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h640q26 0 45 -19t19 -45zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf11b;" horiz-adv-x="1920" d="M832 448v128q0 14 -9 23t-23 9h-192v192q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-192h-192q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h192v-192q0 -14 9 -23t23 -9h128q14 0 23 9t9 23v192h192q14 0 23 9t9 23zM1408 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5 t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 640q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1920 512q0 -212 -150 -362t-362 -150q-192 0 -338 128h-220q-146 -128 -338 -128q-212 0 -362 150 t-150 362t150 362t362 150h896q212 0 362 -150t150 -362z" />
-<glyph unicode="&#xf11c;" horiz-adv-x="1920" d="M384 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM512 624v-96q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h224q16 0 16 -16zM384 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 368v-96q0 -16 -16 -16 h-864q-16 0 -16 16v96q0 16 16 16h864q16 0 16 -16zM768 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM640 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1024 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16 h96q16 0 16 -16zM896 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1280 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1152 880v-96 q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 880v-352q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h112v240q0 16 16 16h96q16 0 16 -16zM1792 128v896h-1664v-896 h1664zM1920 1024v-896q0 -53 -37.5 -90.5t-90.5 -37.5h-1664q-53 0 -90.5 37.5t-37.5 90.5v896q0 53 37.5 90.5t90.5 37.5h1664q53 0 90.5 -37.5t37.5 -90.5z" />
-<glyph unicode="&#xf11d;" horiz-adv-x="1792" d="M1664 491v616q-169 -91 -306 -91q-82 0 -145 32q-100 49 -184 76.5t-178 27.5q-173 0 -403 -127v-599q245 113 433 113q55 0 103.5 -7.5t98 -26t77 -31t82.5 -39.5l28 -14q44 -22 101 -22q120 0 293 92zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9 h-64q-14 0 -23 9t-9 23v1266q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102 q-15 -9 -33 -9q-16 0 -32 8q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" />
-<glyph unicode="&#xf11e;" horiz-adv-x="1792" d="M832 536v192q-181 -16 -384 -117v-185q205 96 384 110zM832 954v197q-172 -8 -384 -126v-189q215 111 384 118zM1664 491v184q-235 -116 -384 -71v224q-20 6 -39 15q-5 3 -33 17t-34.5 17t-31.5 15t-34.5 15.5t-32.5 13t-36 12.5t-35 8.5t-39.5 7.5t-39.5 4t-44 2 q-23 0 -49 -3v-222h19q102 0 192.5 -29t197.5 -82q19 -9 39 -15v-188q42 -17 91 -17q120 0 293 92zM1664 918v189q-169 -91 -306 -91q-45 0 -78 8v-196q148 -42 384 90zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v1266 q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102q-15 -9 -33 -9q-16 0 -32 8 q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" />
-<glyph unicode="&#xf120;" horiz-adv-x="1664" d="M585 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23zM1664 96v-64q0 -14 -9 -23t-23 -9h-960q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h960q14 0 23 -9 t9 -23z" />
-<glyph unicode="&#xf121;" horiz-adv-x="1920" d="M617 137l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23zM1208 1204l-373 -1291q-4 -13 -15.5 -19.5t-23.5 -2.5l-62 17q-13 4 -19.5 15.5t-2.5 24.5 l373 1291q4 13 15.5 19.5t23.5 2.5l62 -17q13 -4 19.5 -15.5t2.5 -24.5zM1865 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23z" />
-<glyph unicode="&#xf122;" horiz-adv-x="1792" d="M640 454v-70q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-69l-397 -398q-19 -19 -19 -45t19 -45zM1792 416q0 -58 -17 -133.5t-38.5 -138t-48 -125t-40.5 -90.5l-20 -40q-8 -17 -28 -17q-6 0 -9 1 q-25 8 -23 34q43 400 -106 565q-64 71 -170.5 110.5t-267.5 52.5v-251q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-262q411 -28 599 -221q169 -173 169 -509z" />
-<glyph unicode="&#xf123;" horiz-adv-x="1664" d="M1186 579l257 250l-356 52l-66 10l-30 60l-159 322v-963l59 -31l318 -168l-60 355l-12 66zM1638 841l-363 -354l86 -500q5 -33 -6 -51.5t-34 -18.5q-17 0 -40 12l-449 236l-449 -236q-23 -12 -40 -12q-23 0 -34 18.5t-6 51.5l86 500l-364 354q-32 32 -23 59.5t54 34.5 l502 73l225 455q20 41 49 41q28 0 49 -41l225 -455l502 -73q45 -7 54 -34.5t-24 -59.5z" />
-<glyph unicode="&#xf124;" horiz-adv-x="1408" d="M1401 1187l-640 -1280q-17 -35 -57 -35q-5 0 -15 2q-22 5 -35.5 22.5t-13.5 39.5v576h-576q-22 0 -39.5 13.5t-22.5 35.5t4 42t29 30l1280 640q13 7 29 7q27 0 45 -19q15 -14 18.5 -34.5t-6.5 -39.5z" />
-<glyph unicode="&#xf125;" horiz-adv-x="1664" d="M557 256h595v595zM512 301l595 595h-595v-595zM1664 224v-192q0 -14 -9 -23t-23 -9h-224v-224q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v224h-864q-14 0 -23 9t-9 23v864h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224v224q0 14 9 23t23 9h192q14 0 23 -9t9 -23 v-224h851l246 247q10 9 23 9t23 -9q9 -10 9 -23t-9 -23l-247 -246v-851h224q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf126;" horiz-adv-x="1024" d="M288 64q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM288 1216q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM928 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1024 1088q0 -52 -26 -96.5t-70 -69.5 q-2 -287 -226 -414q-68 -38 -203 -81q-128 -40 -169.5 -71t-41.5 -100v-26q44 -25 70 -69.5t26 -96.5q0 -80 -56 -136t-136 -56t-136 56t-56 136q0 52 26 96.5t70 69.5v820q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136q0 -52 -26 -96.5t-70 -69.5v-497 q54 26 154 57q55 17 87.5 29.5t70.5 31t59 39.5t40.5 51t28 69.5t8.5 91.5q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136z" />
-<glyph unicode="&#xf127;" horiz-adv-x="1664" d="M439 265l-256 -256q-10 -9 -23 -9q-12 0 -23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23zM608 224v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM384 448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23t9 23t23 9h320 q14 0 23 -9t9 -23zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-334 335q-21 21 -42 56l239 18l273 -274q27 -27 68 -27.5t68 26.5l147 146q28 28 28 67q0 40 -28 68l-274 275l18 239q35 -21 56 -42l336 -336q84 -86 84 -204zM1031 1044l-239 -18 l-273 274q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l274 -274l-18 -240q-35 21 -56 42l-336 336q-84 86 -84 204q0 120 85 203l147 146q83 83 203 83q121 0 204 -85l334 -335q21 -21 42 -56zM1664 960q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9 t-9 23t9 23t23 9h320q14 0 23 -9t9 -23zM1120 1504v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM1527 1353l-256 -256q-11 -9 -23 -9t-23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23z" />
-<glyph unicode="&#xf128;" horiz-adv-x="1024" d="M704 280v-240q0 -16 -12 -28t-28 -12h-240q-16 0 -28 12t-12 28v240q0 16 12 28t28 12h240q16 0 28 -12t12 -28zM1020 880q0 -54 -15.5 -101t-35 -76.5t-55 -59.5t-57.5 -43.5t-61 -35.5q-41 -23 -68.5 -65t-27.5 -67q0 -17 -12 -32.5t-28 -15.5h-240q-15 0 -25.5 18.5 t-10.5 37.5v45q0 83 65 156.5t143 108.5q59 27 84 56t25 76q0 42 -46.5 74t-107.5 32q-65 0 -108 -29q-35 -25 -107 -115q-13 -16 -31 -16q-12 0 -25 8l-164 125q-13 10 -15.5 25t5.5 28q160 266 464 266q80 0 161 -31t146 -83t106 -127.5t41 -158.5z" />
-<glyph unicode="&#xf129;" horiz-adv-x="640" d="M640 192v-128q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64v384h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-576h64q26 0 45 -19t19 -45zM512 1344v-192q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v192 q0 26 19 45t45 19h256q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf12a;" horiz-adv-x="640" d="M512 288v-224q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v224q0 26 19 45t45 19h256q26 0 45 -19t19 -45zM542 1344l-28 -768q-1 -26 -20.5 -45t-45.5 -19h-256q-26 0 -45.5 19t-20.5 45l-28 768q-1 26 17.5 45t44.5 19h320q26 0 44.5 -19t17.5 -45z" />
-<glyph unicode="&#xf12b;" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1534 846v-206h-514l-3 27 q-4 28 -4 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q83 65 188 65q110 0 178 -59.5t68 -158.5q0 -56 -24.5 -103t-62 -76.5t-81.5 -58.5t-82 -50.5t-65.5 -51.5t-30.5 -63h232v80 h126z" />
-<glyph unicode="&#xf12c;" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1536 -50v-206h-514l-4 27 q-3 45 -3 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q80 65 188 65q110 0 178 -59.5t68 -158.5q0 -66 -34.5 -118.5t-84 -86t-99.5 -62.5t-87 -63t-41 -73h232v80h126z" />
-<glyph unicode="&#xf12d;" horiz-adv-x="1920" d="M896 128l336 384h-768l-336 -384h768zM1909 1205q15 -34 9.5 -71.5t-30.5 -65.5l-896 -1024q-38 -44 -96 -44h-768q-38 0 -69.5 20.5t-47.5 54.5q-15 34 -9.5 71.5t30.5 65.5l896 1024q38 44 96 44h768q38 0 69.5 -20.5t47.5 -54.5z" />
-<glyph unicode="&#xf12e;" horiz-adv-x="1664" d="M1664 438q0 -81 -44.5 -135t-123.5 -54q-41 0 -77.5 17.5t-59 38t-56.5 38t-71 17.5q-110 0 -110 -124q0 -39 16 -115t15 -115v-5q-22 0 -33 -1q-34 -3 -97.5 -11.5t-115.5 -13.5t-98 -5q-61 0 -103 26.5t-42 83.5q0 37 17.5 71t38 56.5t38 59t17.5 77.5q0 79 -54 123.5 t-135 44.5q-84 0 -143 -45.5t-59 -127.5q0 -43 15 -83t33.5 -64.5t33.5 -53t15 -50.5q0 -45 -46 -89q-37 -35 -117 -35q-95 0 -245 24q-9 2 -27.5 4t-27.5 4l-13 2q-1 0 -3 1q-2 0 -2 1v1024q2 -1 17.5 -3.5t34 -5t21.5 -3.5q150 -24 245 -24q80 0 117 35q46 44 46 89 q0 22 -15 50.5t-33.5 53t-33.5 64.5t-15 83q0 82 59 127.5t144 45.5q80 0 134 -44.5t54 -123.5q0 -41 -17.5 -77.5t-38 -59t-38 -56.5t-17.5 -71q0 -57 42 -83.5t103 -26.5q64 0 180 15t163 17v-2q-1 -2 -3.5 -17.5t-5 -34t-3.5 -21.5q-24 -150 -24 -245q0 -80 35 -117 q44 -46 89 -46q22 0 50.5 15t53 33.5t64.5 33.5t83 15q82 0 127.5 -59t45.5 -143z" />
-<glyph unicode="&#xf130;" horiz-adv-x="1152" d="M1152 832v-128q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-217 24 -364.5 187.5t-147.5 384.5v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -185 131.5 -316.5t316.5 -131.5 t316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45zM896 1216v-512q0 -132 -94 -226t-226 -94t-226 94t-94 226v512q0 132 94 226t226 94t226 -94t94 -226z" />
-<glyph unicode="&#xf131;" horiz-adv-x="1408" d="M271 591l-101 -101q-42 103 -42 214v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -53 15 -113zM1385 1193l-361 -361v-128q0 -132 -94 -226t-226 -94q-55 0 -109 19l-96 -96q97 -51 205 -51q185 0 316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45v-128 q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-125 13 -235 81l-254 -254q-10 -10 -23 -10t-23 10l-82 82q-10 10 -10 23t10 23l1234 1234q10 10 23 10t23 -10l82 -82q10 -10 10 -23 t-10 -23zM1005 1325l-621 -621v512q0 132 94 226t226 94q102 0 184.5 -59t116.5 -152z" />
-<glyph unicode="&#xf132;" horiz-adv-x="1280" d="M1088 576v640h-448v-1137q119 63 213 137q235 184 235 360zM1280 1344v-768q0 -86 -33.5 -170.5t-83 -150t-118 -127.5t-126.5 -103t-121 -77.5t-89.5 -49.5t-42.5 -20q-12 -6 -26 -6t-26 6q-16 7 -42.5 20t-89.5 49.5t-121 77.5t-126.5 103t-118 127.5t-83 150 t-33.5 170.5v768q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf133;" horiz-adv-x="1664" d="M128 -128h1408v1024h-1408v-1024zM512 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1280 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1664 1152v-1280 q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" />
-<glyph unicode="&#xf134;" horiz-adv-x="1408" d="M512 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 1376v-320q0 -16 -12 -25q-8 -7 -20 -7q-4 0 -7 1l-448 96q-11 2 -18 11t-7 20h-256v-102q111 -23 183.5 -111t72.5 -203v-800q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v800 q0 106 62.5 190.5t161.5 114.5v111h-32q-59 0 -115 -23.5t-91.5 -53t-66 -66.5t-40.5 -53.5t-14 -24.5q-17 -35 -57 -35q-16 0 -29 7q-23 12 -31.5 37t3.5 49q5 10 14.5 26t37.5 53.5t60.5 70t85 67t108.5 52.5q-25 42 -25 86q0 66 47 113t113 47t113 -47t47 -113 q0 -33 -14 -64h302q0 11 7 20t18 11l448 96q3 1 7 1q12 0 20 -7q12 -9 12 -25z" />
-<glyph unicode="&#xf135;" horiz-adv-x="1664" d="M1440 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1664 1376q0 -249 -75.5 -430.5t-253.5 -360.5q-81 -80 -195 -176l-20 -379q-2 -16 -16 -26l-384 -224q-7 -4 -16 -4q-12 0 -23 9l-64 64q-13 14 -8 32l85 276l-281 281l-276 -85q-3 -1 -9 -1 q-14 0 -23 9l-64 64q-17 19 -5 39l224 384q10 14 26 16l379 20q96 114 176 195q188 187 358 258t431 71q14 0 24 -9.5t10 -22.5z" />
-<glyph unicode="&#xf136;" horiz-adv-x="1792" d="M1745 763l-164 -763h-334l178 832q13 56 -15 88q-27 33 -83 33h-169l-204 -953h-334l204 953h-286l-204 -953h-334l204 953l-153 327h1276q101 0 189.5 -40.5t147.5 -113.5q60 -73 81 -168.5t0 -194.5z" />
-<glyph unicode="&#xf137;" d="M909 141l102 102q19 19 19 45t-19 45l-307 307l307 307q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf138;" d="M717 141l454 454q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l307 -307l-307 -307q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf139;" d="M1165 397l102 102q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l307 307l307 -307q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf13a;" d="M813 237l454 454q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-307 -307l-307 307q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf13b;" horiz-adv-x="1408" d="M1130 939l16 175h-884l47 -534h612l-22 -228l-197 -53l-196 53l-13 140h-175l22 -278l362 -100h4v1l359 99l50 544h-644l-15 181h674zM0 1408h1408l-128 -1438l-578 -162l-574 162z" />
-<glyph unicode="&#xf13c;" horiz-adv-x="1792" d="M275 1408h1505l-266 -1333l-804 -267l-698 267l71 356h297l-29 -147l422 -161l486 161l68 339h-1208l58 297h1209l38 191h-1208z" />
-<glyph unicode="&#xf13d;" horiz-adv-x="1792" d="M960 1280q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1792 352v-352q0 -22 -20 -30q-8 -2 -12 -2q-13 0 -23 9l-93 93q-119 -143 -318.5 -226.5t-429.5 -83.5t-429.5 83.5t-318.5 226.5l-93 -93q-9 -9 -23 -9q-4 0 -12 2q-20 8 -20 30v352 q0 14 9 23t23 9h352q22 0 30 -20q8 -19 -7 -35l-100 -100q67 -91 189.5 -153.5t271.5 -82.5v647h-192q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h192v163q-58 34 -93 92.5t-35 128.5q0 106 75 181t181 75t181 -75t75 -181q0 -70 -35 -128.5t-93 -92.5v-163h192q26 0 45 -19 t19 -45v-128q0 -26 -19 -45t-45 -19h-192v-647q149 20 271.5 82.5t189.5 153.5l-100 100q-15 16 -7 35q8 20 30 20h352q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf13e;" horiz-adv-x="1152" d="M1056 768q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v320q0 185 131.5 316.5t316.5 131.5t316.5 -131.5t131.5 -316.5q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45q0 106 -75 181t-181 75t-181 -75t-75 -181 v-320h736z" />
-<glyph unicode="&#xf140;" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM1152 640q0 159 -112.5 271.5t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM1280 640q0 -212 -150 -362t-362 -150t-362 150 t-150 362t150 362t362 150t362 -150t150 -362zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf141;" horiz-adv-x="1408" d="M384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM896 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM1408 800v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf142;" horiz-adv-x="384" d="M384 288v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 1312v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" />
-<glyph unicode="&#xf143;" d="M512 256q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM863 162q-13 232 -177 396t-396 177q-14 1 -24 -9t-10 -23v-128q0 -13 8.5 -22t21.5 -10q154 -11 264 -121t121 -264q1 -13 10 -21.5t22 -8.5h128q13 0 23 10 t9 24zM1247 161q-5 154 -56 297.5t-139.5 260t-205 205t-260 139.5t-297.5 56q-14 1 -23 -9q-10 -10 -10 -23v-128q0 -13 9 -22t22 -10q204 -7 378 -111.5t278.5 -278.5t111.5 -378q1 -13 10 -22t22 -9h128q13 0 23 10q11 9 9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf144;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1152 585q32 18 32 55t-32 55l-544 320q-31 19 -64 1q-32 -19 -32 -56v-640q0 -37 32 -56 q16 -8 32 -8q17 0 32 9z" />
-<glyph unicode="&#xf145;" horiz-adv-x="1792" d="M1024 1084l316 -316l-572 -572l-316 316zM813 105l618 618q19 19 19 45t-19 45l-362 362q-18 18 -45 18t-45 -18l-618 -618q-19 -19 -19 -45t19 -45l362 -362q18 -18 45 -18t45 18zM1702 742l-907 -908q-37 -37 -90.5 -37t-90.5 37l-126 126q56 56 56 136t-56 136 t-136 56t-136 -56l-125 126q-37 37 -37 90.5t37 90.5l907 906q37 37 90.5 37t90.5 -37l125 -125q-56 -56 -56 -136t56 -136t136 -56t136 56l126 -125q37 -37 37 -90.5t-37 -90.5z" />
-<glyph unicode="&#xf146;" d="M1280 576v128q0 26 -19 45t-45 19h-896q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h896q26 0 45 19t19 45zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5 t84.5 -203.5z" />
-<glyph unicode="&#xf147;" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h832q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5 t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf148;" horiz-adv-x="1024" d="M1018 933q-18 -37 -58 -37h-192v-864q0 -14 -9 -23t-23 -9h-704q-21 0 -29 18q-8 20 4 35l160 192q9 11 25 11h320v640h-192q-40 0 -58 37q-17 37 9 68l320 384q18 22 49 22t49 -22l320 -384q27 -32 9 -68z" />
-<glyph unicode="&#xf149;" horiz-adv-x="1024" d="M32 1280h704q13 0 22.5 -9.5t9.5 -23.5v-863h192q40 0 58 -37t-9 -69l-320 -384q-18 -22 -49 -22t-49 22l-320 384q-26 31 -9 69q18 37 58 37h192v640h-320q-14 0 -25 11l-160 192q-13 14 -4 34q9 19 29 19z" />
-<glyph unicode="&#xf14a;" d="M685 237l614 614q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-467 -467l-211 211q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l358 -358q19 -19 45 -19t45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5 t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf14b;" d="M404 428l152 -152l-52 -52h-56v96h-96v56zM818 818q14 -13 -3 -30l-291 -291q-17 -17 -30 -3q-14 13 3 30l291 291q17 17 30 3zM544 128l544 544l-288 288l-544 -544v-288h288zM1152 736l92 92q28 28 28 68t-28 68l-152 152q-28 28 -68 28t-68 -28l-92 -92zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf14c;" d="M1280 608v480q0 26 -19 45t-45 19h-480q-42 0 -59 -39q-17 -41 14 -70l144 -144l-534 -534q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l534 534l144 -144q18 -19 45 -19q12 0 25 5q39 17 39 59zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf14d;" d="M1005 435l352 352q19 19 19 45t-19 45l-352 352q-30 31 -69 14q-40 -17 -40 -59v-160q-119 0 -216 -19.5t-162.5 -51t-114 -79t-76.5 -95.5t-44.5 -109t-21.5 -111.5t-5 -110.5q0 -181 167 -404q10 -12 25 -12q7 0 13 3q22 9 19 33q-44 354 62 473q46 52 130 75.5 t224 23.5v-160q0 -42 40 -59q12 -5 24 -5q26 0 45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf14e;" d="M640 448l256 128l-256 128v-256zM1024 1039v-542l-512 -256v542zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf150;" d="M1145 861q18 -35 -5 -66l-320 -448q-19 -27 -52 -27t-52 27l-320 448q-23 31 -5 66q17 35 57 35h640q40 0 57 -35zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf151;" d="M1145 419q-17 -35 -57 -35h-640q-40 0 -57 35q-18 35 5 66l320 448q19 27 52 27t52 -27l320 -448q23 -31 5 -66zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf152;" d="M1088 640q0 -33 -27 -52l-448 -320q-31 -23 -66 -5q-35 17 -35 57v640q0 40 35 57q35 18 66 -5l448 -320q27 -19 27 -52zM1280 160v960q0 14 -9 23t-23 9h-960q-14 0 -23 -9t-9 -23v-960q0 -14 9 -23t23 -9h960q14 0 23 9t9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf153;" horiz-adv-x="1024" d="M976 229l35 -159q3 -12 -3 -22.5t-17 -14.5l-5 -1q-4 -2 -10.5 -3.5t-16 -4.5t-21.5 -5.5t-25.5 -5t-30 -5t-33.5 -4.5t-36.5 -3t-38.5 -1q-234 0 -409 130.5t-238 351.5h-95q-13 0 -22.5 9.5t-9.5 22.5v113q0 13 9.5 22.5t22.5 9.5h66q-2 57 1 105h-67q-14 0 -23 9 t-9 23v114q0 14 9 23t23 9h98q67 210 243.5 338t400.5 128q102 0 194 -23q11 -3 20 -15q6 -11 3 -24l-43 -159q-3 -13 -14 -19.5t-24 -2.5l-4 1q-4 1 -11.5 2.5l-17.5 3.5t-22.5 3.5t-26 3t-29 2.5t-29.5 1q-126 0 -226 -64t-150 -176h468q16 0 25 -12q10 -12 7 -26 l-24 -114q-5 -26 -32 -26h-488q-3 -37 0 -105h459q15 0 25 -12q9 -12 6 -27l-24 -112q-2 -11 -11 -18.5t-20 -7.5h-387q48 -117 149.5 -185.5t228.5 -68.5q18 0 36 1.5t33.5 3.5t29.5 4.5t24.5 5t18.5 4.5l12 3l5 2q13 5 26 -2q12 -7 15 -21z" />
-<glyph unicode="&#xf154;" horiz-adv-x="1024" d="M1020 399v-367q0 -14 -9 -23t-23 -9h-956q-14 0 -23 9t-9 23v150q0 13 9.5 22.5t22.5 9.5h97v383h-95q-14 0 -23 9.5t-9 22.5v131q0 14 9 23t23 9h95v223q0 171 123.5 282t314.5 111q185 0 335 -125q9 -8 10 -20.5t-7 -22.5l-103 -127q-9 -11 -22 -12q-13 -2 -23 7 q-5 5 -26 19t-69 32t-93 18q-85 0 -137 -47t-52 -123v-215h305q13 0 22.5 -9t9.5 -23v-131q0 -13 -9.5 -22.5t-22.5 -9.5h-305v-379h414v181q0 13 9 22.5t23 9.5h162q14 0 23 -9.5t9 -22.5z" />
-<glyph unicode="&#xf155;" horiz-adv-x="1024" d="M978 351q0 -153 -99.5 -263.5t-258.5 -136.5v-175q0 -14 -9 -23t-23 -9h-135q-13 0 -22.5 9.5t-9.5 22.5v175q-66 9 -127.5 31t-101.5 44.5t-74 48t-46.5 37.5t-17.5 18q-17 21 -2 41l103 135q7 10 23 12q15 2 24 -9l2 -2q113 -99 243 -125q37 -8 74 -8q81 0 142.5 43 t61.5 122q0 28 -15 53t-33.5 42t-58.5 37.5t-66 32t-80 32.5q-39 16 -61.5 25t-61.5 26.5t-62.5 31t-56.5 35.5t-53.5 42.5t-43.5 49t-35.5 58t-21 66.5t-8.5 78q0 138 98 242t255 134v180q0 13 9.5 22.5t22.5 9.5h135q14 0 23 -9t9 -23v-176q57 -6 110.5 -23t87 -33.5 t63.5 -37.5t39 -29t15 -14q17 -18 5 -38l-81 -146q-8 -15 -23 -16q-14 -3 -27 7q-3 3 -14.5 12t-39 26.5t-58.5 32t-74.5 26t-85.5 11.5q-95 0 -155 -43t-60 -111q0 -26 8.5 -48t29.5 -41.5t39.5 -33t56 -31t60.5 -27t70 -27.5q53 -20 81 -31.5t76 -35t75.5 -42.5t62 -50 t53 -63.5t31.5 -76.5t13 -94z" />
-<glyph unicode="&#xf156;" horiz-adv-x="898" d="M898 1066v-102q0 -14 -9 -23t-23 -9h-168q-23 -144 -129 -234t-276 -110q167 -178 459 -536q14 -16 4 -34q-8 -18 -29 -18h-195q-16 0 -25 12q-306 367 -498 571q-9 9 -9 22v127q0 13 9.5 22.5t22.5 9.5h112q132 0 212.5 43t102.5 125h-427q-14 0 -23 9t-9 23v102 q0 14 9 23t23 9h413q-57 113 -268 113h-145q-13 0 -22.5 9.5t-9.5 22.5v133q0 14 9 23t23 9h832q14 0 23 -9t9 -23v-102q0 -14 -9 -23t-23 -9h-233q47 -61 64 -144h171q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf157;" horiz-adv-x="1027" d="M603 0h-172q-13 0 -22.5 9t-9.5 23v330h-288q-13 0 -22.5 9t-9.5 23v103q0 13 9.5 22.5t22.5 9.5h288v85h-288q-13 0 -22.5 9t-9.5 23v104q0 13 9.5 22.5t22.5 9.5h214l-321 578q-8 16 0 32q10 16 28 16h194q19 0 29 -18l215 -425q19 -38 56 -125q10 24 30.5 68t27.5 61 l191 420q8 19 29 19h191q17 0 27 -16q9 -14 1 -31l-313 -579h215q13 0 22.5 -9.5t9.5 -22.5v-104q0 -14 -9.5 -23t-22.5 -9h-290v-85h290q13 0 22.5 -9.5t9.5 -22.5v-103q0 -14 -9.5 -23t-22.5 -9h-290v-330q0 -13 -9.5 -22.5t-22.5 -9.5z" />
-<glyph unicode="&#xf158;" horiz-adv-x="1280" d="M1043 971q0 100 -65 162t-171 62h-320v-448h320q106 0 171 62t65 162zM1280 971q0 -193 -126.5 -315t-326.5 -122h-340v-118h505q14 0 23 -9t9 -23v-128q0 -14 -9 -23t-23 -9h-505v-192q0 -14 -9.5 -23t-22.5 -9h-167q-14 0 -23 9t-9 23v192h-224q-14 0 -23 9t-9 23v128 q0 14 9 23t23 9h224v118h-224q-14 0 -23 9t-9 23v149q0 13 9 22.5t23 9.5h224v629q0 14 9 23t23 9h539q200 0 326.5 -122t126.5 -315z" />
-<glyph unicode="&#xf159;" horiz-adv-x="1792" d="M514 341l81 299h-159l75 -300q1 -1 1 -3t1 -3q0 1 0.5 3.5t0.5 3.5zM630 768l35 128h-292l32 -128h225zM822 768h139l-35 128h-70zM1271 340l78 300h-162l81 -299q0 -1 0.5 -3.5t1.5 -3.5q0 1 0.5 3t0.5 3zM1382 768l33 128h-297l34 -128h230zM1792 736v-64q0 -14 -9 -23 t-23 -9h-213l-164 -616q-7 -24 -31 -24h-159q-24 0 -31 24l-166 616h-209l-167 -616q-7 -24 -31 -24h-159q-11 0 -19.5 7t-10.5 17l-160 616h-208q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h175l-33 128h-142q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h109l-89 344q-5 15 5 28 q10 12 26 12h137q26 0 31 -24l90 -360h359l97 360q7 24 31 24h126q24 0 31 -24l98 -360h365l93 360q5 24 31 24h137q16 0 26 -12q10 -13 5 -28l-91 -344h111q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-145l-34 -128h179q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf15a;" horiz-adv-x="1280" d="M1167 896q18 -182 -131 -258q117 -28 175 -103t45 -214q-7 -71 -32.5 -125t-64.5 -89t-97 -58.5t-121.5 -34.5t-145.5 -15v-255h-154v251q-80 0 -122 1v-252h-154v255q-18 0 -54 0.5t-55 0.5h-200l31 183h111q50 0 58 51v402h16q-6 1 -16 1v287q-13 68 -89 68h-111v164 l212 -1q64 0 97 1v252h154v-247q82 2 122 2v245h154v-252q79 -7 140 -22.5t113 -45t82.5 -78t36.5 -114.5zM952 351q0 36 -15 64t-37 46t-57.5 30.5t-65.5 18.5t-74 9t-69 3t-64.5 -1t-47.5 -1v-338q8 0 37 -0.5t48 -0.5t53 1.5t58.5 4t57 8.5t55.5 14t47.5 21t39.5 30 t24.5 40t9.5 51zM881 827q0 33 -12.5 58.5t-30.5 42t-48 28t-55 16.5t-61.5 8t-58 2.5t-54 -1t-39.5 -0.5v-307q5 0 34.5 -0.5t46.5 0t50 2t55 5.5t51.5 11t48.5 18.5t37 27t27 38.5t9 51z" />
-<glyph unicode="&#xf15b;" horiz-adv-x="1280" d="M1280 768v-800q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h544v-544q0 -40 28 -68t68 -28h544zM1277 896h-509v509q82 -15 132 -65l312 -312q50 -50 65 -132z" />
-<glyph unicode="&#xf15c;" horiz-adv-x="1280" d="M1024 160v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23zM1024 416v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23zM1280 768v-800q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28 t-28 68v1344q0 40 28 68t68 28h544v-544q0 -40 28 -68t68 -28h544zM1277 896h-509v509q82 -15 132 -65l312 -312q50 -50 65 -132z" />
-<glyph unicode="&#xf15d;" horiz-adv-x="1664" d="M1191 1128h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1572 -23 v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -11v-2l14 2q9 2 30 2h248v119h121zM1661 874v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162 l230 -662h70z" />
-<glyph unicode="&#xf15e;" horiz-adv-x="1664" d="M1191 104h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1661 -150 v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162l230 -662h70zM1572 1001v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -10v-3l14 3q9 1 30 1h248 v119h121z" />
-<glyph unicode="&#xf160;" horiz-adv-x="1792" d="M736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1792 -32v-192q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832 q14 0 23 -9t9 -23zM1600 480v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1408 992v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1216 1504v-192q0 -14 -9 -23t-23 -9h-256 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf161;" horiz-adv-x="1792" d="M1216 -32v-192q0 -14 -9 -23t-23 -9h-256q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192 q14 0 23 -9t9 -23zM1408 480v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1600 992v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1792 1504v-192q0 -14 -9 -23t-23 -9h-832 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf162;" d="M1346 223q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23 zM1486 165q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5 t82 -252.5zM1456 882v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165z" />
-<glyph unicode="&#xf163;" d="M1346 1247q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9 t9 -23zM1456 -142v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165zM1486 1189q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13 q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5t82 -252.5z" />
-<glyph unicode="&#xf164;" horiz-adv-x="1664" d="M256 192q0 26 -19 45t-45 19q-27 0 -45.5 -19t-18.5 -45q0 -27 18.5 -45.5t45.5 -18.5q26 0 45 18.5t19 45.5zM416 704v-640q0 -26 -19 -45t-45 -19h-288q-26 0 -45 19t-19 45v640q0 26 19 45t45 19h288q26 0 45 -19t19 -45zM1600 704q0 -86 -55 -149q15 -44 15 -76 q3 -76 -43 -137q17 -56 0 -117q-15 -57 -54 -94q9 -112 -49 -181q-64 -76 -197 -78h-36h-76h-17q-66 0 -144 15.5t-121.5 29t-120.5 39.5q-123 43 -158 44q-26 1 -45 19.5t-19 44.5v641q0 25 18 43.5t43 20.5q24 2 76 59t101 121q68 87 101 120q18 18 31 48t17.5 48.5 t13.5 60.5q7 39 12.5 61t19.5 52t34 50q19 19 45 19q46 0 82.5 -10.5t60 -26t40 -40.5t24 -45t12 -50t5 -45t0.5 -39q0 -38 -9.5 -76t-19 -60t-27.5 -56q-3 -6 -10 -18t-11 -22t-8 -24h277q78 0 135 -57t57 -135z" />
-<glyph unicode="&#xf165;" horiz-adv-x="1664" d="M256 960q0 -26 -19 -45t-45 -19q-27 0 -45.5 19t-18.5 45q0 27 18.5 45.5t45.5 18.5q26 0 45 -18.5t19 -45.5zM416 448v640q0 26 -19 45t-45 19h-288q-26 0 -45 -19t-19 -45v-640q0 -26 19 -45t45 -19h288q26 0 45 19t19 45zM1545 597q55 -61 55 -149q-1 -78 -57.5 -135 t-134.5 -57h-277q4 -14 8 -24t11 -22t10 -18q18 -37 27 -57t19 -58.5t10 -76.5q0 -24 -0.5 -39t-5 -45t-12 -50t-24 -45t-40 -40.5t-60 -26t-82.5 -10.5q-26 0 -45 19q-20 20 -34 50t-19.5 52t-12.5 61q-9 42 -13.5 60.5t-17.5 48.5t-31 48q-33 33 -101 120q-49 64 -101 121 t-76 59q-25 2 -43 20.5t-18 43.5v641q0 26 19 44.5t45 19.5q35 1 158 44q77 26 120.5 39.5t121.5 29t144 15.5h17h76h36q133 -2 197 -78q58 -69 49 -181q39 -37 54 -94q17 -61 0 -117q46 -61 43 -137q0 -32 -15 -76z" />
-<glyph unicode="&#xf166;" d="M919 233v157q0 50 -29 50q-17 0 -33 -16v-224q16 -16 33 -16q29 0 29 49zM1103 355h66v34q0 51 -33 51t-33 -51v-34zM532 621v-70h-80v-423h-74v423h-78v70h232zM733 495v-367h-67v40q-39 -45 -76 -45q-33 0 -42 28q-6 16 -6 54v290h66v-270q0 -24 1 -26q1 -15 15 -15 q20 0 42 31v280h67zM985 384v-146q0 -52 -7 -73q-12 -42 -53 -42q-35 0 -68 41v-36h-67v493h67v-161q32 40 68 40q41 0 53 -42q7 -21 7 -74zM1236 255v-9q0 -29 -2 -43q-3 -22 -15 -40q-27 -40 -80 -40q-52 0 -81 38q-21 27 -21 86v129q0 59 20 86q29 38 80 38t78 -38 q21 -28 21 -86v-76h-133v-65q0 -51 34 -51q24 0 30 26q0 1 0.5 7t0.5 16.5v21.5h68zM785 1079v-156q0 -51 -32 -51t-32 51v156q0 52 32 52t32 -52zM1318 366q0 177 -19 260q-10 44 -43 73.5t-76 34.5q-136 15 -412 15q-275 0 -411 -15q-44 -5 -76.5 -34.5t-42.5 -73.5 q-20 -87 -20 -260q0 -176 20 -260q10 -43 42.5 -73t75.5 -35q137 -15 412 -15t412 15q43 5 75.5 35t42.5 73q20 84 20 260zM563 1017l90 296h-75l-51 -195l-53 195h-78l24 -69t23 -69q35 -103 46 -158v-201h74v201zM852 936v130q0 58 -21 87q-29 38 -78 38q-51 0 -78 -38 q-21 -29 -21 -87v-130q0 -58 21 -87q27 -38 78 -38q49 0 78 38q21 27 21 87zM1033 816h67v370h-67v-283q-22 -31 -42 -31q-15 0 -16 16q-1 2 -1 26v272h-67v-293q0 -37 6 -55q11 -27 43 -27q36 0 77 45v-40zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf167;" d="M971 292v-211q0 -67 -39 -67q-23 0 -45 22v301q22 22 45 22q39 0 39 -67zM1309 291v-46h-90v46q0 68 45 68t45 -68zM343 509h107v94h-312v-94h105v-569h100v569zM631 -60h89v494h-89v-378q-30 -42 -57 -42q-18 0 -21 21q-1 3 -1 35v364h-89v-391q0 -49 8 -73 q12 -37 58 -37q48 0 102 61v-54zM1060 88v197q0 73 -9 99q-17 56 -71 56q-50 0 -93 -54v217h-89v-663h89v48q45 -55 93 -55q54 0 71 55q9 27 9 100zM1398 98v13h-91q0 -51 -2 -61q-7 -36 -40 -36q-46 0 -46 69v87h179v103q0 79 -27 116q-39 51 -106 51q-68 0 -107 -51 q-28 -37 -28 -116v-173q0 -79 29 -116q39 -51 108 -51q72 0 108 53q18 27 21 54q2 9 2 58zM790 1011v210q0 69 -43 69t-43 -69v-210q0 -70 43 -70t43 70zM1509 260q0 -234 -26 -350q-14 -59 -58 -99t-102 -46q-184 -21 -555 -21t-555 21q-58 6 -102.5 46t-57.5 99 q-26 112 -26 350q0 234 26 350q14 59 58 99t103 47q183 20 554 20t555 -20q58 -7 102.5 -47t57.5 -99q26 -112 26 -350zM511 1536h102l-121 -399v-271h-100v271q-14 74 -61 212q-37 103 -65 187h106l71 -263zM881 1203v-175q0 -81 -28 -118q-37 -51 -106 -51q-67 0 -105 51 q-28 38 -28 118v175q0 80 28 117q38 51 105 51q69 0 106 -51q28 -37 28 -117zM1216 1365v-499h-91v55q-53 -62 -103 -62q-46 0 -59 37q-8 24 -8 75v394h91v-367q0 -33 1 -35q3 -22 21 -22q27 0 57 43v381h91z" />
-<glyph unicode="&#xf168;" horiz-adv-x="1408" d="M597 869q-10 -18 -257 -456q-27 -46 -65 -46h-239q-21 0 -31 17t0 36l253 448q1 0 0 1l-161 279q-12 22 -1 37q9 15 32 15h239q40 0 66 -45zM1403 1511q11 -16 0 -37l-528 -934v-1l336 -615q11 -20 1 -37q-10 -15 -32 -15h-239q-42 0 -66 45l-339 622q18 32 531 942 q25 45 64 45h241q22 0 31 -15z" />
-<glyph unicode="&#xf169;" d="M685 771q0 1 -126 222q-21 34 -52 34h-184q-18 0 -26 -11q-7 -12 1 -29l125 -216v-1l-196 -346q-9 -14 0 -28q8 -13 24 -13h185q31 0 50 36zM1309 1268q-7 12 -24 12h-187q-30 0 -49 -35l-411 -729q1 -2 262 -481q20 -35 52 -35h184q18 0 25 12q8 13 -1 28l-260 476v1 l409 723q8 16 0 28zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf16a;" horiz-adv-x="1792" d="M1280 640q0 37 -30 54l-512 320q-31 20 -65 2q-33 -18 -33 -56v-640q0 -38 33 -56q16 -8 31 -8q20 0 34 10l512 320q30 17 30 54zM1792 640q0 -96 -1 -150t-8.5 -136.5t-22.5 -147.5q-16 -73 -69 -123t-124 -58q-222 -25 -671 -25t-671 25q-71 8 -124.5 58t-69.5 123 q-14 65 -21.5 147.5t-8.5 136.5t-1 150t1 150t8.5 136.5t22.5 147.5q16 73 69 123t124 58q222 25 671 25t671 -25q71 -8 124.5 -58t69.5 -123q14 -65 21.5 -147.5t8.5 -136.5t1 -150z" />
-<glyph unicode="&#xf16b;" horiz-adv-x="1792" d="M402 829l494 -305l-342 -285l-490 319zM1388 274v-108l-490 -293v-1l-1 1l-1 -1v1l-489 293v108l147 -96l342 284v2l1 -1l1 1v-2l343 -284zM554 1418l342 -285l-494 -304l-338 270zM1390 829l338 -271l-489 -319l-343 285zM1239 1418l489 -319l-338 -270l-494 304z" />
-<glyph unicode="&#xf16c;" horiz-adv-x="1408" d="M928 135v-151l-707 -1v151zM1169 481v-701l-1 -35v-1h-1132l-35 1h-1v736h121v-618h928v618h120zM241 393l704 -65l-13 -150l-705 65zM309 709l683 -183l-39 -146l-683 183zM472 1058l609 -360l-77 -130l-609 360zM832 1389l398 -585l-124 -85l-399 584zM1285 1536 l121 -697l-149 -26l-121 697z" />
-<glyph unicode="&#xf16d;" d="M1362 110v648h-135q20 -63 20 -131q0 -126 -64 -232.5t-174 -168.5t-240 -62q-197 0 -337 135.5t-140 327.5q0 68 20 131h-141v-648q0 -26 17.5 -43.5t43.5 -17.5h1069q25 0 43 17.5t18 43.5zM1078 643q0 124 -90.5 211.5t-218.5 87.5q-127 0 -217.5 -87.5t-90.5 -211.5 t90.5 -211.5t217.5 -87.5q128 0 218.5 87.5t90.5 211.5zM1362 1003v165q0 28 -20 48.5t-49 20.5h-174q-29 0 -49 -20.5t-20 -48.5v-165q0 -29 20 -49t49 -20h174q29 0 49 20t20 49zM1536 1211v-1142q0 -81 -58 -139t-139 -58h-1142q-81 0 -139 58t-58 139v1142q0 81 58 139 t139 58h1142q81 0 139 -58t58 -139z" />
-<glyph unicode="&#xf16e;" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960zM698 640q0 88 -62 150t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150zM1262 640q0 88 -62 150 t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150z" />
-<glyph unicode="&#xf170;" d="M768 914l201 -306h-402zM1133 384h94l-459 691l-459 -691h94l104 160h522zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf171;" horiz-adv-x="1408" d="M815 677q8 -63 -50.5 -101t-111.5 -6q-39 17 -53.5 58t-0.5 82t52 58q36 18 72.5 12t64 -35.5t27.5 -67.5zM926 698q-14 107 -113 164t-197 13q-63 -28 -100.5 -88.5t-34.5 -129.5q4 -91 77.5 -155t165.5 -56q91 8 152 84t50 168zM1165 1240q-20 27 -56 44.5t-58 22 t-71 12.5q-291 47 -566 -2q-43 -7 -66 -12t-55 -22t-50 -43q30 -28 76 -45.5t73.5 -22t87.5 -11.5q228 -29 448 -1q63 8 89.5 12t72.5 21.5t75 46.5zM1222 205q-8 -26 -15.5 -76.5t-14 -84t-28.5 -70t-58 -56.5q-86 -48 -189.5 -71.5t-202 -22t-201.5 18.5q-46 8 -81.5 18 t-76.5 27t-73 43.5t-52 61.5q-25 96 -57 292l6 16l18 9q223 -148 506.5 -148t507.5 148q21 -6 24 -23t-5 -45t-8 -37zM1403 1166q-26 -167 -111 -655q-5 -30 -27 -56t-43.5 -40t-54.5 -31q-252 -126 -610 -88q-248 27 -394 139q-15 12 -25.5 26.5t-17 35t-9 34t-6 39.5 t-5.5 35q-9 50 -26.5 150t-28 161.5t-23.5 147.5t-22 158q3 26 17.5 48.5t31.5 37.5t45 30t46 22.5t48 18.5q125 46 313 64q379 37 676 -50q155 -46 215 -122q16 -20 16.5 -51t-5.5 -54z" />
-<glyph unicode="&#xf172;" d="M848 666q0 43 -41 66t-77 1q-43 -20 -42.5 -72.5t43.5 -70.5q39 -23 81 4t36 72zM928 682q8 -66 -36 -121t-110 -61t-119 40t-56 113q-2 49 25.5 93t72.5 64q70 31 141.5 -10t81.5 -118zM1100 1073q-20 -21 -53.5 -34t-53 -16t-63.5 -8q-155 -20 -324 0q-44 6 -63 9.5 t-52.5 16t-54.5 32.5q13 19 36 31t40 15.5t47 8.5q198 35 408 1q33 -5 51 -8.5t43 -16t39 -31.5zM1142 327q0 7 5.5 26.5t3 32t-17.5 16.5q-161 -106 -365 -106t-366 106l-12 -6l-5 -12q26 -154 41 -210q47 -81 204 -108q249 -46 428 53q34 19 49 51.5t22.5 85.5t12.5 71z M1272 1020q9 53 -8 75q-43 55 -155 88q-216 63 -487 36q-132 -12 -226 -46q-38 -15 -59.5 -25t-47 -34t-29.5 -54q8 -68 19 -138t29 -171t24 -137q1 -5 5 -31t7 -36t12 -27t22 -28q105 -80 284 -100q259 -28 440 63q24 13 39.5 23t31 29t19.5 40q48 267 80 473zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf173;" horiz-adv-x="1024" d="M390 1408h219v-388h364v-241h-364v-394q0 -136 14 -172q13 -37 52 -60q50 -31 117 -31q117 0 232 76v-242q-102 -48 -178 -65q-77 -19 -173 -19q-105 0 -186 27q-78 25 -138 75q-58 51 -79 105q-22 54 -22 161v539h-170v217q91 30 155 84q64 55 103 132q39 78 54 196z " />
-<glyph unicode="&#xf174;" d="M1123 127v181q-88 -56 -174 -56q-51 0 -88 23q-29 17 -39 45q-11 30 -11 129v295h274v181h-274v291h-164q-11 -90 -40 -147t-78 -99q-48 -40 -116 -63v-163h127v-404q0 -78 17 -121q17 -42 59 -78q43 -37 104 -57q62 -20 140 -20q67 0 129 14q57 13 134 49zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf175;" horiz-adv-x="768" d="M765 237q8 -19 -5 -35l-350 -384q-10 -10 -23 -10q-14 0 -24 10l-355 384q-13 16 -5 35q9 19 29 19h224v1248q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1248h224q21 0 29 -19z" />
-<glyph unicode="&#xf176;" horiz-adv-x="768" d="M765 1043q-9 -19 -29 -19h-224v-1248q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1248h-224q-21 0 -29 19t5 35l350 384q10 10 23 10q14 0 24 -10l355 -384q13 -16 5 -35z" />
-<glyph unicode="&#xf177;" horiz-adv-x="1792" d="M1792 736v-192q0 -14 -9 -23t-23 -9h-1248v-224q0 -21 -19 -29t-35 5l-384 350q-10 10 -10 23q0 14 10 24l384 354q16 14 35 6q19 -9 19 -29v-224h1248q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf178;" horiz-adv-x="1792" d="M1728 643q0 -14 -10 -24l-384 -354q-16 -14 -35 -6q-19 9 -19 29v224h-1248q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h1248v224q0 21 19 29t35 -5l384 -350q10 -10 10 -23z" />
-<glyph unicode="&#xf179;" horiz-adv-x="1408" d="M1393 321q-39 -125 -123 -250q-129 -196 -257 -196q-49 0 -140 32q-86 32 -151 32q-61 0 -142 -33q-81 -34 -132 -34q-152 0 -301 259q-147 261 -147 503q0 228 113 374q112 144 284 144q72 0 177 -30q104 -30 138 -30q45 0 143 34q102 34 173 34q119 0 213 -65 q52 -36 104 -100q-79 -67 -114 -118q-65 -94 -65 -207q0 -124 69 -223t158 -126zM1017 1494q0 -61 -29 -136q-30 -75 -93 -138q-54 -54 -108 -72q-37 -11 -104 -17q3 149 78 257q74 107 250 148q1 -3 2.5 -11t2.5 -11q0 -4 0.5 -10t0.5 -10z" />
-<glyph unicode="&#xf17a;" horiz-adv-x="1664" d="M682 530v-651l-682 94v557h682zM682 1273v-659h-682v565zM1664 530v-786l-907 125v661h907zM1664 1408v-794h-907v669z" />
-<glyph unicode="&#xf17b;" horiz-adv-x="1408" d="M493 1053q16 0 27.5 11.5t11.5 27.5t-11.5 27.5t-27.5 11.5t-27 -11.5t-11 -27.5t11 -27.5t27 -11.5zM915 1053q16 0 27 11.5t11 27.5t-11 27.5t-27 11.5t-27.5 -11.5t-11.5 -27.5t11.5 -27.5t27.5 -11.5zM103 869q42 0 72 -30t30 -72v-430q0 -43 -29.5 -73t-72.5 -30 t-73 30t-30 73v430q0 42 30 72t73 30zM1163 850v-666q0 -46 -32 -78t-77 -32h-75v-227q0 -43 -30 -73t-73 -30t-73 30t-30 73v227h-138v-227q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73l-1 227h-74q-46 0 -78 32t-32 78v666h918zM931 1255q107 -55 171 -153.5t64 -215.5 h-925q0 117 64 215.5t172 153.5l-71 131q-7 13 5 20q13 6 20 -6l72 -132q95 42 201 42t201 -42l72 132q7 12 20 6q12 -7 5 -20zM1408 767v-430q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73v430q0 43 30 72.5t72 29.5q43 0 73 -29.5t30 -72.5z" />
-<glyph unicode="&#xf17c;" d="M663 1125q-11 -1 -15.5 -10.5t-8.5 -9.5q-5 -1 -5 5q0 12 19 15h10zM750 1111q-4 -1 -11.5 6.5t-17.5 4.5q24 11 32 -2q3 -6 -3 -9zM399 684q-4 1 -6 -3t-4.5 -12.5t-5.5 -13.5t-10 -13q-7 -10 -1 -12q4 -1 12.5 7t12.5 18q1 3 2 7t2 6t1.5 4.5t0.5 4v3t-1 2.5t-3 2z M1254 325q0 18 -55 42q4 15 7.5 27.5t5 26t3 21.5t0.5 22.5t-1 19.5t-3.5 22t-4 20.5t-5 25t-5.5 26.5q-10 48 -47 103t-72 75q24 -20 57 -83q87 -162 54 -278q-11 -40 -50 -42q-31 -4 -38.5 18.5t-8 83.5t-11.5 107q-9 39 -19.5 69t-19.5 45.5t-15.5 24.5t-13 15t-7.5 7 q-14 62 -31 103t-29.5 56t-23.5 33t-15 40q-4 21 6 53.5t4.5 49.5t-44.5 25q-15 3 -44.5 18t-35.5 16q-8 1 -11 26t8 51t36 27q37 3 51 -30t4 -58q-11 -19 -2 -26.5t30 -0.5q13 4 13 36v37q-5 30 -13.5 50t-21 30.5t-23.5 15t-27 7.5q-107 -8 -89 -134q0 -15 -1 -15 q-9 9 -29.5 10.5t-33 -0.5t-15.5 5q1 57 -16 90t-45 34q-27 1 -41.5 -27.5t-16.5 -59.5q-1 -15 3.5 -37t13 -37.5t15.5 -13.5q10 3 16 14q4 9 -7 8q-7 0 -15.5 14.5t-9.5 33.5q-1 22 9 37t34 14q17 0 27 -21t9.5 -39t-1.5 -22q-22 -15 -31 -29q-8 -12 -27.5 -23.5 t-20.5 -12.5q-13 -14 -15.5 -27t7.5 -18q14 -8 25 -19.5t16 -19t18.5 -13t35.5 -6.5q47 -2 102 15q2 1 23 7t34.5 10.5t29.5 13t21 17.5q9 14 20 8q5 -3 6.5 -8.5t-3 -12t-16.5 -9.5q-20 -6 -56.5 -21.5t-45.5 -19.5q-44 -19 -70 -23q-25 -5 -79 2q-10 2 -9 -2t17 -19 q25 -23 67 -22q17 1 36 7t36 14t33.5 17.5t30 17t24.5 12t17.5 2.5t8.5 -11q0 -2 -1 -4.5t-4 -5t-6 -4.5t-8.5 -5t-9 -4.5t-10 -5t-9.5 -4.5q-28 -14 -67.5 -44t-66.5 -43t-49 -1q-21 11 -63 73q-22 31 -25 22q-1 -3 -1 -10q0 -25 -15 -56.5t-29.5 -55.5t-21 -58t11.5 -63 q-23 -6 -62.5 -90t-47.5 -141q-2 -18 -1.5 -69t-5.5 -59q-8 -24 -29 -3q-32 31 -36 94q-2 28 4 56q4 19 -1 18l-4 -5q-36 -65 10 -166q5 -12 25 -28t24 -20q20 -23 104 -90.5t93 -76.5q16 -15 17.5 -38t-14 -43t-45.5 -23q8 -15 29 -44.5t28 -54t7 -70.5q46 24 7 92 q-4 8 -10.5 16t-9.5 12t-2 6q3 5 13 9.5t20 -2.5q46 -52 166 -36q133 15 177 87q23 38 34 30q12 -6 10 -52q-1 -25 -23 -92q-9 -23 -6 -37.5t24 -15.5q3 19 14.5 77t13.5 90q2 21 -6.5 73.5t-7.5 97t23 70.5q15 18 51 18q1 37 34.5 53t72.5 10.5t60 -22.5zM626 1152 q3 17 -2.5 30t-11.5 15q-9 2 -9 -7q2 -5 5 -6q10 0 7 -15q-3 -20 8 -20q3 0 3 3zM1045 955q-2 8 -6.5 11.5t-13 5t-14.5 5.5q-5 3 -9.5 8t-7 8t-5.5 6.5t-4 4t-4 -1.5q-14 -16 7 -43.5t39 -31.5q9 -1 14.5 8t3.5 20zM867 1168q0 11 -5 19.5t-11 12.5t-9 3q-14 -1 -7 -7l4 -2 q14 -4 18 -31q0 -3 8 2zM921 1401q0 2 -2.5 5t-9 7t-9.5 6q-15 15 -24 15q-9 -1 -11.5 -7.5t-1 -13t-0.5 -12.5q-1 -4 -6 -10.5t-6 -9t3 -8.5q4 -3 8 0t11 9t15 9q1 1 9 1t15 2t9 7zM1486 60q20 -12 31 -24.5t12 -24t-2.5 -22.5t-15.5 -22t-23.5 -19.5t-30 -18.5 t-31.5 -16.5t-32 -15.5t-27 -13q-38 -19 -85.5 -56t-75.5 -64q-17 -16 -68 -19.5t-89 14.5q-18 9 -29.5 23.5t-16.5 25.5t-22 19.5t-47 9.5q-44 1 -130 1q-19 0 -57 -1.5t-58 -2.5q-44 -1 -79.5 -15t-53.5 -30t-43.5 -28.5t-53.5 -11.5q-29 1 -111 31t-146 43q-19 4 -51 9.5 t-50 9t-39.5 9.5t-33.5 14.5t-17 19.5q-10 23 7 66.5t18 54.5q1 16 -4 40t-10 42.5t-4.5 36.5t10.5 27q14 12 57 14t60 12q30 18 42 35t12 51q21 -73 -32 -106q-32 -20 -83 -15q-34 3 -43 -10q-13 -15 5 -57q2 -6 8 -18t8.5 -18t4.5 -17t1 -22q0 -15 -17 -49t-14 -48 q3 -17 37 -26q20 -6 84.5 -18.5t99.5 -20.5q24 -6 74 -22t82.5 -23t55.5 -4q43 6 64.5 28t23 48t-7.5 58.5t-19 52t-20 36.5q-121 190 -169 242q-68 74 -113 40q-11 -9 -15 15q-3 16 -2 38q1 29 10 52t24 47t22 42q8 21 26.5 72t29.5 78t30 61t39 54q110 143 124 195 q-12 112 -16 310q-2 90 24 151.5t106 104.5q39 21 104 21q53 1 106 -13.5t89 -41.5q57 -42 91.5 -121.5t29.5 -147.5q-5 -95 30 -214q34 -113 133 -218q55 -59 99.5 -163t59.5 -191q8 -49 5 -84.5t-12 -55.5t-20 -22q-10 -2 -23.5 -19t-27 -35.5t-40.5 -33.5t-61 -14 q-18 1 -31.5 5t-22.5 13.5t-13.5 15.5t-11.5 20.5t-9 19.5q-22 37 -41 30t-28 -49t7 -97q20 -70 1 -195q-10 -65 18 -100.5t73 -33t85 35.5q59 49 89.5 66.5t103.5 42.5q53 18 77 36.5t18.5 34.5t-25 28.5t-51.5 23.5q-33 11 -49.5 48t-15 72.5t15.5 47.5q1 -31 8 -56.5 t14.5 -40.5t20.5 -28.5t21 -19t21.5 -13t16.5 -9.5z" />
-<glyph unicode="&#xf17d;" d="M1024 36q-42 241 -140 498h-2l-2 -1q-16 -6 -43 -16.5t-101 -49t-137 -82t-131 -114.5t-103 -148l-15 11q184 -150 418 -150q132 0 256 52zM839 643q-21 49 -53 111q-311 -93 -673 -93q-1 -7 -1 -21q0 -124 44 -236.5t124 -201.5q50 89 123.5 166.5t142.5 124.5t130.5 81 t99.5 48l37 13q4 1 13 3.5t13 4.5zM732 855q-120 213 -244 378q-138 -65 -234 -186t-128 -272q302 0 606 80zM1416 536q-210 60 -409 29q87 -239 128 -469q111 75 185 189.5t96 250.5zM611 1277q-1 0 -2 -1q1 1 2 1zM1201 1132q-185 164 -433 164q-76 0 -155 -19 q131 -170 246 -382q69 26 130 60.5t96.5 61.5t65.5 57t37.5 40.5zM1424 647q-3 232 -149 410l-1 -1q-9 -12 -19 -24.5t-43.5 -44.5t-71 -60.5t-100 -65t-131.5 -64.5q25 -53 44 -95q2 -6 6.5 -17.5t7.5 -16.5q36 5 74.5 7t73.5 2t69 -1.5t64 -4t56.5 -5.5t48 -6.5t36.5 -6 t25 -4.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf17e;" d="M1173 473q0 50 -19.5 91.5t-48.5 68.5t-73 49t-82.5 34t-87.5 23l-104 24q-30 7 -44 10.5t-35 11.5t-30 16t-16.5 21t-7.5 30q0 77 144 77q43 0 77 -12t54 -28.5t38 -33.5t40 -29t48 -12q47 0 75.5 32t28.5 77q0 55 -56 99.5t-142 67.5t-182 23q-68 0 -132 -15.5 t-119.5 -47t-89 -87t-33.5 -128.5q0 -61 19 -106.5t56 -75.5t80 -48.5t103 -32.5l146 -36q90 -22 112 -36q32 -20 32 -60q0 -39 -40 -64.5t-105 -25.5q-51 0 -91.5 16t-65 38.5t-45.5 45t-46 38.5t-54 16q-50 0 -75.5 -30t-25.5 -75q0 -92 122 -157.5t291 -65.5 q73 0 140 18.5t122.5 53.5t88.5 93.5t33 131.5zM1536 256q0 -159 -112.5 -271.5t-271.5 -112.5q-130 0 -234 80q-77 -16 -150 -16q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5q0 73 16 150q-80 104 -80 234q0 159 112.5 271.5t271.5 112.5q130 0 234 -80 q77 16 150 16q143 0 273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -73 -16 -150q80 -104 80 -234z" />
-<glyph unicode="&#xf180;" horiz-adv-x="1664" d="M1483 512l-587 -587q-52 -53 -127.5 -53t-128.5 53l-587 587q-53 53 -53 128t53 128l587 587q53 53 128 53t128 -53l265 -265l-398 -399l-188 188q-42 42 -99 42q-59 0 -100 -41l-120 -121q-42 -40 -42 -99q0 -58 42 -100l406 -408q30 -28 67 -37l6 -4h28q60 0 99 41 l619 619l2 -3q53 -53 53 -128t-53 -128zM1406 1138l120 -120q14 -15 14 -36t-14 -36l-730 -730q-17 -15 -37 -15v0q-4 0 -6 1q-18 2 -30 14l-407 408q-14 15 -14 36t14 35l121 120q13 15 35 15t36 -15l252 -252l574 575q15 15 36 15t36 -15z" />
-<glyph unicode="&#xf181;" d="M704 192v1024q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-1024q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1376 576v640q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-640q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408 q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf182;" horiz-adv-x="1280" d="M1280 480q0 -40 -28 -68t-68 -28q-51 0 -80 43l-227 341h-45v-132l247 -411q9 -15 9 -33q0 -26 -19 -45t-45 -19h-192v-272q0 -46 -33 -79t-79 -33h-160q-46 0 -79 33t-33 79v272h-192q-26 0 -45 19t-19 45q0 18 9 33l247 411v132h-45l-227 -341q-29 -43 -80 -43 q-40 0 -68 28t-28 68q0 29 16 53l256 384q73 107 176 107h384q103 0 176 -107l256 -384q16 -24 16 -53zM864 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" />
-<glyph unicode="&#xf183;" horiz-adv-x="1024" d="M1024 832v-416q0 -40 -28 -68t-68 -28t-68 28t-28 68v352h-64v-912q0 -46 -33 -79t-79 -33t-79 33t-33 79v464h-64v-464q0 -46 -33 -79t-79 -33t-79 33t-33 79v912h-64v-352q0 -40 -28 -68t-68 -28t-68 28t-28 68v416q0 80 56 136t136 56h640q80 0 136 -56t56 -136z M736 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" />
-<glyph unicode="&#xf184;" d="M773 234l350 473q16 22 24.5 59t-6 85t-61.5 79q-40 26 -83 25.5t-73.5 -17.5t-54.5 -45q-36 -40 -96 -40q-59 0 -95 40q-24 28 -54.5 45t-73.5 17.5t-84 -25.5q-46 -31 -60.5 -79t-6 -85t24.5 -59zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf185;" horiz-adv-x="1792" d="M1472 640q0 117 -45.5 223.5t-123 184t-184 123t-223.5 45.5t-223.5 -45.5t-184 -123t-123 -184t-45.5 -223.5t45.5 -223.5t123 -184t184 -123t223.5 -45.5t223.5 45.5t184 123t123 184t45.5 223.5zM1748 363q-4 -15 -20 -20l-292 -96v-306q0 -16 -13 -26q-15 -10 -29 -4 l-292 94l-180 -248q-10 -13 -26 -13t-26 13l-180 248l-292 -94q-14 -6 -29 4q-13 10 -13 26v306l-292 96q-16 5 -20 20q-5 17 4 29l180 248l-180 248q-9 13 -4 29q4 15 20 20l292 96v306q0 16 13 26q15 10 29 4l292 -94l180 248q9 12 26 12t26 -12l180 -248l292 94 q14 6 29 -4q13 -10 13 -26v-306l292 -96q16 -5 20 -20q5 -16 -4 -29l-180 -248l180 -248q9 -12 4 -29z" />
-<glyph unicode="&#xf186;" d="M1262 233q-54 -9 -110 -9q-182 0 -337 90t-245 245t-90 337q0 192 104 357q-201 -60 -328.5 -229t-127.5 -384q0 -130 51 -248.5t136.5 -204t204 -136.5t248.5 -51q144 0 273.5 61.5t220.5 171.5zM1465 318q-94 -203 -283.5 -324.5t-413.5 -121.5q-156 0 -298 61 t-245 164t-164 245t-61 298q0 153 57.5 292.5t156 241.5t235.5 164.5t290 68.5q44 2 61 -39q18 -41 -15 -72q-86 -78 -131.5 -181.5t-45.5 -218.5q0 -148 73 -273t198 -198t273 -73q118 0 228 51q41 18 72 -13q14 -14 17.5 -34t-4.5 -38z" />
-<glyph unicode="&#xf187;" horiz-adv-x="1792" d="M1088 704q0 26 -19 45t-45 19h-256q-26 0 -45 -19t-19 -45t19 -45t45 -19h256q26 0 45 19t19 45zM1664 896v-960q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v960q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1728 1344v-256q0 -26 -19 -45t-45 -19h-1536 q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1536q26 0 45 -19t19 -45z" />
-<glyph unicode="&#xf188;" horiz-adv-x="1664" d="M1632 576q0 -26 -19 -45t-45 -19h-224q0 -171 -67 -290l208 -209q19 -19 19 -45t-19 -45q-18 -19 -45 -19t-45 19l-198 197q-5 -5 -15 -13t-42 -28.5t-65 -36.5t-82 -29t-97 -13v896h-128v-896q-51 0 -101.5 13.5t-87 33t-66 39t-43.5 32.5l-15 14l-183 -207 q-20 -21 -48 -21q-24 0 -43 16q-19 18 -20.5 44.5t15.5 46.5l202 227q-58 114 -58 274h-224q-26 0 -45 19t-19 45t19 45t45 19h224v294l-173 173q-19 19 -19 45t19 45t45 19t45 -19l173 -173h844l173 173q19 19 45 19t45 -19t19 -45t-19 -45l-173 -173v-294h224q26 0 45 -19 t19 -45zM1152 1152h-640q0 133 93.5 226.5t226.5 93.5t226.5 -93.5t93.5 -226.5z" />
-<glyph unicode="&#xf189;" horiz-adv-x="1920" d="M1917 1016q23 -64 -150 -294q-24 -32 -65 -85q-78 -100 -90 -131q-17 -41 14 -81q17 -21 81 -82h1l1 -1l1 -1l2 -2q141 -131 191 -221q3 -5 6.5 -12.5t7 -26.5t-0.5 -34t-25 -27.5t-59 -12.5l-256 -4q-24 -5 -56 5t-52 22l-20 12q-30 21 -70 64t-68.5 77.5t-61 58 t-56.5 15.5q-3 -1 -8 -3.5t-17 -14.5t-21.5 -29.5t-17 -52t-6.5 -77.5q0 -15 -3.5 -27.5t-7.5 -18.5l-4 -5q-18 -19 -53 -22h-115q-71 -4 -146 16.5t-131.5 53t-103 66t-70.5 57.5l-25 24q-10 10 -27.5 30t-71.5 91t-106 151t-122.5 211t-130.5 272q-6 16 -6 27t3 16l4 6 q15 19 57 19l274 2q12 -2 23 -6.5t16 -8.5l5 -3q16 -11 24 -32q20 -50 46 -103.5t41 -81.5l16 -29q29 -60 56 -104t48.5 -68.5t41.5 -38.5t34 -14t27 5q2 1 5 5t12 22t13.5 47t9.5 81t0 125q-2 40 -9 73t-14 46l-6 12q-25 34 -85 43q-13 2 5 24q17 19 38 30q53 26 239 24 q82 -1 135 -13q20 -5 33.5 -13.5t20.5 -24t10.5 -32t3.5 -45.5t-1 -55t-2.5 -70.5t-1.5 -82.5q0 -11 -1 -42t-0.5 -48t3.5 -40.5t11.5 -39t22.5 -24.5q8 -2 17 -4t26 11t38 34.5t52 67t68 107.5q60 104 107 225q4 10 10 17.5t11 10.5l4 3l5 2.5t13 3t20 0.5l288 2 q39 5 64 -2.5t31 -16.5z" />
-<glyph unicode="&#xf18a;" horiz-adv-x="1792" d="M675 252q21 34 11 69t-45 50q-34 14 -73 1t-60 -46q-22 -34 -13 -68.5t43 -50.5t74.5 -2.5t62.5 47.5zM769 373q8 13 3.5 26.5t-17.5 18.5q-14 5 -28.5 -0.5t-21.5 -18.5q-17 -31 13 -45q14 -5 29 0.5t22 18.5zM943 266q-45 -102 -158 -150t-224 -12 q-107 34 -147.5 126.5t6.5 187.5q47 93 151.5 139t210.5 19q111 -29 158.5 -119.5t2.5 -190.5zM1255 426q-9 96 -89 170t-208.5 109t-274.5 21q-223 -23 -369.5 -141.5t-132.5 -264.5q9 -96 89 -170t208.5 -109t274.5 -21q223 23 369.5 141.5t132.5 264.5zM1563 422 q0 -68 -37 -139.5t-109 -137t-168.5 -117.5t-226 -83t-270.5 -31t-275 33.5t-240.5 93t-171.5 151t-65 199.5q0 115 69.5 245t197.5 258q169 169 341.5 236t246.5 -7q65 -64 20 -209q-4 -14 -1 -20t10 -7t14.5 0.5t13.5 3.5l6 2q139 59 246 59t153 -61q45 -63 0 -178 q-2 -13 -4.5 -20t4.5 -12.5t12 -7.5t17 -6q57 -18 103 -47t80 -81.5t34 -116.5zM1489 1046q42 -47 54.5 -108.5t-6.5 -117.5q-8 -23 -29.5 -34t-44.5 -4q-23 8 -34 29.5t-4 44.5q20 63 -24 111t-107 35q-24 -5 -45 8t-25 37q-5 24 8 44.5t37 25.5q60 13 119 -5.5t101 -65.5z M1670 1209q87 -96 112.5 -222.5t-13.5 -241.5q-9 -27 -34 -40t-52 -4t-40 34t-5 52q28 82 10 172t-80 158q-62 69 -148 95.5t-173 8.5q-28 -6 -52 9.5t-30 43.5t9.5 51.5t43.5 29.5q123 26 244 -11.5t208 -134.5z" />
-<glyph unicode="&#xf18b;" d="M1133 -34q-171 -94 -368 -94q-196 0 -367 94q138 87 235.5 211t131.5 268q35 -144 132.5 -268t235.5 -211zM638 1394v-485q0 -252 -126.5 -459.5t-330.5 -306.5q-181 215 -181 495q0 187 83.5 349.5t229.5 269.5t325 137zM1536 638q0 -280 -181 -495 q-204 99 -330.5 306.5t-126.5 459.5v485q179 -30 325 -137t229.5 -269.5t83.5 -349.5z" />
-<glyph unicode="&#xf18c;" horiz-adv-x="1408" d="M1402 433q-32 -80 -76 -138t-91 -88.5t-99 -46.5t-101.5 -14.5t-96.5 8.5t-86.5 22t-69.5 27.5t-46 22.5l-17 10q-113 -228 -289.5 -359.5t-384.5 -132.5q-19 0 -32 13t-13 32t13 31.5t32 12.5q173 1 322.5 107.5t251.5 294.5q-36 -14 -72 -23t-83 -13t-91 2.5t-93 28.5 t-92 59t-84.5 100t-74.5 146q114 47 214 57t167.5 -7.5t124.5 -56.5t88.5 -77t56.5 -82q53 131 79 291q-7 -1 -18 -2.5t-46.5 -2.5t-69.5 0.5t-81.5 10t-88.5 23t-84 42.5t-75 65t-54.5 94.5t-28.5 127.5q70 28 133.5 36.5t112.5 -1t92 -30t73.5 -50t56 -61t42 -63t27.5 -56 t16 -39.5l4 -16q12 122 12 195q-8 6 -21.5 16t-49 44.5t-63.5 71.5t-54 93t-33 112.5t12 127t70 138.5q73 -25 127.5 -61.5t84.5 -76.5t48 -85t20.5 -89t-0.5 -85.5t-13 -76.5t-19 -62t-17 -42l-7 -15q1 -5 1 -50.5t-1 -71.5q3 7 10 18.5t30.5 43t50.5 58t71 55.5t91.5 44.5 t112 14.5t132.5 -24q-2 -78 -21.5 -141.5t-50 -104.5t-69.5 -71.5t-81.5 -45.5t-84.5 -24t-80 -9.5t-67.5 1t-46.5 4.5l-17 3q-23 -147 -73 -283q6 7 18 18.5t49.5 41t77.5 52.5t99.5 42t117.5 20t129 -23.5t137 -77.5z" />
-<glyph unicode="&#xf18d;" horiz-adv-x="1280" d="M1259 283v-66q0 -85 -57.5 -144.5t-138.5 -59.5h-57l-260 -269v269h-529q-81 0 -138.5 59.5t-57.5 144.5v66h1238zM1259 609v-255h-1238v255h1238zM1259 937v-255h-1238v255h1238zM1259 1077v-67h-1238v67q0 84 57.5 143.5t138.5 59.5h846q81 0 138.5 -59.5t57.5 -143.5z " />
-<glyph unicode="&#xf18e;" d="M1152 640q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192h-352q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h352v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf190;" d="M1152 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-352v-192q0 -14 -9 -23t-23 -9q-12 0 -24 10l-319 319q-9 9 -9 23t9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h352q13 0 22.5 -9.5t9.5 -22.5zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf191;" d="M1024 960v-640q0 -26 -19 -45t-45 -19q-20 0 -37 12l-448 320q-27 19 -27 52t27 52l448 320q17 12 37 12q26 0 45 -19t19 -45zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5z M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf192;" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5 t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
-<glyph unicode="&#xf193;" horiz-adv-x="1664" d="M1023 349l102 -204q-58 -179 -210 -290t-339 -111q-156 0 -288.5 77.5t-210 210t-77.5 288.5q0 181 104.5 330t274.5 211l17 -131q-122 -54 -195 -165.5t-73 -244.5q0 -185 131.5 -316.5t316.5 -131.5q126 0 232.5 65t165 175.5t49.5 236.5zM1571 249l58 -114l-256 -128 q-13 -7 -29 -7q-40 0 -57 35l-239 477h-472q-24 0 -42.5 16.5t-21.5 40.5l-96 779q-2 16 6 42q14 51 57 82.5t97 31.5q66 0 113 -47t47 -113q0 -69 -52 -117.5t-120 -41.5l37 -289h423v-128h-407l16 -128h455q40 0 57 -35l228 -455z" />
-<glyph unicode="&#xf194;" d="M1254 899q16 85 -21 132q-52 65 -187 45q-17 -3 -41 -12.5t-57.5 -30.5t-64.5 -48.5t-59.5 -70t-44.5 -91.5q80 7 113.5 -16t26.5 -99q-5 -52 -52 -143q-43 -78 -71 -99q-44 -32 -87 14q-23 24 -37.5 64.5t-19 73t-10 84t-8.5 71.5q-23 129 -34 164q-12 37 -35.5 69 t-50.5 40q-57 16 -127 -25q-54 -32 -136.5 -106t-122.5 -102v-7q16 -8 25.5 -26t21.5 -20q21 -3 54.5 8.5t58 10.5t41.5 -30q11 -18 18.5 -38.5t15 -48t12.5 -40.5q17 -46 53 -187q36 -146 57 -197q42 -99 103 -125q43 -12 85 -1.5t76 31.5q131 77 250 237 q104 139 172.5 292.5t82.5 226.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf195;" horiz-adv-x="1152" d="M1152 704q0 -191 -94.5 -353t-256.5 -256.5t-353 -94.5h-160q-14 0 -23 9t-9 23v611l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v93l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v250q0 14 9 23t23 9h160 q14 0 23 -9t9 -23v-181l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-93l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-487q188 13 318 151t130 328q0 14 9 23t23 9h160q14 0 23 -9t9 -23z" />
-<glyph unicode="&#xf196;" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-352v-352q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v352h-352q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h352v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-352h352q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832 q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" />
-<glyph unicode="&#xf197;" horiz-adv-x="1792" />
-<glyph unicode="&#xf198;" horiz-adv-x="1792" />
-<glyph unicode="&#xf199;" horiz-adv-x="1792" />
-<glyph unicode="&#xf19a;" horiz-adv-x="1792" />
-<glyph unicode="&#xf19b;" horiz-adv-x="1792" />
-<glyph unicode="&#xf19c;" horiz-adv-x="1792" />
-<glyph unicode="&#xf19d;" horiz-adv-x="1792" />
-<glyph unicode="&#xf19e;" horiz-adv-x="1792" />
-<glyph unicode="&#xf500;" horiz-adv-x="1792" />
-</font>
-</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.ttf b/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.ttf
deleted file mode 100755 (executable)
index e89738d..0000000
Binary files a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.ttf and /dev/null differ
diff --git a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.woff b/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.woff
deleted file mode 100755 (executable)
index 8c1748a..0000000
Binary files a/karmaworld/assets/css/font-awesome/fonts/fontawesome-webfont.woff and /dev/null differ
diff --git a/karmaworld/assets/css/fontface.css b/karmaworld/assets/css/fontface.css
new file mode 100644 (file)
index 0000000..e73bbe4
--- /dev/null
@@ -0,0 +1,24 @@
+/* Generated by Font Squirrel (http://www.fontsquirrel.com) on March 19, 2014 */
+
+@font-face {
+    font-family: 'museo700';
+    src: url('//karma-prod.s3.amazonaws.com/css/fonts/museo700-regular-webfont.eot');
+    src: url('//karma-prod.s3.amazonaws.com/css/fonts/museo700-regular-webfont.eot?#iefix') format('embedded-opentype'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo700-regular-webfont.woff') format('woff'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo700-regular-webfont.ttf') format('truetype'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo700-regular-webfont.svg#museo700') format('svg');
+    font-weight: normal;
+    font-style: normal;
+}
+
+@font-face {
+    font-family: 'museo300';
+    src: url('//karma-prod.s3.amazonaws.com/css/fonts/museo300-regular-webfont.eot');
+    src: url('//karma-prod.s3.amazonaws.com/css/fonts/museo300-regular-webfont.eot?#iefix') format('embedded-opentype'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo300-regular-webfont.woff') format('woff'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo300-regular-webfont.ttf') format('truetype'),
+         url('//karma-prod.s3.amazonaws.com/css/fonts/museo300-regular-webfont.svg#museo300') format('svg');
+    font-weight: normal;
+    font-style: normal;
+}
+
diff --git a/karmaworld/assets/css/fontface/fontface.css b/karmaworld/assets/css/fontface/fontface.css
deleted file mode 100644 (file)
index ed1d1ae..0000000
+++ /dev/null
@@ -1,24 +0,0 @@
-/* Generated by Font Squirrel (http://www.fontsquirrel.com) on March 19, 2014 */
-
-@font-face {
-    font-family: 'museo700';
-    src: url('/css/fontface/museo700-regular-webfont.eot');
-    src: url('/css/fontface/museo700-regular-webfont.eot?#iefix') format('embedded-opentype'),
-         url('/css/fontface/museo700-regular-webfont.woff') format('woff'),
-         url('/css/fontface/museo700-regular-webfont.ttf') format('truetype'),
-         url('/css/fontface/museo700-regular-webfont.svg#museo700') format('svg');
-    font-weight: normal;
-    font-style: normal;
-}
-
-@font-face {
-    font-family: 'museo300';
-    src: url('/css/fontface/museo300-regular-webfont.eot');
-    src: url('/css/fontface/museo300-regular-webfont.eot?#iefix') format('embedded-opentype'),
-         url('/css/fontface/museo300-regular-webfont.woff') format('woff'),
-         url('/css/fontface/museo300-regular-webfont.ttf') format('truetype'),
-         url('/css/fontface/museo300-regular-webfont.svg#museo300') format('svg');
-    font-weight: normal;
-    font-style: normal;
-}
-
diff --git a/karmaworld/assets/css/fontface/museo300-regular-webfont.eot b/karmaworld/assets/css/fontface/museo300-regular-webfont.eot
deleted file mode 100644 (file)
index 7368129..0000000
Binary files a/karmaworld/assets/css/fontface/museo300-regular-webfont.eot and /dev/null differ
diff --git a/karmaworld/assets/css/fontface/museo300-regular-webfont.svg b/karmaworld/assets/css/fontface/museo300-regular-webfont.svg
deleted file mode 100644 (file)
index 8002a77..0000000
+++ /dev/null
@@ -1,1006 +0,0 @@
-<?xml version="1.0" standalone="no"?>
-<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
-<svg xmlns="http://www.w3.org/2000/svg">
-<metadata></metadata>
-<defs>
-<font id="museo300" horiz-adv-x="1241" >
-<font-face units-per-em="2048" ascent="1536" descent="-512" />
-<missing-glyph horiz-adv-x="557" />
-<glyph unicode="&#xfb01;" horiz-adv-x="1118" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -51 4q-23 0 -44.5 -3.5t-49 -12.5t-50 -27.5t-42.5 -45.5t-31 -70.5t-11 -98.5v-37h488q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5 t-29.5 95.5v743q0 45 -45 45h-429v-913h-139v913h-129zM788 1264v176h136v-176h-136z" />
-<glyph unicode="&#xfb02;" horiz-adv-x="1105" d="M51 913v117h129v37q0 70 14 127.5t36 95.5t54 66.5t63 44t68 25t64 12t56 2.5h260q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-186q-29 0 -54.5 -4t-59.5 -19t-58 -41t-41 -74.5t-17 -113.5v-37h263 v-117h-263v-913h-139v913h-129z" />
-<glyph unicode="&#xfb03;" horiz-adv-x="1722" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -49 4t-55.5 -4.5t-59.5 -21t-57.5 -43t-41 -76t-16.5 -115.5v-35h465v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -49 4t-55 -4.5t-59.5 -21 t-57.5 -43t-40.5 -76t-16.5 -115.5v-35h487q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v743q0 45 -45 45h-428v-913h-140v913h-465v-913h-139v913h-129zM1393 1264v176h135v-176h-135z" />
-<glyph unicode="&#xfb04;" horiz-adv-x="1708" d="M51 913v117h129v43q0 80 17 143.5t47.5 103t65.5 67t77 40.5t75 18t68 5l68 -4v-125q-22 4 -53 4q-29 0 -55.5 -4.5t-59 -21t-56 -42.5t-39.5 -74t-16 -112v-41h465v37q0 70 14 127.5t36 95.5t54 66.5t63 44t68 25t64 12t56 2.5h260q66 0 95.5 -29.5t29.5 -95.5v-1149 q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-186q-29 0 -54.5 -4t-59.5 -19t-57.5 -41t-40.5 -74.5t-17 -113.5v-37h262v-117h-262v-913h-140v913h-465v-913h-139v913h-129z" />
-<glyph horiz-adv-x="2048" />
-<glyph horiz-adv-x="2048" />
-<glyph unicode="&#xd;" horiz-adv-x="2048" />
-<glyph unicode=" "  horiz-adv-x="557" />
-<glyph unicode="&#x09;" horiz-adv-x="557" />
-<glyph unicode="&#xa0;" horiz-adv-x="557" />
-<glyph unicode="!" horiz-adv-x="608" d="M227 0v158h158v-158h-158zM231 1440h144l-6 -1063h-131z" />
-<glyph unicode="&#x22;" horiz-adv-x="638" d="M135 1114v346h121v-346h-121zM383 1114v346h121v-346h-121z" />
-<glyph unicode="#" horiz-adv-x="1460" d="M84 399l20 115h289l72 401h-289l19 115h290l72 410h125l-72 -410h355l71 410h125l-71 -410h286l-20 -115h-287l-70 -401h285l-18 -115h-287l-70 -399h-125l70 399h-354l-70 -399h-125l70 399h-291zM520 514h352l72 401h-354z" />
-<glyph unicode="$" horiz-adv-x="1089" d="M94 246l107 86q5 -9 14.5 -24t43 -53.5t72 -68t102 -53.5t132.5 -24q128 0 206.5 73.5t78.5 182.5q0 57 -24.5 104t-65.5 80.5t-94.5 63t-112.5 56.5t-117.5 55t-112 64t-94.5 79t-65.5 104t-24.5 135q0 135 101 233.5t266 118.5v195h117v-191q57 -5 111 -20t107 -42.5 t85 -75t32 -107.5v-103h-135v68q0 64 -70 106.5t-171 42.5q-135 0 -215 -64.5t-80 -158.5q0 -69 39 -123t102 -90t138.5 -69t151 -72t138.5 -86.5t102 -123t39 -173.5q0 -149 -102.5 -261.5t-271.5 -129.5v-191h-117v191q-58 6 -112 24t-94.5 41.5t-75.5 51t-58 54t-40 48 t-24 34.5z" />
-<glyph unicode="%" horiz-adv-x="1521" d="M127 1180q0 117 83.5 200.5t203.5 83.5t204 -83.5t84 -200.5q0 -119 -84 -202t-204 -83t-203.5 83t-83.5 202zM139 0l1098 1440h145l-1095 -1440h-148zM248 1180q0 -71 48 -120.5t118 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-118 -50t-48 -120zM819 258 q0 119 83.5 203t203.5 84t204.5 -84t84.5 -203q0 -117 -84.5 -200t-204.5 -83t-203.5 83t-83.5 200zM942 260q0 -71 47 -120.5t117 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-117 -50t-47 -120z" />
-<glyph unicode="&#x26;" horiz-adv-x="1277" d="M94 401q0 127 69 233.5t191 141.5v4q-8 3 -21.5 8.5t-47.5 30.5t-60 57.5t-47.5 92t-21.5 131.5q0 162 116 263t310 101q35 0 77 -5.5t67 -10.5l24 -6l-41 -117q-68 14 -119 14q-126 0 -206.5 -68t-80.5 -179q0 -33 6 -64.5t26 -68.5t52 -64t90 -45.5t135 -18.5h299v199 h142v-199h190v-126h-190v-211q0 -253 -126.5 -386t-346.5 -133q-213 0 -349.5 121.5t-136.5 304.5zM240 406q0 -126 92 -211.5t248 -85.5t243.5 95t87.5 294v207h-295q-184 0 -280 -80t-96 -219z" />
-<glyph unicode="'" horiz-adv-x="391" d="M135 1114v346h121v-346h-121z" />
-<glyph unicode="(" horiz-adv-x="632" d="M174 680q0 461 221 815h131q-223 -375 -223 -805q0 -474 236 -885h-129q-112 184 -174 412t-62 463z" />
-<glyph unicode=")" horiz-adv-x="632" d="M94 -195q236 411 236 885q0 429 -224 805h132q221 -361 221 -815q0 -235 -62 -463t-174 -412h-129z" />
-<glyph unicode="*" horiz-adv-x="976" d="M94 1104l41 129l295 -109l-12 316h139l-14 -316l299 107l41 -125l-303 -88v-4l192 -246l-106 -80l-177 260h-4l-174 -258l-108 78l192 246v4z" />
-<glyph unicode="+" d="M86 522v119h473v522h125v-522h471v-119h-471v-522h-125v522h-473z" />
-<glyph unicode="," horiz-adv-x="440" d="M47 -199l117 367h149l-149 -367h-117z" />
-<glyph unicode="-" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
-<glyph unicode="." horiz-adv-x="440" d="M141 0v164h158v-164h-158z" />
-<glyph unicode="/" horiz-adv-x="665" d="M6 -86l520 1606h129l-518 -1606h-131z" />
-<glyph unicode="0" horiz-adv-x="1232" d="M121 721q0 129 15 237t51.5 203t92 161t141 104t195.5 38t195.5 -38t142 -104t93 -161t52 -203t15.5 -237q0 -130 -15.5 -238.5t-52 -204t-93 -161.5t-142 -104t-195.5 -38t-195.5 38t-141 104t-92 161.5t-51.5 204t-15 238.5zM266 721q0 -108 10 -196.5t35 -167.5 t64 -132.5t100 -84.5t141 -31q99 0 169 46t109 132t56 192t17 242q0 135 -17 240.5t-56 191.5t-109 132t-169 46q-80 0 -141 -31t-100 -84.5t-64 -132.5t-35 -167t-10 -195z" />
-<glyph unicode="1" horiz-adv-x="974" d="M131 0v127h322v1057l2 80h-4q-15 -31 -72 -86l-154 -154l-90 92l326 324h135v-1313h315v-127h-780z" />
-<glyph unicode="2" horiz-adv-x="1155" d="M86 141q0 86 26 158t70 124.5t101.5 98t120.5 82.5t126 72.5t120.5 74.5t101.5 82t70 100.5t26 125.5q0 118 -80.5 194t-214.5 76q-106 0 -181 -46.5t-75 -108.5v-68h-135v106q0 64 40.5 115.5t102.5 79.5t127.5 42.5t124.5 14.5q200 0 319 -115t119 -288 q0 -81 -26 -150.5t-70 -120.5t-101.5 -96t-120.5 -82.5t-126 -73t-120.5 -74t-101.5 -80.5t-70 -97t-26 -119q0 -41 48 -41h602q45 0 45 45v96h133v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-721q-72 0 -100.5 32.5t-28.5 108.5z" />
-<glyph unicode="3" horiz-adv-x="1081" d="M53 176l86 107q6 -7 17.5 -18.5t49 -41t79 -52.5t104.5 -41.5t127 -18.5q132 0 229 88.5t97 222.5q0 140 -103 221.5t-247 81.5h-101l-33 84l355 426q16 21 34 41t29 30l10 9v4q-40 -6 -116 -6h-375q-45 0 -45 -45v-97h-133v144q0 67 28 96t93 29h731v-94l-424 -498 q58 -3 115.5 -18t118 -47t106.5 -78.5t75 -119t29 -161.5q0 -121 -61.5 -224t-171 -164t-242.5 -61q-80 0 -156.5 20.5t-129.5 50t-94 59.5t-61 51z" />
-<glyph unicode="4" horiz-adv-x="1150" d="M31 397v95l700 948h154v-916h229v-127h-229v-397h-144v397h-710zM197 518q57 6 118 6h428v588l7 139h-5q-34 -59 -73 -110l-400 -529q-17 -23 -36 -45.5t-29 -33.5l-10 -11v-4z" />
-<glyph unicode="5" horiz-adv-x="1165" d="M111 180l90 101q4 -7 13 -18.5t40 -40.5t66.5 -51.5t93.5 -41t121 -18.5q153 0 255.5 96t102.5 239q0 147 -108 242.5t-265 95.5q-72 0 -141 -20t-102 -40l-33 -19l-74 30l61 580q6 68 33.5 96.5t91.5 28.5h473q65 0 94 -29.5t29 -95.5v-144h-133v97q0 45 -45 45h-364 q-21 0 -31.5 -10.5t-13.5 -34.5l-37 -326l-13 -82h4q10 6 28.5 15t76 23.5t113.5 14.5q217 0 360 -136t143 -333q0 -127 -64.5 -234.5t-181 -171t-259.5 -63.5q-80 0 -153.5 21t-120.5 51t-82.5 60.5t-51.5 51.5z" />
-<glyph unicode="6" horiz-adv-x="1146" d="M88 633q0 114 22.5 227.5t73 223t122.5 193.5t179.5 135.5t235.5 51.5q70 0 136 -15t97 -29l31 -15l-53 -125q-10 6 -28.5 14.5t-73 22.5t-107.5 14q-87 0 -162.5 -34t-129.5 -90.5t-94.5 -133.5t-63.5 -160.5t-31 -173.5h4q50 82 150 128t216 46q197 0 323 -127.5 t126 -328.5q0 -219 -129.5 -350.5t-323.5 -131.5q-154 0 -273 85.5t-183 235t-64 337.5zM242 541q0 -97 45 -195.5t131 -167.5t188 -69q143 0 226 96.5t83 249.5q0 151 -88.5 241t-236.5 90q-140 0 -244 -77t-104 -168z" />
-<glyph unicode="7" horiz-adv-x="1048" d="M61 1171v144q0 66 28.5 95.5t94.5 29.5h850v-99l-712 -1341h-160l626 1180q18 35 38 68t31 49l11 16v4q-36 -4 -108 -4h-518q-45 0 -45 -45v-97h-136z" />
-<glyph unicode="8" horiz-adv-x="1167" d="M96 406q0 71 26.5 136t64 107.5t75 75t64.5 47.5l26 14v5q-8 4 -21 11t-47 34t-60 58t-47 83.5t-21 109.5q0 75 29 143t83 120t137 83t185 31q201 0 320.5 -106.5t119.5 -276.5q0 -61 -20 -120.5t-48 -100t-56 -72.5t-48 -48l-20 -15v-4q112 -58 171.5 -135t59.5 -195 q0 -171 -140 -293.5t-343 -122.5q-129 0 -239.5 50t-180.5 150t-70 231zM244 412q0 -91 49 -161.5t126.5 -106t166.5 -35.5q133 0 234.5 81t101.5 203q0 54 -20 96t-62.5 74t-83.5 53t-109 48q-40 18 -98 37.5t-70 19.5q-22 0 -60 -24t-77.5 -63t-68.5 -99.5t-29 -122.5z M299 1087q0 -44 15.5 -80.5t37.5 -61.5t62 -48.5t73.5 -37.5t87.5 -34q107 -39 130 -39q19 0 50 25t60.5 64t50.5 94t21 108q0 116 -82.5 185t-214.5 69q-133 0 -212 -70t-79 -174z" />
-<glyph unicode="9" horiz-adv-x="1146" d="M88 983q0 219 128.5 350t322.5 131q154 0 273 -85.5t183 -234.5t64 -337q0 -114 -22.5 -227.5t-72.5 -223.5t-122 -194t-179.5 -135.5t-236.5 -51.5q-70 0 -136 15t-97 30l-31 15l53 125q10 -6 28.5 -14.5t73 -22.5t107.5 -14q108 0 197.5 51t147 137t92 189t44.5 216h-4 q-50 -83 -150 -129.5t-216 -46.5q-197 0 -322 128t-125 329zM231 985q0 -151 89 -241.5t237 -90.5q140 0 244 77.5t104 168.5q0 97 -45 195.5t-131 167.5t-188 69q-143 0 -226.5 -96.5t-83.5 -249.5z" />
-<glyph unicode=":" horiz-adv-x="579" d="M211 0v164h158v-164h-158zM211 866v164h158v-164h-158z" />
-<glyph unicode=";" horiz-adv-x="579" d="M111 -199l98 367h149l-131 -367h-116zM211 866v164h158v-164h-158z" />
-<glyph unicode="&#x3c;" d="M141 530v103l926 414v-138l-752 -325v-4l752 -326v-137z" />
-<glyph unicode="=" d="M143 344v119h955v-119h-955zM143 700v119h955v-119h-955z" />
-<glyph unicode="&#x3e;" d="M158 117v137l751 326v4l-751 325v138l925 -414v-103z" />
-<glyph unicode="?" horiz-adv-x="882" d="M80 1350q5 5 15 12.5t42.5 27.5t68.5 35.5t91.5 28t112.5 12.5q176 0 292.5 -101.5t116.5 -260.5q0 -69 -20 -128t-52.5 -101t-71.5 -80t-78 -73t-71.5 -71t-52.5 -83.5t-20 -102.5v-88h-140v92q0 66 20 123.5t51.5 99.5t69.5 80t76.5 73.5t70 71.5t51.5 82.5t20 98.5 q0 99 -76 167t-193 68q-62 0 -123.5 -22t-92.5 -44l-31 -22zM305 0v158h158v-158h-158z" />
-<glyph unicode="@" horiz-adv-x="1513" d="M84 496q0 154 58 293.5t156 239.5t232.5 159t282.5 59q134 0 234 -32t157 -87.5t84 -122.5t27 -145v-645h145v-115h-551q-174 0 -291.5 116t-117.5 278q0 161 117 277t292 116h267q-3 103 -92 171t-261 68q-165 0 -302.5 -85.5t-215.5 -230t-78 -314.5q0 -172 78 -315.5 t217.5 -227.5t311.5 -84v-123q-157 0 -296.5 59t-238.5 159.5t-157 239t-58 292.5zM643 496q0 -118 80.5 -199.5t198.5 -81.5h254v563h-250q-120 0 -201.5 -82.5t-81.5 -199.5z" />
-<glyph unicode="A" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 z" />
-<glyph unicode="B" d="M82 1313v127h612q172 0 280.5 -98.5t108.5 -264.5q0 -113 -50.5 -192.5t-133.5 -120.5v-4q110 -31 176 -128.5t66 -228.5q0 -187 -121.5 -295t-308.5 -108h-371q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM358 172q0 -45 45 -45h308q130 0 205 76t75 205q0 128 -77.5 206 t-204.5 78h-351v-520zM358 815h334q109 0 176.5 70t67.5 182q0 111 -66.5 178.5t-179.5 67.5h-332v-498z" />
-<glyph unicode="C" horiz-adv-x="1421" d="M78 731q0 205 92 373t255 264t363 96q82 0 171.5 -18t174 -52.5t139 -96t54.5 -138.5v-119h-135v80q0 64 -66.5 113.5t-155.5 72.5t-177 23q-118 0 -222.5 -45t-180 -123t-119.5 -190t-44 -240q0 -170 74 -312t205.5 -225t292.5 -83q61 0 119.5 11t104 29t86.5 39.5 t69.5 43t50 39.5t31.5 29l10 11l82 -104q-8 -10 -23.5 -25.5t-69 -56t-113.5 -71t-154.5 -56t-194.5 -25.5q-155 0 -290 59.5t-228.5 161t-147 240.5t-53.5 295z" />
-<glyph unicode="D" horiz-adv-x="1464" d="M86 1313v127h578q330 0 526 -191t196 -528q0 -340 -196 -530.5t-526 -190.5h-320q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM362 172q0 -45 46 -45h241q271 0 429.5 155t158.5 439q0 282 -159.5 437t-428.5 155h-287v-1141z" />
-<glyph unicode="E" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133z" />
-<glyph unicode="F" horiz-adv-x="1021" d="M86 1313v127h766q66 0 94.5 -29.5t28.5 -95.5v-144h-133v97q0 45 -45 45h-435v-541h523v-127h-523v-645h-143v1313h-133z" />
-<glyph unicode="G" horiz-adv-x="1495" d="M80 723q0 204 94 374t259 268.5t366 98.5q94 0 180 -18t142.5 -44t99.5 -52t63 -44l19 -18l-84 -106q-7 6 -19 16t-53.5 35t-87 44.5t-116 35.5t-142.5 16q-160 0 -291 -79t-206 -218t-75 -309q0 -174 74 -314.5t204.5 -219t291.5 -78.5q80 0 156 21.5t127.5 52.5 t92 62.5t59.5 52.5l19 22v178q0 45 -45 45h-88v127h144q66 0 95.5 -29.5t29.5 -95.5v-547h-132v109l3 61h-5q-7 -8 -20 -21t-58.5 -46.5t-96 -59.5t-131 -47t-165.5 -21q-146 0 -275.5 56.5t-224 155t-149.5 238t-55 298.5z" />
-<glyph unicode="H" horiz-adv-x="1550" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-531h828v531q0 66 29 95.5t94 29.5h153v-127h-88q-45 0 -45 -45v-1268h-143v657h-828v-657h-143v1268q0 45 -45 45h-88z" />
-<glyph unicode="I" horiz-adv-x="600" d="M94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
-<glyph unicode="J" horiz-adv-x="1034" d="M49 403v58h144v-49q0 -82 22.5 -142.5t61.5 -94t84 -49t96 -15.5q50 0 94.5 16t82.5 49t60.5 93t22.5 139v860q0 45 -45 45h-357v127h420q66 0 95.5 -29.5t29.5 -95.5v-912q0 -90 -23 -163.5t-62 -122t-91.5 -81t-109.5 -47t-119 -14.5q-78 0 -148 24t-129 73t-94 134.5 t-35 196.5z" />
-<glyph unicode="K" horiz-adv-x="1208" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-500h173q89 0 120 51l349 574h163l-370 -604q-16 -26 -34.5 -46t-28.5 -27l-11 -7v-4q4 -1 10.5 -5t25 -25t34.5 -52l249 -496q14 -30 37 -38.5t68 -8.5h41v-127h-76q-90 0 -127.5 19.5t-71.5 89.5l-262 526q-16 32 -47 42.5 t-84 10.5h-158v-688h-143v1268q0 45 -45 45h-88z" />
-<glyph unicode="L" horiz-adv-x="1085" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-1143q0 -45 46 -45h477q45 0 45 45v96h135v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-596q-66 0 -95.5 29.5t-29.5 95.5v1143q0 45 -45 45h-88z" />
-<glyph unicode="M" horiz-adv-x="1730" d="M45 0v127h76q42 0 45 45l100 1268h146l381 -838q16 -33 33.5 -75.5t27.5 -68.5l10 -26h4q37 96 70 170l381 838h145l101 -1268q3 -45 45 -45h78v-127h-140q-65 0 -92.5 29t-32.5 96l-67 874q-3 35 -4.5 85t-1.5 83v33h-4q-39 -127 -74 -201l-342 -731h-129l-340 731 q-15 32 -34 83.5t-31 86.5l-11 35h-4q0 -127 -6 -205l-68 -874q-5 -67 -32.5 -96t-92.5 -29h-137z" />
-<glyph unicode="N" horiz-adv-x="1556" d="M86 0v127h88q45 0 45 45v1268h131l735 -1026q22 -32 51 -79.5t48 -78.5l18 -31h4q-10 113 -10 189v901q0 66 29.5 95.5t95.5 29.5h152v-127h-89q-45 0 -45 -45v-1268h-131l-735 1026q-23 31 -52.5 77.5t-48.5 77.5l-18 31h-4q12 -110 12 -186v-901q0 -66 -29 -95.5 t-95 -29.5h-152z" />
-<glyph unicode="O" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305z" />
-<glyph unicode="P" horiz-adv-x="1185" d="M86 1313v127h608q195 0 320 -118.5t125 -315.5q0 -198 -125 -319.5t-320 -121.5h-332v-565h-143v1313h-133zM362 692h314q144 0 229.5 84t85.5 230q0 144 -85 225.5t-228 81.5h-316v-621z" />
-<glyph unicode="Q" horiz-adv-x="1619" d="M78 729q0 153 57 289.5t154 234t232 154.5t286 57q153 0 289.5 -57t234.5 -155t155.5 -234t57.5 -289q0 -139 -47.5 -267.5t-132.5 -228.5l176 -176l-88 -92l-176 178q-196 -168 -469 -168q-150 0 -285.5 59t-232.5 160t-154 240.5t-57 294.5zM227 729q0 -170 76.5 -312 t210 -224t293.5 -82q64 0 125 13.5t103.5 32.5t75.5 38.5t49 32.5l16 14l-172 174l88 92l170 -176q63 79 98 182.5t35 214.5q0 167 -77.5 304.5t-212 215.5t-298.5 78q-161 0 -294 -78t-209.5 -215.5t-76.5 -304.5z" />
-<glyph unicode="R" horiz-adv-x="1239" d="M86 1313v127h610q183 0 298.5 -112t115.5 -298q0 -157 -81.5 -258.5t-197.5 -126.5v-4q30 -16 50 -57l206 -410q14 -30 36.5 -38.5t66.5 -8.5h29v-127h-64q-89 0 -126.5 20t-72.5 89l-206 411q-28 55 -56 70.5t-90 15.5h-242v-606h-143v1313h-133zM362 733h320 q129 0 204 79t75 214q0 133 -74.5 210t-202.5 77h-322v-580z" />
-<glyph unicode="S" horiz-adv-x="1060" d="M76 180l88 105q6 -7 17 -19t48.5 -42.5t78 -53.5t103 -42t126.5 -19q121 0 202.5 71.5t81.5 184.5q0 57 -24.5 104t-65.5 81t-94 63.5t-112 56.5t-118 54.5t-112 63t-94 77t-65.5 101t-24.5 130.5q0 155 122.5 261.5t317.5 106.5q58 0 120.5 -13t125 -39.5t103 -77.5 t40.5 -117v-103h-135v68q0 63 -75 106t-177 43q-135 0 -215 -67.5t-80 -163.5q0 -53 24.5 -97t65.5 -75t94.5 -59t112.5 -53.5t117.5 -53.5t112 -64t94.5 -80t65.5 -106.5t24.5 -138.5q0 -108 -52 -198t-153 -145t-232 -55q-83 0 -160 21t-128.5 51t-91 60.5t-58.5 51.5z " />
-<glyph unicode="T" horiz-adv-x="1269" d="M31 1171v152q0 66 25 91.5t91 25.5h975q66 0 91.5 -25.5t25.5 -91.5v-152h-133v97q0 24 -10.5 34.5t-34.5 10.5h-354v-1313h-144v1313h-356q-45 0 -45 -45v-97h-131z" />
-<glyph unicode="U" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88z" />
-<glyph unicode="V" horiz-adv-x="1337" d="M25 1313v127h63q77 0 109.5 -23t58.5 -96l354 -969q12 -33 26 -79.5t22 -76.5l8 -30h4q28 112 55 186l354 969q27 74 60 96.5t110 22.5h62v-127h-19q-32 0 -47.5 -8.5t-25.5 -36.5l-474 -1268h-153l-473 1268q-10 28 -26 36.5t-48 8.5h-20z" />
-<glyph unicode="W" horiz-adv-x="1935" d="M35 1313v127h63q81 0 118.5 -23.5t55.5 -95.5l250 -993l31 -154h4q19 80 39 154l317 1106h142l288 -1106q9 -33 17 -71.5t12 -60.5l4 -22h4q15 80 33 154l250 993q18 72 55.5 95.5t118.5 23.5h64v-127h-23q-34 0 -51.5 -9t-24.5 -36l-332 -1268h-170l-268 1001 q-11 41 -23 94t-18 86l-6 33h-4q-24 -118 -51 -210l-295 -1004h-170l-330 1268q-7 27 -25 36t-51 9h-24z" />
-<glyph unicode="X" horiz-adv-x="1167" d="M31 0l458 752l-311 508q-20 32 -43.5 42.5t-58.5 10.5h-43v127h76q77 0 116.5 -22t81.5 -93l185 -309l92 -164h4q43 90 88 164l184 309q42 70 82 92.5t117 22.5h76v-127h-43q-36 0 -59.5 -10.5t-43.5 -42.5l-313 -508l461 -752h-164l-299 496l-92 157h-4 q-41 -85 -86 -159l-297 -494h-164z" />
-<glyph unicode="Y" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33z" />
-<glyph unicode="Z" horiz-adv-x="1177" d="M39 0v100l772 1082q24 34 50 66.5t40 48.5l14 16v4q-34 -4 -104 -4h-573q-45 0 -45 -45v-97h-134v144q0 66 29.5 95.5t95.5 29.5h908v-101l-770 -1081q-24 -34 -50.5 -66.5t-41.5 -48.5l-15 -16v-4q35 4 107 4h620q45 0 45 45v96h133v-143q0 -66 -29.5 -95.5t-95.5 -29.5 h-956z" />
-<glyph unicode="[" horiz-adv-x="620" d="M207 -70v1440q0 66 29.5 95.5t95.5 29.5h151v-115h-102q-45 0 -45 -45v-1370q0 -45 45 -45h102v-115h-151q-66 0 -95.5 29.5t-29.5 95.5z" />
-<glyph unicode="\" horiz-adv-x="649" d="M10 1520h131l518 -1606h-129z" />
-<glyph unicode="]" horiz-adv-x="620" d="M137 -80h103q45 0 45 45v1370q0 45 -45 45h-103v115h152q66 0 95.5 -29.5t29.5 -95.5v-1440q0 -66 -29.5 -95.5t-95.5 -29.5h-152v115z" />
-<glyph unicode="^" d="M150 512l405 928h96l406 -928h-133l-320 758l-319 -758h-135z" />
-<glyph unicode="_" horiz-adv-x="1077" d="M10 0h1057v-119h-1057v119z" />
-<glyph unicode="`" horiz-adv-x="737" d="M190 1784h156l143 -244h-120z" />
-<glyph unicode="a" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86z" />
-<glyph unicode="b" horiz-adv-x="1196" d="M41 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-373l-4 -84h4q4 8 11 21.5t36.5 47.5t66 59.5t100 47t137.5 21.5q205 0 326.5 -149.5t121.5 -391.5t-130 -390.5t-335 -148.5q-69 0 -129 20.5t-96.5 49.5t-63.5 58.5t-38 50.5l-11 20h-4q4 -35 4 -84v-90h-135v1274 q0 45 -45 45h-86zM307 512q0 -79 20.5 -152t60 -132t103.5 -94.5t144 -35.5q141 0 236.5 112.5t95.5 303.5q0 187 -91 300.5t-235 113.5q-67 0 -125.5 -24.5t-106 -73t-75 -130.5t-27.5 -188z" />
-<glyph unicode="c" horiz-adv-x="1081" d="M82 514q0 155 71.5 279t195.5 193t276 69q39 0 83.5 -6t95.5 -22t92 -40t68 -63.5t27 -87.5v-93h-131v60q0 58 -78.5 92.5t-156.5 34.5q-169 0 -284.5 -116t-115.5 -300q0 -123 56 -218.5t147.5 -144.5t200.5 -49q59 0 115 15t93.5 36.5t67 43t43.5 36.5l13 15l65 -105 q-6 -7 -17 -18t-49 -40t-81 -51.5t-112.5 -40.5t-143.5 -18q-152 0 -275.5 67.5t-194.5 191t-71 280.5z" />
-<glyph unicode="d" horiz-adv-x="1204" d="M86 516q0 242 129.5 390.5t333.5 148.5q70 0 130.5 -20t96.5 -48t62 -56.5t36 -48.5l11 -20h4q-4 35 -4 78v334q0 45 -45 45h-86v121h145q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-143q-123 0 -123 115l4 65h-4q-3 -8 -10.5 -22t-36.5 -49.5t-65.5 -62.5 t-101 -49t-140.5 -22q-205 0 -327 149.5t-122 391.5zM229 516q0 -189 90 -302.5t236 -113.5q67 0 125.5 24.5t106 73t75 130.5t27.5 188q0 80 -20.5 153t-60 132t-103.5 94t-144 35q-141 0 -236.5 -112.5t-95.5 -301.5z" />
-<glyph unicode="e" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5z" />
-<glyph unicode="f" horiz-adv-x="624" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-18 4 -49 4q-28 0 -54.5 -4.5t-60 -20.5t-57.5 -42.5t-41 -76t-17 -114.5v-37h263v-117h-263v-913h-139v913h-129z" />
-<glyph unicode="g" horiz-adv-x="1185" d="M86 535q0 234 120.5 377t325.5 143q77 0 141 -18t99.5 -44t60 -52t33.5 -44l8 -18h5v39q0 57 27 84.5t89 27.5h144v-121h-84q-45 0 -45 -45v-839q0 -95 -27.5 -172.5t-74 -129.5t-110.5 -87t-135 -50.5t-149 -15.5q-175 0 -336 82l53 117q14 -8 39.5 -20t98.5 -32 t141 -20q161 0 260.5 80t99.5 243v91l2 73h-4q-96 -178 -323 -178q-206 0 -332.5 148t-126.5 381zM229 537q0 -184 92 -295t244 -111q64 0 117.5 21t97 66.5t68 126t24.5 190.5q0 393 -325 393q-151 0 -234.5 -103t-83.5 -288z" />
-<glyph unicode="h" horiz-adv-x="1239" d="M41 1319v121h145q66 0 95.5 -29t29.5 -92v-436l-4 -84h4q12 31 34.5 64t59.5 68t81.5 62t105.5 44.5t127 17.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-18 82t-37.5 68.5t-66 43.5t-100.5 17 q-130 0 -233.5 -82t-138.5 -211q-17 -58 -17 -137v-494h-139v1274q0 45 -45 45h-86z" />
-<glyph unicode="i" horiz-adv-x="514" d="M57 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM184 1264v176h135v-176h-135z" />
-<glyph unicode="j" horiz-adv-x="548" d="M-43 -295q18 -2 45 -2q29 0 55.5 4.5t61 21t59 43.5t41.5 77.5t17 117.5v897q0 45 -46 45h-86v121h146q66 0 95.5 -29.5t29.5 -95.5v-944q0 -97 -27 -170.5t-65 -112.5t-90.5 -63t-93.5 -30.5t-83 -6.5q-16 0 -31 1.5t-21 2.5l-7 2v121zM233 1264v176h134v-176h-134z" />
-<glyph unicode="k" horiz-adv-x="1019" d="M41 1319v121h145q67 0 96 -27t29 -92v-684h107q79 0 117 49l264 344h170l-297 -377q-23 -28 -42.5 -46.5t-27.5 -22.5l-8 -4v-5q30 -14 63 -75l187 -334q13 -26 33 -35.5t61 -9.5h55v-121h-96q-77 0 -110 19t-68 83l-205 369q-25 45 -108 45h-95v-516h-139v1274 q0 45 -45 45h-86z" />
-<glyph unicode="l" horiz-adv-x="501" d="M45 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-86z" />
-<glyph unicode="m" horiz-adv-x="1906" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q39 106 147 183t226 77q141 0 218.5 -64.5t101.5 -193.5h4q43 108 148 183t231 75q181 0 261.5 -101t80.5 -299v-489q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v496q0 69 -9 119.5t-31.5 95.5 t-68.5 68.5t-114 23.5q-112 0 -203 -85.5t-123 -205.5q-18 -58 -18 -150v-487h-139v621q0 44 -2.5 77.5t-10 71t-23 64t-38.5 49t-59.5 34t-83.5 11.5q-120 0 -211 -88.5t-125 -214.5q-17 -61 -17 -138v-487h-139v864q0 45 -45 45h-86z" />
-<glyph unicode="n" horiz-adv-x="1245" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q16 40 47 81t80 83.5t123.5 69t159.5 26.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-17.5 82t-37 68.5t-65 43.5t-99.5 17 q-131 0 -235.5 -81.5t-139.5 -209.5q-17 -61 -17 -139v-494h-139v864q0 45 -45 45h-86z" />
-<glyph unicode="o" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5z" />
-<glyph unicode="p" horiz-adv-x="1202" d="M47 909v121h141q65 0 94 -26.5t29 -81.5l-2 -70h4q3 8 10.5 22t36.5 49t65.5 61.5t101.5 48.5t141 22q205 0 326.5 -149.5t121.5 -391.5t-129.5 -390.5t-331.5 -148.5q-71 0 -131.5 20t-97 48.5t-62.5 57.5t-36 49l-11 20h-4q4 -37 4 -90v-490h-139v1274q0 45 -45 45h-86 zM313 512q0 -79 21.5 -152.5t61.5 -132t103.5 -94t141.5 -35.5q141 0 236.5 112.5t95.5 303.5q0 188 -90 301t-236 113q-67 0 -125.5 -24.5t-106 -73t-75 -130.5t-27.5 -188z" />
-<glyph unicode="q" horiz-adv-x="1204" d="M88 516q0 242 129.5 390.5t333.5 148.5q71 0 132 -20.5t97.5 -50t63 -58.5t36.5 -50l11 -20h4q-2 29 -2 68q0 54 29.5 80t93.5 26h141v-121h-86q-45 0 -45 -45v-1274h-139v494l4 90h-4q-4 -8 -11 -21.5t-36 -48t-65.5 -60.5t-100 -47.5t-137.5 -21.5q-205 0 -327 149.5 t-122 391.5zM229 516q0 -189 91 -302.5t237 -113.5q67 0 125.5 24.5t106 73t75 130.5t27.5 188q0 80 -21 153t-60.5 132t-103.5 94t-143 35q-142 0 -238 -112.5t-96 -301.5z" />
-<glyph unicode="r" horiz-adv-x="741" d="M47 909v121h143q65 0 95 -28t30 -89v-69l-4 -78h4q38 122 123.5 198t202.5 76l55 -6v-137q-24 4 -51 4q-105 0 -184.5 -74t-114.5 -192q-29 -96 -29 -201v-434h-139v864q0 45 -45 45h-86z" />
-<glyph unicode="s" horiz-adv-x="901" d="M59 156l80 96q5 -6 14 -16.5t39.5 -37.5t65 -47.5t88.5 -37.5t111 -17q92 0 154.5 43t62.5 121q0 45 -32 81.5t-83 61.5t-112.5 49.5t-123 52.5t-112.5 62.5t-83 88t-32 120.5q0 135 102.5 207t264.5 72q44 0 93.5 -9.5t101 -29t85 -58.5t33.5 -90v-88h-131v49 q0 51 -57.5 78t-120.5 27q-109 0 -169 -38t-60 -112q0 -47 32 -83.5t82.5 -61.5t112 -48.5t123.5 -51.5t112.5 -62.5t82.5 -89t32 -123.5q0 -128 -102.5 -208.5t-257.5 -80.5q-75 0 -143.5 18.5t-112.5 45t-77 53.5t-48 46z" />
-<glyph unicode="t" horiz-adv-x="686" d="M55 913v117h138v285h137v-285h258v-117h-258v-524q0 -69 17 -121t41.5 -80t58 -45t60 -21.5t54.5 -4.5l47 4v-125q-24 -4 -59 -4q-29 0 -57.5 3t-65.5 13t-68.5 26.5t-63.5 46t-54 68t-36 97t-14 129.5v538h-135z" />
-<glyph unicode="u" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86z" />
-<glyph unicode="v" horiz-adv-x="1060" d="M29 909v121h55q74 0 106 -21.5t58 -90.5l248 -644q8 -23 16.5 -53t13.5 -49l4 -18h5q16 69 34 120l248 644q26 69 58 90.5t104 21.5h53v-121h-18q-57 0 -72 -47l-336 -862h-151l-336 862q-10 27 -26.5 37t-45.5 10h-18z" />
-<glyph unicode="w" horiz-adv-x="1708" d="M20 909v121h72q75 0 107 -22t55 -93l211 -653l31 -110h4q16 61 32 110l252 764h140l252 -764l32 -110h4q13 59 29 110l213 653q23 71 55 93t107 22h72v-121h-29q-57 0 -72 -47l-295 -862h-153l-252 733l-31 111h-4q-15 -60 -33 -111l-250 -733h-155l-295 862 q-15 47 -72 47h-27z" />
-<glyph unicode="x" horiz-adv-x="976" d="M37 909v121h76q78 0 112 -20t80 -92l148 -230l34 -61h5q18 34 32 61l150 230q47 72 80.5 92t111.5 20h74v-121h-41q-36 0 -58 -8t-38 -33l-223 -331l360 -537h-164l-252 383l-32 57h-5q-16 -28 -34 -57l-252 -383h-162l358 537l-223 329q-18 25 -39.5 34t-54.5 9h-43z " />
-<glyph unicode="y" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5z" />
-<glyph unicode="z" horiz-adv-x="1021" d="M80 0v90l579 723q17 22 37.5 45.5t32.5 35.5l12 13v4q-34 -4 -102 -4h-377q-45 0 -45 -45v-80h-131v123q0 66 29.5 95.5t95.5 29.5h715v-92l-578 -721q-18 -22 -39.5 -45.5t-34.5 -35.5l-12 -13v-4q37 4 105 4h426q45 0 45 45v80h131v-123q0 -66 -29.5 -95.5t-95.5 -29.5 h-764z" />
-<glyph unicode="{" horiz-adv-x="667" d="M68 598v127q7 1 19 3.5t42 18t52.5 38.5t41.5 69.5t19 106.5v167q0 70 13 126.5t33 94t48.5 65.5t55.5 43t58.5 24t53.5 11.5t43 2.5h31v-115h-19q-20 0 -39.5 -3.5t-48 -18.5t-49.5 -40.5t-36 -75.5t-15 -118v-200q0 -56 -17 -103.5t-41 -75t-48 -47t-41 -26.5l-17 -8 v-5q7 -2 18 -6.5t39 -25t50 -46.5t39.5 -74.5t17.5 -107.5v-225q0 -67 15 -117t36 -75.5t49.5 -41t48 -19t39.5 -3.5h19v-115q-13 -2 -31 -2q-32 0 -64 5t-78 27.5t-80 59.5t-58.5 109t-24.5 168v195q0 60 -18 106t-43.5 68.5t-51 37t-43.5 17.5z" />
-<glyph unicode="|" horiz-adv-x="583" d="M227 -322v1936h129v-1936h-129z" />
-<glyph unicode="}" horiz-adv-x="667" d="M90 -82h21q19 0 38.5 3.5t47.5 19t49 41t36 75.5t15 117v225q0 59 17 107t41 75t48 46t41 25l17 7v5q-7 2 -18 7.5t-39 26.5t-50 47.5t-39.5 74.5t-17.5 104v200q0 57 -10 101.5t-27.5 71t-36.5 44.5t-42 26t-38.5 10.5t-31.5 2.5h-21v115h33q31 0 62.5 -5t77.5 -27 t80 -59t58.5 -108.5t24.5 -167.5v-167q0 -60 18 -106.5t43.5 -70t51 -38t43.5 -18.5l18 -3v-127q-7 -1 -19 -3.5t-42 -17.5t-52.5 -37.5t-41.5 -68.5t-19 -106v-195q0 -96 -24.5 -168t-58.5 -109t-80 -59.5t-77 -27.5t-63 -5l-33 2v115z" />
-<glyph unicode="~" d="M137 428q0 162 69.5 239.5t190.5 77.5q62 0 111 -22t81 -53.5t61 -62.5t68 -53t87 -22q43 0 74 20.5t45 54.5t20 65.5t6 64.5h121q0 -162 -69.5 -239.5t-190.5 -77.5q-62 0 -111 22t-81 53t-61 62.5t-68 53.5t-87 22q-43 0 -74 -20.5t-45 -54.5t-20 -65.5t-6 -64.5h-121z " />
-<glyph unicode="&#xa1;" horiz-adv-x="608" d="M223 872v158h158v-158h-158zM231 -410l7 1063h131l6 -1063h-144z" />
-<glyph unicode="&#xa2;" horiz-adv-x="1116" d="M113 721q0 231 108 389.5t303 181.5v228h117v-228q126 -15 218.5 -94t148.5 -209l-131 -49q-94 221 -287 221q-109 0 -185.5 -59.5t-111.5 -157t-35 -223.5q0 -128 35 -225.5t111 -156t186 -58.5q194 0 287 221l131 -51q-57 -128 -149 -210.5t-218 -93.5v-227h-117v227 q-195 23 -303 182.5t-108 391.5z" />
-<glyph unicode="&#xa3;" horiz-adv-x="1191" d="M111 0v127h129v541h-93v112h93v305q0 162 119.5 270.5t302.5 108.5q55 0 108 -12t90 -29t66 -34t43 -29l14 -12l-88 -103q-4 3 -11.5 9t-31.5 21t-49.5 26t-64 20.5t-76.5 9.5q-129 0 -204 -73.5t-75 -180.5v-297h391v-112h-391v-541h539q45 0 45 45v96h133v-143 q0 -66 -29.5 -95.5t-95.5 -29.5h-864z" />
-<glyph unicode="&#xa5;" horiz-adv-x="1243" d="M35 1313v127h49q77 0 118.5 -22t84.5 -93l243 -407l88 -160h5q43 84 88 160l245 407q41 71 83 93t120 22h47v-127h-24q-71 0 -99 -45l-266 -439v-4h205v-104h-272l-56 -94v-84h328v-107h-328v-436h-143v436h-332v107h332v84l-59 94h-281v104h215v4l-268 439 q-28 45 -99 45h-24z" />
-<glyph unicode="&#xa7;" horiz-adv-x="849" d="M123 -41l72 98q8 -7 22.5 -17t58 -27t86.5 -17q97 0 160.5 60t63.5 163q0 35 -8 66l-134 878h123l140 -889q8 -54 8 -71q0 -144 -98.5 -237t-256.5 -93q-63 0 -122 21.5t-87 43.5zM150 1135q0 143 97 236t255 93q63 0 122 -21.5t87 -42.5l28 -22l-71 -96q-8 7 -22 16.5 t-57.5 26t-86.5 16.5q-97 0 -161.5 -59t-64.5 -160q0 -28 9 -63l135 -885h-123l-139 889q-8 33 -8 72z" />
-<glyph unicode="&#xa8;" horiz-adv-x="1009" d="M322 1608v176h120v-176h-120zM629 1608v176h121v-176h-121z" />
-<glyph unicode="&#xa9;" horiz-adv-x="1624" d="M84 721q0 152 57.5 290t154 237t230.5 157.5t281 58.5q150 0 286 -58.5t234 -157.5t155.5 -236.5t57.5 -290.5q0 -154 -57.5 -292.5t-155.5 -238t-233.5 -157.5t-286.5 -58q-147 0 -281 58.5t-230.5 157.5t-154 237.5t-57.5 292.5zM205 721q0 -176 79 -322t217.5 -229.5 t305.5 -83.5q171 0 312 83.5t221.5 229t80.5 322.5q0 175 -80.5 320t-221.5 229t-312 84q-167 0 -305.5 -84t-217.5 -229t-79 -320zM406 717q0 82 28.5 157t80.5 134.5t133 95t179 35.5q63 0 120.5 -19.5t95 -47.5t65.5 -56.5t40 -47.5l13 -20l-94 -63q-3 6 -10 15.5 t-29.5 33.5t-48 43t-65.5 34t-83 15q-142 0 -223.5 -90.5t-81.5 -216.5q0 -127 81 -217t224 -90q43 0 83 14.5t67 35t47 41.5t30 35l9 15l94 -64q-5 -8 -13.5 -20.5t-40 -45.5t-67 -58t-93.5 -45.5t-120 -20.5q-98 0 -179 35t-133 93.5t-80.5 133.5t-28.5 156z" />
-<glyph unicode="&#xaa;" horiz-adv-x="847" d="M119 541v96h620v-96h-620zM123 979q0 225 389 225h27q-1 87 -35 122.5t-111 35.5q-20 0 -40.5 -2t-43 -12t-22.5 -27v-49h-109v80q0 31 25 54t63 34t70 15.5t59 4.5q75 0 127 -19t79 -55t38.5 -78.5t11.5 -99.5v-290q0 -19 19 -19h59v-104h-96q-83 0 -86 79v25h-4 q-2 -5 -6.5 -13t-21.5 -28t-37.5 -35.5t-55.5 -28t-74 -12.5q-93 0 -159 53t-66 144zM240 985q0 -43 32 -73.5t90 -30.5q81 0 128.5 68t50.5 165h-25q-37 0 -65 -1t-71 -8.5t-70.5 -20t-48.5 -38t-21 -61.5z" />
-<glyph unicode="&#xab;" horiz-adv-x="1069" d="M78 578l336 421h149l-336 -421l336 -420h-149zM444 578l336 421h152l-336 -421l336 -420h-152z" />
-<glyph unicode="&#xac;" d="M143 700v119h955v-495h-125v376h-830z" />
-<glyph unicode="&#xad;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
-<glyph unicode="&#xae;" horiz-adv-x="1624" d="M84 721q0 152 57.5 290t154 237t230.5 157.5t281 58.5q150 0 286 -58.5t234 -157.5t155.5 -236.5t57.5 -290.5q0 -154 -57.5 -292.5t-155.5 -238t-233.5 -157.5t-286.5 -58q-147 0 -281 58.5t-230.5 157.5t-154 237.5t-57.5 292.5zM205 721q0 -176 79 -322t217.5 -229.5 t305.5 -83.5q171 0 312 83.5t221.5 229t80.5 322.5q0 175 -80.5 320t-221.5 229t-312 84q-167 0 -305.5 -84t-217.5 -229t-79 -320zM492 1024v96h358q106 0 173 -65t67 -172q0 -84 -44.5 -140t-105.5 -71v-4q23 -8 41 -43l92 -185q12 -26 55 -26h21v-92h-59q-48 0 -71 11 t-44 50l-111 217q-14 28 -29.5 36.5t-43.5 8.5h-111v-323h-115v702h-73zM680 735h149q65 0 103.5 39.5t38.5 108.5q0 67 -38.5 104t-103.5 37h-149v-289z" />
-<glyph unicode="&#xaf;" horiz-adv-x="944" d="M229 1608v110h504v-110h-504z" />
-<glyph unicode="&#xb0;" horiz-adv-x="784" d="M104 1178q0 117 83.5 200.5t203.5 83.5t204.5 -83.5t84.5 -200.5q0 -118 -84.5 -201.5t-204.5 -83.5t-203.5 83t-83.5 202zM227 1178q0 -71 47 -120.5t117 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-117 -50t-47 -120z" />
-<glyph unicode="&#xb1;" d="M86 522v119h473v522h125v-522h471v-119h-471v-522h-125v522h-473zM123 -213h995v-119h-995v119z" />
-<glyph unicode="&#xb2;" horiz-adv-x="837" d="M104 645q0 37 8.5 70.5t20 59t34.5 51.5t40 42t49.5 38t51 33t54.5 32q39 22 61 35t53 36.5t47 44t28 49.5t12 62q0 64 -44 106t-118 42q-58 0 -98.5 -24.5t-40.5 -57.5v-54h-110v80q0 42 26 75.5t66 52.5t80.5 28.5t76.5 9.5q130 0 205.5 -73t75.5 -185 q0 -59 -19 -106.5t-63.5 -86.5t-74.5 -59t-93 -56q-8 -5 -12 -7q-50 -30 -75.5 -46.5t-59.5 -45.5t-49 -60.5t-15 -68.5q0 -13 19 -13h358q12 0 12 15v71h111v-102q0 -47 -21.5 -68.5t-68.5 -21.5h-434q-52 0 -72.5 22t-20.5 80z" />
-<glyph unicode="&#xb3;" horiz-adv-x="837" d="M102 674l82 80q4 -5 11 -13t30 -28t47.5 -35.5t61.5 -28t74 -12.5q72 0 126 50t54 126q0 75 -57 120.5t-136 45.5h-71l-21 70l197 239q9 11 20.5 23.5t19.5 18.5l7 7v4q-35 -6 -74 -6h-194q-21 0 -21 -22v-58h-111v88q0 54 21 75.5t76 21.5h452v-80l-241 -283 q44 -4 87.5 -22.5t81 -50t60.5 -82t23 -111.5q0 -122 -88.5 -203.5t-212.5 -81.5q-50 0 -100 15t-85 37t-63 44t-42 37z" />
-<glyph unicode="&#xb4;" horiz-adv-x="759" d="M236 1540l143 244h156l-179 -244h-120z" />
-<glyph unicode="&#xb6;" horiz-adv-x="1175" d="M88 969q0 130 66.5 239t178 170.5t242.5 61.5h490v-127h-371v-1415h-116v596q-130 0 -243 62.5t-180 172.5t-67 240zM821 -102v1292h119v-1292h-119z" />
-<glyph unicode="&#xb7;" horiz-adv-x="440" d="M141 508v164h158v-164h-158z" />
-<glyph unicode="&#xb8;" horiz-adv-x="845" d="M227 -311q39 -13 86 -13q105 0 105 70q0 33 -31 51.5t-86 18.5l-31 -2l54 227l82 -14v-17l-25 -123q65 -9 105 -47t40 -98q0 -83 -57 -122.5t-141 -39.5q-26 0 -51.5 2.5t-37.5 5.5l-12 2v99z" />
-<glyph unicode="&#xb9;" horiz-adv-x="837" d="M162 1231l209 209h104v-791h191v-106h-502v106h192v563l2 70h-4q-10 -21 -26 -37l-92 -90z" />
-<glyph unicode="&#xba;" horiz-adv-x="933" d="M125 1126q0 142 100 239t242 97t242 -97t100 -239q0 -145 -100 -243.5t-242 -98.5t-242 98.5t-100 243.5zM160 541v96h620v-96h-620zM238 1126q0 -102 66.5 -169.5t162.5 -67.5t162.5 67.5t66.5 169.5q0 100 -66.5 167t-162.5 67t-162.5 -67t-66.5 -167z" />
-<glyph unicode="&#xbb;" horiz-adv-x="1069" d="M135 158l336 420l-336 421h152l336 -421l-336 -420h-152zM504 158l336 420l-336 421h151l336 -421l-336 -420h-151z" />
-<glyph unicode="&#xbc;" horiz-adv-x="1822" d="M158 1231l209 209h102v-791h188v-106h-497v106h192v563l2 70h-4q-10 -21 -26 -37l-93 -90zM551 0l608 1440h127l-606 -1440h-129zM1016 240v75l426 582h123v-551h137v-106h-137v-240h-117v240h-432zM1155 344q29 2 43 2h252v313l2 80h-4q-15 -28 -33 -55l-231 -305 l-29 -33v-2z" />
-<glyph unicode="&#xbd;" horiz-adv-x="1822" d="M158 1231l209 209h102v-791h188v-106h-497v106h192v563l2 70h-4q-10 -21 -26 -37l-93 -90zM528 0l609 1440h127l-607 -1440h-129zM1063 102q0 51 16 96t37.5 75t61 62t67.5 49t76 44q39 22 61 35t53 36.5t47 44t28 49.5t12 62q0 64 -44 106t-118 42q-58 0 -98.5 -24.5 t-40.5 -57.5v-51h-111v78q0 43 26 76.5t66.5 52t81 27.5t76.5 9q130 0 205 -73t75 -185q0 -31 -5.5 -59t-19 -53t-25 -43.5t-36.5 -40t-38.5 -33.5t-46 -32t-44 -27t-47.5 -27q-39 -23 -60 -36.5t-51 -36.5t-45.5 -42.5t-27.5 -46.5t-12 -57q0 -15 16 -15h358q13 0 13 15v72 h110v-103q0 -46 -21.5 -68t-68.5 -22h-434q-51 0 -71.5 22t-20.5 80z" />
-<glyph unicode="&#xbe;" horiz-adv-x="1822" d="M127 674l82 80q4 -5 11 -13t30 -28t47 -35.5t61 -28t74 -12.5q72 0 126 50t54 126q0 75 -56.5 120.5t-135.5 45.5h-72l-20 70l196 239q9 11 20.5 23.5t19.5 18.5l7 7v4q-34 -6 -73 -6h-195q-20 0 -20 -22v-58h-111v88q0 55 20.5 76t75.5 21h453v-80l-242 -283 q44 -4 87.5 -22.5t81 -50t60.5 -82t23 -111.5q0 -122 -88.5 -203.5t-212.5 -81.5q-50 0 -100 15t-85 37t-63 44t-42 37zM549 0l608 1440h127l-606 -1440h-129zM1016 240v75l426 582h123v-551h137v-106h-137v-240h-117v240h-432zM1155 344q29 2 43 2h252v313l2 80h-4 q-15 -28 -33 -55l-231 -305l-29 -33v-2z" />
-<glyph unicode="&#xbf;" horiz-adv-x="882" d="M63 -68q0 69 20 127.5t52.5 100.5t71.5 80t78.5 73t72 71.5t52.5 84t20 102.5v82h137v-88q0 -66 -19.5 -123t-51 -98.5t-69.5 -79.5t-76 -73t-69.5 -71t-51 -82.5t-19.5 -98.5q0 -100 75.5 -168t192.5 -68q62 0 124 21.5t93 43.5l31 21l76 -102q-5 -5 -15 -13t-42.5 -28 t-68.5 -35.5t-91.5 -28t-112.5 -12.5q-176 0 -293 102t-117 260zM420 872v158h158v-158h-158z" />
-<glyph unicode="&#xc0;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM434 1784h156l143 -244h-121z" />
-<glyph unicode="&#xc1;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM612 1540l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xc2;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM432 1540l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
-<glyph unicode="&#xc3;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM350 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15 q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186z" />
-<glyph unicode="&#xc4;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM461 1608v176h121v-176h-121zM768 1608v176h121v-176h-121z" />
-<glyph unicode="&#xc5;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM522 1663q0 63 44.5 104t107.5 41t107 -41t44 -104t-44 -104t-107 -41t-107.5 41t-44.5 104zM606 1663q0 -30 19 -49t49 -19q29 0 48 19.5t19 48.5q0 31 -19 50.5t-48 19.5t-48.5 -19.5t-19.5 -50.5z" />
-<glyph unicode="&#xc6;" horiz-adv-x="1685" d="M25 0v127h18q31 0 47.5 9t26.5 36l487 1268h848q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-475v-525h524v-126h-524v-490q0 -28 12.5 -36.5t44.5 -8.5h477q45 0 45 45v96h135v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-589q-80 0 -112 25.5t-32 99.5v537h-325 l-205 -543q-26 -73 -58.5 -96t-109.5 -23h-55zM500 788h278v525h-82z" />
-<glyph unicode="&#xc7;" horiz-adv-x="1421" d="M78 731q0 205 92 373t255 264t363 96q82 0 171.5 -18t174 -52.5t139 -96t54.5 -138.5v-119h-135v80q0 64 -66.5 113.5t-155.5 72.5t-177 23q-118 0 -222.5 -45t-180 -123t-119.5 -190t-44 -240q0 -171 72.5 -312.5t202.5 -224.5t291 -83q83 0 163 20.5t134 50t96.5 59 t63.5 49.5l20 21l82 -102q-8 -9 -23 -24.5t-67.5 -55t-111 -70t-151.5 -56.5t-192 -28l-19 -88q65 -9 104.5 -47t39.5 -98q0 -83 -56.5 -122.5t-140.5 -39.5q-26 0 -51 2.5t-37 5.5l-12 2v99q39 -13 86 -13q102 0 102 70q0 34 -30 52t-86 18l-29 -2l39 166 q-188 17 -334.5 120.5t-225.5 268.5t-79 362z" />
-<glyph unicode="&#xc8;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM362 1784h156l144 -244h-121z" />
-<glyph unicode="&#xc9;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM541 1540l143 244h156l-178 -244h-121z " />
-<glyph unicode="&#xca;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM360 1540l170 244h144l170 -244h-129 l-111 166h-4l-111 -166h-129z" />
-<glyph unicode="&#xcb;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM389 1608v176h121v-176h-121zM696 1608 v176h121v-176h-121z" />
-<glyph unicode="&#xcc;" horiz-adv-x="600" d="M59 1784h156l143 -244h-120zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
-<glyph unicode="&#xcd;" horiz-adv-x="600" d="M94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412zM238 1540l143 244h156l-179 -244h-120z" />
-<glyph unicode="&#xce;" horiz-adv-x="600" d="M57 1540l170 244h144l170 -244h-129l-111 166h-4l-111 -166h-129zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
-<glyph unicode="&#xcf;" horiz-adv-x="600" d="M86 1608v176h121v-176h-121zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412zM393 1608v176h121v-176h-121z" />
-<glyph unicode="&#xd0;" horiz-adv-x="1464" d="M86 1313v127h578q330 0 526 -191t196 -528q0 -340 -196 -530.5t-526 -190.5h-320q-66 0 -95.5 29.5t-29.5 95.5v537h-102v122h102v529h-133zM362 172q0 -45 46 -45h241q271 0 429.5 155t158.5 439q0 282 -159.5 437t-428.5 155h-287v-529h336v-122h-336v-490z" />
-<glyph unicode="&#xd1;" horiz-adv-x="1556" d="M86 0v127h88q45 0 45 45v1268h131l735 -1026q22 -32 51 -79.5t48 -78.5l18 -31h4q-10 113 -10 189v901q0 66 29.5 95.5t95.5 29.5h152v-127h-89q-45 0 -45 -45v-1268h-131l-735 1026q-23 31 -52.5 77.5t-48.5 77.5l-18 31h-4q12 -110 12 -186v-901q0 -66 -29 -95.5 t-95 -29.5h-152zM477 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
-<glyph unicode="&#xd2;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM565 1784h156l143 -244h-121z" />
-<glyph unicode="&#xd3;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM743 1540l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xd4;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM563 1540l170 244h144l170 -244h-129l-111 166h-4l-111 -166h-129z" />
-<glyph unicode="&#xd5;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM481 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50 t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
-<glyph unicode="&#xd6;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM592 1608v176h121v-176h-121zM899 1608v176h121v-176h-121z" />
-<glyph unicode="&#xd7;" d="M98 84l443 498l-443 497l84 84l439 -493l438 493l84 -84l-445 -497l445 -498l-84 -84l-438 494l-439 -494z" />
-<glyph unicode="&#xd8;" horiz-adv-x="1626" d="M80 729q0 152 57.5 289t155.5 234.5t233.5 154.5t286.5 57q209 0 387 -110l98 137l84 -61l-96 -136q122 -104 191 -250t69 -315q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-215 0 -391 115l-98 -139l-86 59l100 142q-121 105 -189.5 255t-68.5 322zM229 729 q0 -138 51.5 -257t143.5 -204l696 973q-144 88 -307 88q-159 0 -293 -78.5t-212.5 -216.5t-78.5 -305zM504 203q145 -92 309 -92q120 0 228 48t186 130t124 197t46 243q0 133 -52.5 249.5t-144.5 197.5z" />
-<glyph unicode="&#xd9;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM498 1784h155 l144 -244h-121z" />
-<glyph unicode="&#xda;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM676 1540 l143 244h156l-178 -244h-121z" />
-<glyph unicode="&#xdb;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM496 1540 l170 244h143l170 -244h-129l-111 166h-4l-110 -166h-129z" />
-<glyph unicode="&#xdc;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM524 1608v176 h121v-176h-121zM831 1608v176h121v-176h-121z" />
-<glyph unicode="&#xdd;" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33zM547 1540l143 244h156l-178 -244 h-121z" />
-<glyph unicode="&#xde;" horiz-adv-x="1196" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-131h332q195 0 320 -119t125 -317q0 -197 -126 -318t-323 -121h-328v-309h-143v1268q0 45 -45 45h-88zM362 436h314q144 0 229.5 83.5t85.5 228.5q0 146 -85 227.5t-228 81.5h-316v-621z" />
-<glyph unicode="&#xdf;" horiz-adv-x="1142" d="M41 0v121h84q45 0 45 45v921q0 89 35.5 162t94 119t131.5 71t151 25q159 0 258.5 -90t99.5 -215q0 -56 -23.5 -105.5t-57 -84t-66.5 -65.5t-56.5 -65t-23.5 -67q0 -35 29.5 -70.5t74 -65.5t96 -69t96 -79t74 -97.5t29.5 -122.5q0 -94 -48 -162.5t-121.5 -99.5t-162.5 -31 q-55 0 -108 12.5t-89 30t-64.5 34.5t-42.5 30l-13 12l51 109q5 -4 13.5 -11t35.5 -25t55.5 -31.5t70 -24.5t81.5 -11q85 0 143 43.5t58 128.5q0 47 -30 91.5t-74.5 77t-96.5 70.5t-96.5 72.5t-74.5 83t-30 101.5q0 47 23.5 89.5t57 76t67 66.5t57 73.5t23.5 83.5 q0 71 -59 125.5t-163 54.5q-107 0 -186.5 -69.5t-79.5 -190.5v-952q0 -66 -29.5 -95.5t-95.5 -29.5h-143z" />
-<glyph unicode="&#xe0;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM293 1440h156l143 -244h-121z" />
-<glyph unicode="&#xe1;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM471 1196l143 244h156l-178 -244h-121z" />
-<glyph unicode="&#xe2;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM291 1196l170 244h143l170 -244h-129l-110 166h-5l-110 -166h-129z" />
-<glyph unicode="&#xe3;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM209 1202q0 240 190 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h109q0 -118 -48.5 -179 t-142.5 -61q-38 0 -70.5 15t-54.5 36t-42 42.5t-43.5 36.5t-49.5 15q-45 0 -63.5 -43t-18.5 -96h-106zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26t-74 -41.5t-47.5 -62t-19.5 -86z" />
-<glyph unicode="&#xe4;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM319 1264v176h121v-176h-121zM627 1264v176h121v-176h-121z" />
-<glyph unicode="&#xe5;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM381 1319q0 63 44 104t107 41t107.5 -41t44.5 -104t-44.5 -104t-107.5 -41t-107 41t-44 104zM465 1319q0 -30 18.5 -49t48.5 -19q29 0 48.5 19.5t19.5 48.5q0 31 -19.5 50.5t-48.5 19.5t-48 -19.5t-19 -50.5z" />
-<glyph unicode="&#xe6;" horiz-adv-x="1783" d="M82 281q0 54 14 99.5t37 78.5t59 59.5t71.5 43.5t85 29.5t89 18.5t92.5 10t87.5 4.5t82.5 0.5h68v22q0 159 -62 225t-202 66q-25 0 -54.5 -3.5t-65 -12.5t-58.5 -28t-23 -46v-66h-133v99q0 45 32 79.5t83 54.5t107.5 30t113.5 10q157 0 240 -54.5t116 -158.5h4 q63 105 162.5 159t226.5 54q82 0 151.5 -24.5t119 -67.5t84.5 -100t52 -122.5t17 -134.5l-4 -92h-772q4 -196 111.5 -305t273.5 -109q52 0 103 13t86.5 32t63.5 37.5t42 31.5l14 13l66 -104q-6 -6 -17.5 -16t-49.5 -35.5t-79.5 -45t-105.5 -35.5t-129 -16 q-157 0 -276.5 76.5t-176.5 210.5h-4q-7 -22 -20 -50.5t-45 -72.5t-73 -78.5t-107.5 -60t-143.5 -25.5q-149 0 -251.5 81.5t-102.5 224.5zM225 289q0 -81 61 -138t171 -57q94 0 167.5 59.5t109.5 146t36 179.5v35h-121q-53 0 -93 -2t-93.5 -9t-92 -22.5t-73.5 -39 t-53.5 -62.5t-18.5 -90zM913 625h625q-6 151 -89 231t-200 80q-131 0 -222 -80.5t-114 -230.5z" />
-<glyph unicode="&#xe7;" horiz-adv-x="1081" d="M82 514q0 155 71.5 279t195.5 193t276 69q39 0 83.5 -6t95.5 -22t92 -40t68 -63.5t27 -87.5v-93h-131v60q0 58 -78.5 92.5t-156.5 34.5q-169 0 -284.5 -116t-115.5 -300q0 -123 56 -218.5t147.5 -144.5t200.5 -49q59 0 115 15t93.5 36.5t67 43t43.5 36.5l13 15l65 -105 q-6 -7 -17 -18t-49.5 -40t-82 -51t-114 -40t-145.5 -19l-16 -88q65 -9 104 -47t39 -98q0 -83 -56 -122.5t-140 -39.5q-26 0 -52 2.5t-39 5.5l-12 2v99q39 -13 86 -13q105 0 105 70q0 33 -31 51.5t-86 18.5l-31 -2l39 170q-197 28 -321.5 173t-124.5 357z" />
-<glyph unicode="&#xe8;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM346 1440h156l143 -244h-121z" />
-<glyph unicode="&#xe9;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM524 1196l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xea;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM344 1196l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
-<glyph unicode="&#xeb;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM373 1264v176h121v-176h-121zM680 1264v176h121v-176h-121z" />
-<glyph unicode="&#xec;" horiz-adv-x="516" d="M6 1440h156l141 -244h-121zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86z" />
-<glyph unicode="&#xed;" horiz-adv-x="516" d="M59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM182 1196l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xee;" horiz-adv-x="516" d="M2 1196l172 244h141l172 -244h-129l-110 166h-4l-113 -166h-129zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86z" />
-<glyph unicode="&#xef;" horiz-adv-x="516" d="M51 1264v176h123v-176h-123zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM309 1264v176h121v-176h-121z" />
-<glyph unicode="&#xf0;" horiz-adv-x="1157" d="M76 475q0 93 32 178.5t91.5 153.5t154 108.5t211.5 40.5q55 0 106 -11.5t83.5 -27.5t57.5 -32t36 -27l12 -12h4q-69 198 -254 325l-360 -163l-27 98l277 129q-126 64 -291 104l41 119q237 -60 401 -158l269 121l26 -98l-198 -92q142 -111 225.5 -280.5t83.5 -391.5 q0 -85 -18 -166.5t-58 -157.5t-98 -133.5t-144 -92t-190 -34.5q-109 0 -200 42.5t-150 113t-91 160t-32 184.5zM219 473q0 -96 37.5 -180t115.5 -138.5t181 -54.5q73 0 134.5 26t102.5 69t69.5 100t41 116.5t12.5 120.5q0 134 -92 220t-241 86q-89 0 -159.5 -31 t-113.5 -83.5t-65.5 -116.5t-22.5 -134z" />
-<glyph unicode="&#xf1;" horiz-adv-x="1245" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q16 40 47 81t80 83.5t123.5 69t159.5 26.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-17.5 82t-37 68.5t-65 43.5t-99.5 17 q-131 0 -235.5 -81.5t-139.5 -209.5q-17 -61 -17 -139v-494h-139v864q0 45 -45 45h-86zM326 1202q0 240 190 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h109q0 -118 -48.5 -179t-142.5 -61q-38 0 -70.5 15t-54.5 36t-42 42.5 t-43.5 36.5t-49.5 15q-45 0 -63.5 -43t-18.5 -96h-106z" />
-<glyph unicode="&#xf2;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM387 1440h156l143 -244h-121z" />
-<glyph unicode="&#xf3;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM565 1196l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xf4;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM385 1196l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
-<glyph unicode="&#xf5;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM303 1202q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-38 0 -70.5 15t-54.5 36t-42 42.5t-43.5 36.5t-49.5 15 q-45 0 -63.5 -43t-18.5 -96h-107z" />
-<glyph unicode="&#xf6;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM414 1264v176h121v-176h-121zM721 1264v176h121v-176h-121z" />
-<glyph unicode="&#xf7;" d="M102 522v119h1004v-119h-1004zM526 125v151h154v-151h-154zM526 887v151h154v-151h-154z" />
-<glyph unicode="&#xf8;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q153 0 280 -76l80 113l84 -62l-80 -110q85 -73 132.5 -177t47.5 -223q0 -152 -73 -278t-197 -196.5t-272 -70.5q-145 0 -265 66l-77 -109l-84 62l75 104q-91 75 -142.5 184.5t-51.5 237.5zM225 520q0 -185 129 -311l475 663 q-94 56 -202 56q-167 0 -284.5 -117.5t-117.5 -290.5zM438 150q89 -50 189 -50q166 0 282.5 121t116.5 299q0 171 -119 287z" />
-<glyph unicode="&#xf9;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM365 1440h155l144 -244h-121z" />
-<glyph unicode="&#xfa;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM543 1196l143 244h156l-178 -244h-121z" />
-<glyph unicode="&#xfb;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM362 1196l170 244h144l170 -244h-129l-111 166h-4l-110 -166h-130z" />
-<glyph unicode="&#xfc;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM391 1264v176h121v-176h-121zM698 1264v176h121v-176h-121z" />
-<glyph unicode="&#xfd;" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5zM487 1196l144 244h155l-178 -244h-121z" />
-<glyph unicode="&#xfe;" horiz-adv-x="1196" d="M41 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-367l-4 -90h4q99 197 346 197q208 0 330.5 -149t122.5 -390q0 -242 -122.5 -391.5t-330.5 -149.5q-73 0 -136 20t-100 48.5t-63.5 56.5t-36.5 48l-10 20h-4q4 -37 4 -90v-488h-139v1684q0 45 -45 45h-86zM307 514 q0 -109 28 -191t76 -129.5t106.5 -70.5t125.5 -23q146 0 235 114t89 302q0 186 -89 299t-235 113q-70 0 -129 -22.5t-106.5 -70t-74 -129.5t-26.5 -192z" />
-<glyph unicode="&#xff;" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5zM336 1264v176h121v-176h-121zM643 1264v176h121v-176h-121z" />
-<glyph unicode="&#x152;" horiz-adv-x="1863" d="M78 721q0 205 89 374t248.5 267t356.5 98q50 0 153 -10t138 -10h565q66 0 95.5 -29.5t29.5 -95.5v-144h-133v97q0 45 -45 45h-477v-525h524v-126h-524v-535h536q45 0 45 45v96h133v-143q0 -66 -27.5 -95.5t-86.5 -29.5h-633q-34 0 -138 -10t-155 -10q-148 0 -277.5 57.5 t-220.5 156t-143.5 235.5t-52.5 292zM227 721q0 -171 67 -308.5t192 -216.5t286 -79q119 0 182 14v1176q-72 16 -182 16q-161 0 -286 -79t-192 -216t-67 -307z" />
-<glyph unicode="&#x153;" horiz-adv-x="2068" d="M82 512q0 160 74.5 285t197.5 191.5t271 66.5q154 0 277 -74t190 -203h4q60 132 175.5 204.5t264.5 72.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-790q4 -98 37.5 -177t88.5 -129t125 -77t148 -27q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104 q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-159 0 -282 75t-187 206h-4q-65 -132 -188.5 -206.5t-280.5 -74.5q-110 0 -209 38.5t-173 107t-117.5 170.5t-43.5 221zM225 512q0 -182 116 -297t284 -115q167 0 283 116.5t116 303.5q0 182 -117 295t-282 113 q-168 0 -284 -116t-116 -300zM1180 621h645q-7 153 -88.5 235t-202.5 82q-132 0 -230.5 -83.5t-123.5 -233.5z" />
-<glyph unicode="&#x178;" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33zM395 1608v176h121v-176h-121z M702 1608v176h121v-176h-121z" />
-<glyph unicode="&#x2c6;" horiz-adv-x="962" d="M240 1540l170 244h143l170 -244h-129l-111 166h-4l-110 -166h-129z" />
-<glyph unicode="&#x2dc;" horiz-adv-x="1007" d="M182 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
-<glyph unicode="&#x2000;" horiz-adv-x="904" />
-<glyph unicode="&#x2001;" horiz-adv-x="1808" />
-<glyph unicode="&#x2002;" horiz-adv-x="904" />
-<glyph unicode="&#x2003;" horiz-adv-x="1808" />
-<glyph unicode="&#x2004;" horiz-adv-x="602" />
-<glyph unicode="&#x2005;" horiz-adv-x="452" />
-<glyph unicode="&#x2006;" horiz-adv-x="301" />
-<glyph unicode="&#x2007;" horiz-adv-x="301" />
-<glyph unicode="&#x2008;" horiz-adv-x="226" />
-<glyph unicode="&#x2009;" horiz-adv-x="361" />
-<glyph unicode="&#x200a;" horiz-adv-x="100" />
-<glyph unicode="&#x2010;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
-<glyph unicode="&#x2011;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
-<glyph unicode="&#x2012;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
-<glyph unicode="&#x2013;" horiz-adv-x="1314" d="M145 522v119h1024v-119h-1024z" />
-<glyph unicode="&#x2014;" horiz-adv-x="1724" d="M145 522v119h1434v-119h-1434z" />
-<glyph unicode="&#x2018;" horiz-adv-x="434" d="M104 1106l115 352h111l-80 -352h-146z" />
-<glyph unicode="&#x2019;" horiz-adv-x="434" d="M104 1108l80 352h146l-115 -352h-111z" />
-<glyph unicode="&#x201a;" horiz-adv-x="434" d="M104 -184l80 352h146l-115 -352h-111z" />
-<glyph unicode="&#x201c;" horiz-adv-x="675" d="M104 1106l115 352h111l-80 -352h-146zM346 1106l115 352h110l-79 -352h-146z" />
-<glyph unicode="&#x201d;" horiz-adv-x="675" d="M104 1108l80 352h146l-115 -352h-111zM346 1108l80 352h145l-114 -352h-111z" />
-<glyph unicode="&#x201e;" horiz-adv-x="675" d="M104 -184l80 352h146l-115 -352h-111zM346 -184l80 352h145l-114 -352h-111z" />
-<glyph unicode="&#x2022;" horiz-adv-x="899" d="M158 596q0 122 86 207.5t207 85.5t205.5 -85.5t84.5 -207.5t-84.5 -207.5t-205.5 -85.5t-207 85.5t-86 207.5z" />
-<glyph unicode="&#x2026;" horiz-adv-x="1673" d="M276 0v164h158v-164h-158zM758 0v164h157v-164h-157zM1239 0v164h158v-164h-158z" />
-<glyph unicode="&#x202f;" horiz-adv-x="361" />
-<glyph unicode="&#x2039;" horiz-adv-x="702" d="M78 578l336 421h149l-336 -421l336 -420h-149z" />
-<glyph unicode="&#x203a;" horiz-adv-x="702" d="M135 158l336 420l-336 421h152l336 -421l-336 -420h-152z" />
-<glyph unicode="&#x205f;" horiz-adv-x="452" />
-<glyph unicode="&#x20ac;" horiz-adv-x="1208" d="M80 545v104h117q-4 37 -4 72l4 94h-117v105h135q61 241 249.5 392.5t438.5 151.5q48 0 95.5 -6t70.5 -12l23 -6l-33 -133q-74 22 -158 22q-194 0 -336.5 -111.5t-195.5 -297.5h620l-20 -105h-623q-8 -41 -8 -90l4 -76h596l-18 -104h-553q46 -194 192.5 -314t345.5 -120 q46 0 92.5 7t69.5 14l23 7l32 -131q-94 -33 -219 -33q-258 0 -447.5 158.5t-244.5 411.5h-131z" />
-<glyph unicode="&#x2122;" horiz-adv-x="1998" d="M88 1251v95q0 54 20.5 74t75.5 20h566q55 0 75.5 -20t20.5 -74v-95h-107v62q0 20 -20 20h-195v-790h-116v790h-193q-20 0 -20 -20v-62h-107zM858 543v104h51q20 0 23 21l59 772h107l235 -514q8 -17 15.5 -38t10.5 -34l3 -12h4q11 45 29 84l235 514h107l59 -772 q3 -21 23 -21h51v-104h-88q-55 0 -74.5 19t-24.5 75l-41 514q-1 16 0 29t2 22l1 8h-5l-229 -499h-94l-230 499h-4l2 -59l-41 -514q-5 -56 -24 -75t-74 -19h-88z" />
-<glyph unicode="&#x25fc;" horiz-adv-x="1034" d="M0 0v1034h1034v-1034h-1034z" />
-<hkern u1="&#x20;" u2="&#x2026;" k="102" />
-<hkern u1="&#x20;" u2="&#x201e;" k="102" />
-<hkern u1="&#x20;" u2="&#x201d;" k="143" />
-<hkern u1="&#x20;" u2="&#x201c;" k="143" />
-<hkern u1="&#x20;" u2="&#x201a;" k="102" />
-<hkern u1="&#x20;" u2="&#x2019;" k="143" />
-<hkern u1="&#x20;" u2="&#x2018;" k="143" />
-<hkern u1="&#x20;" u2="&#x178;" k="72" />
-<hkern u1="&#x20;" u2="&#xdd;" k="72" />
-<hkern u1="&#x20;" u2="Y" k="72" />
-<hkern u1="&#x20;" u2="W" k="47" />
-<hkern u1="&#x20;" u2="V" k="47" />
-<hkern u1="&#x20;" u2="T" k="41" />
-<hkern u1="&#x20;" u2="&#x2e;" k="102" />
-<hkern u1="&#x20;" u2="&#x2c;" k="102" />
-<hkern u1="&#x22;" u2="X" k="-41" />
-<hkern u1="&#x22;" u2="&#x34;" k="102" />
-<hkern u1="&#x24;" u2="&#x37;" k="41" />
-<hkern u1="&#x27;" u2="X" k="-41" />
-<hkern u1="&#x27;" u2="&#x34;" k="102" />
-<hkern u1="&#x28;" u2="j" k="-35" />
-<hkern u1="&#x28;" u2="&#x34;" k="82" />
-<hkern u1="&#x2b;" u2="&#x37;" k="39" />
-<hkern u1="&#x2c;" u2="&#x39;" k="10" />
-<hkern u1="&#x2c;" u2="&#x37;" k="39" />
-<hkern u1="&#x2c;" u2="&#x36;" k="20" />
-<hkern u1="&#x2c;" u2="&#x34;" k="35" />
-<hkern u1="&#x2c;" u2="&#x30;" k="41" />
-<hkern u1="&#x2d;" u2="x" k="53" />
-<hkern u1="&#x2d;" u2="X" k="20" />
-<hkern u1="&#x2d;" u2="&#x39;" k="72" />
-<hkern u1="&#x2d;" u2="&#x37;" k="141" />
-<hkern u1="&#x2d;" u2="&#x35;" k="57" />
-<hkern u1="&#x2d;" u2="&#x33;" k="82" />
-<hkern u1="&#x2d;" u2="&#x31;" k="61" />
-<hkern u1="&#x2e;" u2="&#x39;" k="10" />
-<hkern u1="&#x2e;" u2="&#x37;" k="39" />
-<hkern u1="&#x2e;" u2="&#x36;" k="20" />
-<hkern u1="&#x2e;" u2="&#x34;" k="35" />
-<hkern u1="&#x2e;" u2="&#x30;" k="41" />
-<hkern u1="&#x2f;" u2="&#x37;" k="-25" />
-<hkern u1="&#x30;" u2="&#x2026;" k="82" />
-<hkern u1="&#x30;" u2="&#x201e;" k="82" />
-<hkern u1="&#x30;" u2="&#x201a;" k="82" />
-<hkern u1="&#x30;" u2="&#xb0;" k="20" />
-<hkern u1="&#x30;" u2="&#x38;" k="23" />
-<hkern u1="&#x30;" u2="&#x37;" k="57" />
-<hkern u1="&#x30;" u2="&#x33;" k="16" />
-<hkern u1="&#x30;" u2="&#x32;" k="23" />
-<hkern u1="&#x30;" u2="&#x31;" k="31" />
-<hkern u1="&#x30;" u2="&#x2e;" k="82" />
-<hkern u1="&#x30;" u2="&#x2c;" k="82" />
-<hkern u1="&#x31;" u2="&#x201d;" k="102" />
-<hkern u1="&#x31;" u2="&#x201c;" k="102" />
-<hkern u1="&#x31;" u2="&#x2019;" k="102" />
-<hkern u1="&#x31;" u2="&#x2018;" k="102" />
-<hkern u1="&#x31;" u2="&#x2014;" k="102" />
-<hkern u1="&#x31;" u2="&#x2013;" k="102" />
-<hkern u1="&#x31;" u2="&#xb0;" k="143" />
-<hkern u1="&#x31;" u2="&#x39;" k="23" />
-<hkern u1="&#x31;" u2="&#x38;" k="14" />
-<hkern u1="&#x31;" u2="&#x37;" k="20" />
-<hkern u1="&#x31;" u2="&#x36;" k="23" />
-<hkern u1="&#x31;" u2="&#x35;" k="14" />
-<hkern u1="&#x31;" u2="&#x34;" k="37" />
-<hkern u1="&#x31;" u2="&#x33;" k="8" />
-<hkern u1="&#x31;" u2="&#x30;" k="31" />
-<hkern u1="&#x31;" u2="&#x2f;" k="-57" />
-<hkern u1="&#x31;" u2="&#x2d;" k="102" />
-<hkern u1="&#x31;" u2="&#x27;" k="123" />
-<hkern u1="&#x31;" u2="&#x25;" k="45" />
-<hkern u1="&#x31;" u2="&#x22;" k="123" />
-<hkern u1="&#x32;" u2="&#x2014;" k="57" />
-<hkern u1="&#x32;" u2="&#x2013;" k="57" />
-<hkern u1="&#x32;" u2="&#x39;" k="37" />
-<hkern u1="&#x32;" u2="&#x37;" k="6" />
-<hkern u1="&#x32;" u2="&#x34;" k="41" />
-<hkern u1="&#x32;" u2="&#x30;" k="10" />
-<hkern u1="&#x32;" u2="&#x2d;" k="57" />
-<hkern u1="&#x33;" u2="&#x39;" k="10" />
-<hkern u1="&#x33;" u2="&#x37;" k="10" />
-<hkern u1="&#x34;" u2="&#x2026;" k="20" />
-<hkern u1="&#x34;" u2="&#x201e;" k="20" />
-<hkern u1="&#x34;" u2="&#x201d;" k="41" />
-<hkern u1="&#x34;" u2="&#x201c;" k="41" />
-<hkern u1="&#x34;" u2="&#x201a;" k="20" />
-<hkern u1="&#x34;" u2="&#x2019;" k="41" />
-<hkern u1="&#x34;" u2="&#x2018;" k="41" />
-<hkern u1="&#x34;" u2="&#xb0;" k="41" />
-<hkern u1="&#x34;" u2="&#x39;" k="20" />
-<hkern u1="&#x34;" u2="&#x34;" k="-61" />
-<hkern u1="&#x34;" u2="&#x32;" k="-41" />
-<hkern u1="&#x34;" u2="&#x31;" k="14" />
-<hkern u1="&#x34;" u2="&#x2e;" k="20" />
-<hkern u1="&#x34;" u2="&#x2c;" k="20" />
-<hkern u1="&#x35;" u2="&#x2026;" k="27" />
-<hkern u1="&#x35;" u2="&#x201e;" k="27" />
-<hkern u1="&#x35;" u2="&#x201a;" k="27" />
-<hkern u1="&#x35;" u2="&#xb0;" k="41" />
-<hkern u1="&#x35;" u2="&#x39;" k="6" />
-<hkern u1="&#x35;" u2="&#x37;" k="35" />
-<hkern u1="&#x35;" u2="&#x35;" k="16" />
-<hkern u1="&#x35;" u2="&#x33;" k="16" />
-<hkern u1="&#x35;" u2="&#x32;" k="10" />
-<hkern u1="&#x35;" u2="&#x31;" k="41" />
-<hkern u1="&#x35;" u2="&#x30;" k="14" />
-<hkern u1="&#x35;" u2="&#x2e;" k="27" />
-<hkern u1="&#x35;" u2="&#x2c;" k="27" />
-<hkern u1="&#x36;" u2="&#x2014;" k="27" />
-<hkern u1="&#x36;" u2="&#x2013;" k="27" />
-<hkern u1="&#x36;" u2="&#x39;" k="20" />
-<hkern u1="&#x36;" u2="&#x37;" k="18" />
-<hkern u1="&#x36;" u2="&#x35;" k="10" />
-<hkern u1="&#x36;" u2="&#x33;" k="10" />
-<hkern u1="&#x36;" u2="&#x30;" k="16" />
-<hkern u1="&#x36;" u2="&#x2d;" k="27" />
-<hkern u1="&#x37;" u2="&#x203a;" k="49" />
-<hkern u1="&#x37;" u2="&#x2039;" k="49" />
-<hkern u1="&#x37;" u2="&#x2026;" k="246" />
-<hkern u1="&#x37;" u2="&#x201e;" k="246" />
-<hkern u1="&#x37;" u2="&#x201d;" k="-72" />
-<hkern u1="&#x37;" u2="&#x201c;" k="-72" />
-<hkern u1="&#x37;" u2="&#x201a;" k="246" />
-<hkern u1="&#x37;" u2="&#x2019;" k="-72" />
-<hkern u1="&#x37;" u2="&#x2018;" k="-72" />
-<hkern u1="&#x37;" u2="&#x2014;" k="111" />
-<hkern u1="&#x37;" u2="&#x2013;" k="111" />
-<hkern u1="&#x37;" u2="&#xbb;" k="49" />
-<hkern u1="&#x37;" u2="&#xb0;" k="-61" />
-<hkern u1="&#x37;" u2="&#xab;" k="49" />
-<hkern u1="&#x37;" u2="&#x3f;" k="-37" />
-<hkern u1="&#x37;" u2="&#x3e;" k="80" />
-<hkern u1="&#x37;" u2="&#x3d;" k="80" />
-<hkern u1="&#x37;" u2="&#x3c;" k="80" />
-<hkern u1="&#x37;" u2="&#x3b;" k="31" />
-<hkern u1="&#x37;" u2="&#x3a;" k="31" />
-<hkern u1="&#x37;" u2="&#x39;" k="18" />
-<hkern u1="&#x37;" u2="&#x38;" k="14" />
-<hkern u1="&#x37;" u2="&#x37;" k="-10" />
-<hkern u1="&#x37;" u2="&#x35;" k="6" />
-<hkern u1="&#x37;" u2="&#x34;" k="119" />
-<hkern u1="&#x37;" u2="&#x32;" k="14" />
-<hkern u1="&#x37;" u2="&#x31;" k="2" />
-<hkern u1="&#x37;" u2="&#x30;" k="41" />
-<hkern u1="&#x37;" u2="&#x2f;" k="123" />
-<hkern u1="&#x37;" u2="&#x2e;" k="246" />
-<hkern u1="&#x37;" u2="&#x2d;" k="111" />
-<hkern u1="&#x37;" u2="&#x2c;" k="246" />
-<hkern u1="&#x37;" u2="&#x2b;" k="80" />
-<hkern u1="&#x38;" u2="&#x39;" k="14" />
-<hkern u1="&#x38;" u2="&#x37;" k="25" />
-<hkern u1="&#x38;" u2="&#x34;" k="-6" />
-<hkern u1="&#x38;" u2="&#x30;" k="23" />
-<hkern u1="&#x39;" u2="&#x2026;" k="82" />
-<hkern u1="&#x39;" u2="&#x201e;" k="82" />
-<hkern u1="&#x39;" u2="&#x201a;" k="82" />
-<hkern u1="&#x39;" u2="&#x38;" k="10" />
-<hkern u1="&#x39;" u2="&#x37;" k="27" />
-<hkern u1="&#x39;" u2="&#x33;" k="10" />
-<hkern u1="&#x39;" u2="&#x32;" k="10" />
-<hkern u1="&#x39;" u2="&#x31;" k="2" />
-<hkern u1="&#x39;" u2="&#x30;" k="10" />
-<hkern u1="&#x39;" u2="&#x2e;" k="82" />
-<hkern u1="&#x39;" u2="&#x2c;" k="82" />
-<hkern u1="&#x3c;" u2="&#x37;" k="39" />
-<hkern u1="&#x3d;" u2="&#x37;" k="39" />
-<hkern u1="&#x3e;" u2="&#x37;" k="39" />
-<hkern u1="A" u2="X" k="18" />
-<hkern u1="B" u2="&#x201d;" k="35" />
-<hkern u1="B" u2="&#x201c;" k="35" />
-<hkern u1="B" u2="&#x2019;" k="35" />
-<hkern u1="B" u2="&#x2018;" k="35" />
-<hkern u1="B" u2="&#x178;" k="51" />
-<hkern u1="B" u2="&#xdd;" k="51" />
-<hkern u1="B" u2="w" k="10" />
-<hkern u1="B" u2="v" k="10" />
-<hkern u1="B" u2="Y" k="51" />
-<hkern u1="B" u2="W" k="25" />
-<hkern u1="B" u2="V" k="25" />
-<hkern u1="B" u2="T" k="39" />
-<hkern u1="B" u2="&#x27;" k="12" />
-<hkern u1="B" u2="&#x22;" k="12" />
-<hkern u1="D" u2="i" k="-14" />
-<hkern u1="D" u2="X" k="23" />
-<hkern u1="F" u2="&#x2026;" k="205" />
-<hkern u1="F" u2="&#x201e;" k="205" />
-<hkern u1="F" u2="&#x201d;" k="-51" />
-<hkern u1="F" u2="&#x201c;" k="-51" />
-<hkern u1="F" u2="&#x201a;" k="205" />
-<hkern u1="F" u2="&#x2019;" k="-51" />
-<hkern u1="F" u2="&#x2018;" k="-51" />
-<hkern u1="F" u2="&#x153;" k="10" />
-<hkern u1="F" u2="&#x152;" k="20" />
-<hkern u1="F" u2="&#xf8;" k="10" />
-<hkern u1="F" u2="&#xf6;" k="10" />
-<hkern u1="F" u2="&#xf5;" k="10" />
-<hkern u1="F" u2="&#xf4;" k="10" />
-<hkern u1="F" u2="&#xf3;" k="10" />
-<hkern u1="F" u2="&#xf2;" k="10" />
-<hkern u1="F" u2="&#xeb;" k="10" />
-<hkern u1="F" u2="&#xea;" k="10" />
-<hkern u1="F" u2="&#xe9;" k="10" />
-<hkern u1="F" u2="&#xe8;" k="10" />
-<hkern u1="F" u2="&#xe7;" k="10" />
-<hkern u1="F" u2="&#xe6;" k="31" />
-<hkern u1="F" u2="&#xe5;" k="31" />
-<hkern u1="F" u2="&#xe4;" k="31" />
-<hkern u1="F" u2="&#xe3;" k="31" />
-<hkern u1="F" u2="&#xe2;" k="31" />
-<hkern u1="F" u2="&#xe1;" k="31" />
-<hkern u1="F" u2="&#xe0;" k="31" />
-<hkern u1="F" u2="&#xd8;" k="20" />
-<hkern u1="F" u2="&#xd6;" k="20" />
-<hkern u1="F" u2="&#xd5;" k="20" />
-<hkern u1="F" u2="&#xd4;" k="20" />
-<hkern u1="F" u2="&#xd3;" k="20" />
-<hkern u1="F" u2="&#xd2;" k="20" />
-<hkern u1="F" u2="&#xc7;" k="20" />
-<hkern u1="F" u2="&#xc6;" k="94" />
-<hkern u1="F" u2="&#xc5;" k="94" />
-<hkern u1="F" u2="&#xc4;" k="94" />
-<hkern u1="F" u2="&#xc3;" k="94" />
-<hkern u1="F" u2="&#xc2;" k="94" />
-<hkern u1="F" u2="&#xc1;" k="94" />
-<hkern u1="F" u2="&#xc0;" k="94" />
-<hkern u1="F" u2="q" k="10" />
-<hkern u1="F" u2="o" k="10" />
-<hkern u1="F" u2="g" k="10" />
-<hkern u1="F" u2="e" k="10" />
-<hkern u1="F" u2="d" k="10" />
-<hkern u1="F" u2="c" k="10" />
-<hkern u1="F" u2="a" k="31" />
-<hkern u1="F" u2="Q" k="20" />
-<hkern u1="F" u2="O" k="20" />
-<hkern u1="F" u2="N" k="14" />
-<hkern u1="F" u2="M" k="14" />
-<hkern u1="F" u2="J" k="37" />
-<hkern u1="F" u2="G" k="20" />
-<hkern u1="F" u2="C" k="20" />
-<hkern u1="F" u2="A" k="94" />
-<hkern u1="F" u2="&#x40;" k="10" />
-<hkern u1="F" u2="&#x2e;" k="205" />
-<hkern u1="F" u2="&#x2c;" k="205" />
-<hkern u1="F" u2="&#x27;" k="-39" />
-<hkern u1="F" u2="&#x22;" k="-39" />
-<hkern u1="K" u2="x" k="10" />
-<hkern u1="L" u2="&#x2a;" k="158" />
-<hkern u1="M" u2="&#x201d;" k="59" />
-<hkern u1="M" u2="&#x201c;" k="59" />
-<hkern u1="M" u2="&#x2019;" k="59" />
-<hkern u1="M" u2="&#x2018;" k="59" />
-<hkern u1="M" u2="&#xfc;" k="-8" />
-<hkern u1="M" u2="&#xfb;" k="-8" />
-<hkern u1="M" u2="&#xfa;" k="-8" />
-<hkern u1="M" u2="&#xf9;" k="-8" />
-<hkern u1="M" u2="&#xf1;" k="-8" />
-<hkern u1="M" u2="u" k="-8" />
-<hkern u1="M" u2="r" k="-8" />
-<hkern u1="M" u2="p" k="-8" />
-<hkern u1="M" u2="n" k="-8" />
-<hkern u1="M" u2="m" k="-8" />
-<hkern u1="M" u2="T" k="35" />
-<hkern u1="M" u2="&#x27;" k="61" />
-<hkern u1="M" u2="&#x22;" k="61" />
-<hkern u1="O" u2="i" k="-14" />
-<hkern u1="O" u2="X" k="23" />
-<hkern u1="P" u2="&#x2026;" k="215" />
-<hkern u1="P" u2="&#x201e;" k="215" />
-<hkern u1="P" u2="&#x201a;" k="215" />
-<hkern u1="P" u2="&#x153;" k="41" />
-<hkern u1="P" u2="&#xf8;" k="41" />
-<hkern u1="P" u2="&#xf6;" k="41" />
-<hkern u1="P" u2="&#xf5;" k="41" />
-<hkern u1="P" u2="&#xf4;" k="41" />
-<hkern u1="P" u2="&#xf3;" k="41" />
-<hkern u1="P" u2="&#xf2;" k="41" />
-<hkern u1="P" u2="&#xeb;" k="41" />
-<hkern u1="P" u2="&#xea;" k="41" />
-<hkern u1="P" u2="&#xe9;" k="41" />
-<hkern u1="P" u2="&#xe8;" k="41" />
-<hkern u1="P" u2="&#xe7;" k="41" />
-<hkern u1="P" u2="&#xe6;" k="41" />
-<hkern u1="P" u2="&#xe5;" k="41" />
-<hkern u1="P" u2="&#xe4;" k="41" />
-<hkern u1="P" u2="&#xe3;" k="41" />
-<hkern u1="P" u2="&#xe2;" k="41" />
-<hkern u1="P" u2="&#xe1;" k="41" />
-<hkern u1="P" u2="&#xe0;" k="41" />
-<hkern u1="P" u2="&#xc6;" k="121" />
-<hkern u1="P" u2="&#xc5;" k="121" />
-<hkern u1="P" u2="&#xc4;" k="121" />
-<hkern u1="P" u2="&#xc3;" k="121" />
-<hkern u1="P" u2="&#xc2;" k="121" />
-<hkern u1="P" u2="&#xc1;" k="121" />
-<hkern u1="P" u2="&#xc0;" k="121" />
-<hkern u1="P" u2="z" k="10" />
-<hkern u1="P" u2="s" k="23" />
-<hkern u1="P" u2="q" k="41" />
-<hkern u1="P" u2="o" k="41" />
-<hkern u1="P" u2="g" k="41" />
-<hkern u1="P" u2="e" k="41" />
-<hkern u1="P" u2="d" k="41" />
-<hkern u1="P" u2="c" k="41" />
-<hkern u1="P" u2="a" k="41" />
-<hkern u1="P" u2="N" k="14" />
-<hkern u1="P" u2="M" k="14" />
-<hkern u1="P" u2="J" k="39" />
-<hkern u1="P" u2="A" k="121" />
-<hkern u1="P" u2="&#x40;" k="41" />
-<hkern u1="P" u2="&#x2e;" k="215" />
-<hkern u1="P" u2="&#x2c;" k="215" />
-<hkern u1="P" u2="&#x27;" k="-10" />
-<hkern u1="P" u2="&#x22;" k="-10" />
-<hkern u1="Q" u2="i" k="-14" />
-<hkern u1="Q" u2="X" k="23" />
-<hkern u1="T" u2="&#xef;" k="-61" />
-<hkern u1="T" u2="j" k="82" />
-<hkern u1="T" u2="i" k="74" />
-<hkern u1="T" u2="&#x20;" k="41" />
-<hkern u1="V" u2="&#x20;" k="47" />
-<hkern u1="W" u2="&#x20;" k="47" />
-<hkern u1="X" u2="&#x201d;" k="-27" />
-<hkern u1="X" u2="&#x201c;" k="-27" />
-<hkern u1="X" u2="&#x2019;" k="-27" />
-<hkern u1="X" u2="&#x2018;" k="-27" />
-<hkern u1="X" u2="&#x2014;" k="20" />
-<hkern u1="X" u2="&#x2013;" k="20" />
-<hkern u1="X" u2="&#x153;" k="14" />
-<hkern u1="X" u2="&#x152;" k="23" />
-<hkern u1="X" u2="&#xf8;" k="14" />
-<hkern u1="X" u2="&#xf6;" k="14" />
-<hkern u1="X" u2="&#xf5;" k="14" />
-<hkern u1="X" u2="&#xf4;" k="14" />
-<hkern u1="X" u2="&#xf3;" k="14" />
-<hkern u1="X" u2="&#xf2;" k="14" />
-<hkern u1="X" u2="&#xeb;" k="14" />
-<hkern u1="X" u2="&#xea;" k="14" />
-<hkern u1="X" u2="&#xe9;" k="14" />
-<hkern u1="X" u2="&#xe8;" k="14" />
-<hkern u1="X" u2="&#xe7;" k="14" />
-<hkern u1="X" u2="&#xd8;" k="23" />
-<hkern u1="X" u2="&#xd6;" k="23" />
-<hkern u1="X" u2="&#xd5;" k="23" />
-<hkern u1="X" u2="&#xd4;" k="23" />
-<hkern u1="X" u2="&#xd3;" k="23" />
-<hkern u1="X" u2="&#xd2;" k="23" />
-<hkern u1="X" u2="&#xc7;" k="23" />
-<hkern u1="X" u2="&#xc6;" k="18" />
-<hkern u1="X" u2="&#xc5;" k="18" />
-<hkern u1="X" u2="&#xc4;" k="18" />
-<hkern u1="X" u2="&#xc3;" k="18" />
-<hkern u1="X" u2="&#xc2;" k="18" />
-<hkern u1="X" u2="&#xc1;" k="18" />
-<hkern u1="X" u2="&#xc0;" k="18" />
-<hkern u1="X" u2="&#x7d;" k="-41" />
-<hkern u1="X" u2="&#x7c;" k="-41" />
-<hkern u1="X" u2="q" k="14" />
-<hkern u1="X" u2="o" k="14" />
-<hkern u1="X" u2="g" k="14" />
-<hkern u1="X" u2="e" k="14" />
-<hkern u1="X" u2="d" k="14" />
-<hkern u1="X" u2="c" k="14" />
-<hkern u1="X" u2="]" k="-41" />
-<hkern u1="X" u2="Q" k="23" />
-<hkern u1="X" u2="O" k="23" />
-<hkern u1="X" u2="G" k="23" />
-<hkern u1="X" u2="C" k="23" />
-<hkern u1="X" u2="A" k="18" />
-<hkern u1="X" u2="&#x40;" k="14" />
-<hkern u1="X" u2="&#x2d;" k="20" />
-<hkern u1="X" u2="&#x29;" k="-41" />
-<hkern u1="X" u2="&#x27;" k="-41" />
-<hkern u1="X" u2="&#x22;" k="-41" />
-<hkern u1="Y" u2="&#x20;" k="72" />
-<hkern u1="[" u2="j" k="-35" />
-<hkern u1="[" u2="&#x34;" k="82" />
-<hkern u1="c" u2="&#xff;" k="10" />
-<hkern u1="c" u2="&#xfd;" k="10" />
-<hkern u1="c" u2="y" k="10" />
-<hkern u1="c" u2="l" k="6" />
-<hkern u1="c" u2="k" k="6" />
-<hkern u1="c" u2="h" k="6" />
-<hkern u1="c" u2="b" k="6" />
-<hkern u1="c" u2="T" k="61" />
-<hkern u1="k" u2="&#x201d;" k="-20" />
-<hkern u1="k" u2="&#x201c;" k="-20" />
-<hkern u1="k" u2="&#x2019;" k="-20" />
-<hkern u1="k" u2="&#x2018;" k="-20" />
-<hkern u1="k" u2="&#x153;" k="20" />
-<hkern u1="k" u2="&#xff;" k="23" />
-<hkern u1="k" u2="&#xfd;" k="23" />
-<hkern u1="k" u2="&#xf8;" k="20" />
-<hkern u1="k" u2="&#xf6;" k="20" />
-<hkern u1="k" u2="&#xf5;" k="20" />
-<hkern u1="k" u2="&#xf4;" k="20" />
-<hkern u1="k" u2="&#xf3;" k="20" />
-<hkern u1="k" u2="&#xf2;" k="20" />
-<hkern u1="k" u2="&#xeb;" k="20" />
-<hkern u1="k" u2="&#xea;" k="20" />
-<hkern u1="k" u2="&#xe9;" k="20" />
-<hkern u1="k" u2="&#xe8;" k="20" />
-<hkern u1="k" u2="&#xe7;" k="20" />
-<hkern u1="k" u2="&#xe6;" k="14" />
-<hkern u1="k" u2="&#xe5;" k="14" />
-<hkern u1="k" u2="&#xe4;" k="14" />
-<hkern u1="k" u2="&#xe3;" k="14" />
-<hkern u1="k" u2="&#xe2;" k="14" />
-<hkern u1="k" u2="&#xe1;" k="14" />
-<hkern u1="k" u2="&#xe0;" k="14" />
-<hkern u1="k" u2="y" k="23" />
-<hkern u1="k" u2="w" k="23" />
-<hkern u1="k" u2="v" k="23" />
-<hkern u1="k" u2="q" k="20" />
-<hkern u1="k" u2="o" k="20" />
-<hkern u1="k" u2="l" k="14" />
-<hkern u1="k" u2="k" k="14" />
-<hkern u1="k" u2="h" k="14" />
-<hkern u1="k" u2="g" k="20" />
-<hkern u1="k" u2="e" k="20" />
-<hkern u1="k" u2="d" k="20" />
-<hkern u1="k" u2="c" k="20" />
-<hkern u1="k" u2="b" k="14" />
-<hkern u1="k" u2="a" k="14" />
-<hkern u1="k" u2="T" k="41" />
-<hkern u1="k" u2="&#x40;" k="20" />
-<hkern u1="x" u2="&#x201d;" k="-41" />
-<hkern u1="x" u2="&#x201c;" k="-41" />
-<hkern u1="x" u2="&#x2019;" k="-41" />
-<hkern u1="x" u2="&#x2018;" k="-41" />
-<hkern u1="x" u2="&#x2014;" k="53" />
-<hkern u1="x" u2="&#x2013;" k="53" />
-<hkern u1="x" u2="&#x2d;" k="53" />
-<hkern u1="&#x7b;" u2="j" k="-35" />
-<hkern u1="&#x7b;" u2="&#x34;" k="82" />
-<hkern u1="&#x7c;" u2="j" k="-35" />
-<hkern u1="&#x7c;" u2="&#x34;" k="82" />
-<hkern u1="&#xa3;" u2="&#x37;" k="35" />
-<hkern u1="&#xa5;" u2="&#x37;" k="-25" />
-<hkern u1="&#xa5;" u2="&#x34;" k="55" />
-<hkern u1="&#xab;" u2="&#x37;" k="66" />
-<hkern u1="&#xbb;" u2="&#x37;" k="66" />
-<hkern u1="&#xc0;" u2="X" k="18" />
-<hkern u1="&#xc1;" u2="X" k="18" />
-<hkern u1="&#xc2;" u2="X" k="18" />
-<hkern u1="&#xc3;" u2="X" k="18" />
-<hkern u1="&#xc4;" u2="X" k="18" />
-<hkern u1="&#xc5;" u2="X" k="18" />
-<hkern u1="&#xd0;" u2="i" k="-14" />
-<hkern u1="&#xd0;" u2="X" k="23" />
-<hkern u1="&#xd2;" u2="i" k="-14" />
-<hkern u1="&#xd2;" u2="X" k="23" />
-<hkern u1="&#xd3;" u2="i" k="-14" />
-<hkern u1="&#xd3;" u2="X" k="23" />
-<hkern u1="&#xd4;" u2="i" k="-14" />
-<hkern u1="&#xd4;" u2="X" k="23" />
-<hkern u1="&#xd5;" u2="i" k="-14" />
-<hkern u1="&#xd5;" u2="X" k="23" />
-<hkern u1="&#xd6;" u2="i" k="-14" />
-<hkern u1="&#xd6;" u2="X" k="23" />
-<hkern u1="&#xd8;" u2="i" k="-14" />
-<hkern u1="&#xd8;" u2="X" k="23" />
-<hkern u1="&#xdd;" u2="&#x20;" k="72" />
-<hkern u1="&#x178;" u2="&#x20;" k="72" />
-<hkern u1="&#x2013;" u2="x" k="53" />
-<hkern u1="&#x2013;" u2="X" k="20" />
-<hkern u1="&#x2013;" u2="&#x39;" k="72" />
-<hkern u1="&#x2013;" u2="&#x37;" k="141" />
-<hkern u1="&#x2013;" u2="&#x35;" k="57" />
-<hkern u1="&#x2013;" u2="&#x33;" k="82" />
-<hkern u1="&#x2013;" u2="&#x31;" k="61" />
-<hkern u1="&#x2014;" u2="x" k="53" />
-<hkern u1="&#x2014;" u2="X" k="20" />
-<hkern u1="&#x2014;" u2="&#x39;" k="72" />
-<hkern u1="&#x2014;" u2="&#x37;" k="141" />
-<hkern u1="&#x2014;" u2="&#x35;" k="57" />
-<hkern u1="&#x2014;" u2="&#x33;" k="82" />
-<hkern u1="&#x2014;" u2="&#x31;" k="61" />
-<hkern u1="&#x2018;" u2="X" k="-27" />
-<hkern u1="&#x2018;" u2="&#x38;" k="57" />
-<hkern u1="&#x2018;" u2="&#x37;" k="-43" />
-<hkern u1="&#x2018;" u2="&#x36;" k="82" />
-<hkern u1="&#x2018;" u2="&#x34;" k="180" />
-<hkern u1="&#x2018;" u2="&#x30;" k="57" />
-<hkern u1="&#x2019;" u2="X" k="-27" />
-<hkern u1="&#x2019;" u2="&#x38;" k="57" />
-<hkern u1="&#x2019;" u2="&#x37;" k="-43" />
-<hkern u1="&#x2019;" u2="&#x36;" k="82" />
-<hkern u1="&#x2019;" u2="&#x34;" k="180" />
-<hkern u1="&#x2019;" u2="&#x30;" k="57" />
-<hkern u1="&#x201a;" u2="&#x39;" k="10" />
-<hkern u1="&#x201a;" u2="&#x37;" k="39" />
-<hkern u1="&#x201a;" u2="&#x36;" k="20" />
-<hkern u1="&#x201a;" u2="&#x34;" k="35" />
-<hkern u1="&#x201a;" u2="&#x30;" k="41" />
-<hkern u1="&#x201c;" u2="X" k="-27" />
-<hkern u1="&#x201c;" u2="&#x38;" k="57" />
-<hkern u1="&#x201c;" u2="&#x37;" k="-43" />
-<hkern u1="&#x201c;" u2="&#x36;" k="82" />
-<hkern u1="&#x201c;" u2="&#x34;" k="180" />
-<hkern u1="&#x201c;" u2="&#x30;" k="57" />
-<hkern u1="&#x201d;" u2="X" k="-27" />
-<hkern u1="&#x201d;" u2="&#x38;" k="57" />
-<hkern u1="&#x201d;" u2="&#x37;" k="-43" />
-<hkern u1="&#x201d;" u2="&#x36;" k="82" />
-<hkern u1="&#x201d;" u2="&#x34;" k="180" />
-<hkern u1="&#x201d;" u2="&#x30;" k="57" />
-<hkern u1="&#x201e;" u2="&#x39;" k="10" />
-<hkern u1="&#x201e;" u2="&#x37;" k="39" />
-<hkern u1="&#x201e;" u2="&#x36;" k="20" />
-<hkern u1="&#x201e;" u2="&#x34;" k="35" />
-<hkern u1="&#x201e;" u2="&#x30;" k="41" />
-<hkern u1="&#x2026;" u2="&#x39;" k="10" />
-<hkern u1="&#x2026;" u2="&#x37;" k="39" />
-<hkern u1="&#x2026;" u2="&#x36;" k="20" />
-<hkern u1="&#x2026;" u2="&#x34;" k="35" />
-<hkern u1="&#x2026;" u2="&#x30;" k="41" />
-<hkern u1="&#x2039;" u2="&#x37;" k="66" />
-<hkern u1="&#x203a;" u2="&#x37;" k="66" />
-<hkern g1="C,Ccedilla"         g2="Y,Yacute,Ydieresis"         k="20" />
-<hkern g1="C,Ccedilla"         g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="10" />
-<hkern g1="C,Ccedilla"         g2="quotedbl,quotesingle"       k="-47" />
-<hkern g1="C,Ccedilla"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-51" />
-<hkern g1="C,Ccedilla"         g2="parenright,bracketright,bar,braceright"     k="-53" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="T"  k="39" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="Y,Yacute,Ydieresis"         k="72" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="V,W"        k="20" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-10" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="v,w"        k="-6" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="y,yacute,ydieresis"         k="-6" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="hyphen,endash,emdash"       k="-31" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quotedbl,quotesingle"       k="20" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="12" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="27" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="T"  k="14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="V,W"        k="31" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="v,w"        k="6" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="J"  k="-14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="f,uniFB01,uniFB02,uniFB03,uniFB04"  k="-12" />
-<hkern g1="G"  g2="T"  k="33" />
-<hkern g1="G"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="16" />
-<hkern g1="G"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-18" />
-<hkern g1="G"  g2="hyphen,endash,emdash"       k="-41" />
-<hkern g1="G"  g2="quotedbl,quotesingle"       k="10" />
-<hkern g1="G"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="41" />
-<hkern g1="G"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-18" />
-<hkern g1="G"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-18" />
-<hkern g1="G"  g2="colon,semicolon"    k="-55" />
-<hkern g1="G"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="12" />
-<hkern g1="H,N,Ntilde"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="20" />
-<hkern g1="H,N,Ntilde"         g2="v,w"        k="20" />
-<hkern g1="H,N,Ntilde"         g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="H,N,Ntilde"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="41" />
-<hkern g1="H,N,Ntilde"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="10" />
-<hkern g1="J"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="27" />
-<hkern g1="J"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
-<hkern g1="J"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="20" />
-<hkern g1="J"  g2="colon,semicolon"    k="35" />
-<hkern g1="K"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="47" />
-<hkern g1="K"  g2="v,w"        k="61" />
-<hkern g1="K"  g2="y,yacute,ydieresis"         k="41" />
-<hkern g1="K"  g2="hyphen,endash,emdash"       k="84" />
-<hkern g1="K"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="6" />
-<hkern g1="K"  g2="parenright,bracketright,bar,braceright"     k="-51" />
-<hkern g1="K"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
-<hkern g1="K"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="K"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="18" />
-<hkern g1="K"  g2="colon,semicolon"    k="-61" />
-<hkern g1="K"  g2="z"  k="20" />
-<hkern g1="K"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="16" />
-<hkern g1="L"  g2="T"  k="205" />
-<hkern g1="L"  g2="Y,Yacute,Ydieresis"         k="164" />
-<hkern g1="L"  g2="V,W"        k="82" />
-<hkern g1="L"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="41" />
-<hkern g1="L"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="76" />
-<hkern g1="L"  g2="v,w"        k="98" />
-<hkern g1="L"  g2="y,yacute,ydieresis"         k="80" />
-<hkern g1="L"  g2="hyphen,endash,emdash"       k="61" />
-<hkern g1="L"  g2="quotedbl,quotesingle"       k="166" />
-<hkern g1="L"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="123" />
-<hkern g1="L"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-20" />
-<hkern g1="L"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="L"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="L"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="10" />
-<hkern g1="L"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="63" />
-<hkern g1="L"  g2="b,h,k,l"    k="27" />
-<hkern g1="R"  g2="T"  k="47" />
-<hkern g1="R"  g2="Y,Yacute,Ydieresis"         k="61" />
-<hkern g1="R"  g2="V,W"        k="10" />
-<hkern g1="R"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="6" />
-<hkern g1="R"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="37" />
-<hkern g1="R"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
-<hkern g1="R"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="R"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
-<hkern g1="R"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
-<hkern g1="S"  g2="hyphen,endash,emdash"       k="-14" />
-<hkern g1="S"  g2="quotedbl,quotesingle"       k="-14" />
-<hkern g1="S"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
-<hkern g1="S"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-10" />
-<hkern g1="S"  g2="z"  k="10" />
-<hkern g1="T"  g2="Y,Yacute,Ydieresis"         k="-20" />
-<hkern g1="T"  g2="V,W"        k="-14" />
-<hkern g1="T"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="39" />
-<hkern g1="T"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="123" />
-<hkern g1="T"  g2="v,w"        k="127" />
-<hkern g1="T"  g2="y,yacute,ydieresis"         k="133" />
-<hkern g1="T"  g2="hyphen,endash,emdash"       k="123" />
-<hkern g1="T"  g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="T"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
-<hkern g1="T"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="178" />
-<hkern g1="T"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="154" />
-<hkern g1="T"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="92" />
-<hkern g1="T"  g2="J"  k="102" />
-<hkern g1="T"  g2="z"  k="127" />
-<hkern g1="T"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="61" />
-<hkern g1="T"  g2="M,N"        k="23" />
-<hkern g1="T"  g2="s"  k="96" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="41" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="M,N"        k="10" />
-<hkern g1="V,W"        g2="T"  k="-14" />
-<hkern g1="V,W"        g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="V,W"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="96" />
-<hkern g1="V,W"        g2="hyphen,endash,emdash"       k="61" />
-<hkern g1="V,W"        g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="V,W"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-10" />
-<hkern g1="V,W"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
-<hkern g1="V,W"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="70" />
-<hkern g1="V,W"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="109" />
-<hkern g1="V,W"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="41" />
-<hkern g1="V,W"        g2="J"  k="68" />
-<hkern g1="V,W"        g2="M,N"        k="12" />
-<hkern g1="V,W"        g2="S"  k="10" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="T"  k="-20" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="hyphen,endash,emdash"       k="123" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-6" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="164" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="166" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="143" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="76" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="J"  k="72" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="z"  k="61" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="41" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="M,N"        k="35" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="s"  k="98" />
-<hkern g1="Z"  g2="hyphen,endash,emdash"       k="53" />
-<hkern g1="Z"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="20" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="T"  k="174" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="v,w"        k="25" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="y,yacute,ydieresis"         k="25" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quotedbl,quotesingle"       k="143" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="76" />
-<hkern g1="f"  g2="T"  k="-41" />
-<hkern g1="f"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="41" />
-<hkern g1="f"  g2="hyphen,endash,emdash"       k="35" />
-<hkern g1="f"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-90" />
-<hkern g1="f"  g2="parenright,bracketright,bar,braceright"     k="-27" />
-<hkern g1="f"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="102" />
-<hkern g1="f"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="47" />
-<hkern g1="f"  g2="s"  k="18" />
-<hkern g1="g"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-41" />
-<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="v,w"        k="10" />
-<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="y,yacute,ydieresis"         k="10" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="T"  k="82" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="Y,Yacute,Ydieresis"         k="61" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="v,w"        k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quotedbl,quotesingle"       k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="96" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="z"  k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="b,h,k,l"    k="18" />
-<hkern g1="r"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="68" />
-<hkern g1="r"  g2="v,w"        k="-27" />
-<hkern g1="r"  g2="y,yacute,ydieresis"         k="-27" />
-<hkern g1="r"  g2="hyphen,endash,emdash"       k="41" />
-<hkern g1="r"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-72" />
-<hkern g1="r"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="113" />
-<hkern g1="r"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="41" />
-<hkern g1="r"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
-<hkern g1="r"  g2="b,h,k,l"    k="23" />
-<hkern g1="s"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="20" />
-<hkern g1="t"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
-<hkern g1="t"  g2="v,w"        k="20" />
-<hkern g1="t"  g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="t"  g2="hyphen,endash,emdash"       k="31" />
-<hkern g1="t"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="t"  g2="b,h,k,l"    k="14" />
-<hkern g1="v,w"        g2="T"  k="61" />
-<hkern g1="v,w"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
-<hkern g1="v,w"        g2="hyphen,endash,emdash"       k="37" />
-<hkern g1="v,w"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-47" />
-<hkern g1="v,w"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="82" />
-<hkern g1="v,w"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="y,yacute,ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
-<hkern g1="y,yacute,ydieresis"         g2="hyphen,endash,emdash"       k="37" />
-<hkern g1="y,yacute,ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-57" />
-<hkern g1="y,yacute,ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="92" />
-<hkern g1="y,yacute,ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="z"  g2="v,w"        k="37" />
-<hkern g1="z"  g2="y,yacute,ydieresis"         k="31" />
-<hkern g1="z"  g2="hyphen,endash,emdash"       k="37" />
-<hkern g1="z"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-82" />
-<hkern g1="z"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="T"  k="143" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="Y,Yacute,Ydieresis"         k="164" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="V,W"        k="143" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="v,w"        k="82" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="y,yacute,ydieresis"         k="82" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="hyphen,endash,emdash"       k="172" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="27" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="J"  k="-51" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="41" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="102" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="T"  k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Y,Yacute,Ydieresis"         k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="V,W"        k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="72" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="v,w"        k="-14" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="205" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="145" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-20" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="J"  k="123" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="z"  k="6" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="b,h,k,l"    k="-55" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="M,N"        k="61" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="s"  k="92" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="S"  k="29" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Z"  k="-20" />
-<hkern g1="quotedbl,quotesingle"       g2="T"  k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="Y,Yacute,Ydieresis"         k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="V,W"        k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="98" />
-<hkern g1="quotedbl,quotesingle"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
-<hkern g1="quotedbl,quotesingle"       g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="J"  k="141" />
-<hkern g1="quotedbl,quotesingle"       g2="M,N"        k="47" />
-<hkern g1="quotedbl,quotesingle"       g2="s"  k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="Z"  k="-27" />
-<hkern g1="hyphen,endash,emdash"       g2="T"  k="123" />
-<hkern g1="hyphen,endash,emdash"       g2="Y,Yacute,Ydieresis"         k="123" />
-<hkern g1="hyphen,endash,emdash"       g2="V,W"        k="61" />
-<hkern g1="hyphen,endash,emdash"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="-31" />
-<hkern g1="hyphen,endash,emdash"       g2="v,w"        k="37" />
-<hkern g1="hyphen,endash,emdash"       g2="y,yacute,ydieresis"         k="37" />
-<hkern g1="hyphen,endash,emdash"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="35" />
-<hkern g1="hyphen,endash,emdash"       g2="z"  k="37" />
-<hkern g1="hyphen,endash,emdash"       g2="S"  k="53" />
-<hkern g1="hyphen,endash,emdash"       g2="Z"  k="20" />
-<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="T"  k="61" />
-<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="Y,Yacute,Ydieresis"         k="41" />
-<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="T"  k="82" />
-<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="61" />
-<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="T"  k="82" />
-<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="57" />
-</font>
-</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/fontface/museo300-regular-webfont.ttf b/karmaworld/assets/css/fontface/museo300-regular-webfont.ttf
deleted file mode 100644 (file)
index 5663b82..0000000
Binary files a/karmaworld/assets/css/fontface/museo300-regular-webfont.ttf and /dev/null differ
diff --git a/karmaworld/assets/css/fontface/museo300-regular-webfont.woff b/karmaworld/assets/css/fontface/museo300-regular-webfont.woff
deleted file mode 100644 (file)
index dba8de0..0000000
Binary files a/karmaworld/assets/css/fontface/museo300-regular-webfont.woff and /dev/null differ
diff --git a/karmaworld/assets/css/fontface/museo700-regular-webfont.eot b/karmaworld/assets/css/fontface/museo700-regular-webfont.eot
deleted file mode 100644 (file)
index d0b51ba..0000000
Binary files a/karmaworld/assets/css/fontface/museo700-regular-webfont.eot and /dev/null differ
diff --git a/karmaworld/assets/css/fontface/museo700-regular-webfont.svg b/karmaworld/assets/css/fontface/museo700-regular-webfont.svg
deleted file mode 100644 (file)
index 922e88f..0000000
+++ /dev/null
@@ -1,1006 +0,0 @@
-<?xml version="1.0" standalone="no"?>
-<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
-<svg xmlns="http://www.w3.org/2000/svg">
-<metadata></metadata>
-<defs>
-<font id="museo700" horiz-adv-x="1267" >
-<font-face units-per-em="2048" ascent="1536" descent="-512" />
-<missing-glyph horiz-adv-x="542" />
-<glyph unicode="&#xfb01;" horiz-adv-x="1298" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-24 4 -59 4q-26 0 -49 -3.5t-51 -14.5t-48 -29t-33.5 -51t-13.5 -76v-21h555q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-245 q-74 0 -107 33t-33 106v654q0 45 -45 45h-389v-838h-260v838h-129zM877 1214v240h225v-240h-225z" />
-<glyph unicode="&#xfb02;" horiz-adv-x="1282" d="M41 838v206h129v31q0 98 31.5 170.5t76 111t107 62t110.5 29.5t101 6h375q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-174q-201 0 -201 -164v-25h223v-206h-223v-838h-260v838h-129z" />
-<glyph unicode="&#xfb03;" horiz-adv-x="1986" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-24 4 -59 4q-33 0 -62.5 -6.5t-62 -23.5t-51.5 -54.5t-19 -91.5v-19h426v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81.5 27t78.5 14 t70.5 3.5q23 0 44.5 -1.5t31.5 -2.5l10 -2v-221q-24 4 -57 4q-34 0 -63.5 -6.5t-62.5 -23.5t-52 -54.5t-19 -91.5v-19h555q73 0 106 -33.5t33 -105.5v-641q0 -45 45 -45h82v-219h-247q-74 0 -107 33t-33 106v654q0 45 -45 45h-389v-838h-260v838h-426v-838h-260v838h-129z M1563 1214v240h225v-240h-225z" />
-<glyph unicode="&#xfb04;" horiz-adv-x="1970" d="M41 838v206h129v33q0 97 31 170t75.5 113t106 64t110.5 31t101 7q24 0 46.5 -1.5t33.5 -2.5l10 -2v-221q-24 4 -57 4q-26 0 -49.5 -3.5t-51.5 -14.5t-48.5 -29t-34 -51t-13.5 -76v-21h428v31q0 98 31.5 170.5t76 111t107 62t110.5 29.5t101 6h375q72 0 105.5 -33.5 t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-174q-201 0 -201 -164v-25h223v-206h-223v-838h-260v838h-428v-838h-260v838h-129z" />
-<glyph horiz-adv-x="2048" />
-<glyph horiz-adv-x="2048" />
-<glyph unicode="&#xd;" horiz-adv-x="2048" />
-<glyph unicode=" "  horiz-adv-x="542" />
-<glyph unicode="&#x09;" horiz-adv-x="542" />
-<glyph unicode="&#xa0;" horiz-adv-x="542" />
-<glyph unicode="!" horiz-adv-x="679" d="M205 1454h270l-20 -1034h-228zM215 0v242h252v-242h-252z" />
-<glyph unicode="&#x22;" horiz-adv-x="755" d="M117 1053v428h192v-428h-192zM444 1053v428h193v-428h-193z" />
-<glyph unicode="#" horiz-adv-x="1433" d="M66 383l30 186h244l51 287h-239l30 188h242l72 410h209l-72 -410h278l72 410h209l-72 -410h248l-33 -188h-245l-52 -287h244l-31 -186h-245l-66 -383h-209l68 383h-281l-65 -383h-209l65 383h-243zM549 569h280l52 287h-281z" />
-<glyph unicode="$" horiz-adv-x="1146" d="M78 268l186 156q5 -8 14 -22t41.5 -50t68 -63t93 -49.5t117.5 -22.5q92 0 150.5 46t58.5 126q0 40 -23.5 74.5t-63 61.5t-91 52t-108 51t-113 55t-108 67.5t-91 84t-63 109.5t-23.5 139q0 151 107 255.5t278 131.5v191h182v-191q49 -6 95.5 -19.5t91.5 -36.5t78.5 -53.5 t54 -74t20.5 -94.5v-135h-242v65q0 50 -54 81.5t-128 31.5q-92 0 -152.5 -42t-60.5 -106q0 -41 23.5 -75.5t63 -60t91 -49t108 -48t113 -52t108 -65t91 -83.5t63 -112t23.5 -145q0 -155 -106.5 -271t-280.5 -142v-191h-182v189q-84 11 -159 45t-122.5 74t-82.5 78t-50 63z " />
-<glyph unicode="%" horiz-adv-x="1689" d="M113 1155q0 133 98 228.5t235 95.5q138 0 237 -96t99 -228q0 -135 -99 -229.5t-237 -94.5t-235.5 94.5t-97.5 229.5zM164 0l1116 1454h240l-1117 -1454h-239zM311 1155q0 -57 39 -96t96 -39t97.5 39t40.5 96q0 56 -40.5 95.5t-97.5 39.5t-96 -39.5t-39 -95.5zM907 297 q0 133 97.5 228.5t236.5 95.5q138 0 236 -96t98 -228q0 -133 -98 -227.5t-236 -94.5q-139 0 -236.5 94t-97.5 228zM1106 299q0 -57 39 -96t96 -39t97 39t40 96q0 56 -40 95.5t-97 39.5t-96 -39.5t-39 -95.5z" />
-<glyph unicode="&#x26;" horiz-adv-x="1333" d="M86 426q0 112 65 213.5t177 134.5v4q-7 3 -19 9.5t-43 32t-54.5 58t-42.5 91t-19 127.5q0 172 124.5 277.5t317.5 105.5q51 0 101.5 -6.5t74.5 -12.5l25 -6l-64 -209q-51 12 -98 12q-96 0 -155.5 -55.5t-59.5 -138.5q0 -34 10.5 -65.5t33.5 -61.5t68.5 -48t108.5 -18h219 v174h260v-174h174v-229h-174v-172q0 -225 -136.5 -359.5t-373.5 -134.5q-228 0 -374 129t-146 322zM356 428q0 -88 68.5 -149.5t181.5 -61.5q119 0 184.5 68t65.5 198v158h-219q-130 0 -205.5 -54.5t-75.5 -158.5z" />
-<glyph unicode="'" horiz-adv-x="430" d="M117 1053v428h196v-428h-196z" />
-<glyph unicode="(" horiz-adv-x="718" d="M166 668q0 491 240 850h221q-230 -383 -230 -832q0 -470 236 -881h-221q-120 176 -183 400.5t-63 462.5z" />
-<glyph unicode=")" horiz-adv-x="718" d="M86 -195q236 411 236 881q0 449 -230 832h221q120 -179 181 -397t61 -453q0 -238 -63 -462.5t-183 -400.5h-223z" />
-<glyph unicode="*" horiz-adv-x="989" d="M76 1065l69 221l248 -100l-18 268h235l-18 -268l248 100l73 -219l-262 -66v-4l172 -202l-186 -138l-141 226h-4l-142 -226l-186 136l170 204v4z" />
-<glyph unicode="+" d="M86 483v203h442v485h211v-485h443v-203h-443v-483h-211v483h-442z" />
-<glyph unicode="," horiz-adv-x="542" d="M45 -215l137 479h250l-196 -479h-191z" />
-<glyph unicode="-" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
-<glyph unicode="." horiz-adv-x="542" d="M145 0v260h252v-260h-252z" />
-<glyph unicode="/" horiz-adv-x="751" d="M-2 -86l520 1614h223l-522 -1614h-221z" />
-<glyph unicode="0" horiz-adv-x="1253" d="M100 729q0 130 16.5 239t55 205t98 162.5t150.5 105t207 38.5t207 -38.5t150 -105t97.5 -162.5t55 -205t16.5 -239t-16.5 -239.5t-55 -206t-97.5 -164t-150 -106t-207 -38.5t-207 38.5t-150.5 106t-98 164t-55 206t-16.5 239.5zM371 729q0 -512 256 -512t256 512 q0 506 -256 506t-256 -506z" />
-<glyph unicode="1" horiz-adv-x="1091" d="M106 1104l365 350h242v-1227h313v-227h-895v227h313v807l2 99h-4q-16 -35 -63 -82l-117 -111z" />
-<glyph unicode="2" horiz-adv-x="1189" d="M68 193q0 84 24.5 155.5t65.5 123.5t94 96.5t112 79.5t118 68t112 67t94 71t65.5 85.5t24.5 104.5q0 86 -58.5 137.5t-152.5 51.5q-82 0 -136 -35.5t-54 -79.5v-63h-242v143q0 69 42.5 125t109.5 88.5t142 50t149 17.5q96 0 181 -29.5t149.5 -83.5t102.5 -136t38 -181 q0 -100 -39 -184t-101 -141.5t-136.5 -106.5t-149.5 -89t-137 -78.5t-101 -85.5t-39 -100q0 -20 13 -28.5t42 -8.5h426q45 0 45 45v88h242v-221q0 -73 -33 -106t-106 -33h-758q-91 0 -120 42t-29 151z" />
-<glyph unicode="3" horiz-adv-x="1138" d="M53 180l135 201l16.5 -16.5t47 -37.5t75.5 -47.5t98.5 -37.5t119.5 -17q108 0 178 61t70 156t-78 154t-197 59h-102l-54 133l246 330q22 33 46 60.5t38 39.5l13 11v4q-46 -6 -130 -6h-182q-45 0 -45 -45v-88h-242v221q0 74 27.5 106.5t99.5 32.5h791v-166l-334 -418 q158 -25 266.5 -137t108.5 -287q0 -92 -35 -176t-99.5 -150t-164 -105.5t-219.5 -39.5q-88 0 -171.5 21t-139.5 51t-99 60.5t-63 51.5z" />
-<glyph unicode="4" horiz-adv-x="1206" d="M37 367v170l602 917h315v-860h224v-227h-224v-367h-268v367h-649zM317 588q59 6 127 6h246v403q0 32 2.5 71.5t5.5 63.5l2 23h-4q-41 -78 -78 -131l-227 -336q-17 -24 -35.5 -48t-28.5 -36l-10 -12v-4z" />
-<glyph unicode="5" horiz-adv-x="1218" d="M96 176l135 203q5 -6 14.5 -16.5t43 -37t70 -47t93.5 -37t117 -16.5q119 0 193 70t74 172q0 116 -91 182t-223 66q-71 0 -139.5 -16.5t-101.5 -32.5l-33 -17l-94 47l53 619q6 74 36.5 106.5t100.5 32.5h537q72 0 105.5 -33.5t33.5 -105.5v-221h-244v88q0 45 -45 45h-239 q-43 0 -46 -45l-18 -201l-10 -68h4q67 27 153 27q244 0 388.5 -136t144.5 -341q0 -96 -37 -184t-104.5 -156.5t-170.5 -109t-227 -40.5q-86 0 -166.5 21t-133.5 50.5t-94 59.5t-60 51z" />
-<glyph unicode="6" horiz-adv-x="1177" d="M68 651q0 118 25.5 234.5t80.5 224t132 189.5t188.5 131t242.5 49q82 0 156.5 -15.5t108.5 -31.5l34 -15l-78 -227q-93 45 -204 45q-82 0 -150.5 -32.5t-114.5 -88.5t-76 -125t-44 -149h4q36 47 113.5 76.5t156.5 29.5q139 0 246.5 -67t163 -176t55.5 -240 q0 -207 -133 -347.5t-344 -140.5q-114 0 -216 46t-179 130t-122.5 213.5t-45.5 286.5zM344 571q0 -138 86 -246t199 -108q100 0 159.5 70t59.5 176q0 114 -70 190t-196 76q-97 0 -167.5 -46t-70.5 -112z" />
-<glyph unicode="7" horiz-adv-x="1101" d="M45 1094v221q0 74 28.5 106.5t98.5 32.5h909v-184l-692 -1270h-293l600 1094q22 40 44 73t33 47l11 13v4q-26 -4 -100 -4h-350q-45 0 -45 -45v-88h-244z" />
-<glyph unicode="8" horiz-adv-x="1193" d="M74 420q0 46 12.5 91t32 80t43.5 66.5t47.5 53.5t43 38.5t31.5 24.5l13 8v4q-7 4 -17.5 11.5t-38.5 34.5t-49.5 57.5t-39 81.5t-17.5 106q0 78 31 150t89 128.5t148 90t199 33.5q209 0 338 -114.5t129 -289.5q0 -57 -16.5 -112.5t-39.5 -93t-46 -67t-39 -43.5l-17 -14v-4 q201 -127 201 -333q0 -84 -37 -162t-103 -138t-164.5 -96.5t-213.5 -36.5q-221 0 -370.5 125.5t-149.5 319.5zM344 436q0 -98 71.5 -158.5t178.5 -60.5q103 0 175.5 57.5t72.5 145.5q0 37 -15 67t-46.5 54t-64.5 41.5t-83 38.5q-107 49 -131 49q-43 0 -100.5 -73.5 t-57.5 -160.5zM395 1071q0 -69 50 -110.5t147 -79.5q77 -31 96 -31q37 0 80 66t43 141q0 82 -57.5 130t-151.5 48q-95 0 -151 -47t-56 -117z" />
-<glyph unicode="9" horiz-adv-x="1177" d="M68 991q0 134 58.5 245t169 177t251.5 66q114 0 215 -46t178.5 -130t122.5 -213.5t45 -286.5q0 -118 -26 -234.5t-80.5 -224t-132 -189.5t-189 -131t-242.5 -49q-82 0 -156.5 15.5t-108.5 31.5l-34 15l78 227q11 -5 29.5 -13t72.5 -21t103 -13q82 0 150.5 32.5 t114.5 89.5t76 126t44 149h-4q-35 -46 -113 -76t-158 -30q-139 0 -246.5 67t-162.5 176t-55 240zM328 991q0 -114 70.5 -190t197.5 -76q96 0 165.5 45.5t69.5 112.5q0 138 -85.5 245t-198.5 107q-100 0 -159.5 -69t-59.5 -175z" />
-<glyph unicode=":" horiz-adv-x="626" d="M188 0v260h250v-260h-250zM188 784v260h250v-260h-250z" />
-<glyph unicode=";" horiz-adv-x="626" d="M72 -215l112 479h248l-168 -479h-192zM190 784v260h250v-260h-250z" />
-<glyph unicode="&#x3c;" d="M131 502v168l985 438v-227l-710 -293v-4l710 -293v-228z" />
-<glyph unicode="=" d="M135 274v201h1000v-201h-1000zM135 694v201h1000v-201h-1000z" />
-<glyph unicode="&#x3e;" d="M145 63v228l711 293v4l-711 293v227l985 -438v-168z" />
-<glyph unicode="?" horiz-adv-x="974" d="M74 1335q6 6 17 16t48.5 35.5t79 45t107 35.5t133.5 16q117 0 217.5 -44.5t164.5 -134t64 -206.5q0 -69 -19.5 -127.5t-51 -100.5t-69.5 -79t-76 -69.5t-69.5 -65t-51 -72t-19.5 -84.5v-80h-252v98q0 82 35 150t84.5 114t99 88.5t84.5 93.5t35 109q0 72 -57 121t-142 49 q-52 0 -107 -21.5t-83 -43.5l-29 -21zM297 0v242h252v-242h-252z" />
-<glyph unicode="@" horiz-adv-x="1607" d="M78 492q0 157 60 298.5t162 243.5t245 161.5t303 59.5q151 0 263.5 -36t176 -99.5t93.5 -140.5t30 -170v-512h150v-186h-568q-100 0 -184.5 32t-139.5 85t-85.5 121.5t-30.5 142.5q0 154 119 264t321 110h174q-3 79 -90 130t-221 51q-145 0 -266 -78t-188.5 -205 t-67.5 -272q0 -150 66.5 -274.5t194.5 -199.5t294 -75v-203q-179 0 -331.5 58.5t-257 159.5t-163.5 239.5t-59 294.5zM811 498q0 -85 55.5 -143t143.5 -58h157v401h-153q-90 0 -146.5 -58t-56.5 -142z" />
-<glyph unicode="A" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z " />
-<glyph unicode="B" horiz-adv-x="1288" d="M68 1227v227h628q201 0 326 -99.5t125 -275.5q0 -113 -51 -193t-125 -118v-4q113 -34 173 -129.5t60 -212.5q0 -85 -26.5 -155.5t-72.5 -119t-109.5 -82.5t-137.5 -49.5t-156 -15.5h-362q-72 0 -105.5 33t-33.5 106v1088h-133zM469 272q0 -45 45 -45h209q96 0 150.5 58.5 t54.5 152.5q0 93 -55 151t-150 58h-254v-375zM469 860h229q82 0 129 53t47 134t-46.5 130.5t-133.5 49.5h-225v-367z" />
-<glyph unicode="C" horiz-adv-x="1452" d="M61 739q0 207 96 376.5t265 266.5t377 97q60 0 129 -9.5t145 -34t136.5 -60t100.5 -93.5t40 -129v-162h-244v82q0 50 -50 87t-116.5 53t-134.5 16q-200 0 -332.5 -134t-132.5 -356q0 -140 62.5 -258.5t171.5 -187t239 -68.5q77 0 150.5 20t123.5 48.5t89.5 56.5t57.5 48 l19 20l142 -193q-9 -10 -25.5 -27t-73 -60t-119.5 -76t-163 -60t-205 -27q-163 0 -303.5 59t-237.5 161.5t-152 243t-55 300.5z" />
-<glyph unicode="D" horiz-adv-x="1464" d="M70 1227v227h592q340 0 540.5 -192t200.5 -533t-200.5 -535t-540.5 -194h-320q-74 0 -106.5 33t-32.5 106v1088h-133zM471 272q0 -45 45 -45h131q222 0 349.5 130t127.5 372q0 239 -128.5 368.5t-348.5 129.5h-176v-955z" />
-<glyph unicode="E" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133z" />
-<glyph unicode="F" horiz-adv-x="1077" d="M70 1227v227h829q73 0 106 -33.5t33 -105.5v-221h-241v88q0 45 -45 45h-281v-412h465v-227h-465v-588h-268v1227h-133z" />
-<glyph unicode="G" horiz-adv-x="1519" d="M63 735q0 154 56.5 292t154.5 237t235.5 157t293.5 58q100 0 191 -19t150 -46t104 -54.5t65 -46.5l20 -19l-151 -192q-6 5 -17.5 14t-50 31t-79 39t-102.5 31t-124 14q-94 0 -179 -36t-149 -100t-101.5 -157t-37.5 -201q0 -231 138 -371.5t339 -140.5q65 0 126.5 15.5 t103.5 38t75 45t48 38.5l16 15v108q0 45 -45 45h-88v228h235q74 0 107 -32.5t33 -104.5v-621h-230v70l2 61h-4q-6 -6 -18.5 -16.5t-54 -37.5t-87.5 -47.5t-119 -37.5t-149 -17q-143 0 -271.5 53.5t-225 150t-153.5 241t-57 315.5z" />
-<glyph unicode="H" horiz-adv-x="1583" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-477h641v477q0 72 33.5 105.5t105.5 33.5h262v-227h-88q-45 0 -45 -45v-1182h-268v610h-641v-610h-268v1182q0 45 -45 45h-88z" />
-<glyph unicode="I" horiz-adv-x="700" d="M78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
-<glyph unicode="J" horiz-adv-x="1103" d="M41 430v84h268v-59q0 -121 54.5 -175.5t136.5 -54.5q81 0 134.5 53t53.5 164v740q0 45 -45 45h-352v227h526q72 0 105.5 -33.5t33.5 -105.5v-885q0 -92 -26 -168.5t-70 -129t-103 -88.5t-124 -52.5t-135 -16.5q-69 0 -134.5 17t-124.5 53.5t-102.5 89t-69.5 128.5 t-26 167z" />
-<glyph unicode="K" horiz-adv-x="1298" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-453h102q46 0 73 8.5t44 38.5l293 545h295l-328 -598q-20 -36 -43 -62.5t-36 -35.5l-13 -8v-5q5 -1 14.5 -5.5t34.5 -30t45 -64.5l185 -371q14 -30 37.5 -38.5t64.5 -8.5h39v-227h-154q-86 0 -127 20.5t-75 88.5l-238 477 q-17 32 -46 40.5t-81 8.5h-86v-635h-268v1182q0 45 -45 45h-88z" />
-<glyph unicode="L" horiz-adv-x="1142" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-1043q0 -45 45 -45h318q45 0 45 45v88h243v-221q0 -73 -33 -106t-106 -33h-641q-74 0 -106.5 33t-32.5 106v1043q0 45 -45 45h-88z" />
-<glyph unicode="M" horiz-adv-x="1781" d="M37 0v227h63q42 0 45 45l95 1182h278l299 -692q16 -37 34 -86t28 -79l10 -30h4q37 111 72 195l299 692h278l94 -1182q3 -45 45 -45h64v-227h-232q-71 0 -101 32t-36 107l-49 647q-5 44 -5 100v21q0 42 2 70l1 35h-4q-43 -144 -80 -226l-242 -536h-217l-241 536 q-16 36 -36 93t-32 96l-12 39h-4q3 -57 3 -107q0 -67 -5 -121l-47 -647q-6 -75 -37.5 -107t-102.5 -32h-231z" />
-<glyph unicode="N" horiz-adv-x="1576" d="M70 0v227h88q45 0 45 45v1182h241l551 -805q25 -37 55.5 -88.5t47.5 -84.5l18 -32h4q-14 121 -14 205v666q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-1182h-239l-553 803q-25 36 -55.5 87.5t-48.5 84.5l-17 33h-4q14 -121 14 -205v-664q0 -73 -32.5 -106 t-106.5 -33h-262z" />
-<glyph unicode="O" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350z" />
-<glyph unicode="P" horiz-adv-x="1239" d="M70 1227v227h665q205 0 334 -131t129 -342q0 -212 -129.5 -345.5t-333.5 -133.5h-264v-502h-268v1227h-133zM471 731h215q113 0 175.5 67.5t62.5 182.5q0 113 -62.5 179.5t-171.5 66.5h-219v-496z" />
-<glyph unicode="Q" horiz-adv-x="1626" d="M61 735q0 154 57.5 291.5t157 236.5t239 156.5t296.5 57.5q159 0 299 -57.5t239.5 -156.5t157.5 -236.5t58 -291.5q0 -247 -160 -459l158 -143l-160 -174l-158 156q-183 -140 -434 -140q-209 0 -381.5 101t-270.5 275.5t-98 383.5zM340 735q0 -216 137 -363t334 -147 q68 0 128 17.5t86 35.5l26 17l-148 137l158 174l147 -147q78 124 78 276q0 210 -137.5 351t-337.5 141q-198 0 -334.5 -141.5t-136.5 -350.5z" />
-<glyph unicode="R" horiz-adv-x="1294" d="M70 1227v227h651q203 0 328 -117.5t125 -320.5q0 -92 -28.5 -167.5t-70.5 -119t-79 -67.5t-64 -29v-4q5 -2 13 -7t27.5 -24t31.5 -43l141 -281q16 -30 39 -38.5t63 -8.5h27v-227h-141q-85 0 -127 21t-76 88l-187 366q-23 42 -50.5 55t-86.5 13h-135v-543h-268v1227h-133z M471 772h213q101 0 158 60t57 169q0 107 -56 166.5t-155 59.5h-217v-455z" />
-<glyph unicode="S" horiz-adv-x="1124" d="M66 201l151 188q6 -7 17.5 -18.5t48 -41t75 -52.5t96.5 -41.5t115 -18.5q88 0 148.5 45.5t60.5 126.5q0 39 -23.5 73t-63 60.5t-91 52t-108 51.5t-113 54.5t-108 66t-91 82t-63 106t-23.5 134.5q0 177 137.5 293.5t348.5 116.5q68 0 140 -16.5t139 -49t110 -90t43 -131.5 v-135h-242v65q0 49 -58.5 81t-133.5 32q-93 0 -153 -43.5t-60 -112.5q0 -39 23.5 -72.5t63 -58.5t91 -48.5t108 -48t113 -52t108 -65t91 -82.5t63 -109t23.5 -140q0 -180 -131.5 -304t-352.5 -124q-66 0 -129 12.5t-111 32.5t-91 44t-73 48t-52 44t-33 32z" />
-<glyph unicode="T" horiz-adv-x="1337" d="M31 1094v229q0 72 29 101.5t102 29.5h1014q73 0 102 -29.5t29 -101.5v-229h-236v88q0 45 -45 45h-223v-1227h-268v1227h-224q-45 0 -45 -45v-88h-235z" />
-<glyph unicode="U" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z" />
-<glyph unicode="V" horiz-adv-x="1400" d="M23 1227v227h170q76 0 111.5 -25t60.5 -94l278 -811q13 -36 26.5 -89.5t20.5 -88.5l8 -35h4q27 131 56 213l278 811q25 70 59.5 94.5t110.5 24.5h172v-227h-39q-27 0 -40.5 -9.5t-22.5 -35.5l-434 -1182h-283l-436 1182q-9 26 -23 35.5t-41 9.5h-36z" />
-<glyph unicode="W" horiz-adv-x="2031" d="M33 1227v227h174q80 0 121.5 -25.5t58.5 -93.5l199 -866q8 -36 14 -74.5t8 -58.5l2 -21h4q8 70 31 154l264 981h228l249 -981q10 -37 17.5 -75.5t9.5 -58.5l2 -20h4q7 72 25 154l201 866q14 68 56 93.5t122 25.5h176v-227h-39q-29 0 -44.5 -10t-21.5 -35l-303 -1182h-309 l-221 823q-11 41 -20.5 86t-12.5 70l-4 25h-4q-12 -87 -39 -181l-231 -823h-312l-301 1182q-10 45 -65 45h-39z" />
-<glyph unicode="X" horiz-adv-x="1255" d="M10 0l451 737l-271 441q-19 32 -35.5 40.5t-52.5 8.5h-61v227h168q74 0 111.5 -21.5t74.5 -84.5l140 -242l92 -176h4q39 92 88 176l141 242q36 63 75 84.5t114 21.5h165v-227h-61q-35 0 -51.5 -9t-36.5 -40l-272 -441l452 -737h-301l-225 383l-92 170h-4 q-39 -86 -88 -170l-224 -383h-301z" />
-<glyph unicode="Y" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48z" />
-<glyph unicode="Z" horiz-adv-x="1204" d="M35 0v170l653 926q26 36 54 69t42 47l15 15v4q-43 -4 -111 -4h-352q-45 0 -45 -45v-88h-244v221q0 72 33 105.5t106 33.5h944v-168l-653 -928q-26 -37 -53.5 -70t-41.5 -47l-15 -14v-4q42 4 110 4h397q46 0 46 45v88h241v-221q0 -73 -32.5 -106t-106.5 -33h-987z" />
-<glyph unicode="[" horiz-adv-x="720" d="M188 -55v1433q0 74 33 107t107 33h264v-189h-137q-45 0 -45 -45v-1245q0 -45 45 -45h137v-189h-264q-74 0 -107 33.5t-33 106.5z" />
-<glyph unicode="\" horiz-adv-x="745" d="M10 1528h223l523 -1614h-224z" />
-<glyph unicode="]" horiz-adv-x="720" d="M129 -6h135q45 0 45 45v1245q0 45 -45 45h-135v189h264q73 0 106 -33t33 -107v-1433q0 -74 -33 -107t-106 -33h-264v189z" />
-<glyph unicode="^" d="M133 502l412 952h164l411 -952h-225l-268 678l-269 -678h-225z" />
-<glyph unicode="_" horiz-adv-x="1169" d="M10 0h1149v-201h-1149v201z" />
-<glyph unicode="`" horiz-adv-x="817" d="M147 1829h250l156 -279h-193z" />
-<glyph unicode="a" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
-<glyph unicode="b" horiz-adv-x="1265" d="M35 1233v221h248q72 0 105.5 -33.5t33.5 -105.5v-303l-4 -88h4q4 6 11.5 15.5t35 34.5t60.5 44.5t88.5 35t117.5 15.5q211 0 337 -151t126 -396q0 -246 -134.5 -396.5t-344.5 -150.5q-61 0 -115.5 15t-88.5 37t-59.5 44t-36.5 37l-11 15h-5q5 -29 5 -70v-53h-246v1188 q0 45 -45 45h-82zM414 516q0 -131 68.5 -226t191.5 -95q111 0 186.5 86.5t75.5 236.5q0 148 -72 238t-188 90q-111 0 -186.5 -83.5t-75.5 -246.5z" />
-<glyph unicode="c" horiz-adv-x="1101" d="M66 522q0 149 67 272.5t199 199t305 75.5q56 0 117 -12t122 -37.5t100.5 -73.5t39.5 -112v-123h-230v57q0 39 -47 60.5t-102 21.5q-135 0 -222 -92.5t-87 -233.5q0 -77 27 -139.5t72.5 -101.5t103.5 -59.5t122 -20.5q50 0 100 14.5t86.5 35.5t65.5 41.5t43 35.5l15 14 l108 -180q-6 -8 -18.5 -20.5t-54.5 -45t-89 -57.5t-122.5 -45.5t-155.5 -20.5q-126 0 -233 43t-179 117t-112.5 174t-40.5 213z" />
-<glyph unicode="d" horiz-adv-x="1273" d="M66 522q0 247 133 397t342 150q64 0 118 -13t86.5 -31.5t55.5 -37.5t32 -32l9 -13h4q-2 27 -2 62v184q0 45 -45 45h-82v221h248q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-240q-129 0 -129 106v39h-4q-4 -7 -11 -18.5t-35 -40.5t-61.5 -51.5t-92.5 -41 t-126 -18.5q-211 0 -337.5 151t-126.5 396zM330 522q0 -149 71 -238t187 -89q111 0 186.5 83t75.5 246q0 84 -27.5 155.5t-87.5 119t-143 47.5q-112 0 -187 -87t-75 -237z" />
-<glyph unicode="e" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
-<glyph unicode="f" horiz-adv-x="706" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-22 4 -53 4q-201 0 -201 -170v-25h223v-206h-223v-838h-260v838h-129z" />
-<glyph unicode="g" horiz-adv-x="1253" d="M66 549q0 146 51.5 262t158 187t252.5 71q68 0 126 -15t92.5 -36.5t59.5 -43.5t34 -37l10 -15h4v26q0 39 29 67.5t86 28.5h241v-221h-80q-45 0 -45 -41v-719q0 -129 -47 -227t-127 -154.5t-174.5 -84t-201.5 -27.5q-96 0 -195 24.5t-176 65.5l80 205q14 -8 40 -19.5 t101.5 -31t146.5 -19.5q130 0 212.5 62t82.5 194v49l2 56h-4q-94 -136 -290 -136q-145 0 -253 73t-162 191.5t-54 264.5zM330 557q0 -141 68.5 -229t191.5 -88q50 0 91.5 15.5t77 49t55.5 95.5t20 147q0 301 -261 301q-117 0 -180 -78.5t-63 -212.5z" />
-<glyph unicode="h" horiz-adv-x="1310" d="M35 1233v221h248q72 0 105.5 -33t33.5 -104v-367l-4 -88h4q41 84 136.5 145.5t221.5 61.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-72 0 -104.5 33t-32.5 106v479q0 104 -36.5 158.5t-129.5 54.5q-101 0 -177 -60t-106 -157q-16 -55 -16 -135v-479h-260v1188 q0 45 -45 45h-82z" />
-<glyph unicode="i" horiz-adv-x="612" d="M51 823v221h248q72 0 104.5 -33.5t32.5 -105.5v-641q0 -45 45 -45h82v-219h-248q-72 0 -104.5 33t-32.5 106v639q0 45 -45 45h-82zM190 1214v240h226v-240h-226z" />
-<glyph unicode="j" horiz-adv-x="624" d="M-39 -199q18 -4 45 -4q26 0 50.5 3.5t54.5 15.5t52 32t37 56.5t15 85.5v788q0 45 -45 45h-82v221h248q73 0 106 -33.5t33 -105.5v-936q0 -100 -32.5 -175t-79 -115t-110 -65t-113 -31.5t-101.5 -6.5q-21 0 -40.5 1.5t-28.5 2.5l-9 2v219zM225 1214v240h228v-240h-228z " />
-<glyph unicode="k" horiz-adv-x="1132" d="M35 1233v221h248q75 0 107 -25t32 -94v-659h78q71 0 98 39l213 329h289l-264 -393q-20 -29 -39.5 -49.5t-28.5 -26.5l-10 -6v-4q4 -2 11 -6t26.5 -25t35.5 -51l119 -225q12 -23 30.5 -31t55.5 -8h70v-219h-193q-68 0 -100.5 17t-62.5 73l-175 328q-21 39 -96 39h-57v-457 h-260v1188q0 45 -45 45h-82z" />
-<glyph unicode="l" horiz-adv-x="595" d="M37 1233v221h248q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-82z" />
-<glyph unicode="m" horiz-adv-x="1931" d="M43 823v221h240q137 0 137 -116v-31l-2 -45h4q41 86 132.5 151.5t205.5 65.5q236 0 305 -215h4q44 90 140.5 152.5t215.5 62.5q342 0 342 -397v-408q0 -45 45 -45h80v-219h-245q-74 0 -107 33t-33 106v484q0 49 -5.5 83.5t-20.5 64.5t-44 45t-73 15q-93 0 -160 -68 t-90 -171q-16 -55 -16 -133v-459h-260v623q0 38 -2.5 65.5t-11.5 56t-24 46.5t-41.5 29t-62.5 11q-94 0 -160 -67.5t-92 -173.5q-16 -66 -16 -131v-459h-258v778q0 45 -45 45h-82z" />
-<glyph unicode="n" horiz-adv-x="1316" d="M43 823v221h240q137 0 137 -116v-31l-4 -45h4q15 29 35 56.5t53 57.5t72 52t93 36.5t115 14.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-74 0 -106.5 33t-32.5 106v479q0 104 -36 158.5t-128 54.5q-102 0 -177 -58.5t-103 -154.5q-21 -64 -21 -139v-479h-258v778 q0 45 -45 45h-82z" />
-<glyph unicode="o" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234z" />
-<glyph unicode="p" horiz-adv-x="1271" d="M43 823v221h231q132 0 132 -100v-41h4q4 7 11 18t35.5 39.5t62.5 50.5t94 40t128 18q211 0 338 -151t127 -396q0 -246 -135 -396.5t-344 -150.5q-58 0 -110 14t-85 34.5t-58 41t-36 34.5l-10 14h-4q4 -37 4 -90v-433h-258v1188q0 45 -45 45h-82zM422 516q0 -131 68 -226 t190 -95q112 0 188 86.5t76 236.5q0 148 -72 238t-188 90q-111 0 -186.5 -83.5t-75.5 -246.5z" />
-<glyph unicode="q" horiz-adv-x="1273" d="M68 522q0 247 132 397t341 150q67 0 124.5 -16t92.5 -38.5t60.5 -45t35.5 -38.5l10 -16h4v37q0 42 33 67t100 25h230v-221h-82q-45 0 -45 -45v-1188h-260v443l4 90h-4q-4 -6 -11 -16t-34.5 -35.5t-60.5 -45t-89 -35.5t-119 -16q-211 0 -336.5 151t-125.5 396zM330 522 q0 -148 72 -237.5t188 -89.5q111 0 186.5 83t75.5 246q0 84 -28 155.5t-88.5 119t-143.5 47.5q-111 0 -186.5 -87t-75.5 -237z" />
-<glyph unicode="r" horiz-adv-x="843" d="M43 823v221h238q70 0 104.5 -30.5t34.5 -95.5v-62l-4 -65h4q37 117 126.5 192.5t205.5 75.5l47 -4v-256q-27 4 -64 4q-59 0 -113 -21.5t-101.5 -72.5t-69.5 -125q-23 -84 -23 -170v-414h-258v778q0 45 -45 45h-82z" />
-<glyph unicode="s" horiz-adv-x="958" d="M51 162l123 170q5 -6 15 -16.5t43 -37t67 -47t85 -37t101 -16.5q63 0 102.5 26.5t39.5 76.5q0 29 -30.5 54.5t-79 46.5t-107 44t-117.5 53t-107.5 67t-79 93t-30.5 125q0 100 57 171t146.5 102.5t201.5 31.5q59 0 118 -10.5t117.5 -33.5t95 -68t36.5 -105v-109h-230v52 q0 34 -41 53.5t-90 19.5q-71 0 -113 -24.5t-42 -69.5q0 -33 30.5 -59.5t79.5 -46.5t108.5 -41t118.5 -49.5t108 -64t79.5 -91.5t30.5 -127q0 -145 -114 -232.5t-288 -87.5q-80 0 -154.5 19.5t-123 46.5t-85.5 54.5t-54 46.5z" />
-<glyph unicode="t" horiz-adv-x="757" d="M39 838v206h141v285h254v-285h238v-206h-238v-422q0 -49 15 -86t37 -57.5t51.5 -33.5t54 -16.5t49.5 -3.5l47 4v-227q-33 -6 -80 -6q-36 0 -70 3t-79 13.5t-83 27.5t-76.5 47.5t-65 70.5t-43.5 99.5t-17 131.5v455h-135z" />
-<glyph unicode="u" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z" />
-<glyph unicode="v" horiz-adv-x="1116" d="M25 823v221h149q65 0 99.5 -22t54.5 -76l196 -549q10 -27 20 -64.5t14 -60.5l5 -24h4q17 88 37 149l197 549q20 54 55 76t98 22h140v-221h-25q-43 0 -57 -37l-299 -786h-310l-299 786q-14 37 -57 37h-22z" />
-<glyph unicode="w" horiz-adv-x="1710" d="M20 823v221h179q65 0 98.5 -23.5t48.5 -82.5l154 -580q6 -24 11 -51.5t7 -42.5l2 -16h4q9 55 25 110l192 682h230l194 -682q7 -24 13 -51.5t8 -42.5l2 -16h4q6 55 20 110l152 580q15 59 48.5 82.5t98.5 23.5h179v-221h-29q-24 0 -36 -7.5t-21 -29.5l-250 -786h-293 l-178 596q-7 24 -13.5 52.5t-9.5 44.5l-2 16h-4q-11 -58 -27 -113l-176 -596h-295l-250 786q-7 22 -19.5 29.5t-37.5 7.5h-29z" />
-<glyph unicode="x" horiz-adv-x="1048" d="M23 0l339 528l-172 260q-14 22 -29.5 28.5t-49.5 6.5h-76v221h182q66 0 100.5 -19.5t69.5 -78.5l102 -172l33 -67h4q19 40 33 67l103 172q35 59 68.5 78.5t100.5 19.5h181v-221h-74q-34 0 -50 -6.5t-30 -28.5l-174 -260l342 -528h-289l-182 291q-6 9 -13.5 22.5 t-11.5 22.5l-4 10h-4q-16 -32 -30 -55l-181 -291h-288z" />
-<glyph unicode="y" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5z" />
-<glyph unicode="z" horiz-adv-x="1046" d="M55 0v139l482 588q21 26 43 50t34 35l11 11v4q-31 -4 -97 -4h-188q-45 0 -45 -45v-59h-236v186q0 72 33.5 105.5t106.5 33.5h766v-141l-482 -588q-21 -25 -43 -49t-34 -36l-11 -11v-4q31 6 99 6h229q45 0 45 45v58h236v-185q0 -73 -33 -106t-105 -33h-811z" />
-<glyph unicode="{" horiz-adv-x="720" d="M49 557v227q7 0 19 2t42 14.5t52.5 33.5t41.5 64.5t19 102.5v177q0 89 27.5 155t66 101.5t92 57t94 27t83.5 5.5l63 -2v-193q-17 2 -37 2t-39 -3t-43.5 -13.5t-42.5 -28.5t-30.5 -51.5t-12.5 -77.5v-223q0 -57 -17.5 -105t-42 -75.5t-49 -46.5t-41.5 -26l-18 -7v-4 q7 -2 18 -6.5t40 -24t51.5 -45.5t40.5 -74.5t18 -107.5v-246q0 -45 12.5 -78.5t30.5 -51t42.5 -28.5t43.5 -13.5t39 -2.5l37 2v-193q-26 -4 -63 -4q-43 0 -83.5 5.5t-94 27t-92 57t-66 102.5t-27.5 156v199q0 57 -18 100.5t-43.5 63.5t-51 32.5t-43.5 14.5z" />
-<glyph unicode="|" horiz-adv-x="638" d="M209 -330v1960h221v-1960h-221z" />
-<glyph unicode="}" horiz-adv-x="720" d="M72 -6q17 -2 37 -2t38.5 2.5t43 13.5t41.5 28.5t29.5 51t12.5 78.5v246q0 59 17.5 107.5t42.5 75t50 45t42 24.5l18 6v4q-7 2 -18.5 7t-40.5 25.5t-51.5 47t-41 75t-18.5 105.5v223q0 44 -12 77.5t-29.5 51.5t-42 28.5t-43 13.5t-38.5 3l-37 -2v193q26 2 63 2 q43 0 83.5 -5.5t94 -27t92 -57t66 -101.5t27.5 -155v-177q0 -59 18 -102.5t43.5 -64.5t51 -33.5t43.5 -14.5l18 -2v-227q-7 0 -19 -2t-42 -14.5t-52.5 -32.5t-41.5 -63.5t-19 -100.5v-199q0 -89 -27.5 -156t-66 -102.5t-92 -57t-94 -27t-83.5 -5.5l-63 4v193z" />
-<glyph unicode="~" d="M115 408q0 186 81 279t234 93q57 0 104 -19t79 -46.5t60.5 -55t62.5 -46.5t71 -19q63 0 95 51t32 127h205q0 -187 -80.5 -280t-233.5 -93q-57 0 -104 19t-78.5 46.5t-60 54.5t-62.5 46t-71 19q-64 0 -95.5 -50.5t-31.5 -125.5h-207z" />
-<glyph unicode="&#xa1;" horiz-adv-x="679" d="M205 -410l22 1033h228l20 -1033h-270zM215 801v241h250v-241h-250z" />
-<glyph unicode="&#xa2;" horiz-adv-x="1198" d="M113 727q0 222 117 383t307 195v223h182v-223q132 -25 231.5 -112.5t147.5 -219.5l-234 -90q-32 81 -90 131.5t-139 50.5q-115 0 -187.5 -95t-72.5 -243q0 -154 70 -246t190 -92q81 0 139.5 50t89.5 132l234 -90q-23 -58 -56.5 -110.5t-80 -99.5t-109 -78.5t-133.5 -40.5 v-228h-182v228q-190 32 -307 192.5t-117 382.5z" />
-<glyph unicode="&#xa3;" horiz-adv-x="1200" d="M96 0v227h119v410h-90v178h90v248q0 181 132 298.5t335 117.5q61 0 121.5 -15t102.5 -37t75 -44t49 -37l17 -15l-150 -180q-11 10 -30 24.5t-74.5 39t-106.5 24.5q-90 0 -146.5 -52.5t-56.5 -131.5v-240h363v-178h-363v-410h344q45 0 45 45v88h242v-221q0 -73 -32.5 -106 t-104.5 -33h-881z" />
-<glyph unicode="&#xa5;" horiz-adv-x="1271" d="M27 1227v227h133q74 0 115 -20.5t81 -85.5l191 -320q23 -38 45 -78t32 -61l11 -21h4q37 74 88 160l191 320q38 65 79 85.5t115 20.5h133v-227h-43q-36 0 -52 -8t-34 -37l-188 -301v-4h168v-156h-271l-55 -86v-82h326v-156h-326v-397h-268v397h-328v156h328v82l-56 86 h-274v156h172v4l-188 301q-18 29 -34 37t-52 8h-43z" />
-<glyph unicode="&#xa7;" horiz-adv-x="1030" d="M125 -2l111 176q4 -4 11.5 -10t32 -21.5t50 -27.5t63 -21.5t74.5 -9.5q92 0 151.5 52.5t59.5 154.5q0 46 -19 117l-137 661h205l145 -704q15 -77 15 -117q0 -166 -111.5 -270.5t-308.5 -104.5q-60 0 -117.5 13t-96.5 31.5t-69 36.5t-44 31zM164 1104q0 165 111.5 270 t308.5 105q60 0 117.5 -13t96.5 -31.5t69 -37.5t45 -32l14 -13l-117 -166q-11 9 -30 22.5t-77.5 35.5t-115.5 22q-95 0 -153 -47.5t-58 -145.5q0 -47 14 -102l141 -688h-202l-150 704q-14 68 -14 117z" />
-<glyph unicode="&#xa8;" horiz-adv-x="1042" d="M260 1591v238h180v-238h-180zM627 1591v238h182v-238h-182z" />
-<glyph unicode="&#xa9;" horiz-adv-x="1599" d="M66 727q0 153 58 292t156 239.5t233 159.5t284 59q151 0 287.5 -59t235 -159.5t156.5 -239.5t58 -292t-58 -292.5t-156.5 -240t-235 -160t-287.5 -59.5q-149 0 -284 59.5t-233 160t-156 240t-58 292.5zM248 727q0 -162 72.5 -296.5t198.5 -212t278 -77.5q155 0 283 77.5 t201 212t73 296.5q0 161 -73 295t-201 211.5t-283 77.5q-114 0 -216 -45.5t-175 -123.5t-115.5 -186.5t-42.5 -228.5zM424 723q0 166 108.5 282.5t274.5 116.5q51 0 96.5 -12t78 -31t60 -41.5t45 -45.5t30 -42t17.5 -31l5 -12l-156 -73q-2 5 -6.5 13t-20 28t-33.5 35.5 t-47.5 28.5t-62.5 13q-90 0 -145.5 -65.5t-55.5 -163.5q0 -101 54 -165t147 -64q33 0 63 12t48.5 29.5t32.5 35t20 29.5l6 12l156 -71q-2 -5 -5.5 -12.5t-17 -30t-30 -43t-45 -45.5t-60.5 -43t-77.5 -30.5t-96.5 -12.5q-166 0 -274.5 116.5t-108.5 282.5z" />
-<glyph unicode="&#xaa;" horiz-adv-x="851" d="M100 993q0 46 18.5 83t50.5 59.5t68.5 38t81 23t79 10.5t69.5 3h29q-3 64 -25.5 88.5t-75.5 24.5q-69 0 -69 -31v-30h-176v86q0 38 27.5 65.5t70.5 39.5t79 17t68 5q287 0 287 -269v-221q0 -24 23 -24h53v-164h-140q-91 0 -104 71l-2 19h-4q-2 -4 -7 -11t-21.5 -25 t-36 -31.5t-51.5 -24.5t-68 -11q-92 0 -158 56t-66 153zM102 545v139h660v-139h-660zM291 1001q0 -30 19.5 -49.5t58.5 -19.5q56 0 89.5 45t39.5 113h-21q-186 0 -186 -89z" />
-<glyph unicode="&#xab;" horiz-adv-x="1257" d="M94 578l336 421h248l-336 -421l336 -420h-248zM553 578l336 421h248l-336 -421l336 -420h-248z" />
-<glyph unicode="&#xac;" d="M135 694v201h1000v-602h-209v401h-791z" />
-<glyph unicode="&#xad;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
-<glyph unicode="&#xae;" horiz-adv-x="1599" d="M66 727q0 153 58 292t156 239.5t233 159.5t284 59q151 0 287.5 -59t235 -159.5t156.5 -239.5t58 -292t-58 -292.5t-156.5 -240t-235 -160t-287.5 -59.5q-149 0 -284 59.5t-233 160t-156 240t-58 292.5zM248 727q0 -162 72.5 -296.5t198.5 -212t278 -77.5q155 0 283 77.5 t201 212t73 296.5q0 161 -73 295t-201 211.5t-283 77.5q-114 0 -216 -45.5t-175 -123.5t-115.5 -186.5t-42.5 -228.5zM475 979v127h377q110 0 178 -65.5t68 -172.5q0 -79 -42 -130t-91 -64v-4q27 -6 47 -41l65 -123q14 -25 45 -25h23v-125h-98q-43 0 -66 11.5t-41 44.5 l-100 188q-11 21 -26.5 27t-41.5 6h-57v-277h-174v623h-66zM715 756h96q51 0 80 30t29 82q0 53 -28.5 82t-78.5 29h-98v-223z" />
-<glyph unicode="&#xaf;" horiz-adv-x="956" d="M213 1604v172h537v-172h-537z" />
-<glyph unicode="&#xb0;" horiz-adv-x="839" d="M86 1157q0 133 97.5 228.5t236.5 95.5q138 0 236 -96t98 -228q0 -134 -97.5 -227.5t-236.5 -93.5q-140 0 -237 93t-97 228zM285 1157q0 -57 39 -96t96 -39t97 39t40 96q0 56 -40 95.5t-97 39.5t-96 -39.5t-39 -95.5z" />
-<glyph unicode="&#xb1;" d="M86 483v203h442v485h211v-485h443v-203h-443v-483h-211v483h-442zM115 -174h1040v-201h-1040v201z" />
-<glyph unicode="&#xb2;" horiz-adv-x="894" d="M106 686q0 51 16 95.5t37 74.5t59.5 62t65 48.5t72.5 43.5q86 48 130 88.5t44 97.5q0 44 -29 70t-77 26q-44 0 -71 -18t-27 -43v-45h-181v102q0 60 50 103.5t111.5 61t119.5 17.5q128 0 215.5 -72.5t87.5 -197.5q0 -30 -6 -58t-13.5 -50t-24.5 -45t-28.5 -38t-36.5 -35 l-37.5 -30t-42 -27.5t-40 -23.5t-41.5 -23q-75 -40 -113.5 -71t-38.5 -70q0 -12 23 -12h245q13 0 13 12v68h180v-150q0 -53 -24 -76.5t-76 -23.5h-459q-60 0 -81.5 27t-21.5 112z" />
-<glyph unicode="&#xb3;" horiz-adv-x="894" d="M111 713l135 121q3 -5 9.5 -13t27.5 -29t43 -37t55 -29t65 -13q56 0 94 33t38 83q0 49 -39 79t-101 30h-71l-27 109l147 198q8 10 18 21t17 16l6 6v4q-30 -4 -63 -4h-115q-18 0 -18 -18v-49h-180v133q0 56 21 78t77 22h504v-133l-189 -234q95 -20 153 -94.5t58 -167.5 q0 -132 -97 -213.5t-230 -81.5q-57 0 -113 19t-95 45.5t-69.5 53.5t-45.5 46z" />
-<glyph unicode="&#xb4;" horiz-adv-x="827" d="M252 1550l156 279h249l-215 -279h-190z" />
-<glyph unicode="&#xb6;" horiz-adv-x="1280" d="M80 975q0 201 141 340t340 139h625v-227h-436v-1329h-189v596q-199 0 -340 140t-141 341zM877 -102v1216h190v-1216h-190z" />
-<glyph unicode="&#xb7;" horiz-adv-x="542" d="M145 469v258h252v-258h-252z" />
-<glyph unicode="&#xb8;" horiz-adv-x="860" d="M231 -268q44 -17 91 -17q88 0 88 58q0 55 -99 55l-43 -4l64 227l119 -26v-15l-21 -100q66 -8 108 -48t42 -108q0 -49 -19 -85t-51.5 -56t-70.5 -29.5t-81 -9.5q-31 0 -63 3.5t-48 6.5l-16 4v144z" />
-<glyph unicode="&#xb9;" horiz-adv-x="894" d="M127 1229l235 225h170v-737h187v-170h-572v170h189v420l2 63h-4q-9 -19 -23 -31l-69 -65z" />
-<glyph unicode="&#xba;" horiz-adv-x="931" d="M106 1133q0 148 104.5 245t254.5 97q151 0 255.5 -96.5t104.5 -245.5q0 -150 -104.5 -248.5t-255.5 -98.5q-150 0 -254.5 98.5t-104.5 248.5zM137 545v139h660v-139h-660zM293 1133q0 -80 50 -131.5t122 -51.5q73 0 123.5 51.5t50.5 131.5q0 78 -50.5 129t-123.5 51 q-72 0 -122 -51t-50 -129z" />
-<glyph unicode="&#xbb;" horiz-adv-x="1257" d="M119 158l336 420l-336 421h248l335 -421l-335 -420h-248zM580 158l335 420l-335 421h247l336 -421l-336 -420h-247z" />
-<glyph unicode="&#xbc;" horiz-adv-x="1931" d="M137 1229l234 225h170v-737h178v-170h-561v170h188v420l2 63h-4q-8 -19 -22 -31l-70 -65zM614 0l568 1454h202l-567 -1454h-203zM1102 221v115l358 573h236v-516h133v-172h-133v-221h-197v221h-397zM1300 391q25 2 39 2h164v244l2 70h-4q-12 -31 -28 -58l-144 -219 l-29 -35v-4z" />
-<glyph unicode="&#xbd;" horiz-adv-x="1931" d="M137 1229l234 225h170v-737h178v-170h-561v170h188v420l2 63h-4q-8 -19 -22 -31l-70 -65zM590 0l567 1454h201l-567 -1454h-201zM1161 141q0 50 16 94.5t37.5 75t59.5 62t66 49t73 43.5q43 25 66.5 40t52.5 39t42 50t13 57q0 43 -29.5 68.5t-78.5 25.5q-43 0 -70 -17.5 t-27 -41.5v-47h-180v102q0 46 29 83t73 58.5t90.5 32.5t88.5 11q128 0 215.5 -74t87.5 -199q0 -43 -10 -80.5t-32.5 -68.5t-43 -53.5t-57 -47t-57.5 -37t-62 -34.5q-7 -4 -11 -6q-72 -39 -110.5 -72t-38.5 -72q0 -12 22 -12h244q12 0 12 14v66h183v-150q0 -52 -25 -76 t-78 -24h-456q-61 0 -83 27.5t-22 113.5z" />
-<glyph unicode="&#xbe;" horiz-adv-x="1931" d="M119 713l133 121q4 -5 10 -13t27.5 -29t43.5 -37t55 -29t65 -13q56 0 93.5 32.5t37.5 83.5q0 49 -39 79t-101 30h-71l-27 109l148 198q8 10 18 21t16 16l7 6v4q-31 -4 -64 -4h-115q-18 0 -18 -18v-49h-180v133q0 56 21 78t77 22h504v-133l-189 -234q95 -20 153 -94.5 t58 -167.5q0 -132 -97 -213.5t-230 -81.5q-57 0 -113 19t-94.5 45.5t-69 53.5t-44.5 46zM608 0l568 1454h200l-565 -1454h-203zM1102 221v115l358 573h236v-516h133v-172h-133v-221h-197v221h-397zM1300 391q25 2 39 2h164v244l2 70h-4q-12 -31 -28 -58l-144 -219l-29 -35 v-4z" />
-<glyph unicode="&#xbf;" horiz-adv-x="974" d="M68 -45q0 68 19.5 126.5t51.5 100.5t70 79t76 70t70 65t51.5 72t19.5 85v72h250v-90q0 -60 -18.5 -112.5t-48 -91t-65.5 -73.5t-72 -66t-65.5 -62t-48 -69.5t-18.5 -80.5q0 -72 57.5 -122.5t141.5 -50.5q52 0 106 22.5t83 44.5l28 22l145 -181q-6 -6 -17 -15.5 t-48.5 -34.5t-79.5 -44.5t-107 -35t-133 -15.5q-118 0 -218.5 44.5t-165 134t-64.5 206.5zM426 803v241h250v-241h-250z" />
-<glyph unicode="&#xc0;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM377 1829h250l155 -279h-192zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5 l-8 36h-4q-30 -138 -57 -218z" />
-<glyph unicode="&#xc1;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z M590 1550l155 279h250l-215 -279h-190z" />
-<glyph unicode="&#xc2;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM393 1550l187 279h223l188 -279h-194l-103 166h-4l-104 -166h-193zM506 594h368 l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z" />
-<glyph unicode="&#xc3;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM319 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21 q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z" />
-<glyph unicode="&#xc4;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM418 1591v238h180v-238h-180zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5 l-8 36h-4q-30 -138 -57 -218zM784 1591v238h183v-238h-183z" />
-<glyph unicode="&#xc5;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z M508 1686q0 75 54 118t128 43t128 -43t54 -118q0 -74 -54 -117t-128 -43t-128 43t-54 117zM618 1686q0 -31 20.5 -50.5t51.5 -19.5t51.5 19.5t20.5 50.5q0 32 -20.5 51.5t-51.5 19.5t-51.5 -19.5t-20.5 -51.5z" />
-<glyph unicode="&#xc6;" horiz-adv-x="1824" d="M23 0v227h28q28 0 41 9t23 36l485 1182h989q73 0 106.5 -33.5t33.5 -105.5v-221h-244v88q0 45 -45 45h-320v-381h465v-228h-465v-346q0 -24 12 -34.5t39 -10.5h324q45 0 45 45v88h242v-221q0 -73 -33 -106t-107 -33h-645q-79 0 -113 31t-34 108v479h-326l-186 -499 q-27 -69 -62 -94t-110 -25h-143zM610 846h240v381h-96z" />
-<glyph unicode="&#xc7;" horiz-adv-x="1452" d="M61 739q0 207 96 376.5t265 266.5t377 97q60 0 129 -9.5t145 -34t136.5 -60t100.5 -93.5t40 -129v-162h-244v82q0 50 -50 87t-116.5 53t-134.5 16q-200 0 -332.5 -134t-132.5 -356q0 -105 36 -200t98 -164t149 -109.5t184 -40.5q77 0 151.5 19.5t125.5 48t91 56.5t59 47 l19 20l142 -191q-8 -10 -23.5 -26t-69.5 -57t-114 -73.5t-157 -60.5t-200 -31l-14 -67q66 -8 108 -48t42 -108q0 -94 -64 -137t-158 -43q-31 0 -62 3.5t-47 6.5l-15 4v144q43 -17 88 -17q90 0 90 58q0 55 -99 55l-43 -4l43 158q-191 22 -337 127t-224 268.5t-78 361.5z" />
-<glyph unicode="&#xc8;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM295 1829h250l155 -279h-192z" />
-<glyph unicode="&#xc9;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM508 1550l156 279h249l-215 -279h-190z" />
-<glyph unicode="&#xca;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM309 1550l187 279h223l188 -279h-194 l-103 166h-4l-104 -166h-193z" />
-<glyph unicode="&#xcb;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM336 1591v238h180v-238h-180zM702 1591v238 h183v-238h-183z" />
-<glyph unicode="&#xcc;" horiz-adv-x="700" d="M37 1829h250l155 -279h-192zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
-<glyph unicode="&#xcd;" horiz-adv-x="700" d="M78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545zM250 1550l156 279h249l-215 -279h-190z" />
-<glyph unicode="&#xce;" horiz-adv-x="700" d="M51 1550l187 279h223l188 -279h-194l-103 166h-4l-104 -166h-193zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
-<glyph unicode="&#xcf;" horiz-adv-x="700" d="M76 1591v238h180v-238h-180zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545zM442 1591v238h183v-238h-183z" />
-<glyph unicode="&#xd0;" horiz-adv-x="1464" d="M70 1227v227h592q340 0 540.5 -192t200.5 -533t-200.5 -535t-540.5 -194h-320q-74 0 -106.5 33t-32.5 106v477h-99v215h99v396h-133zM471 272q0 -45 45 -45h131q222 0 349.5 130t127.5 372q0 239 -128.5 368.5t-348.5 129.5h-176v-396h252v-215h-252v-344z" />
-<glyph unicode="&#xd1;" horiz-adv-x="1576" d="M70 0v227h88q45 0 45 45v1182h241l551 -805q25 -37 55.5 -88.5t47.5 -84.5l18 -32h4q-14 121 -14 205v666q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-1182h-239l-553 803q-25 36 -55.5 87.5t-48.5 84.5l-17 33h-4q14 -121 14 -205v-664q0 -73 -32.5 -106 t-106.5 -33h-262zM434 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
-<glyph unicode="&#xd2;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM496 1829h249l156 -279h-192z" />
-<glyph unicode="&#xd3;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM709 1550l155 279h250l-215 -279h-190z" />
-<glyph unicode="&#xd4;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM510 1550l186 279h224l188 -279h-195l-102 166h-4l-105 -166h-192z" />
-<glyph unicode="&#xd5;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM436 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
-<glyph unicode="&#xd6;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM535 1591v238h180v-238h-180zM901 1591v238h182v-238h-182z" />
-<glyph unicode="&#xd7;" d="M94 141l404 445l-404 442l142 143l399 -438l399 438l142 -143l-406 -442l406 -445l-142 -141l-399 438l-399 -438z" />
-<glyph unicode="&#xd8;" horiz-adv-x="1628" d="M63 737q0 154 58 291t157.5 236t239 157t297.5 58q203 0 381 -101l94 129l117 -80l-94 -129q119 -105 186.5 -250t67.5 -311q0 -158 -58 -299t-158 -242.5t-239.5 -161t-296.5 -59.5q-206 0 -381 101l-94 -129l-117 80l92 131q-119 106 -185.5 255.5t-66.5 323.5z M342 737q0 -213 135 -358l567 788q-108 62 -229 62q-198 0 -335.5 -142t-137.5 -350zM586 287q103 -62 229 -62q196 0 333.5 147.5t137.5 364.5q0 199 -133 338z" />
-<glyph unicode="&#xd9;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M446 1829h250l156 -279h-193z" />
-<glyph unicode="&#xda;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M659 1550l156 279h250l-215 -279h-191z" />
-<glyph unicode="&#xdb;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M461 1550l186 279h223l189 -279h-195l-102 166h-4l-105 -166h-192z" />
-<glyph unicode="&#xdc;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M485 1591v238h181v-238h-181zM852 1591v238h182v-238h-182z" />
-<glyph unicode="&#xdd;" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48zM530 1550l156 279h250l-215 -279h-191 z" />
-<glyph unicode="&#xde;" horiz-adv-x="1249" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-96h264q205 0 334 -131.5t129 -342.5q0 -212 -129.5 -344.5t-335.5 -132.5h-262v-268h-268v1182q0 45 -45 45h-88zM471 496h215q113 0 175.5 67t62.5 182q0 114 -62 180t-172 66h-219v-495z" />
-<glyph unicode="&#xdf;" horiz-adv-x="1224" d="M37 0v219h72q45 0 45 45v819q0 124 69 216t175 136t229 44q178 0 301 -102t123 -255q0 -50 -19 -94.5t-46.5 -75.5t-54.5 -59.5t-46 -60.5t-19 -64q0 -25 18.5 -50t47.5 -48.5t64.5 -50t71 -58t64.5 -67.5t47.5 -85t18.5 -104q0 -80 -30.5 -144t-82 -104t-117 -61 t-139.5 -21q-56 0 -107.5 9t-85.5 21.5t-60 25t-38 21.5l-12 9l60 201q11 -7 29.5 -18t72.5 -29t103 -18q64 0 104.5 29t40.5 93q0 33 -24.5 66.5t-61.5 61t-80 62t-80 68.5t-61.5 82.5t-24.5 102.5q0 44 19 85t46 72.5t54 62t46 65.5t19 71q0 57 -45.5 98t-124.5 41 q-86 0 -145 -48.5t-59 -143.5v-926q0 -73 -33 -106t-107 -33h-237z" />
-<glyph unicode="&#xe0;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM242 1452h250l155 -278h-192zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
-<glyph unicode="&#xe1;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM455 1174l155 278h250l-215 -278h-190z " />
-<glyph unicode="&#xe2;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM258 1174l186 278h224l188 -278h-194l-103 165h-4l-104 -165h-193zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127 v24h-45q-350 0 -350 -164z" />
-<glyph unicode="&#xe3;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM184 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-39 0 -72.5 14 t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
-<glyph unicode="&#xe4;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM283 1214v238h180v-238h-180zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM649 1214 v238h182v-238h-182z" />
-<glyph unicode="&#xe5;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM373 1309q0 75 54 118t128 43t128 -43 t54 -118q0 -74 -54 -117t-128 -43t-128 43t-54 117zM483 1309q0 -31 20.5 -50.5t51.5 -19.5t51.5 19.5t20.5 50.5q0 32 -20.5 51.5t-51.5 19.5t-51.5 -19.5t-20.5 -51.5z" />
-<glyph unicode="&#xe6;" horiz-adv-x="1773" d="M70 301q0 67 24.5 121.5t63 90.5t94.5 62.5t109.5 41t118.5 23t111.5 11t96.5 2.5h35v15q0 110 -48.5 155t-146.5 45q-21 0 -42.5 -3t-44.5 -10t-37.5 -21.5t-14.5 -34.5v-56h-242v111q0 61 35.5 105.5t95.5 67t122 32.5t130 10q252 0 349 -154h4q126 154 348 154 q111 0 200 -40.5t144.5 -111t85 -162.5t29.5 -198l-4 -84h-715q17 -135 100.5 -205.5t206.5 -70.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l108 -180q-6 -6 -18.5 -17t-54 -38t-87 -48t-116 -38t-143.5 -17q-151 0 -261.5 60.5t-177.5 169.5h-4q-8 -19 -23 -43 t-48.5 -58t-75 -61t-106 -46.5t-138.5 -19.5q-151 0 -253.5 87.5t-102.5 236.5zM332 313q0 -58 41 -96.5t119 -38.5q101 0 168 87t67 190v18h-74q-59 0 -110 -6.5t-101.5 -23t-80 -50t-29.5 -80.5zM981 653h444q-3 94 -59 153.5t-139 59.5q-97 0 -161 -57t-85 -156z" />
-<glyph unicode="&#xe7;" horiz-adv-x="1101" d="M66 522q0 149 67 272.5t199 199t305 75.5q56 0 117 -12t122 -37.5t100.5 -73.5t39.5 -112v-123h-230v57q0 39 -47 60.5t-102 21.5q-135 0 -222 -92.5t-87 -233.5q0 -77 27 -139.5t72.5 -101.5t103.5 -59.5t122 -20.5q50 0 100 14.5t86.5 35.5t65.5 41.5t43 35.5l15 14 l108 -180q-6 -8 -18 -20.5t-53 -44.5t-87.5 -56.5t-120.5 -45.5t-153 -22l-14 -65q65 -8 106 -47.5t41 -108.5q0 -64 -33 -106t-80 -58t-106 -16q-32 0 -63.5 3.5t-47.5 6.5l-16 4v144q43 -17 90 -17q88 0 88 58q0 55 -98 55l-43 -4l45 164q-202 36 -322 183.5t-120 350.5z " />
-<glyph unicode="&#xe8;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM276 1452h250l156 -278h-193zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
-<glyph unicode="&#xe9;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155zM489 1174l156 278h250l-215 -278h-191z" />
-<glyph unicode="&#xea;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM291 1174l186 278h223l189 -278h-195l-102 165h-4l-105 -165h-192zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
-<glyph unicode="&#xeb;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM315 1214v238h181v-238h-181zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155zM682 1214v238h182v-238h-182z" />
-<glyph unicode="&#xec;" horiz-adv-x="618" d="M-18 1454h247l156 -280h-190zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82z" />
-<glyph unicode="&#xed;" horiz-adv-x="618" d="M53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82zM195 1174l155 280h248l-213 -280h-190z" />
-<glyph unicode="&#xee;" horiz-adv-x="618" d="M-6 1174l188 280h224l188 -280h-197l-102 167h-4l-103 -167h-194zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82z" />
-<glyph unicode="&#xef;" horiz-adv-x="618" d="M41 1214v240h180v-240h-180zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82zM356 1214v240h183v-240h-183z" />
-<glyph unicode="&#xf0;" horiz-adv-x="1198" d="M78 485q0 123 55 228t166.5 172t259.5 67q58 0 110.5 -15t75.5 -29l23 -15h4q-60 133 -192 217l-379 -164l-13 154l228 100q-104 51 -236 82l72 205q259 -58 442 -170l303 129l13 -152l-181 -80q281 -246 281 -645q0 -87 -17.5 -169t-58.5 -160t-101 -136.5t-151.5 -93.5 t-203.5 -35q-116 0 -212 43t-158 114.5t-96 163t-34 189.5zM340 479q0 -117 63.5 -200.5t180.5 -83.5q55 0 100 19.5t75 51.5t50.5 74.5t29.5 88t9 93.5q0 100 -65.5 164t-176.5 64q-127 0 -196.5 -79.5t-69.5 -191.5z" />
-<glyph unicode="&#xf1;" horiz-adv-x="1316" d="M43 823v221h240q137 0 137 -116v-31l-4 -45h4q15 29 35 56.5t53 57.5t72 52t93 36.5t115 14.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-74 0 -106.5 33t-32.5 106v479q0 104 -36 158.5t-128 54.5q-102 0 -177 -58.5t-103 -154.5q-21 -64 -21 -139v-479h-258v778 q0 45 -45 45h-82zM301 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h161q0 -281 -233 -281q-39 0 -72.5 14t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
-<glyph unicode="&#xf2;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM324 1452h249l156 -278h-192zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234 q0 142 -90.5 234t-220.5 92q-129 0 -219 -92t-90 -234z" />
-<glyph unicode="&#xf3;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM539 1174l155 278h250l-215 -278h-190z" />
-<glyph unicode="&#xf4;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM340 1174l186 278h224l188 -278h-195l-102 165h-4l-105 -165h-192z" />
-<glyph unicode="&#xf5;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM266 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90 h162q0 -281 -234 -281q-39 0 -72.5 14t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92q-129 0 -219 -92t-90 -234z" />
-<glyph unicode="&#xf6;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM365 1214v238h180v-238h-180zM731 1214v238h182v-238h-182z" />
-<glyph unicode="&#xf7;" d="M94 483v203h1067v-203h-1067zM510 55v221h233v-221h-233zM510 895v221h233v-221h-233z" />
-<glyph unicode="&#xf8;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q147 0 274 -65l84 116l113 -78l-82 -112q87 -75 135.5 -180t48.5 -228q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-141 0 -256 56l-84 -119l-113 80l78 108q-93 75 -144.5 183.5t-51.5 238.5zM328 522q0 -128 80 -221 l366 514q-68 33 -137 33q-129 0 -219 -92t-90 -234zM518 221q56 -24 119 -24q130 0 220.5 91t90.5 234q0 119 -69 201z" />
-<glyph unicode="&#xf9;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M328 1452h250l155 -278h-192z" />
-<glyph unicode="&#xfa;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M541 1174l155 278h250l-215 -278h-190z" />
-<glyph unicode="&#xfb;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M342 1174l186 278h224l188 -278h-195l-102 165h-4l-104 -165h-193z" />
-<glyph unicode="&#xfc;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M369 1214v238h180v-238h-180zM735 1214v238h183v-238h-183z" />
-<glyph unicode="&#xfd;" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5zM471 1174l156 278h250l-215 -278h-191z" />
-<glyph unicode="&#xfe;" horiz-adv-x="1265" d="M37 1233v221h248q73 0 106 -33.5t33 -105.5v-297l-4 -90h4q98 141 305 141q212 0 341.5 -153.5t129.5 -393.5q0 -238 -129.5 -392.5t-341.5 -154.5q-63 0 -117.5 14.5t-87.5 35t-57 41t-33 34.5l-10 15h-4q4 -37 4 -90v-435h-260v1598q0 45 -45 45h-82zM416 522 q0 -171 74.5 -248t191.5 -77q115 0 185.5 91.5t70.5 233.5q0 143 -70 234.5t-186 91.5q-119 0 -192.5 -78t-73.5 -248z" />
-<glyph unicode="&#xff;" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5zM297 1214v238h180v-238h-180zM664 1214v238h182v-238h-182z" />
-<glyph unicode="&#x152;" horiz-adv-x="1945" d="M61 729q0 206 96.5 376t264 267.5t369.5 97.5q70 0 162.5 -8t133.5 -8h621q73 0 106 -33.5t33 -105.5v-221h-241v88q0 45 -45 45h-322v-381h465v-228h-465v-391h375q45 0 45 45v88h242v-221q0 -73 -32.5 -106t-101.5 -33h-680q-40 0 -132.5 -9t-163.5 -9 q-202 0 -369.5 99t-264 270.5t-96.5 377.5zM340 729q0 -216 127 -357t324 -141q119 0 180 15v960q-76 17 -180 17q-197 0 -324 -140.5t-127 -353.5z" />
-<glyph unicode="&#x153;" horiz-adv-x="2035" d="M66 520q0 160 77 286.5t206.5 194.5t285.5 68q283 0 440 -215h4q135 215 412 215q146 0 252.5 -67t158.5 -178t52 -251l-6 -96h-721q18 -134 105 -207t208 -73q47 0 94.5 12t82 29t62.5 34t42 29l14 12l107 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17 q-292 0 -437 222h-4q-159 -222 -444 -222q-158 0 -287.5 66.5t-206.5 192t-77 286.5zM328 520q0 -145 89.5 -234t219.5 -89t220.5 89.5t90.5 235.5q0 145 -91 235.5t-220 90.5t-219 -91t-90 -237zM1235 657h453q-5 94 -59 152.5t-138 58.5q-99 0 -166.5 -56t-89.5 -155z" />
-<glyph unicode="&#x178;" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48zM358 1591v238h181v-238h-181z M725 1591v238h182v-238h-182z" />
-<glyph unicode="&#x2c6;" horiz-adv-x="1026" d="M215 1550l186 279h224l188 -279h-195l-102 166h-4l-104 -166h-193z" />
-<glyph unicode="&#x2dc;" horiz-adv-x="1122" d="M197 1552q0 281 233 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -233 -281q-48 0 -88.5 21t-64 45.5t-53 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-161z" />
-<glyph unicode="&#x2000;" horiz-adv-x="923" />
-<glyph unicode="&#x2001;" horiz-adv-x="1847" />
-<glyph unicode="&#x2002;" horiz-adv-x="923" />
-<glyph unicode="&#x2003;" horiz-adv-x="1847" />
-<glyph unicode="&#x2004;" horiz-adv-x="615" />
-<glyph unicode="&#x2005;" horiz-adv-x="461" />
-<glyph unicode="&#x2006;" horiz-adv-x="307" />
-<glyph unicode="&#x2007;" horiz-adv-x="307" />
-<glyph unicode="&#x2008;" horiz-adv-x="230" />
-<glyph unicode="&#x2009;" horiz-adv-x="369" />
-<glyph unicode="&#x200a;" horiz-adv-x="102" />
-<glyph unicode="&#x2010;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
-<glyph unicode="&#x2011;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
-<glyph unicode="&#x2012;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
-<glyph unicode="&#x2013;" horiz-adv-x="1357" d="M113 483v203h1132v-203h-1132z" />
-<glyph unicode="&#x2014;" horiz-adv-x="1767" d="M113 483v203h1542v-203h-1542z" />
-<glyph unicode="&#x2018;" horiz-adv-x="501" d="M86 1032l154 447h176l-97 -447h-233z" />
-<glyph unicode="&#x2019;" horiz-adv-x="501" d="M86 1032l96 449h234l-154 -449h-176z" />
-<glyph unicode="&#x201a;" horiz-adv-x="501" d="M86 -182l96 446h234l-154 -446h-176z" />
-<glyph unicode="&#x201c;" horiz-adv-x="827" d="M86 1032l154 447h176l-97 -447h-233zM414 1032l151 447h176l-96 -447h-231z" />
-<glyph unicode="&#x201d;" horiz-adv-x="827" d="M86 1032l96 449h234l-154 -449h-176zM414 1032l96 449h231l-151 -449h-176z" />
-<glyph unicode="&#x201e;" horiz-adv-x="827" d="M86 -182l96 446h234l-154 -446h-176zM414 -182l96 446h231l-151 -446h-176z" />
-<glyph unicode="&#x2022;" horiz-adv-x="960" d="M137 596q0 141 100.5 241.5t241.5 100.5q142 0 242 -100.5t100 -241.5t-100 -241.5t-242 -100.5q-141 0 -241.5 100.5t-100.5 241.5z" />
-<glyph unicode="&#x2026;" horiz-adv-x="2033" d="M309 0v260h250v-260h-250zM891 0v260h252v-260h-252zM1475 0v260h251v-260h-251z" />
-<glyph unicode="&#x202f;" horiz-adv-x="369" />
-<glyph unicode="&#x2039;" horiz-adv-x="802" d="M94 578l336 421h248l-336 -421l336 -420h-248z" />
-<glyph unicode="&#x203a;" horiz-adv-x="802" d="M119 158l336 420l-336 421h248l335 -421l-335 -420h-248z" />
-<glyph unicode="&#x205f;" horiz-adv-x="461" />
-<glyph unicode="&#x20ac;" horiz-adv-x="1253" d="M78 512v156h127q-4 34 -4 61l4 66h-127v157h153q67 233 259 380t442 147q48 0 99 -6.5t77 -13.5l27 -7l-64 -240q-69 21 -145 21q-145 0 -253.5 -75.5t-158.5 -205.5h510l-33 -157h-514q-4 -31 -4 -62l6 -65h488l-31 -156h-410q47 -131 158 -209t252 -78q47 0 96.5 7.5 t75.5 15.5l25 8l47 -242q-107 -39 -248 -39q-259 0 -448 148t-253 389h-153z" />
-<glyph unicode="&#x2122;" horiz-adv-x="2029" d="M70 1206v156q0 53 20 72.5t78 19.5h606q56 0 76 -19.5t20 -72.5v-156h-163v60q0 16 -15 16h-123v-735h-196v735h-119q-16 0 -16 -16v-60h-168zM874 547v170h46q17 0 20 18l57 719h183l186 -428l29 -86h4q12 51 26 86l189 428h180l57 -719q3 -18 21 -18h47v-170h-154 q-57 0 -78.5 17.5t-25.5 74.5l-27 375l2 63h-4l-159 -364h-154l-160 364h-4l2 -63l-27 -375q-4 -57 -24.5 -74.5t-77.5 -17.5h-154z" />
-<glyph unicode="&#x25fc;" horiz-adv-x="1044" d="M0 0v1044h1044v-1044h-1044z" />
-<hkern u1="&#x20;" u2="&#x2026;" k="102" />
-<hkern u1="&#x20;" u2="&#x201e;" k="102" />
-<hkern u1="&#x20;" u2="&#x201d;" k="143" />
-<hkern u1="&#x20;" u2="&#x201c;" k="143" />
-<hkern u1="&#x20;" u2="&#x201a;" k="102" />
-<hkern u1="&#x20;" u2="&#x2019;" k="143" />
-<hkern u1="&#x20;" u2="&#x2018;" k="143" />
-<hkern u1="&#x20;" u2="&#x178;" k="72" />
-<hkern u1="&#x20;" u2="&#xdd;" k="72" />
-<hkern u1="&#x20;" u2="Y" k="72" />
-<hkern u1="&#x20;" u2="W" k="47" />
-<hkern u1="&#x20;" u2="V" k="47" />
-<hkern u1="&#x20;" u2="T" k="41" />
-<hkern u1="&#x20;" u2="&#x2e;" k="102" />
-<hkern u1="&#x20;" u2="&#x2c;" k="102" />
-<hkern u1="&#x22;" u2="X" k="-41" />
-<hkern u1="&#x22;" u2="&#x34;" k="102" />
-<hkern u1="&#x24;" u2="&#x37;" k="41" />
-<hkern u1="&#x27;" u2="X" k="-41" />
-<hkern u1="&#x27;" u2="&#x34;" k="102" />
-<hkern u1="&#x28;" u2="j" k="-43" />
-<hkern u1="&#x28;" u2="&#x34;" k="82" />
-<hkern u1="&#x2b;" u2="&#x37;" k="35" />
-<hkern u1="&#x2c;" u2="&#x39;" k="10" />
-<hkern u1="&#x2c;" u2="&#x37;" k="35" />
-<hkern u1="&#x2c;" u2="&#x36;" k="20" />
-<hkern u1="&#x2c;" u2="&#x34;" k="20" />
-<hkern u1="&#x2c;" u2="&#x30;" k="41" />
-<hkern u1="&#x2d;" u2="x" k="35" />
-<hkern u1="&#x2d;" u2="X" k="20" />
-<hkern u1="&#x2d;" u2="&#x39;" k="57" />
-<hkern u1="&#x2d;" u2="&#x37;" k="123" />
-<hkern u1="&#x2d;" u2="&#x35;" k="49" />
-<hkern u1="&#x2d;" u2="&#x33;" k="82" />
-<hkern u1="&#x2d;" u2="&#x31;" k="61" />
-<hkern u1="&#x2e;" u2="&#x39;" k="10" />
-<hkern u1="&#x2e;" u2="&#x37;" k="35" />
-<hkern u1="&#x2e;" u2="&#x36;" k="20" />
-<hkern u1="&#x2e;" u2="&#x34;" k="20" />
-<hkern u1="&#x2e;" u2="&#x30;" k="41" />
-<hkern u1="&#x2f;" u2="&#x37;" k="-33" />
-<hkern u1="&#x30;" u2="&#x2026;" k="82" />
-<hkern u1="&#x30;" u2="&#x201e;" k="82" />
-<hkern u1="&#x30;" u2="&#x201a;" k="82" />
-<hkern u1="&#x30;" u2="&#xb0;" k="20" />
-<hkern u1="&#x30;" u2="&#x38;" k="23" />
-<hkern u1="&#x30;" u2="&#x37;" k="49" />
-<hkern u1="&#x30;" u2="&#x33;" k="20" />
-<hkern u1="&#x30;" u2="&#x32;" k="23" />
-<hkern u1="&#x30;" u2="&#x31;" k="31" />
-<hkern u1="&#x30;" u2="&#x2e;" k="82" />
-<hkern u1="&#x30;" u2="&#x2c;" k="82" />
-<hkern u1="&#x31;" u2="&#x201d;" k="102" />
-<hkern u1="&#x31;" u2="&#x201c;" k="102" />
-<hkern u1="&#x31;" u2="&#x2019;" k="102" />
-<hkern u1="&#x31;" u2="&#x2018;" k="102" />
-<hkern u1="&#x31;" u2="&#x2014;" k="102" />
-<hkern u1="&#x31;" u2="&#x2013;" k="102" />
-<hkern u1="&#x31;" u2="&#xb0;" k="143" />
-<hkern u1="&#x31;" u2="&#x39;" k="27" />
-<hkern u1="&#x31;" u2="&#x38;" k="14" />
-<hkern u1="&#x31;" u2="&#x37;" k="20" />
-<hkern u1="&#x31;" u2="&#x36;" k="27" />
-<hkern u1="&#x31;" u2="&#x35;" k="14" />
-<hkern u1="&#x31;" u2="&#x34;" k="37" />
-<hkern u1="&#x31;" u2="&#x33;" k="8" />
-<hkern u1="&#x31;" u2="&#x30;" k="31" />
-<hkern u1="&#x31;" u2="&#x2f;" k="-49" />
-<hkern u1="&#x31;" u2="&#x2d;" k="102" />
-<hkern u1="&#x31;" u2="&#x27;" k="123" />
-<hkern u1="&#x31;" u2="&#x25;" k="53" />
-<hkern u1="&#x31;" u2="&#x22;" k="123" />
-<hkern u1="&#x32;" u2="&#x2014;" k="35" />
-<hkern u1="&#x32;" u2="&#x2013;" k="35" />
-<hkern u1="&#x32;" u2="&#x39;" k="37" />
-<hkern u1="&#x32;" u2="&#x37;" k="6" />
-<hkern u1="&#x32;" u2="&#x34;" k="41" />
-<hkern u1="&#x32;" u2="&#x30;" k="10" />
-<hkern u1="&#x32;" u2="&#x2d;" k="35" />
-<hkern u1="&#x33;" u2="&#x39;" k="10" />
-<hkern u1="&#x33;" u2="&#x37;" k="10" />
-<hkern u1="&#x34;" u2="&#x2026;" k="20" />
-<hkern u1="&#x34;" u2="&#x201e;" k="20" />
-<hkern u1="&#x34;" u2="&#x201d;" k="41" />
-<hkern u1="&#x34;" u2="&#x201c;" k="41" />
-<hkern u1="&#x34;" u2="&#x201a;" k="20" />
-<hkern u1="&#x34;" u2="&#x2019;" k="41" />
-<hkern u1="&#x34;" u2="&#x2018;" k="41" />
-<hkern u1="&#x34;" u2="&#xb0;" k="41" />
-<hkern u1="&#x34;" u2="&#x39;" k="20" />
-<hkern u1="&#x34;" u2="&#x34;" k="-61" />
-<hkern u1="&#x34;" u2="&#x32;" k="-41" />
-<hkern u1="&#x34;" u2="&#x31;" k="14" />
-<hkern u1="&#x34;" u2="&#x2e;" k="20" />
-<hkern u1="&#x34;" u2="&#x2c;" k="20" />
-<hkern u1="&#x35;" u2="&#x2026;" k="27" />
-<hkern u1="&#x35;" u2="&#x201e;" k="27" />
-<hkern u1="&#x35;" u2="&#x201a;" k="27" />
-<hkern u1="&#x35;" u2="&#xb0;" k="41" />
-<hkern u1="&#x35;" u2="&#x39;" k="6" />
-<hkern u1="&#x35;" u2="&#x37;" k="35" />
-<hkern u1="&#x35;" u2="&#x35;" k="18" />
-<hkern u1="&#x35;" u2="&#x33;" k="18" />
-<hkern u1="&#x35;" u2="&#x32;" k="10" />
-<hkern u1="&#x35;" u2="&#x31;" k="41" />
-<hkern u1="&#x35;" u2="&#x30;" k="14" />
-<hkern u1="&#x35;" u2="&#x2e;" k="27" />
-<hkern u1="&#x35;" u2="&#x2c;" k="27" />
-<hkern u1="&#x36;" u2="&#x2014;" k="27" />
-<hkern u1="&#x36;" u2="&#x2013;" k="27" />
-<hkern u1="&#x36;" u2="&#x39;" k="20" />
-<hkern u1="&#x36;" u2="&#x37;" k="18" />
-<hkern u1="&#x36;" u2="&#x35;" k="10" />
-<hkern u1="&#x36;" u2="&#x33;" k="10" />
-<hkern u1="&#x36;" u2="&#x30;" k="16" />
-<hkern u1="&#x36;" u2="&#x2d;" k="27" />
-<hkern u1="&#x37;" u2="&#x203a;" k="23" />
-<hkern u1="&#x37;" u2="&#x2039;" k="23" />
-<hkern u1="&#x37;" u2="&#x2026;" k="246" />
-<hkern u1="&#x37;" u2="&#x201e;" k="246" />
-<hkern u1="&#x37;" u2="&#x201d;" k="-72" />
-<hkern u1="&#x37;" u2="&#x201c;" k="-72" />
-<hkern u1="&#x37;" u2="&#x201a;" k="246" />
-<hkern u1="&#x37;" u2="&#x2019;" k="-72" />
-<hkern u1="&#x37;" u2="&#x2018;" k="-72" />
-<hkern u1="&#x37;" u2="&#x2014;" k="111" />
-<hkern u1="&#x37;" u2="&#x2013;" k="111" />
-<hkern u1="&#x37;" u2="&#xbb;" k="23" />
-<hkern u1="&#x37;" u2="&#xb0;" k="-61" />
-<hkern u1="&#x37;" u2="&#xab;" k="23" />
-<hkern u1="&#x37;" u2="&#x3f;" k="-29" />
-<hkern u1="&#x37;" u2="&#x3e;" k="76" />
-<hkern u1="&#x37;" u2="&#x3d;" k="76" />
-<hkern u1="&#x37;" u2="&#x3c;" k="76" />
-<hkern u1="&#x37;" u2="&#x3b;" k="31" />
-<hkern u1="&#x37;" u2="&#x3a;" k="31" />
-<hkern u1="&#x37;" u2="&#x39;" k="18" />
-<hkern u1="&#x37;" u2="&#x38;" k="14" />
-<hkern u1="&#x37;" u2="&#x37;" k="-10" />
-<hkern u1="&#x37;" u2="&#x35;" k="8" />
-<hkern u1="&#x37;" u2="&#x34;" k="119" />
-<hkern u1="&#x37;" u2="&#x32;" k="14" />
-<hkern u1="&#x37;" u2="&#x31;" k="6" />
-<hkern u1="&#x37;" u2="&#x30;" k="41" />
-<hkern u1="&#x37;" u2="&#x2f;" k="123" />
-<hkern u1="&#x37;" u2="&#x2e;" k="246" />
-<hkern u1="&#x37;" u2="&#x2d;" k="111" />
-<hkern u1="&#x37;" u2="&#x2c;" k="246" />
-<hkern u1="&#x37;" u2="&#x2b;" k="76" />
-<hkern u1="&#x38;" u2="&#x39;" k="14" />
-<hkern u1="&#x38;" u2="&#x37;" k="25" />
-<hkern u1="&#x38;" u2="&#x34;" k="-6" />
-<hkern u1="&#x38;" u2="&#x30;" k="23" />
-<hkern u1="&#x39;" u2="&#x2026;" k="82" />
-<hkern u1="&#x39;" u2="&#x201e;" k="82" />
-<hkern u1="&#x39;" u2="&#x201a;" k="82" />
-<hkern u1="&#x39;" u2="&#x38;" k="10" />
-<hkern u1="&#x39;" u2="&#x37;" k="27" />
-<hkern u1="&#x39;" u2="&#x33;" k="10" />
-<hkern u1="&#x39;" u2="&#x32;" k="10" />
-<hkern u1="&#x39;" u2="&#x31;" k="6" />
-<hkern u1="&#x39;" u2="&#x30;" k="10" />
-<hkern u1="&#x39;" u2="&#x2e;" k="82" />
-<hkern u1="&#x39;" u2="&#x2c;" k="82" />
-<hkern u1="&#x3c;" u2="&#x37;" k="35" />
-<hkern u1="&#x3d;" u2="&#x37;" k="35" />
-<hkern u1="&#x3e;" u2="&#x37;" k="35" />
-<hkern u1="A" u2="X" k="14" />
-<hkern u1="B" u2="&#x201d;" k="35" />
-<hkern u1="B" u2="&#x201c;" k="35" />
-<hkern u1="B" u2="&#x2019;" k="35" />
-<hkern u1="B" u2="&#x2018;" k="35" />
-<hkern u1="B" u2="&#x178;" k="51" />
-<hkern u1="B" u2="&#xdd;" k="51" />
-<hkern u1="B" u2="w" k="10" />
-<hkern u1="B" u2="v" k="10" />
-<hkern u1="B" u2="Y" k="51" />
-<hkern u1="B" u2="W" k="25" />
-<hkern u1="B" u2="V" k="25" />
-<hkern u1="B" u2="T" k="39" />
-<hkern u1="B" u2="&#x27;" k="12" />
-<hkern u1="B" u2="&#x22;" k="12" />
-<hkern u1="D" u2="i" k="-14" />
-<hkern u1="D" u2="X" k="23" />
-<hkern u1="F" u2="&#x2026;" k="205" />
-<hkern u1="F" u2="&#x201e;" k="205" />
-<hkern u1="F" u2="&#x201d;" k="-51" />
-<hkern u1="F" u2="&#x201c;" k="-51" />
-<hkern u1="F" u2="&#x201a;" k="205" />
-<hkern u1="F" u2="&#x2019;" k="-51" />
-<hkern u1="F" u2="&#x2018;" k="-51" />
-<hkern u1="F" u2="&#x153;" k="10" />
-<hkern u1="F" u2="&#x152;" k="20" />
-<hkern u1="F" u2="&#xf8;" k="10" />
-<hkern u1="F" u2="&#xf6;" k="10" />
-<hkern u1="F" u2="&#xf5;" k="10" />
-<hkern u1="F" u2="&#xf4;" k="10" />
-<hkern u1="F" u2="&#xf3;" k="10" />
-<hkern u1="F" u2="&#xf2;" k="10" />
-<hkern u1="F" u2="&#xeb;" k="10" />
-<hkern u1="F" u2="&#xea;" k="10" />
-<hkern u1="F" u2="&#xe9;" k="10" />
-<hkern u1="F" u2="&#xe8;" k="10" />
-<hkern u1="F" u2="&#xe7;" k="10" />
-<hkern u1="F" u2="&#xe6;" k="31" />
-<hkern u1="F" u2="&#xe5;" k="31" />
-<hkern u1="F" u2="&#xe4;" k="31" />
-<hkern u1="F" u2="&#xe3;" k="31" />
-<hkern u1="F" u2="&#xe2;" k="31" />
-<hkern u1="F" u2="&#xe1;" k="31" />
-<hkern u1="F" u2="&#xe0;" k="31" />
-<hkern u1="F" u2="&#xd8;" k="20" />
-<hkern u1="F" u2="&#xd6;" k="20" />
-<hkern u1="F" u2="&#xd5;" k="20" />
-<hkern u1="F" u2="&#xd4;" k="20" />
-<hkern u1="F" u2="&#xd3;" k="20" />
-<hkern u1="F" u2="&#xd2;" k="20" />
-<hkern u1="F" u2="&#xc7;" k="20" />
-<hkern u1="F" u2="&#xc6;" k="94" />
-<hkern u1="F" u2="&#xc5;" k="94" />
-<hkern u1="F" u2="&#xc4;" k="94" />
-<hkern u1="F" u2="&#xc3;" k="94" />
-<hkern u1="F" u2="&#xc2;" k="94" />
-<hkern u1="F" u2="&#xc1;" k="94" />
-<hkern u1="F" u2="&#xc0;" k="94" />
-<hkern u1="F" u2="q" k="10" />
-<hkern u1="F" u2="o" k="10" />
-<hkern u1="F" u2="g" k="10" />
-<hkern u1="F" u2="e" k="10" />
-<hkern u1="F" u2="d" k="10" />
-<hkern u1="F" u2="c" k="10" />
-<hkern u1="F" u2="a" k="31" />
-<hkern u1="F" u2="Q" k="20" />
-<hkern u1="F" u2="O" k="20" />
-<hkern u1="F" u2="N" k="14" />
-<hkern u1="F" u2="M" k="14" />
-<hkern u1="F" u2="J" k="37" />
-<hkern u1="F" u2="G" k="20" />
-<hkern u1="F" u2="C" k="20" />
-<hkern u1="F" u2="A" k="94" />
-<hkern u1="F" u2="&#x40;" k="10" />
-<hkern u1="F" u2="&#x2e;" k="205" />
-<hkern u1="F" u2="&#x2c;" k="205" />
-<hkern u1="F" u2="&#x27;" k="-39" />
-<hkern u1="F" u2="&#x22;" k="-39" />
-<hkern u1="K" u2="x" k="10" />
-<hkern u1="L" u2="&#x2a;" k="143" />
-<hkern u1="M" u2="&#x201d;" k="59" />
-<hkern u1="M" u2="&#x201c;" k="59" />
-<hkern u1="M" u2="&#x2019;" k="59" />
-<hkern u1="M" u2="&#x2018;" k="59" />
-<hkern u1="M" u2="&#xfc;" k="-8" />
-<hkern u1="M" u2="&#xfb;" k="-8" />
-<hkern u1="M" u2="&#xfa;" k="-8" />
-<hkern u1="M" u2="&#xf9;" k="-8" />
-<hkern u1="M" u2="&#xf1;" k="-8" />
-<hkern u1="M" u2="u" k="-8" />
-<hkern u1="M" u2="r" k="-8" />
-<hkern u1="M" u2="p" k="-8" />
-<hkern u1="M" u2="n" k="-8" />
-<hkern u1="M" u2="m" k="-8" />
-<hkern u1="M" u2="T" k="35" />
-<hkern u1="M" u2="&#x27;" k="61" />
-<hkern u1="M" u2="&#x22;" k="61" />
-<hkern u1="O" u2="i" k="-14" />
-<hkern u1="O" u2="X" k="23" />
-<hkern u1="P" u2="&#x2026;" k="215" />
-<hkern u1="P" u2="&#x201e;" k="215" />
-<hkern u1="P" u2="&#x201a;" k="215" />
-<hkern u1="P" u2="&#x153;" k="41" />
-<hkern u1="P" u2="&#xf8;" k="41" />
-<hkern u1="P" u2="&#xf6;" k="41" />
-<hkern u1="P" u2="&#xf5;" k="41" />
-<hkern u1="P" u2="&#xf4;" k="41" />
-<hkern u1="P" u2="&#xf3;" k="41" />
-<hkern u1="P" u2="&#xf2;" k="41" />
-<hkern u1="P" u2="&#xeb;" k="41" />
-<hkern u1="P" u2="&#xea;" k="41" />
-<hkern u1="P" u2="&#xe9;" k="41" />
-<hkern u1="P" u2="&#xe8;" k="41" />
-<hkern u1="P" u2="&#xe7;" k="41" />
-<hkern u1="P" u2="&#xe6;" k="41" />
-<hkern u1="P" u2="&#xe5;" k="41" />
-<hkern u1="P" u2="&#xe4;" k="41" />
-<hkern u1="P" u2="&#xe3;" k="41" />
-<hkern u1="P" u2="&#xe2;" k="41" />
-<hkern u1="P" u2="&#xe1;" k="41" />
-<hkern u1="P" u2="&#xe0;" k="41" />
-<hkern u1="P" u2="&#xc6;" k="117" />
-<hkern u1="P" u2="&#xc5;" k="117" />
-<hkern u1="P" u2="&#xc4;" k="117" />
-<hkern u1="P" u2="&#xc3;" k="117" />
-<hkern u1="P" u2="&#xc2;" k="117" />
-<hkern u1="P" u2="&#xc1;" k="117" />
-<hkern u1="P" u2="&#xc0;" k="117" />
-<hkern u1="P" u2="z" k="10" />
-<hkern u1="P" u2="s" k="23" />
-<hkern u1="P" u2="q" k="41" />
-<hkern u1="P" u2="o" k="41" />
-<hkern u1="P" u2="g" k="41" />
-<hkern u1="P" u2="e" k="41" />
-<hkern u1="P" u2="d" k="41" />
-<hkern u1="P" u2="c" k="41" />
-<hkern u1="P" u2="a" k="41" />
-<hkern u1="P" u2="N" k="14" />
-<hkern u1="P" u2="M" k="14" />
-<hkern u1="P" u2="J" k="31" />
-<hkern u1="P" u2="A" k="117" />
-<hkern u1="P" u2="&#x40;" k="41" />
-<hkern u1="P" u2="&#x2e;" k="215" />
-<hkern u1="P" u2="&#x2c;" k="215" />
-<hkern u1="P" u2="&#x27;" k="-10" />
-<hkern u1="P" u2="&#x22;" k="-10" />
-<hkern u1="Q" u2="i" k="-14" />
-<hkern u1="Q" u2="X" k="23" />
-<hkern u1="T" u2="&#xef;" k="-61" />
-<hkern u1="T" u2="j" k="82" />
-<hkern u1="T" u2="i" k="55" />
-<hkern u1="T" u2="&#x20;" k="41" />
-<hkern u1="V" u2="&#x20;" k="47" />
-<hkern u1="W" u2="&#x20;" k="47" />
-<hkern u1="X" u2="&#x201d;" k="-27" />
-<hkern u1="X" u2="&#x201c;" k="-27" />
-<hkern u1="X" u2="&#x2019;" k="-27" />
-<hkern u1="X" u2="&#x2018;" k="-27" />
-<hkern u1="X" u2="&#x2014;" k="20" />
-<hkern u1="X" u2="&#x2013;" k="20" />
-<hkern u1="X" u2="&#x153;" k="14" />
-<hkern u1="X" u2="&#x152;" k="23" />
-<hkern u1="X" u2="&#xf8;" k="14" />
-<hkern u1="X" u2="&#xf6;" k="14" />
-<hkern u1="X" u2="&#xf5;" k="14" />
-<hkern u1="X" u2="&#xf4;" k="14" />
-<hkern u1="X" u2="&#xf3;" k="14" />
-<hkern u1="X" u2="&#xf2;" k="14" />
-<hkern u1="X" u2="&#xeb;" k="14" />
-<hkern u1="X" u2="&#xea;" k="14" />
-<hkern u1="X" u2="&#xe9;" k="14" />
-<hkern u1="X" u2="&#xe8;" k="14" />
-<hkern u1="X" u2="&#xe7;" k="14" />
-<hkern u1="X" u2="&#xd8;" k="23" />
-<hkern u1="X" u2="&#xd6;" k="23" />
-<hkern u1="X" u2="&#xd5;" k="23" />
-<hkern u1="X" u2="&#xd4;" k="23" />
-<hkern u1="X" u2="&#xd3;" k="23" />
-<hkern u1="X" u2="&#xd2;" k="23" />
-<hkern u1="X" u2="&#xc7;" k="23" />
-<hkern u1="X" u2="&#xc6;" k="14" />
-<hkern u1="X" u2="&#xc5;" k="14" />
-<hkern u1="X" u2="&#xc4;" k="14" />
-<hkern u1="X" u2="&#xc3;" k="14" />
-<hkern u1="X" u2="&#xc2;" k="14" />
-<hkern u1="X" u2="&#xc1;" k="14" />
-<hkern u1="X" u2="&#xc0;" k="14" />
-<hkern u1="X" u2="&#x7d;" k="-41" />
-<hkern u1="X" u2="&#x7c;" k="-41" />
-<hkern u1="X" u2="q" k="14" />
-<hkern u1="X" u2="o" k="14" />
-<hkern u1="X" u2="g" k="14" />
-<hkern u1="X" u2="e" k="14" />
-<hkern u1="X" u2="d" k="14" />
-<hkern u1="X" u2="c" k="14" />
-<hkern u1="X" u2="]" k="-41" />
-<hkern u1="X" u2="Q" k="23" />
-<hkern u1="X" u2="O" k="23" />
-<hkern u1="X" u2="G" k="23" />
-<hkern u1="X" u2="C" k="23" />
-<hkern u1="X" u2="A" k="14" />
-<hkern u1="X" u2="&#x40;" k="14" />
-<hkern u1="X" u2="&#x2d;" k="20" />
-<hkern u1="X" u2="&#x29;" k="-41" />
-<hkern u1="X" u2="&#x27;" k="-41" />
-<hkern u1="X" u2="&#x22;" k="-41" />
-<hkern u1="Y" u2="&#x20;" k="72" />
-<hkern u1="[" u2="j" k="-43" />
-<hkern u1="[" u2="&#x34;" k="82" />
-<hkern u1="c" u2="&#xff;" k="10" />
-<hkern u1="c" u2="&#xfd;" k="10" />
-<hkern u1="c" u2="y" k="10" />
-<hkern u1="c" u2="l" k="6" />
-<hkern u1="c" u2="k" k="6" />
-<hkern u1="c" u2="h" k="6" />
-<hkern u1="c" u2="b" k="6" />
-<hkern u1="c" u2="T" k="61" />
-<hkern u1="k" u2="&#x201d;" k="-20" />
-<hkern u1="k" u2="&#x201c;" k="-20" />
-<hkern u1="k" u2="&#x2019;" k="-20" />
-<hkern u1="k" u2="&#x2018;" k="-20" />
-<hkern u1="k" u2="&#x153;" k="16" />
-<hkern u1="k" u2="&#xff;" k="23" />
-<hkern u1="k" u2="&#xfd;" k="23" />
-<hkern u1="k" u2="&#xf8;" k="16" />
-<hkern u1="k" u2="&#xf6;" k="16" />
-<hkern u1="k" u2="&#xf5;" k="16" />
-<hkern u1="k" u2="&#xf4;" k="16" />
-<hkern u1="k" u2="&#xf3;" k="16" />
-<hkern u1="k" u2="&#xf2;" k="16" />
-<hkern u1="k" u2="&#xeb;" k="16" />
-<hkern u1="k" u2="&#xea;" k="16" />
-<hkern u1="k" u2="&#xe9;" k="16" />
-<hkern u1="k" u2="&#xe8;" k="16" />
-<hkern u1="k" u2="&#xe7;" k="16" />
-<hkern u1="k" u2="&#xe6;" k="6" />
-<hkern u1="k" u2="&#xe5;" k="6" />
-<hkern u1="k" u2="&#xe4;" k="6" />
-<hkern u1="k" u2="&#xe3;" k="6" />
-<hkern u1="k" u2="&#xe2;" k="6" />
-<hkern u1="k" u2="&#xe1;" k="6" />
-<hkern u1="k" u2="&#xe0;" k="6" />
-<hkern u1="k" u2="y" k="23" />
-<hkern u1="k" u2="w" k="23" />
-<hkern u1="k" u2="v" k="23" />
-<hkern u1="k" u2="q" k="16" />
-<hkern u1="k" u2="o" k="16" />
-<hkern u1="k" u2="l" k="12" />
-<hkern u1="k" u2="k" k="12" />
-<hkern u1="k" u2="h" k="12" />
-<hkern u1="k" u2="g" k="16" />
-<hkern u1="k" u2="e" k="16" />
-<hkern u1="k" u2="d" k="16" />
-<hkern u1="k" u2="c" k="16" />
-<hkern u1="k" u2="b" k="12" />
-<hkern u1="k" u2="a" k="6" />
-<hkern u1="k" u2="T" k="41" />
-<hkern u1="k" u2="&#x40;" k="16" />
-<hkern u1="x" u2="&#x201d;" k="-41" />
-<hkern u1="x" u2="&#x201c;" k="-41" />
-<hkern u1="x" u2="&#x2019;" k="-41" />
-<hkern u1="x" u2="&#x2018;" k="-41" />
-<hkern u1="x" u2="&#x2014;" k="35" />
-<hkern u1="x" u2="&#x2013;" k="35" />
-<hkern u1="x" u2="&#x2d;" k="35" />
-<hkern u1="&#x7b;" u2="j" k="-43" />
-<hkern u1="&#x7b;" u2="&#x34;" k="82" />
-<hkern u1="&#x7c;" u2="j" k="-43" />
-<hkern u1="&#x7c;" u2="&#x34;" k="82" />
-<hkern u1="&#xa3;" u2="&#x37;" k="20" />
-<hkern u1="&#xa5;" u2="&#x37;" k="-33" />
-<hkern u1="&#xa5;" u2="&#x34;" k="41" />
-<hkern u1="&#xab;" u2="&#x37;" k="74" />
-<hkern u1="&#xbb;" u2="&#x37;" k="74" />
-<hkern u1="&#xc0;" u2="X" k="14" />
-<hkern u1="&#xc1;" u2="X" k="14" />
-<hkern u1="&#xc2;" u2="X" k="14" />
-<hkern u1="&#xc3;" u2="X" k="14" />
-<hkern u1="&#xc4;" u2="X" k="14" />
-<hkern u1="&#xc5;" u2="X" k="14" />
-<hkern u1="&#xd0;" u2="i" k="-14" />
-<hkern u1="&#xd0;" u2="X" k="23" />
-<hkern u1="&#xd2;" u2="i" k="-14" />
-<hkern u1="&#xd2;" u2="X" k="23" />
-<hkern u1="&#xd3;" u2="i" k="-14" />
-<hkern u1="&#xd3;" u2="X" k="23" />
-<hkern u1="&#xd4;" u2="i" k="-14" />
-<hkern u1="&#xd4;" u2="X" k="23" />
-<hkern u1="&#xd5;" u2="i" k="-14" />
-<hkern u1="&#xd5;" u2="X" k="23" />
-<hkern u1="&#xd6;" u2="i" k="-14" />
-<hkern u1="&#xd6;" u2="X" k="23" />
-<hkern u1="&#xd8;" u2="i" k="-14" />
-<hkern u1="&#xd8;" u2="X" k="23" />
-<hkern u1="&#xdd;" u2="&#x20;" k="72" />
-<hkern u1="&#x178;" u2="&#x20;" k="72" />
-<hkern u1="&#x2013;" u2="x" k="35" />
-<hkern u1="&#x2013;" u2="X" k="20" />
-<hkern u1="&#x2013;" u2="&#x39;" k="57" />
-<hkern u1="&#x2013;" u2="&#x37;" k="123" />
-<hkern u1="&#x2013;" u2="&#x35;" k="49" />
-<hkern u1="&#x2013;" u2="&#x33;" k="82" />
-<hkern u1="&#x2013;" u2="&#x31;" k="61" />
-<hkern u1="&#x2014;" u2="x" k="35" />
-<hkern u1="&#x2014;" u2="X" k="20" />
-<hkern u1="&#x2014;" u2="&#x39;" k="57" />
-<hkern u1="&#x2014;" u2="&#x37;" k="123" />
-<hkern u1="&#x2014;" u2="&#x35;" k="49" />
-<hkern u1="&#x2014;" u2="&#x33;" k="82" />
-<hkern u1="&#x2014;" u2="&#x31;" k="61" />
-<hkern u1="&#x2018;" u2="X" k="-27" />
-<hkern u1="&#x2018;" u2="&#x38;" k="49" />
-<hkern u1="&#x2018;" u2="&#x37;" k="-47" />
-<hkern u1="&#x2018;" u2="&#x36;" k="82" />
-<hkern u1="&#x2018;" u2="&#x34;" k="172" />
-<hkern u1="&#x2018;" u2="&#x30;" k="49" />
-<hkern u1="&#x2019;" u2="X" k="-27" />
-<hkern u1="&#x2019;" u2="&#x38;" k="49" />
-<hkern u1="&#x2019;" u2="&#x37;" k="-47" />
-<hkern u1="&#x2019;" u2="&#x36;" k="82" />
-<hkern u1="&#x2019;" u2="&#x34;" k="172" />
-<hkern u1="&#x2019;" u2="&#x30;" k="49" />
-<hkern u1="&#x201a;" u2="&#x39;" k="10" />
-<hkern u1="&#x201a;" u2="&#x37;" k="35" />
-<hkern u1="&#x201a;" u2="&#x36;" k="20" />
-<hkern u1="&#x201a;" u2="&#x34;" k="20" />
-<hkern u1="&#x201a;" u2="&#x30;" k="41" />
-<hkern u1="&#x201c;" u2="X" k="-27" />
-<hkern u1="&#x201c;" u2="&#x38;" k="49" />
-<hkern u1="&#x201c;" u2="&#x37;" k="-47" />
-<hkern u1="&#x201c;" u2="&#x36;" k="82" />
-<hkern u1="&#x201c;" u2="&#x34;" k="172" />
-<hkern u1="&#x201c;" u2="&#x30;" k="49" />
-<hkern u1="&#x201d;" u2="X" k="-27" />
-<hkern u1="&#x201d;" u2="&#x38;" k="49" />
-<hkern u1="&#x201d;" u2="&#x37;" k="-47" />
-<hkern u1="&#x201d;" u2="&#x36;" k="82" />
-<hkern u1="&#x201d;" u2="&#x34;" k="172" />
-<hkern u1="&#x201d;" u2="&#x30;" k="49" />
-<hkern u1="&#x201e;" u2="&#x39;" k="10" />
-<hkern u1="&#x201e;" u2="&#x37;" k="35" />
-<hkern u1="&#x201e;" u2="&#x36;" k="20" />
-<hkern u1="&#x201e;" u2="&#x34;" k="20" />
-<hkern u1="&#x201e;" u2="&#x30;" k="41" />
-<hkern u1="&#x2026;" u2="&#x39;" k="10" />
-<hkern u1="&#x2026;" u2="&#x37;" k="35" />
-<hkern u1="&#x2026;" u2="&#x36;" k="20" />
-<hkern u1="&#x2026;" u2="&#x34;" k="20" />
-<hkern u1="&#x2026;" u2="&#x30;" k="41" />
-<hkern u1="&#x2039;" u2="&#x37;" k="74" />
-<hkern u1="&#x203a;" u2="&#x37;" k="74" />
-<hkern g1="C,Ccedilla"         g2="Y,Yacute,Ydieresis"         k="20" />
-<hkern g1="C,Ccedilla"         g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="10" />
-<hkern g1="C,Ccedilla"         g2="quotedbl,quotesingle"       k="-47" />
-<hkern g1="C,Ccedilla"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-51" />
-<hkern g1="C,Ccedilla"         g2="parenright,bracketright,bar,braceright"     k="-35" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="T"  k="39" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="Y,Yacute,Ydieresis"         k="72" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="V,W"        k="20" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-10" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="v,w"        k="-6" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="y,yacute,ydieresis"         k="-6" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="hyphen,endash,emdash"       k="-31" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quotedbl,quotesingle"       k="20" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="14" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="27" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
-<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="T"  k="14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="V,W"        k="31" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="v,w"        k="6" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="J"  k="-14" />
-<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="f,uniFB01,uniFB02,uniFB03,uniFB04"  k="-12" />
-<hkern g1="G"  g2="T"  k="33" />
-<hkern g1="G"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="16" />
-<hkern g1="G"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-18" />
-<hkern g1="G"  g2="hyphen,endash,emdash"       k="-41" />
-<hkern g1="G"  g2="quotedbl,quotesingle"       k="10" />
-<hkern g1="G"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="41" />
-<hkern g1="G"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-18" />
-<hkern g1="G"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-18" />
-<hkern g1="G"  g2="colon,semicolon"    k="-55" />
-<hkern g1="G"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="12" />
-<hkern g1="H,N,Ntilde"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="20" />
-<hkern g1="H,N,Ntilde"         g2="v,w"        k="20" />
-<hkern g1="H,N,Ntilde"         g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="H,N,Ntilde"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="41" />
-<hkern g1="H,N,Ntilde"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="10" />
-<hkern g1="J"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="27" />
-<hkern g1="J"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
-<hkern g1="J"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="20" />
-<hkern g1="J"  g2="colon,semicolon"    k="35" />
-<hkern g1="K"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="47" />
-<hkern g1="K"  g2="v,w"        k="61" />
-<hkern g1="K"  g2="y,yacute,ydieresis"         k="41" />
-<hkern g1="K"  g2="hyphen,endash,emdash"       k="66" />
-<hkern g1="K"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="6" />
-<hkern g1="K"  g2="parenright,bracketright,bar,braceright"     k="-51" />
-<hkern g1="K"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
-<hkern g1="K"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="K"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="18" />
-<hkern g1="K"  g2="colon,semicolon"    k="-61" />
-<hkern g1="K"  g2="z"  k="20" />
-<hkern g1="K"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="16" />
-<hkern g1="L"  g2="T"  k="205" />
-<hkern g1="L"  g2="Y,Yacute,Ydieresis"         k="164" />
-<hkern g1="L"  g2="V,W"        k="82" />
-<hkern g1="L"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="41" />
-<hkern g1="L"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="76" />
-<hkern g1="L"  g2="v,w"        k="98" />
-<hkern g1="L"  g2="y,yacute,ydieresis"         k="80" />
-<hkern g1="L"  g2="hyphen,endash,emdash"       k="39" />
-<hkern g1="L"  g2="quotedbl,quotesingle"       k="166" />
-<hkern g1="L"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="123" />
-<hkern g1="L"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-20" />
-<hkern g1="L"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="L"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
-<hkern g1="L"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="10" />
-<hkern g1="L"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="63" />
-<hkern g1="L"  g2="b,h,k,l"    k="27" />
-<hkern g1="R"  g2="T"  k="47" />
-<hkern g1="R"  g2="Y,Yacute,Ydieresis"         k="61" />
-<hkern g1="R"  g2="V,W"        k="10" />
-<hkern g1="R"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="6" />
-<hkern g1="R"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="37" />
-<hkern g1="R"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
-<hkern g1="R"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
-<hkern g1="R"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
-<hkern g1="R"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
-<hkern g1="S"  g2="hyphen,endash,emdash"       k="-23" />
-<hkern g1="S"  g2="quotedbl,quotesingle"       k="-14" />
-<hkern g1="S"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
-<hkern g1="S"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-10" />
-<hkern g1="S"  g2="z"  k="10" />
-<hkern g1="T"  g2="Y,Yacute,Ydieresis"         k="-20" />
-<hkern g1="T"  g2="V,W"        k="-14" />
-<hkern g1="T"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="39" />
-<hkern g1="T"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="123" />
-<hkern g1="T"  g2="v,w"        k="127" />
-<hkern g1="T"  g2="y,yacute,ydieresis"         k="133" />
-<hkern g1="T"  g2="hyphen,endash,emdash"       k="123" />
-<hkern g1="T"  g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="T"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
-<hkern g1="T"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="176" />
-<hkern g1="T"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="154" />
-<hkern g1="T"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="92" />
-<hkern g1="T"  g2="J"  k="102" />
-<hkern g1="T"  g2="z"  k="127" />
-<hkern g1="T"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="61" />
-<hkern g1="T"  g2="M,N"        k="23" />
-<hkern g1="T"  g2="s"  k="96" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="41" />
-<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="M,N"        k="10" />
-<hkern g1="V,W"        g2="T"  k="-14" />
-<hkern g1="V,W"        g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="V,W"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="96" />
-<hkern g1="V,W"        g2="hyphen,endash,emdash"       k="61" />
-<hkern g1="V,W"        g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="V,W"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-10" />
-<hkern g1="V,W"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
-<hkern g1="V,W"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="63" />
-<hkern g1="V,W"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="109" />
-<hkern g1="V,W"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="41" />
-<hkern g1="V,W"        g2="J"  k="59" />
-<hkern g1="V,W"        g2="M,N"        k="12" />
-<hkern g1="V,W"        g2="S"  k="10" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="T"  k="-20" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="hyphen,endash,emdash"       k="123" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="quotedbl,quotesingle"       k="-41" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-6" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="164" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="158" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="143" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="76" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="J"  k="72" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="z"  k="61" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="41" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="M,N"        k="35" />
-<hkern g1="Y,Yacute,Ydieresis"         g2="s"  k="98" />
-<hkern g1="Z"  g2="hyphen,endash,emdash"       k="35" />
-<hkern g1="Z"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="20" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="T"  k="174" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="v,w"        k="20" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quotedbl,quotesingle"       k="143" />
-<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="76" />
-<hkern g1="f"  g2="T"  k="-41" />
-<hkern g1="f"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="37" />
-<hkern g1="f"  g2="hyphen,endash,emdash"       k="35" />
-<hkern g1="f"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-90" />
-<hkern g1="f"  g2="parenright,bracketright,bar,braceright"     k="-27" />
-<hkern g1="f"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="102" />
-<hkern g1="f"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="45" />
-<hkern g1="f"  g2="s"  k="14" />
-<hkern g1="g"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-41" />
-<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="v,w"        k="10" />
-<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="y,yacute,ydieresis"         k="10" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="T"  k="82" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="Y,Yacute,Ydieresis"         k="61" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="v,w"        k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quotedbl,quotesingle"       k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="82" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="z"  k="20" />
-<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="b,h,k,l"    k="16" />
-<hkern g1="r"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="61" />
-<hkern g1="r"  g2="v,w"        k="-27" />
-<hkern g1="r"  g2="y,yacute,ydieresis"         k="-27" />
-<hkern g1="r"  g2="hyphen,endash,emdash"       k="41" />
-<hkern g1="r"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-72" />
-<hkern g1="r"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="113" />
-<hkern g1="r"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="39" />
-<hkern g1="r"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-12" />
-<hkern g1="r"  g2="b,h,k,l"    k="20" />
-<hkern g1="s"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="20" />
-<hkern g1="t"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="6" />
-<hkern g1="t"  g2="v,w"        k="20" />
-<hkern g1="t"  g2="y,yacute,ydieresis"         k="20" />
-<hkern g1="t"  g2="hyphen,endash,emdash"       k="31" />
-<hkern g1="t"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="16" />
-<hkern g1="t"  g2="b,h,k,l"    k="12" />
-<hkern g1="v,w"        g2="T"  k="61" />
-<hkern g1="v,w"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
-<hkern g1="v,w"        g2="hyphen,endash,emdash"       k="29" />
-<hkern g1="v,w"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-47" />
-<hkern g1="v,w"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="82" />
-<hkern g1="v,w"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="y,yacute,ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
-<hkern g1="y,yacute,ydieresis"         g2="hyphen,endash,emdash"       k="29" />
-<hkern g1="y,yacute,ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-57" />
-<hkern g1="y,yacute,ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="92" />
-<hkern g1="y,yacute,ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="z"  g2="v,w"        k="37" />
-<hkern g1="z"  g2="y,yacute,ydieresis"         k="31" />
-<hkern g1="z"  g2="hyphen,endash,emdash"       k="29" />
-<hkern g1="z"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-82" />
-<hkern g1="z"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="T"  k="143" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="Y,Yacute,Ydieresis"         k="164" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="V,W"        k="143" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="v,w"        k="82" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="y,yacute,ydieresis"         k="82" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="hyphen,endash,emdash"       k="145" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="27" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="J"  k="-51" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="41" />
-<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="102" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="T"  k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Y,Yacute,Ydieresis"         k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="V,W"        k="-33" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="72" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="v,w"        k="-14" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="205" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="145" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-20" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="J"  k="123" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="z"  k="6" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="b,h,k,l"    k="-55" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="M,N"        k="61" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="s"  k="92" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="S"  k="29" />
-<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Z"  k="-20" />
-<hkern g1="quotedbl,quotesingle"       g2="T"  k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="Y,Yacute,Ydieresis"         k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="V,W"        k="-41" />
-<hkern g1="quotedbl,quotesingle"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="90" />
-<hkern g1="quotedbl,quotesingle"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
-<hkern g1="quotedbl,quotesingle"       g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="J"  k="141" />
-<hkern g1="quotedbl,quotesingle"       g2="M,N"        k="47" />
-<hkern g1="quotedbl,quotesingle"       g2="s"  k="20" />
-<hkern g1="quotedbl,quotesingle"       g2="Z"  k="-27" />
-<hkern g1="hyphen,endash,emdash"       g2="T"  k="123" />
-<hkern g1="hyphen,endash,emdash"       g2="Y,Yacute,Ydieresis"         k="123" />
-<hkern g1="hyphen,endash,emdash"       g2="V,W"        k="61" />
-<hkern g1="hyphen,endash,emdash"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="-31" />
-<hkern g1="hyphen,endash,emdash"       g2="v,w"        k="29" />
-<hkern g1="hyphen,endash,emdash"       g2="y,yacute,ydieresis"         k="29" />
-<hkern g1="hyphen,endash,emdash"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="18" />
-<hkern g1="hyphen,endash,emdash"       g2="z"  k="29" />
-<hkern g1="hyphen,endash,emdash"       g2="S"  k="35" />
-<hkern g1="hyphen,endash,emdash"       g2="Z"  k="20" />
-<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="T"  k="61" />
-<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="Y,Yacute,Ydieresis"         k="41" />
-<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="T"  k="82" />
-<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="61" />
-<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="T"  k="82" />
-<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="53" />
-</font>
-</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/fontface/museo700-regular-webfont.ttf b/karmaworld/assets/css/fontface/museo700-regular-webfont.ttf
deleted file mode 100644 (file)
index e8203c6..0000000
Binary files a/karmaworld/assets/css/fontface/museo700-regular-webfont.ttf and /dev/null differ
diff --git a/karmaworld/assets/css/fontface/museo700-regular-webfont.woff b/karmaworld/assets/css/fontface/museo700-regular-webfont.woff
deleted file mode 100644 (file)
index fc95afd..0000000
Binary files a/karmaworld/assets/css/fontface/museo700-regular-webfont.woff and /dev/null differ
diff --git a/karmaworld/assets/css/fonts/FontAwesome.otf b/karmaworld/assets/css/fonts/FontAwesome.otf
new file mode 100644 (file)
index 0000000..8b0f54e
Binary files /dev/null and b/karmaworld/assets/css/fonts/FontAwesome.otf differ
diff --git a/karmaworld/assets/css/fonts/fontawesome-webfont.eot b/karmaworld/assets/css/fonts/fontawesome-webfont.eot
new file mode 100755 (executable)
index 0000000..7c79c6a
Binary files /dev/null and b/karmaworld/assets/css/fonts/fontawesome-webfont.eot differ
diff --git a/karmaworld/assets/css/fonts/fontawesome-webfont.svg b/karmaworld/assets/css/fonts/fontawesome-webfont.svg
new file mode 100755 (executable)
index 0000000..45fdf33
--- /dev/null
@@ -0,0 +1,414 @@
+<?xml version="1.0" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
+<svg xmlns="http://www.w3.org/2000/svg">
+<metadata></metadata>
+<defs>
+<font id="fontawesomeregular" horiz-adv-x="1536" >
+<font-face units-per-em="1792" ascent="1536" descent="-256" />
+<missing-glyph horiz-adv-x="448" />
+<glyph unicode=" "  horiz-adv-x="448" />
+<glyph unicode="&#x09;" horiz-adv-x="448" />
+<glyph unicode="&#xa0;" horiz-adv-x="448" />
+<glyph unicode="&#xa8;" horiz-adv-x="1792" />
+<glyph unicode="&#xa9;" horiz-adv-x="1792" />
+<glyph unicode="&#xae;" horiz-adv-x="1792" />
+<glyph unicode="&#xb4;" horiz-adv-x="1792" />
+<glyph unicode="&#xc6;" horiz-adv-x="1792" />
+<glyph unicode="&#x2000;" horiz-adv-x="768" />
+<glyph unicode="&#x2001;" />
+<glyph unicode="&#x2002;" horiz-adv-x="768" />
+<glyph unicode="&#x2003;" />
+<glyph unicode="&#x2004;" horiz-adv-x="512" />
+<glyph unicode="&#x2005;" horiz-adv-x="384" />
+<glyph unicode="&#x2006;" horiz-adv-x="256" />
+<glyph unicode="&#x2007;" horiz-adv-x="256" />
+<glyph unicode="&#x2008;" horiz-adv-x="192" />
+<glyph unicode="&#x2009;" horiz-adv-x="307" />
+<glyph unicode="&#x200a;" horiz-adv-x="85" />
+<glyph unicode="&#x202f;" horiz-adv-x="307" />
+<glyph unicode="&#x205f;" horiz-adv-x="384" />
+<glyph unicode="&#x2122;" horiz-adv-x="1792" />
+<glyph unicode="&#x221e;" horiz-adv-x="1792" />
+<glyph unicode="&#x2260;" horiz-adv-x="1792" />
+<glyph unicode="&#xe000;" horiz-adv-x="500" d="M0 0z" />
+<glyph unicode="&#xf000;" horiz-adv-x="1792" d="M1699 1350q0 -35 -43 -78l-632 -632v-768h320q26 0 45 -19t19 -45t-19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45t45 19h320v768l-632 632q-43 43 -43 78q0 23 18 36.5t38 17.5t43 4h1408q23 0 43 -4t38 -17.5t18 -36.5z" />
+<glyph unicode="&#xf001;" d="M1536 1312v-1120q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v537l-768 -237v-709q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89 t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v967q0 31 19 56.5t49 35.5l832 256q12 4 28 4q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf002;" horiz-adv-x="1664" d="M1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -52 -38 -90t-90 -38q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5 t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" />
+<glyph unicode="&#xf003;" horiz-adv-x="1792" d="M1664 32v768q-32 -36 -69 -66q-268 -206 -426 -338q-51 -43 -83 -67t-86.5 -48.5t-102.5 -24.5h-1h-1q-48 0 -102.5 24.5t-86.5 48.5t-83 67q-158 132 -426 338q-37 30 -69 66v-768q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1664 1083v11v13.5t-0.5 13 t-3 12.5t-5.5 9t-9 7.5t-14 2.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5q0 -168 147 -284q193 -152 401 -317q6 -5 35 -29.5t46 -37.5t44.5 -31.5t50.5 -27.5t43 -9h1h1q20 0 43 9t50.5 27.5t44.5 31.5t46 37.5t35 29.5q208 165 401 317q54 43 100.5 115.5t46.5 131.5z M1792 1120v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf004;" horiz-adv-x="1792" d="M896 -128q-26 0 -44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5q224 0 351 -124t127 -344q0 -221 -229 -450l-623 -600 q-18 -18 -44 -18z" />
+<glyph unicode="&#xf005;" horiz-adv-x="1664" d="M1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -21 -10.5 -35.5t-30.5 -14.5q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455 l502 -73q56 -9 56 -46z" />
+<glyph unicode="&#xf006;" horiz-adv-x="1664" d="M1137 532l306 297l-422 62l-189 382l-189 -382l-422 -62l306 -297l-73 -421l378 199l377 -199zM1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -50 -41 -50q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500 l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455l502 -73q56 -9 56 -46z" />
+<glyph unicode="&#xf007;" horiz-adv-x="1408" d="M1408 131q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5t43 97.5t62 81t85.5 53.5t111.5 20q9 0 42 -21.5t74.5 -48t108 -48t133.5 -21.5t133.5 21.5t108 48t74.5 48t42 21.5q61 0 111.5 -20t85.5 -53.5t62 -81 t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5z" />
+<glyph unicode="&#xf008;" horiz-adv-x="1920" d="M384 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 320v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 704v128q0 26 -19 45t-45 19h-128 q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 -64v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM384 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45 t45 -19h128q26 0 45 19t19 45zM1792 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 704v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1792 320v128 q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 704v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19 t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1920 1248v-1344q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1344q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf009;" horiz-adv-x="1664" d="M768 512v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM768 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 512v-384q0 -52 -38 -90t-90 -38 h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" />
+<glyph unicode="&#xf00a;" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 288v-192q0 -40 -28 -68t-68 -28h-320 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf00b;" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-960 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h960q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf00c;" horiz-adv-x="1792" d="M1671 970q0 -40 -28 -68l-724 -724l-136 -136q-28 -28 -68 -28t-68 28l-136 136l-362 362q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -295l656 657q28 28 68 28t68 -28l136 -136q28 -28 28 -68z" />
+<glyph unicode="&#xf00d;" horiz-adv-x="1408" d="M1298 214q0 -40 -28 -68l-136 -136q-28 -28 -68 -28t-68 28l-294 294l-294 -294q-28 -28 -68 -28t-68 28l-136 136q-28 28 -28 68t28 68l294 294l-294 294q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -294l294 294q28 28 68 28t68 -28l136 -136q28 -28 28 -68 t-28 -68l-294 -294l294 -294q28 -28 28 -68z" />
+<glyph unicode="&#xf00e;" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-224q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v224h-224q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h224v224q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5v-224h224 q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5 t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" />
+<glyph unicode="&#xf010;" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-576q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h576q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5z M1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z " />
+<glyph unicode="&#xf011;" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61t-298 61t-245 164t-164 245t-61 298q0 182 80.5 343t226.5 270q43 32 95.5 25t83.5 -50q32 -42 24.5 -94.5t-49.5 -84.5q-98 -74 -151.5 -181t-53.5 -228q0 -104 40.5 -198.5t109.5 -163.5t163.5 -109.5 t198.5 -40.5t198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5q0 121 -53.5 228t-151.5 181q-42 32 -49.5 84.5t24.5 94.5q31 43 84 50t95 -25q146 -109 226.5 -270t80.5 -343zM896 1408v-640q0 -52 -38 -90t-90 -38t-90 38t-38 90v640q0 52 38 90t90 38t90 -38t38 -90z" />
+<glyph unicode="&#xf012;" horiz-adv-x="1792" d="M256 96v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM640 224v-320q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1024 480v-576q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23 v576q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1408 864v-960q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v960q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1792 1376v-1472q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1472q0 14 9 23t23 9h192q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf013;" d="M1024 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1536 749v-222q0 -12 -8 -23t-20 -13l-185 -28q-19 -54 -39 -91q35 -50 107 -138q10 -12 10 -25t-9 -23q-27 -37 -99 -108t-94 -71q-12 0 -26 9l-138 108q-44 -23 -91 -38 q-16 -136 -29 -186q-7 -28 -36 -28h-222q-14 0 -24.5 8.5t-11.5 21.5l-28 184q-49 16 -90 37l-141 -107q-10 -9 -25 -9q-14 0 -25 11q-126 114 -165 168q-7 10 -7 23q0 12 8 23q15 21 51 66.5t54 70.5q-27 50 -41 99l-183 27q-13 2 -21 12.5t-8 23.5v222q0 12 8 23t19 13 l186 28q14 46 39 92q-40 57 -107 138q-10 12 -10 24q0 10 9 23q26 36 98.5 107.5t94.5 71.5q13 0 26 -10l138 -107q44 23 91 38q16 136 29 186q7 28 36 28h222q14 0 24.5 -8.5t11.5 -21.5l28 -184q49 -16 90 -37l142 107q9 9 24 9q13 0 25 -10q129 -119 165 -170q7 -8 7 -22 q0 -12 -8 -23q-15 -21 -51 -66.5t-54 -70.5q26 -50 41 -98l183 -28q13 -2 21 -12.5t8 -23.5z" />
+<glyph unicode="&#xf014;" horiz-adv-x="1408" d="M512 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM768 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1024 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1152 76v948h-896v-948q0 -22 7 -40.5t14.5 -27t10.5 -8.5h832q3 0 10.5 8.5t14.5 27t7 40.5zM480 1152h448l-48 117q-7 9 -17 11h-317q-10 -2 -17 -11zM1408 1120v-64q0 -14 -9 -23t-23 -9h-96v-948q0 -83 -47 -143.5t-113 -60.5h-832 q-66 0 -113 58.5t-47 141.5v952h-96q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h309l70 167q15 37 54 63t79 26h320q40 0 79 -26t54 -63l70 -167h309q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf015;" horiz-adv-x="1664" d="M1408 544v-480q0 -26 -19 -45t-45 -19h-384v384h-256v-384h-384q-26 0 -45 19t-19 45v480q0 1 0.5 3t0.5 3l575 474l575 -474q1 -2 1 -6zM1631 613l-62 -74q-8 -9 -21 -11h-3q-13 0 -21 7l-692 577l-692 -577q-12 -8 -24 -7q-13 2 -21 11l-62 74q-8 10 -7 23.5t11 21.5 l719 599q32 26 76 26t76 -26l244 -204v195q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-408l219 -182q10 -8 11 -21.5t-7 -23.5z" />
+<glyph unicode="&#xf016;" horiz-adv-x="1280" d="M128 0h1024v768h-416q-40 0 -68 28t-28 68v416h-512v-1280zM768 896h376q-10 29 -22 41l-313 313q-12 12 -41 22v-376zM1280 864v-896q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h640q40 0 88 -20t76 -48l312 -312q28 -28 48 -76t20 -88z " />
+<glyph unicode="&#xf017;" d="M896 992v-448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h224v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf018;" horiz-adv-x="1920" d="M1111 540v4l-24 320q-1 13 -11 22.5t-23 9.5h-186q-13 0 -23 -9.5t-11 -22.5l-24 -320v-4q-1 -12 8 -20t21 -8h244q12 0 21 8t8 20zM1870 73q0 -73 -46 -73h-704q13 0 22 9.5t8 22.5l-20 256q-1 13 -11 22.5t-23 9.5h-272q-13 0 -23 -9.5t-11 -22.5l-20 -256 q-1 -13 8 -22.5t22 -9.5h-704q-46 0 -46 73q0 54 26 116l417 1044q8 19 26 33t38 14h339q-13 0 -23 -9.5t-11 -22.5l-15 -192q-1 -14 8 -23t22 -9h166q13 0 22 9t8 23l-15 192q-1 13 -11 22.5t-23 9.5h339q20 0 38 -14t26 -33l417 -1044q26 -62 26 -116z" />
+<glyph unicode="&#xf019;" horiz-adv-x="1664" d="M1280 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 416v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h465l135 -136 q58 -56 136 -56t136 56l136 136h464q40 0 68 -28t28 -68zM1339 985q17 -41 -14 -70l-448 -448q-18 -19 -45 -19t-45 19l-448 448q-31 29 -14 70q17 39 59 39h256v448q0 26 19 45t45 19h256q26 0 45 -19t19 -45v-448h256q42 0 59 -39z" />
+<glyph unicode="&#xf01a;" d="M1120 608q0 -12 -10 -24l-319 -319q-11 -9 -23 -9t-23 9l-320 320q-15 16 -7 35q8 20 30 20h192v352q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-352h192q14 0 23 -9t9 -23zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273 t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf01b;" d="M1118 660q-8 -20 -30 -20h-192v-352q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v352h-192q-14 0 -23 9t-9 23q0 12 10 24l319 319q11 9 23 9t23 -9l320 -320q15 -16 7 -35zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198 t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf01c;" d="M1023 576h316q-1 3 -2.5 8t-2.5 8l-212 496h-708l-212 -496q-1 -2 -2.5 -8t-2.5 -8h316l95 -192h320zM1536 546v-482q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v482q0 62 25 123l238 552q10 25 36.5 42t52.5 17h832q26 0 52.5 -17t36.5 -42l238 -552 q25 -61 25 -123z" />
+<glyph unicode="&#xf01d;" d="M1184 640q0 -37 -32 -55l-544 -320q-15 -9 -32 -9q-16 0 -32 8q-32 19 -32 56v640q0 37 32 56q33 18 64 -1l544 -320q32 -18 32 -55zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf01e;" d="M1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l138 138q-148 137 -349 137q-104 0 -198.5 -40.5t-163.5 -109.5t-109.5 -163.5t-40.5 -198.5t40.5 -198.5t109.5 -163.5t163.5 -109.5t198.5 -40.5q119 0 225 52t179 147q7 10 23 12q14 0 25 -9 l137 -138q9 -8 9.5 -20.5t-7.5 -22.5q-109 -132 -264 -204.5t-327 -72.5q-156 0 -298 61t-245 164t-164 245t-61 298t61 298t164 245t245 164t298 61q147 0 284.5 -55.5t244.5 -156.5l130 129q29 31 70 14q39 -17 39 -59z" />
+<glyph unicode="&#xf021;" d="M1511 480q0 -5 -1 -7q-64 -268 -268 -434.5t-478 -166.5q-146 0 -282.5 55t-243.5 157l-129 -129q-19 -19 -45 -19t-45 19t-19 45v448q0 26 19 45t45 19h448q26 0 45 -19t19 -45t-19 -45l-137 -137q71 -66 161 -102t187 -36q134 0 250 65t186 179q11 17 53 117 q8 23 30 23h192q13 0 22.5 -9.5t9.5 -22.5zM1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-26 0 -45 19t-19 45t19 45l138 138q-148 137 -349 137q-134 0 -250 -65t-186 -179q-11 -17 -53 -117q-8 -23 -30 -23h-199q-13 0 -22.5 9.5t-9.5 22.5v7q65 268 270 434.5t480 166.5 q146 0 284 -55.5t245 -156.5l130 129q19 19 45 19t45 -19t19 -45z" />
+<glyph unicode="&#xf022;" horiz-adv-x="1792" d="M384 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M384 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1536 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5z M1536 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5zM1536 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5 t9.5 -22.5zM1664 160v832q0 13 -9.5 22.5t-22.5 9.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1792 1248v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47 t47 -113z" />
+<glyph unicode="&#xf023;" horiz-adv-x="1152" d="M320 768h512v192q0 106 -75 181t-181 75t-181 -75t-75 -181v-192zM1152 672v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v192q0 184 132 316t316 132t316 -132t132 -316v-192h32q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf024;" horiz-adv-x="1792" d="M320 1280q0 -72 -64 -110v-1266q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v1266q-64 38 -64 110q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -25 -12.5 -38.5t-39.5 -27.5q-215 -116 -369 -116q-61 0 -123.5 22t-108.5 48 t-115.5 48t-142.5 22q-192 0 -464 -146q-17 -9 -33 -9q-26 0 -45 19t-19 45v742q0 32 31 55q21 14 79 43q236 120 421 120q107 0 200 -29t219 -88q38 -19 88 -19q54 0 117.5 21t110 47t88 47t54.5 21q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf025;" horiz-adv-x="1664" d="M1664 650q0 -166 -60 -314l-20 -49l-185 -33q-22 -83 -90.5 -136.5t-156.5 -53.5v-32q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-32q71 0 130 -35.5t93 -95.5l68 12q29 95 29 193q0 148 -88 279t-236.5 209t-315.5 78 t-315.5 -78t-236.5 -209t-88 -279q0 -98 29 -193l68 -12q34 60 93 95.5t130 35.5v32q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v32q-88 0 -156.5 53.5t-90.5 136.5l-185 33l-20 49q-60 148 -60 314q0 151 67 291t179 242.5 t266 163.5t320 61t320 -61t266 -163.5t179 -242.5t67 -291z" />
+<glyph unicode="&#xf026;" horiz-adv-x="768" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45z" />
+<glyph unicode="&#xf027;" horiz-adv-x="1152" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142z" />
+<glyph unicode="&#xf028;" horiz-adv-x="1664" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142zM1408 640q0 -153 -85 -282.5t-225 -188.5q-13 -5 -25 -5q-27 0 -46 19t-19 45q0 39 39 59q56 29 76 44q74 54 115.5 135.5t41.5 173.5t-41.5 173.5 t-115.5 135.5q-20 15 -76 44q-39 20 -39 59q0 26 19 45t45 19q13 0 26 -5q140 -59 225 -188.5t85 -282.5zM1664 640q0 -230 -127 -422.5t-338 -283.5q-13 -5 -26 -5q-26 0 -45 19t-19 45q0 36 39 59q7 4 22.5 10.5t22.5 10.5q46 25 82 51q123 91 192 227t69 289t-69 289 t-192 227q-36 26 -82 51q-7 4 -22.5 10.5t-22.5 10.5q-39 23 -39 59q0 26 19 45t45 19q13 0 26 -5q211 -91 338 -283.5t127 -422.5z" />
+<glyph unicode="&#xf029;" horiz-adv-x="1408" d="M384 384v-128h-128v128h128zM384 1152v-128h-128v128h128zM1152 1152v-128h-128v128h128zM128 129h384v383h-384v-383zM128 896h384v384h-384v-384zM896 896h384v384h-384v-384zM640 640v-640h-640v640h640zM1152 128v-128h-128v128h128zM1408 128v-128h-128v128h128z M1408 640v-384h-384v128h-128v-384h-128v640h384v-128h128v128h128zM640 1408v-640h-640v640h640zM1408 1408v-640h-640v640h640z" />
+<glyph unicode="&#xf02a;" horiz-adv-x="1792" d="M63 0h-63v1408h63v-1408zM126 1h-32v1407h32v-1407zM220 1h-31v1407h31v-1407zM377 1h-31v1407h31v-1407zM534 1h-62v1407h62v-1407zM660 1h-31v1407h31v-1407zM723 1h-31v1407h31v-1407zM786 1h-31v1407h31v-1407zM943 1h-63v1407h63v-1407zM1100 1h-63v1407h63v-1407z M1226 1h-63v1407h63v-1407zM1352 1h-63v1407h63v-1407zM1446 1h-63v1407h63v-1407zM1635 1h-94v1407h94v-1407zM1698 1h-32v1407h32v-1407zM1792 0h-63v1408h63v-1408z" />
+<glyph unicode="&#xf02b;" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91z" />
+<glyph unicode="&#xf02c;" horiz-adv-x="1920" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91zM1899 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-36 0 -59 14t-53 45l470 470q37 37 37 90q0 52 -37 91l-715 714q-38 38 -102 64.5t-117 26.5h224q53 0 117 -26.5t102 -64.5l715 -714q37 -39 37 -91z" />
+<glyph unicode="&#xf02d;" horiz-adv-x="1664" d="M1639 1058q40 -57 18 -129l-275 -906q-19 -64 -76.5 -107.5t-122.5 -43.5h-923q-77 0 -148.5 53.5t-99.5 131.5q-24 67 -2 127q0 4 3 27t4 37q1 8 -3 21.5t-3 19.5q2 11 8 21t16.5 23.5t16.5 23.5q23 38 45 91.5t30 91.5q3 10 0.5 30t-0.5 28q3 11 17 28t17 23 q21 36 42 92t25 90q1 9 -2.5 32t0.5 28q4 13 22 30.5t22 22.5q19 26 42.5 84.5t27.5 96.5q1 8 -3 25.5t-2 26.5q2 8 9 18t18 23t17 21q8 12 16.5 30.5t15 35t16 36t19.5 32t26.5 23.5t36 11.5t47.5 -5.5l-1 -3q38 9 51 9h761q74 0 114 -56t18 -130l-274 -906 q-36 -119 -71.5 -153.5t-128.5 -34.5h-869q-27 0 -38 -15q-11 -16 -1 -43q24 -70 144 -70h923q29 0 56 15.5t35 41.5l300 987q7 22 5 57q38 -15 59 -43zM575 1056q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5 t-16.5 -22.5zM492 800q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5t-16.5 -22.5z" />
+<glyph unicode="&#xf02e;" horiz-adv-x="1280" d="M1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289q0 34 19.5 62t52.5 41q21 9 44 9h1048z" />
+<glyph unicode="&#xf02f;" horiz-adv-x="1664" d="M384 0h896v256h-896v-256zM384 640h896v384h-160q-40 0 -68 28t-28 68v160h-640v-640zM1536 576q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 576v-416q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-160q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68 v160h-224q-13 0 -22.5 9.5t-9.5 22.5v416q0 79 56.5 135.5t135.5 56.5h64v544q0 40 28 68t68 28h672q40 0 88 -20t76 -48l152 -152q28 -28 48 -76t20 -88v-256h64q79 0 135.5 -56.5t56.5 -135.5z" />
+<glyph unicode="&#xf030;" horiz-adv-x="1920" d="M960 864q119 0 203.5 -84.5t84.5 -203.5t-84.5 -203.5t-203.5 -84.5t-203.5 84.5t-84.5 203.5t84.5 203.5t203.5 84.5zM1664 1280q106 0 181 -75t75 -181v-896q0 -106 -75 -181t-181 -75h-1408q-106 0 -181 75t-75 181v896q0 106 75 181t181 75h224l51 136 q19 49 69.5 84.5t103.5 35.5h512q53 0 103.5 -35.5t69.5 -84.5l51 -136h224zM960 128q185 0 316.5 131.5t131.5 316.5t-131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5z" />
+<glyph unicode="&#xf031;" horiz-adv-x="1664" d="M725 977l-170 -450q73 -1 153.5 -2t119 -1.5t52.5 -0.5l29 2q-32 95 -92 241q-53 132 -92 211zM21 -128h-21l2 79q22 7 80 18q89 16 110 31q20 16 48 68l237 616l280 724h75h53l11 -21l205 -480q103 -242 124 -297q39 -102 96 -235q26 -58 65 -164q24 -67 65 -149 q22 -49 35 -57q22 -19 69 -23q47 -6 103 -27q6 -39 6 -57q0 -14 -1 -26q-80 0 -192 8q-93 8 -189 8q-79 0 -135 -2l-200 -11l-58 -2q0 45 4 78l131 28q56 13 68 23q12 12 12 27t-6 32l-47 114l-92 228l-450 2q-29 -65 -104 -274q-23 -64 -23 -84q0 -31 17 -43 q26 -21 103 -32q3 0 13.5 -2t30 -5t40.5 -6q1 -28 1 -58q0 -17 -2 -27q-66 0 -349 20l-48 -8q-81 -14 -167 -14z" />
+<glyph unicode="&#xf032;" horiz-adv-x="1408" d="M555 15q76 -32 140 -32q131 0 216 41t122 113q38 70 38 181q0 114 -41 180q-58 94 -141 126q-80 32 -247 32q-74 0 -101 -10v-144l-1 -173l3 -270q0 -15 12 -44zM541 761q43 -7 109 -7q175 0 264 65t89 224q0 112 -85 187q-84 75 -255 75q-52 0 -130 -13q0 -44 2 -77 q7 -122 6 -279l-1 -98q0 -43 1 -77zM0 -128l2 94q45 9 68 12q77 12 123 31q17 27 21 51q9 66 9 194l-2 497q-5 256 -9 404q-1 87 -11 109q-1 4 -12 12q-18 12 -69 15q-30 2 -114 13l-4 83l260 6l380 13l45 1q5 0 14 0.5t14 0.5q1 0 21.5 -0.5t40.5 -0.5h74q88 0 191 -27 q43 -13 96 -39q57 -29 102 -76q44 -47 65 -104t21 -122q0 -70 -32 -128t-95 -105q-26 -20 -150 -77q177 -41 267 -146q92 -106 92 -236q0 -76 -29 -161q-21 -62 -71 -117q-66 -72 -140 -108q-73 -36 -203 -60q-82 -15 -198 -11l-197 4q-84 2 -298 -11q-33 -3 -272 -11z" />
+<glyph unicode="&#xf033;" horiz-adv-x="1024" d="M0 -126l17 85q4 1 77 20q76 19 116 39q29 37 41 101l27 139l56 268l12 64q8 44 17 84.5t16 67t12.5 46.5t9 30.5t3.5 11.5l29 157l16 63l22 135l8 50v38q-41 22 -144 28q-28 2 -38 4l19 103l317 -14q39 -2 73 -2q66 0 214 9q33 2 68 4.5t36 2.5q-2 -19 -6 -38 q-7 -29 -13 -51q-55 -19 -109 -31q-64 -16 -101 -31q-12 -31 -24 -88q-9 -44 -13 -82q-44 -199 -66 -306l-61 -311l-38 -158l-43 -235l-12 -45q-2 -7 1 -27q64 -15 119 -21q36 -5 66 -10q-1 -29 -7 -58q-7 -31 -9 -41q-18 0 -23 -1q-24 -2 -42 -2q-9 0 -28 3q-19 4 -145 17 l-198 2q-41 1 -174 -11q-74 -7 -98 -9z" />
+<glyph unicode="&#xf034;" horiz-adv-x="1792" d="M81 1407l54 -27q20 -5 211 -5h130l19 3l115 1l215 -1h293l34 -2q14 -1 28 7t21 16l7 8l42 1q15 0 28 -1v-104.5t1 -131.5l1 -100l-1 -58q0 -32 -4 -51q-39 -15 -68 -18q-25 43 -54 128q-8 24 -15.5 62.5t-11.5 65.5t-6 29q-13 15 -27 19q-7 2 -42.5 2t-103.5 -1t-111 -1 q-34 0 -67 -5q-10 -97 -8 -136l1 -152v-332l3 -359l-1 -147q-1 -46 11 -85q49 -25 89 -32q2 0 18 -5t44 -13t43 -12q30 -8 50 -18q5 -45 5 -50q0 -10 -3 -29q-14 -1 -34 -1q-110 0 -187 10q-72 8 -238 8q-88 0 -233 -14q-48 -4 -70 -4q-2 22 -2 26l-1 26v9q21 33 79 49 q139 38 159 50q9 21 12 56q8 192 6 433l-5 428q-1 62 -0.5 118.5t0.5 102.5t-2 57t-6 15q-6 5 -14 6q-38 6 -148 6q-43 0 -100 -13.5t-73 -24.5q-13 -9 -22 -33t-22 -75t-24 -84q-6 -19 -19.5 -32t-20.5 -13q-44 27 -56 44v297v86zM1744 128q33 0 42 -18.5t-11 -44.5 l-126 -162q-20 -26 -49 -26t-49 26l-126 162q-20 26 -11 44.5t42 18.5h80v1024h-80q-33 0 -42 18.5t11 44.5l126 162q20 26 49 26t49 -26l126 -162q20 -26 11 -44.5t-42 -18.5h-80v-1024h80z" />
+<glyph unicode="&#xf035;" d="M81 1407l54 -27q20 -5 211 -5h130l19 3l115 1l446 -1h318l34 -2q14 -1 28 7t21 16l7 8l42 1q15 0 28 -1v-104.5t1 -131.5l1 -100l-1 -58q0 -32 -4 -51q-39 -15 -68 -18q-25 43 -54 128q-8 24 -15.5 62.5t-11.5 65.5t-6 29q-13 15 -27 19q-7 2 -58.5 2t-138.5 -1t-128 -1 q-94 0 -127 -5q-10 -97 -8 -136l1 -152v52l3 -359l-1 -147q-1 -46 11 -85q49 -25 89 -32q2 0 18 -5t44 -13t43 -12q30 -8 50 -18q5 -45 5 -50q0 -10 -3 -29q-14 -1 -34 -1q-110 0 -187 10q-72 8 -238 8q-82 0 -233 -13q-45 -5 -70 -5q-2 22 -2 26l-1 26v9q21 33 79 49 q139 38 159 50q9 21 12 56q6 137 6 433l-5 44q0 265 -2 278q-2 11 -6 15q-6 5 -14 6q-38 6 -148 6q-50 0 -168.5 -14t-132.5 -24q-13 -9 -22 -33t-22 -75t-24 -84q-6 -19 -19.5 -32t-20.5 -13q-44 27 -56 44v297v86zM1505 113q26 -20 26 -49t-26 -49l-162 -126 q-26 -20 -44.5 -11t-18.5 42v80h-1024v-80q0 -33 -18.5 -42t-44.5 11l-162 126q-26 20 -26 49t26 49l162 126q26 20 44.5 11t18.5 -42v-80h1024v80q0 33 18.5 42t44.5 -11z" />
+<glyph unicode="&#xf036;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf037;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h896q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45t-45 -19 h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h640q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf038;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf039;" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf03a;" horiz-adv-x="1792" d="M256 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM256 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5 t9.5 -22.5zM256 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344 q13 0 22.5 -9.5t9.5 -22.5zM256 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192 q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5z" />
+<glyph unicode="&#xf03b;" horiz-adv-x="1792" d="M384 992v-576q0 -13 -9.5 -22.5t-22.5 -9.5q-14 0 -23 9l-288 288q-9 9 -9 23t9 23l288 288q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" />
+<glyph unicode="&#xf03c;" horiz-adv-x="1792" d="M352 704q0 -14 -9 -23l-288 -288q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v576q0 13 9.5 22.5t22.5 9.5q14 0 23 -9l288 -288q9 -9 9 -23zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" />
+<glyph unicode="&#xf03d;" horiz-adv-x="1792" d="M1792 1184v-1088q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-403 403v-166q0 -119 -84.5 -203.5t-203.5 -84.5h-704q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h704q119 0 203.5 -84.5t84.5 -203.5v-165l403 402q18 19 45 19q12 0 25 -5 q39 -17 39 -59z" />
+<glyph unicode="&#xf03e;" horiz-adv-x="1920" d="M640 960q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1664 576v-448h-1408v192l320 320l160 -160l512 512zM1760 1280h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-1216q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5v1216 q0 13 -9.5 22.5t-22.5 9.5zM1920 1248v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf040;" d="M363 0l91 91l-235 235l-91 -91v-107h128v-128h107zM886 928q0 22 -22 22q-10 0 -17 -7l-542 -542q-7 -7 -7 -17q0 -22 22 -22q10 0 17 7l542 542q7 7 7 17zM832 1120l416 -416l-832 -832h-416v416zM1515 1024q0 -53 -37 -90l-166 -166l-416 416l166 165q36 38 90 38 q53 0 91 -38l235 -234q37 -39 37 -91z" />
+<glyph unicode="&#xf041;" horiz-adv-x="1024" d="M768 896q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1024 896q0 -109 -33 -179l-364 -774q-16 -33 -47.5 -52t-67.5 -19t-67.5 19t-46.5 52l-365 774q-33 70 -33 179q0 212 150 362t362 150t362 -150t150 -362z" />
+<glyph unicode="&#xf042;" d="M768 96v1088q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf043;" horiz-adv-x="1024" d="M512 384q0 36 -20 69q-1 1 -15.5 22.5t-25.5 38t-25 44t-21 50.5q-4 16 -21 16t-21 -16q-7 -23 -21 -50.5t-25 -44t-25.5 -38t-15.5 -22.5q-20 -33 -20 -69q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 512q0 -212 -150 -362t-362 -150t-362 150t-150 362 q0 145 81 275q6 9 62.5 90.5t101 151t99.5 178t83 201.5q9 30 34 47t51 17t51.5 -17t33.5 -47q28 -93 83 -201.5t99.5 -178t101 -151t62.5 -90.5q81 -127 81 -275z" />
+<glyph unicode="&#xf044;" horiz-adv-x="1792" d="M888 352l116 116l-152 152l-116 -116v-56h96v-96h56zM1328 1072q-16 16 -33 -1l-350 -350q-17 -17 -1 -33t33 1l350 350q17 17 1 33zM1408 478v-190q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-14 -14 -32 -8q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v126q0 13 9 22l64 64q15 15 35 7t20 -29zM1312 1216l288 -288l-672 -672h-288v288zM1756 1084l-92 -92 l-288 288l92 92q28 28 68 28t68 -28l152 -152q28 -28 28 -68t-28 -68z" />
+<glyph unicode="&#xf045;" horiz-adv-x="1664" d="M1408 547v-259q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h255v0q13 0 22.5 -9.5t9.5 -22.5q0 -27 -26 -32q-77 -26 -133 -60q-10 -4 -16 -4h-112q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832 q66 0 113 47t47 113v214q0 19 18 29q28 13 54 37q16 16 35 8q21 -9 21 -29zM1645 1043l-384 -384q-18 -19 -45 -19q-12 0 -25 5q-39 17 -39 59v192h-160q-323 0 -438 -131q-119 -137 -74 -473q3 -23 -20 -34q-8 -2 -12 -2q-16 0 -26 13q-10 14 -21 31t-39.5 68.5t-49.5 99.5 t-38.5 114t-17.5 122q0 49 3.5 91t14 90t28 88t47 81.5t68.5 74t94.5 61.5t124.5 48.5t159.5 30.5t196.5 11h160v192q0 42 39 59q13 5 25 5q26 0 45 -19l384 -384q19 -19 19 -45t-19 -45z" />
+<glyph unicode="&#xf046;" horiz-adv-x="1664" d="M1408 606v-318q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-10 -10 -23 -10q-3 0 -9 2q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832 q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v254q0 13 9 22l64 64q10 10 23 10q6 0 12 -3q20 -8 20 -29zM1639 1095l-814 -814q-24 -24 -57 -24t-57 24l-430 430q-24 24 -24 57t24 57l110 110q24 24 57 24t57 -24l263 -263l647 647q24 24 57 24t57 -24l110 -110 q24 -24 24 -57t-24 -57z" />
+<glyph unicode="&#xf047;" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-384v-384h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v384h-384v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45 t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h384v384h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45t-19 -45t-45 -19h-128v-384h384v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" />
+<glyph unicode="&#xf048;" horiz-adv-x="1024" d="M979 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19z" />
+<glyph unicode="&#xf049;" horiz-adv-x="1792" d="M1747 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19l710 710 q19 19 32 13t13 -32v-710q4 11 13 19z" />
+<glyph unicode="&#xf04a;" horiz-adv-x="1664" d="M1619 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-8 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-19 19 -19 45t19 45l710 710q19 19 32 13t13 -32v-710q5 11 13 19z" />
+<glyph unicode="&#xf04b;" horiz-adv-x="1408" d="M1384 609l-1328 -738q-23 -13 -39.5 -3t-16.5 36v1472q0 26 16.5 36t39.5 -3l1328 -738q23 -13 23 -31t-23 -31z" />
+<glyph unicode="&#xf04c;" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45zM640 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf04d;" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf04e;" horiz-adv-x="1664" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q19 -19 19 -45t-19 -45l-710 -710q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" />
+<glyph unicode="&#xf050;" horiz-adv-x="1792" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19l-710 -710 q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" />
+<glyph unicode="&#xf051;" horiz-adv-x="1024" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19z" />
+<glyph unicode="&#xf052;" horiz-adv-x="1538" d="M14 557l710 710q19 19 45 19t45 -19l710 -710q19 -19 13 -32t-32 -13h-1472q-26 0 -32 13t13 32zM1473 0h-1408q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1408q26 0 45 -19t19 -45v-256q0 -26 -19 -45t-45 -19z" />
+<glyph unicode="&#xf053;" horiz-adv-x="1152" d="M742 -37l-652 651q-37 37 -37 90.5t37 90.5l652 651q37 37 90.5 37t90.5 -37l75 -75q37 -37 37 -90.5t-37 -90.5l-486 -486l486 -485q37 -38 37 -91t-37 -90l-75 -75q-37 -37 -90.5 -37t-90.5 37z" />
+<glyph unicode="&#xf054;" horiz-adv-x="1152" d="M1099 704q0 -52 -37 -91l-652 -651q-37 -37 -90 -37t-90 37l-76 75q-37 39 -37 91q0 53 37 90l486 486l-486 485q-37 39 -37 91q0 53 37 90l76 75q36 38 90 38t90 -38l652 -651q37 -37 37 -90z" />
+<glyph unicode="&#xf055;" d="M1216 576v128q0 26 -19 45t-45 19h-256v256q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-256h-256q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h256v-256q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v256h256q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5 t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf056;" d="M1216 576v128q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5 t103 -385.5z" />
+<glyph unicode="&#xf057;" d="M1149 414q0 26 -19 45l-181 181l181 181q19 19 19 45q0 27 -19 46l-90 90q-19 19 -46 19q-26 0 -45 -19l-181 -181l-181 181q-19 19 -45 19q-27 0 -46 -19l-90 -90q-19 -19 -19 -46q0 -26 19 -45l181 -181l-181 -181q-19 -19 -19 -45q0 -27 19 -46l90 -90q19 -19 46 -19 q26 0 45 19l181 181l181 -181q19 -19 45 -19q27 0 46 19l90 90q19 19 19 46zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf058;" d="M1284 802q0 28 -18 46l-91 90q-19 19 -45 19t-45 -19l-408 -407l-226 226q-19 19 -45 19t-45 -19l-91 -90q-18 -18 -18 -46q0 -27 18 -45l362 -362q19 -19 45 -19q27 0 46 19l543 543q18 18 18 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf059;" d="M896 160v192q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h192q14 0 23 9t9 23zM1152 832q0 88 -55.5 163t-138.5 116t-170 41q-243 0 -371 -213q-15 -24 8 -42l132 -100q7 -6 19 -6q16 0 25 12q53 68 86 92q34 24 86 24q48 0 85.5 -26t37.5 -59 q0 -38 -20 -61t-68 -45q-63 -28 -115.5 -86.5t-52.5 -125.5v-36q0 -14 9 -23t23 -9h192q14 0 23 9t9 23q0 19 21.5 49.5t54.5 49.5q32 18 49 28.5t46 35t44.5 48t28 60.5t12.5 81zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf05a;" d="M1024 160v160q0 14 -9 23t-23 9h-96v512q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h96v-320h-96q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h448q14 0 23 9t9 23zM896 1056v160q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23 t23 -9h192q14 0 23 9t9 23zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf05b;" d="M1197 512h-109q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h109q-32 108 -112.5 188.5t-188.5 112.5v-109q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v109q-108 -32 -188.5 -112.5t-112.5 -188.5h109q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-109 q32 -108 112.5 -188.5t188.5 -112.5v109q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-109q108 32 188.5 112.5t112.5 188.5zM1536 704v-128q0 -26 -19 -45t-45 -19h-143q-37 -161 -154.5 -278.5t-278.5 -154.5v-143q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v143 q-161 37 -278.5 154.5t-154.5 278.5h-143q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h143q37 161 154.5 278.5t278.5 154.5v143q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-143q161 -37 278.5 -154.5t154.5 -278.5h143q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf05c;" d="M1097 457l-146 -146q-10 -10 -23 -10t-23 10l-137 137l-137 -137q-10 -10 -23 -10t-23 10l-146 146q-10 10 -10 23t10 23l137 137l-137 137q-10 10 -10 23t10 23l146 146q10 10 23 10t23 -10l137 -137l137 137q10 10 23 10t23 -10l146 -146q10 -10 10 -23t-10 -23 l-137 -137l137 -137q10 -10 10 -23t-10 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5 t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf05d;" d="M1171 723l-422 -422q-19 -19 -45 -19t-45 19l-294 294q-19 19 -19 45t19 45l102 102q19 19 45 19t45 -19l147 -147l275 275q19 19 45 19t45 -19l102 -102q19 -19 19 -45t-19 -45zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198 t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf05e;" d="M1312 643q0 161 -87 295l-754 -753q137 -89 297 -89q111 0 211.5 43.5t173.5 116.5t116 174.5t43 212.5zM313 344l755 754q-135 91 -300 91q-148 0 -273 -73t-198 -199t-73 -274q0 -162 89 -299zM1536 643q0 -157 -61 -300t-163.5 -246t-245 -164t-298.5 -61t-298.5 61 t-245 164t-163.5 246t-61 300t61 299.5t163.5 245.5t245 164t298.5 61t298.5 -61t245 -164t163.5 -245.5t61 -299.5z" />
+<glyph unicode="&#xf060;" d="M1536 640v-128q0 -53 -32.5 -90.5t-84.5 -37.5h-704l293 -294q38 -36 38 -90t-38 -90l-75 -76q-37 -37 -90 -37q-52 0 -91 37l-651 652q-37 37 -37 90q0 52 37 91l651 650q38 38 91 38q52 0 90 -38l75 -74q38 -38 38 -91t-38 -91l-293 -293h704q52 0 84.5 -37.5 t32.5 -90.5z" />
+<glyph unicode="&#xf061;" d="M1472 576q0 -54 -37 -91l-651 -651q-39 -37 -91 -37q-51 0 -90 37l-75 75q-38 38 -38 91t38 91l293 293h-704q-52 0 -84.5 37.5t-32.5 90.5v128q0 53 32.5 90.5t84.5 37.5h704l-293 294q-38 36 -38 90t38 90l75 75q38 38 90 38q53 0 91 -38l651 -651q37 -35 37 -90z" />
+<glyph unicode="&#xf062;" horiz-adv-x="1664" d="M1611 565q0 -51 -37 -90l-75 -75q-38 -38 -91 -38q-54 0 -90 38l-294 293v-704q0 -52 -37.5 -84.5t-90.5 -32.5h-128q-53 0 -90.5 32.5t-37.5 84.5v704l-294 -293q-36 -38 -90 -38t-90 38l-75 75q-38 38 -38 90q0 53 38 91l651 651q35 37 90 37q54 0 91 -37l651 -651 q37 -39 37 -91z" />
+<glyph unicode="&#xf063;" horiz-adv-x="1664" d="M1611 704q0 -53 -37 -90l-651 -652q-39 -37 -91 -37q-53 0 -90 37l-651 652q-38 36 -38 90q0 53 38 91l74 75q39 37 91 37q53 0 90 -37l294 -294v704q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-704l294 294q37 37 90 37q52 0 91 -37l75 -75q37 -39 37 -91z" />
+<glyph unicode="&#xf064;" horiz-adv-x="1792" d="M1792 896q0 -26 -19 -45l-512 -512q-19 -19 -45 -19t-45 19t-19 45v256h-224q-98 0 -175.5 -6t-154 -21.5t-133 -42.5t-105.5 -69.5t-80 -101t-48.5 -138.5t-17.5 -181q0 -55 5 -123q0 -6 2.5 -23.5t2.5 -26.5q0 -15 -8.5 -25t-23.5 -10q-16 0 -28 17q-7 9 -13 22 t-13.5 30t-10.5 24q-127 285 -127 451q0 199 53 333q162 403 875 403h224v256q0 26 19 45t45 19t45 -19l512 -512q19 -19 19 -45z" />
+<glyph unicode="&#xf065;" d="M755 480q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23zM1536 1344v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332 q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf066;" d="M768 576v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45zM1523 1248q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45 t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23z" />
+<glyph unicode="&#xf067;" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-416v-416q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v416h-416q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h416v416q0 40 28 68t68 28h192q40 0 68 -28t28 -68v-416h416q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf068;" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-1216q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h1216q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf069;" horiz-adv-x="1664" d="M1482 486q46 -26 59.5 -77.5t-12.5 -97.5l-64 -110q-26 -46 -77.5 -59.5t-97.5 12.5l-266 153v-307q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v307l-266 -153q-46 -26 -97.5 -12.5t-77.5 59.5l-64 110q-26 46 -12.5 97.5t59.5 77.5l266 154l-266 154 q-46 26 -59.5 77.5t12.5 97.5l64 110q26 46 77.5 59.5t97.5 -12.5l266 -153v307q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-307l266 153q46 26 97.5 12.5t77.5 -59.5l64 -110q26 -46 12.5 -97.5t-59.5 -77.5l-266 -154z" />
+<glyph unicode="&#xf06a;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM896 161v190q0 14 -9 23.5t-22 9.5h-192q-13 0 -23 -10t-10 -23v-190q0 -13 10 -23t23 -10h192 q13 0 22 9.5t9 23.5zM894 505l18 621q0 12 -10 18q-10 8 -24 8h-220q-14 0 -24 -8q-10 -6 -10 -18l17 -621q0 -10 10 -17.5t24 -7.5h185q14 0 23.5 7.5t10.5 17.5z" />
+<glyph unicode="&#xf06b;" d="M928 180v56v468v192h-320v-192v-468v-56q0 -25 18 -38.5t46 -13.5h192q28 0 46 13.5t18 38.5zM472 1024h195l-126 161q-26 31 -69 31q-40 0 -68 -28t-28 -68t28 -68t68 -28zM1160 1120q0 40 -28 68t-68 28q-43 0 -69 -31l-125 -161h194q40 0 68 28t28 68zM1536 864v-320 q0 -14 -9 -23t-23 -9h-96v-416q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v416h-96q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h440q-93 0 -158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5q107 0 168 -77l128 -165l128 165q61 77 168 77q93 0 158.5 -65.5t65.5 -158.5 t-65.5 -158.5t-158.5 -65.5h440q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf06c;" horiz-adv-x="1792" d="M1280 832q0 26 -19 45t-45 19q-172 0 -318 -49.5t-259.5 -134t-235.5 -219.5q-19 -21 -19 -45q0 -26 19 -45t45 -19q24 0 45 19q27 24 74 71t67 66q137 124 268.5 176t313.5 52q26 0 45 19t19 45zM1792 1030q0 -95 -20 -193q-46 -224 -184.5 -383t-357.5 -268 q-214 -108 -438 -108q-148 0 -286 47q-15 5 -88 42t-96 37q-16 0 -39.5 -32t-45 -70t-52.5 -70t-60 -32q-30 0 -51 11t-31 24t-27 42q-2 4 -6 11t-5.5 10t-3 9.5t-1.5 13.5q0 35 31 73.5t68 65.5t68 56t31 48q0 4 -14 38t-16 44q-9 51 -9 104q0 115 43.5 220t119 184.5 t170.5 139t204 95.5q55 18 145 25.5t179.5 9t178.5 6t163.5 24t113.5 56.5l29.5 29.5t29.5 28t27 20t36.5 16t43.5 4.5q39 0 70.5 -46t47.5 -112t24 -124t8 -96z" />
+<glyph unicode="&#xf06d;" horiz-adv-x="1408" d="M1408 -160v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1152 896q0 -78 -24.5 -144t-64 -112.5t-87.5 -88t-96 -77.5t-87.5 -72t-64 -81.5t-24.5 -96.5q0 -96 67 -224l-4 1l1 -1 q-90 41 -160 83t-138.5 100t-113.5 122.5t-72.5 150.5t-27.5 184q0 78 24.5 144t64 112.5t87.5 88t96 77.5t87.5 72t64 81.5t24.5 96.5q0 94 -66 224l3 -1l-1 1q90 -41 160 -83t138.5 -100t113.5 -122.5t72.5 -150.5t27.5 -184z" />
+<glyph unicode="&#xf06e;" horiz-adv-x="1792" d="M1664 576q-152 236 -381 353q61 -104 61 -225q0 -185 -131.5 -316.5t-316.5 -131.5t-316.5 131.5t-131.5 316.5q0 121 61 225q-229 -117 -381 -353q133 -205 333.5 -326.5t434.5 -121.5t434.5 121.5t333.5 326.5zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5 t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1792 576q0 -34 -20 -69q-140 -230 -376.5 -368.5t-499.5 -138.5t-499.5 139t-376.5 368q-20 35 -20 69t20 69q140 229 376.5 368t499.5 139t499.5 -139t376.5 -368q20 -35 20 -69z" />
+<glyph unicode="&#xf070;" horiz-adv-x="1792" d="M555 201l78 141q-87 63 -136 159t-49 203q0 121 61 225q-229 -117 -381 -353q167 -258 427 -375zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1307 1151q0 -7 -1 -9 q-105 -188 -315 -566t-316 -567l-49 -89q-10 -16 -28 -16q-12 0 -134 70q-16 10 -16 28q0 12 44 87q-143 65 -263.5 173t-208.5 245q-20 31 -20 69t20 69q153 235 380 371t496 136q89 0 180 -17l54 97q10 16 28 16q5 0 18 -6t31 -15.5t33 -18.5t31.5 -18.5t19.5 -11.5 q16 -10 16 -27zM1344 704q0 -139 -79 -253.5t-209 -164.5l280 502q8 -45 8 -84zM1792 576q0 -35 -20 -69q-39 -64 -109 -145q-150 -172 -347.5 -267t-419.5 -95l74 132q212 18 392.5 137t301.5 307q-115 179 -282 294l63 112q95 -64 182.5 -153t144.5 -184q20 -34 20 -69z " />
+<glyph unicode="&#xf071;" horiz-adv-x="1792" d="M1024 161v190q0 14 -9.5 23.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -23.5v-190q0 -14 9.5 -23.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 23.5zM1022 535l18 459q0 12 -10 19q-13 11 -24 11h-220q-11 0 -24 -11q-10 -7 -10 -21l17 -457q0 -10 10 -16.5t24 -6.5h185 q14 0 23.5 6.5t10.5 16.5zM1008 1469l768 -1408q35 -63 -2 -126q-17 -29 -46.5 -46t-63.5 -17h-1536q-34 0 -63.5 17t-46.5 46q-37 63 -2 126l768 1408q17 31 47 49t65 18t65 -18t47 -49z" />
+<glyph unicode="&#xf072;" horiz-adv-x="1408" d="M1376 1376q44 -52 12 -148t-108 -172l-161 -161l160 -696q5 -19 -12 -33l-128 -96q-7 -6 -19 -6q-4 0 -7 1q-15 3 -21 16l-279 508l-259 -259l53 -194q5 -17 -8 -31l-96 -96q-9 -9 -23 -9h-2q-15 2 -24 13l-189 252l-252 189q-11 7 -13 23q-1 13 9 25l96 97q9 9 23 9 q6 0 8 -1l194 -53l259 259l-508 279q-14 8 -17 24q-2 16 9 27l128 128q14 13 30 8l665 -159l160 160q76 76 172 108t148 -12z" />
+<glyph unicode="&#xf073;" horiz-adv-x="1664" d="M128 -128h288v288h-288v-288zM480 -128h320v288h-320v-288zM128 224h288v320h-288v-320zM480 224h320v320h-320v-320zM128 608h288v288h-288v-288zM864 -128h320v288h-320v-288zM480 608h320v288h-320v-288zM1248 -128h288v288h-288v-288zM864 224h320v320h-320v-320z M512 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1248 224h288v320h-288v-320zM864 608h320v288h-320v-288zM1248 608h288v288h-288v-288zM1280 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64 q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1664 1152v-1280q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47 h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" />
+<glyph unicode="&#xf074;" horiz-adv-x="1792" d="M666 1055q-60 -92 -137 -273q-22 45 -37 72.5t-40.5 63.5t-51 56.5t-63 35t-81.5 14.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q250 0 410 -225zM1792 256q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192q-32 0 -85 -0.5t-81 -1t-73 1 t-71 5t-64 10.5t-63 18.5t-58 28.5t-59 40t-55 53.5t-56 69.5q59 93 136 273q22 -45 37 -72.5t40.5 -63.5t51 -56.5t63 -35t81.5 -14.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1792 1152q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5 v192h-256q-48 0 -87 -15t-69 -45t-51 -61.5t-45 -77.5q-32 -62 -78 -171q-29 -66 -49.5 -111t-54 -105t-64 -100t-74 -83t-90 -68.5t-106.5 -42t-128 -16.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q48 0 87 15t69 45t51 61.5t45 77.5q32 62 78 171q29 66 49.5 111 t54 105t64 100t74 83t90 68.5t106.5 42t128 16.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" />
+<glyph unicode="&#xf075;" horiz-adv-x="1792" d="M1792 640q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22q-17 -2 -30.5 9t-17.5 29v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281 q0 130 71 248.5t191 204.5t286 136.5t348 50.5q244 0 450 -85.5t326 -233t120 -321.5z" />
+<glyph unicode="&#xf076;" d="M1536 704v-128q0 -201 -98.5 -362t-274 -251.5t-395.5 -90.5t-395.5 90.5t-274 251.5t-98.5 362v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-128q0 -52 23.5 -90t53.5 -57t71 -30t64 -13t44 -2t44 2t64 13t71 30t53.5 57t23.5 90v128q0 26 19 45t45 19h384 q26 0 45 -19t19 -45zM512 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45zM1536 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf077;" horiz-adv-x="1664" d="M1611 320q0 -53 -37 -90l-75 -75q-38 -38 -91 -38q-54 0 -90 38l-486 485l-486 -485q-36 -38 -90 -38t-90 38l-75 75q-38 36 -38 90q0 53 38 91l651 651q37 37 90 37q52 0 91 -37l650 -651q38 -38 38 -91z" />
+<glyph unicode="&#xf078;" horiz-adv-x="1664" d="M1611 832q0 -53 -37 -90l-651 -651q-38 -38 -91 -38q-54 0 -90 38l-651 651q-38 36 -38 90q0 53 38 91l74 75q39 37 91 37q53 0 90 -37l486 -486l486 486q37 37 90 37q52 0 91 -37l75 -75q37 -39 37 -91z" />
+<glyph unicode="&#xf079;" horiz-adv-x="1920" d="M1280 32q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-8 0 -13.5 2t-9 7t-5.5 8t-3 11.5t-1 11.5v13v11v160v416h-192q-26 0 -45 19t-19 45q0 24 15 41l320 384q19 22 49 22t49 -22l320 -384q15 -17 15 -41q0 -26 -19 -45t-45 -19h-192v-384h576q16 0 25 -11l160 -192q7 -11 7 -21 zM1920 448q0 -24 -15 -41l-320 -384q-20 -23 -49 -23t-49 23l-320 384q-15 17 -15 41q0 26 19 45t45 19h192v384h-576q-16 0 -25 12l-160 192q-7 9 -7 20q0 13 9.5 22.5t22.5 9.5h960q8 0 13.5 -2t9 -7t5.5 -8t3 -11.5t1 -11.5v-13v-11v-160v-416h192q26 0 45 -19t19 -45z " />
+<glyph unicode="&#xf07a;" horiz-adv-x="1664" d="M640 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1536 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1664 1088v-512q0 -24 -16 -42.5t-41 -21.5 l-1044 -122q1 -7 4.5 -21.5t6 -26.5t2.5 -22q0 -16 -24 -64h920q26 0 45 -19t19 -45t-19 -45t-45 -19h-1024q-26 0 -45 19t-19 45q0 14 11 39.5t29.5 59.5t20.5 38l-177 823h-204q-26 0 -45 19t-19 45t19 45t45 19h256q16 0 28.5 -6.5t20 -15.5t13 -24.5t7.5 -26.5 t5.5 -29.5t4.5 -25.5h1201q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf07b;" horiz-adv-x="1664" d="M1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" />
+<glyph unicode="&#xf07c;" horiz-adv-x="1920" d="M1879 584q0 -31 -31 -66l-336 -396q-43 -51 -120.5 -86.5t-143.5 -35.5h-1088q-34 0 -60.5 13t-26.5 43q0 31 31 66l336 396q43 51 120.5 86.5t143.5 35.5h1088q34 0 60.5 -13t26.5 -43zM1536 928v-160h-832q-94 0 -197 -47.5t-164 -119.5l-337 -396l-5 -6q0 4 -0.5 12.5 t-0.5 12.5v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158z" />
+<glyph unicode="&#xf07d;" horiz-adv-x="768" d="M704 1216q0 -26 -19 -45t-45 -19h-128v-1024h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v1024h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45z" />
+<glyph unicode="&#xf07e;" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-1024v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h1024v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" />
+<glyph unicode="&#xf080;" horiz-adv-x="1920" d="M512 512v-384h-256v384h256zM896 1024v-896h-256v896h256zM1280 768v-640h-256v640h256zM1664 1152v-1024h-256v1024h256zM1792 32v1216q0 13 -9.5 22.5t-22.5 9.5h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-1216q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5z M1920 1248v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf081;" d="M1280 926q-56 -25 -121 -34q68 40 93 117q-65 -38 -134 -51q-61 66 -153 66q-87 0 -148.5 -61.5t-61.5 -148.5q0 -29 5 -48q-129 7 -242 65t-192 155q-29 -50 -29 -106q0 -114 91 -175q-47 1 -100 26v-2q0 -75 50 -133.5t123 -72.5q-29 -8 -51 -8q-13 0 -39 4 q21 -63 74.5 -104t121.5 -42q-116 -90 -261 -90q-26 0 -50 3q148 -94 322 -94q112 0 210 35.5t168 95t120.5 137t75 162t24.5 168.5q0 18 -1 27q63 45 105 109zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5 t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf082;" d="M1307 618l23 219h-198v109q0 49 15.5 68.5t71.5 19.5h110v219h-175q-152 0 -218 -72t-66 -213v-131h-131v-219h131v-635h262v635h175zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960 q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf083;" horiz-adv-x="1792" d="M928 704q0 14 -9 23t-23 9q-66 0 -113 -47t-47 -113q0 -14 9 -23t23 -9t23 9t9 23q0 40 28 68t68 28q14 0 23 9t9 23zM1152 574q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM128 0h1536v128h-1536v-128zM1280 574q0 159 -112.5 271.5 t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM256 1216h384v128h-384v-128zM128 1024h1536v118v138h-828l-64 -128h-644v-128zM1792 1280v-1280q0 -53 -37.5 -90.5t-90.5 -37.5h-1536q-53 0 -90.5 37.5t-37.5 90.5v1280 q0 53 37.5 90.5t90.5 37.5h1536q53 0 90.5 -37.5t37.5 -90.5z" />
+<glyph unicode="&#xf084;" horiz-adv-x="1792" d="M832 1024q0 80 -56 136t-136 56t-136 -56t-56 -136q0 -42 19 -83q-41 19 -83 19q-80 0 -136 -56t-56 -136t56 -136t136 -56t136 56t56 136q0 42 -19 83q41 -19 83 -19q80 0 136 56t56 136zM1683 320q0 -17 -49 -66t-66 -49q-9 0 -28.5 16t-36.5 33t-38.5 40t-24.5 26 l-96 -96l220 -220q28 -28 28 -68q0 -42 -39 -81t-81 -39q-40 0 -68 28l-671 671q-176 -131 -365 -131q-163 0 -265.5 102.5t-102.5 265.5q0 160 95 313t248 248t313 95q163 0 265.5 -102.5t102.5 -265.5q0 -189 -131 -365l355 -355l96 96q-3 3 -26 24.5t-40 38.5t-33 36.5 t-16 28.5q0 17 49 66t66 49q13 0 23 -10q6 -6 46 -44.5t82 -79.5t86.5 -86t73 -78t28.5 -41z" />
+<glyph unicode="&#xf085;" horiz-adv-x="1920" d="M896 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1664 128q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 1152q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1280 731v-185q0 -10 -7 -19.5t-16 -10.5l-155 -24q-11 -35 -32 -76q34 -48 90 -115q7 -10 7 -20q0 -12 -7 -19q-23 -30 -82.5 -89.5t-78.5 -59.5q-11 0 -21 7l-115 90q-37 -19 -77 -31q-11 -108 -23 -155q-7 -24 -30 -24h-186q-11 0 -20 7.5t-10 17.5 l-23 153q-34 10 -75 31l-118 -89q-7 -7 -20 -7q-11 0 -21 8q-144 133 -144 160q0 9 7 19q10 14 41 53t47 61q-23 44 -35 82l-152 24q-10 1 -17 9.5t-7 19.5v185q0 10 7 19.5t16 10.5l155 24q11 35 32 76q-34 48 -90 115q-7 11 -7 20q0 12 7 20q22 30 82 89t79 59q11 0 21 -7 l115 -90q34 18 77 32q11 108 23 154q7 24 30 24h186q11 0 20 -7.5t10 -17.5l23 -153q34 -10 75 -31l118 89q8 7 20 7q11 0 21 -8q144 -133 144 -160q0 -9 -7 -19q-12 -16 -42 -54t-45 -60q23 -48 34 -82l152 -23q10 -2 17 -10.5t7 -19.5zM1920 198v-140q0 -16 -149 -31 q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20 t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31zM1920 1222v-140q0 -16 -149 -31q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68 q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70 q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31z" />
+<glyph unicode="&#xf086;" horiz-adv-x="1792" d="M1408 768q0 -139 -94 -257t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224 q0 139 94 257t256.5 186.5t353.5 68.5t353.5 -68.5t256.5 -186.5t94 -257zM1792 512q0 -120 -71 -224.5t-195 -176.5q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7 q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230z" />
+<glyph unicode="&#xf087;" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 768q0 51 -39 89.5t-89 38.5h-352q0 58 48 159.5t48 160.5q0 98 -32 145t-128 47q-26 -26 -38 -85t-30.5 -125.5t-59.5 -109.5q-22 -23 -77 -91q-4 -5 -23 -30t-31.5 -41t-34.5 -42.5 t-40 -44t-38.5 -35.5t-40 -27t-35.5 -9h-32v-640h32q13 0 31.5 -3t33 -6.5t38 -11t35 -11.5t35.5 -12.5t29 -10.5q211 -73 342 -73h121q192 0 192 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5q32 1 53.5 47t21.5 81zM1536 769 q0 -89 -49 -163q9 -33 9 -69q0 -77 -38 -144q3 -21 3 -43q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5h-36h-93q-96 0 -189.5 22.5t-216.5 65.5q-116 40 -138 40h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h274q36 24 137 155q58 75 107 128 q24 25 35.5 85.5t30.5 126.5t62 108q39 37 90 37q84 0 151 -32.5t102 -101.5t35 -186q0 -93 -48 -192h176q104 0 180 -76t76 -179z" />
+<glyph unicode="&#xf088;" d="M256 1088q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 512q0 35 -21.5 81t-53.5 47q15 17 25 47.5t10 55.5q0 69 -53 119q18 32 18 69t-17.5 73.5t-47.5 52.5q5 30 5 56q0 85 -49 126t-136 41h-128q-131 0 -342 -73q-5 -2 -29 -10.5 t-35.5 -12.5t-35 -11.5t-38 -11t-33 -6.5t-31.5 -3h-32v-640h32q16 0 35.5 -9t40 -27t38.5 -35.5t40 -44t34.5 -42.5t31.5 -41t23 -30q55 -68 77 -91q41 -43 59.5 -109.5t30.5 -125.5t38 -85q96 0 128 47t32 145q0 59 -48 160.5t-48 159.5h352q50 0 89 38.5t39 89.5z M1536 511q0 -103 -76 -179t-180 -76h-176q48 -99 48 -192q0 -118 -35 -186q-35 -69 -102 -101.5t-151 -32.5q-51 0 -90 37q-34 33 -54 82t-25.5 90.5t-17.5 84.5t-31 64q-48 50 -107 127q-101 131 -137 155h-274q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5 h288q22 0 138 40q128 44 223 66t200 22h112q140 0 226.5 -79t85.5 -216v-5q60 -77 60 -178q0 -22 -3 -43q38 -67 38 -144q0 -36 -9 -69q49 -74 49 -163z" />
+<glyph unicode="&#xf089;" horiz-adv-x="896" d="M832 1504v-1339l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41z" />
+<glyph unicode="&#xf08a;" horiz-adv-x="1792" d="M1664 940q0 81 -21.5 143t-55 98.5t-81.5 59.5t-94 31t-98 8t-112 -25.5t-110.5 -64t-86.5 -72t-60 -61.5q-18 -22 -49 -22t-49 22q-24 28 -60 61.5t-86.5 72t-110.5 64t-112 25.5t-98 -8t-94 -31t-81.5 -59.5t-55 -98.5t-21.5 -143q0 -168 187 -355l581 -560l580 559 q188 188 188 356zM1792 940q0 -221 -229 -450l-623 -600q-18 -18 -44 -18t-44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5 q224 0 351 -124t127 -344z" />
+<glyph unicode="&#xf08b;" horiz-adv-x="1664" d="M640 96q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h320q13 0 22.5 -9.5t9.5 -22.5q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-66 0 -113 -47t-47 -113v-704 q0 -66 47 -113t113 -47h288h11h13t11.5 -1t11.5 -3t8 -5.5t7 -9t2 -13.5zM1568 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45z" />
+<glyph unicode="&#xf08c;" d="M237 122h231v694h-231v-694zM483 1030q-1 52 -36 86t-93 34t-94.5 -34t-36.5 -86q0 -51 35.5 -85.5t92.5 -34.5h1q59 0 95 34.5t36 85.5zM1068 122h231v398q0 154 -73 233t-193 79q-136 0 -209 -117h2v101h-231q3 -66 0 -694h231v388q0 38 7 56q15 35 45 59.5t74 24.5 q116 0 116 -157v-371zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf08d;" horiz-adv-x="1152" d="M480 672v448q0 14 -9 23t-23 9t-23 -9t-9 -23v-448q0 -14 9 -23t23 -9t23 9t9 23zM1152 320q0 -26 -19 -45t-45 -19h-429l-51 -483q-2 -12 -10.5 -20.5t-20.5 -8.5h-1q-27 0 -32 27l-76 485h-404q-26 0 -45 19t-19 45q0 123 78.5 221.5t177.5 98.5v512q-52 0 -90 38 t-38 90t38 90t90 38h640q52 0 90 -38t38 -90t-38 -90t-90 -38v-512q99 0 177.5 -98.5t78.5 -221.5z" />
+<glyph unicode="&#xf08e;" horiz-adv-x="1792" d="M1408 608v-320q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h704q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v320 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1792 1472v-512q0 -26 -19 -45t-45 -19t-45 19l-176 176l-652 -652q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l652 652l-176 176q-19 19 -19 45t19 45t45 19h512q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf090;" d="M1184 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45zM1536 992v-704q0 -119 -84.5 -203.5t-203.5 -84.5h-320q-13 0 -22.5 9.5t-9.5 22.5 q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q66 0 113 47t47 113v704q0 66 -47 113t-113 47h-288h-11h-13t-11.5 1t-11.5 3t-8 5.5t-7 9t-2 13.5q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf091;" horiz-adv-x="1664" d="M458 653q-74 162 -74 371h-256v-96q0 -78 94.5 -162t235.5 -113zM1536 928v96h-256q0 -209 -74 -371q141 29 235.5 113t94.5 162zM1664 1056v-128q0 -71 -41.5 -143t-112 -130t-173 -97.5t-215.5 -44.5q-42 -54 -95 -95q-38 -34 -52.5 -72.5t-14.5 -89.5q0 -54 30.5 -91 t97.5 -37q75 0 133.5 -45.5t58.5 -114.5v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 69 58.5 114.5t133.5 45.5q67 0 97.5 37t30.5 91q0 51 -14.5 89.5t-52.5 72.5q-53 41 -95 95q-113 5 -215.5 44.5t-173 97.5t-112 130t-41.5 143v128q0 40 28 68t68 28h288v96 q0 66 47 113t113 47h576q66 0 113 -47t47 -113v-96h288q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf092;" d="M394 184q-8 -9 -20 3q-13 11 -4 19q8 9 20 -3q12 -11 4 -19zM352 245q9 -12 0 -19q-8 -6 -17 7t0 18q9 7 17 -6zM291 305q-5 -7 -13 -2q-10 5 -7 12q3 5 13 2q10 -5 7 -12zM322 271q-6 -7 -16 3q-9 11 -2 16q6 6 16 -3q9 -11 2 -16zM451 159q-4 -12 -19 -6q-17 4 -13 15 t19 7q16 -5 13 -16zM514 154q0 -11 -16 -11q-17 -2 -17 11q0 11 16 11q17 2 17 -11zM572 164q2 -10 -14 -14t-18 8t14 15q16 2 18 -9zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-224q-16 0 -24.5 1t-19.5 5t-16 14.5t-5 27.5v239q0 97 -52 142q57 6 102.5 18t94 39 t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103 q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -103t0.5 -68q0 -22 -11 -33.5t-22 -13t-33 -1.5 h-224q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf093;" horiz-adv-x="1664" d="M1280 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 288v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h427q21 -56 70.5 -92 t110.5 -36h256q61 0 110.5 36t70.5 92h427q40 0 68 -28t28 -68zM1339 936q-17 -40 -59 -40h-256v-448q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v448h-256q-42 0 -59 40q-17 39 14 69l448 448q18 19 45 19t45 -19l448 -448q31 -30 14 -69z" />
+<glyph unicode="&#xf094;" d="M1407 710q0 44 -7 113.5t-18 96.5q-12 30 -17 44t-9 36.5t-4 48.5q0 23 5 68.5t5 67.5q0 37 -10 55q-4 1 -13 1q-19 0 -58 -4.5t-59 -4.5q-60 0 -176 24t-175 24q-43 0 -94.5 -11.5t-85 -23.5t-89.5 -34q-137 -54 -202 -103q-96 -73 -159.5 -189.5t-88 -236t-24.5 -248.5 q0 -40 12.5 -120t12.5 -121q0 -23 -11 -66.5t-11 -65.5t12 -36.5t34 -14.5q24 0 72.5 11t73.5 11q57 0 169.5 -15.5t169.5 -15.5q181 0 284 36q129 45 235.5 152.5t166 245.5t59.5 275zM1535 712q0 -165 -70 -327.5t-196 -288t-281 -180.5q-124 -44 -326 -44 q-57 0 -170 14.5t-169 14.5q-24 0 -72.5 -14.5t-73.5 -14.5q-73 0 -123.5 55.5t-50.5 128.5q0 24 11 68t11 67q0 40 -12.5 120.5t-12.5 121.5q0 111 18 217.5t54.5 209.5t100.5 194t150 156q78 59 232 120q194 78 316 78q60 0 175.5 -24t173.5 -24q19 0 57 5t58 5 q81 0 118 -50.5t37 -134.5q0 -23 -5 -68t-5 -68q0 -10 1 -18.5t3 -17t4 -13.5t6.5 -16t6.5 -17q16 -40 25 -118.5t9 -136.5z" />
+<glyph unicode="&#xf095;" horiz-adv-x="1408" d="M1408 296q0 -27 -10 -70.5t-21 -68.5q-21 -50 -122 -106q-94 -51 -186 -51q-27 0 -52.5 3.5t-57.5 12.5t-47.5 14.5t-55.5 20.5t-49 18q-98 35 -175 83q-128 79 -264.5 215.5t-215.5 264.5q-48 77 -83 175q-3 9 -18 49t-20.5 55.5t-14.5 47.5t-12.5 57.5t-3.5 52.5 q0 92 51 186q56 101 106 122q25 11 68.5 21t70.5 10q14 0 21 -3q18 -6 53 -76q11 -19 30 -54t35 -63.5t31 -53.5q3 -4 17.5 -25t21.5 -35.5t7 -28.5q0 -20 -28.5 -50t-62 -55t-62 -53t-28.5 -46q0 -9 5 -22.5t8.5 -20.5t14 -24t11.5 -19q76 -137 174 -235t235 -174 q2 -1 19 -11.5t24 -14t20.5 -8.5t22.5 -5q18 0 46 28.5t53 62t55 62t50 28.5q14 0 28.5 -7t35.5 -21.5t25 -17.5q25 -15 53.5 -31t63.5 -35t54 -30q70 -35 76 -53q3 -7 3 -21z" />
+<glyph unicode="&#xf096;" horiz-adv-x="1408" d="M1120 1280h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v832q0 66 -47 113t-113 47zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf097;" horiz-adv-x="1280" d="M1152 1280h-1024v-1242l423 406l89 85l89 -85l423 -406v1242zM1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289 q0 34 19.5 62t52.5 41q21 9 44 9h1048z" />
+<glyph unicode="&#xf098;" d="M1280 343q0 11 -2 16q-3 8 -38.5 29.5t-88.5 49.5l-53 29q-5 3 -19 13t-25 15t-21 5q-18 0 -47 -32.5t-57 -65.5t-44 -33q-7 0 -16.5 3.5t-15.5 6.5t-17 9.5t-14 8.5q-99 55 -170.5 126.5t-126.5 170.5q-2 3 -8.5 14t-9.5 17t-6.5 15.5t-3.5 16.5q0 13 20.5 33.5t45 38.5 t45 39.5t20.5 36.5q0 10 -5 21t-15 25t-13 19q-3 6 -15 28.5t-25 45.5t-26.5 47.5t-25 40.5t-16.5 18t-16 2q-48 0 -101 -22q-46 -21 -80 -94.5t-34 -130.5q0 -16 2.5 -34t5 -30.5t9 -33t10 -29.5t12.5 -33t11 -30q60 -164 216.5 -320.5t320.5 -216.5q6 -2 30 -11t33 -12.5 t29.5 -10t33 -9t30.5 -5t34 -2.5q57 0 130.5 34t94.5 80q22 53 22 101zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf099;" horiz-adv-x="1664" d="M1620 1128q-67 -98 -162 -167q1 -14 1 -42q0 -130 -38 -259.5t-115.5 -248.5t-184.5 -210.5t-258 -146t-323 -54.5q-271 0 -496 145q35 -4 78 -4q225 0 401 138q-105 2 -188 64.5t-114 159.5q33 -5 61 -5q43 0 85 11q-112 23 -185.5 111.5t-73.5 205.5v4q68 -38 146 -41 q-66 44 -105 115t-39 154q0 88 44 163q121 -149 294.5 -238.5t371.5 -99.5q-8 38 -8 74q0 134 94.5 228.5t228.5 94.5q140 0 236 -102q109 21 205 78q-37 -115 -142 -178q93 10 186 50z" />
+<glyph unicode="&#xf09a;" horiz-adv-x="768" d="M511 980h257l-30 -284h-227v-824h-341v824h-170v284h170v171q0 182 86 275.5t283 93.5h227v-284h-142q-39 0 -62.5 -6.5t-34 -23.5t-13.5 -34.5t-3 -49.5v-142z" />
+<glyph unicode="&#xf09b;" d="M1536 640q0 -251 -146.5 -451.5t-378.5 -277.5q-27 -5 -39.5 7t-12.5 30v211q0 97 -52 142q57 6 102.5 18t94 39t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5 q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23 q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -89t0.5 -54q0 -18 -13 -30t-40 -7q-232 77 -378.5 277.5t-146.5 451.5q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf09c;" horiz-adv-x="1664" d="M1664 960v-256q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45v256q0 106 -75 181t-181 75t-181 -75t-75 -181v-192h96q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h672v192q0 185 131.5 316.5t316.5 131.5 t316.5 -131.5t131.5 -316.5z" />
+<glyph unicode="&#xf09d;" horiz-adv-x="1920" d="M1760 1408q66 0 113 -47t47 -113v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600zM160 1280q-13 0 -22.5 -9.5t-9.5 -22.5v-224h1664v224q0 13 -9.5 22.5t-22.5 9.5h-1600zM1760 0q13 0 22.5 9.5t9.5 22.5v608h-1664v-608 q0 -13 9.5 -22.5t22.5 -9.5h1600zM256 128v128h256v-128h-256zM640 128v128h384v-128h-384z" />
+<glyph unicode="&#xf09e;" horiz-adv-x="1408" d="M384 192q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM896 69q2 -28 -17 -48q-18 -21 -47 -21h-135q-25 0 -43 16.5t-20 41.5q-22 229 -184.5 391.5t-391.5 184.5q-25 2 -41.5 20t-16.5 43v135q0 29 21 47q17 17 43 17h5q160 -13 306 -80.5 t259 -181.5q114 -113 181.5 -259t80.5 -306zM1408 67q2 -27 -18 -47q-18 -20 -46 -20h-143q-26 0 -44.5 17.5t-19.5 42.5q-12 215 -101 408.5t-231.5 336t-336 231.5t-408.5 102q-25 1 -42.5 19.5t-17.5 43.5v143q0 28 20 46q18 18 44 18h3q262 -13 501.5 -120t425.5 -294 q187 -186 294 -425.5t120 -501.5z" />
+<glyph unicode="&#xf0a0;" d="M1040 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1296 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1408 160v320q0 13 -9.5 22.5t-22.5 9.5 h-1216q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h1216q13 0 22.5 9.5t9.5 22.5zM178 640h1180l-157 482q-4 13 -16 21.5t-26 8.5h-782q-14 0 -26 -8.5t-16 -21.5zM1536 480v-320q0 -66 -47 -113t-113 -47h-1216q-66 0 -113 47t-47 113v320q0 25 16 75 l197 606q17 53 63 86t101 33h782q55 0 101 -33t63 -86l197 -606q16 -50 16 -75z" />
+<glyph unicode="&#xf0a1;" horiz-adv-x="1792" d="M1664 896q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5v-384q0 -52 -38 -90t-90 -38q-417 347 -812 380q-58 -19 -91 -66t-31 -100.5t40 -92.5q-20 -33 -23 -65.5t6 -58t33.5 -55t48 -50t61.5 -50.5q-29 -58 -111.5 -83t-168.5 -11.5t-132 55.5q-7 23 -29.5 87.5 t-32 94.5t-23 89t-15 101t3.5 98.5t22 110.5h-122q-66 0 -113 47t-47 113v192q0 66 47 113t113 47h480q435 0 896 384q52 0 90 -38t38 -90v-384zM1536 292v954q-394 -302 -768 -343v-270q377 -42 768 -341z" />
+<glyph unicode="&#xf0a2;" horiz-adv-x="1664" d="M848 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM183 128h1298q-164 181 -246.5 411.5t-82.5 484.5q0 256 -320 256t-320 -256q0 -254 -82.5 -484.5t-246.5 -411.5zM1664 128q0 -52 -38 -90t-90 -38 h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q190 161 287 397.5t97 498.5q0 165 96 262t264 117q-8 18 -8 37q0 40 28 68t68 28t68 -28t28 -68q0 -19 -8 -37q168 -20 264 -117t96 -262q0 -262 97 -498.5t287 -397.5z" />
+<glyph unicode="&#xf0a3;" d="M1376 640l138 -135q30 -28 20 -70q-12 -41 -52 -51l-188 -48l53 -186q12 -41 -19 -70q-29 -31 -70 -19l-186 53l-48 -188q-10 -40 -51 -52q-12 -2 -19 -2q-31 0 -51 22l-135 138l-135 -138q-28 -30 -70 -20q-41 11 -51 52l-48 188l-186 -53q-41 -12 -70 19q-31 29 -19 70 l53 186l-188 48q-40 10 -52 51q-10 42 20 70l138 135l-138 135q-30 28 -20 70q12 41 52 51l188 48l-53 186q-12 41 19 70q29 31 70 19l186 -53l48 188q10 41 51 51q41 12 70 -19l135 -139l135 139q29 30 70 19q41 -10 51 -51l48 -188l186 53q41 12 70 -19q31 -29 19 -70 l-53 -186l188 -48q40 -10 52 -51q10 -42 -20 -70z" />
+<glyph unicode="&#xf0a4;" horiz-adv-x="1792" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 768q0 51 -39 89.5t-89 38.5h-576q0 20 15 48.5t33 55t33 68t15 84.5q0 67 -44.5 97.5t-115.5 30.5q-24 0 -90 -139q-24 -44 -37 -65q-40 -64 -112 -145q-71 -81 -101 -106 q-69 -57 -140 -57h-32v-640h32q72 0 167 -32t193.5 -64t179.5 -32q189 0 189 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5h331q52 0 90 38t38 90zM1792 769q0 -105 -75.5 -181t-180.5 -76h-169q-4 -62 -37 -119q3 -21 3 -43 q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5q-133 0 -322 69q-164 59 -223 59h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h288q10 0 21.5 4.5t23.5 14t22.5 18t24 22.5t20.5 21.5t19 21.5t14 17q65 74 100 129q13 21 33 62t37 72t40.5 63t55 49.5 t69.5 17.5q125 0 206.5 -67t81.5 -189q0 -68 -22 -128h374q104 0 180 -76t76 -179z" />
+<glyph unicode="&#xf0a5;" horiz-adv-x="1792" d="M1376 128h32v640h-32q-35 0 -67.5 12t-62.5 37t-50 46t-49 54q-2 3 -3.5 4.5t-4 4.5t-4.5 5q-72 81 -112 145q-14 22 -38 68q-1 3 -10.5 22.5t-18.5 36t-20 35.5t-21.5 30.5t-18.5 11.5q-71 0 -115.5 -30.5t-44.5 -97.5q0 -43 15 -84.5t33 -68t33 -55t15 -48.5h-576 q-50 0 -89 -38.5t-39 -89.5q0 -52 38 -90t90 -38h331q-15 -17 -25 -47.5t-10 -55.5q0 -69 53 -119q-18 -32 -18 -69t17.5 -73.5t47.5 -52.5q-4 -24 -4 -56q0 -85 48.5 -126t135.5 -41q84 0 183 32t194 64t167 32zM1664 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45 t45 -19t45 19t19 45zM1792 768v-640q0 -53 -37.5 -90.5t-90.5 -37.5h-288q-59 0 -223 -59q-190 -69 -317 -69q-142 0 -230 77.5t-87 217.5l1 5q-61 76 -61 178q0 22 3 43q-33 57 -37 119h-169q-105 0 -180.5 76t-75.5 181q0 103 76 179t180 76h374q-22 60 -22 128 q0 122 81.5 189t206.5 67q38 0 69.5 -17.5t55 -49.5t40.5 -63t37 -72t33 -62q35 -55 100 -129q2 -3 14 -17t19 -21.5t20.5 -21.5t24 -22.5t22.5 -18t23.5 -14t21.5 -4.5h288q53 0 90.5 -37.5t37.5 -90.5z" />
+<glyph unicode="&#xf0a6;" d="M1280 -64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 700q0 189 -167 189q-26 0 -56 -5q-16 30 -52.5 47.5t-73.5 17.5t-69 -18q-50 53 -119 53q-25 0 -55.5 -10t-47.5 -25v331q0 52 -38 90t-90 38q-51 0 -89.5 -39t-38.5 -89v-576 q-20 0 -48.5 15t-55 33t-68 33t-84.5 15q-67 0 -97.5 -44.5t-30.5 -115.5q0 -24 139 -90q44 -24 65 -37q64 -40 145 -112q81 -71 106 -101q57 -69 57 -140v-32h640v32q0 72 32 167t64 193.5t32 179.5zM1536 705q0 -133 -69 -322q-59 -164 -59 -223v-288q0 -53 -37.5 -90.5 t-90.5 -37.5h-640q-53 0 -90.5 37.5t-37.5 90.5v288q0 10 -4.5 21.5t-14 23.5t-18 22.5t-22.5 24t-21.5 20.5t-21.5 19t-17 14q-74 65 -129 100q-21 13 -62 33t-72 37t-63 40.5t-49.5 55t-17.5 69.5q0 125 67 206.5t189 81.5q68 0 128 -22v374q0 104 76 180t179 76 q105 0 181 -75.5t76 -180.5v-169q62 -4 119 -37q21 3 43 3q101 0 178 -60q139 1 219.5 -85t80.5 -227z" />
+<glyph unicode="&#xf0a7;" d="M1408 576q0 84 -32 183t-64 194t-32 167v32h-640v-32q0 -35 -12 -67.5t-37 -62.5t-46 -50t-54 -49q-9 -8 -14 -12q-81 -72 -145 -112q-22 -14 -68 -38q-3 -1 -22.5 -10.5t-36 -18.5t-35.5 -20t-30.5 -21.5t-11.5 -18.5q0 -71 30.5 -115.5t97.5 -44.5q43 0 84.5 15t68 33 t55 33t48.5 15v-576q0 -50 38.5 -89t89.5 -39q52 0 90 38t38 90v331q46 -35 103 -35q69 0 119 53q32 -18 69 -18t73.5 17.5t52.5 47.5q24 -4 56 -4q85 0 126 48.5t41 135.5zM1280 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 580 q0 -142 -77.5 -230t-217.5 -87l-5 1q-76 -61 -178 -61q-22 0 -43 3q-54 -30 -119 -37v-169q0 -105 -76 -180.5t-181 -75.5q-103 0 -179 76t-76 180v374q-54 -22 -128 -22q-121 0 -188.5 81.5t-67.5 206.5q0 38 17.5 69.5t49.5 55t63 40.5t72 37t62 33q55 35 129 100 q3 2 17 14t21.5 19t21.5 20.5t22.5 24t18 22.5t14 23.5t4.5 21.5v288q0 53 37.5 90.5t90.5 37.5h640q53 0 90.5 -37.5t37.5 -90.5v-288q0 -59 59 -223q69 -190 69 -317z" />
+<glyph unicode="&#xf0a8;" d="M1280 576v128q0 26 -19 45t-45 19h-502l189 189q19 19 19 45t-19 45l-91 91q-18 18 -45 18t-45 -18l-362 -362l-91 -91q-18 -18 -18 -45t18 -45l91 -91l362 -362q18 -18 45 -18t45 18l91 91q18 18 18 45t-18 45l-189 189h502q26 0 45 19t19 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf0a9;" d="M1285 640q0 27 -18 45l-91 91l-362 362q-18 18 -45 18t-45 -18l-91 -91q-18 -18 -18 -45t18 -45l189 -189h-502q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h502l-189 -189q-19 -19 -19 -45t19 -45l91 -91q18 -18 45 -18t45 18l362 362l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf0aa;" d="M1284 641q0 27 -18 45l-362 362l-91 91q-18 18 -45 18t-45 -18l-91 -91l-362 -362q-18 -18 -18 -45t18 -45l91 -91q18 -18 45 -18t45 18l189 189v-502q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v502l189 -189q19 -19 45 -19t45 19l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf0ab;" d="M1284 639q0 27 -18 45l-91 91q-18 18 -45 18t-45 -18l-189 -189v502q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-502l-189 189q-19 19 -45 19t-45 -19l-91 -91q-18 -18 -18 -45t18 -45l362 -362l91 -91q18 -18 45 -18t45 18l91 91l362 362q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf0ac;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1042 887q-2 -1 -9.5 -9.5t-13.5 -9.5q2 0 4.5 5t5 11t3.5 7q6 7 22 15q14 6 52 12q34 8 51 -11 q-2 2 9.5 13t14.5 12q3 2 15 4.5t15 7.5l2 22q-12 -1 -17.5 7t-6.5 21q0 -2 -6 -8q0 7 -4.5 8t-11.5 -1t-9 -1q-10 3 -15 7.5t-8 16.5t-4 15q-2 5 -9.5 10.5t-9.5 10.5q-1 2 -2.5 5.5t-3 6.5t-4 5.5t-5.5 2.5t-7 -5t-7.5 -10t-4.5 -5q-3 2 -6 1.5t-4.5 -1t-4.5 -3t-5 -3.5 q-3 -2 -8.5 -3t-8.5 -2q15 5 -1 11q-10 4 -16 3q9 4 7.5 12t-8.5 14h5q-1 4 -8.5 8.5t-17.5 8.5t-13 6q-8 5 -34 9.5t-33 0.5q-5 -6 -4.5 -10.5t4 -14t3.5 -12.5q1 -6 -5.5 -13t-6.5 -12q0 -7 14 -15.5t10 -21.5q-3 -8 -16 -16t-16 -12q-5 -8 -1.5 -18.5t10.5 -16.5 q2 -2 1.5 -4t-3.5 -4.5t-5.5 -4t-6.5 -3.5l-3 -2q-11 -5 -20.5 6t-13.5 26q-7 25 -16 30q-23 8 -29 -1q-5 13 -41 26q-25 9 -58 4q6 1 0 15q-7 15 -19 12q3 6 4 17.5t1 13.5q3 13 12 23q1 1 7 8.5t9.5 13.5t0.5 6q35 -4 50 11q5 5 11.5 17t10.5 17q9 6 14 5.5t14.5 -5.5 t14.5 -5q14 -1 15.5 11t-7.5 20q12 -1 3 17q-5 7 -8 9q-12 4 -27 -5q-8 -4 2 -8q-1 1 -9.5 -10.5t-16.5 -17.5t-16 5q-1 1 -5.5 13.5t-9.5 13.5q-8 0 -16 -15q3 8 -11 15t-24 8q19 12 -8 27q-7 4 -20.5 5t-19.5 -4q-5 -7 -5.5 -11.5t5 -8t10.5 -5.5t11.5 -4t8.5 -3 q14 -10 8 -14q-2 -1 -8.5 -3.5t-11.5 -4.5t-6 -4q-3 -4 0 -14t-2 -14q-5 5 -9 17.5t-7 16.5q7 -9 -25 -6l-10 1q-4 0 -16 -2t-20.5 -1t-13.5 8q-4 8 0 20q1 4 4 2q-4 3 -11 9.5t-10 8.5q-46 -15 -94 -41q6 -1 12 1q5 2 13 6.5t10 5.5q34 14 42 7l5 5q14 -16 20 -25 q-7 4 -30 1q-20 -6 -22 -12q7 -12 5 -18q-4 3 -11.5 10t-14.5 11t-15 5q-16 0 -22 -1q-146 -80 -235 -222q7 -7 12 -8q4 -1 5 -9t2.5 -11t11.5 3q9 -8 3 -19q1 1 44 -27q19 -17 21 -21q3 -11 -10 -18q-1 2 -9 9t-9 4q-3 -5 0.5 -18.5t10.5 -12.5q-7 0 -9.5 -16t-2.5 -35.5 t-1 -23.5l2 -1q-3 -12 5.5 -34.5t21.5 -19.5q-13 -3 20 -43q6 -8 8 -9q3 -2 12 -7.5t15 -10t10 -10.5q4 -5 10 -22.5t14 -23.5q-2 -6 9.5 -20t10.5 -23q-1 0 -2.5 -1t-2.5 -1q3 -7 15.5 -14t15.5 -13q1 -3 2 -10t3 -11t8 -2q2 20 -24 62q-15 25 -17 29q-3 5 -5.5 15.5 t-4.5 14.5q2 0 6 -1.5t8.5 -3.5t7.5 -4t2 -3q-3 -7 2 -17.5t12 -18.5t17 -19t12 -13q6 -6 14 -19.5t0 -13.5q9 0 20 -10t17 -20q5 -8 8 -26t5 -24q2 -7 8.5 -13.5t12.5 -9.5l16 -8t13 -7q5 -2 18.5 -10.5t21.5 -11.5q10 -4 16 -4t14.5 2.5t13.5 3.5q15 2 29 -15t21 -21 q36 -19 55 -11q-2 -1 0.5 -7.5t8 -15.5t9 -14.5t5.5 -8.5q5 -6 18 -15t18 -15q6 4 7 9q-3 -8 7 -20t18 -10q14 3 14 32q-31 -15 -49 18q0 1 -2.5 5.5t-4 8.5t-2.5 8.5t0 7.5t5 3q9 0 10 3.5t-2 12.5t-4 13q-1 8 -11 20t-12 15q-5 -9 -16 -8t-16 9q0 -1 -1.5 -5.5t-1.5 -6.5 q-13 0 -15 1q1 3 2.5 17.5t3.5 22.5q1 4 5.5 12t7.5 14.5t4 12.5t-4.5 9.5t-17.5 2.5q-19 -1 -26 -20q-1 -3 -3 -10.5t-5 -11.5t-9 -7q-7 -3 -24 -2t-24 5q-13 8 -22.5 29t-9.5 37q0 10 2.5 26.5t3 25t-5.5 24.5q3 2 9 9.5t10 10.5q2 1 4.5 1.5t4.5 0t4 1.5t3 6q-1 1 -4 3 q-3 3 -4 3q7 -3 28.5 1.5t27.5 -1.5q15 -11 22 2q0 1 -2.5 9.5t-0.5 13.5q5 -27 29 -9q3 -3 15.5 -5t17.5 -5q3 -2 7 -5.5t5.5 -4.5t5 0.5t8.5 6.5q10 -14 12 -24q11 -40 19 -44q7 -3 11 -2t4.5 9.5t0 14t-1.5 12.5l-1 8v18l-1 8q-15 3 -18.5 12t1.5 18.5t15 18.5q1 1 8 3.5 t15.5 6.5t12.5 8q21 19 15 35q7 0 11 9q-1 0 -5 3t-7.5 5t-4.5 2q9 5 2 16q5 3 7.5 11t7.5 10q9 -12 21 -2q7 8 1 16q5 7 20.5 10.5t18.5 9.5q7 -2 8 2t1 12t3 12q4 5 15 9t13 5l17 11q3 4 0 4q18 -2 31 11q10 11 -6 20q3 6 -3 9.5t-15 5.5q3 1 11.5 0.5t10.5 1.5 q15 10 -7 16q-17 5 -43 -12zM879 10q206 36 351 189q-3 3 -12.5 4.5t-12.5 3.5q-18 7 -24 8q1 7 -2.5 13t-8 9t-12.5 8t-11 7q-2 2 -7 6t-7 5.5t-7.5 4.5t-8.5 2t-10 -1l-3 -1q-3 -1 -5.5 -2.5t-5.5 -3t-4 -3t0 -2.5q-21 17 -36 22q-5 1 -11 5.5t-10.5 7t-10 1.5t-11.5 -7 q-5 -5 -6 -15t-2 -13q-7 5 0 17.5t2 18.5q-3 6 -10.5 4.5t-12 -4.5t-11.5 -8.5t-9 -6.5t-8.5 -5.5t-8.5 -7.5q-3 -4 -6 -12t-5 -11q-2 4 -11.5 6.5t-9.5 5.5q2 -10 4 -35t5 -38q7 -31 -12 -48q-27 -25 -29 -40q-4 -22 12 -26q0 -7 -8 -20.5t-7 -21.5q0 -6 2 -16z" />
+<glyph unicode="&#xf0ad;" horiz-adv-x="1664" d="M384 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1028 484l-682 -682q-37 -37 -90 -37q-52 0 -91 37l-106 108q-38 36 -38 90q0 53 38 91l681 681q39 -98 114.5 -173.5t173.5 -114.5zM1662 919q0 -39 -23 -106q-47 -134 -164.5 -217.5 t-258.5 -83.5q-185 0 -316.5 131.5t-131.5 316.5t131.5 316.5t316.5 131.5q58 0 121.5 -16.5t107.5 -46.5q16 -11 16 -28t-16 -28l-293 -169v-224l193 -107q5 3 79 48.5t135.5 81t70.5 35.5q15 0 23.5 -10t8.5 -25z" />
+<glyph unicode="&#xf0ae;" horiz-adv-x="1792" d="M1024 128h640v128h-640v-128zM640 640h1024v128h-1024v-128zM1280 1152h384v128h-384v-128zM1792 320v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 832v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19 t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0b0;" horiz-adv-x="1408" d="M1403 1241q17 -41 -14 -70l-493 -493v-742q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-256 256q-19 19 -19 45v486l-493 493q-31 29 -14 70q17 39 59 39h1280q42 0 59 -39z" />
+<glyph unicode="&#xf0b1;" horiz-adv-x="1792" d="M640 1280h512v128h-512v-128zM1792 640v-480q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v480h672v-160q0 -26 19 -45t45 -19h320q26 0 45 19t19 45v160h672zM1024 640v-128h-256v128h256zM1792 1120v-384h-1792v384q0 66 47 113t113 47h352v160q0 40 28 68 t68 28h576q40 0 68 -28t28 -68v-160h352q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf0b2;" d="M1283 995l-355 -355l355 -355l144 144q29 31 70 14q39 -17 39 -59v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l144 144l-355 355l-355 -355l144 -144q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l144 -144 l355 355l-355 355l-144 -144q-19 -19 -45 -19q-12 0 -24 5q-40 17 -40 59v448q0 26 19 45t45 19h448q42 0 59 -40q17 -39 -14 -69l-144 -144l355 -355l355 355l-144 144q-31 30 -14 69q17 40 59 40h448q26 0 45 -19t19 -45v-448q0 -42 -39 -59q-13 -5 -25 -5q-26 0 -45 19z " />
+<glyph unicode="&#xf0c0;" horiz-adv-x="1920" d="M593 640q-162 -5 -265 -128h-134q-82 0 -138 40.5t-56 118.5q0 353 124 353q6 0 43.5 -21t97.5 -42.5t119 -21.5q67 0 133 23q-5 -37 -5 -66q0 -139 81 -256zM1664 3q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5 t43 97.5t62 81t85.5 53.5t111.5 20q10 0 43 -21.5t73 -48t107 -48t135 -21.5t135 21.5t107 48t73 48t43 21.5q61 0 111.5 -20t85.5 -53.5t62 -81t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM640 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75 t75 -181zM1344 896q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5zM1920 671q0 -78 -56 -118.5t-138 -40.5h-134q-103 123 -265 128q81 117 81 256q0 29 -5 66q66 -23 133 -23q59 0 119 21.5t97.5 42.5 t43.5 21q124 0 124 -353zM1792 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181z" />
+<glyph unicode="&#xf0c1;" horiz-adv-x="1664" d="M1456 320q0 40 -28 68l-208 208q-28 28 -68 28q-42 0 -72 -32q3 -3 19 -18.5t21.5 -21.5t15 -19t13 -25.5t3.5 -27.5q0 -40 -28 -68t-68 -28q-15 0 -27.5 3.5t-25.5 13t-19 15t-21.5 21.5t-18.5 19q-33 -31 -33 -73q0 -40 28 -68l206 -207q27 -27 68 -27q40 0 68 26 l147 146q28 28 28 67zM753 1025q0 40 -28 68l-206 207q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l208 -208q27 -27 68 -27q42 0 72 31q-3 3 -19 18.5t-21.5 21.5t-15 19t-13 25.5t-3.5 27.5q0 40 28 68t68 28q15 0 27.5 -3.5t25.5 -13t19 -15 t21.5 -21.5t18.5 -19q33 31 33 73zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-206 207q-83 83 -83 203q0 123 88 209l-88 88q-86 -88 -208 -88q-120 0 -204 84l-208 208q-84 84 -84 204t85 203l147 146q83 83 203 83q121 0 204 -85l206 -207 q83 -83 83 -203q0 -123 -88 -209l88 -88q86 88 208 88q120 0 204 -84l208 -208q84 -84 84 -204z" />
+<glyph unicode="&#xf0c2;" horiz-adv-x="1920" d="M1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088q-185 0 -316.5 131.5t-131.5 316.5q0 132 71 241.5t187 163.5q-2 28 -2 43q0 212 150 362t362 150q158 0 286.5 -88t187.5 -230q70 62 166 62q106 0 181 -75t75 -181q0 -75 -41 -138q129 -30 213 -134.5t84 -239.5z " />
+<glyph unicode="&#xf0c3;" horiz-adv-x="1664" d="M1527 88q56 -89 21.5 -152.5t-140.5 -63.5h-1152q-106 0 -140.5 63.5t21.5 152.5l503 793v399h-64q-26 0 -45 19t-19 45t19 45t45 19h512q26 0 45 -19t19 -45t-19 -45t-45 -19h-64v-399zM748 813l-272 -429h712l-272 429l-20 31v37v399h-128v-399v-37z" />
+<glyph unicode="&#xf0c4;" horiz-adv-x="1792" d="M960 640q26 0 45 -19t19 -45t-19 -45t-45 -19t-45 19t-19 45t19 45t45 19zM1260 576l507 -398q28 -20 25 -56q-5 -35 -35 -51l-128 -64q-13 -7 -29 -7q-17 0 -31 8l-690 387l-110 -66q-8 -4 -12 -5q14 -49 10 -97q-7 -77 -56 -147.5t-132 -123.5q-132 -84 -277 -84 q-136 0 -222 78q-90 84 -79 207q7 76 56 147t131 124q132 84 278 84q83 0 151 -31q9 13 22 22l122 73l-122 73q-13 9 -22 22q-68 -31 -151 -31q-146 0 -278 84q-82 53 -131 124t-56 147q-5 59 15.5 113t63.5 93q85 79 222 79q145 0 277 -84q83 -52 132 -123t56 -148 q4 -48 -10 -97q4 -1 12 -5l110 -66l690 387q14 8 31 8q16 0 29 -7l128 -64q30 -16 35 -51q3 -36 -25 -56zM579 836q46 42 21 108t-106 117q-92 59 -192 59q-74 0 -113 -36q-46 -42 -21 -108t106 -117q92 -59 192 -59q74 0 113 36zM494 91q81 51 106 117t-21 108 q-39 36 -113 36q-100 0 -192 -59q-81 -51 -106 -117t21 -108q39 -36 113 -36q100 0 192 59zM672 704l96 -58v11q0 36 33 56l14 8l-79 47l-26 -26q-3 -3 -10 -11t-12 -12q-2 -2 -4 -3.5t-3 -2.5zM896 480l96 -32l736 576l-128 64l-768 -431v-113l-160 -96l9 -8q2 -2 7 -6 q4 -4 11 -12t11 -12l26 -26zM1600 64l128 64l-520 408l-177 -138q-2 -3 -13 -7z" />
+<glyph unicode="&#xf0c5;" horiz-adv-x="1792" d="M1696 1152q40 0 68 -28t28 -68v-1216q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v288h-544q-40 0 -68 28t-28 68v672q0 40 20 88t48 76l408 408q28 28 76 48t88 20h416q40 0 68 -28t28 -68v-328q68 40 128 40h416zM1152 939l-299 -299h299v299zM512 1323l-299 -299 h299v299zM708 676l316 316v416h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h512v256q0 40 20 88t48 76zM1664 -128v1152h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h896z" />
+<glyph unicode="&#xf0c6;" horiz-adv-x="1408" d="M1404 151q0 -117 -79 -196t-196 -79q-135 0 -235 100l-777 776q-113 115 -113 271q0 159 110 270t269 111q158 0 273 -113l605 -606q10 -10 10 -22q0 -16 -30.5 -46.5t-46.5 -30.5q-13 0 -23 10l-606 607q-79 77 -181 77q-106 0 -179 -75t-73 -181q0 -105 76 -181 l776 -777q63 -63 145 -63q64 0 106 42t42 106q0 82 -63 145l-581 581q-26 24 -60 24q-29 0 -48 -19t-19 -48q0 -32 25 -59l410 -410q10 -10 10 -22q0 -16 -31 -47t-47 -31q-12 0 -22 10l-410 410q-63 61 -63 149q0 82 57 139t139 57q88 0 149 -63l581 -581q100 -98 100 -235 z" />
+<glyph unicode="&#xf0c7;" d="M384 0h768v384h-768v-384zM1280 0h128v896q0 14 -10 38.5t-20 34.5l-281 281q-10 10 -34 20t-39 10v-416q0 -40 -28 -68t-68 -28h-576q-40 0 -68 28t-28 68v416h-128v-1280h128v416q0 40 28 68t68 28h832q40 0 68 -28t28 -68v-416zM896 928v320q0 13 -9.5 22.5t-22.5 9.5 h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5zM1536 896v-928q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h928q40 0 88 -20t76 -48l280 -280q28 -28 48 -76t20 -88z" />
+<glyph unicode="&#xf0c8;" d="M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf0c9;" d="M1536 192v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 704v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 1216v-128q0 -26 -19 -45 t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0ca;" horiz-adv-x="1792" d="M384 128q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM384 640q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1152q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z M1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" />
+<glyph unicode="&#xf0cb;" horiz-adv-x="1792" d="M381 -84q0 -80 -54.5 -126t-135.5 -46q-106 0 -172 66l57 88q49 -45 106 -45q29 0 50.5 14.5t21.5 42.5q0 64 -105 56l-26 56q8 10 32.5 43.5t42.5 54t37 38.5v1q-16 0 -48.5 -1t-48.5 -1v-53h-106v152h333v-88l-95 -115q51 -12 81 -49t30 -88zM383 543v-159h-362 q-6 36 -6 54q0 51 23.5 93t56.5 68t66 47.5t56.5 43.5t23.5 45q0 25 -14.5 38.5t-39.5 13.5q-46 0 -81 -58l-85 59q24 51 71.5 79.5t105.5 28.5q73 0 123 -41.5t50 -112.5q0 -50 -34 -91.5t-75 -64.5t-75.5 -50.5t-35.5 -52.5h127v60h105zM1792 224v-192q0 -13 -9.5 -22.5 t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1123v-99h-335v99h107q0 41 0.5 122t0.5 121v12h-2q-8 -17 -50 -54l-71 76l136 127h106v-404h108zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5 t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" />
+<glyph unicode="&#xf0cc;" horiz-adv-x="1792" d="M1760 640q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-1728q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h1728zM483 704q-28 35 -51 80q-48 97 -48 188q0 181 134 309q133 127 393 127q50 0 167 -19q66 -12 177 -48q10 -38 21 -118q14 -123 14 -183q0 -18 -5 -45l-12 -3l-84 6 l-14 2q-50 149 -103 205q-88 91 -210 91q-114 0 -182 -59q-67 -58 -67 -146q0 -73 66 -140t279 -129q69 -20 173 -66q58 -28 95 -52h-743zM990 448h411q7 -39 7 -92q0 -111 -41 -212q-23 -55 -71 -104q-37 -35 -109 -81q-80 -48 -153 -66q-80 -21 -203 -21q-114 0 -195 23 l-140 40q-57 16 -72 28q-8 8 -8 22v13q0 108 -2 156q-1 30 0 68l2 37v44l102 2q15 -34 30 -71t22.5 -56t12.5 -27q35 -57 80 -94q43 -36 105 -57q59 -22 132 -22q64 0 139 27q77 26 122 86q47 61 47 129q0 84 -81 157q-34 29 -137 71z" />
+<glyph unicode="&#xf0cd;" d="M48 1313q-37 2 -45 4l-3 88q13 1 40 1q60 0 112 -4q132 -7 166 -7q86 0 168 3q116 4 146 5q56 0 86 2l-1 -14l2 -64v-9q-60 -9 -124 -9q-60 0 -79 -25q-13 -14 -13 -132q0 -13 0.5 -32.5t0.5 -25.5l1 -229l14 -280q6 -124 51 -202q35 -59 96 -92q88 -47 177 -47 q104 0 191 28q56 18 99 51q48 36 65 64q36 56 53 114q21 73 21 229q0 79 -3.5 128t-11 122.5t-13.5 159.5l-4 59q-5 67 -24 88q-34 35 -77 34l-100 -2l-14 3l2 86h84l205 -10q76 -3 196 10l18 -2q6 -38 6 -51q0 -7 -4 -31q-45 -12 -84 -13q-73 -11 -79 -17q-15 -15 -15 -41 q0 -7 1.5 -27t1.5 -31q8 -19 22 -396q6 -195 -15 -304q-15 -76 -41 -122q-38 -65 -112 -123q-75 -57 -182 -89q-109 -33 -255 -33q-167 0 -284 46q-119 47 -179 122q-61 76 -83 195q-16 80 -16 237v333q0 188 -17 213q-25 36 -147 39zM1536 -96v64q0 14 -9 23t-23 9h-1472 q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h1472q14 0 23 9t9 23z" />
+<glyph unicode="&#xf0ce;" horiz-adv-x="1664" d="M512 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23 v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 160v192 q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192 q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1664 1248v-1088q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1344q66 0 113 -47t47 -113 z" />
+<glyph unicode="&#xf0d0;" horiz-adv-x="1664" d="M1190 955l293 293l-107 107l-293 -293zM1637 1248q0 -27 -18 -45l-1286 -1286q-18 -18 -45 -18t-45 18l-198 198q-18 18 -18 45t18 45l1286 1286q18 18 45 18t45 -18l198 -198q18 -18 18 -45zM286 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM636 1276 l196 -60l-196 -60l-60 -196l-60 196l-196 60l196 60l60 196zM1566 798l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM926 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98z" />
+<glyph unicode="&#xf0d1;" horiz-adv-x="1792" d="M640 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM256 640h384v256h-158q-13 0 -22 -9l-195 -195q-9 -9 -9 -22v-30zM1536 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM1792 1216v-1024q0 -15 -4 -26.5t-13.5 -18.5 t-16.5 -11.5t-23.5 -6t-22.5 -2t-25.5 0t-22.5 0.5q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-64q-3 0 -22.5 -0.5t-25.5 0t-22.5 2t-23.5 6t-16.5 11.5t-13.5 18.5t-4 26.5q0 26 19 45t45 19v320q0 8 -0.5 35t0 38 t2.5 34.5t6.5 37t14 30.5t22.5 30l198 198q19 19 50.5 32t58.5 13h160v192q0 26 19 45t45 19h1024q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0d2;" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103q-111 0 -218 32q59 93 78 164q9 34 54 211q20 -39 73 -67.5t114 -28.5q121 0 216 68.5t147 188.5t52 270q0 114 -59.5 214t-172.5 163t-255 63q-105 0 -196 -29t-154.5 -77t-109 -110.5t-67 -129.5t-21.5 -134 q0 -104 40 -183t117 -111q30 -12 38 20q2 7 8 31t8 30q6 23 -11 43q-51 61 -51 151q0 151 104.5 259.5t273.5 108.5q151 0 235.5 -82t84.5 -213q0 -170 -68.5 -289t-175.5 -119q-61 0 -98 43.5t-23 104.5q8 35 26.5 93.5t30 103t11.5 75.5q0 50 -27 83t-77 33 q-62 0 -105 -57t-43 -142q0 -73 25 -122l-99 -418q-17 -70 -13 -177q-206 91 -333 281t-127 423q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf0d3;" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-725q85 122 108 210q9 34 53 209q21 -39 73.5 -67t112.5 -28q181 0 295.5 147.5t114.5 373.5q0 84 -35 162.5t-96.5 139t-152.5 97t-197 36.5q-104 0 -194.5 -28.5t-153 -76.5 t-107.5 -109.5t-66.5 -128t-21.5 -132.5q0 -102 39.5 -180t116.5 -110q13 -5 23.5 0t14.5 19q10 44 15 61q6 23 -11 42q-50 62 -50 150q0 150 103.5 256.5t270.5 106.5q149 0 232.5 -81t83.5 -210q0 -168 -67.5 -286t-173.5 -118q-60 0 -97 43.5t-23 103.5q8 34 26.5 92.5 t29.5 102t11 74.5q0 49 -26.5 81.5t-75.5 32.5q-61 0 -103.5 -56.5t-42.5 -139.5q0 -72 24 -121l-98 -414q-24 -100 -7 -254h-183q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960z" />
+<glyph unicode="&#xf0d4;" d="M678 -57q0 -38 -10 -71h-380q-95 0 -171.5 56.5t-103.5 147.5q24 45 69 77.5t100 49.5t107 24t107 7q32 0 49 -2q6 -4 30.5 -21t33 -23t31 -23t32 -25.5t27.5 -25.5t26.5 -29.5t21 -30.5t17.5 -34.5t9.5 -36t4.5 -40.5zM385 294q-234 -7 -385 -85v433q103 -118 273 -118 q32 0 70 5q-21 -61 -21 -86q0 -67 63 -149zM558 805q0 -100 -43.5 -160.5t-140.5 -60.5q-51 0 -97 26t-78 67.5t-56 93.5t-35.5 104t-11.5 99q0 96 51.5 165t144.5 69q66 0 119 -41t84 -104t47 -130t16 -128zM1536 896v-736q0 -119 -84.5 -203.5t-203.5 -84.5h-468 q39 73 39 157q0 66 -22 122.5t-55.5 93t-72 71t-72 59.5t-55.5 54.5t-22 59.5q0 36 23 68t56 61.5t65.5 64.5t55.5 93t23 131t-26.5 145.5t-75.5 118.5q-6 6 -14 11t-12.5 7.5t-10 9.5t-10.5 17h135l135 64h-437q-138 0 -244.5 -38.5t-182.5 -133.5q0 126 81 213t207 87h960 q119 0 203.5 -84.5t84.5 -203.5v-96h-256v256h-128v-256h-256v-128h256v-256h128v256h256z" />
+<glyph unicode="&#xf0d5;" horiz-adv-x="1664" d="M876 71q0 21 -4.5 40.5t-9.5 36t-17.5 34.5t-21 30.5t-26.5 29.5t-27.5 25.5t-32 25.5t-31 23t-33 23t-30.5 21q-17 2 -50 2q-54 0 -106 -7t-108 -25t-98 -46t-69 -75t-27 -107q0 -68 35.5 -121.5t93 -84t120.5 -45.5t127 -15q59 0 112.5 12.5t100.5 39t74.5 73.5 t27.5 110zM756 933q0 60 -16.5 127.5t-47 130.5t-84 104t-119.5 41q-93 0 -144 -69t-51 -165q0 -47 11.5 -99t35.5 -104t56 -93.5t78 -67.5t97 -26q97 0 140.5 60.5t43.5 160.5zM625 1408h437l-135 -79h-135q71 -45 110 -126t39 -169q0 -74 -23 -131.5t-56 -92.5t-66 -64.5 t-56 -61t-23 -67.5q0 -26 16.5 -51t43 -48t58.5 -48t64 -55.5t58.5 -66t43 -85t16.5 -106.5q0 -160 -140 -282q-152 -131 -420 -131q-59 0 -119.5 10t-122 33.5t-108.5 58t-77 89t-30 121.5q0 61 37 135q32 64 96 110.5t145 71t155 36t150 13.5q-64 83 -64 149q0 12 2 23.5 t5 19.5t8 21.5t7 21.5q-40 -5 -70 -5q-149 0 -255.5 98t-106.5 246q0 140 95 250.5t234 141.5q94 20 187 20zM1664 1152v-128h-256v-256h-128v256h-256v128h256v256h128v-256h256z" />
+<glyph unicode="&#xf0d6;" horiz-adv-x="1920" d="M768 384h384v96h-128v448h-114l-148 -137l77 -80q42 37 55 57h2v-288h-128v-96zM1280 640q0 -70 -21 -142t-59.5 -134t-101.5 -101t-138 -39t-138 39t-101.5 101t-59.5 134t-21 142t21 142t59.5 134t101.5 101t138 39t138 -39t101.5 -101t59.5 -134t21 -142zM1792 384 v512q-106 0 -181 75t-75 181h-1152q0 -106 -75 -181t-181 -75v-512q106 0 181 -75t75 -181h1152q0 106 75 181t181 75zM1920 1216v-1152q0 -26 -19 -45t-45 -19h-1792q-26 0 -45 19t-19 45v1152q0 26 19 45t45 19h1792q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0d7;" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0d8;" horiz-adv-x="1024" d="M1024 320q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
+<glyph unicode="&#xf0d9;" horiz-adv-x="640" d="M640 1088v-896q0 -26 -19 -45t-45 -19t-45 19l-448 448q-19 19 -19 45t19 45l448 448q19 19 45 19t45 -19t19 -45z" />
+<glyph unicode="&#xf0da;" horiz-adv-x="640" d="M576 640q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19t-19 45v896q0 26 19 45t45 19t45 -19l448 -448q19 -19 19 -45z" />
+<glyph unicode="&#xf0db;" horiz-adv-x="1664" d="M160 0h608v1152h-640v-1120q0 -13 9.5 -22.5t22.5 -9.5zM1536 32v1120h-640v-1152h608q13 0 22.5 9.5t9.5 22.5zM1664 1248v-1216q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1344q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf0dc;" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45zM1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
+<glyph unicode="&#xf0dd;" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0de;" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" />
+<glyph unicode="&#xf0e0;" horiz-adv-x="1792" d="M1792 826v-794q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v794q44 -49 101 -87q362 -246 497 -345q57 -42 92.5 -65.5t94.5 -48t110 -24.5h1h1q51 0 110 24.5t94.5 48t92.5 65.5q170 123 498 345q57 39 100 87zM1792 1120q0 -79 -49 -151t-122 -123 q-376 -261 -468 -325q-10 -7 -42.5 -30.5t-54 -38t-52 -32.5t-57.5 -27t-50 -9h-1h-1q-23 0 -50 9t-57.5 27t-52 32.5t-54 38t-42.5 30.5q-91 64 -262 182.5t-205 142.5q-62 42 -117 115.5t-55 136.5q0 78 41.5 130t118.5 52h1472q65 0 112.5 -47t47.5 -113z" />
+<glyph unicode="&#xf0e1;" d="M349 911v-991h-330v991h330zM370 1217q1 -73 -50.5 -122t-135.5 -49h-2q-82 0 -132 49t-50 122q0 74 51.5 122.5t134.5 48.5t133 -48.5t51 -122.5zM1536 488v-568h-329v530q0 105 -40.5 164.5t-126.5 59.5q-63 0 -105.5 -34.5t-63.5 -85.5q-11 -30 -11 -81v-553h-329 q2 399 2 647t-1 296l-1 48h329v-144h-2q20 32 41 56t56.5 52t87 43.5t114.5 15.5q171 0 275 -113.5t104 -332.5z" />
+<glyph unicode="&#xf0e2;" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61q-172 0 -327 72.5t-264 204.5q-7 10 -6.5 22.5t8.5 20.5l137 138q10 9 25 9q16 -2 23 -12q73 -95 179 -147t225 -52q104 0 198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5t-40.5 198.5t-109.5 163.5 t-163.5 109.5t-198.5 40.5q-98 0 -188 -35.5t-160 -101.5l137 -138q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l130 -129q107 101 244.5 156.5t284.5 55.5q156 0 298 -61t245 -164t164 -245t61 -298z" />
+<glyph unicode="&#xf0e3;" horiz-adv-x="1792" d="M1771 0q0 -53 -37 -90l-107 -108q-39 -37 -91 -37q-53 0 -90 37l-363 364q-38 36 -38 90q0 53 43 96l-256 256l-126 -126q-14 -14 -34 -14t-34 14q2 -2 12.5 -12t12.5 -13t10 -11.5t10 -13.5t6 -13.5t5.5 -16.5t1.5 -18q0 -38 -28 -68q-3 -3 -16.5 -18t-19 -20.5 t-18.5 -16.5t-22 -15.5t-22 -9t-26 -4.5q-40 0 -68 28l-408 408q-28 28 -28 68q0 13 4.5 26t9 22t15.5 22t16.5 18.5t20.5 19t18 16.5q30 28 68 28q10 0 18 -1.5t16.5 -5.5t13.5 -6t13.5 -10t11.5 -10t13 -12.5t12 -12.5q-14 14 -14 34t14 34l348 348q14 14 34 14t34 -14 q-2 2 -12.5 12t-12.5 13t-10 11.5t-10 13.5t-6 13.5t-5.5 16.5t-1.5 18q0 38 28 68q3 3 16.5 18t19 20.5t18.5 16.5t22 15.5t22 9t26 4.5q40 0 68 -28l408 -408q28 -28 28 -68q0 -13 -4.5 -26t-9 -22t-15.5 -22t-16.5 -18.5t-20.5 -19t-18 -16.5q-30 -28 -68 -28 q-10 0 -18 1.5t-16.5 5.5t-13.5 6t-13.5 10t-11.5 10t-13 12.5t-12 12.5q14 -14 14 -34t-14 -34l-126 -126l256 -256q43 43 96 43q52 0 91 -37l363 -363q37 -39 37 -91z" />
+<glyph unicode="&#xf0e4;" horiz-adv-x="1792" d="M384 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM576 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1004 351l101 382q6 26 -7.5 48.5t-38.5 29.5 t-48 -6.5t-30 -39.5l-101 -382q-60 -5 -107 -43.5t-63 -98.5q-20 -77 20 -146t117 -89t146 20t89 117q16 60 -6 117t-72 91zM1664 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 1024q0 53 -37.5 90.5 t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1472 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1792 384q0 -261 -141 -483q-19 -29 -54 -29h-1402q-35 0 -54 29 q-141 221 -141 483q0 182 71 348t191 286t286 191t348 71t348 -71t286 -191t191 -286t71 -348z" />
+<glyph unicode="&#xf0e5;" horiz-adv-x="1792" d="M896 1152q-204 0 -381.5 -69.5t-282 -187.5t-104.5 -255q0 -112 71.5 -213.5t201.5 -175.5l87 -50l-27 -96q-24 -91 -70 -172q152 63 275 171l43 38l57 -6q69 -8 130 -8q204 0 381.5 69.5t282 187.5t104.5 255t-104.5 255t-282 187.5t-381.5 69.5zM1792 640 q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22h-5q-15 0 -27 10.5t-16 27.5v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281q0 174 120 321.5 t326 233t450 85.5t450 -85.5t326 -233t120 -321.5z" />
+<glyph unicode="&#xf0e6;" horiz-adv-x="1792" d="M704 1152q-153 0 -286 -52t-211.5 -141t-78.5 -191q0 -82 53 -158t149 -132l97 -56l-35 -84q34 20 62 39l44 31l53 -10q78 -14 153 -14q153 0 286 52t211.5 141t78.5 191t-78.5 191t-211.5 141t-286 52zM704 1280q191 0 353.5 -68.5t256.5 -186.5t94 -257t-94 -257 t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224q0 139 94 257t256.5 186.5 t353.5 68.5zM1526 111q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129 q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230q0 -120 -71 -224.5t-195 -176.5z" />
+<glyph unicode="&#xf0e7;" horiz-adv-x="896" d="M885 970q18 -20 7 -44l-540 -1157q-13 -25 -42 -25q-4 0 -14 2q-17 5 -25.5 19t-4.5 30l197 808l-406 -101q-4 -1 -12 -1q-18 0 -31 11q-18 15 -13 39l201 825q4 14 16 23t28 9h328q19 0 32 -12.5t13 -29.5q0 -8 -5 -18l-171 -463l396 98q8 2 12 2q19 0 34 -15z" />
+<glyph unicode="&#xf0e8;" horiz-adv-x="1792" d="M1792 288v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192q0 52 38 90t90 38h512v192h-96q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h320q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-96v-192h512q52 0 90 -38t38 -90v-192h96q40 0 68 -28t28 -68 z" />
+<glyph unicode="&#xf0e9;" horiz-adv-x="1664" d="M896 708v-580q0 -104 -76 -180t-180 -76t-180 76t-76 180q0 26 19 45t45 19t45 -19t19 -45q0 -50 39 -89t89 -39t89 39t39 89v580q33 11 64 11t64 -11zM1664 681q0 -13 -9.5 -22.5t-22.5 -9.5q-11 0 -23 10q-49 46 -93 69t-102 23q-68 0 -128 -37t-103 -97 q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -28 -17q-18 0 -29 17q-4 6 -14.5 24t-17.5 28q-43 60 -102.5 97t-127.5 37t-127.5 -37t-102.5 -97q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -29 -17q-17 0 -28 17q-4 6 -14.5 24t-17.5 28q-43 60 -103 97t-128 37q-58 0 -102 -23t-93 -69 q-12 -10 -23 -10q-13 0 -22.5 9.5t-9.5 22.5q0 5 1 7q45 183 172.5 319.5t298 204.5t360.5 68q140 0 274.5 -40t246.5 -113.5t194.5 -187t115.5 -251.5q1 -2 1 -7zM896 1408v-98q-42 2 -64 2t-64 -2v98q0 26 19 45t45 19t45 -19t19 -45z" />
+<glyph unicode="&#xf0ea;" horiz-adv-x="1792" d="M768 -128h896v640h-416q-40 0 -68 28t-28 68v416h-384v-1152zM1024 1312v64q0 13 -9.5 22.5t-22.5 9.5h-704q-13 0 -22.5 -9.5t-9.5 -22.5v-64q0 -13 9.5 -22.5t22.5 -9.5h704q13 0 22.5 9.5t9.5 22.5zM1280 640h299l-299 299v-299zM1792 512v-672q0 -40 -28 -68t-68 -28 h-960q-40 0 -68 28t-28 68v160h-544q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h1088q40 0 68 -28t28 -68v-328q21 -13 36 -28l408 -408q28 -28 48 -76t20 -88z" />
+<glyph unicode="&#xf0eb;" horiz-adv-x="1024" d="M736 960q0 -13 -9.5 -22.5t-22.5 -9.5t-22.5 9.5t-9.5 22.5q0 46 -54 71t-106 25q-13 0 -22.5 9.5t-9.5 22.5t9.5 22.5t22.5 9.5q50 0 99.5 -16t87 -54t37.5 -90zM896 960q0 72 -34.5 134t-90 101.5t-123 62t-136.5 22.5t-136.5 -22.5t-123 -62t-90 -101.5t-34.5 -134 q0 -101 68 -180q10 -11 30.5 -33t30.5 -33q128 -153 141 -298h228q13 145 141 298q10 11 30.5 33t30.5 33q68 79 68 180zM1024 960q0 -155 -103 -268q-45 -49 -74.5 -87t-59.5 -95.5t-34 -107.5q47 -28 47 -82q0 -37 -25 -64q25 -27 25 -64q0 -52 -45 -81q13 -23 13 -47 q0 -46 -31.5 -71t-77.5 -25q-20 -44 -60 -70t-87 -26t-87 26t-60 70q-46 0 -77.5 25t-31.5 71q0 24 13 47q-45 29 -45 81q0 37 25 64q-25 27 -25 64q0 54 47 82q-4 50 -34 107.5t-59.5 95.5t-74.5 87q-103 113 -103 268q0 99 44.5 184.5t117 142t164 89t186.5 32.5 t186.5 -32.5t164 -89t117 -142t44.5 -184.5z" />
+<glyph unicode="&#xf0ec;" horiz-adv-x="1792" d="M1792 352v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5q-12 0 -24 10l-319 320q-9 9 -9 22q0 14 9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h1376q13 0 22.5 -9.5t9.5 -22.5zM1792 896q0 -14 -9 -23l-320 -320q-9 -9 -23 -9 q-13 0 -22.5 9.5t-9.5 22.5v192h-1376q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1376v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" />
+<glyph unicode="&#xf0ed;" horiz-adv-x="1920" d="M1280 608q0 14 -9 23t-23 9h-224v352q0 13 -9.5 22.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-352h-224q-13 0 -22.5 -9.5t-9.5 -22.5q0 -14 9 -23l352 -352q9 -9 23 -9t23 9l351 351q10 12 10 24zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" />
+<glyph unicode="&#xf0ee;" horiz-adv-x="1920" d="M1280 672q0 14 -9 23l-352 352q-9 9 -23 9t-23 -9l-351 -351q-10 -12 -10 -24q0 -14 9 -23t23 -9h224v-352q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5v352h224q13 0 22.5 9.5t9.5 22.5zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" />
+<glyph unicode="&#xf0f0;" horiz-adv-x="1408" d="M384 192q0 -26 -19 -45t-45 -19t-45 19t-19 45t19 45t45 19t45 -19t19 -45zM1408 131q0 -121 -73 -190t-194 -69h-874q-121 0 -194 69t-73 190q0 68 5.5 131t24 138t47.5 132.5t81 103t120 60.5q-22 -52 -22 -120v-203q-58 -20 -93 -70t-35 -111q0 -80 56 -136t136 -56 t136 56t56 136q0 61 -35.5 111t-92.5 70v203q0 62 25 93q132 -104 295 -104t295 104q25 -31 25 -93v-64q-106 0 -181 -75t-75 -181v-89q-32 -29 -32 -71q0 -40 28 -68t68 -28t68 28t28 68q0 42 -32 71v89q0 52 38 90t90 38t90 -38t38 -90v-89q-32 -29 -32 -71q0 -40 28 -68 t68 -28t68 28t28 68q0 42 -32 71v89q0 68 -34.5 127.5t-93.5 93.5q0 10 0.5 42.5t0 48t-2.5 41.5t-7 47t-13 40q68 -15 120 -60.5t81 -103t47.5 -132.5t24 -138t5.5 -131zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5 t271.5 -112.5t112.5 -271.5z" />
+<glyph unicode="&#xf0f1;" horiz-adv-x="1408" d="M1280 832q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 832q0 -62 -35.5 -111t-92.5 -70v-395q0 -159 -131.5 -271.5t-316.5 -112.5t-316.5 112.5t-131.5 271.5v132q-164 20 -274 128t-110 252v512q0 26 19 45t45 19q6 0 16 -2q17 30 47 48 t65 18q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5q-33 0 -64 18v-402q0 -106 94 -181t226 -75t226 75t94 181v402q-31 -18 -64 -18q-53 0 -90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5q35 0 65 -18t47 -48q10 2 16 2q26 0 45 -19t19 -45v-512q0 -144 -110 -252 t-274 -128v-132q0 -106 94 -181t226 -75t226 75t94 181v395q-57 21 -92.5 70t-35.5 111q0 80 56 136t136 56t136 -56t56 -136z" />
+<glyph unicode="&#xf0f2;" horiz-adv-x="1792" d="M640 1152h512v128h-512v-128zM288 1152v-1280h-64q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h64zM1408 1152v-1280h-1024v1280h128v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h128zM1792 928v-832q0 -92 -66 -158t-158 -66h-64v1280h64q92 0 158 -66 t66 -158z" />
+<glyph unicode="&#xf0f3;" horiz-adv-x="1664" d="M848 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM1664 128q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q190 161 287 397.5t97 498.5 q0 165 96 262t264 117q-8 18 -8 37q0 40 28 68t68 28t68 -28t28 -68q0 -19 -8 -37q168 -20 264 -117t96 -262q0 -262 97 -498.5t287 -397.5z" />
+<glyph unicode="&#xf0f4;" horiz-adv-x="1920" d="M1664 896q0 80 -56 136t-136 56h-64v-384h64q80 0 136 56t56 136zM0 128h1792q0 -106 -75 -181t-181 -75h-1280q-106 0 -181 75t-75 181zM1856 896q0 -159 -112.5 -271.5t-271.5 -112.5h-64v-32q0 -92 -66 -158t-158 -66h-704q-92 0 -158 66t-66 158v736q0 26 19 45 t45 19h1152q159 0 271.5 -112.5t112.5 -271.5z" />
+<glyph unicode="&#xf0f5;" horiz-adv-x="1408" d="M640 1472v-640q0 -61 -35.5 -111t-92.5 -70v-779q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v779q-57 20 -92.5 70t-35.5 111v640q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45 t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45zM1408 1472v-1600q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v512h-224q-13 0 -22.5 9.5t-9.5 22.5v800q0 132 94 226t226 94h256q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0f6;" horiz-adv-x="1280" d="M1024 352v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704q14 0 23 -9t9 -23zM1024 608v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704q14 0 23 -9t9 -23zM128 0h1024v768h-416q-40 0 -68 28t-28 68v416h-512v-1280z M768 896h376q-10 29 -22 41l-313 313q-12 12 -41 22v-376zM1280 864v-896q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h640q40 0 88 -20t76 -48l312 -312q28 -28 48 -76t20 -88z" />
+<glyph unicode="&#xf0f7;" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1536h-1152v-1536h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM1408 1472v-1664q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1664q0 26 19 45t45 19h1280q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0f8;" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1152h-256v-32q0 -40 -28 -68t-68 -28h-448q-40 0 -68 28t-28 68v32h-256v-1152h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM896 1056v320q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-96h-128v96q0 13 -9.5 22.5 t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5v96h128v-96q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1408 1088v-1280q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1280q0 26 19 45t45 19h320 v288q0 40 28 68t68 28h448q40 0 68 -28t28 -68v-288h320q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0f9;" horiz-adv-x="1920" d="M640 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM256 640h384v256h-158q-14 -2 -22 -9l-195 -195q-7 -12 -9 -22v-30zM1536 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1664 800v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM1920 1344v-1152 q0 -26 -19 -45t-45 -19h-192q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-128q-26 0 -45 19t-19 45t19 45t45 19v416q0 26 13 58t32 51l198 198q19 19 51 32t58 13h160v320q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf0fa;" horiz-adv-x="1792" d="M1280 416v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM640 1152h512v128h-512v-128zM256 1152v-1280h-32 q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h32zM1440 1152v-1280h-1088v1280h160v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h160zM1792 928v-832q0 -92 -66 -158t-158 -66h-32v1280h32q92 0 158 -66t66 -158z" />
+<glyph unicode="&#xf0fb;" horiz-adv-x="1920" d="M1920 576q-1 -32 -288 -96l-352 -32l-224 -64h-64l-293 -352h69q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-96h-160h-64v32h64v416h-160l-192 -224h-96l-32 32v192h32v32h128v8l-192 24v128l192 24v8h-128v32h-32v192l32 32h96l192 -224h160v416h-64v32h64h160h96 q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-69l293 -352h64l224 -64l352 -32q261 -58 287 -93z" />
+<glyph unicode="&#xf0fc;" horiz-adv-x="1664" d="M640 640v384h-256v-256q0 -53 37.5 -90.5t90.5 -37.5h128zM1664 192v-192h-1152v192l128 192h-128q-159 0 -271.5 112.5t-112.5 271.5v320l-64 64l32 128h480l32 128h960l32 -192l-64 -32v-800z" />
+<glyph unicode="&#xf0fd;" d="M1280 192v896q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-512v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-896q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h512v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf0fe;" d="M1280 576v128q0 26 -19 45t-45 19h-320v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-320q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h320v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h320q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf100;" horiz-adv-x="1024" d="M627 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23zM1011 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23z" />
+<glyph unicode="&#xf101;" horiz-adv-x="1024" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM979 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23 l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
+<glyph unicode="&#xf102;" horiz-adv-x="1152" d="M1075 224q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM1075 608q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393 q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
+<glyph unicode="&#xf103;" horiz-adv-x="1152" d="M1075 672q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23zM1075 1056q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
+<glyph unicode="&#xf104;" horiz-adv-x="640" d="M627 992q0 -13 -10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
+<glyph unicode="&#xf105;" horiz-adv-x="640" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
+<glyph unicode="&#xf106;" horiz-adv-x="1152" d="M1075 352q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" />
+<glyph unicode="&#xf107;" horiz-adv-x="1152" d="M1075 800q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" />
+<glyph unicode="&#xf108;" horiz-adv-x="1920" d="M1792 544v832q0 13 -9.5 22.5t-22.5 9.5h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5zM1920 1376v-1088q0 -66 -47 -113t-113 -47h-544q0 -37 16 -77.5t32 -71t16 -43.5q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19 t-19 45q0 14 16 44t32 70t16 78h-544q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf109;" horiz-adv-x="1920" d="M416 256q-66 0 -113 47t-47 113v704q0 66 47 113t113 47h1088q66 0 113 -47t47 -113v-704q0 -66 -47 -113t-113 -47h-1088zM384 1120v-704q0 -13 9.5 -22.5t22.5 -9.5h1088q13 0 22.5 9.5t9.5 22.5v704q0 13 -9.5 22.5t-22.5 9.5h-1088q-13 0 -22.5 -9.5t-9.5 -22.5z M1760 192h160v-96q0 -40 -47 -68t-113 -28h-1600q-66 0 -113 28t-47 68v96h160h1600zM1040 96q16 0 16 16t-16 16h-160q-16 0 -16 -16t16 -16h160z" />
+<glyph unicode="&#xf10a;" horiz-adv-x="1152" d="M640 128q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1024 288v960q0 13 -9.5 22.5t-22.5 9.5h-832q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h832q13 0 22.5 9.5t9.5 22.5zM1152 1248v-1088q0 -66 -47 -113t-113 -47h-832 q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h832q66 0 113 -47t47 -113z" />
+<glyph unicode="&#xf10b;" horiz-adv-x="768" d="M464 128q0 33 -23.5 56.5t-56.5 23.5t-56.5 -23.5t-23.5 -56.5t23.5 -56.5t56.5 -23.5t56.5 23.5t23.5 56.5zM672 288v704q0 13 -9.5 22.5t-22.5 9.5h-512q-13 0 -22.5 -9.5t-9.5 -22.5v-704q0 -13 9.5 -22.5t22.5 -9.5h512q13 0 22.5 9.5t9.5 22.5zM480 1136 q0 16 -16 16h-160q-16 0 -16 -16t16 -16h160q16 0 16 16zM768 1152v-1024q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v1024q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" />
+<glyph unicode="&#xf10c;" d="M768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103 t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf10d;" horiz-adv-x="1664" d="M768 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z M1664 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z" />
+<glyph unicode="&#xf10e;" horiz-adv-x="1664" d="M768 1216v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136zM1664 1216 v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136z" />
+<glyph unicode="&#xf110;" horiz-adv-x="1568" d="M496 192q0 -60 -42.5 -102t-101.5 -42q-60 0 -102 42t-42 102t42 102t102 42q59 0 101.5 -42t42.5 -102zM928 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM320 640q0 -66 -47 -113t-113 -47t-113 47t-47 113 t47 113t113 47t113 -47t47 -113zM1360 192q0 -46 -33 -79t-79 -33t-79 33t-33 79t33 79t79 33t79 -33t33 -79zM528 1088q0 -73 -51.5 -124.5t-124.5 -51.5t-124.5 51.5t-51.5 124.5t51.5 124.5t124.5 51.5t124.5 -51.5t51.5 -124.5zM992 1280q0 -80 -56 -136t-136 -56 t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1536 640q0 -40 -28 -68t-68 -28t-68 28t-28 68t28 68t68 28t68 -28t28 -68zM1328 1088q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5z" />
+<glyph unicode="&#xf111;" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf112;" horiz-adv-x="1792" d="M1792 416q0 -166 -127 -451q-3 -7 -10.5 -24t-13.5 -30t-13 -22q-12 -17 -28 -17q-15 0 -23.5 10t-8.5 25q0 9 2.5 26.5t2.5 23.5q5 68 5 123q0 101 -17.5 181t-48.5 138.5t-80 101t-105.5 69.5t-133 42.5t-154 21.5t-175.5 6h-224v-256q0 -26 -19 -45t-45 -19t-45 19 l-512 512q-19 19 -19 45t19 45l512 512q19 19 45 19t45 -19t19 -45v-256h224q713 0 875 -403q53 -134 53 -333z" />
+<glyph unicode="&#xf113;" horiz-adv-x="1664" d="M640 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1280 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1440 320 q0 120 -69 204t-187 84q-41 0 -195 -21q-71 -11 -157 -11t-157 11q-152 21 -195 21q-118 0 -187 -84t-69 -204q0 -88 32 -153.5t81 -103t122 -60t140 -29.5t149 -7h168q82 0 149 7t140 29.5t122 60t81 103t32 153.5zM1664 496q0 -207 -61 -331q-38 -77 -105.5 -133t-141 -86 t-170 -47.5t-171.5 -22t-167 -4.5q-78 0 -142 3t-147.5 12.5t-152.5 30t-137 51.5t-121 81t-86 115q-62 123 -62 331q0 237 136 396q-27 82 -27 170q0 116 51 218q108 0 190 -39.5t189 -123.5q147 35 309 35q148 0 280 -32q105 82 187 121t189 39q51 -102 51 -218 q0 -87 -27 -168q136 -160 136 -398z" />
+<glyph unicode="&#xf114;" horiz-adv-x="1664" d="M1536 224v704q0 40 -28 68t-68 28h-704q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68v-960q0 -40 28 -68t68 -28h1216q40 0 68 28t28 68zM1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320 q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" />
+<glyph unicode="&#xf115;" horiz-adv-x="1920" d="M1781 605q0 35 -53 35h-1088q-40 0 -85.5 -21.5t-71.5 -52.5l-294 -363q-18 -24 -18 -40q0 -35 53 -35h1088q40 0 86 22t71 53l294 363q18 22 18 39zM640 768h768v160q0 40 -28 68t-68 28h-576q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68 v-853l256 315q44 53 116 87.5t140 34.5zM1909 605q0 -62 -46 -120l-295 -363q-43 -53 -116 -87.5t-140 -34.5h-1088q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158v-160h192q54 0 99 -24.5t67 -70.5q15 -32 15 -68z " />
+<glyph unicode="&#xf116;" horiz-adv-x="1792" />
+<glyph unicode="&#xf117;" horiz-adv-x="1792" />
+<glyph unicode="&#xf118;" d="M1134 461q-37 -121 -138 -195t-228 -74t-228 74t-138 195q-8 25 4 48.5t38 31.5q25 8 48.5 -4t31.5 -38q25 -80 92.5 -129.5t151.5 -49.5t151.5 49.5t92.5 129.5q8 26 32 38t49 4t37 -31.5t4 -48.5zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5 t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5 t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf119;" d="M1134 307q8 -25 -4 -48.5t-37 -31.5t-49 4t-32 38q-25 80 -92.5 129.5t-151.5 49.5t-151.5 -49.5t-92.5 -129.5q-8 -26 -31.5 -38t-48.5 -4q-26 8 -38 31.5t-4 48.5q37 121 138 195t228 74t228 -74t138 -195zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204 t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf11a;" d="M1152 448q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h640q26 0 45 -19t19 -45zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf11b;" horiz-adv-x="1920" d="M832 448v128q0 14 -9 23t-23 9h-192v192q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-192h-192q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h192v-192q0 -14 9 -23t23 -9h128q14 0 23 9t9 23v192h192q14 0 23 9t9 23zM1408 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5 t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 640q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1920 512q0 -212 -150 -362t-362 -150q-192 0 -338 128h-220q-146 -128 -338 -128q-212 0 -362 150 t-150 362t150 362t362 150h896q212 0 362 -150t150 -362z" />
+<glyph unicode="&#xf11c;" horiz-adv-x="1920" d="M384 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM512 624v-96q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h224q16 0 16 -16zM384 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 368v-96q0 -16 -16 -16 h-864q-16 0 -16 16v96q0 16 16 16h864q16 0 16 -16zM768 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM640 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1024 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16 h96q16 0 16 -16zM896 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1280 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1152 880v-96 q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 880v-352q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h112v240q0 16 16 16h96q16 0 16 -16zM1792 128v896h-1664v-896 h1664zM1920 1024v-896q0 -53 -37.5 -90.5t-90.5 -37.5h-1664q-53 0 -90.5 37.5t-37.5 90.5v896q0 53 37.5 90.5t90.5 37.5h1664q53 0 90.5 -37.5t37.5 -90.5z" />
+<glyph unicode="&#xf11d;" horiz-adv-x="1792" d="M1664 491v616q-169 -91 -306 -91q-82 0 -145 32q-100 49 -184 76.5t-178 27.5q-173 0 -403 -127v-599q245 113 433 113q55 0 103.5 -7.5t98 -26t77 -31t82.5 -39.5l28 -14q44 -22 101 -22q120 0 293 92zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9 h-64q-14 0 -23 9t-9 23v1266q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102 q-15 -9 -33 -9q-16 0 -32 8q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" />
+<glyph unicode="&#xf11e;" horiz-adv-x="1792" d="M832 536v192q-181 -16 -384 -117v-185q205 96 384 110zM832 954v197q-172 -8 -384 -126v-189q215 111 384 118zM1664 491v184q-235 -116 -384 -71v224q-20 6 -39 15q-5 3 -33 17t-34.5 17t-31.5 15t-34.5 15.5t-32.5 13t-36 12.5t-35 8.5t-39.5 7.5t-39.5 4t-44 2 q-23 0 -49 -3v-222h19q102 0 192.5 -29t197.5 -82q19 -9 39 -15v-188q42 -17 91 -17q120 0 293 92zM1664 918v189q-169 -91 -306 -91q-45 0 -78 8v-196q148 -42 384 90zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v1266 q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102q-15 -9 -33 -9q-16 0 -32 8 q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" />
+<glyph unicode="&#xf120;" horiz-adv-x="1664" d="M585 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23zM1664 96v-64q0 -14 -9 -23t-23 -9h-960q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h960q14 0 23 -9 t9 -23z" />
+<glyph unicode="&#xf121;" horiz-adv-x="1920" d="M617 137l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23zM1208 1204l-373 -1291q-4 -13 -15.5 -19.5t-23.5 -2.5l-62 17q-13 4 -19.5 15.5t-2.5 24.5 l373 1291q4 13 15.5 19.5t23.5 2.5l62 -17q13 -4 19.5 -15.5t2.5 -24.5zM1865 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23z" />
+<glyph unicode="&#xf122;" horiz-adv-x="1792" d="M640 454v-70q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-69l-397 -398q-19 -19 -19 -45t19 -45zM1792 416q0 -58 -17 -133.5t-38.5 -138t-48 -125t-40.5 -90.5l-20 -40q-8 -17 -28 -17q-6 0 -9 1 q-25 8 -23 34q43 400 -106 565q-64 71 -170.5 110.5t-267.5 52.5v-251q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-262q411 -28 599 -221q169 -173 169 -509z" />
+<glyph unicode="&#xf123;" horiz-adv-x="1664" d="M1186 579l257 250l-356 52l-66 10l-30 60l-159 322v-963l59 -31l318 -168l-60 355l-12 66zM1638 841l-363 -354l86 -500q5 -33 -6 -51.5t-34 -18.5q-17 0 -40 12l-449 236l-449 -236q-23 -12 -40 -12q-23 0 -34 18.5t-6 51.5l86 500l-364 354q-32 32 -23 59.5t54 34.5 l502 73l225 455q20 41 49 41q28 0 49 -41l225 -455l502 -73q45 -7 54 -34.5t-24 -59.5z" />
+<glyph unicode="&#xf124;" horiz-adv-x="1408" d="M1401 1187l-640 -1280q-17 -35 -57 -35q-5 0 -15 2q-22 5 -35.5 22.5t-13.5 39.5v576h-576q-22 0 -39.5 13.5t-22.5 35.5t4 42t29 30l1280 640q13 7 29 7q27 0 45 -19q15 -14 18.5 -34.5t-6.5 -39.5z" />
+<glyph unicode="&#xf125;" horiz-adv-x="1664" d="M557 256h595v595zM512 301l595 595h-595v-595zM1664 224v-192q0 -14 -9 -23t-23 -9h-224v-224q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v224h-864q-14 0 -23 9t-9 23v864h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224v224q0 14 9 23t23 9h192q14 0 23 -9t9 -23 v-224h851l246 247q10 9 23 9t23 -9q9 -10 9 -23t-9 -23l-247 -246v-851h224q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf126;" horiz-adv-x="1024" d="M288 64q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM288 1216q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM928 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1024 1088q0 -52 -26 -96.5t-70 -69.5 q-2 -287 -226 -414q-68 -38 -203 -81q-128 -40 -169.5 -71t-41.5 -100v-26q44 -25 70 -69.5t26 -96.5q0 -80 -56 -136t-136 -56t-136 56t-56 136q0 52 26 96.5t70 69.5v820q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136q0 -52 -26 -96.5t-70 -69.5v-497 q54 26 154 57q55 17 87.5 29.5t70.5 31t59 39.5t40.5 51t28 69.5t8.5 91.5q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136z" />
+<glyph unicode="&#xf127;" horiz-adv-x="1664" d="M439 265l-256 -256q-10 -9 -23 -9q-12 0 -23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23zM608 224v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM384 448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23t9 23t23 9h320 q14 0 23 -9t9 -23zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-334 335q-21 21 -42 56l239 18l273 -274q27 -27 68 -27.5t68 26.5l147 146q28 28 28 67q0 40 -28 68l-274 275l18 239q35 -21 56 -42l336 -336q84 -86 84 -204zM1031 1044l-239 -18 l-273 274q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l274 -274l-18 -240q-35 21 -56 42l-336 336q-84 86 -84 204q0 120 85 203l147 146q83 83 203 83q121 0 204 -85l334 -335q21 -21 42 -56zM1664 960q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9 t-9 23t9 23t23 9h320q14 0 23 -9t9 -23zM1120 1504v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM1527 1353l-256 -256q-11 -9 -23 -9t-23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23z" />
+<glyph unicode="&#xf128;" horiz-adv-x="1024" d="M704 280v-240q0 -16 -12 -28t-28 -12h-240q-16 0 -28 12t-12 28v240q0 16 12 28t28 12h240q16 0 28 -12t12 -28zM1020 880q0 -54 -15.5 -101t-35 -76.5t-55 -59.5t-57.5 -43.5t-61 -35.5q-41 -23 -68.5 -65t-27.5 -67q0 -17 -12 -32.5t-28 -15.5h-240q-15 0 -25.5 18.5 t-10.5 37.5v45q0 83 65 156.5t143 108.5q59 27 84 56t25 76q0 42 -46.5 74t-107.5 32q-65 0 -108 -29q-35 -25 -107 -115q-13 -16 -31 -16q-12 0 -25 8l-164 125q-13 10 -15.5 25t5.5 28q160 266 464 266q80 0 161 -31t146 -83t106 -127.5t41 -158.5z" />
+<glyph unicode="&#xf129;" horiz-adv-x="640" d="M640 192v-128q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64v384h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-576h64q26 0 45 -19t19 -45zM512 1344v-192q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v192 q0 26 19 45t45 19h256q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf12a;" horiz-adv-x="640" d="M512 288v-224q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v224q0 26 19 45t45 19h256q26 0 45 -19t19 -45zM542 1344l-28 -768q-1 -26 -20.5 -45t-45.5 -19h-256q-26 0 -45.5 19t-20.5 45l-28 768q-1 26 17.5 45t44.5 19h320q26 0 44.5 -19t17.5 -45z" />
+<glyph unicode="&#xf12b;" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1534 846v-206h-514l-3 27 q-4 28 -4 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q83 65 188 65q110 0 178 -59.5t68 -158.5q0 -56 -24.5 -103t-62 -76.5t-81.5 -58.5t-82 -50.5t-65.5 -51.5t-30.5 -63h232v80 h126z" />
+<glyph unicode="&#xf12c;" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1536 -50v-206h-514l-4 27 q-3 45 -3 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q80 65 188 65q110 0 178 -59.5t68 -158.5q0 -66 -34.5 -118.5t-84 -86t-99.5 -62.5t-87 -63t-41 -73h232v80h126z" />
+<glyph unicode="&#xf12d;" horiz-adv-x="1920" d="M896 128l336 384h-768l-336 -384h768zM1909 1205q15 -34 9.5 -71.5t-30.5 -65.5l-896 -1024q-38 -44 -96 -44h-768q-38 0 -69.5 20.5t-47.5 54.5q-15 34 -9.5 71.5t30.5 65.5l896 1024q38 44 96 44h768q38 0 69.5 -20.5t47.5 -54.5z" />
+<glyph unicode="&#xf12e;" horiz-adv-x="1664" d="M1664 438q0 -81 -44.5 -135t-123.5 -54q-41 0 -77.5 17.5t-59 38t-56.5 38t-71 17.5q-110 0 -110 -124q0 -39 16 -115t15 -115v-5q-22 0 -33 -1q-34 -3 -97.5 -11.5t-115.5 -13.5t-98 -5q-61 0 -103 26.5t-42 83.5q0 37 17.5 71t38 56.5t38 59t17.5 77.5q0 79 -54 123.5 t-135 44.5q-84 0 -143 -45.5t-59 -127.5q0 -43 15 -83t33.5 -64.5t33.5 -53t15 -50.5q0 -45 -46 -89q-37 -35 -117 -35q-95 0 -245 24q-9 2 -27.5 4t-27.5 4l-13 2q-1 0 -3 1q-2 0 -2 1v1024q2 -1 17.5 -3.5t34 -5t21.5 -3.5q150 -24 245 -24q80 0 117 35q46 44 46 89 q0 22 -15 50.5t-33.5 53t-33.5 64.5t-15 83q0 82 59 127.5t144 45.5q80 0 134 -44.5t54 -123.5q0 -41 -17.5 -77.5t-38 -59t-38 -56.5t-17.5 -71q0 -57 42 -83.5t103 -26.5q64 0 180 15t163 17v-2q-1 -2 -3.5 -17.5t-5 -34t-3.5 -21.5q-24 -150 -24 -245q0 -80 35 -117 q44 -46 89 -46q22 0 50.5 15t53 33.5t64.5 33.5t83 15q82 0 127.5 -59t45.5 -143z" />
+<glyph unicode="&#xf130;" horiz-adv-x="1152" d="M1152 832v-128q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-217 24 -364.5 187.5t-147.5 384.5v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -185 131.5 -316.5t316.5 -131.5 t316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45zM896 1216v-512q0 -132 -94 -226t-226 -94t-226 94t-94 226v512q0 132 94 226t226 94t226 -94t94 -226z" />
+<glyph unicode="&#xf131;" horiz-adv-x="1408" d="M271 591l-101 -101q-42 103 -42 214v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -53 15 -113zM1385 1193l-361 -361v-128q0 -132 -94 -226t-226 -94q-55 0 -109 19l-96 -96q97 -51 205 -51q185 0 316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45v-128 q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-125 13 -235 81l-254 -254q-10 -10 -23 -10t-23 10l-82 82q-10 10 -10 23t10 23l1234 1234q10 10 23 10t23 -10l82 -82q10 -10 10 -23 t-10 -23zM1005 1325l-621 -621v512q0 132 94 226t226 94q102 0 184.5 -59t116.5 -152z" />
+<glyph unicode="&#xf132;" horiz-adv-x="1280" d="M1088 576v640h-448v-1137q119 63 213 137q235 184 235 360zM1280 1344v-768q0 -86 -33.5 -170.5t-83 -150t-118 -127.5t-126.5 -103t-121 -77.5t-89.5 -49.5t-42.5 -20q-12 -6 -26 -6t-26 6q-16 7 -42.5 20t-89.5 49.5t-121 77.5t-126.5 103t-118 127.5t-83 150 t-33.5 170.5v768q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf133;" horiz-adv-x="1664" d="M128 -128h1408v1024h-1408v-1024zM512 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1280 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1664 1152v-1280 q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" />
+<glyph unicode="&#xf134;" horiz-adv-x="1408" d="M512 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 1376v-320q0 -16 -12 -25q-8 -7 -20 -7q-4 0 -7 1l-448 96q-11 2 -18 11t-7 20h-256v-102q111 -23 183.5 -111t72.5 -203v-800q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v800 q0 106 62.5 190.5t161.5 114.5v111h-32q-59 0 -115 -23.5t-91.5 -53t-66 -66.5t-40.5 -53.5t-14 -24.5q-17 -35 -57 -35q-16 0 -29 7q-23 12 -31.5 37t3.5 49q5 10 14.5 26t37.5 53.5t60.5 70t85 67t108.5 52.5q-25 42 -25 86q0 66 47 113t113 47t113 -47t47 -113 q0 -33 -14 -64h302q0 11 7 20t18 11l448 96q3 1 7 1q12 0 20 -7q12 -9 12 -25z" />
+<glyph unicode="&#xf135;" horiz-adv-x="1664" d="M1440 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1664 1376q0 -249 -75.5 -430.5t-253.5 -360.5q-81 -80 -195 -176l-20 -379q-2 -16 -16 -26l-384 -224q-7 -4 -16 -4q-12 0 -23 9l-64 64q-13 14 -8 32l85 276l-281 281l-276 -85q-3 -1 -9 -1 q-14 0 -23 9l-64 64q-17 19 -5 39l224 384q10 14 26 16l379 20q96 114 176 195q188 187 358 258t431 71q14 0 24 -9.5t10 -22.5z" />
+<glyph unicode="&#xf136;" horiz-adv-x="1792" d="M1745 763l-164 -763h-334l178 832q13 56 -15 88q-27 33 -83 33h-169l-204 -953h-334l204 953h-286l-204 -953h-334l204 953l-153 327h1276q101 0 189.5 -40.5t147.5 -113.5q60 -73 81 -168.5t0 -194.5z" />
+<glyph unicode="&#xf137;" d="M909 141l102 102q19 19 19 45t-19 45l-307 307l307 307q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf138;" d="M717 141l454 454q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l307 -307l-307 -307q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf139;" d="M1165 397l102 102q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l307 307l307 -307q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf13a;" d="M813 237l454 454q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-307 -307l-307 307q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf13b;" horiz-adv-x="1408" d="M1130 939l16 175h-884l47 -534h612l-22 -228l-197 -53l-196 53l-13 140h-175l22 -278l362 -100h4v1l359 99l50 544h-644l-15 181h674zM0 1408h1408l-128 -1438l-578 -162l-574 162z" />
+<glyph unicode="&#xf13c;" horiz-adv-x="1792" d="M275 1408h1505l-266 -1333l-804 -267l-698 267l71 356h297l-29 -147l422 -161l486 161l68 339h-1208l58 297h1209l38 191h-1208z" />
+<glyph unicode="&#xf13d;" horiz-adv-x="1792" d="M960 1280q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1792 352v-352q0 -22 -20 -30q-8 -2 -12 -2q-13 0 -23 9l-93 93q-119 -143 -318.5 -226.5t-429.5 -83.5t-429.5 83.5t-318.5 226.5l-93 -93q-9 -9 -23 -9q-4 0 -12 2q-20 8 -20 30v352 q0 14 9 23t23 9h352q22 0 30 -20q8 -19 -7 -35l-100 -100q67 -91 189.5 -153.5t271.5 -82.5v647h-192q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h192v163q-58 34 -93 92.5t-35 128.5q0 106 75 181t181 75t181 -75t75 -181q0 -70 -35 -128.5t-93 -92.5v-163h192q26 0 45 -19 t19 -45v-128q0 -26 -19 -45t-45 -19h-192v-647q149 20 271.5 82.5t189.5 153.5l-100 100q-15 16 -7 35q8 20 30 20h352q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf13e;" horiz-adv-x="1152" d="M1056 768q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v320q0 185 131.5 316.5t316.5 131.5t316.5 -131.5t131.5 -316.5q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45q0 106 -75 181t-181 75t-181 -75t-75 -181 v-320h736z" />
+<glyph unicode="&#xf140;" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM1152 640q0 159 -112.5 271.5t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM1280 640q0 -212 -150 -362t-362 -150t-362 150 t-150 362t150 362t362 150t362 -150t150 -362zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf141;" horiz-adv-x="1408" d="M384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM896 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM1408 800v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf142;" horiz-adv-x="384" d="M384 288v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 1312v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" />
+<glyph unicode="&#xf143;" d="M512 256q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM863 162q-13 232 -177 396t-396 177q-14 1 -24 -9t-10 -23v-128q0 -13 8.5 -22t21.5 -10q154 -11 264 -121t121 -264q1 -13 10 -21.5t22 -8.5h128q13 0 23 10 t9 24zM1247 161q-5 154 -56 297.5t-139.5 260t-205 205t-260 139.5t-297.5 56q-14 1 -23 -9q-10 -10 -10 -23v-128q0 -13 9 -22t22 -10q204 -7 378 -111.5t278.5 -278.5t111.5 -378q1 -13 10 -22t22 -9h128q13 0 23 10q11 9 9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf144;" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1152 585q32 18 32 55t-32 55l-544 320q-31 19 -64 1q-32 -19 -32 -56v-640q0 -37 32 -56 q16 -8 32 -8q17 0 32 9z" />
+<glyph unicode="&#xf145;" horiz-adv-x="1792" d="M1024 1084l316 -316l-572 -572l-316 316zM813 105l618 618q19 19 19 45t-19 45l-362 362q-18 18 -45 18t-45 -18l-618 -618q-19 -19 -19 -45t19 -45l362 -362q18 -18 45 -18t45 18zM1702 742l-907 -908q-37 -37 -90.5 -37t-90.5 37l-126 126q56 56 56 136t-56 136 t-136 56t-136 -56l-125 126q-37 37 -37 90.5t37 90.5l907 906q37 37 90.5 37t90.5 -37l125 -125q-56 -56 -56 -136t56 -136t136 -56t136 56l126 -125q37 -37 37 -90.5t-37 -90.5z" />
+<glyph unicode="&#xf146;" d="M1280 576v128q0 26 -19 45t-45 19h-896q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h896q26 0 45 19t19 45zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5 t84.5 -203.5z" />
+<glyph unicode="&#xf147;" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h832q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5 t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf148;" horiz-adv-x="1024" d="M1018 933q-18 -37 -58 -37h-192v-864q0 -14 -9 -23t-23 -9h-704q-21 0 -29 18q-8 20 4 35l160 192q9 11 25 11h320v640h-192q-40 0 -58 37q-17 37 9 68l320 384q18 22 49 22t49 -22l320 -384q27 -32 9 -68z" />
+<glyph unicode="&#xf149;" horiz-adv-x="1024" d="M32 1280h704q13 0 22.5 -9.5t9.5 -23.5v-863h192q40 0 58 -37t-9 -69l-320 -384q-18 -22 -49 -22t-49 22l-320 384q-26 31 -9 69q18 37 58 37h192v640h-320q-14 0 -25 11l-160 192q-13 14 -4 34q9 19 29 19z" />
+<glyph unicode="&#xf14a;" d="M685 237l614 614q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-467 -467l-211 211q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l358 -358q19 -19 45 -19t45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5 t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf14b;" d="M404 428l152 -152l-52 -52h-56v96h-96v56zM818 818q14 -13 -3 -30l-291 -291q-17 -17 -30 -3q-14 13 3 30l291 291q17 17 30 3zM544 128l544 544l-288 288l-544 -544v-288h288zM1152 736l92 92q28 28 28 68t-28 68l-152 152q-28 28 -68 28t-68 -28l-92 -92zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf14c;" d="M1280 608v480q0 26 -19 45t-45 19h-480q-42 0 -59 -39q-17 -41 14 -70l144 -144l-534 -534q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l534 534l144 -144q18 -19 45 -19q12 0 25 5q39 17 39 59zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf14d;" d="M1005 435l352 352q19 19 19 45t-19 45l-352 352q-30 31 -69 14q-40 -17 -40 -59v-160q-119 0 -216 -19.5t-162.5 -51t-114 -79t-76.5 -95.5t-44.5 -109t-21.5 -111.5t-5 -110.5q0 -181 167 -404q10 -12 25 -12q7 0 13 3q22 9 19 33q-44 354 62 473q46 52 130 75.5 t224 23.5v-160q0 -42 40 -59q12 -5 24 -5q26 0 45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf14e;" d="M640 448l256 128l-256 128v-256zM1024 1039v-542l-512 -256v542zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf150;" d="M1145 861q18 -35 -5 -66l-320 -448q-19 -27 -52 -27t-52 27l-320 448q-23 31 -5 66q17 35 57 35h640q40 0 57 -35zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf151;" d="M1145 419q-17 -35 -57 -35h-640q-40 0 -57 35q-18 35 5 66l320 448q19 27 52 27t52 -27l320 -448q23 -31 5 -66zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf152;" d="M1088 640q0 -33 -27 -52l-448 -320q-31 -23 -66 -5q-35 17 -35 57v640q0 40 35 57q35 18 66 -5l448 -320q27 -19 27 -52zM1280 160v960q0 14 -9 23t-23 9h-960q-14 0 -23 -9t-9 -23v-960q0 -14 9 -23t23 -9h960q14 0 23 9t9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf153;" horiz-adv-x="1024" d="M976 229l35 -159q3 -12 -3 -22.5t-17 -14.5l-5 -1q-4 -2 -10.5 -3.5t-16 -4.5t-21.5 -5.5t-25.5 -5t-30 -5t-33.5 -4.5t-36.5 -3t-38.5 -1q-234 0 -409 130.5t-238 351.5h-95q-13 0 -22.5 9.5t-9.5 22.5v113q0 13 9.5 22.5t22.5 9.5h66q-2 57 1 105h-67q-14 0 -23 9 t-9 23v114q0 14 9 23t23 9h98q67 210 243.5 338t400.5 128q102 0 194 -23q11 -3 20 -15q6 -11 3 -24l-43 -159q-3 -13 -14 -19.5t-24 -2.5l-4 1q-4 1 -11.5 2.5l-17.5 3.5t-22.5 3.5t-26 3t-29 2.5t-29.5 1q-126 0 -226 -64t-150 -176h468q16 0 25 -12q10 -12 7 -26 l-24 -114q-5 -26 -32 -26h-488q-3 -37 0 -105h459q15 0 25 -12q9 -12 6 -27l-24 -112q-2 -11 -11 -18.5t-20 -7.5h-387q48 -117 149.5 -185.5t228.5 -68.5q18 0 36 1.5t33.5 3.5t29.5 4.5t24.5 5t18.5 4.5l12 3l5 2q13 5 26 -2q12 -7 15 -21z" />
+<glyph unicode="&#xf154;" horiz-adv-x="1024" d="M1020 399v-367q0 -14 -9 -23t-23 -9h-956q-14 0 -23 9t-9 23v150q0 13 9.5 22.5t22.5 9.5h97v383h-95q-14 0 -23 9.5t-9 22.5v131q0 14 9 23t23 9h95v223q0 171 123.5 282t314.5 111q185 0 335 -125q9 -8 10 -20.5t-7 -22.5l-103 -127q-9 -11 -22 -12q-13 -2 -23 7 q-5 5 -26 19t-69 32t-93 18q-85 0 -137 -47t-52 -123v-215h305q13 0 22.5 -9t9.5 -23v-131q0 -13 -9.5 -22.5t-22.5 -9.5h-305v-379h414v181q0 13 9 22.5t23 9.5h162q14 0 23 -9.5t9 -22.5z" />
+<glyph unicode="&#xf155;" horiz-adv-x="1024" d="M978 351q0 -153 -99.5 -263.5t-258.5 -136.5v-175q0 -14 -9 -23t-23 -9h-135q-13 0 -22.5 9.5t-9.5 22.5v175q-66 9 -127.5 31t-101.5 44.5t-74 48t-46.5 37.5t-17.5 18q-17 21 -2 41l103 135q7 10 23 12q15 2 24 -9l2 -2q113 -99 243 -125q37 -8 74 -8q81 0 142.5 43 t61.5 122q0 28 -15 53t-33.5 42t-58.5 37.5t-66 32t-80 32.5q-39 16 -61.5 25t-61.5 26.5t-62.5 31t-56.5 35.5t-53.5 42.5t-43.5 49t-35.5 58t-21 66.5t-8.5 78q0 138 98 242t255 134v180q0 13 9.5 22.5t22.5 9.5h135q14 0 23 -9t9 -23v-176q57 -6 110.5 -23t87 -33.5 t63.5 -37.5t39 -29t15 -14q17 -18 5 -38l-81 -146q-8 -15 -23 -16q-14 -3 -27 7q-3 3 -14.5 12t-39 26.5t-58.5 32t-74.5 26t-85.5 11.5q-95 0 -155 -43t-60 -111q0 -26 8.5 -48t29.5 -41.5t39.5 -33t56 -31t60.5 -27t70 -27.5q53 -20 81 -31.5t76 -35t75.5 -42.5t62 -50 t53 -63.5t31.5 -76.5t13 -94z" />
+<glyph unicode="&#xf156;" horiz-adv-x="898" d="M898 1066v-102q0 -14 -9 -23t-23 -9h-168q-23 -144 -129 -234t-276 -110q167 -178 459 -536q14 -16 4 -34q-8 -18 -29 -18h-195q-16 0 -25 12q-306 367 -498 571q-9 9 -9 22v127q0 13 9.5 22.5t22.5 9.5h112q132 0 212.5 43t102.5 125h-427q-14 0 -23 9t-9 23v102 q0 14 9 23t23 9h413q-57 113 -268 113h-145q-13 0 -22.5 9.5t-9.5 22.5v133q0 14 9 23t23 9h832q14 0 23 -9t9 -23v-102q0 -14 -9 -23t-23 -9h-233q47 -61 64 -144h171q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf157;" horiz-adv-x="1027" d="M603 0h-172q-13 0 -22.5 9t-9.5 23v330h-288q-13 0 -22.5 9t-9.5 23v103q0 13 9.5 22.5t22.5 9.5h288v85h-288q-13 0 -22.5 9t-9.5 23v104q0 13 9.5 22.5t22.5 9.5h214l-321 578q-8 16 0 32q10 16 28 16h194q19 0 29 -18l215 -425q19 -38 56 -125q10 24 30.5 68t27.5 61 l191 420q8 19 29 19h191q17 0 27 -16q9 -14 1 -31l-313 -579h215q13 0 22.5 -9.5t9.5 -22.5v-104q0 -14 -9.5 -23t-22.5 -9h-290v-85h290q13 0 22.5 -9.5t9.5 -22.5v-103q0 -14 -9.5 -23t-22.5 -9h-290v-330q0 -13 -9.5 -22.5t-22.5 -9.5z" />
+<glyph unicode="&#xf158;" horiz-adv-x="1280" d="M1043 971q0 100 -65 162t-171 62h-320v-448h320q106 0 171 62t65 162zM1280 971q0 -193 -126.5 -315t-326.5 -122h-340v-118h505q14 0 23 -9t9 -23v-128q0 -14 -9 -23t-23 -9h-505v-192q0 -14 -9.5 -23t-22.5 -9h-167q-14 0 -23 9t-9 23v192h-224q-14 0 -23 9t-9 23v128 q0 14 9 23t23 9h224v118h-224q-14 0 -23 9t-9 23v149q0 13 9 22.5t23 9.5h224v629q0 14 9 23t23 9h539q200 0 326.5 -122t126.5 -315z" />
+<glyph unicode="&#xf159;" horiz-adv-x="1792" d="M514 341l81 299h-159l75 -300q1 -1 1 -3t1 -3q0 1 0.5 3.5t0.5 3.5zM630 768l35 128h-292l32 -128h225zM822 768h139l-35 128h-70zM1271 340l78 300h-162l81 -299q0 -1 0.5 -3.5t1.5 -3.5q0 1 0.5 3t0.5 3zM1382 768l33 128h-297l34 -128h230zM1792 736v-64q0 -14 -9 -23 t-23 -9h-213l-164 -616q-7 -24 -31 -24h-159q-24 0 -31 24l-166 616h-209l-167 -616q-7 -24 -31 -24h-159q-11 0 -19.5 7t-10.5 17l-160 616h-208q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h175l-33 128h-142q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h109l-89 344q-5 15 5 28 q10 12 26 12h137q26 0 31 -24l90 -360h359l97 360q7 24 31 24h126q24 0 31 -24l98 -360h365l93 360q5 24 31 24h137q16 0 26 -12q10 -13 5 -28l-91 -344h111q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-145l-34 -128h179q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf15a;" horiz-adv-x="1280" d="M1167 896q18 -182 -131 -258q117 -28 175 -103t45 -214q-7 -71 -32.5 -125t-64.5 -89t-97 -58.5t-121.5 -34.5t-145.5 -15v-255h-154v251q-80 0 -122 1v-252h-154v255q-18 0 -54 0.5t-55 0.5h-200l31 183h111q50 0 58 51v402h16q-6 1 -16 1v287q-13 68 -89 68h-111v164 l212 -1q64 0 97 1v252h154v-247q82 2 122 2v245h154v-252q79 -7 140 -22.5t113 -45t82.5 -78t36.5 -114.5zM952 351q0 36 -15 64t-37 46t-57.5 30.5t-65.5 18.5t-74 9t-69 3t-64.5 -1t-47.5 -1v-338q8 0 37 -0.5t48 -0.5t53 1.5t58.5 4t57 8.5t55.5 14t47.5 21t39.5 30 t24.5 40t9.5 51zM881 827q0 33 -12.5 58.5t-30.5 42t-48 28t-55 16.5t-61.5 8t-58 2.5t-54 -1t-39.5 -0.5v-307q5 0 34.5 -0.5t46.5 0t50 2t55 5.5t51.5 11t48.5 18.5t37 27t27 38.5t9 51z" />
+<glyph unicode="&#xf15b;" horiz-adv-x="1280" d="M1280 768v-800q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h544v-544q0 -40 28 -68t68 -28h544zM1277 896h-509v509q82 -15 132 -65l312 -312q50 -50 65 -132z" />
+<glyph unicode="&#xf15c;" horiz-adv-x="1280" d="M1024 160v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23zM1024 416v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23zM1280 768v-800q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28 t-28 68v1344q0 40 28 68t68 28h544v-544q0 -40 28 -68t68 -28h544zM1277 896h-509v509q82 -15 132 -65l312 -312q50 -50 65 -132z" />
+<glyph unicode="&#xf15d;" horiz-adv-x="1664" d="M1191 1128h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1572 -23 v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -11v-2l14 2q9 2 30 2h248v119h121zM1661 874v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162 l230 -662h70z" />
+<glyph unicode="&#xf15e;" horiz-adv-x="1664" d="M1191 104h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1661 -150 v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162l230 -662h70zM1572 1001v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -10v-3l14 3q9 1 30 1h248 v119h121z" />
+<glyph unicode="&#xf160;" horiz-adv-x="1792" d="M736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1792 -32v-192q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832 q14 0 23 -9t9 -23zM1600 480v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1408 992v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1216 1504v-192q0 -14 -9 -23t-23 -9h-256 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf161;" horiz-adv-x="1792" d="M1216 -32v-192q0 -14 -9 -23t-23 -9h-256q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192 q14 0 23 -9t9 -23zM1408 480v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1600 992v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1792 1504v-192q0 -14 -9 -23t-23 -9h-832 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf162;" d="M1346 223q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23 zM1486 165q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5 t82 -252.5zM1456 882v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165z" />
+<glyph unicode="&#xf163;" d="M1346 1247q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9 t9 -23zM1456 -142v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165zM1486 1189q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13 q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5t82 -252.5z" />
+<glyph unicode="&#xf164;" horiz-adv-x="1664" d="M256 192q0 26 -19 45t-45 19q-27 0 -45.5 -19t-18.5 -45q0 -27 18.5 -45.5t45.5 -18.5q26 0 45 18.5t19 45.5zM416 704v-640q0 -26 -19 -45t-45 -19h-288q-26 0 -45 19t-19 45v640q0 26 19 45t45 19h288q26 0 45 -19t19 -45zM1600 704q0 -86 -55 -149q15 -44 15 -76 q3 -76 -43 -137q17 -56 0 -117q-15 -57 -54 -94q9 -112 -49 -181q-64 -76 -197 -78h-36h-76h-17q-66 0 -144 15.5t-121.5 29t-120.5 39.5q-123 43 -158 44q-26 1 -45 19.5t-19 44.5v641q0 25 18 43.5t43 20.5q24 2 76 59t101 121q68 87 101 120q18 18 31 48t17.5 48.5 t13.5 60.5q7 39 12.5 61t19.5 52t34 50q19 19 45 19q46 0 82.5 -10.5t60 -26t40 -40.5t24 -45t12 -50t5 -45t0.5 -39q0 -38 -9.5 -76t-19 -60t-27.5 -56q-3 -6 -10 -18t-11 -22t-8 -24h277q78 0 135 -57t57 -135z" />
+<glyph unicode="&#xf165;" horiz-adv-x="1664" d="M256 960q0 -26 -19 -45t-45 -19q-27 0 -45.5 19t-18.5 45q0 27 18.5 45.5t45.5 18.5q26 0 45 -18.5t19 -45.5zM416 448v640q0 26 -19 45t-45 19h-288q-26 0 -45 -19t-19 -45v-640q0 -26 19 -45t45 -19h288q26 0 45 19t19 45zM1545 597q55 -61 55 -149q-1 -78 -57.5 -135 t-134.5 -57h-277q4 -14 8 -24t11 -22t10 -18q18 -37 27 -57t19 -58.5t10 -76.5q0 -24 -0.5 -39t-5 -45t-12 -50t-24 -45t-40 -40.5t-60 -26t-82.5 -10.5q-26 0 -45 19q-20 20 -34 50t-19.5 52t-12.5 61q-9 42 -13.5 60.5t-17.5 48.5t-31 48q-33 33 -101 120q-49 64 -101 121 t-76 59q-25 2 -43 20.5t-18 43.5v641q0 26 19 44.5t45 19.5q35 1 158 44q77 26 120.5 39.5t121.5 29t144 15.5h17h76h36q133 -2 197 -78q58 -69 49 -181q39 -37 54 -94q17 -61 0 -117q46 -61 43 -137q0 -32 -15 -76z" />
+<glyph unicode="&#xf166;" d="M919 233v157q0 50 -29 50q-17 0 -33 -16v-224q16 -16 33 -16q29 0 29 49zM1103 355h66v34q0 51 -33 51t-33 -51v-34zM532 621v-70h-80v-423h-74v423h-78v70h232zM733 495v-367h-67v40q-39 -45 -76 -45q-33 0 -42 28q-6 16 -6 54v290h66v-270q0 -24 1 -26q1 -15 15 -15 q20 0 42 31v280h67zM985 384v-146q0 -52 -7 -73q-12 -42 -53 -42q-35 0 -68 41v-36h-67v493h67v-161q32 40 68 40q41 0 53 -42q7 -21 7 -74zM1236 255v-9q0 -29 -2 -43q-3 -22 -15 -40q-27 -40 -80 -40q-52 0 -81 38q-21 27 -21 86v129q0 59 20 86q29 38 80 38t78 -38 q21 -28 21 -86v-76h-133v-65q0 -51 34 -51q24 0 30 26q0 1 0.5 7t0.5 16.5v21.5h68zM785 1079v-156q0 -51 -32 -51t-32 51v156q0 52 32 52t32 -52zM1318 366q0 177 -19 260q-10 44 -43 73.5t-76 34.5q-136 15 -412 15q-275 0 -411 -15q-44 -5 -76.5 -34.5t-42.5 -73.5 q-20 -87 -20 -260q0 -176 20 -260q10 -43 42.5 -73t75.5 -35q137 -15 412 -15t412 15q43 5 75.5 35t42.5 73q20 84 20 260zM563 1017l90 296h-75l-51 -195l-53 195h-78l24 -69t23 -69q35 -103 46 -158v-201h74v201zM852 936v130q0 58 -21 87q-29 38 -78 38q-51 0 -78 -38 q-21 -29 -21 -87v-130q0 -58 21 -87q27 -38 78 -38q49 0 78 38q21 27 21 87zM1033 816h67v370h-67v-283q-22 -31 -42 -31q-15 0 -16 16q-1 2 -1 26v272h-67v-293q0 -37 6 -55q11 -27 43 -27q36 0 77 45v-40zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf167;" d="M971 292v-211q0 -67 -39 -67q-23 0 -45 22v301q22 22 45 22q39 0 39 -67zM1309 291v-46h-90v46q0 68 45 68t45 -68zM343 509h107v94h-312v-94h105v-569h100v569zM631 -60h89v494h-89v-378q-30 -42 -57 -42q-18 0 -21 21q-1 3 -1 35v364h-89v-391q0 -49 8 -73 q12 -37 58 -37q48 0 102 61v-54zM1060 88v197q0 73 -9 99q-17 56 -71 56q-50 0 -93 -54v217h-89v-663h89v48q45 -55 93 -55q54 0 71 55q9 27 9 100zM1398 98v13h-91q0 -51 -2 -61q-7 -36 -40 -36q-46 0 -46 69v87h179v103q0 79 -27 116q-39 51 -106 51q-68 0 -107 -51 q-28 -37 -28 -116v-173q0 -79 29 -116q39 -51 108 -51q72 0 108 53q18 27 21 54q2 9 2 58zM790 1011v210q0 69 -43 69t-43 -69v-210q0 -70 43 -70t43 70zM1509 260q0 -234 -26 -350q-14 -59 -58 -99t-102 -46q-184 -21 -555 -21t-555 21q-58 6 -102.5 46t-57.5 99 q-26 112 -26 350q0 234 26 350q14 59 58 99t103 47q183 20 554 20t555 -20q58 -7 102.5 -47t57.5 -99q26 -112 26 -350zM511 1536h102l-121 -399v-271h-100v271q-14 74 -61 212q-37 103 -65 187h106l71 -263zM881 1203v-175q0 -81 -28 -118q-37 -51 -106 -51q-67 0 -105 51 q-28 38 -28 118v175q0 80 28 117q38 51 105 51q69 0 106 -51q28 -37 28 -117zM1216 1365v-499h-91v55q-53 -62 -103 -62q-46 0 -59 37q-8 24 -8 75v394h91v-367q0 -33 1 -35q3 -22 21 -22q27 0 57 43v381h91z" />
+<glyph unicode="&#xf168;" horiz-adv-x="1408" d="M597 869q-10 -18 -257 -456q-27 -46 -65 -46h-239q-21 0 -31 17t0 36l253 448q1 0 0 1l-161 279q-12 22 -1 37q9 15 32 15h239q40 0 66 -45zM1403 1511q11 -16 0 -37l-528 -934v-1l336 -615q11 -20 1 -37q-10 -15 -32 -15h-239q-42 0 -66 45l-339 622q18 32 531 942 q25 45 64 45h241q22 0 31 -15z" />
+<glyph unicode="&#xf169;" d="M685 771q0 1 -126 222q-21 34 -52 34h-184q-18 0 -26 -11q-7 -12 1 -29l125 -216v-1l-196 -346q-9 -14 0 -28q8 -13 24 -13h185q31 0 50 36zM1309 1268q-7 12 -24 12h-187q-30 0 -49 -35l-411 -729q1 -2 262 -481q20 -35 52 -35h184q18 0 25 12q8 13 -1 28l-260 476v1 l409 723q8 16 0 28zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf16a;" horiz-adv-x="1792" d="M1280 640q0 37 -30 54l-512 320q-31 20 -65 2q-33 -18 -33 -56v-640q0 -38 33 -56q16 -8 31 -8q20 0 34 10l512 320q30 17 30 54zM1792 640q0 -96 -1 -150t-8.5 -136.5t-22.5 -147.5q-16 -73 -69 -123t-124 -58q-222 -25 -671 -25t-671 25q-71 8 -124.5 58t-69.5 123 q-14 65 -21.5 147.5t-8.5 136.5t-1 150t1 150t8.5 136.5t22.5 147.5q16 73 69 123t124 58q222 25 671 25t671 -25q71 -8 124.5 -58t69.5 -123q14 -65 21.5 -147.5t8.5 -136.5t1 -150z" />
+<glyph unicode="&#xf16b;" horiz-adv-x="1792" d="M402 829l494 -305l-342 -285l-490 319zM1388 274v-108l-490 -293v-1l-1 1l-1 -1v1l-489 293v108l147 -96l342 284v2l1 -1l1 1v-2l343 -284zM554 1418l342 -285l-494 -304l-338 270zM1390 829l338 -271l-489 -319l-343 285zM1239 1418l489 -319l-338 -270l-494 304z" />
+<glyph unicode="&#xf16c;" horiz-adv-x="1408" d="M928 135v-151l-707 -1v151zM1169 481v-701l-1 -35v-1h-1132l-35 1h-1v736h121v-618h928v618h120zM241 393l704 -65l-13 -150l-705 65zM309 709l683 -183l-39 -146l-683 183zM472 1058l609 -360l-77 -130l-609 360zM832 1389l398 -585l-124 -85l-399 584zM1285 1536 l121 -697l-149 -26l-121 697z" />
+<glyph unicode="&#xf16d;" d="M1362 110v648h-135q20 -63 20 -131q0 -126 -64 -232.5t-174 -168.5t-240 -62q-197 0 -337 135.5t-140 327.5q0 68 20 131h-141v-648q0 -26 17.5 -43.5t43.5 -17.5h1069q25 0 43 17.5t18 43.5zM1078 643q0 124 -90.5 211.5t-218.5 87.5q-127 0 -217.5 -87.5t-90.5 -211.5 t90.5 -211.5t217.5 -87.5q128 0 218.5 87.5t90.5 211.5zM1362 1003v165q0 28 -20 48.5t-49 20.5h-174q-29 0 -49 -20.5t-20 -48.5v-165q0 -29 20 -49t49 -20h174q29 0 49 20t20 49zM1536 1211v-1142q0 -81 -58 -139t-139 -58h-1142q-81 0 -139 58t-58 139v1142q0 81 58 139 t139 58h1142q81 0 139 -58t58 -139z" />
+<glyph unicode="&#xf16e;" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960zM698 640q0 88 -62 150t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150zM1262 640q0 88 -62 150 t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150z" />
+<glyph unicode="&#xf170;" d="M768 914l201 -306h-402zM1133 384h94l-459 691l-459 -691h94l104 160h522zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf171;" horiz-adv-x="1408" d="M815 677q8 -63 -50.5 -101t-111.5 -6q-39 17 -53.5 58t-0.5 82t52 58q36 18 72.5 12t64 -35.5t27.5 -67.5zM926 698q-14 107 -113 164t-197 13q-63 -28 -100.5 -88.5t-34.5 -129.5q4 -91 77.5 -155t165.5 -56q91 8 152 84t50 168zM1165 1240q-20 27 -56 44.5t-58 22 t-71 12.5q-291 47 -566 -2q-43 -7 -66 -12t-55 -22t-50 -43q30 -28 76 -45.5t73.5 -22t87.5 -11.5q228 -29 448 -1q63 8 89.5 12t72.5 21.5t75 46.5zM1222 205q-8 -26 -15.5 -76.5t-14 -84t-28.5 -70t-58 -56.5q-86 -48 -189.5 -71.5t-202 -22t-201.5 18.5q-46 8 -81.5 18 t-76.5 27t-73 43.5t-52 61.5q-25 96 -57 292l6 16l18 9q223 -148 506.5 -148t507.5 148q21 -6 24 -23t-5 -45t-8 -37zM1403 1166q-26 -167 -111 -655q-5 -30 -27 -56t-43.5 -40t-54.5 -31q-252 -126 -610 -88q-248 27 -394 139q-15 12 -25.5 26.5t-17 35t-9 34t-6 39.5 t-5.5 35q-9 50 -26.5 150t-28 161.5t-23.5 147.5t-22 158q3 26 17.5 48.5t31.5 37.5t45 30t46 22.5t48 18.5q125 46 313 64q379 37 676 -50q155 -46 215 -122q16 -20 16.5 -51t-5.5 -54z" />
+<glyph unicode="&#xf172;" d="M848 666q0 43 -41 66t-77 1q-43 -20 -42.5 -72.5t43.5 -70.5q39 -23 81 4t36 72zM928 682q8 -66 -36 -121t-110 -61t-119 40t-56 113q-2 49 25.5 93t72.5 64q70 31 141.5 -10t81.5 -118zM1100 1073q-20 -21 -53.5 -34t-53 -16t-63.5 -8q-155 -20 -324 0q-44 6 -63 9.5 t-52.5 16t-54.5 32.5q13 19 36 31t40 15.5t47 8.5q198 35 408 1q33 -5 51 -8.5t43 -16t39 -31.5zM1142 327q0 7 5.5 26.5t3 32t-17.5 16.5q-161 -106 -365 -106t-366 106l-12 -6l-5 -12q26 -154 41 -210q47 -81 204 -108q249 -46 428 53q34 19 49 51.5t22.5 85.5t12.5 71z M1272 1020q9 53 -8 75q-43 55 -155 88q-216 63 -487 36q-132 -12 -226 -46q-38 -15 -59.5 -25t-47 -34t-29.5 -54q8 -68 19 -138t29 -171t24 -137q1 -5 5 -31t7 -36t12 -27t22 -28q105 -80 284 -100q259 -28 440 63q24 13 39.5 23t31 29t19.5 40q48 267 80 473zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf173;" horiz-adv-x="1024" d="M390 1408h219v-388h364v-241h-364v-394q0 -136 14 -172q13 -37 52 -60q50 -31 117 -31q117 0 232 76v-242q-102 -48 -178 -65q-77 -19 -173 -19q-105 0 -186 27q-78 25 -138 75q-58 51 -79 105q-22 54 -22 161v539h-170v217q91 30 155 84q64 55 103 132q39 78 54 196z " />
+<glyph unicode="&#xf174;" d="M1123 127v181q-88 -56 -174 -56q-51 0 -88 23q-29 17 -39 45q-11 30 -11 129v295h274v181h-274v291h-164q-11 -90 -40 -147t-78 -99q-48 -40 -116 -63v-163h127v-404q0 -78 17 -121q17 -42 59 -78q43 -37 104 -57q62 -20 140 -20q67 0 129 14q57 13 134 49zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf175;" horiz-adv-x="768" d="M765 237q8 -19 -5 -35l-350 -384q-10 -10 -23 -10q-14 0 -24 10l-355 384q-13 16 -5 35q9 19 29 19h224v1248q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1248h224q21 0 29 -19z" />
+<glyph unicode="&#xf176;" horiz-adv-x="768" d="M765 1043q-9 -19 -29 -19h-224v-1248q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1248h-224q-21 0 -29 19t5 35l350 384q10 10 23 10q14 0 24 -10l355 -384q13 -16 5 -35z" />
+<glyph unicode="&#xf177;" horiz-adv-x="1792" d="M1792 736v-192q0 -14 -9 -23t-23 -9h-1248v-224q0 -21 -19 -29t-35 5l-384 350q-10 10 -10 23q0 14 10 24l384 354q16 14 35 6q19 -9 19 -29v-224h1248q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf178;" horiz-adv-x="1792" d="M1728 643q0 -14 -10 -24l-384 -354q-16 -14 -35 -6q-19 9 -19 29v224h-1248q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h1248v224q0 21 19 29t35 -5l384 -350q10 -10 10 -23z" />
+<glyph unicode="&#xf179;" horiz-adv-x="1408" d="M1393 321q-39 -125 -123 -250q-129 -196 -257 -196q-49 0 -140 32q-86 32 -151 32q-61 0 -142 -33q-81 -34 -132 -34q-152 0 -301 259q-147 261 -147 503q0 228 113 374q112 144 284 144q72 0 177 -30q104 -30 138 -30q45 0 143 34q102 34 173 34q119 0 213 -65 q52 -36 104 -100q-79 -67 -114 -118q-65 -94 -65 -207q0 -124 69 -223t158 -126zM1017 1494q0 -61 -29 -136q-30 -75 -93 -138q-54 -54 -108 -72q-37 -11 -104 -17q3 149 78 257q74 107 250 148q1 -3 2.5 -11t2.5 -11q0 -4 0.5 -10t0.5 -10z" />
+<glyph unicode="&#xf17a;" horiz-adv-x="1664" d="M682 530v-651l-682 94v557h682zM682 1273v-659h-682v565zM1664 530v-786l-907 125v661h907zM1664 1408v-794h-907v669z" />
+<glyph unicode="&#xf17b;" horiz-adv-x="1408" d="M493 1053q16 0 27.5 11.5t11.5 27.5t-11.5 27.5t-27.5 11.5t-27 -11.5t-11 -27.5t11 -27.5t27 -11.5zM915 1053q16 0 27 11.5t11 27.5t-11 27.5t-27 11.5t-27.5 -11.5t-11.5 -27.5t11.5 -27.5t27.5 -11.5zM103 869q42 0 72 -30t30 -72v-430q0 -43 -29.5 -73t-72.5 -30 t-73 30t-30 73v430q0 42 30 72t73 30zM1163 850v-666q0 -46 -32 -78t-77 -32h-75v-227q0 -43 -30 -73t-73 -30t-73 30t-30 73v227h-138v-227q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73l-1 227h-74q-46 0 -78 32t-32 78v666h918zM931 1255q107 -55 171 -153.5t64 -215.5 h-925q0 117 64 215.5t172 153.5l-71 131q-7 13 5 20q13 6 20 -6l72 -132q95 42 201 42t201 -42l72 132q7 12 20 6q12 -7 5 -20zM1408 767v-430q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73v430q0 43 30 72.5t72 29.5q43 0 73 -29.5t30 -72.5z" />
+<glyph unicode="&#xf17c;" d="M663 1125q-11 -1 -15.5 -10.5t-8.5 -9.5q-5 -1 -5 5q0 12 19 15h10zM750 1111q-4 -1 -11.5 6.5t-17.5 4.5q24 11 32 -2q3 -6 -3 -9zM399 684q-4 1 -6 -3t-4.5 -12.5t-5.5 -13.5t-10 -13q-7 -10 -1 -12q4 -1 12.5 7t12.5 18q1 3 2 7t2 6t1.5 4.5t0.5 4v3t-1 2.5t-3 2z M1254 325q0 18 -55 42q4 15 7.5 27.5t5 26t3 21.5t0.5 22.5t-1 19.5t-3.5 22t-4 20.5t-5 25t-5.5 26.5q-10 48 -47 103t-72 75q24 -20 57 -83q87 -162 54 -278q-11 -40 -50 -42q-31 -4 -38.5 18.5t-8 83.5t-11.5 107q-9 39 -19.5 69t-19.5 45.5t-15.5 24.5t-13 15t-7.5 7 q-14 62 -31 103t-29.5 56t-23.5 33t-15 40q-4 21 6 53.5t4.5 49.5t-44.5 25q-15 3 -44.5 18t-35.5 16q-8 1 -11 26t8 51t36 27q37 3 51 -30t4 -58q-11 -19 -2 -26.5t30 -0.5q13 4 13 36v37q-5 30 -13.5 50t-21 30.5t-23.5 15t-27 7.5q-107 -8 -89 -134q0 -15 -1 -15 q-9 9 -29.5 10.5t-33 -0.5t-15.5 5q1 57 -16 90t-45 34q-27 1 -41.5 -27.5t-16.5 -59.5q-1 -15 3.5 -37t13 -37.5t15.5 -13.5q10 3 16 14q4 9 -7 8q-7 0 -15.5 14.5t-9.5 33.5q-1 22 9 37t34 14q17 0 27 -21t9.5 -39t-1.5 -22q-22 -15 -31 -29q-8 -12 -27.5 -23.5 t-20.5 -12.5q-13 -14 -15.5 -27t7.5 -18q14 -8 25 -19.5t16 -19t18.5 -13t35.5 -6.5q47 -2 102 15q2 1 23 7t34.5 10.5t29.5 13t21 17.5q9 14 20 8q5 -3 6.5 -8.5t-3 -12t-16.5 -9.5q-20 -6 -56.5 -21.5t-45.5 -19.5q-44 -19 -70 -23q-25 -5 -79 2q-10 2 -9 -2t17 -19 q25 -23 67 -22q17 1 36 7t36 14t33.5 17.5t30 17t24.5 12t17.5 2.5t8.5 -11q0 -2 -1 -4.5t-4 -5t-6 -4.5t-8.5 -5t-9 -4.5t-10 -5t-9.5 -4.5q-28 -14 -67.5 -44t-66.5 -43t-49 -1q-21 11 -63 73q-22 31 -25 22q-1 -3 -1 -10q0 -25 -15 -56.5t-29.5 -55.5t-21 -58t11.5 -63 q-23 -6 -62.5 -90t-47.5 -141q-2 -18 -1.5 -69t-5.5 -59q-8 -24 -29 -3q-32 31 -36 94q-2 28 4 56q4 19 -1 18l-4 -5q-36 -65 10 -166q5 -12 25 -28t24 -20q20 -23 104 -90.5t93 -76.5q16 -15 17.5 -38t-14 -43t-45.5 -23q8 -15 29 -44.5t28 -54t7 -70.5q46 24 7 92 q-4 8 -10.5 16t-9.5 12t-2 6q3 5 13 9.5t20 -2.5q46 -52 166 -36q133 15 177 87q23 38 34 30q12 -6 10 -52q-1 -25 -23 -92q-9 -23 -6 -37.5t24 -15.5q3 19 14.5 77t13.5 90q2 21 -6.5 73.5t-7.5 97t23 70.5q15 18 51 18q1 37 34.5 53t72.5 10.5t60 -22.5zM626 1152 q3 17 -2.5 30t-11.5 15q-9 2 -9 -7q2 -5 5 -6q10 0 7 -15q-3 -20 8 -20q3 0 3 3zM1045 955q-2 8 -6.5 11.5t-13 5t-14.5 5.5q-5 3 -9.5 8t-7 8t-5.5 6.5t-4 4t-4 -1.5q-14 -16 7 -43.5t39 -31.5q9 -1 14.5 8t3.5 20zM867 1168q0 11 -5 19.5t-11 12.5t-9 3q-14 -1 -7 -7l4 -2 q14 -4 18 -31q0 -3 8 2zM921 1401q0 2 -2.5 5t-9 7t-9.5 6q-15 15 -24 15q-9 -1 -11.5 -7.5t-1 -13t-0.5 -12.5q-1 -4 -6 -10.5t-6 -9t3 -8.5q4 -3 8 0t11 9t15 9q1 1 9 1t15 2t9 7zM1486 60q20 -12 31 -24.5t12 -24t-2.5 -22.5t-15.5 -22t-23.5 -19.5t-30 -18.5 t-31.5 -16.5t-32 -15.5t-27 -13q-38 -19 -85.5 -56t-75.5 -64q-17 -16 -68 -19.5t-89 14.5q-18 9 -29.5 23.5t-16.5 25.5t-22 19.5t-47 9.5q-44 1 -130 1q-19 0 -57 -1.5t-58 -2.5q-44 -1 -79.5 -15t-53.5 -30t-43.5 -28.5t-53.5 -11.5q-29 1 -111 31t-146 43q-19 4 -51 9.5 t-50 9t-39.5 9.5t-33.5 14.5t-17 19.5q-10 23 7 66.5t18 54.5q1 16 -4 40t-10 42.5t-4.5 36.5t10.5 27q14 12 57 14t60 12q30 18 42 35t12 51q21 -73 -32 -106q-32 -20 -83 -15q-34 3 -43 -10q-13 -15 5 -57q2 -6 8 -18t8.5 -18t4.5 -17t1 -22q0 -15 -17 -49t-14 -48 q3 -17 37 -26q20 -6 84.5 -18.5t99.5 -20.5q24 -6 74 -22t82.5 -23t55.5 -4q43 6 64.5 28t23 48t-7.5 58.5t-19 52t-20 36.5q-121 190 -169 242q-68 74 -113 40q-11 -9 -15 15q-3 16 -2 38q1 29 10 52t24 47t22 42q8 21 26.5 72t29.5 78t30 61t39 54q110 143 124 195 q-12 112 -16 310q-2 90 24 151.5t106 104.5q39 21 104 21q53 1 106 -13.5t89 -41.5q57 -42 91.5 -121.5t29.5 -147.5q-5 -95 30 -214q34 -113 133 -218q55 -59 99.5 -163t59.5 -191q8 -49 5 -84.5t-12 -55.5t-20 -22q-10 -2 -23.5 -19t-27 -35.5t-40.5 -33.5t-61 -14 q-18 1 -31.5 5t-22.5 13.5t-13.5 15.5t-11.5 20.5t-9 19.5q-22 37 -41 30t-28 -49t7 -97q20 -70 1 -195q-10 -65 18 -100.5t73 -33t85 35.5q59 49 89.5 66.5t103.5 42.5q53 18 77 36.5t18.5 34.5t-25 28.5t-51.5 23.5q-33 11 -49.5 48t-15 72.5t15.5 47.5q1 -31 8 -56.5 t14.5 -40.5t20.5 -28.5t21 -19t21.5 -13t16.5 -9.5z" />
+<glyph unicode="&#xf17d;" d="M1024 36q-42 241 -140 498h-2l-2 -1q-16 -6 -43 -16.5t-101 -49t-137 -82t-131 -114.5t-103 -148l-15 11q184 -150 418 -150q132 0 256 52zM839 643q-21 49 -53 111q-311 -93 -673 -93q-1 -7 -1 -21q0 -124 44 -236.5t124 -201.5q50 89 123.5 166.5t142.5 124.5t130.5 81 t99.5 48l37 13q4 1 13 3.5t13 4.5zM732 855q-120 213 -244 378q-138 -65 -234 -186t-128 -272q302 0 606 80zM1416 536q-210 60 -409 29q87 -239 128 -469q111 75 185 189.5t96 250.5zM611 1277q-1 0 -2 -1q1 1 2 1zM1201 1132q-185 164 -433 164q-76 0 -155 -19 q131 -170 246 -382q69 26 130 60.5t96.5 61.5t65.5 57t37.5 40.5zM1424 647q-3 232 -149 410l-1 -1q-9 -12 -19 -24.5t-43.5 -44.5t-71 -60.5t-100 -65t-131.5 -64.5q25 -53 44 -95q2 -6 6.5 -17.5t7.5 -16.5q36 5 74.5 7t73.5 2t69 -1.5t64 -4t56.5 -5.5t48 -6.5t36.5 -6 t25 -4.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf17e;" d="M1173 473q0 50 -19.5 91.5t-48.5 68.5t-73 49t-82.5 34t-87.5 23l-104 24q-30 7 -44 10.5t-35 11.5t-30 16t-16.5 21t-7.5 30q0 77 144 77q43 0 77 -12t54 -28.5t38 -33.5t40 -29t48 -12q47 0 75.5 32t28.5 77q0 55 -56 99.5t-142 67.5t-182 23q-68 0 -132 -15.5 t-119.5 -47t-89 -87t-33.5 -128.5q0 -61 19 -106.5t56 -75.5t80 -48.5t103 -32.5l146 -36q90 -22 112 -36q32 -20 32 -60q0 -39 -40 -64.5t-105 -25.5q-51 0 -91.5 16t-65 38.5t-45.5 45t-46 38.5t-54 16q-50 0 -75.5 -30t-25.5 -75q0 -92 122 -157.5t291 -65.5 q73 0 140 18.5t122.5 53.5t88.5 93.5t33 131.5zM1536 256q0 -159 -112.5 -271.5t-271.5 -112.5q-130 0 -234 80q-77 -16 -150 -16q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5q0 73 16 150q-80 104 -80 234q0 159 112.5 271.5t271.5 112.5q130 0 234 -80 q77 16 150 16q143 0 273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -73 -16 -150q80 -104 80 -234z" />
+<glyph unicode="&#xf180;" horiz-adv-x="1664" d="M1483 512l-587 -587q-52 -53 -127.5 -53t-128.5 53l-587 587q-53 53 -53 128t53 128l587 587q53 53 128 53t128 -53l265 -265l-398 -399l-188 188q-42 42 -99 42q-59 0 -100 -41l-120 -121q-42 -40 -42 -99q0 -58 42 -100l406 -408q30 -28 67 -37l6 -4h28q60 0 99 41 l619 619l2 -3q53 -53 53 -128t-53 -128zM1406 1138l120 -120q14 -15 14 -36t-14 -36l-730 -730q-17 -15 -37 -15v0q-4 0 -6 1q-18 2 -30 14l-407 408q-14 15 -14 36t14 35l121 120q13 15 35 15t36 -15l252 -252l574 575q15 15 36 15t36 -15z" />
+<glyph unicode="&#xf181;" d="M704 192v1024q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-1024q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1376 576v640q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-640q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408 q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf182;" horiz-adv-x="1280" d="M1280 480q0 -40 -28 -68t-68 -28q-51 0 -80 43l-227 341h-45v-132l247 -411q9 -15 9 -33q0 -26 -19 -45t-45 -19h-192v-272q0 -46 -33 -79t-79 -33h-160q-46 0 -79 33t-33 79v272h-192q-26 0 -45 19t-19 45q0 18 9 33l247 411v132h-45l-227 -341q-29 -43 -80 -43 q-40 0 -68 28t-28 68q0 29 16 53l256 384q73 107 176 107h384q103 0 176 -107l256 -384q16 -24 16 -53zM864 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" />
+<glyph unicode="&#xf183;" horiz-adv-x="1024" d="M1024 832v-416q0 -40 -28 -68t-68 -28t-68 28t-28 68v352h-64v-912q0 -46 -33 -79t-79 -33t-79 33t-33 79v464h-64v-464q0 -46 -33 -79t-79 -33t-79 33t-33 79v912h-64v-352q0 -40 -28 -68t-68 -28t-68 28t-28 68v416q0 80 56 136t136 56h640q80 0 136 -56t56 -136z M736 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" />
+<glyph unicode="&#xf184;" d="M773 234l350 473q16 22 24.5 59t-6 85t-61.5 79q-40 26 -83 25.5t-73.5 -17.5t-54.5 -45q-36 -40 -96 -40q-59 0 -95 40q-24 28 -54.5 45t-73.5 17.5t-84 -25.5q-46 -31 -60.5 -79t-6 -85t24.5 -59zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf185;" horiz-adv-x="1792" d="M1472 640q0 117 -45.5 223.5t-123 184t-184 123t-223.5 45.5t-223.5 -45.5t-184 -123t-123 -184t-45.5 -223.5t45.5 -223.5t123 -184t184 -123t223.5 -45.5t223.5 45.5t184 123t123 184t45.5 223.5zM1748 363q-4 -15 -20 -20l-292 -96v-306q0 -16 -13 -26q-15 -10 -29 -4 l-292 94l-180 -248q-10 -13 -26 -13t-26 13l-180 248l-292 -94q-14 -6 -29 4q-13 10 -13 26v306l-292 96q-16 5 -20 20q-5 17 4 29l180 248l-180 248q-9 13 -4 29q4 15 20 20l292 96v306q0 16 13 26q15 10 29 4l292 -94l180 248q9 12 26 12t26 -12l180 -248l292 94 q14 6 29 -4q13 -10 13 -26v-306l292 -96q16 -5 20 -20q5 -16 -4 -29l-180 -248l180 -248q9 -12 4 -29z" />
+<glyph unicode="&#xf186;" d="M1262 233q-54 -9 -110 -9q-182 0 -337 90t-245 245t-90 337q0 192 104 357q-201 -60 -328.5 -229t-127.5 -384q0 -130 51 -248.5t136.5 -204t204 -136.5t248.5 -51q144 0 273.5 61.5t220.5 171.5zM1465 318q-94 -203 -283.5 -324.5t-413.5 -121.5q-156 0 -298 61 t-245 164t-164 245t-61 298q0 153 57.5 292.5t156 241.5t235.5 164.5t290 68.5q44 2 61 -39q18 -41 -15 -72q-86 -78 -131.5 -181.5t-45.5 -218.5q0 -148 73 -273t198 -198t273 -73q118 0 228 51q41 18 72 -13q14 -14 17.5 -34t-4.5 -38z" />
+<glyph unicode="&#xf187;" horiz-adv-x="1792" d="M1088 704q0 26 -19 45t-45 19h-256q-26 0 -45 -19t-19 -45t19 -45t45 -19h256q26 0 45 19t19 45zM1664 896v-960q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v960q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1728 1344v-256q0 -26 -19 -45t-45 -19h-1536 q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1536q26 0 45 -19t19 -45z" />
+<glyph unicode="&#xf188;" horiz-adv-x="1664" d="M1632 576q0 -26 -19 -45t-45 -19h-224q0 -171 -67 -290l208 -209q19 -19 19 -45t-19 -45q-18 -19 -45 -19t-45 19l-198 197q-5 -5 -15 -13t-42 -28.5t-65 -36.5t-82 -29t-97 -13v896h-128v-896q-51 0 -101.5 13.5t-87 33t-66 39t-43.5 32.5l-15 14l-183 -207 q-20 -21 -48 -21q-24 0 -43 16q-19 18 -20.5 44.5t15.5 46.5l202 227q-58 114 -58 274h-224q-26 0 -45 19t-19 45t19 45t45 19h224v294l-173 173q-19 19 -19 45t19 45t45 19t45 -19l173 -173h844l173 173q19 19 45 19t45 -19t19 -45t-19 -45l-173 -173v-294h224q26 0 45 -19 t19 -45zM1152 1152h-640q0 133 93.5 226.5t226.5 93.5t226.5 -93.5t93.5 -226.5z" />
+<glyph unicode="&#xf189;" horiz-adv-x="1920" d="M1917 1016q23 -64 -150 -294q-24 -32 -65 -85q-78 -100 -90 -131q-17 -41 14 -81q17 -21 81 -82h1l1 -1l1 -1l2 -2q141 -131 191 -221q3 -5 6.5 -12.5t7 -26.5t-0.5 -34t-25 -27.5t-59 -12.5l-256 -4q-24 -5 -56 5t-52 22l-20 12q-30 21 -70 64t-68.5 77.5t-61 58 t-56.5 15.5q-3 -1 -8 -3.5t-17 -14.5t-21.5 -29.5t-17 -52t-6.5 -77.5q0 -15 -3.5 -27.5t-7.5 -18.5l-4 -5q-18 -19 -53 -22h-115q-71 -4 -146 16.5t-131.5 53t-103 66t-70.5 57.5l-25 24q-10 10 -27.5 30t-71.5 91t-106 151t-122.5 211t-130.5 272q-6 16 -6 27t3 16l4 6 q15 19 57 19l274 2q12 -2 23 -6.5t16 -8.5l5 -3q16 -11 24 -32q20 -50 46 -103.5t41 -81.5l16 -29q29 -60 56 -104t48.5 -68.5t41.5 -38.5t34 -14t27 5q2 1 5 5t12 22t13.5 47t9.5 81t0 125q-2 40 -9 73t-14 46l-6 12q-25 34 -85 43q-13 2 5 24q17 19 38 30q53 26 239 24 q82 -1 135 -13q20 -5 33.5 -13.5t20.5 -24t10.5 -32t3.5 -45.5t-1 -55t-2.5 -70.5t-1.5 -82.5q0 -11 -1 -42t-0.5 -48t3.5 -40.5t11.5 -39t22.5 -24.5q8 -2 17 -4t26 11t38 34.5t52 67t68 107.5q60 104 107 225q4 10 10 17.5t11 10.5l4 3l5 2.5t13 3t20 0.5l288 2 q39 5 64 -2.5t31 -16.5z" />
+<glyph unicode="&#xf18a;" horiz-adv-x="1792" d="M675 252q21 34 11 69t-45 50q-34 14 -73 1t-60 -46q-22 -34 -13 -68.5t43 -50.5t74.5 -2.5t62.5 47.5zM769 373q8 13 3.5 26.5t-17.5 18.5q-14 5 -28.5 -0.5t-21.5 -18.5q-17 -31 13 -45q14 -5 29 0.5t22 18.5zM943 266q-45 -102 -158 -150t-224 -12 q-107 34 -147.5 126.5t6.5 187.5q47 93 151.5 139t210.5 19q111 -29 158.5 -119.5t2.5 -190.5zM1255 426q-9 96 -89 170t-208.5 109t-274.5 21q-223 -23 -369.5 -141.5t-132.5 -264.5q9 -96 89 -170t208.5 -109t274.5 -21q223 23 369.5 141.5t132.5 264.5zM1563 422 q0 -68 -37 -139.5t-109 -137t-168.5 -117.5t-226 -83t-270.5 -31t-275 33.5t-240.5 93t-171.5 151t-65 199.5q0 115 69.5 245t197.5 258q169 169 341.5 236t246.5 -7q65 -64 20 -209q-4 -14 -1 -20t10 -7t14.5 0.5t13.5 3.5l6 2q139 59 246 59t153 -61q45 -63 0 -178 q-2 -13 -4.5 -20t4.5 -12.5t12 -7.5t17 -6q57 -18 103 -47t80 -81.5t34 -116.5zM1489 1046q42 -47 54.5 -108.5t-6.5 -117.5q-8 -23 -29.5 -34t-44.5 -4q-23 8 -34 29.5t-4 44.5q20 63 -24 111t-107 35q-24 -5 -45 8t-25 37q-5 24 8 44.5t37 25.5q60 13 119 -5.5t101 -65.5z M1670 1209q87 -96 112.5 -222.5t-13.5 -241.5q-9 -27 -34 -40t-52 -4t-40 34t-5 52q28 82 10 172t-80 158q-62 69 -148 95.5t-173 8.5q-28 -6 -52 9.5t-30 43.5t9.5 51.5t43.5 29.5q123 26 244 -11.5t208 -134.5z" />
+<glyph unicode="&#xf18b;" d="M1133 -34q-171 -94 -368 -94q-196 0 -367 94q138 87 235.5 211t131.5 268q35 -144 132.5 -268t235.5 -211zM638 1394v-485q0 -252 -126.5 -459.5t-330.5 -306.5q-181 215 -181 495q0 187 83.5 349.5t229.5 269.5t325 137zM1536 638q0 -280 -181 -495 q-204 99 -330.5 306.5t-126.5 459.5v485q179 -30 325 -137t229.5 -269.5t83.5 -349.5z" />
+<glyph unicode="&#xf18c;" horiz-adv-x="1408" d="M1402 433q-32 -80 -76 -138t-91 -88.5t-99 -46.5t-101.5 -14.5t-96.5 8.5t-86.5 22t-69.5 27.5t-46 22.5l-17 10q-113 -228 -289.5 -359.5t-384.5 -132.5q-19 0 -32 13t-13 32t13 31.5t32 12.5q173 1 322.5 107.5t251.5 294.5q-36 -14 -72 -23t-83 -13t-91 2.5t-93 28.5 t-92 59t-84.5 100t-74.5 146q114 47 214 57t167.5 -7.5t124.5 -56.5t88.5 -77t56.5 -82q53 131 79 291q-7 -1 -18 -2.5t-46.5 -2.5t-69.5 0.5t-81.5 10t-88.5 23t-84 42.5t-75 65t-54.5 94.5t-28.5 127.5q70 28 133.5 36.5t112.5 -1t92 -30t73.5 -50t56 -61t42 -63t27.5 -56 t16 -39.5l4 -16q12 122 12 195q-8 6 -21.5 16t-49 44.5t-63.5 71.5t-54 93t-33 112.5t12 127t70 138.5q73 -25 127.5 -61.5t84.5 -76.5t48 -85t20.5 -89t-0.5 -85.5t-13 -76.5t-19 -62t-17 -42l-7 -15q1 -5 1 -50.5t-1 -71.5q3 7 10 18.5t30.5 43t50.5 58t71 55.5t91.5 44.5 t112 14.5t132.5 -24q-2 -78 -21.5 -141.5t-50 -104.5t-69.5 -71.5t-81.5 -45.5t-84.5 -24t-80 -9.5t-67.5 1t-46.5 4.5l-17 3q-23 -147 -73 -283q6 7 18 18.5t49.5 41t77.5 52.5t99.5 42t117.5 20t129 -23.5t137 -77.5z" />
+<glyph unicode="&#xf18d;" horiz-adv-x="1280" d="M1259 283v-66q0 -85 -57.5 -144.5t-138.5 -59.5h-57l-260 -269v269h-529q-81 0 -138.5 59.5t-57.5 144.5v66h1238zM1259 609v-255h-1238v255h1238zM1259 937v-255h-1238v255h1238zM1259 1077v-67h-1238v67q0 84 57.5 143.5t138.5 59.5h846q81 0 138.5 -59.5t57.5 -143.5z " />
+<glyph unicode="&#xf18e;" d="M1152 640q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192h-352q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h352v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf190;" d="M1152 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-352v-192q0 -14 -9 -23t-23 -9q-12 0 -24 10l-319 319q-9 9 -9 23t9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h352q13 0 22.5 -9.5t9.5 -22.5zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf191;" d="M1024 960v-640q0 -26 -19 -45t-45 -19q-20 0 -37 12l-448 320q-27 19 -27 52t27 52l448 320q17 12 37 12q26 0 45 -19t19 -45zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5z M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf192;" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5 t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" />
+<glyph unicode="&#xf193;" horiz-adv-x="1664" d="M1023 349l102 -204q-58 -179 -210 -290t-339 -111q-156 0 -288.5 77.5t-210 210t-77.5 288.5q0 181 104.5 330t274.5 211l17 -131q-122 -54 -195 -165.5t-73 -244.5q0 -185 131.5 -316.5t316.5 -131.5q126 0 232.5 65t165 175.5t49.5 236.5zM1571 249l58 -114l-256 -128 q-13 -7 -29 -7q-40 0 -57 35l-239 477h-472q-24 0 -42.5 16.5t-21.5 40.5l-96 779q-2 16 6 42q14 51 57 82.5t97 31.5q66 0 113 -47t47 -113q0 -69 -52 -117.5t-120 -41.5l37 -289h423v-128h-407l16 -128h455q40 0 57 -35l228 -455z" />
+<glyph unicode="&#xf194;" d="M1254 899q16 85 -21 132q-52 65 -187 45q-17 -3 -41 -12.5t-57.5 -30.5t-64.5 -48.5t-59.5 -70t-44.5 -91.5q80 7 113.5 -16t26.5 -99q-5 -52 -52 -143q-43 -78 -71 -99q-44 -32 -87 14q-23 24 -37.5 64.5t-19 73t-10 84t-8.5 71.5q-23 129 -34 164q-12 37 -35.5 69 t-50.5 40q-57 16 -127 -25q-54 -32 -136.5 -106t-122.5 -102v-7q16 -8 25.5 -26t21.5 -20q21 -3 54.5 8.5t58 10.5t41.5 -30q11 -18 18.5 -38.5t15 -48t12.5 -40.5q17 -46 53 -187q36 -146 57 -197q42 -99 103 -125q43 -12 85 -1.5t76 31.5q131 77 250 237 q104 139 172.5 292.5t82.5 226.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf195;" horiz-adv-x="1152" d="M1152 704q0 -191 -94.5 -353t-256.5 -256.5t-353 -94.5h-160q-14 0 -23 9t-9 23v611l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v93l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v250q0 14 9 23t23 9h160 q14 0 23 -9t9 -23v-181l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-93l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-487q188 13 318 151t130 328q0 14 9 23t23 9h160q14 0 23 -9t9 -23z" />
+<glyph unicode="&#xf196;" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-352v-352q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v352h-352q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h352v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-352h352q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832 q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" />
+<glyph unicode="&#xf197;" horiz-adv-x="1792" />
+<glyph unicode="&#xf198;" horiz-adv-x="1792" />
+<glyph unicode="&#xf199;" horiz-adv-x="1792" />
+<glyph unicode="&#xf19a;" horiz-adv-x="1792" />
+<glyph unicode="&#xf19b;" horiz-adv-x="1792" />
+<glyph unicode="&#xf19c;" horiz-adv-x="1792" />
+<glyph unicode="&#xf19d;" horiz-adv-x="1792" />
+<glyph unicode="&#xf19e;" horiz-adv-x="1792" />
+<glyph unicode="&#xf500;" horiz-adv-x="1792" />
+</font>
+</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/fonts/fontawesome-webfont.ttf b/karmaworld/assets/css/fonts/fontawesome-webfont.ttf
new file mode 100755 (executable)
index 0000000..e89738d
Binary files /dev/null and b/karmaworld/assets/css/fonts/fontawesome-webfont.ttf differ
diff --git a/karmaworld/assets/css/fonts/fontawesome-webfont.woff b/karmaworld/assets/css/fonts/fontawesome-webfont.woff
new file mode 100755 (executable)
index 0000000..8c1748a
Binary files /dev/null and b/karmaworld/assets/css/fonts/fontawesome-webfont.woff differ
diff --git a/karmaworld/assets/css/fonts/museo300-regular-webfont.eot b/karmaworld/assets/css/fonts/museo300-regular-webfont.eot
new file mode 100644 (file)
index 0000000..7368129
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo300-regular-webfont.eot differ
diff --git a/karmaworld/assets/css/fonts/museo300-regular-webfont.svg b/karmaworld/assets/css/fonts/museo300-regular-webfont.svg
new file mode 100644 (file)
index 0000000..8002a77
--- /dev/null
@@ -0,0 +1,1006 @@
+<?xml version="1.0" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
+<svg xmlns="http://www.w3.org/2000/svg">
+<metadata></metadata>
+<defs>
+<font id="museo300" horiz-adv-x="1241" >
+<font-face units-per-em="2048" ascent="1536" descent="-512" />
+<missing-glyph horiz-adv-x="557" />
+<glyph unicode="&#xfb01;" horiz-adv-x="1118" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -51 4q-23 0 -44.5 -3.5t-49 -12.5t-50 -27.5t-42.5 -45.5t-31 -70.5t-11 -98.5v-37h488q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5 t-29.5 95.5v743q0 45 -45 45h-429v-913h-139v913h-129zM788 1264v176h136v-176h-136z" />
+<glyph unicode="&#xfb02;" horiz-adv-x="1105" d="M51 913v117h129v37q0 70 14 127.5t36 95.5t54 66.5t63 44t68 25t64 12t56 2.5h260q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-186q-29 0 -54.5 -4t-59.5 -19t-58 -41t-41 -74.5t-17 -113.5v-37h263 v-117h-263v-913h-139v913h-129z" />
+<glyph unicode="&#xfb03;" horiz-adv-x="1722" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -49 4t-55.5 -4.5t-59.5 -21t-57.5 -43t-41 -76t-16.5 -115.5v-35h465v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-20 4 -49 4t-55 -4.5t-59.5 -21 t-57.5 -43t-40.5 -76t-16.5 -115.5v-35h487q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v743q0 45 -45 45h-428v-913h-140v913h-465v-913h-139v913h-129zM1393 1264v176h135v-176h-135z" />
+<glyph unicode="&#xfb04;" horiz-adv-x="1708" d="M51 913v117h129v43q0 80 17 143.5t47.5 103t65.5 67t77 40.5t75 18t68 5l68 -4v-125q-22 4 -53 4q-29 0 -55.5 -4.5t-59 -21t-56 -42.5t-39.5 -74t-16 -112v-41h465v37q0 70 14 127.5t36 95.5t54 66.5t63 44t68 25t64 12t56 2.5h260q66 0 95.5 -29.5t29.5 -95.5v-1149 q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-186q-29 0 -54.5 -4t-59.5 -19t-57.5 -41t-40.5 -74.5t-17 -113.5v-37h262v-117h-262v-913h-140v913h-465v-913h-139v913h-129z" />
+<glyph horiz-adv-x="2048" />
+<glyph horiz-adv-x="2048" />
+<glyph unicode="&#xd;" horiz-adv-x="2048" />
+<glyph unicode=" "  horiz-adv-x="557" />
+<glyph unicode="&#x09;" horiz-adv-x="557" />
+<glyph unicode="&#xa0;" horiz-adv-x="557" />
+<glyph unicode="!" horiz-adv-x="608" d="M227 0v158h158v-158h-158zM231 1440h144l-6 -1063h-131z" />
+<glyph unicode="&#x22;" horiz-adv-x="638" d="M135 1114v346h121v-346h-121zM383 1114v346h121v-346h-121z" />
+<glyph unicode="#" horiz-adv-x="1460" d="M84 399l20 115h289l72 401h-289l19 115h290l72 410h125l-72 -410h355l71 410h125l-71 -410h286l-20 -115h-287l-70 -401h285l-18 -115h-287l-70 -399h-125l70 399h-354l-70 -399h-125l70 399h-291zM520 514h352l72 401h-354z" />
+<glyph unicode="$" horiz-adv-x="1089" d="M94 246l107 86q5 -9 14.5 -24t43 -53.5t72 -68t102 -53.5t132.5 -24q128 0 206.5 73.5t78.5 182.5q0 57 -24.5 104t-65.5 80.5t-94.5 63t-112.5 56.5t-117.5 55t-112 64t-94.5 79t-65.5 104t-24.5 135q0 135 101 233.5t266 118.5v195h117v-191q57 -5 111 -20t107 -42.5 t85 -75t32 -107.5v-103h-135v68q0 64 -70 106.5t-171 42.5q-135 0 -215 -64.5t-80 -158.5q0 -69 39 -123t102 -90t138.5 -69t151 -72t138.5 -86.5t102 -123t39 -173.5q0 -149 -102.5 -261.5t-271.5 -129.5v-191h-117v191q-58 6 -112 24t-94.5 41.5t-75.5 51t-58 54t-40 48 t-24 34.5z" />
+<glyph unicode="%" horiz-adv-x="1521" d="M127 1180q0 117 83.5 200.5t203.5 83.5t204 -83.5t84 -200.5q0 -119 -84 -202t-204 -83t-203.5 83t-83.5 202zM139 0l1098 1440h145l-1095 -1440h-148zM248 1180q0 -71 48 -120.5t118 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-118 -50t-48 -120zM819 258 q0 119 83.5 203t203.5 84t204.5 -84t84.5 -203q0 -117 -84.5 -200t-204.5 -83t-203.5 83t-83.5 200zM942 260q0 -71 47 -120.5t117 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-117 -50t-47 -120z" />
+<glyph unicode="&#x26;" horiz-adv-x="1277" d="M94 401q0 127 69 233.5t191 141.5v4q-8 3 -21.5 8.5t-47.5 30.5t-60 57.5t-47.5 92t-21.5 131.5q0 162 116 263t310 101q35 0 77 -5.5t67 -10.5l24 -6l-41 -117q-68 14 -119 14q-126 0 -206.5 -68t-80.5 -179q0 -33 6 -64.5t26 -68.5t52 -64t90 -45.5t135 -18.5h299v199 h142v-199h190v-126h-190v-211q0 -253 -126.5 -386t-346.5 -133q-213 0 -349.5 121.5t-136.5 304.5zM240 406q0 -126 92 -211.5t248 -85.5t243.5 95t87.5 294v207h-295q-184 0 -280 -80t-96 -219z" />
+<glyph unicode="'" horiz-adv-x="391" d="M135 1114v346h121v-346h-121z" />
+<glyph unicode="(" horiz-adv-x="632" d="M174 680q0 461 221 815h131q-223 -375 -223 -805q0 -474 236 -885h-129q-112 184 -174 412t-62 463z" />
+<glyph unicode=")" horiz-adv-x="632" d="M94 -195q236 411 236 885q0 429 -224 805h132q221 -361 221 -815q0 -235 -62 -463t-174 -412h-129z" />
+<glyph unicode="*" horiz-adv-x="976" d="M94 1104l41 129l295 -109l-12 316h139l-14 -316l299 107l41 -125l-303 -88v-4l192 -246l-106 -80l-177 260h-4l-174 -258l-108 78l192 246v4z" />
+<glyph unicode="+" d="M86 522v119h473v522h125v-522h471v-119h-471v-522h-125v522h-473z" />
+<glyph unicode="," horiz-adv-x="440" d="M47 -199l117 367h149l-149 -367h-117z" />
+<glyph unicode="-" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
+<glyph unicode="." horiz-adv-x="440" d="M141 0v164h158v-164h-158z" />
+<glyph unicode="/" horiz-adv-x="665" d="M6 -86l520 1606h129l-518 -1606h-131z" />
+<glyph unicode="0" horiz-adv-x="1232" d="M121 721q0 129 15 237t51.5 203t92 161t141 104t195.5 38t195.5 -38t142 -104t93 -161t52 -203t15.5 -237q0 -130 -15.5 -238.5t-52 -204t-93 -161.5t-142 -104t-195.5 -38t-195.5 38t-141 104t-92 161.5t-51.5 204t-15 238.5zM266 721q0 -108 10 -196.5t35 -167.5 t64 -132.5t100 -84.5t141 -31q99 0 169 46t109 132t56 192t17 242q0 135 -17 240.5t-56 191.5t-109 132t-169 46q-80 0 -141 -31t-100 -84.5t-64 -132.5t-35 -167t-10 -195z" />
+<glyph unicode="1" horiz-adv-x="974" d="M131 0v127h322v1057l2 80h-4q-15 -31 -72 -86l-154 -154l-90 92l326 324h135v-1313h315v-127h-780z" />
+<glyph unicode="2" horiz-adv-x="1155" d="M86 141q0 86 26 158t70 124.5t101.5 98t120.5 82.5t126 72.5t120.5 74.5t101.5 82t70 100.5t26 125.5q0 118 -80.5 194t-214.5 76q-106 0 -181 -46.5t-75 -108.5v-68h-135v106q0 64 40.5 115.5t102.5 79.5t127.5 42.5t124.5 14.5q200 0 319 -115t119 -288 q0 -81 -26 -150.5t-70 -120.5t-101.5 -96t-120.5 -82.5t-126 -73t-120.5 -74t-101.5 -80.5t-70 -97t-26 -119q0 -41 48 -41h602q45 0 45 45v96h133v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-721q-72 0 -100.5 32.5t-28.5 108.5z" />
+<glyph unicode="3" horiz-adv-x="1081" d="M53 176l86 107q6 -7 17.5 -18.5t49 -41t79 -52.5t104.5 -41.5t127 -18.5q132 0 229 88.5t97 222.5q0 140 -103 221.5t-247 81.5h-101l-33 84l355 426q16 21 34 41t29 30l10 9v4q-40 -6 -116 -6h-375q-45 0 -45 -45v-97h-133v144q0 67 28 96t93 29h731v-94l-424 -498 q58 -3 115.5 -18t118 -47t106.5 -78.5t75 -119t29 -161.5q0 -121 -61.5 -224t-171 -164t-242.5 -61q-80 0 -156.5 20.5t-129.5 50t-94 59.5t-61 51z" />
+<glyph unicode="4" horiz-adv-x="1150" d="M31 397v95l700 948h154v-916h229v-127h-229v-397h-144v397h-710zM197 518q57 6 118 6h428v588l7 139h-5q-34 -59 -73 -110l-400 -529q-17 -23 -36 -45.5t-29 -33.5l-10 -11v-4z" />
+<glyph unicode="5" horiz-adv-x="1165" d="M111 180l90 101q4 -7 13 -18.5t40 -40.5t66.5 -51.5t93.5 -41t121 -18.5q153 0 255.5 96t102.5 239q0 147 -108 242.5t-265 95.5q-72 0 -141 -20t-102 -40l-33 -19l-74 30l61 580q6 68 33.5 96.5t91.5 28.5h473q65 0 94 -29.5t29 -95.5v-144h-133v97q0 45 -45 45h-364 q-21 0 -31.5 -10.5t-13.5 -34.5l-37 -326l-13 -82h4q10 6 28.5 15t76 23.5t113.5 14.5q217 0 360 -136t143 -333q0 -127 -64.5 -234.5t-181 -171t-259.5 -63.5q-80 0 -153.5 21t-120.5 51t-82.5 60.5t-51.5 51.5z" />
+<glyph unicode="6" horiz-adv-x="1146" d="M88 633q0 114 22.5 227.5t73 223t122.5 193.5t179.5 135.5t235.5 51.5q70 0 136 -15t97 -29l31 -15l-53 -125q-10 6 -28.5 14.5t-73 22.5t-107.5 14q-87 0 -162.5 -34t-129.5 -90.5t-94.5 -133.5t-63.5 -160.5t-31 -173.5h4q50 82 150 128t216 46q197 0 323 -127.5 t126 -328.5q0 -219 -129.5 -350.5t-323.5 -131.5q-154 0 -273 85.5t-183 235t-64 337.5zM242 541q0 -97 45 -195.5t131 -167.5t188 -69q143 0 226 96.5t83 249.5q0 151 -88.5 241t-236.5 90q-140 0 -244 -77t-104 -168z" />
+<glyph unicode="7" horiz-adv-x="1048" d="M61 1171v144q0 66 28.5 95.5t94.5 29.5h850v-99l-712 -1341h-160l626 1180q18 35 38 68t31 49l11 16v4q-36 -4 -108 -4h-518q-45 0 -45 -45v-97h-136z" />
+<glyph unicode="8" horiz-adv-x="1167" d="M96 406q0 71 26.5 136t64 107.5t75 75t64.5 47.5l26 14v5q-8 4 -21 11t-47 34t-60 58t-47 83.5t-21 109.5q0 75 29 143t83 120t137 83t185 31q201 0 320.5 -106.5t119.5 -276.5q0 -61 -20 -120.5t-48 -100t-56 -72.5t-48 -48l-20 -15v-4q112 -58 171.5 -135t59.5 -195 q0 -171 -140 -293.5t-343 -122.5q-129 0 -239.5 50t-180.5 150t-70 231zM244 412q0 -91 49 -161.5t126.5 -106t166.5 -35.5q133 0 234.5 81t101.5 203q0 54 -20 96t-62.5 74t-83.5 53t-109 48q-40 18 -98 37.5t-70 19.5q-22 0 -60 -24t-77.5 -63t-68.5 -99.5t-29 -122.5z M299 1087q0 -44 15.5 -80.5t37.5 -61.5t62 -48.5t73.5 -37.5t87.5 -34q107 -39 130 -39q19 0 50 25t60.5 64t50.5 94t21 108q0 116 -82.5 185t-214.5 69q-133 0 -212 -70t-79 -174z" />
+<glyph unicode="9" horiz-adv-x="1146" d="M88 983q0 219 128.5 350t322.5 131q154 0 273 -85.5t183 -234.5t64 -337q0 -114 -22.5 -227.5t-72.5 -223.5t-122 -194t-179.5 -135.5t-236.5 -51.5q-70 0 -136 15t-97 30l-31 15l53 125q10 -6 28.5 -14.5t73 -22.5t107.5 -14q108 0 197.5 51t147 137t92 189t44.5 216h-4 q-50 -83 -150 -129.5t-216 -46.5q-197 0 -322 128t-125 329zM231 985q0 -151 89 -241.5t237 -90.5q140 0 244 77.5t104 168.5q0 97 -45 195.5t-131 167.5t-188 69q-143 0 -226.5 -96.5t-83.5 -249.5z" />
+<glyph unicode=":" horiz-adv-x="579" d="M211 0v164h158v-164h-158zM211 866v164h158v-164h-158z" />
+<glyph unicode=";" horiz-adv-x="579" d="M111 -199l98 367h149l-131 -367h-116zM211 866v164h158v-164h-158z" />
+<glyph unicode="&#x3c;" d="M141 530v103l926 414v-138l-752 -325v-4l752 -326v-137z" />
+<glyph unicode="=" d="M143 344v119h955v-119h-955zM143 700v119h955v-119h-955z" />
+<glyph unicode="&#x3e;" d="M158 117v137l751 326v4l-751 325v138l925 -414v-103z" />
+<glyph unicode="?" horiz-adv-x="882" d="M80 1350q5 5 15 12.5t42.5 27.5t68.5 35.5t91.5 28t112.5 12.5q176 0 292.5 -101.5t116.5 -260.5q0 -69 -20 -128t-52.5 -101t-71.5 -80t-78 -73t-71.5 -71t-52.5 -83.5t-20 -102.5v-88h-140v92q0 66 20 123.5t51.5 99.5t69.5 80t76.5 73.5t70 71.5t51.5 82.5t20 98.5 q0 99 -76 167t-193 68q-62 0 -123.5 -22t-92.5 -44l-31 -22zM305 0v158h158v-158h-158z" />
+<glyph unicode="@" horiz-adv-x="1513" d="M84 496q0 154 58 293.5t156 239.5t232.5 159t282.5 59q134 0 234 -32t157 -87.5t84 -122.5t27 -145v-645h145v-115h-551q-174 0 -291.5 116t-117.5 278q0 161 117 277t292 116h267q-3 103 -92 171t-261 68q-165 0 -302.5 -85.5t-215.5 -230t-78 -314.5q0 -172 78 -315.5 t217.5 -227.5t311.5 -84v-123q-157 0 -296.5 59t-238.5 159.5t-157 239t-58 292.5zM643 496q0 -118 80.5 -199.5t198.5 -81.5h254v563h-250q-120 0 -201.5 -82.5t-81.5 -199.5z" />
+<glyph unicode="A" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 z" />
+<glyph unicode="B" d="M82 1313v127h612q172 0 280.5 -98.5t108.5 -264.5q0 -113 -50.5 -192.5t-133.5 -120.5v-4q110 -31 176 -128.5t66 -228.5q0 -187 -121.5 -295t-308.5 -108h-371q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM358 172q0 -45 45 -45h308q130 0 205 76t75 205q0 128 -77.5 206 t-204.5 78h-351v-520zM358 815h334q109 0 176.5 70t67.5 182q0 111 -66.5 178.5t-179.5 67.5h-332v-498z" />
+<glyph unicode="C" horiz-adv-x="1421" d="M78 731q0 205 92 373t255 264t363 96q82 0 171.5 -18t174 -52.5t139 -96t54.5 -138.5v-119h-135v80q0 64 -66.5 113.5t-155.5 72.5t-177 23q-118 0 -222.5 -45t-180 -123t-119.5 -190t-44 -240q0 -170 74 -312t205.5 -225t292.5 -83q61 0 119.5 11t104 29t86.5 39.5 t69.5 43t50 39.5t31.5 29l10 11l82 -104q-8 -10 -23.5 -25.5t-69 -56t-113.5 -71t-154.5 -56t-194.5 -25.5q-155 0 -290 59.5t-228.5 161t-147 240.5t-53.5 295z" />
+<glyph unicode="D" horiz-adv-x="1464" d="M86 1313v127h578q330 0 526 -191t196 -528q0 -340 -196 -530.5t-526 -190.5h-320q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM362 172q0 -45 46 -45h241q271 0 429.5 155t158.5 439q0 282 -159.5 437t-428.5 155h-287v-1141z" />
+<glyph unicode="E" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133z" />
+<glyph unicode="F" horiz-adv-x="1021" d="M86 1313v127h766q66 0 94.5 -29.5t28.5 -95.5v-144h-133v97q0 45 -45 45h-435v-541h523v-127h-523v-645h-143v1313h-133z" />
+<glyph unicode="G" horiz-adv-x="1495" d="M80 723q0 204 94 374t259 268.5t366 98.5q94 0 180 -18t142.5 -44t99.5 -52t63 -44l19 -18l-84 -106q-7 6 -19 16t-53.5 35t-87 44.5t-116 35.5t-142.5 16q-160 0 -291 -79t-206 -218t-75 -309q0 -174 74 -314.5t204.5 -219t291.5 -78.5q80 0 156 21.5t127.5 52.5 t92 62.5t59.5 52.5l19 22v178q0 45 -45 45h-88v127h144q66 0 95.5 -29.5t29.5 -95.5v-547h-132v109l3 61h-5q-7 -8 -20 -21t-58.5 -46.5t-96 -59.5t-131 -47t-165.5 -21q-146 0 -275.5 56.5t-224 155t-149.5 238t-55 298.5z" />
+<glyph unicode="H" horiz-adv-x="1550" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-531h828v531q0 66 29 95.5t94 29.5h153v-127h-88q-45 0 -45 -45v-1268h-143v657h-828v-657h-143v1268q0 45 -45 45h-88z" />
+<glyph unicode="I" horiz-adv-x="600" d="M94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
+<glyph unicode="J" horiz-adv-x="1034" d="M49 403v58h144v-49q0 -82 22.5 -142.5t61.5 -94t84 -49t96 -15.5q50 0 94.5 16t82.5 49t60.5 93t22.5 139v860q0 45 -45 45h-357v127h420q66 0 95.5 -29.5t29.5 -95.5v-912q0 -90 -23 -163.5t-62 -122t-91.5 -81t-109.5 -47t-119 -14.5q-78 0 -148 24t-129 73t-94 134.5 t-35 196.5z" />
+<glyph unicode="K" horiz-adv-x="1208" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-500h173q89 0 120 51l349 574h163l-370 -604q-16 -26 -34.5 -46t-28.5 -27l-11 -7v-4q4 -1 10.5 -5t25 -25t34.5 -52l249 -496q14 -30 37 -38.5t68 -8.5h41v-127h-76q-90 0 -127.5 19.5t-71.5 89.5l-262 526q-16 32 -47 42.5 t-84 10.5h-158v-688h-143v1268q0 45 -45 45h-88z" />
+<glyph unicode="L" horiz-adv-x="1085" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-1143q0 -45 46 -45h477q45 0 45 45v96h135v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-596q-66 0 -95.5 29.5t-29.5 95.5v1143q0 45 -45 45h-88z" />
+<glyph unicode="M" horiz-adv-x="1730" d="M45 0v127h76q42 0 45 45l100 1268h146l381 -838q16 -33 33.5 -75.5t27.5 -68.5l10 -26h4q37 96 70 170l381 838h145l101 -1268q3 -45 45 -45h78v-127h-140q-65 0 -92.5 29t-32.5 96l-67 874q-3 35 -4.5 85t-1.5 83v33h-4q-39 -127 -74 -201l-342 -731h-129l-340 731 q-15 32 -34 83.5t-31 86.5l-11 35h-4q0 -127 -6 -205l-68 -874q-5 -67 -32.5 -96t-92.5 -29h-137z" />
+<glyph unicode="N" horiz-adv-x="1556" d="M86 0v127h88q45 0 45 45v1268h131l735 -1026q22 -32 51 -79.5t48 -78.5l18 -31h4q-10 113 -10 189v901q0 66 29.5 95.5t95.5 29.5h152v-127h-89q-45 0 -45 -45v-1268h-131l-735 1026q-23 31 -52.5 77.5t-48.5 77.5l-18 31h-4q12 -110 12 -186v-901q0 -66 -29 -95.5 t-95 -29.5h-152z" />
+<glyph unicode="O" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305z" />
+<glyph unicode="P" horiz-adv-x="1185" d="M86 1313v127h608q195 0 320 -118.5t125 -315.5q0 -198 -125 -319.5t-320 -121.5h-332v-565h-143v1313h-133zM362 692h314q144 0 229.5 84t85.5 230q0 144 -85 225.5t-228 81.5h-316v-621z" />
+<glyph unicode="Q" horiz-adv-x="1619" d="M78 729q0 153 57 289.5t154 234t232 154.5t286 57q153 0 289.5 -57t234.5 -155t155.5 -234t57.5 -289q0 -139 -47.5 -267.5t-132.5 -228.5l176 -176l-88 -92l-176 178q-196 -168 -469 -168q-150 0 -285.5 59t-232.5 160t-154 240.5t-57 294.5zM227 729q0 -170 76.5 -312 t210 -224t293.5 -82q64 0 125 13.5t103.5 32.5t75.5 38.5t49 32.5l16 14l-172 174l88 92l170 -176q63 79 98 182.5t35 214.5q0 167 -77.5 304.5t-212 215.5t-298.5 78q-161 0 -294 -78t-209.5 -215.5t-76.5 -304.5z" />
+<glyph unicode="R" horiz-adv-x="1239" d="M86 1313v127h610q183 0 298.5 -112t115.5 -298q0 -157 -81.5 -258.5t-197.5 -126.5v-4q30 -16 50 -57l206 -410q14 -30 36.5 -38.5t66.5 -8.5h29v-127h-64q-89 0 -126.5 20t-72.5 89l-206 411q-28 55 -56 70.5t-90 15.5h-242v-606h-143v1313h-133zM362 733h320 q129 0 204 79t75 214q0 133 -74.5 210t-202.5 77h-322v-580z" />
+<glyph unicode="S" horiz-adv-x="1060" d="M76 180l88 105q6 -7 17 -19t48.5 -42.5t78 -53.5t103 -42t126.5 -19q121 0 202.5 71.5t81.5 184.5q0 57 -24.5 104t-65.5 81t-94 63.5t-112 56.5t-118 54.5t-112 63t-94 77t-65.5 101t-24.5 130.5q0 155 122.5 261.5t317.5 106.5q58 0 120.5 -13t125 -39.5t103 -77.5 t40.5 -117v-103h-135v68q0 63 -75 106t-177 43q-135 0 -215 -67.5t-80 -163.5q0 -53 24.5 -97t65.5 -75t94.5 -59t112.5 -53.5t117.5 -53.5t112 -64t94.5 -80t65.5 -106.5t24.5 -138.5q0 -108 -52 -198t-153 -145t-232 -55q-83 0 -160 21t-128.5 51t-91 60.5t-58.5 51.5z " />
+<glyph unicode="T" horiz-adv-x="1269" d="M31 1171v152q0 66 25 91.5t91 25.5h975q66 0 91.5 -25.5t25.5 -91.5v-152h-133v97q0 24 -10.5 34.5t-34.5 10.5h-354v-1313h-144v1313h-356q-45 0 -45 -45v-97h-131z" />
+<glyph unicode="U" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88z" />
+<glyph unicode="V" horiz-adv-x="1337" d="M25 1313v127h63q77 0 109.5 -23t58.5 -96l354 -969q12 -33 26 -79.5t22 -76.5l8 -30h4q28 112 55 186l354 969q27 74 60 96.5t110 22.5h62v-127h-19q-32 0 -47.5 -8.5t-25.5 -36.5l-474 -1268h-153l-473 1268q-10 28 -26 36.5t-48 8.5h-20z" />
+<glyph unicode="W" horiz-adv-x="1935" d="M35 1313v127h63q81 0 118.5 -23.5t55.5 -95.5l250 -993l31 -154h4q19 80 39 154l317 1106h142l288 -1106q9 -33 17 -71.5t12 -60.5l4 -22h4q15 80 33 154l250 993q18 72 55.5 95.5t118.5 23.5h64v-127h-23q-34 0 -51.5 -9t-24.5 -36l-332 -1268h-170l-268 1001 q-11 41 -23 94t-18 86l-6 33h-4q-24 -118 -51 -210l-295 -1004h-170l-330 1268q-7 27 -25 36t-51 9h-24z" />
+<glyph unicode="X" horiz-adv-x="1167" d="M31 0l458 752l-311 508q-20 32 -43.5 42.5t-58.5 10.5h-43v127h76q77 0 116.5 -22t81.5 -93l185 -309l92 -164h4q43 90 88 164l184 309q42 70 82 92.5t117 22.5h76v-127h-43q-36 0 -59.5 -10.5t-43.5 -42.5l-313 -508l461 -752h-164l-299 496l-92 157h-4 q-41 -85 -86 -159l-297 -494h-164z" />
+<glyph unicode="Y" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33z" />
+<glyph unicode="Z" horiz-adv-x="1177" d="M39 0v100l772 1082q24 34 50 66.5t40 48.5l14 16v4q-34 -4 -104 -4h-573q-45 0 -45 -45v-97h-134v144q0 66 29.5 95.5t95.5 29.5h908v-101l-770 -1081q-24 -34 -50.5 -66.5t-41.5 -48.5l-15 -16v-4q35 4 107 4h620q45 0 45 45v96h133v-143q0 -66 -29.5 -95.5t-95.5 -29.5 h-956z" />
+<glyph unicode="[" horiz-adv-x="620" d="M207 -70v1440q0 66 29.5 95.5t95.5 29.5h151v-115h-102q-45 0 -45 -45v-1370q0 -45 45 -45h102v-115h-151q-66 0 -95.5 29.5t-29.5 95.5z" />
+<glyph unicode="\" horiz-adv-x="649" d="M10 1520h131l518 -1606h-129z" />
+<glyph unicode="]" horiz-adv-x="620" d="M137 -80h103q45 0 45 45v1370q0 45 -45 45h-103v115h152q66 0 95.5 -29.5t29.5 -95.5v-1440q0 -66 -29.5 -95.5t-95.5 -29.5h-152v115z" />
+<glyph unicode="^" d="M150 512l405 928h96l406 -928h-133l-320 758l-319 -758h-135z" />
+<glyph unicode="_" horiz-adv-x="1077" d="M10 0h1057v-119h-1057v119z" />
+<glyph unicode="`" horiz-adv-x="737" d="M190 1784h156l143 -244h-120z" />
+<glyph unicode="a" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86z" />
+<glyph unicode="b" horiz-adv-x="1196" d="M41 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-373l-4 -84h4q4 8 11 21.5t36.5 47.5t66 59.5t100 47t137.5 21.5q205 0 326.5 -149.5t121.5 -391.5t-130 -390.5t-335 -148.5q-69 0 -129 20.5t-96.5 49.5t-63.5 58.5t-38 50.5l-11 20h-4q4 -35 4 -84v-90h-135v1274 q0 45 -45 45h-86zM307 512q0 -79 20.5 -152t60 -132t103.5 -94.5t144 -35.5q141 0 236.5 112.5t95.5 303.5q0 187 -91 300.5t-235 113.5q-67 0 -125.5 -24.5t-106 -73t-75 -130.5t-27.5 -188z" />
+<glyph unicode="c" horiz-adv-x="1081" d="M82 514q0 155 71.5 279t195.5 193t276 69q39 0 83.5 -6t95.5 -22t92 -40t68 -63.5t27 -87.5v-93h-131v60q0 58 -78.5 92.5t-156.5 34.5q-169 0 -284.5 -116t-115.5 -300q0 -123 56 -218.5t147.5 -144.5t200.5 -49q59 0 115 15t93.5 36.5t67 43t43.5 36.5l13 15l65 -105 q-6 -7 -17 -18t-49 -40t-81 -51.5t-112.5 -40.5t-143.5 -18q-152 0 -275.5 67.5t-194.5 191t-71 280.5z" />
+<glyph unicode="d" horiz-adv-x="1204" d="M86 516q0 242 129.5 390.5t333.5 148.5q70 0 130.5 -20t96.5 -48t62 -56.5t36 -48.5l11 -20h4q-4 35 -4 78v334q0 45 -45 45h-86v121h145q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-143q-123 0 -123 115l4 65h-4q-3 -8 -10.5 -22t-36.5 -49.5t-65.5 -62.5 t-101 -49t-140.5 -22q-205 0 -327 149.5t-122 391.5zM229 516q0 -189 90 -302.5t236 -113.5q67 0 125.5 24.5t106 73t75 130.5t27.5 188q0 80 -20.5 153t-60 132t-103.5 94t-144 35q-141 0 -236.5 -112.5t-95.5 -301.5z" />
+<glyph unicode="e" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5z" />
+<glyph unicode="f" horiz-adv-x="624" d="M51 913v117h129v37q0 81 18 146t49 105t66.5 67.5t78.5 41t76 18.5t67 5l63 -4v-125q-18 4 -49 4q-28 0 -54.5 -4.5t-60 -20.5t-57.5 -42.5t-41 -76t-17 -114.5v-37h263v-117h-263v-913h-139v913h-129z" />
+<glyph unicode="g" horiz-adv-x="1185" d="M86 535q0 234 120.5 377t325.5 143q77 0 141 -18t99.5 -44t60 -52t33.5 -44l8 -18h5v39q0 57 27 84.5t89 27.5h144v-121h-84q-45 0 -45 -45v-839q0 -95 -27.5 -172.5t-74 -129.5t-110.5 -87t-135 -50.5t-149 -15.5q-175 0 -336 82l53 117q14 -8 39.5 -20t98.5 -32 t141 -20q161 0 260.5 80t99.5 243v91l2 73h-4q-96 -178 -323 -178q-206 0 -332.5 148t-126.5 381zM229 537q0 -184 92 -295t244 -111q64 0 117.5 21t97 66.5t68 126t24.5 190.5q0 393 -325 393q-151 0 -234.5 -103t-83.5 -288z" />
+<glyph unicode="h" horiz-adv-x="1239" d="M41 1319v121h145q66 0 95.5 -29t29.5 -92v-436l-4 -84h4q12 31 34.5 64t59.5 68t81.5 62t105.5 44.5t127 17.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-18 82t-37.5 68.5t-66 43.5t-100.5 17 q-130 0 -233.5 -82t-138.5 -211q-17 -58 -17 -137v-494h-139v1274q0 45 -45 45h-86z" />
+<glyph unicode="i" horiz-adv-x="514" d="M57 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM184 1264v176h135v-176h-135z" />
+<glyph unicode="j" horiz-adv-x="548" d="M-43 -295q18 -2 45 -2q29 0 55.5 4.5t61 21t59 43.5t41.5 77.5t17 117.5v897q0 45 -46 45h-86v121h146q66 0 95.5 -29.5t29.5 -95.5v-944q0 -97 -27 -170.5t-65 -112.5t-90.5 -63t-93.5 -30.5t-83 -6.5q-16 0 -31 1.5t-21 2.5l-7 2v121zM233 1264v176h134v-176h-134z" />
+<glyph unicode="k" horiz-adv-x="1019" d="M41 1319v121h145q67 0 96 -27t29 -92v-684h107q79 0 117 49l264 344h170l-297 -377q-23 -28 -42.5 -46.5t-27.5 -22.5l-8 -4v-5q30 -14 63 -75l187 -334q13 -26 33 -35.5t61 -9.5h55v-121h-96q-77 0 -110 19t-68 83l-205 369q-25 45 -108 45h-95v-516h-139v1274 q0 45 -45 45h-86z" />
+<glyph unicode="l" horiz-adv-x="501" d="M45 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-1149q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v1149q0 45 -45 45h-86z" />
+<glyph unicode="m" horiz-adv-x="1906" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q39 106 147 183t226 77q141 0 218.5 -64.5t101.5 -193.5h4q43 108 148 183t231 75q181 0 261.5 -101t80.5 -299v-489q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v496q0 69 -9 119.5t-31.5 95.5 t-68.5 68.5t-114 23.5q-112 0 -203 -85.5t-123 -205.5q-18 -58 -18 -150v-487h-139v621q0 44 -2.5 77.5t-10 71t-23 64t-38.5 49t-59.5 34t-83.5 11.5q-120 0 -211 -88.5t-125 -214.5q-17 -61 -17 -138v-487h-139v864q0 45 -45 45h-86z" />
+<glyph unicode="n" horiz-adv-x="1245" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q16 40 47 81t80 83.5t123.5 69t159.5 26.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-17.5 82t-37 68.5t-65 43.5t-99.5 17 q-131 0 -235.5 -81.5t-139.5 -209.5q-17 -61 -17 -139v-494h-139v864q0 45 -45 45h-86z" />
+<glyph unicode="o" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5z" />
+<glyph unicode="p" horiz-adv-x="1202" d="M47 909v121h141q65 0 94 -26.5t29 -81.5l-2 -70h4q3 8 10.5 22t36.5 49t65.5 61.5t101.5 48.5t141 22q205 0 326.5 -149.5t121.5 -391.5t-129.5 -390.5t-331.5 -148.5q-71 0 -131.5 20t-97 48.5t-62.5 57.5t-36 49l-11 20h-4q4 -37 4 -90v-490h-139v1274q0 45 -45 45h-86 zM313 512q0 -79 21.5 -152.5t61.5 -132t103.5 -94t141.5 -35.5q141 0 236.5 112.5t95.5 303.5q0 188 -90 301t-236 113q-67 0 -125.5 -24.5t-106 -73t-75 -130.5t-27.5 -188z" />
+<glyph unicode="q" horiz-adv-x="1204" d="M88 516q0 242 129.5 390.5t333.5 148.5q71 0 132 -20.5t97.5 -50t63 -58.5t36.5 -50l11 -20h4q-2 29 -2 68q0 54 29.5 80t93.5 26h141v-121h-86q-45 0 -45 -45v-1274h-139v494l4 90h-4q-4 -8 -11 -21.5t-36 -48t-65.5 -60.5t-100 -47.5t-137.5 -21.5q-205 0 -327 149.5 t-122 391.5zM229 516q0 -189 91 -302.5t237 -113.5q67 0 125.5 24.5t106 73t75 130.5t27.5 188q0 80 -21 153t-60.5 132t-103.5 94t-143 35q-142 0 -238 -112.5t-96 -301.5z" />
+<glyph unicode="r" horiz-adv-x="741" d="M47 909v121h143q65 0 95 -28t30 -89v-69l-4 -78h4q38 122 123.5 198t202.5 76l55 -6v-137q-24 4 -51 4q-105 0 -184.5 -74t-114.5 -192q-29 -96 -29 -201v-434h-139v864q0 45 -45 45h-86z" />
+<glyph unicode="s" horiz-adv-x="901" d="M59 156l80 96q5 -6 14 -16.5t39.5 -37.5t65 -47.5t88.5 -37.5t111 -17q92 0 154.5 43t62.5 121q0 45 -32 81.5t-83 61.5t-112.5 49.5t-123 52.5t-112.5 62.5t-83 88t-32 120.5q0 135 102.5 207t264.5 72q44 0 93.5 -9.5t101 -29t85 -58.5t33.5 -90v-88h-131v49 q0 51 -57.5 78t-120.5 27q-109 0 -169 -38t-60 -112q0 -47 32 -83.5t82.5 -61.5t112 -48.5t123.5 -51.5t112.5 -62.5t82.5 -89t32 -123.5q0 -128 -102.5 -208.5t-257.5 -80.5q-75 0 -143.5 18.5t-112.5 45t-77 53.5t-48 46z" />
+<glyph unicode="t" horiz-adv-x="686" d="M55 913v117h138v285h137v-285h258v-117h-258v-524q0 -69 17 -121t41.5 -80t58 -45t60 -21.5t54.5 -4.5l47 4v-125q-24 -4 -59 -4q-29 0 -57.5 3t-65.5 13t-68.5 26.5t-63.5 46t-54 68t-36 97t-14 129.5v538h-135z" />
+<glyph unicode="u" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86z" />
+<glyph unicode="v" horiz-adv-x="1060" d="M29 909v121h55q74 0 106 -21.5t58 -90.5l248 -644q8 -23 16.5 -53t13.5 -49l4 -18h5q16 69 34 120l248 644q26 69 58 90.5t104 21.5h53v-121h-18q-57 0 -72 -47l-336 -862h-151l-336 862q-10 27 -26.5 37t-45.5 10h-18z" />
+<glyph unicode="w" horiz-adv-x="1708" d="M20 909v121h72q75 0 107 -22t55 -93l211 -653l31 -110h4q16 61 32 110l252 764h140l252 -764l32 -110h4q13 59 29 110l213 653q23 71 55 93t107 22h72v-121h-29q-57 0 -72 -47l-295 -862h-153l-252 733l-31 111h-4q-15 -60 -33 -111l-250 -733h-155l-295 862 q-15 47 -72 47h-27z" />
+<glyph unicode="x" horiz-adv-x="976" d="M37 909v121h76q78 0 112 -20t80 -92l148 -230l34 -61h5q18 34 32 61l150 230q47 72 80.5 92t111.5 20h74v-121h-41q-36 0 -58 -8t-38 -33l-223 -331l360 -537h-164l-252 383l-32 57h-5q-16 -28 -34 -57l-252 -383h-162l358 537l-223 329q-18 25 -39.5 34t-54.5 9h-43z " />
+<glyph unicode="y" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5z" />
+<glyph unicode="z" horiz-adv-x="1021" d="M80 0v90l579 723q17 22 37.5 45.5t32.5 35.5l12 13v4q-34 -4 -102 -4h-377q-45 0 -45 -45v-80h-131v123q0 66 29.5 95.5t95.5 29.5h715v-92l-578 -721q-18 -22 -39.5 -45.5t-34.5 -35.5l-12 -13v-4q37 4 105 4h426q45 0 45 45v80h131v-123q0 -66 -29.5 -95.5t-95.5 -29.5 h-764z" />
+<glyph unicode="{" horiz-adv-x="667" d="M68 598v127q7 1 19 3.5t42 18t52.5 38.5t41.5 69.5t19 106.5v167q0 70 13 126.5t33 94t48.5 65.5t55.5 43t58.5 24t53.5 11.5t43 2.5h31v-115h-19q-20 0 -39.5 -3.5t-48 -18.5t-49.5 -40.5t-36 -75.5t-15 -118v-200q0 -56 -17 -103.5t-41 -75t-48 -47t-41 -26.5l-17 -8 v-5q7 -2 18 -6.5t39 -25t50 -46.5t39.5 -74.5t17.5 -107.5v-225q0 -67 15 -117t36 -75.5t49.5 -41t48 -19t39.5 -3.5h19v-115q-13 -2 -31 -2q-32 0 -64 5t-78 27.5t-80 59.5t-58.5 109t-24.5 168v195q0 60 -18 106t-43.5 68.5t-51 37t-43.5 17.5z" />
+<glyph unicode="|" horiz-adv-x="583" d="M227 -322v1936h129v-1936h-129z" />
+<glyph unicode="}" horiz-adv-x="667" d="M90 -82h21q19 0 38.5 3.5t47.5 19t49 41t36 75.5t15 117v225q0 59 17 107t41 75t48 46t41 25l17 7v5q-7 2 -18 7.5t-39 26.5t-50 47.5t-39.5 74.5t-17.5 104v200q0 57 -10 101.5t-27.5 71t-36.5 44.5t-42 26t-38.5 10.5t-31.5 2.5h-21v115h33q31 0 62.5 -5t77.5 -27 t80 -59t58.5 -108.5t24.5 -167.5v-167q0 -60 18 -106.5t43.5 -70t51 -38t43.5 -18.5l18 -3v-127q-7 -1 -19 -3.5t-42 -17.5t-52.5 -37.5t-41.5 -68.5t-19 -106v-195q0 -96 -24.5 -168t-58.5 -109t-80 -59.5t-77 -27.5t-63 -5l-33 2v115z" />
+<glyph unicode="~" d="M137 428q0 162 69.5 239.5t190.5 77.5q62 0 111 -22t81 -53.5t61 -62.5t68 -53t87 -22q43 0 74 20.5t45 54.5t20 65.5t6 64.5h121q0 -162 -69.5 -239.5t-190.5 -77.5q-62 0 -111 22t-81 53t-61 62.5t-68 53.5t-87 22q-43 0 -74 -20.5t-45 -54.5t-20 -65.5t-6 -64.5h-121z " />
+<glyph unicode="&#xa1;" horiz-adv-x="608" d="M223 872v158h158v-158h-158zM231 -410l7 1063h131l6 -1063h-144z" />
+<glyph unicode="&#xa2;" horiz-adv-x="1116" d="M113 721q0 231 108 389.5t303 181.5v228h117v-228q126 -15 218.5 -94t148.5 -209l-131 -49q-94 221 -287 221q-109 0 -185.5 -59.5t-111.5 -157t-35 -223.5q0 -128 35 -225.5t111 -156t186 -58.5q194 0 287 221l131 -51q-57 -128 -149 -210.5t-218 -93.5v-227h-117v227 q-195 23 -303 182.5t-108 391.5z" />
+<glyph unicode="&#xa3;" horiz-adv-x="1191" d="M111 0v127h129v541h-93v112h93v305q0 162 119.5 270.5t302.5 108.5q55 0 108 -12t90 -29t66 -34t43 -29l14 -12l-88 -103q-4 3 -11.5 9t-31.5 21t-49.5 26t-64 20.5t-76.5 9.5q-129 0 -204 -73.5t-75 -180.5v-297h391v-112h-391v-541h539q45 0 45 45v96h133v-143 q0 -66 -29.5 -95.5t-95.5 -29.5h-864z" />
+<glyph unicode="&#xa5;" horiz-adv-x="1243" d="M35 1313v127h49q77 0 118.5 -22t84.5 -93l243 -407l88 -160h5q43 84 88 160l245 407q41 71 83 93t120 22h47v-127h-24q-71 0 -99 -45l-266 -439v-4h205v-104h-272l-56 -94v-84h328v-107h-328v-436h-143v436h-332v107h332v84l-59 94h-281v104h215v4l-268 439 q-28 45 -99 45h-24z" />
+<glyph unicode="&#xa7;" horiz-adv-x="849" d="M123 -41l72 98q8 -7 22.5 -17t58 -27t86.5 -17q97 0 160.5 60t63.5 163q0 35 -8 66l-134 878h123l140 -889q8 -54 8 -71q0 -144 -98.5 -237t-256.5 -93q-63 0 -122 21.5t-87 43.5zM150 1135q0 143 97 236t255 93q63 0 122 -21.5t87 -42.5l28 -22l-71 -96q-8 7 -22 16.5 t-57.5 26t-86.5 16.5q-97 0 -161.5 -59t-64.5 -160q0 -28 9 -63l135 -885h-123l-139 889q-8 33 -8 72z" />
+<glyph unicode="&#xa8;" horiz-adv-x="1009" d="M322 1608v176h120v-176h-120zM629 1608v176h121v-176h-121z" />
+<glyph unicode="&#xa9;" horiz-adv-x="1624" d="M84 721q0 152 57.5 290t154 237t230.5 157.5t281 58.5q150 0 286 -58.5t234 -157.5t155.5 -236.5t57.5 -290.5q0 -154 -57.5 -292.5t-155.5 -238t-233.5 -157.5t-286.5 -58q-147 0 -281 58.5t-230.5 157.5t-154 237.5t-57.5 292.5zM205 721q0 -176 79 -322t217.5 -229.5 t305.5 -83.5q171 0 312 83.5t221.5 229t80.5 322.5q0 175 -80.5 320t-221.5 229t-312 84q-167 0 -305.5 -84t-217.5 -229t-79 -320zM406 717q0 82 28.5 157t80.5 134.5t133 95t179 35.5q63 0 120.5 -19.5t95 -47.5t65.5 -56.5t40 -47.5l13 -20l-94 -63q-3 6 -10 15.5 t-29.5 33.5t-48 43t-65.5 34t-83 15q-142 0 -223.5 -90.5t-81.5 -216.5q0 -127 81 -217t224 -90q43 0 83 14.5t67 35t47 41.5t30 35l9 15l94 -64q-5 -8 -13.5 -20.5t-40 -45.5t-67 -58t-93.5 -45.5t-120 -20.5q-98 0 -179 35t-133 93.5t-80.5 133.5t-28.5 156z" />
+<glyph unicode="&#xaa;" horiz-adv-x="847" d="M119 541v96h620v-96h-620zM123 979q0 225 389 225h27q-1 87 -35 122.5t-111 35.5q-20 0 -40.5 -2t-43 -12t-22.5 -27v-49h-109v80q0 31 25 54t63 34t70 15.5t59 4.5q75 0 127 -19t79 -55t38.5 -78.5t11.5 -99.5v-290q0 -19 19 -19h59v-104h-96q-83 0 -86 79v25h-4 q-2 -5 -6.5 -13t-21.5 -28t-37.5 -35.5t-55.5 -28t-74 -12.5q-93 0 -159 53t-66 144zM240 985q0 -43 32 -73.5t90 -30.5q81 0 128.5 68t50.5 165h-25q-37 0 -65 -1t-71 -8.5t-70.5 -20t-48.5 -38t-21 -61.5z" />
+<glyph unicode="&#xab;" horiz-adv-x="1069" d="M78 578l336 421h149l-336 -421l336 -420h-149zM444 578l336 421h152l-336 -421l336 -420h-152z" />
+<glyph unicode="&#xac;" d="M143 700v119h955v-495h-125v376h-830z" />
+<glyph unicode="&#xad;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
+<glyph unicode="&#xae;" horiz-adv-x="1624" d="M84 721q0 152 57.5 290t154 237t230.5 157.5t281 58.5q150 0 286 -58.5t234 -157.5t155.5 -236.5t57.5 -290.5q0 -154 -57.5 -292.5t-155.5 -238t-233.5 -157.5t-286.5 -58q-147 0 -281 58.5t-230.5 157.5t-154 237.5t-57.5 292.5zM205 721q0 -176 79 -322t217.5 -229.5 t305.5 -83.5q171 0 312 83.5t221.5 229t80.5 322.5q0 175 -80.5 320t-221.5 229t-312 84q-167 0 -305.5 -84t-217.5 -229t-79 -320zM492 1024v96h358q106 0 173 -65t67 -172q0 -84 -44.5 -140t-105.5 -71v-4q23 -8 41 -43l92 -185q12 -26 55 -26h21v-92h-59q-48 0 -71 11 t-44 50l-111 217q-14 28 -29.5 36.5t-43.5 8.5h-111v-323h-115v702h-73zM680 735h149q65 0 103.5 39.5t38.5 108.5q0 67 -38.5 104t-103.5 37h-149v-289z" />
+<glyph unicode="&#xaf;" horiz-adv-x="944" d="M229 1608v110h504v-110h-504z" />
+<glyph unicode="&#xb0;" horiz-adv-x="784" d="M104 1178q0 117 83.5 200.5t203.5 83.5t204.5 -83.5t84.5 -200.5q0 -118 -84.5 -201.5t-204.5 -83.5t-203.5 83t-83.5 202zM227 1178q0 -71 47 -120.5t117 -49.5t119 49.5t49 120.5q0 70 -49 120t-119 50t-117 -50t-47 -120z" />
+<glyph unicode="&#xb1;" d="M86 522v119h473v522h125v-522h471v-119h-471v-522h-125v522h-473zM123 -213h995v-119h-995v119z" />
+<glyph unicode="&#xb2;" horiz-adv-x="837" d="M104 645q0 37 8.5 70.5t20 59t34.5 51.5t40 42t49.5 38t51 33t54.5 32q39 22 61 35t53 36.5t47 44t28 49.5t12 62q0 64 -44 106t-118 42q-58 0 -98.5 -24.5t-40.5 -57.5v-54h-110v80q0 42 26 75.5t66 52.5t80.5 28.5t76.5 9.5q130 0 205.5 -73t75.5 -185 q0 -59 -19 -106.5t-63.5 -86.5t-74.5 -59t-93 -56q-8 -5 -12 -7q-50 -30 -75.5 -46.5t-59.5 -45.5t-49 -60.5t-15 -68.5q0 -13 19 -13h358q12 0 12 15v71h111v-102q0 -47 -21.5 -68.5t-68.5 -21.5h-434q-52 0 -72.5 22t-20.5 80z" />
+<glyph unicode="&#xb3;" horiz-adv-x="837" d="M102 674l82 80q4 -5 11 -13t30 -28t47.5 -35.5t61.5 -28t74 -12.5q72 0 126 50t54 126q0 75 -57 120.5t-136 45.5h-71l-21 70l197 239q9 11 20.5 23.5t19.5 18.5l7 7v4q-35 -6 -74 -6h-194q-21 0 -21 -22v-58h-111v88q0 54 21 75.5t76 21.5h452v-80l-241 -283 q44 -4 87.5 -22.5t81 -50t60.5 -82t23 -111.5q0 -122 -88.5 -203.5t-212.5 -81.5q-50 0 -100 15t-85 37t-63 44t-42 37z" />
+<glyph unicode="&#xb4;" horiz-adv-x="759" d="M236 1540l143 244h156l-179 -244h-120z" />
+<glyph unicode="&#xb6;" horiz-adv-x="1175" d="M88 969q0 130 66.5 239t178 170.5t242.5 61.5h490v-127h-371v-1415h-116v596q-130 0 -243 62.5t-180 172.5t-67 240zM821 -102v1292h119v-1292h-119z" />
+<glyph unicode="&#xb7;" horiz-adv-x="440" d="M141 508v164h158v-164h-158z" />
+<glyph unicode="&#xb8;" horiz-adv-x="845" d="M227 -311q39 -13 86 -13q105 0 105 70q0 33 -31 51.5t-86 18.5l-31 -2l54 227l82 -14v-17l-25 -123q65 -9 105 -47t40 -98q0 -83 -57 -122.5t-141 -39.5q-26 0 -51.5 2.5t-37.5 5.5l-12 2v99z" />
+<glyph unicode="&#xb9;" horiz-adv-x="837" d="M162 1231l209 209h104v-791h191v-106h-502v106h192v563l2 70h-4q-10 -21 -26 -37l-92 -90z" />
+<glyph unicode="&#xba;" horiz-adv-x="933" d="M125 1126q0 142 100 239t242 97t242 -97t100 -239q0 -145 -100 -243.5t-242 -98.5t-242 98.5t-100 243.5zM160 541v96h620v-96h-620zM238 1126q0 -102 66.5 -169.5t162.5 -67.5t162.5 67.5t66.5 169.5q0 100 -66.5 167t-162.5 67t-162.5 -67t-66.5 -167z" />
+<glyph unicode="&#xbb;" horiz-adv-x="1069" d="M135 158l336 420l-336 421h152l336 -421l-336 -420h-152zM504 158l336 420l-336 421h151l336 -421l-336 -420h-151z" />
+<glyph unicode="&#xbc;" horiz-adv-x="1822" d="M158 1231l209 209h102v-791h188v-106h-497v106h192v563l2 70h-4q-10 -21 -26 -37l-93 -90zM551 0l608 1440h127l-606 -1440h-129zM1016 240v75l426 582h123v-551h137v-106h-137v-240h-117v240h-432zM1155 344q29 2 43 2h252v313l2 80h-4q-15 -28 -33 -55l-231 -305 l-29 -33v-2z" />
+<glyph unicode="&#xbd;" horiz-adv-x="1822" d="M158 1231l209 209h102v-791h188v-106h-497v106h192v563l2 70h-4q-10 -21 -26 -37l-93 -90zM528 0l609 1440h127l-607 -1440h-129zM1063 102q0 51 16 96t37.5 75t61 62t67.5 49t76 44q39 22 61 35t53 36.5t47 44t28 49.5t12 62q0 64 -44 106t-118 42q-58 0 -98.5 -24.5 t-40.5 -57.5v-51h-111v78q0 43 26 76.5t66.5 52t81 27.5t76.5 9q130 0 205 -73t75 -185q0 -31 -5.5 -59t-19 -53t-25 -43.5t-36.5 -40t-38.5 -33.5t-46 -32t-44 -27t-47.5 -27q-39 -23 -60 -36.5t-51 -36.5t-45.5 -42.5t-27.5 -46.5t-12 -57q0 -15 16 -15h358q13 0 13 15v72 h110v-103q0 -46 -21.5 -68t-68.5 -22h-434q-51 0 -71.5 22t-20.5 80z" />
+<glyph unicode="&#xbe;" horiz-adv-x="1822" d="M127 674l82 80q4 -5 11 -13t30 -28t47 -35.5t61 -28t74 -12.5q72 0 126 50t54 126q0 75 -56.5 120.5t-135.5 45.5h-72l-20 70l196 239q9 11 20.5 23.5t19.5 18.5l7 7v4q-34 -6 -73 -6h-195q-20 0 -20 -22v-58h-111v88q0 55 20.5 76t75.5 21h453v-80l-242 -283 q44 -4 87.5 -22.5t81 -50t60.5 -82t23 -111.5q0 -122 -88.5 -203.5t-212.5 -81.5q-50 0 -100 15t-85 37t-63 44t-42 37zM549 0l608 1440h127l-606 -1440h-129zM1016 240v75l426 582h123v-551h137v-106h-137v-240h-117v240h-432zM1155 344q29 2 43 2h252v313l2 80h-4 q-15 -28 -33 -55l-231 -305l-29 -33v-2z" />
+<glyph unicode="&#xbf;" horiz-adv-x="882" d="M63 -68q0 69 20 127.5t52.5 100.5t71.5 80t78.5 73t72 71.5t52.5 84t20 102.5v82h137v-88q0 -66 -19.5 -123t-51 -98.5t-69.5 -79.5t-76 -73t-69.5 -71t-51 -82.5t-19.5 -98.5q0 -100 75.5 -168t192.5 -68q62 0 124 21.5t93 43.5l31 21l76 -102q-5 -5 -15 -13t-42.5 -28 t-68.5 -35.5t-91.5 -28t-112.5 -12.5q-176 0 -293 102t-117 260zM420 872v158h158v-158h-158z" />
+<glyph unicode="&#xc0;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM434 1784h156l143 -244h-121z" />
+<glyph unicode="&#xc1;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM612 1540l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xc2;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM432 1540l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
+<glyph unicode="&#xc3;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM350 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15 q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186z" />
+<glyph unicode="&#xc4;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM461 1608v176h121v-176h-121zM768 1608v176h121v-176h-121z" />
+<glyph unicode="&#xc5;" horiz-adv-x="1345" d="M25 0v127h26q31 0 47.5 9t26.5 36l471 1268h154l471 -1268q10 -28 25.5 -36.5t47.5 -8.5h25v-127h-66q-77 0 -109.5 23t-60.5 96l-125 340h-571l-127 -340q-28 -74 -60 -96.5t-108 -22.5h-67zM426 584h494l-191 514q-11 30 -25 76.5t-22 77.5l-8 32h-4q-31 -118 -56 -186 zM522 1663q0 63 44.5 104t107.5 41t107 -41t44 -104t-44 -104t-107 -41t-107.5 41t-44.5 104zM606 1663q0 -30 19 -49t49 -19q29 0 48 19.5t19 48.5q0 31 -19 50.5t-48 19.5t-48.5 -19.5t-19.5 -50.5z" />
+<glyph unicode="&#xc6;" horiz-adv-x="1685" d="M25 0v127h18q31 0 47.5 9t26.5 36l487 1268h848q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-475v-525h524v-126h-524v-490q0 -28 12.5 -36.5t44.5 -8.5h477q45 0 45 45v96h135v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-589q-80 0 -112 25.5t-32 99.5v537h-325 l-205 -543q-26 -73 -58.5 -96t-109.5 -23h-55zM500 788h278v525h-82z" />
+<glyph unicode="&#xc7;" horiz-adv-x="1421" d="M78 731q0 205 92 373t255 264t363 96q82 0 171.5 -18t174 -52.5t139 -96t54.5 -138.5v-119h-135v80q0 64 -66.5 113.5t-155.5 72.5t-177 23q-118 0 -222.5 -45t-180 -123t-119.5 -190t-44 -240q0 -171 72.5 -312.5t202.5 -224.5t291 -83q83 0 163 20.5t134 50t96.5 59 t63.5 49.5l20 21l82 -102q-8 -9 -23 -24.5t-67.5 -55t-111 -70t-151.5 -56.5t-192 -28l-19 -88q65 -9 104.5 -47t39.5 -98q0 -83 -56.5 -122.5t-140.5 -39.5q-26 0 -51 2.5t-37 5.5l-12 2v99q39 -13 86 -13q102 0 102 70q0 34 -30 52t-86 18l-29 -2l39 166 q-188 17 -334.5 120.5t-225.5 268.5t-79 362z" />
+<glyph unicode="&#xc8;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM362 1784h156l144 -244h-121z" />
+<glyph unicode="&#xc9;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM541 1540l143 244h156l-178 -244h-121z " />
+<glyph unicode="&#xca;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM360 1540l170 244h144l170 -244h-129 l-111 166h-4l-111 -166h-129z" />
+<glyph unicode="&#xcb;" horiz-adv-x="1142" d="M86 1313v127h823q66 0 95.5 -29.5t29.5 -95.5v-144h-135v97q0 45 -45 45h-492v-525h541v-126h-541v-490q0 -45 46 -45h505q45 0 45 45v96h134v-143q0 -66 -29.5 -95.5t-95.5 -29.5h-623q-66 0 -95.5 29.5t-29.5 95.5v1188h-133zM389 1608v176h121v-176h-121zM696 1608 v176h121v-176h-121z" />
+<glyph unicode="&#xcc;" horiz-adv-x="600" d="M59 1784h156l143 -244h-120zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
+<glyph unicode="&#xcd;" horiz-adv-x="600" d="M94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412zM238 1540l143 244h156l-179 -244h-120z" />
+<glyph unicode="&#xce;" horiz-adv-x="600" d="M57 1540l170 244h144l170 -244h-129l-111 166h-4l-111 -166h-129zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412z" />
+<glyph unicode="&#xcf;" horiz-adv-x="600" d="M86 1608v176h121v-176h-121zM94 0v127h135v1186h-135v127h412v-127h-137v-1186h137v-127h-412zM393 1608v176h121v-176h-121z" />
+<glyph unicode="&#xd0;" horiz-adv-x="1464" d="M86 1313v127h578q330 0 526 -191t196 -528q0 -340 -196 -530.5t-526 -190.5h-320q-66 0 -95.5 29.5t-29.5 95.5v537h-102v122h102v529h-133zM362 172q0 -45 46 -45h241q271 0 429.5 155t158.5 439q0 282 -159.5 437t-428.5 155h-287v-529h336v-122h-336v-490z" />
+<glyph unicode="&#xd1;" horiz-adv-x="1556" d="M86 0v127h88q45 0 45 45v1268h131l735 -1026q22 -32 51 -79.5t48 -78.5l18 -31h4q-10 113 -10 189v901q0 66 29.5 95.5t95.5 29.5h152v-127h-89q-45 0 -45 -45v-1268h-131l-735 1026q-23 31 -52.5 77.5t-48.5 77.5l-18 31h-4q12 -110 12 -186v-901q0 -66 -29 -95.5 t-95 -29.5h-152zM477 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
+<glyph unicode="&#xd2;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM565 1784h156l143 -244h-121z" />
+<glyph unicode="&#xd3;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM743 1540l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xd4;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM563 1540l170 244h144l170 -244h-129l-111 166h-4l-111 -166h-129z" />
+<glyph unicode="&#xd5;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM481 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50 t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
+<glyph unicode="&#xd6;" horiz-adv-x="1619" d="M78 729q0 153 57.5 289.5t155 234t233.5 154.5t287 57t286.5 -57t233.5 -154.5t155.5 -234.5t57.5 -289q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-202 0 -370.5 100t-265.5 273t-97 381zM227 729q0 -128 46 -243t124 -197t186 -130t228 -48q119 0 227 48 t186 130t124.5 197t46.5 243q0 167 -78.5 305t-212.5 216.5t-293 78.5q-160 0 -294 -78.5t-212 -216.5t-78 -305zM592 1608v176h121v-176h-121zM899 1608v176h121v-176h-121z" />
+<glyph unicode="&#xd7;" d="M98 84l443 498l-443 497l84 84l439 -493l438 493l84 -84l-445 -497l445 -498l-84 -84l-438 494l-439 -494z" />
+<glyph unicode="&#xd8;" horiz-adv-x="1626" d="M80 729q0 152 57.5 289t155.5 234.5t233.5 154.5t286.5 57q209 0 387 -110l98 137l84 -61l-96 -136q122 -104 191 -250t69 -315q0 -155 -57.5 -295t-155.5 -240.5t-234 -159.5t-286 -59q-215 0 -391 115l-98 -139l-86 59l100 142q-121 105 -189.5 255t-68.5 322zM229 729 q0 -138 51.5 -257t143.5 -204l696 973q-144 88 -307 88q-159 0 -293 -78.5t-212.5 -216.5t-78.5 -305zM504 203q145 -92 309 -92q120 0 228 48t186 130t124 197t46 243q0 133 -52.5 249.5t-144.5 197.5z" />
+<glyph unicode="&#xd9;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM498 1784h155 l144 -244h-121z" />
+<glyph unicode="&#xda;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM676 1540 l143 244h156l-178 -244h-121z" />
+<glyph unicode="&#xdb;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM496 1540 l170 244h143l170 -244h-129l-111 166h-4l-110 -166h-129z" />
+<glyph unicode="&#xdc;" horiz-adv-x="1468" d="M70 1313v127h151q66 0 95.5 -29.5t29.5 -95.5v-815q0 -180 105 -284.5t282 -104.5q178 0 283.5 105.5t105.5 287.5v811q0 66 29.5 95.5t95.5 29.5h152v-127h-88q-45 0 -45 -45v-774q0 -233 -146.5 -376t-384.5 -143t-385 143t-147 376v774q0 45 -45 45h-88zM524 1608v176 h121v-176h-121zM831 1608v176h121v-176h-121z" />
+<glyph unicode="&#xdd;" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33zM547 1540l143 244h156l-178 -244 h-121z" />
+<glyph unicode="&#xde;" horiz-adv-x="1196" d="M86 1313v127h152q66 0 95 -29.5t29 -95.5v-131h332q195 0 320 -119t125 -317q0 -197 -126 -318t-323 -121h-328v-309h-143v1268q0 45 -45 45h-88zM362 436h314q144 0 229.5 83.5t85.5 228.5q0 146 -85 227.5t-228 81.5h-316v-621z" />
+<glyph unicode="&#xdf;" horiz-adv-x="1142" d="M41 0v121h84q45 0 45 45v921q0 89 35.5 162t94 119t131.5 71t151 25q159 0 258.5 -90t99.5 -215q0 -56 -23.5 -105.5t-57 -84t-66.5 -65.5t-56.5 -65t-23.5 -67q0 -35 29.5 -70.5t74 -65.5t96 -69t96 -79t74 -97.5t29.5 -122.5q0 -94 -48 -162.5t-121.5 -99.5t-162.5 -31 q-55 0 -108 12.5t-89 30t-64.5 34.5t-42.5 30l-13 12l51 109q5 -4 13.5 -11t35.5 -25t55.5 -31.5t70 -24.5t81.5 -11q85 0 143 43.5t58 128.5q0 47 -30 91.5t-74.5 77t-96.5 70.5t-96.5 72.5t-74.5 83t-30 101.5q0 47 23.5 89.5t57 76t67 66.5t57 73.5t23.5 83.5 q0 71 -59 125.5t-163 54.5q-107 0 -186.5 -69.5t-79.5 -190.5v-952q0 -66 -29.5 -95.5t-95.5 -29.5h-143z" />
+<glyph unicode="&#xe0;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM293 1440h156l143 -244h-121z" />
+<glyph unicode="&#xe1;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM471 1196l143 244h156l-178 -244h-121z" />
+<glyph unicode="&#xe2;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM291 1196l170 244h143l170 -244h-129l-110 166h-5l-110 -166h-129z" />
+<glyph unicode="&#xe3;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM209 1202q0 240 190 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h109q0 -118 -48.5 -179 t-142.5 -61q-38 0 -70.5 15t-54.5 36t-42 42.5t-43.5 36.5t-49.5 15q-45 0 -63.5 -43t-18.5 -96h-106zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26t-74 -41.5t-47.5 -62t-19.5 -86z" />
+<glyph unicode="&#xe4;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM319 1264v176h121v-176h-121zM627 1264v176h121v-176h-121z" />
+<glyph unicode="&#xe5;" horiz-adv-x="1083" d="M82 281q0 354 631 354h57v12q0 159 -61.5 225t-204.5 66q-24 0 -53.5 -3.5t-65 -12.5t-59 -28t-23.5 -46v-66h-133v99q0 41 26.5 73t65.5 50.5t87.5 30.5t87 16t69.5 4q95 0 166.5 -20.5t116 -55t72 -86t38 -108t10.5 -126.5v-493q0 -45 45 -45h86v-121h-141 q-65 0 -94 29.5t-29 93.5l2 76h-4q2 0 -9 -23t-37 -56t-63 -66t-99 -56t-134 -23q-52 0 -102.5 12t-95 37t-78.5 60.5t-54 86t-20 110.5zM225 289q0 -78 60.5 -136.5t169.5 -58.5q94 0 168 59.5t110.5 145.5t36.5 178v47h-59q-47 0 -79 -1t-87.5 -5.5t-94 -13t-84.5 -26 t-74 -41.5t-47.5 -62t-19.5 -86zM381 1319q0 63 44 104t107 41t107.5 -41t44.5 -104t-44.5 -104t-107.5 -41t-107 41t-44 104zM465 1319q0 -30 18.5 -49t48.5 -19q29 0 48.5 19.5t19.5 48.5q0 31 -19.5 50.5t-48.5 19.5t-48 -19.5t-19 -50.5z" />
+<glyph unicode="&#xe6;" horiz-adv-x="1783" d="M82 281q0 54 14 99.5t37 78.5t59 59.5t71.5 43.5t85 29.5t89 18.5t92.5 10t87.5 4.5t82.5 0.5h68v22q0 159 -62 225t-202 66q-25 0 -54.5 -3.5t-65 -12.5t-58.5 -28t-23 -46v-66h-133v99q0 45 32 79.5t83 54.5t107.5 30t113.5 10q157 0 240 -54.5t116 -158.5h4 q63 105 162.5 159t226.5 54q82 0 151.5 -24.5t119 -67.5t84.5 -100t52 -122.5t17 -134.5l-4 -92h-772q4 -196 111.5 -305t273.5 -109q52 0 103 13t86.5 32t63.5 37.5t42 31.5l14 13l66 -104q-6 -6 -17.5 -16t-49.5 -35.5t-79.5 -45t-105.5 -35.5t-129 -16 q-157 0 -276.5 76.5t-176.5 210.5h-4q-7 -22 -20 -50.5t-45 -72.5t-73 -78.5t-107.5 -60t-143.5 -25.5q-149 0 -251.5 81.5t-102.5 224.5zM225 289q0 -81 61 -138t171 -57q94 0 167.5 59.5t109.5 146t36 179.5v35h-121q-53 0 -93 -2t-93.5 -9t-92 -22.5t-73.5 -39 t-53.5 -62.5t-18.5 -90zM913 625h625q-6 151 -89 231t-200 80q-131 0 -222 -80.5t-114 -230.5z" />
+<glyph unicode="&#xe7;" horiz-adv-x="1081" d="M82 514q0 155 71.5 279t195.5 193t276 69q39 0 83.5 -6t95.5 -22t92 -40t68 -63.5t27 -87.5v-93h-131v60q0 58 -78.5 92.5t-156.5 34.5q-169 0 -284.5 -116t-115.5 -300q0 -123 56 -218.5t147.5 -144.5t200.5 -49q59 0 115 15t93.5 36.5t67 43t43.5 36.5l13 15l65 -105 q-6 -7 -17 -18t-49.5 -40t-82 -51t-114 -40t-145.5 -19l-16 -88q65 -9 104 -47t39 -98q0 -83 -56 -122.5t-140 -39.5q-26 0 -52 2.5t-39 5.5l-12 2v99q39 -13 86 -13q105 0 105 70q0 33 -31 51.5t-86 18.5l-31 -2l39 170q-197 28 -321.5 173t-124.5 357z" />
+<glyph unicode="&#xe8;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM346 1440h156l143 -244h-121z" />
+<glyph unicode="&#xe9;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM524 1196l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xea;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM344 1196l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
+<glyph unicode="&#xeb;" horiz-adv-x="1122" d="M82 514q0 124 40.5 227t110 171t161.5 105.5t196 37.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-791q3 -188 118.5 -299t281.5 -111q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-151 0 -274 68 t-194 191.5t-71 279.5zM233 621h646q-6 153 -88 235t-203 82q-132 0 -231 -83.5t-124 -233.5zM373 1264v176h121v-176h-121zM680 1264v176h121v-176h-121z" />
+<glyph unicode="&#xec;" horiz-adv-x="516" d="M6 1440h156l141 -244h-121zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86z" />
+<glyph unicode="&#xed;" horiz-adv-x="516" d="M59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM182 1196l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xee;" horiz-adv-x="516" d="M2 1196l172 244h141l172 -244h-129l-110 166h-4l-113 -166h-129zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86z" />
+<glyph unicode="&#xef;" horiz-adv-x="516" d="M51 1264v176h123v-176h-123zM59 909v121h146q66 0 95.5 -29.5t29.5 -95.5v-739q0 -45 45 -45h86v-121h-146q-66 0 -95.5 29.5t-29.5 95.5v739q0 45 -45 45h-86zM309 1264v176h121v-176h-121z" />
+<glyph unicode="&#xf0;" horiz-adv-x="1157" d="M76 475q0 93 32 178.5t91.5 153.5t154 108.5t211.5 40.5q55 0 106 -11.5t83.5 -27.5t57.5 -32t36 -27l12 -12h4q-69 198 -254 325l-360 -163l-27 98l277 129q-126 64 -291 104l41 119q237 -60 401 -158l269 121l26 -98l-198 -92q142 -111 225.5 -280.5t83.5 -391.5 q0 -85 -18 -166.5t-58 -157.5t-98 -133.5t-144 -92t-190 -34.5q-109 0 -200 42.5t-150 113t-91 160t-32 184.5zM219 473q0 -96 37.5 -180t115.5 -138.5t181 -54.5q73 0 134.5 26t102.5 69t69.5 100t41 116.5t12.5 120.5q0 134 -92 220t-241 86q-89 0 -159.5 -31 t-113.5 -83.5t-65.5 -116.5t-22.5 -134z" />
+<glyph unicode="&#xf1;" horiz-adv-x="1245" d="M47 909v121h143q64 0 94.5 -28t30.5 -87v-47l-4 -73h4q16 40 47 81t80 83.5t123.5 69t159.5 26.5q185 0 265.5 -100.5t80.5 -299.5v-489q0 -45 45 -45h86v-121h-145q-66 0 -95.5 29.5t-29.5 95.5v493q0 55 -4 95t-17.5 82t-37 68.5t-65 43.5t-99.5 17 q-131 0 -235.5 -81.5t-139.5 -209.5q-17 -61 -17 -139v-494h-139v864q0 45 -45 45h-86zM326 1202q0 240 190 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h109q0 -118 -48.5 -179t-142.5 -61q-38 0 -70.5 15t-54.5 36t-42 42.5 t-43.5 36.5t-49.5 15q-45 0 -63.5 -43t-18.5 -96h-106z" />
+<glyph unicode="&#xf2;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM387 1440h156l143 -244h-121z" />
+<glyph unicode="&#xf3;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM565 1196l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xf4;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM385 1196l170 244h143l170 -244h-129l-110 166h-4l-111 -166h-129z" />
+<glyph unicode="&#xf5;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM303 1202q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-38 0 -70.5 15t-54.5 36t-42 42.5t-43.5 36.5t-49.5 15 q-45 0 -63.5 -43t-18.5 -96h-107z" />
+<glyph unicode="&#xf6;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q149 0 273.5 -69.5t197.5 -192.5t73 -273q0 -152 -73 -278t-197 -196.5t-272 -70.5q-111 0 -211.5 42t-174 113.5t-116.5 173.5t-43 216zM225 520q0 -178 117.5 -299t284.5 -121q166 0 282.5 121t116.5 299 q0 173 -116.5 290.5t-282.5 117.5q-167 0 -284.5 -117.5t-117.5 -290.5zM414 1264v176h121v-176h-121zM721 1264v176h121v-176h-121z" />
+<glyph unicode="&#xf7;" d="M102 522v119h1004v-119h-1004zM526 125v151h154v-151h-154zM526 887v151h154v-151h-154z" />
+<glyph unicode="&#xf8;" horiz-adv-x="1251" d="M82 520q0 149 73 272.5t197.5 193t272.5 69.5q153 0 280 -76l80 113l84 -62l-80 -110q85 -73 132.5 -177t47.5 -223q0 -152 -73 -278t-197 -196.5t-272 -70.5q-145 0 -265 66l-77 -109l-84 62l75 104q-91 75 -142.5 184.5t-51.5 237.5zM225 520q0 -185 129 -311l475 663 q-94 56 -202 56q-167 0 -284.5 -117.5t-117.5 -290.5zM438 150q89 -50 189 -50q166 0 282.5 121t116.5 299q0 171 -119 287z" />
+<glyph unicode="&#xf9;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM365 1440h155l144 -244h-121z" />
+<glyph unicode="&#xfa;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM543 1196l143 244h156l-178 -244h-121z" />
+<glyph unicode="&#xfb;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM362 1196l170 244h144l170 -244h-129l-111 166h-4l-110 -166h-130z" />
+<glyph unicode="&#xfc;" horiz-adv-x="1234" d="M43 909v121h145q66 0 95.5 -29t29.5 -92v-497q0 -54 4 -94.5t18 -82.5t38 -68.5t66 -43.5t100 -17q85 0 157 36t120 96t75 137.5t27 161.5v493h139v-864q0 -45 45 -45h86v-121h-141q-64 0 -94.5 28t-30.5 87v47l4 74h-4q-17 -41 -49.5 -83.5t-81.5 -84t-120 -67.5 t-151 -26q-181 0 -263.5 98t-82.5 302v489q0 45 -45 45h-86zM391 1264v176h121v-176h-121zM698 1264v176h121v-176h-121z" />
+<glyph unicode="&#xfd;" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5zM487 1196l144 244h155l-178 -244h-121z" />
+<glyph unicode="&#xfe;" horiz-adv-x="1196" d="M41 1319v121h145q66 0 95.5 -29.5t29.5 -95.5v-367l-4 -90h4q99 197 346 197q208 0 330.5 -149t122.5 -390q0 -242 -122.5 -391.5t-330.5 -149.5q-73 0 -136 20t-100 48.5t-63.5 56.5t-36.5 48l-10 20h-4q4 -37 4 -90v-488h-139v1684q0 45 -45 45h-86zM307 514 q0 -109 28 -191t76 -129.5t106.5 -70.5t125.5 -23q146 0 235 114t89 302q0 186 -89 299t-235 113q-70 0 -129 -22.5t-106.5 -70t-74 -129.5t-26.5 -192z" />
+<glyph unicode="&#xff;" horiz-adv-x="1103" d="M16 -330l66 103q0 -3 19 -21t57.5 -37.5t77.5 -19.5q120 0 190 168l61 141l-362 858q-12 27 -27.5 37t-44.5 10h-20v121h63q69 0 99.5 -21.5t58.5 -90.5l264 -644l37 -110h4q15 59 35 110l254 644q26 69 57.5 90.5t102.5 21.5h63v-121h-20q-29 0 -45.5 -10t-26.5 -37 l-444 -1077q-41 -100 -117.5 -157.5t-177.5 -57.5q-40 0 -78 10.5t-63 25t-45 29t-29 25.5zM336 1264v176h121v-176h-121zM643 1264v176h121v-176h-121z" />
+<glyph unicode="&#x152;" horiz-adv-x="1863" d="M78 721q0 205 89 374t248.5 267t356.5 98q50 0 153 -10t138 -10h565q66 0 95.5 -29.5t29.5 -95.5v-144h-133v97q0 45 -45 45h-477v-525h524v-126h-524v-535h536q45 0 45 45v96h133v-143q0 -66 -27.5 -95.5t-86.5 -29.5h-633q-34 0 -138 -10t-155 -10q-148 0 -277.5 57.5 t-220.5 156t-143.5 235.5t-52.5 292zM227 721q0 -171 67 -308.5t192 -216.5t286 -79q119 0 182 14v1176q-72 16 -182 16q-161 0 -286 -79t-192 -216t-67 -307z" />
+<glyph unicode="&#x153;" horiz-adv-x="2068" d="M82 512q0 160 74.5 285t197.5 191.5t271 66.5q154 0 277 -74t190 -203h4q60 132 175.5 204.5t264.5 72.5q138 0 237.5 -66t147 -172t47.5 -237l-4 -70h-790q4 -98 37.5 -177t88.5 -129t125 -77t148 -27q53 0 104 13t86.5 32t63.5 37.5t41 31.5l14 13l68 -104 q-6 -6 -17.5 -16t-50 -35.5t-80 -45t-106 -35.5t-129.5 -16q-159 0 -282 75t-187 206h-4q-65 -132 -188.5 -206.5t-280.5 -74.5q-110 0 -209 38.5t-173 107t-117.5 170.5t-43.5 221zM225 512q0 -182 116 -297t284 -115q167 0 283 116.5t116 303.5q0 182 -117 295t-282 113 q-168 0 -284 -116t-116 -300zM1180 621h645q-7 153 -88.5 235t-202.5 82q-132 0 -230.5 -83.5t-123.5 -233.5z" />
+<glyph unicode="&#x178;" horiz-adv-x="1212" d="M20 1313v127h56q76 0 114 -21t82 -94l244 -407q20 -34 42 -74.5t34 -63.5l12 -24h4q43 86 88 162l244 407q44 73 82.5 94t114.5 21h55v-127h-33q-33 0 -54.5 -11t-39.5 -42l-387 -633v-627h-143v627l-385 633q-19 31 -41 42t-56 11h-33zM395 1608v176h121v-176h-121z M702 1608v176h121v-176h-121z" />
+<glyph unicode="&#x2c6;" horiz-adv-x="962" d="M240 1540l170 244h143l170 -244h-129l-111 166h-4l-110 -166h-129z" />
+<glyph unicode="&#x2dc;" horiz-adv-x="1007" d="M182 1546q0 240 191 240q38 0 70 -15t54 -37t42 -44t43.5 -37t48.5 -15q24 0 41 14t25.5 37.5t12 45.5t3.5 45h108q0 -240 -190 -240q-47 0 -86 23t-61 50t-52 50t-61 23q-45 0 -63.5 -43.5t-18.5 -96.5h-107z" />
+<glyph unicode="&#x2000;" horiz-adv-x="904" />
+<glyph unicode="&#x2001;" horiz-adv-x="1808" />
+<glyph unicode="&#x2002;" horiz-adv-x="904" />
+<glyph unicode="&#x2003;" horiz-adv-x="1808" />
+<glyph unicode="&#x2004;" horiz-adv-x="602" />
+<glyph unicode="&#x2005;" horiz-adv-x="452" />
+<glyph unicode="&#x2006;" horiz-adv-x="301" />
+<glyph unicode="&#x2007;" horiz-adv-x="301" />
+<glyph unicode="&#x2008;" horiz-adv-x="226" />
+<glyph unicode="&#x2009;" horiz-adv-x="361" />
+<glyph unicode="&#x200a;" horiz-adv-x="100" />
+<glyph unicode="&#x2010;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
+<glyph unicode="&#x2011;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
+<glyph unicode="&#x2012;" horiz-adv-x="884" d="M152 518v127h581v-127h-581z" />
+<glyph unicode="&#x2013;" horiz-adv-x="1314" d="M145 522v119h1024v-119h-1024z" />
+<glyph unicode="&#x2014;" horiz-adv-x="1724" d="M145 522v119h1434v-119h-1434z" />
+<glyph unicode="&#x2018;" horiz-adv-x="434" d="M104 1106l115 352h111l-80 -352h-146z" />
+<glyph unicode="&#x2019;" horiz-adv-x="434" d="M104 1108l80 352h146l-115 -352h-111z" />
+<glyph unicode="&#x201a;" horiz-adv-x="434" d="M104 -184l80 352h146l-115 -352h-111z" />
+<glyph unicode="&#x201c;" horiz-adv-x="675" d="M104 1106l115 352h111l-80 -352h-146zM346 1106l115 352h110l-79 -352h-146z" />
+<glyph unicode="&#x201d;" horiz-adv-x="675" d="M104 1108l80 352h146l-115 -352h-111zM346 1108l80 352h145l-114 -352h-111z" />
+<glyph unicode="&#x201e;" horiz-adv-x="675" d="M104 -184l80 352h146l-115 -352h-111zM346 -184l80 352h145l-114 -352h-111z" />
+<glyph unicode="&#x2022;" horiz-adv-x="899" d="M158 596q0 122 86 207.5t207 85.5t205.5 -85.5t84.5 -207.5t-84.5 -207.5t-205.5 -85.5t-207 85.5t-86 207.5z" />
+<glyph unicode="&#x2026;" horiz-adv-x="1673" d="M276 0v164h158v-164h-158zM758 0v164h157v-164h-157zM1239 0v164h158v-164h-158z" />
+<glyph unicode="&#x202f;" horiz-adv-x="361" />
+<glyph unicode="&#x2039;" horiz-adv-x="702" d="M78 578l336 421h149l-336 -421l336 -420h-149z" />
+<glyph unicode="&#x203a;" horiz-adv-x="702" d="M135 158l336 420l-336 421h152l336 -421l-336 -420h-152z" />
+<glyph unicode="&#x205f;" horiz-adv-x="452" />
+<glyph unicode="&#x20ac;" horiz-adv-x="1208" d="M80 545v104h117q-4 37 -4 72l4 94h-117v105h135q61 241 249.5 392.5t438.5 151.5q48 0 95.5 -6t70.5 -12l23 -6l-33 -133q-74 22 -158 22q-194 0 -336.5 -111.5t-195.5 -297.5h620l-20 -105h-623q-8 -41 -8 -90l4 -76h596l-18 -104h-553q46 -194 192.5 -314t345.5 -120 q46 0 92.5 7t69.5 14l23 7l32 -131q-94 -33 -219 -33q-258 0 -447.5 158.5t-244.5 411.5h-131z" />
+<glyph unicode="&#x2122;" horiz-adv-x="1998" d="M88 1251v95q0 54 20.5 74t75.5 20h566q55 0 75.5 -20t20.5 -74v-95h-107v62q0 20 -20 20h-195v-790h-116v790h-193q-20 0 -20 -20v-62h-107zM858 543v104h51q20 0 23 21l59 772h107l235 -514q8 -17 15.5 -38t10.5 -34l3 -12h4q11 45 29 84l235 514h107l59 -772 q3 -21 23 -21h51v-104h-88q-55 0 -74.5 19t-24.5 75l-41 514q-1 16 0 29t2 22l1 8h-5l-229 -499h-94l-230 499h-4l2 -59l-41 -514q-5 -56 -24 -75t-74 -19h-88z" />
+<glyph unicode="&#x25fc;" horiz-adv-x="1034" d="M0 0v1034h1034v-1034h-1034z" />
+<hkern u1="&#x20;" u2="&#x2026;" k="102" />
+<hkern u1="&#x20;" u2="&#x201e;" k="102" />
+<hkern u1="&#x20;" u2="&#x201d;" k="143" />
+<hkern u1="&#x20;" u2="&#x201c;" k="143" />
+<hkern u1="&#x20;" u2="&#x201a;" k="102" />
+<hkern u1="&#x20;" u2="&#x2019;" k="143" />
+<hkern u1="&#x20;" u2="&#x2018;" k="143" />
+<hkern u1="&#x20;" u2="&#x178;" k="72" />
+<hkern u1="&#x20;" u2="&#xdd;" k="72" />
+<hkern u1="&#x20;" u2="Y" k="72" />
+<hkern u1="&#x20;" u2="W" k="47" />
+<hkern u1="&#x20;" u2="V" k="47" />
+<hkern u1="&#x20;" u2="T" k="41" />
+<hkern u1="&#x20;" u2="&#x2e;" k="102" />
+<hkern u1="&#x20;" u2="&#x2c;" k="102" />
+<hkern u1="&#x22;" u2="X" k="-41" />
+<hkern u1="&#x22;" u2="&#x34;" k="102" />
+<hkern u1="&#x24;" u2="&#x37;" k="41" />
+<hkern u1="&#x27;" u2="X" k="-41" />
+<hkern u1="&#x27;" u2="&#x34;" k="102" />
+<hkern u1="&#x28;" u2="j" k="-35" />
+<hkern u1="&#x28;" u2="&#x34;" k="82" />
+<hkern u1="&#x2b;" u2="&#x37;" k="39" />
+<hkern u1="&#x2c;" u2="&#x39;" k="10" />
+<hkern u1="&#x2c;" u2="&#x37;" k="39" />
+<hkern u1="&#x2c;" u2="&#x36;" k="20" />
+<hkern u1="&#x2c;" u2="&#x34;" k="35" />
+<hkern u1="&#x2c;" u2="&#x30;" k="41" />
+<hkern u1="&#x2d;" u2="x" k="53" />
+<hkern u1="&#x2d;" u2="X" k="20" />
+<hkern u1="&#x2d;" u2="&#x39;" k="72" />
+<hkern u1="&#x2d;" u2="&#x37;" k="141" />
+<hkern u1="&#x2d;" u2="&#x35;" k="57" />
+<hkern u1="&#x2d;" u2="&#x33;" k="82" />
+<hkern u1="&#x2d;" u2="&#x31;" k="61" />
+<hkern u1="&#x2e;" u2="&#x39;" k="10" />
+<hkern u1="&#x2e;" u2="&#x37;" k="39" />
+<hkern u1="&#x2e;" u2="&#x36;" k="20" />
+<hkern u1="&#x2e;" u2="&#x34;" k="35" />
+<hkern u1="&#x2e;" u2="&#x30;" k="41" />
+<hkern u1="&#x2f;" u2="&#x37;" k="-25" />
+<hkern u1="&#x30;" u2="&#x2026;" k="82" />
+<hkern u1="&#x30;" u2="&#x201e;" k="82" />
+<hkern u1="&#x30;" u2="&#x201a;" k="82" />
+<hkern u1="&#x30;" u2="&#xb0;" k="20" />
+<hkern u1="&#x30;" u2="&#x38;" k="23" />
+<hkern u1="&#x30;" u2="&#x37;" k="57" />
+<hkern u1="&#x30;" u2="&#x33;" k="16" />
+<hkern u1="&#x30;" u2="&#x32;" k="23" />
+<hkern u1="&#x30;" u2="&#x31;" k="31" />
+<hkern u1="&#x30;" u2="&#x2e;" k="82" />
+<hkern u1="&#x30;" u2="&#x2c;" k="82" />
+<hkern u1="&#x31;" u2="&#x201d;" k="102" />
+<hkern u1="&#x31;" u2="&#x201c;" k="102" />
+<hkern u1="&#x31;" u2="&#x2019;" k="102" />
+<hkern u1="&#x31;" u2="&#x2018;" k="102" />
+<hkern u1="&#x31;" u2="&#x2014;" k="102" />
+<hkern u1="&#x31;" u2="&#x2013;" k="102" />
+<hkern u1="&#x31;" u2="&#xb0;" k="143" />
+<hkern u1="&#x31;" u2="&#x39;" k="23" />
+<hkern u1="&#x31;" u2="&#x38;" k="14" />
+<hkern u1="&#x31;" u2="&#x37;" k="20" />
+<hkern u1="&#x31;" u2="&#x36;" k="23" />
+<hkern u1="&#x31;" u2="&#x35;" k="14" />
+<hkern u1="&#x31;" u2="&#x34;" k="37" />
+<hkern u1="&#x31;" u2="&#x33;" k="8" />
+<hkern u1="&#x31;" u2="&#x30;" k="31" />
+<hkern u1="&#x31;" u2="&#x2f;" k="-57" />
+<hkern u1="&#x31;" u2="&#x2d;" k="102" />
+<hkern u1="&#x31;" u2="&#x27;" k="123" />
+<hkern u1="&#x31;" u2="&#x25;" k="45" />
+<hkern u1="&#x31;" u2="&#x22;" k="123" />
+<hkern u1="&#x32;" u2="&#x2014;" k="57" />
+<hkern u1="&#x32;" u2="&#x2013;" k="57" />
+<hkern u1="&#x32;" u2="&#x39;" k="37" />
+<hkern u1="&#x32;" u2="&#x37;" k="6" />
+<hkern u1="&#x32;" u2="&#x34;" k="41" />
+<hkern u1="&#x32;" u2="&#x30;" k="10" />
+<hkern u1="&#x32;" u2="&#x2d;" k="57" />
+<hkern u1="&#x33;" u2="&#x39;" k="10" />
+<hkern u1="&#x33;" u2="&#x37;" k="10" />
+<hkern u1="&#x34;" u2="&#x2026;" k="20" />
+<hkern u1="&#x34;" u2="&#x201e;" k="20" />
+<hkern u1="&#x34;" u2="&#x201d;" k="41" />
+<hkern u1="&#x34;" u2="&#x201c;" k="41" />
+<hkern u1="&#x34;" u2="&#x201a;" k="20" />
+<hkern u1="&#x34;" u2="&#x2019;" k="41" />
+<hkern u1="&#x34;" u2="&#x2018;" k="41" />
+<hkern u1="&#x34;" u2="&#xb0;" k="41" />
+<hkern u1="&#x34;" u2="&#x39;" k="20" />
+<hkern u1="&#x34;" u2="&#x34;" k="-61" />
+<hkern u1="&#x34;" u2="&#x32;" k="-41" />
+<hkern u1="&#x34;" u2="&#x31;" k="14" />
+<hkern u1="&#x34;" u2="&#x2e;" k="20" />
+<hkern u1="&#x34;" u2="&#x2c;" k="20" />
+<hkern u1="&#x35;" u2="&#x2026;" k="27" />
+<hkern u1="&#x35;" u2="&#x201e;" k="27" />
+<hkern u1="&#x35;" u2="&#x201a;" k="27" />
+<hkern u1="&#x35;" u2="&#xb0;" k="41" />
+<hkern u1="&#x35;" u2="&#x39;" k="6" />
+<hkern u1="&#x35;" u2="&#x37;" k="35" />
+<hkern u1="&#x35;" u2="&#x35;" k="16" />
+<hkern u1="&#x35;" u2="&#x33;" k="16" />
+<hkern u1="&#x35;" u2="&#x32;" k="10" />
+<hkern u1="&#x35;" u2="&#x31;" k="41" />
+<hkern u1="&#x35;" u2="&#x30;" k="14" />
+<hkern u1="&#x35;" u2="&#x2e;" k="27" />
+<hkern u1="&#x35;" u2="&#x2c;" k="27" />
+<hkern u1="&#x36;" u2="&#x2014;" k="27" />
+<hkern u1="&#x36;" u2="&#x2013;" k="27" />
+<hkern u1="&#x36;" u2="&#x39;" k="20" />
+<hkern u1="&#x36;" u2="&#x37;" k="18" />
+<hkern u1="&#x36;" u2="&#x35;" k="10" />
+<hkern u1="&#x36;" u2="&#x33;" k="10" />
+<hkern u1="&#x36;" u2="&#x30;" k="16" />
+<hkern u1="&#x36;" u2="&#x2d;" k="27" />
+<hkern u1="&#x37;" u2="&#x203a;" k="49" />
+<hkern u1="&#x37;" u2="&#x2039;" k="49" />
+<hkern u1="&#x37;" u2="&#x2026;" k="246" />
+<hkern u1="&#x37;" u2="&#x201e;" k="246" />
+<hkern u1="&#x37;" u2="&#x201d;" k="-72" />
+<hkern u1="&#x37;" u2="&#x201c;" k="-72" />
+<hkern u1="&#x37;" u2="&#x201a;" k="246" />
+<hkern u1="&#x37;" u2="&#x2019;" k="-72" />
+<hkern u1="&#x37;" u2="&#x2018;" k="-72" />
+<hkern u1="&#x37;" u2="&#x2014;" k="111" />
+<hkern u1="&#x37;" u2="&#x2013;" k="111" />
+<hkern u1="&#x37;" u2="&#xbb;" k="49" />
+<hkern u1="&#x37;" u2="&#xb0;" k="-61" />
+<hkern u1="&#x37;" u2="&#xab;" k="49" />
+<hkern u1="&#x37;" u2="&#x3f;" k="-37" />
+<hkern u1="&#x37;" u2="&#x3e;" k="80" />
+<hkern u1="&#x37;" u2="&#x3d;" k="80" />
+<hkern u1="&#x37;" u2="&#x3c;" k="80" />
+<hkern u1="&#x37;" u2="&#x3b;" k="31" />
+<hkern u1="&#x37;" u2="&#x3a;" k="31" />
+<hkern u1="&#x37;" u2="&#x39;" k="18" />
+<hkern u1="&#x37;" u2="&#x38;" k="14" />
+<hkern u1="&#x37;" u2="&#x37;" k="-10" />
+<hkern u1="&#x37;" u2="&#x35;" k="6" />
+<hkern u1="&#x37;" u2="&#x34;" k="119" />
+<hkern u1="&#x37;" u2="&#x32;" k="14" />
+<hkern u1="&#x37;" u2="&#x31;" k="2" />
+<hkern u1="&#x37;" u2="&#x30;" k="41" />
+<hkern u1="&#x37;" u2="&#x2f;" k="123" />
+<hkern u1="&#x37;" u2="&#x2e;" k="246" />
+<hkern u1="&#x37;" u2="&#x2d;" k="111" />
+<hkern u1="&#x37;" u2="&#x2c;" k="246" />
+<hkern u1="&#x37;" u2="&#x2b;" k="80" />
+<hkern u1="&#x38;" u2="&#x39;" k="14" />
+<hkern u1="&#x38;" u2="&#x37;" k="25" />
+<hkern u1="&#x38;" u2="&#x34;" k="-6" />
+<hkern u1="&#x38;" u2="&#x30;" k="23" />
+<hkern u1="&#x39;" u2="&#x2026;" k="82" />
+<hkern u1="&#x39;" u2="&#x201e;" k="82" />
+<hkern u1="&#x39;" u2="&#x201a;" k="82" />
+<hkern u1="&#x39;" u2="&#x38;" k="10" />
+<hkern u1="&#x39;" u2="&#x37;" k="27" />
+<hkern u1="&#x39;" u2="&#x33;" k="10" />
+<hkern u1="&#x39;" u2="&#x32;" k="10" />
+<hkern u1="&#x39;" u2="&#x31;" k="2" />
+<hkern u1="&#x39;" u2="&#x30;" k="10" />
+<hkern u1="&#x39;" u2="&#x2e;" k="82" />
+<hkern u1="&#x39;" u2="&#x2c;" k="82" />
+<hkern u1="&#x3c;" u2="&#x37;" k="39" />
+<hkern u1="&#x3d;" u2="&#x37;" k="39" />
+<hkern u1="&#x3e;" u2="&#x37;" k="39" />
+<hkern u1="A" u2="X" k="18" />
+<hkern u1="B" u2="&#x201d;" k="35" />
+<hkern u1="B" u2="&#x201c;" k="35" />
+<hkern u1="B" u2="&#x2019;" k="35" />
+<hkern u1="B" u2="&#x2018;" k="35" />
+<hkern u1="B" u2="&#x178;" k="51" />
+<hkern u1="B" u2="&#xdd;" k="51" />
+<hkern u1="B" u2="w" k="10" />
+<hkern u1="B" u2="v" k="10" />
+<hkern u1="B" u2="Y" k="51" />
+<hkern u1="B" u2="W" k="25" />
+<hkern u1="B" u2="V" k="25" />
+<hkern u1="B" u2="T" k="39" />
+<hkern u1="B" u2="&#x27;" k="12" />
+<hkern u1="B" u2="&#x22;" k="12" />
+<hkern u1="D" u2="i" k="-14" />
+<hkern u1="D" u2="X" k="23" />
+<hkern u1="F" u2="&#x2026;" k="205" />
+<hkern u1="F" u2="&#x201e;" k="205" />
+<hkern u1="F" u2="&#x201d;" k="-51" />
+<hkern u1="F" u2="&#x201c;" k="-51" />
+<hkern u1="F" u2="&#x201a;" k="205" />
+<hkern u1="F" u2="&#x2019;" k="-51" />
+<hkern u1="F" u2="&#x2018;" k="-51" />
+<hkern u1="F" u2="&#x153;" k="10" />
+<hkern u1="F" u2="&#x152;" k="20" />
+<hkern u1="F" u2="&#xf8;" k="10" />
+<hkern u1="F" u2="&#xf6;" k="10" />
+<hkern u1="F" u2="&#xf5;" k="10" />
+<hkern u1="F" u2="&#xf4;" k="10" />
+<hkern u1="F" u2="&#xf3;" k="10" />
+<hkern u1="F" u2="&#xf2;" k="10" />
+<hkern u1="F" u2="&#xeb;" k="10" />
+<hkern u1="F" u2="&#xea;" k="10" />
+<hkern u1="F" u2="&#xe9;" k="10" />
+<hkern u1="F" u2="&#xe8;" k="10" />
+<hkern u1="F" u2="&#xe7;" k="10" />
+<hkern u1="F" u2="&#xe6;" k="31" />
+<hkern u1="F" u2="&#xe5;" k="31" />
+<hkern u1="F" u2="&#xe4;" k="31" />
+<hkern u1="F" u2="&#xe3;" k="31" />
+<hkern u1="F" u2="&#xe2;" k="31" />
+<hkern u1="F" u2="&#xe1;" k="31" />
+<hkern u1="F" u2="&#xe0;" k="31" />
+<hkern u1="F" u2="&#xd8;" k="20" />
+<hkern u1="F" u2="&#xd6;" k="20" />
+<hkern u1="F" u2="&#xd5;" k="20" />
+<hkern u1="F" u2="&#xd4;" k="20" />
+<hkern u1="F" u2="&#xd3;" k="20" />
+<hkern u1="F" u2="&#xd2;" k="20" />
+<hkern u1="F" u2="&#xc7;" k="20" />
+<hkern u1="F" u2="&#xc6;" k="94" />
+<hkern u1="F" u2="&#xc5;" k="94" />
+<hkern u1="F" u2="&#xc4;" k="94" />
+<hkern u1="F" u2="&#xc3;" k="94" />
+<hkern u1="F" u2="&#xc2;" k="94" />
+<hkern u1="F" u2="&#xc1;" k="94" />
+<hkern u1="F" u2="&#xc0;" k="94" />
+<hkern u1="F" u2="q" k="10" />
+<hkern u1="F" u2="o" k="10" />
+<hkern u1="F" u2="g" k="10" />
+<hkern u1="F" u2="e" k="10" />
+<hkern u1="F" u2="d" k="10" />
+<hkern u1="F" u2="c" k="10" />
+<hkern u1="F" u2="a" k="31" />
+<hkern u1="F" u2="Q" k="20" />
+<hkern u1="F" u2="O" k="20" />
+<hkern u1="F" u2="N" k="14" />
+<hkern u1="F" u2="M" k="14" />
+<hkern u1="F" u2="J" k="37" />
+<hkern u1="F" u2="G" k="20" />
+<hkern u1="F" u2="C" k="20" />
+<hkern u1="F" u2="A" k="94" />
+<hkern u1="F" u2="&#x40;" k="10" />
+<hkern u1="F" u2="&#x2e;" k="205" />
+<hkern u1="F" u2="&#x2c;" k="205" />
+<hkern u1="F" u2="&#x27;" k="-39" />
+<hkern u1="F" u2="&#x22;" k="-39" />
+<hkern u1="K" u2="x" k="10" />
+<hkern u1="L" u2="&#x2a;" k="158" />
+<hkern u1="M" u2="&#x201d;" k="59" />
+<hkern u1="M" u2="&#x201c;" k="59" />
+<hkern u1="M" u2="&#x2019;" k="59" />
+<hkern u1="M" u2="&#x2018;" k="59" />
+<hkern u1="M" u2="&#xfc;" k="-8" />
+<hkern u1="M" u2="&#xfb;" k="-8" />
+<hkern u1="M" u2="&#xfa;" k="-8" />
+<hkern u1="M" u2="&#xf9;" k="-8" />
+<hkern u1="M" u2="&#xf1;" k="-8" />
+<hkern u1="M" u2="u" k="-8" />
+<hkern u1="M" u2="r" k="-8" />
+<hkern u1="M" u2="p" k="-8" />
+<hkern u1="M" u2="n" k="-8" />
+<hkern u1="M" u2="m" k="-8" />
+<hkern u1="M" u2="T" k="35" />
+<hkern u1="M" u2="&#x27;" k="61" />
+<hkern u1="M" u2="&#x22;" k="61" />
+<hkern u1="O" u2="i" k="-14" />
+<hkern u1="O" u2="X" k="23" />
+<hkern u1="P" u2="&#x2026;" k="215" />
+<hkern u1="P" u2="&#x201e;" k="215" />
+<hkern u1="P" u2="&#x201a;" k="215" />
+<hkern u1="P" u2="&#x153;" k="41" />
+<hkern u1="P" u2="&#xf8;" k="41" />
+<hkern u1="P" u2="&#xf6;" k="41" />
+<hkern u1="P" u2="&#xf5;" k="41" />
+<hkern u1="P" u2="&#xf4;" k="41" />
+<hkern u1="P" u2="&#xf3;" k="41" />
+<hkern u1="P" u2="&#xf2;" k="41" />
+<hkern u1="P" u2="&#xeb;" k="41" />
+<hkern u1="P" u2="&#xea;" k="41" />
+<hkern u1="P" u2="&#xe9;" k="41" />
+<hkern u1="P" u2="&#xe8;" k="41" />
+<hkern u1="P" u2="&#xe7;" k="41" />
+<hkern u1="P" u2="&#xe6;" k="41" />
+<hkern u1="P" u2="&#xe5;" k="41" />
+<hkern u1="P" u2="&#xe4;" k="41" />
+<hkern u1="P" u2="&#xe3;" k="41" />
+<hkern u1="P" u2="&#xe2;" k="41" />
+<hkern u1="P" u2="&#xe1;" k="41" />
+<hkern u1="P" u2="&#xe0;" k="41" />
+<hkern u1="P" u2="&#xc6;" k="121" />
+<hkern u1="P" u2="&#xc5;" k="121" />
+<hkern u1="P" u2="&#xc4;" k="121" />
+<hkern u1="P" u2="&#xc3;" k="121" />
+<hkern u1="P" u2="&#xc2;" k="121" />
+<hkern u1="P" u2="&#xc1;" k="121" />
+<hkern u1="P" u2="&#xc0;" k="121" />
+<hkern u1="P" u2="z" k="10" />
+<hkern u1="P" u2="s" k="23" />
+<hkern u1="P" u2="q" k="41" />
+<hkern u1="P" u2="o" k="41" />
+<hkern u1="P" u2="g" k="41" />
+<hkern u1="P" u2="e" k="41" />
+<hkern u1="P" u2="d" k="41" />
+<hkern u1="P" u2="c" k="41" />
+<hkern u1="P" u2="a" k="41" />
+<hkern u1="P" u2="N" k="14" />
+<hkern u1="P" u2="M" k="14" />
+<hkern u1="P" u2="J" k="39" />
+<hkern u1="P" u2="A" k="121" />
+<hkern u1="P" u2="&#x40;" k="41" />
+<hkern u1="P" u2="&#x2e;" k="215" />
+<hkern u1="P" u2="&#x2c;" k="215" />
+<hkern u1="P" u2="&#x27;" k="-10" />
+<hkern u1="P" u2="&#x22;" k="-10" />
+<hkern u1="Q" u2="i" k="-14" />
+<hkern u1="Q" u2="X" k="23" />
+<hkern u1="T" u2="&#xef;" k="-61" />
+<hkern u1="T" u2="j" k="82" />
+<hkern u1="T" u2="i" k="74" />
+<hkern u1="T" u2="&#x20;" k="41" />
+<hkern u1="V" u2="&#x20;" k="47" />
+<hkern u1="W" u2="&#x20;" k="47" />
+<hkern u1="X" u2="&#x201d;" k="-27" />
+<hkern u1="X" u2="&#x201c;" k="-27" />
+<hkern u1="X" u2="&#x2019;" k="-27" />
+<hkern u1="X" u2="&#x2018;" k="-27" />
+<hkern u1="X" u2="&#x2014;" k="20" />
+<hkern u1="X" u2="&#x2013;" k="20" />
+<hkern u1="X" u2="&#x153;" k="14" />
+<hkern u1="X" u2="&#x152;" k="23" />
+<hkern u1="X" u2="&#xf8;" k="14" />
+<hkern u1="X" u2="&#xf6;" k="14" />
+<hkern u1="X" u2="&#xf5;" k="14" />
+<hkern u1="X" u2="&#xf4;" k="14" />
+<hkern u1="X" u2="&#xf3;" k="14" />
+<hkern u1="X" u2="&#xf2;" k="14" />
+<hkern u1="X" u2="&#xeb;" k="14" />
+<hkern u1="X" u2="&#xea;" k="14" />
+<hkern u1="X" u2="&#xe9;" k="14" />
+<hkern u1="X" u2="&#xe8;" k="14" />
+<hkern u1="X" u2="&#xe7;" k="14" />
+<hkern u1="X" u2="&#xd8;" k="23" />
+<hkern u1="X" u2="&#xd6;" k="23" />
+<hkern u1="X" u2="&#xd5;" k="23" />
+<hkern u1="X" u2="&#xd4;" k="23" />
+<hkern u1="X" u2="&#xd3;" k="23" />
+<hkern u1="X" u2="&#xd2;" k="23" />
+<hkern u1="X" u2="&#xc7;" k="23" />
+<hkern u1="X" u2="&#xc6;" k="18" />
+<hkern u1="X" u2="&#xc5;" k="18" />
+<hkern u1="X" u2="&#xc4;" k="18" />
+<hkern u1="X" u2="&#xc3;" k="18" />
+<hkern u1="X" u2="&#xc2;" k="18" />
+<hkern u1="X" u2="&#xc1;" k="18" />
+<hkern u1="X" u2="&#xc0;" k="18" />
+<hkern u1="X" u2="&#x7d;" k="-41" />
+<hkern u1="X" u2="&#x7c;" k="-41" />
+<hkern u1="X" u2="q" k="14" />
+<hkern u1="X" u2="o" k="14" />
+<hkern u1="X" u2="g" k="14" />
+<hkern u1="X" u2="e" k="14" />
+<hkern u1="X" u2="d" k="14" />
+<hkern u1="X" u2="c" k="14" />
+<hkern u1="X" u2="]" k="-41" />
+<hkern u1="X" u2="Q" k="23" />
+<hkern u1="X" u2="O" k="23" />
+<hkern u1="X" u2="G" k="23" />
+<hkern u1="X" u2="C" k="23" />
+<hkern u1="X" u2="A" k="18" />
+<hkern u1="X" u2="&#x40;" k="14" />
+<hkern u1="X" u2="&#x2d;" k="20" />
+<hkern u1="X" u2="&#x29;" k="-41" />
+<hkern u1="X" u2="&#x27;" k="-41" />
+<hkern u1="X" u2="&#x22;" k="-41" />
+<hkern u1="Y" u2="&#x20;" k="72" />
+<hkern u1="[" u2="j" k="-35" />
+<hkern u1="[" u2="&#x34;" k="82" />
+<hkern u1="c" u2="&#xff;" k="10" />
+<hkern u1="c" u2="&#xfd;" k="10" />
+<hkern u1="c" u2="y" k="10" />
+<hkern u1="c" u2="l" k="6" />
+<hkern u1="c" u2="k" k="6" />
+<hkern u1="c" u2="h" k="6" />
+<hkern u1="c" u2="b" k="6" />
+<hkern u1="c" u2="T" k="61" />
+<hkern u1="k" u2="&#x201d;" k="-20" />
+<hkern u1="k" u2="&#x201c;" k="-20" />
+<hkern u1="k" u2="&#x2019;" k="-20" />
+<hkern u1="k" u2="&#x2018;" k="-20" />
+<hkern u1="k" u2="&#x153;" k="20" />
+<hkern u1="k" u2="&#xff;" k="23" />
+<hkern u1="k" u2="&#xfd;" k="23" />
+<hkern u1="k" u2="&#xf8;" k="20" />
+<hkern u1="k" u2="&#xf6;" k="20" />
+<hkern u1="k" u2="&#xf5;" k="20" />
+<hkern u1="k" u2="&#xf4;" k="20" />
+<hkern u1="k" u2="&#xf3;" k="20" />
+<hkern u1="k" u2="&#xf2;" k="20" />
+<hkern u1="k" u2="&#xeb;" k="20" />
+<hkern u1="k" u2="&#xea;" k="20" />
+<hkern u1="k" u2="&#xe9;" k="20" />
+<hkern u1="k" u2="&#xe8;" k="20" />
+<hkern u1="k" u2="&#xe7;" k="20" />
+<hkern u1="k" u2="&#xe6;" k="14" />
+<hkern u1="k" u2="&#xe5;" k="14" />
+<hkern u1="k" u2="&#xe4;" k="14" />
+<hkern u1="k" u2="&#xe3;" k="14" />
+<hkern u1="k" u2="&#xe2;" k="14" />
+<hkern u1="k" u2="&#xe1;" k="14" />
+<hkern u1="k" u2="&#xe0;" k="14" />
+<hkern u1="k" u2="y" k="23" />
+<hkern u1="k" u2="w" k="23" />
+<hkern u1="k" u2="v" k="23" />
+<hkern u1="k" u2="q" k="20" />
+<hkern u1="k" u2="o" k="20" />
+<hkern u1="k" u2="l" k="14" />
+<hkern u1="k" u2="k" k="14" />
+<hkern u1="k" u2="h" k="14" />
+<hkern u1="k" u2="g" k="20" />
+<hkern u1="k" u2="e" k="20" />
+<hkern u1="k" u2="d" k="20" />
+<hkern u1="k" u2="c" k="20" />
+<hkern u1="k" u2="b" k="14" />
+<hkern u1="k" u2="a" k="14" />
+<hkern u1="k" u2="T" k="41" />
+<hkern u1="k" u2="&#x40;" k="20" />
+<hkern u1="x" u2="&#x201d;" k="-41" />
+<hkern u1="x" u2="&#x201c;" k="-41" />
+<hkern u1="x" u2="&#x2019;" k="-41" />
+<hkern u1="x" u2="&#x2018;" k="-41" />
+<hkern u1="x" u2="&#x2014;" k="53" />
+<hkern u1="x" u2="&#x2013;" k="53" />
+<hkern u1="x" u2="&#x2d;" k="53" />
+<hkern u1="&#x7b;" u2="j" k="-35" />
+<hkern u1="&#x7b;" u2="&#x34;" k="82" />
+<hkern u1="&#x7c;" u2="j" k="-35" />
+<hkern u1="&#x7c;" u2="&#x34;" k="82" />
+<hkern u1="&#xa3;" u2="&#x37;" k="35" />
+<hkern u1="&#xa5;" u2="&#x37;" k="-25" />
+<hkern u1="&#xa5;" u2="&#x34;" k="55" />
+<hkern u1="&#xab;" u2="&#x37;" k="66" />
+<hkern u1="&#xbb;" u2="&#x37;" k="66" />
+<hkern u1="&#xc0;" u2="X" k="18" />
+<hkern u1="&#xc1;" u2="X" k="18" />
+<hkern u1="&#xc2;" u2="X" k="18" />
+<hkern u1="&#xc3;" u2="X" k="18" />
+<hkern u1="&#xc4;" u2="X" k="18" />
+<hkern u1="&#xc5;" u2="X" k="18" />
+<hkern u1="&#xd0;" u2="i" k="-14" />
+<hkern u1="&#xd0;" u2="X" k="23" />
+<hkern u1="&#xd2;" u2="i" k="-14" />
+<hkern u1="&#xd2;" u2="X" k="23" />
+<hkern u1="&#xd3;" u2="i" k="-14" />
+<hkern u1="&#xd3;" u2="X" k="23" />
+<hkern u1="&#xd4;" u2="i" k="-14" />
+<hkern u1="&#xd4;" u2="X" k="23" />
+<hkern u1="&#xd5;" u2="i" k="-14" />
+<hkern u1="&#xd5;" u2="X" k="23" />
+<hkern u1="&#xd6;" u2="i" k="-14" />
+<hkern u1="&#xd6;" u2="X" k="23" />
+<hkern u1="&#xd8;" u2="i" k="-14" />
+<hkern u1="&#xd8;" u2="X" k="23" />
+<hkern u1="&#xdd;" u2="&#x20;" k="72" />
+<hkern u1="&#x178;" u2="&#x20;" k="72" />
+<hkern u1="&#x2013;" u2="x" k="53" />
+<hkern u1="&#x2013;" u2="X" k="20" />
+<hkern u1="&#x2013;" u2="&#x39;" k="72" />
+<hkern u1="&#x2013;" u2="&#x37;" k="141" />
+<hkern u1="&#x2013;" u2="&#x35;" k="57" />
+<hkern u1="&#x2013;" u2="&#x33;" k="82" />
+<hkern u1="&#x2013;" u2="&#x31;" k="61" />
+<hkern u1="&#x2014;" u2="x" k="53" />
+<hkern u1="&#x2014;" u2="X" k="20" />
+<hkern u1="&#x2014;" u2="&#x39;" k="72" />
+<hkern u1="&#x2014;" u2="&#x37;" k="141" />
+<hkern u1="&#x2014;" u2="&#x35;" k="57" />
+<hkern u1="&#x2014;" u2="&#x33;" k="82" />
+<hkern u1="&#x2014;" u2="&#x31;" k="61" />
+<hkern u1="&#x2018;" u2="X" k="-27" />
+<hkern u1="&#x2018;" u2="&#x38;" k="57" />
+<hkern u1="&#x2018;" u2="&#x37;" k="-43" />
+<hkern u1="&#x2018;" u2="&#x36;" k="82" />
+<hkern u1="&#x2018;" u2="&#x34;" k="180" />
+<hkern u1="&#x2018;" u2="&#x30;" k="57" />
+<hkern u1="&#x2019;" u2="X" k="-27" />
+<hkern u1="&#x2019;" u2="&#x38;" k="57" />
+<hkern u1="&#x2019;" u2="&#x37;" k="-43" />
+<hkern u1="&#x2019;" u2="&#x36;" k="82" />
+<hkern u1="&#x2019;" u2="&#x34;" k="180" />
+<hkern u1="&#x2019;" u2="&#x30;" k="57" />
+<hkern u1="&#x201a;" u2="&#x39;" k="10" />
+<hkern u1="&#x201a;" u2="&#x37;" k="39" />
+<hkern u1="&#x201a;" u2="&#x36;" k="20" />
+<hkern u1="&#x201a;" u2="&#x34;" k="35" />
+<hkern u1="&#x201a;" u2="&#x30;" k="41" />
+<hkern u1="&#x201c;" u2="X" k="-27" />
+<hkern u1="&#x201c;" u2="&#x38;" k="57" />
+<hkern u1="&#x201c;" u2="&#x37;" k="-43" />
+<hkern u1="&#x201c;" u2="&#x36;" k="82" />
+<hkern u1="&#x201c;" u2="&#x34;" k="180" />
+<hkern u1="&#x201c;" u2="&#x30;" k="57" />
+<hkern u1="&#x201d;" u2="X" k="-27" />
+<hkern u1="&#x201d;" u2="&#x38;" k="57" />
+<hkern u1="&#x201d;" u2="&#x37;" k="-43" />
+<hkern u1="&#x201d;" u2="&#x36;" k="82" />
+<hkern u1="&#x201d;" u2="&#x34;" k="180" />
+<hkern u1="&#x201d;" u2="&#x30;" k="57" />
+<hkern u1="&#x201e;" u2="&#x39;" k="10" />
+<hkern u1="&#x201e;" u2="&#x37;" k="39" />
+<hkern u1="&#x201e;" u2="&#x36;" k="20" />
+<hkern u1="&#x201e;" u2="&#x34;" k="35" />
+<hkern u1="&#x201e;" u2="&#x30;" k="41" />
+<hkern u1="&#x2026;" u2="&#x39;" k="10" />
+<hkern u1="&#x2026;" u2="&#x37;" k="39" />
+<hkern u1="&#x2026;" u2="&#x36;" k="20" />
+<hkern u1="&#x2026;" u2="&#x34;" k="35" />
+<hkern u1="&#x2026;" u2="&#x30;" k="41" />
+<hkern u1="&#x2039;" u2="&#x37;" k="66" />
+<hkern u1="&#x203a;" u2="&#x37;" k="66" />
+<hkern g1="C,Ccedilla"         g2="Y,Yacute,Ydieresis"         k="20" />
+<hkern g1="C,Ccedilla"         g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="10" />
+<hkern g1="C,Ccedilla"         g2="quotedbl,quotesingle"       k="-47" />
+<hkern g1="C,Ccedilla"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-51" />
+<hkern g1="C,Ccedilla"         g2="parenright,bracketright,bar,braceright"     k="-53" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="T"  k="39" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="Y,Yacute,Ydieresis"         k="72" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="V,W"        k="20" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-10" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="v,w"        k="-6" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="y,yacute,ydieresis"         k="-6" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="hyphen,endash,emdash"       k="-31" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quotedbl,quotesingle"       k="20" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="12" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="27" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="T"  k="14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="V,W"        k="31" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="v,w"        k="6" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="J"  k="-14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="f,uniFB01,uniFB02,uniFB03,uniFB04"  k="-12" />
+<hkern g1="G"  g2="T"  k="33" />
+<hkern g1="G"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="16" />
+<hkern g1="G"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-18" />
+<hkern g1="G"  g2="hyphen,endash,emdash"       k="-41" />
+<hkern g1="G"  g2="quotedbl,quotesingle"       k="10" />
+<hkern g1="G"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="41" />
+<hkern g1="G"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-18" />
+<hkern g1="G"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-18" />
+<hkern g1="G"  g2="colon,semicolon"    k="-55" />
+<hkern g1="G"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="12" />
+<hkern g1="H,N,Ntilde"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="20" />
+<hkern g1="H,N,Ntilde"         g2="v,w"        k="20" />
+<hkern g1="H,N,Ntilde"         g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="H,N,Ntilde"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="41" />
+<hkern g1="H,N,Ntilde"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="10" />
+<hkern g1="J"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="27" />
+<hkern g1="J"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
+<hkern g1="J"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="20" />
+<hkern g1="J"  g2="colon,semicolon"    k="35" />
+<hkern g1="K"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="47" />
+<hkern g1="K"  g2="v,w"        k="61" />
+<hkern g1="K"  g2="y,yacute,ydieresis"         k="41" />
+<hkern g1="K"  g2="hyphen,endash,emdash"       k="84" />
+<hkern g1="K"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="6" />
+<hkern g1="K"  g2="parenright,bracketright,bar,braceright"     k="-51" />
+<hkern g1="K"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
+<hkern g1="K"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="K"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="18" />
+<hkern g1="K"  g2="colon,semicolon"    k="-61" />
+<hkern g1="K"  g2="z"  k="20" />
+<hkern g1="K"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="16" />
+<hkern g1="L"  g2="T"  k="205" />
+<hkern g1="L"  g2="Y,Yacute,Ydieresis"         k="164" />
+<hkern g1="L"  g2="V,W"        k="82" />
+<hkern g1="L"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="41" />
+<hkern g1="L"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="76" />
+<hkern g1="L"  g2="v,w"        k="98" />
+<hkern g1="L"  g2="y,yacute,ydieresis"         k="80" />
+<hkern g1="L"  g2="hyphen,endash,emdash"       k="61" />
+<hkern g1="L"  g2="quotedbl,quotesingle"       k="166" />
+<hkern g1="L"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="123" />
+<hkern g1="L"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-20" />
+<hkern g1="L"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="L"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="L"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="10" />
+<hkern g1="L"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="63" />
+<hkern g1="L"  g2="b,h,k,l"    k="27" />
+<hkern g1="R"  g2="T"  k="47" />
+<hkern g1="R"  g2="Y,Yacute,Ydieresis"         k="61" />
+<hkern g1="R"  g2="V,W"        k="10" />
+<hkern g1="R"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="6" />
+<hkern g1="R"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="37" />
+<hkern g1="R"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
+<hkern g1="R"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="R"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
+<hkern g1="R"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
+<hkern g1="S"  g2="hyphen,endash,emdash"       k="-14" />
+<hkern g1="S"  g2="quotedbl,quotesingle"       k="-14" />
+<hkern g1="S"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
+<hkern g1="S"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-10" />
+<hkern g1="S"  g2="z"  k="10" />
+<hkern g1="T"  g2="Y,Yacute,Ydieresis"         k="-20" />
+<hkern g1="T"  g2="V,W"        k="-14" />
+<hkern g1="T"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="39" />
+<hkern g1="T"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="123" />
+<hkern g1="T"  g2="v,w"        k="127" />
+<hkern g1="T"  g2="y,yacute,ydieresis"         k="133" />
+<hkern g1="T"  g2="hyphen,endash,emdash"       k="123" />
+<hkern g1="T"  g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="T"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
+<hkern g1="T"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="178" />
+<hkern g1="T"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="154" />
+<hkern g1="T"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="92" />
+<hkern g1="T"  g2="J"  k="102" />
+<hkern g1="T"  g2="z"  k="127" />
+<hkern g1="T"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="61" />
+<hkern g1="T"  g2="M,N"        k="23" />
+<hkern g1="T"  g2="s"  k="96" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="41" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="M,N"        k="10" />
+<hkern g1="V,W"        g2="T"  k="-14" />
+<hkern g1="V,W"        g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="V,W"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="96" />
+<hkern g1="V,W"        g2="hyphen,endash,emdash"       k="61" />
+<hkern g1="V,W"        g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="V,W"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-10" />
+<hkern g1="V,W"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
+<hkern g1="V,W"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="70" />
+<hkern g1="V,W"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="109" />
+<hkern g1="V,W"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="41" />
+<hkern g1="V,W"        g2="J"  k="68" />
+<hkern g1="V,W"        g2="M,N"        k="12" />
+<hkern g1="V,W"        g2="S"  k="10" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="T"  k="-20" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="hyphen,endash,emdash"       k="123" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-6" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="164" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="166" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="143" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="76" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="J"  k="72" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="z"  k="61" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="41" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="M,N"        k="35" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="s"  k="98" />
+<hkern g1="Z"  g2="hyphen,endash,emdash"       k="53" />
+<hkern g1="Z"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="20" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="T"  k="174" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="v,w"        k="25" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="y,yacute,ydieresis"         k="25" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quotedbl,quotesingle"       k="143" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="76" />
+<hkern g1="f"  g2="T"  k="-41" />
+<hkern g1="f"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="41" />
+<hkern g1="f"  g2="hyphen,endash,emdash"       k="35" />
+<hkern g1="f"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-90" />
+<hkern g1="f"  g2="parenright,bracketright,bar,braceright"     k="-27" />
+<hkern g1="f"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="102" />
+<hkern g1="f"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="47" />
+<hkern g1="f"  g2="s"  k="18" />
+<hkern g1="g"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-41" />
+<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="v,w"        k="10" />
+<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="y,yacute,ydieresis"         k="10" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="T"  k="82" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="Y,Yacute,Ydieresis"         k="61" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="v,w"        k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quotedbl,quotesingle"       k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="96" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="z"  k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="b,h,k,l"    k="18" />
+<hkern g1="r"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="68" />
+<hkern g1="r"  g2="v,w"        k="-27" />
+<hkern g1="r"  g2="y,yacute,ydieresis"         k="-27" />
+<hkern g1="r"  g2="hyphen,endash,emdash"       k="41" />
+<hkern g1="r"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-72" />
+<hkern g1="r"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="113" />
+<hkern g1="r"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="41" />
+<hkern g1="r"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
+<hkern g1="r"  g2="b,h,k,l"    k="23" />
+<hkern g1="s"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="20" />
+<hkern g1="t"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
+<hkern g1="t"  g2="v,w"        k="20" />
+<hkern g1="t"  g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="t"  g2="hyphen,endash,emdash"       k="31" />
+<hkern g1="t"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="t"  g2="b,h,k,l"    k="14" />
+<hkern g1="v,w"        g2="T"  k="61" />
+<hkern g1="v,w"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
+<hkern g1="v,w"        g2="hyphen,endash,emdash"       k="37" />
+<hkern g1="v,w"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-47" />
+<hkern g1="v,w"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="82" />
+<hkern g1="v,w"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="y,yacute,ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
+<hkern g1="y,yacute,ydieresis"         g2="hyphen,endash,emdash"       k="37" />
+<hkern g1="y,yacute,ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-57" />
+<hkern g1="y,yacute,ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="92" />
+<hkern g1="y,yacute,ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="z"  g2="v,w"        k="37" />
+<hkern g1="z"  g2="y,yacute,ydieresis"         k="31" />
+<hkern g1="z"  g2="hyphen,endash,emdash"       k="37" />
+<hkern g1="z"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-82" />
+<hkern g1="z"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="T"  k="143" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="Y,Yacute,Ydieresis"         k="164" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="V,W"        k="143" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="v,w"        k="82" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="y,yacute,ydieresis"         k="82" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="hyphen,endash,emdash"       k="172" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="27" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="J"  k="-51" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="41" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="102" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="T"  k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Y,Yacute,Ydieresis"         k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="V,W"        k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="72" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="v,w"        k="-14" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="205" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="145" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-20" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="J"  k="123" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="z"  k="6" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="b,h,k,l"    k="-55" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="M,N"        k="61" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="s"  k="92" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="S"  k="29" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Z"  k="-20" />
+<hkern g1="quotedbl,quotesingle"       g2="T"  k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="Y,Yacute,Ydieresis"         k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="V,W"        k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="98" />
+<hkern g1="quotedbl,quotesingle"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
+<hkern g1="quotedbl,quotesingle"       g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="J"  k="141" />
+<hkern g1="quotedbl,quotesingle"       g2="M,N"        k="47" />
+<hkern g1="quotedbl,quotesingle"       g2="s"  k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="Z"  k="-27" />
+<hkern g1="hyphen,endash,emdash"       g2="T"  k="123" />
+<hkern g1="hyphen,endash,emdash"       g2="Y,Yacute,Ydieresis"         k="123" />
+<hkern g1="hyphen,endash,emdash"       g2="V,W"        k="61" />
+<hkern g1="hyphen,endash,emdash"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="-31" />
+<hkern g1="hyphen,endash,emdash"       g2="v,w"        k="37" />
+<hkern g1="hyphen,endash,emdash"       g2="y,yacute,ydieresis"         k="37" />
+<hkern g1="hyphen,endash,emdash"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="35" />
+<hkern g1="hyphen,endash,emdash"       g2="z"  k="37" />
+<hkern g1="hyphen,endash,emdash"       g2="S"  k="53" />
+<hkern g1="hyphen,endash,emdash"       g2="Z"  k="20" />
+<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="T"  k="61" />
+<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="Y,Yacute,Ydieresis"         k="41" />
+<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="T"  k="82" />
+<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="61" />
+<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="T"  k="82" />
+<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="57" />
+</font>
+</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/fonts/museo300-regular-webfont.ttf b/karmaworld/assets/css/fonts/museo300-regular-webfont.ttf
new file mode 100644 (file)
index 0000000..5663b82
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo300-regular-webfont.ttf differ
diff --git a/karmaworld/assets/css/fonts/museo300-regular-webfont.woff b/karmaworld/assets/css/fonts/museo300-regular-webfont.woff
new file mode 100644 (file)
index 0000000..dba8de0
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo300-regular-webfont.woff differ
diff --git a/karmaworld/assets/css/fonts/museo700-regular-webfont.eot b/karmaworld/assets/css/fonts/museo700-regular-webfont.eot
new file mode 100644 (file)
index 0000000..d0b51ba
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo700-regular-webfont.eot differ
diff --git a/karmaworld/assets/css/fonts/museo700-regular-webfont.svg b/karmaworld/assets/css/fonts/museo700-regular-webfont.svg
new file mode 100644 (file)
index 0000000..922e88f
--- /dev/null
@@ -0,0 +1,1006 @@
+<?xml version="1.0" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
+<svg xmlns="http://www.w3.org/2000/svg">
+<metadata></metadata>
+<defs>
+<font id="museo700" horiz-adv-x="1267" >
+<font-face units-per-em="2048" ascent="1536" descent="-512" />
+<missing-glyph horiz-adv-x="542" />
+<glyph unicode="&#xfb01;" horiz-adv-x="1298" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-24 4 -59 4q-26 0 -49 -3.5t-51 -14.5t-48 -29t-33.5 -51t-13.5 -76v-21h555q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-245 q-74 0 -107 33t-33 106v654q0 45 -45 45h-389v-838h-260v838h-129zM877 1214v240h225v-240h-225z" />
+<glyph unicode="&#xfb02;" horiz-adv-x="1282" d="M41 838v206h129v31q0 98 31.5 170.5t76 111t107 62t110.5 29.5t101 6h375q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-174q-201 0 -201 -164v-25h223v-206h-223v-838h-260v838h-129z" />
+<glyph unicode="&#xfb03;" horiz-adv-x="1986" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-24 4 -59 4q-33 0 -62.5 -6.5t-62 -23.5t-51.5 -54.5t-19 -91.5v-19h426v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81.5 27t78.5 14 t70.5 3.5q23 0 44.5 -1.5t31.5 -2.5l10 -2v-221q-24 4 -57 4q-34 0 -63.5 -6.5t-62.5 -23.5t-52 -54.5t-19 -91.5v-19h555q73 0 106 -33.5t33 -105.5v-641q0 -45 45 -45h82v-219h-247q-74 0 -107 33t-33 106v654q0 45 -45 45h-389v-838h-260v838h-426v-838h-260v838h-129z M1563 1214v240h225v-240h-225z" />
+<glyph unicode="&#xfb04;" horiz-adv-x="1970" d="M41 838v206h129v33q0 97 31 170t75.5 113t106 64t110.5 31t101 7q24 0 46.5 -1.5t33.5 -2.5l10 -2v-221q-24 4 -57 4q-26 0 -49.5 -3.5t-51.5 -14.5t-48.5 -29t-34 -51t-13.5 -76v-21h428v31q0 98 31.5 170.5t76 111t107 62t110.5 29.5t101 6h375q72 0 105.5 -33.5 t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-174q-201 0 -201 -164v-25h223v-206h-223v-838h-260v838h-428v-838h-260v838h-129z" />
+<glyph horiz-adv-x="2048" />
+<glyph horiz-adv-x="2048" />
+<glyph unicode="&#xd;" horiz-adv-x="2048" />
+<glyph unicode=" "  horiz-adv-x="542" />
+<glyph unicode="&#x09;" horiz-adv-x="542" />
+<glyph unicode="&#xa0;" horiz-adv-x="542" />
+<glyph unicode="!" horiz-adv-x="679" d="M205 1454h270l-20 -1034h-228zM215 0v242h252v-242h-252z" />
+<glyph unicode="&#x22;" horiz-adv-x="755" d="M117 1053v428h192v-428h-192zM444 1053v428h193v-428h-193z" />
+<glyph unicode="#" horiz-adv-x="1433" d="M66 383l30 186h244l51 287h-239l30 188h242l72 410h209l-72 -410h278l72 410h209l-72 -410h248l-33 -188h-245l-52 -287h244l-31 -186h-245l-66 -383h-209l68 383h-281l-65 -383h-209l65 383h-243zM549 569h280l52 287h-281z" />
+<glyph unicode="$" horiz-adv-x="1146" d="M78 268l186 156q5 -8 14 -22t41.5 -50t68 -63t93 -49.5t117.5 -22.5q92 0 150.5 46t58.5 126q0 40 -23.5 74.5t-63 61.5t-91 52t-108 51t-113 55t-108 67.5t-91 84t-63 109.5t-23.5 139q0 151 107 255.5t278 131.5v191h182v-191q49 -6 95.5 -19.5t91.5 -36.5t78.5 -53.5 t54 -74t20.5 -94.5v-135h-242v65q0 50 -54 81.5t-128 31.5q-92 0 -152.5 -42t-60.5 -106q0 -41 23.5 -75.5t63 -60t91 -49t108 -48t113 -52t108 -65t91 -83.5t63 -112t23.5 -145q0 -155 -106.5 -271t-280.5 -142v-191h-182v189q-84 11 -159 45t-122.5 74t-82.5 78t-50 63z " />
+<glyph unicode="%" horiz-adv-x="1689" d="M113 1155q0 133 98 228.5t235 95.5q138 0 237 -96t99 -228q0 -135 -99 -229.5t-237 -94.5t-235.5 94.5t-97.5 229.5zM164 0l1116 1454h240l-1117 -1454h-239zM311 1155q0 -57 39 -96t96 -39t97.5 39t40.5 96q0 56 -40.5 95.5t-97.5 39.5t-96 -39.5t-39 -95.5zM907 297 q0 133 97.5 228.5t236.5 95.5q138 0 236 -96t98 -228q0 -133 -98 -227.5t-236 -94.5q-139 0 -236.5 94t-97.5 228zM1106 299q0 -57 39 -96t96 -39t97 39t40 96q0 56 -40 95.5t-97 39.5t-96 -39.5t-39 -95.5z" />
+<glyph unicode="&#x26;" horiz-adv-x="1333" d="M86 426q0 112 65 213.5t177 134.5v4q-7 3 -19 9.5t-43 32t-54.5 58t-42.5 91t-19 127.5q0 172 124.5 277.5t317.5 105.5q51 0 101.5 -6.5t74.5 -12.5l25 -6l-64 -209q-51 12 -98 12q-96 0 -155.5 -55.5t-59.5 -138.5q0 -34 10.5 -65.5t33.5 -61.5t68.5 -48t108.5 -18h219 v174h260v-174h174v-229h-174v-172q0 -225 -136.5 -359.5t-373.5 -134.5q-228 0 -374 129t-146 322zM356 428q0 -88 68.5 -149.5t181.5 -61.5q119 0 184.5 68t65.5 198v158h-219q-130 0 -205.5 -54.5t-75.5 -158.5z" />
+<glyph unicode="'" horiz-adv-x="430" d="M117 1053v428h196v-428h-196z" />
+<glyph unicode="(" horiz-adv-x="718" d="M166 668q0 491 240 850h221q-230 -383 -230 -832q0 -470 236 -881h-221q-120 176 -183 400.5t-63 462.5z" />
+<glyph unicode=")" horiz-adv-x="718" d="M86 -195q236 411 236 881q0 449 -230 832h221q120 -179 181 -397t61 -453q0 -238 -63 -462.5t-183 -400.5h-223z" />
+<glyph unicode="*" horiz-adv-x="989" d="M76 1065l69 221l248 -100l-18 268h235l-18 -268l248 100l73 -219l-262 -66v-4l172 -202l-186 -138l-141 226h-4l-142 -226l-186 136l170 204v4z" />
+<glyph unicode="+" d="M86 483v203h442v485h211v-485h443v-203h-443v-483h-211v483h-442z" />
+<glyph unicode="," horiz-adv-x="542" d="M45 -215l137 479h250l-196 -479h-191z" />
+<glyph unicode="-" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
+<glyph unicode="." horiz-adv-x="542" d="M145 0v260h252v-260h-252z" />
+<glyph unicode="/" horiz-adv-x="751" d="M-2 -86l520 1614h223l-522 -1614h-221z" />
+<glyph unicode="0" horiz-adv-x="1253" d="M100 729q0 130 16.5 239t55 205t98 162.5t150.5 105t207 38.5t207 -38.5t150 -105t97.5 -162.5t55 -205t16.5 -239t-16.5 -239.5t-55 -206t-97.5 -164t-150 -106t-207 -38.5t-207 38.5t-150.5 106t-98 164t-55 206t-16.5 239.5zM371 729q0 -512 256 -512t256 512 q0 506 -256 506t-256 -506z" />
+<glyph unicode="1" horiz-adv-x="1091" d="M106 1104l365 350h242v-1227h313v-227h-895v227h313v807l2 99h-4q-16 -35 -63 -82l-117 -111z" />
+<glyph unicode="2" horiz-adv-x="1189" d="M68 193q0 84 24.5 155.5t65.5 123.5t94 96.5t112 79.5t118 68t112 67t94 71t65.5 85.5t24.5 104.5q0 86 -58.5 137.5t-152.5 51.5q-82 0 -136 -35.5t-54 -79.5v-63h-242v143q0 69 42.5 125t109.5 88.5t142 50t149 17.5q96 0 181 -29.5t149.5 -83.5t102.5 -136t38 -181 q0 -100 -39 -184t-101 -141.5t-136.5 -106.5t-149.5 -89t-137 -78.5t-101 -85.5t-39 -100q0 -20 13 -28.5t42 -8.5h426q45 0 45 45v88h242v-221q0 -73 -33 -106t-106 -33h-758q-91 0 -120 42t-29 151z" />
+<glyph unicode="3" horiz-adv-x="1138" d="M53 180l135 201l16.5 -16.5t47 -37.5t75.5 -47.5t98.5 -37.5t119.5 -17q108 0 178 61t70 156t-78 154t-197 59h-102l-54 133l246 330q22 33 46 60.5t38 39.5l13 11v4q-46 -6 -130 -6h-182q-45 0 -45 -45v-88h-242v221q0 74 27.5 106.5t99.5 32.5h791v-166l-334 -418 q158 -25 266.5 -137t108.5 -287q0 -92 -35 -176t-99.5 -150t-164 -105.5t-219.5 -39.5q-88 0 -171.5 21t-139.5 51t-99 60.5t-63 51.5z" />
+<glyph unicode="4" horiz-adv-x="1206" d="M37 367v170l602 917h315v-860h224v-227h-224v-367h-268v367h-649zM317 588q59 6 127 6h246v403q0 32 2.5 71.5t5.5 63.5l2 23h-4q-41 -78 -78 -131l-227 -336q-17 -24 -35.5 -48t-28.5 -36l-10 -12v-4z" />
+<glyph unicode="5" horiz-adv-x="1218" d="M96 176l135 203q5 -6 14.5 -16.5t43 -37t70 -47t93.5 -37t117 -16.5q119 0 193 70t74 172q0 116 -91 182t-223 66q-71 0 -139.5 -16.5t-101.5 -32.5l-33 -17l-94 47l53 619q6 74 36.5 106.5t100.5 32.5h537q72 0 105.5 -33.5t33.5 -105.5v-221h-244v88q0 45 -45 45h-239 q-43 0 -46 -45l-18 -201l-10 -68h4q67 27 153 27q244 0 388.5 -136t144.5 -341q0 -96 -37 -184t-104.5 -156.5t-170.5 -109t-227 -40.5q-86 0 -166.5 21t-133.5 50.5t-94 59.5t-60 51z" />
+<glyph unicode="6" horiz-adv-x="1177" d="M68 651q0 118 25.5 234.5t80.5 224t132 189.5t188.5 131t242.5 49q82 0 156.5 -15.5t108.5 -31.5l34 -15l-78 -227q-93 45 -204 45q-82 0 -150.5 -32.5t-114.5 -88.5t-76 -125t-44 -149h4q36 47 113.5 76.5t156.5 29.5q139 0 246.5 -67t163 -176t55.5 -240 q0 -207 -133 -347.5t-344 -140.5q-114 0 -216 46t-179 130t-122.5 213.5t-45.5 286.5zM344 571q0 -138 86 -246t199 -108q100 0 159.5 70t59.5 176q0 114 -70 190t-196 76q-97 0 -167.5 -46t-70.5 -112z" />
+<glyph unicode="7" horiz-adv-x="1101" d="M45 1094v221q0 74 28.5 106.5t98.5 32.5h909v-184l-692 -1270h-293l600 1094q22 40 44 73t33 47l11 13v4q-26 -4 -100 -4h-350q-45 0 -45 -45v-88h-244z" />
+<glyph unicode="8" horiz-adv-x="1193" d="M74 420q0 46 12.5 91t32 80t43.5 66.5t47.5 53.5t43 38.5t31.5 24.5l13 8v4q-7 4 -17.5 11.5t-38.5 34.5t-49.5 57.5t-39 81.5t-17.5 106q0 78 31 150t89 128.5t148 90t199 33.5q209 0 338 -114.5t129 -289.5q0 -57 -16.5 -112.5t-39.5 -93t-46 -67t-39 -43.5l-17 -14v-4 q201 -127 201 -333q0 -84 -37 -162t-103 -138t-164.5 -96.5t-213.5 -36.5q-221 0 -370.5 125.5t-149.5 319.5zM344 436q0 -98 71.5 -158.5t178.5 -60.5q103 0 175.5 57.5t72.5 145.5q0 37 -15 67t-46.5 54t-64.5 41.5t-83 38.5q-107 49 -131 49q-43 0 -100.5 -73.5 t-57.5 -160.5zM395 1071q0 -69 50 -110.5t147 -79.5q77 -31 96 -31q37 0 80 66t43 141q0 82 -57.5 130t-151.5 48q-95 0 -151 -47t-56 -117z" />
+<glyph unicode="9" horiz-adv-x="1177" d="M68 991q0 134 58.5 245t169 177t251.5 66q114 0 215 -46t178.5 -130t122.5 -213.5t45 -286.5q0 -118 -26 -234.5t-80.5 -224t-132 -189.5t-189 -131t-242.5 -49q-82 0 -156.5 15.5t-108.5 31.5l-34 15l78 227q11 -5 29.5 -13t72.5 -21t103 -13q82 0 150.5 32.5 t114.5 89.5t76 126t44 149h-4q-35 -46 -113 -76t-158 -30q-139 0 -246.5 67t-162.5 176t-55 240zM328 991q0 -114 70.5 -190t197.5 -76q96 0 165.5 45.5t69.5 112.5q0 138 -85.5 245t-198.5 107q-100 0 -159.5 -69t-59.5 -175z" />
+<glyph unicode=":" horiz-adv-x="626" d="M188 0v260h250v-260h-250zM188 784v260h250v-260h-250z" />
+<glyph unicode=";" horiz-adv-x="626" d="M72 -215l112 479h248l-168 -479h-192zM190 784v260h250v-260h-250z" />
+<glyph unicode="&#x3c;" d="M131 502v168l985 438v-227l-710 -293v-4l710 -293v-228z" />
+<glyph unicode="=" d="M135 274v201h1000v-201h-1000zM135 694v201h1000v-201h-1000z" />
+<glyph unicode="&#x3e;" d="M145 63v228l711 293v4l-711 293v227l985 -438v-168z" />
+<glyph unicode="?" horiz-adv-x="974" d="M74 1335q6 6 17 16t48.5 35.5t79 45t107 35.5t133.5 16q117 0 217.5 -44.5t164.5 -134t64 -206.5q0 -69 -19.5 -127.5t-51 -100.5t-69.5 -79t-76 -69.5t-69.5 -65t-51 -72t-19.5 -84.5v-80h-252v98q0 82 35 150t84.5 114t99 88.5t84.5 93.5t35 109q0 72 -57 121t-142 49 q-52 0 -107 -21.5t-83 -43.5l-29 -21zM297 0v242h252v-242h-252z" />
+<glyph unicode="@" horiz-adv-x="1607" d="M78 492q0 157 60 298.5t162 243.5t245 161.5t303 59.5q151 0 263.5 -36t176 -99.5t93.5 -140.5t30 -170v-512h150v-186h-568q-100 0 -184.5 32t-139.5 85t-85.5 121.5t-30.5 142.5q0 154 119 264t321 110h174q-3 79 -90 130t-221 51q-145 0 -266 -78t-188.5 -205 t-67.5 -272q0 -150 66.5 -274.5t194.5 -199.5t294 -75v-203q-179 0 -331.5 58.5t-257 159.5t-163.5 239.5t-59 294.5zM811 498q0 -85 55.5 -143t143.5 -58h157v401h-153q-90 0 -146.5 -58t-56.5 -142z" />
+<glyph unicode="A" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z " />
+<glyph unicode="B" horiz-adv-x="1288" d="M68 1227v227h628q201 0 326 -99.5t125 -275.5q0 -113 -51 -193t-125 -118v-4q113 -34 173 -129.5t60 -212.5q0 -85 -26.5 -155.5t-72.5 -119t-109.5 -82.5t-137.5 -49.5t-156 -15.5h-362q-72 0 -105.5 33t-33.5 106v1088h-133zM469 272q0 -45 45 -45h209q96 0 150.5 58.5 t54.5 152.5q0 93 -55 151t-150 58h-254v-375zM469 860h229q82 0 129 53t47 134t-46.5 130.5t-133.5 49.5h-225v-367z" />
+<glyph unicode="C" horiz-adv-x="1452" d="M61 739q0 207 96 376.5t265 266.5t377 97q60 0 129 -9.5t145 -34t136.5 -60t100.5 -93.5t40 -129v-162h-244v82q0 50 -50 87t-116.5 53t-134.5 16q-200 0 -332.5 -134t-132.5 -356q0 -140 62.5 -258.5t171.5 -187t239 -68.5q77 0 150.5 20t123.5 48.5t89.5 56.5t57.5 48 l19 20l142 -193q-9 -10 -25.5 -27t-73 -60t-119.5 -76t-163 -60t-205 -27q-163 0 -303.5 59t-237.5 161.5t-152 243t-55 300.5z" />
+<glyph unicode="D" horiz-adv-x="1464" d="M70 1227v227h592q340 0 540.5 -192t200.5 -533t-200.5 -535t-540.5 -194h-320q-74 0 -106.5 33t-32.5 106v1088h-133zM471 272q0 -45 45 -45h131q222 0 349.5 130t127.5 372q0 239 -128.5 368.5t-348.5 129.5h-176v-955z" />
+<glyph unicode="E" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133z" />
+<glyph unicode="F" horiz-adv-x="1077" d="M70 1227v227h829q73 0 106 -33.5t33 -105.5v-221h-241v88q0 45 -45 45h-281v-412h465v-227h-465v-588h-268v1227h-133z" />
+<glyph unicode="G" horiz-adv-x="1519" d="M63 735q0 154 56.5 292t154.5 237t235.5 157t293.5 58q100 0 191 -19t150 -46t104 -54.5t65 -46.5l20 -19l-151 -192q-6 5 -17.5 14t-50 31t-79 39t-102.5 31t-124 14q-94 0 -179 -36t-149 -100t-101.5 -157t-37.5 -201q0 -231 138 -371.5t339 -140.5q65 0 126.5 15.5 t103.5 38t75 45t48 38.5l16 15v108q0 45 -45 45h-88v228h235q74 0 107 -32.5t33 -104.5v-621h-230v70l2 61h-4q-6 -6 -18.5 -16.5t-54 -37.5t-87.5 -47.5t-119 -37.5t-149 -17q-143 0 -271.5 53.5t-225 150t-153.5 241t-57 315.5z" />
+<glyph unicode="H" horiz-adv-x="1583" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-477h641v477q0 72 33.5 105.5t105.5 33.5h262v-227h-88q-45 0 -45 -45v-1182h-268v610h-641v-610h-268v1182q0 45 -45 45h-88z" />
+<glyph unicode="I" horiz-adv-x="700" d="M78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
+<glyph unicode="J" horiz-adv-x="1103" d="M41 430v84h268v-59q0 -121 54.5 -175.5t136.5 -54.5q81 0 134.5 53t53.5 164v740q0 45 -45 45h-352v227h526q72 0 105.5 -33.5t33.5 -105.5v-885q0 -92 -26 -168.5t-70 -129t-103 -88.5t-124 -52.5t-135 -16.5q-69 0 -134.5 17t-124.5 53.5t-102.5 89t-69.5 128.5 t-26 167z" />
+<glyph unicode="K" horiz-adv-x="1298" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-453h102q46 0 73 8.5t44 38.5l293 545h295l-328 -598q-20 -36 -43 -62.5t-36 -35.5l-13 -8v-5q5 -1 14.5 -5.5t34.5 -30t45 -64.5l185 -371q14 -30 37.5 -38.5t64.5 -8.5h39v-227h-154q-86 0 -127 20.5t-75 88.5l-238 477 q-17 32 -46 40.5t-81 8.5h-86v-635h-268v1182q0 45 -45 45h-88z" />
+<glyph unicode="L" horiz-adv-x="1142" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-1043q0 -45 45 -45h318q45 0 45 45v88h243v-221q0 -73 -33 -106t-106 -33h-641q-74 0 -106.5 33t-32.5 106v1043q0 45 -45 45h-88z" />
+<glyph unicode="M" horiz-adv-x="1781" d="M37 0v227h63q42 0 45 45l95 1182h278l299 -692q16 -37 34 -86t28 -79l10 -30h4q37 111 72 195l299 692h278l94 -1182q3 -45 45 -45h64v-227h-232q-71 0 -101 32t-36 107l-49 647q-5 44 -5 100v21q0 42 2 70l1 35h-4q-43 -144 -80 -226l-242 -536h-217l-241 536 q-16 36 -36 93t-32 96l-12 39h-4q3 -57 3 -107q0 -67 -5 -121l-47 -647q-6 -75 -37.5 -107t-102.5 -32h-231z" />
+<glyph unicode="N" horiz-adv-x="1576" d="M70 0v227h88q45 0 45 45v1182h241l551 -805q25 -37 55.5 -88.5t47.5 -84.5l18 -32h4q-14 121 -14 205v666q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-1182h-239l-553 803q-25 36 -55.5 87.5t-48.5 84.5l-17 33h-4q14 -121 14 -205v-664q0 -73 -32.5 -106 t-106.5 -33h-262z" />
+<glyph unicode="O" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350z" />
+<glyph unicode="P" horiz-adv-x="1239" d="M70 1227v227h665q205 0 334 -131t129 -342q0 -212 -129.5 -345.5t-333.5 -133.5h-264v-502h-268v1227h-133zM471 731h215q113 0 175.5 67.5t62.5 182.5q0 113 -62.5 179.5t-171.5 66.5h-219v-496z" />
+<glyph unicode="Q" horiz-adv-x="1626" d="M61 735q0 154 57.5 291.5t157 236.5t239 156.5t296.5 57.5q159 0 299 -57.5t239.5 -156.5t157.5 -236.5t58 -291.5q0 -247 -160 -459l158 -143l-160 -174l-158 156q-183 -140 -434 -140q-209 0 -381.5 101t-270.5 275.5t-98 383.5zM340 735q0 -216 137 -363t334 -147 q68 0 128 17.5t86 35.5l26 17l-148 137l158 174l147 -147q78 124 78 276q0 210 -137.5 351t-337.5 141q-198 0 -334.5 -141.5t-136.5 -350.5z" />
+<glyph unicode="R" horiz-adv-x="1294" d="M70 1227v227h651q203 0 328 -117.5t125 -320.5q0 -92 -28.5 -167.5t-70.5 -119t-79 -67.5t-64 -29v-4q5 -2 13 -7t27.5 -24t31.5 -43l141 -281q16 -30 39 -38.5t63 -8.5h27v-227h-141q-85 0 -127 21t-76 88l-187 366q-23 42 -50.5 55t-86.5 13h-135v-543h-268v1227h-133z M471 772h213q101 0 158 60t57 169q0 107 -56 166.5t-155 59.5h-217v-455z" />
+<glyph unicode="S" horiz-adv-x="1124" d="M66 201l151 188q6 -7 17.5 -18.5t48 -41t75 -52.5t96.5 -41.5t115 -18.5q88 0 148.5 45.5t60.5 126.5q0 39 -23.5 73t-63 60.5t-91 52t-108 51.5t-113 54.5t-108 66t-91 82t-63 106t-23.5 134.5q0 177 137.5 293.5t348.5 116.5q68 0 140 -16.5t139 -49t110 -90t43 -131.5 v-135h-242v65q0 49 -58.5 81t-133.5 32q-93 0 -153 -43.5t-60 -112.5q0 -39 23.5 -72.5t63 -58.5t91 -48.5t108 -48t113 -52t108 -65t91 -82.5t63 -109t23.5 -140q0 -180 -131.5 -304t-352.5 -124q-66 0 -129 12.5t-111 32.5t-91 44t-73 48t-52 44t-33 32z" />
+<glyph unicode="T" horiz-adv-x="1337" d="M31 1094v229q0 72 29 101.5t102 29.5h1014q73 0 102 -29.5t29 -101.5v-229h-236v88q0 45 -45 45h-223v-1227h-268v1227h-224q-45 0 -45 -45v-88h-235z" />
+<glyph unicode="U" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z" />
+<glyph unicode="V" horiz-adv-x="1400" d="M23 1227v227h170q76 0 111.5 -25t60.5 -94l278 -811q13 -36 26.5 -89.5t20.5 -88.5l8 -35h4q27 131 56 213l278 811q25 70 59.5 94.5t110.5 24.5h172v-227h-39q-27 0 -40.5 -9.5t-22.5 -35.5l-434 -1182h-283l-436 1182q-9 26 -23 35.5t-41 9.5h-36z" />
+<glyph unicode="W" horiz-adv-x="2031" d="M33 1227v227h174q80 0 121.5 -25.5t58.5 -93.5l199 -866q8 -36 14 -74.5t8 -58.5l2 -21h4q8 70 31 154l264 981h228l249 -981q10 -37 17.5 -75.5t9.5 -58.5l2 -20h4q7 72 25 154l201 866q14 68 56 93.5t122 25.5h176v-227h-39q-29 0 -44.5 -10t-21.5 -35l-303 -1182h-309 l-221 823q-11 41 -20.5 86t-12.5 70l-4 25h-4q-12 -87 -39 -181l-231 -823h-312l-301 1182q-10 45 -65 45h-39z" />
+<glyph unicode="X" horiz-adv-x="1255" d="M10 0l451 737l-271 441q-19 32 -35.5 40.5t-52.5 8.5h-61v227h168q74 0 111.5 -21.5t74.5 -84.5l140 -242l92 -176h4q39 92 88 176l141 242q36 63 75 84.5t114 21.5h165v-227h-61q-35 0 -51.5 -9t-36.5 -40l-272 -441l452 -737h-301l-225 383l-92 170h-4 q-39 -86 -88 -170l-224 -383h-301z" />
+<glyph unicode="Y" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48z" />
+<glyph unicode="Z" horiz-adv-x="1204" d="M35 0v170l653 926q26 36 54 69t42 47l15 15v4q-43 -4 -111 -4h-352q-45 0 -45 -45v-88h-244v221q0 72 33 105.5t106 33.5h944v-168l-653 -928q-26 -37 -53.5 -70t-41.5 -47l-15 -14v-4q42 4 110 4h397q46 0 46 45v88h241v-221q0 -73 -32.5 -106t-106.5 -33h-987z" />
+<glyph unicode="[" horiz-adv-x="720" d="M188 -55v1433q0 74 33 107t107 33h264v-189h-137q-45 0 -45 -45v-1245q0 -45 45 -45h137v-189h-264q-74 0 -107 33.5t-33 106.5z" />
+<glyph unicode="\" horiz-adv-x="745" d="M10 1528h223l523 -1614h-224z" />
+<glyph unicode="]" horiz-adv-x="720" d="M129 -6h135q45 0 45 45v1245q0 45 -45 45h-135v189h264q73 0 106 -33t33 -107v-1433q0 -74 -33 -107t-106 -33h-264v189z" />
+<glyph unicode="^" d="M133 502l412 952h164l411 -952h-225l-268 678l-269 -678h-225z" />
+<glyph unicode="_" horiz-adv-x="1169" d="M10 0h1149v-201h-1149v201z" />
+<glyph unicode="`" horiz-adv-x="817" d="M147 1829h250l156 -279h-193z" />
+<glyph unicode="a" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
+<glyph unicode="b" horiz-adv-x="1265" d="M35 1233v221h248q72 0 105.5 -33.5t33.5 -105.5v-303l-4 -88h4q4 6 11.5 15.5t35 34.5t60.5 44.5t88.5 35t117.5 15.5q211 0 337 -151t126 -396q0 -246 -134.5 -396.5t-344.5 -150.5q-61 0 -115.5 15t-88.5 37t-59.5 44t-36.5 37l-11 15h-5q5 -29 5 -70v-53h-246v1188 q0 45 -45 45h-82zM414 516q0 -131 68.5 -226t191.5 -95q111 0 186.5 86.5t75.5 236.5q0 148 -72 238t-188 90q-111 0 -186.5 -83.5t-75.5 -246.5z" />
+<glyph unicode="c" horiz-adv-x="1101" d="M66 522q0 149 67 272.5t199 199t305 75.5q56 0 117 -12t122 -37.5t100.5 -73.5t39.5 -112v-123h-230v57q0 39 -47 60.5t-102 21.5q-135 0 -222 -92.5t-87 -233.5q0 -77 27 -139.5t72.5 -101.5t103.5 -59.5t122 -20.5q50 0 100 14.5t86.5 35.5t65.5 41.5t43 35.5l15 14 l108 -180q-6 -8 -18.5 -20.5t-54.5 -45t-89 -57.5t-122.5 -45.5t-155.5 -20.5q-126 0 -233 43t-179 117t-112.5 174t-40.5 213z" />
+<glyph unicode="d" horiz-adv-x="1273" d="M66 522q0 247 133 397t342 150q64 0 118 -13t86.5 -31.5t55.5 -37.5t32 -32l9 -13h4q-2 27 -2 62v184q0 45 -45 45h-82v221h248q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-240q-129 0 -129 106v39h-4q-4 -7 -11 -18.5t-35 -40.5t-61.5 -51.5t-92.5 -41 t-126 -18.5q-211 0 -337.5 151t-126.5 396zM330 522q0 -149 71 -238t187 -89q111 0 186.5 83t75.5 246q0 84 -27.5 155.5t-87.5 119t-143 47.5q-112 0 -187 -87t-75 -237z" />
+<glyph unicode="e" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
+<glyph unicode="f" horiz-adv-x="706" d="M41 838v206h129v31q0 71 16.5 129t42.5 97.5t63.5 69.5t75 46.5t81 27t78 14t69.5 3.5q24 0 46 -1.5t32 -2.5l10 -2v-221q-22 4 -53 4q-201 0 -201 -170v-25h223v-206h-223v-838h-260v838h-129z" />
+<glyph unicode="g" horiz-adv-x="1253" d="M66 549q0 146 51.5 262t158 187t252.5 71q68 0 126 -15t92.5 -36.5t59.5 -43.5t34 -37l10 -15h4v26q0 39 29 67.5t86 28.5h241v-221h-80q-45 0 -45 -41v-719q0 -129 -47 -227t-127 -154.5t-174.5 -84t-201.5 -27.5q-96 0 -195 24.5t-176 65.5l80 205q14 -8 40 -19.5 t101.5 -31t146.5 -19.5q130 0 212.5 62t82.5 194v49l2 56h-4q-94 -136 -290 -136q-145 0 -253 73t-162 191.5t-54 264.5zM330 557q0 -141 68.5 -229t191.5 -88q50 0 91.5 15.5t77 49t55.5 95.5t20 147q0 301 -261 301q-117 0 -180 -78.5t-63 -212.5z" />
+<glyph unicode="h" horiz-adv-x="1310" d="M35 1233v221h248q72 0 105.5 -33t33.5 -104v-367l-4 -88h4q41 84 136.5 145.5t221.5 61.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-72 0 -104.5 33t-32.5 106v479q0 104 -36.5 158.5t-129.5 54.5q-101 0 -177 -60t-106 -157q-16 -55 -16 -135v-479h-260v1188 q0 45 -45 45h-82z" />
+<glyph unicode="i" horiz-adv-x="612" d="M51 823v221h248q72 0 104.5 -33.5t32.5 -105.5v-641q0 -45 45 -45h82v-219h-248q-72 0 -104.5 33t-32.5 106v639q0 45 -45 45h-82zM190 1214v240h226v-240h-226z" />
+<glyph unicode="j" horiz-adv-x="624" d="M-39 -199q18 -4 45 -4q26 0 50.5 3.5t54.5 15.5t52 32t37 56.5t15 85.5v788q0 45 -45 45h-82v221h248q73 0 106 -33.5t33 -105.5v-936q0 -100 -32.5 -175t-79 -115t-110 -65t-113 -31.5t-101.5 -6.5q-21 0 -40.5 1.5t-28.5 2.5l-9 2v219zM225 1214v240h228v-240h-228z " />
+<glyph unicode="k" horiz-adv-x="1132" d="M35 1233v221h248q75 0 107 -25t32 -94v-659h78q71 0 98 39l213 329h289l-264 -393q-20 -29 -39.5 -49.5t-28.5 -26.5l-10 -6v-4q4 -2 11 -6t26.5 -25t35.5 -51l119 -225q12 -23 30.5 -31t55.5 -8h70v-219h-193q-68 0 -100.5 17t-62.5 73l-175 328q-21 39 -96 39h-57v-457 h-260v1188q0 45 -45 45h-82z" />
+<glyph unicode="l" horiz-adv-x="595" d="M37 1233v221h248q72 0 105.5 -33.5t33.5 -105.5v-1051q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v1049q0 45 -45 45h-82z" />
+<glyph unicode="m" horiz-adv-x="1931" d="M43 823v221h240q137 0 137 -116v-31l-2 -45h4q41 86 132.5 151.5t205.5 65.5q236 0 305 -215h4q44 90 140.5 152.5t215.5 62.5q342 0 342 -397v-408q0 -45 45 -45h80v-219h-245q-74 0 -107 33t-33 106v484q0 49 -5.5 83.5t-20.5 64.5t-44 45t-73 15q-93 0 -160 -68 t-90 -171q-16 -55 -16 -133v-459h-260v623q0 38 -2.5 65.5t-11.5 56t-24 46.5t-41.5 29t-62.5 11q-94 0 -160 -67.5t-92 -173.5q-16 -66 -16 -131v-459h-258v778q0 45 -45 45h-82z" />
+<glyph unicode="n" horiz-adv-x="1316" d="M43 823v221h240q137 0 137 -116v-31l-4 -45h4q15 29 35 56.5t53 57.5t72 52t93 36.5t115 14.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-74 0 -106.5 33t-32.5 106v479q0 104 -36 158.5t-128 54.5q-102 0 -177 -58.5t-103 -154.5q-21 -64 -21 -139v-479h-258v778 q0 45 -45 45h-82z" />
+<glyph unicode="o" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234z" />
+<glyph unicode="p" horiz-adv-x="1271" d="M43 823v221h231q132 0 132 -100v-41h4q4 7 11 18t35.5 39.5t62.5 50.5t94 40t128 18q211 0 338 -151t127 -396q0 -246 -135 -396.5t-344 -150.5q-58 0 -110 14t-85 34.5t-58 41t-36 34.5l-10 14h-4q4 -37 4 -90v-433h-258v1188q0 45 -45 45h-82zM422 516q0 -131 68 -226 t190 -95q112 0 188 86.5t76 236.5q0 148 -72 238t-188 90q-111 0 -186.5 -83.5t-75.5 -246.5z" />
+<glyph unicode="q" horiz-adv-x="1273" d="M68 522q0 247 132 397t341 150q67 0 124.5 -16t92.5 -38.5t60.5 -45t35.5 -38.5l10 -16h4v37q0 42 33 67t100 25h230v-221h-82q-45 0 -45 -45v-1188h-260v443l4 90h-4q-4 -6 -11 -16t-34.5 -35.5t-60.5 -45t-89 -35.5t-119 -16q-211 0 -336.5 151t-125.5 396zM330 522 q0 -148 72 -237.5t188 -89.5q111 0 186.5 83t75.5 246q0 84 -28 155.5t-88.5 119t-143.5 47.5q-111 0 -186.5 -87t-75.5 -237z" />
+<glyph unicode="r" horiz-adv-x="843" d="M43 823v221h238q70 0 104.5 -30.5t34.5 -95.5v-62l-4 -65h4q37 117 126.5 192.5t205.5 75.5l47 -4v-256q-27 4 -64 4q-59 0 -113 -21.5t-101.5 -72.5t-69.5 -125q-23 -84 -23 -170v-414h-258v778q0 45 -45 45h-82z" />
+<glyph unicode="s" horiz-adv-x="958" d="M51 162l123 170q5 -6 15 -16.5t43 -37t67 -47t85 -37t101 -16.5q63 0 102.5 26.5t39.5 76.5q0 29 -30.5 54.5t-79 46.5t-107 44t-117.5 53t-107.5 67t-79 93t-30.5 125q0 100 57 171t146.5 102.5t201.5 31.5q59 0 118 -10.5t117.5 -33.5t95 -68t36.5 -105v-109h-230v52 q0 34 -41 53.5t-90 19.5q-71 0 -113 -24.5t-42 -69.5q0 -33 30.5 -59.5t79.5 -46.5t108.5 -41t118.5 -49.5t108 -64t79.5 -91.5t30.5 -127q0 -145 -114 -232.5t-288 -87.5q-80 0 -154.5 19.5t-123 46.5t-85.5 54.5t-54 46.5z" />
+<glyph unicode="t" horiz-adv-x="757" d="M39 838v206h141v285h254v-285h238v-206h-238v-422q0 -49 15 -86t37 -57.5t51.5 -33.5t54 -16.5t49.5 -3.5l47 4v-227q-33 -6 -80 -6q-36 0 -70 3t-79 13.5t-83 27.5t-76.5 47.5t-65 70.5t-43.5 99.5t-17 131.5v455h-135z" />
+<glyph unicode="u" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z" />
+<glyph unicode="v" horiz-adv-x="1116" d="M25 823v221h149q65 0 99.5 -22t54.5 -76l196 -549q10 -27 20 -64.5t14 -60.5l5 -24h4q17 88 37 149l197 549q20 54 55 76t98 22h140v-221h-25q-43 0 -57 -37l-299 -786h-310l-299 786q-14 37 -57 37h-22z" />
+<glyph unicode="w" horiz-adv-x="1710" d="M20 823v221h179q65 0 98.5 -23.5t48.5 -82.5l154 -580q6 -24 11 -51.5t7 -42.5l2 -16h4q9 55 25 110l192 682h230l194 -682q7 -24 13 -51.5t8 -42.5l2 -16h4q6 55 20 110l152 580q15 59 48.5 82.5t98.5 23.5h179v-221h-29q-24 0 -36 -7.5t-21 -29.5l-250 -786h-293 l-178 596q-7 24 -13.5 52.5t-9.5 44.5l-2 16h-4q-11 -58 -27 -113l-176 -596h-295l-250 786q-7 22 -19.5 29.5t-37.5 7.5h-29z" />
+<glyph unicode="x" horiz-adv-x="1048" d="M23 0l339 528l-172 260q-14 22 -29.5 28.5t-49.5 6.5h-76v221h182q66 0 100.5 -19.5t69.5 -78.5l102 -172l33 -67h4q19 40 33 67l103 172q35 59 68.5 78.5t100.5 19.5h181v-221h-74q-34 0 -50 -6.5t-30 -28.5l-174 -260l342 -528h-289l-182 291q-6 9 -13.5 22.5 t-11.5 22.5l-4 10h-4q-16 -32 -30 -55l-181 -291h-288z" />
+<glyph unicode="y" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5z" />
+<glyph unicode="z" horiz-adv-x="1046" d="M55 0v139l482 588q21 26 43 50t34 35l11 11v4q-31 -4 -97 -4h-188q-45 0 -45 -45v-59h-236v186q0 72 33.5 105.5t106.5 33.5h766v-141l-482 -588q-21 -25 -43 -49t-34 -36l-11 -11v-4q31 6 99 6h229q45 0 45 45v58h236v-185q0 -73 -33 -106t-105 -33h-811z" />
+<glyph unicode="{" horiz-adv-x="720" d="M49 557v227q7 0 19 2t42 14.5t52.5 33.5t41.5 64.5t19 102.5v177q0 89 27.5 155t66 101.5t92 57t94 27t83.5 5.5l63 -2v-193q-17 2 -37 2t-39 -3t-43.5 -13.5t-42.5 -28.5t-30.5 -51.5t-12.5 -77.5v-223q0 -57 -17.5 -105t-42 -75.5t-49 -46.5t-41.5 -26l-18 -7v-4 q7 -2 18 -6.5t40 -24t51.5 -45.5t40.5 -74.5t18 -107.5v-246q0 -45 12.5 -78.5t30.5 -51t42.5 -28.5t43.5 -13.5t39 -2.5l37 2v-193q-26 -4 -63 -4q-43 0 -83.5 5.5t-94 27t-92 57t-66 102.5t-27.5 156v199q0 57 -18 100.5t-43.5 63.5t-51 32.5t-43.5 14.5z" />
+<glyph unicode="|" horiz-adv-x="638" d="M209 -330v1960h221v-1960h-221z" />
+<glyph unicode="}" horiz-adv-x="720" d="M72 -6q17 -2 37 -2t38.5 2.5t43 13.5t41.5 28.5t29.5 51t12.5 78.5v246q0 59 17.5 107.5t42.5 75t50 45t42 24.5l18 6v4q-7 2 -18.5 7t-40.5 25.5t-51.5 47t-41 75t-18.5 105.5v223q0 44 -12 77.5t-29.5 51.5t-42 28.5t-43 13.5t-38.5 3l-37 -2v193q26 2 63 2 q43 0 83.5 -5.5t94 -27t92 -57t66 -101.5t27.5 -155v-177q0 -59 18 -102.5t43.5 -64.5t51 -33.5t43.5 -14.5l18 -2v-227q-7 0 -19 -2t-42 -14.5t-52.5 -32.5t-41.5 -63.5t-19 -100.5v-199q0 -89 -27.5 -156t-66 -102.5t-92 -57t-94 -27t-83.5 -5.5l-63 4v193z" />
+<glyph unicode="~" d="M115 408q0 186 81 279t234 93q57 0 104 -19t79 -46.5t60.5 -55t62.5 -46.5t71 -19q63 0 95 51t32 127h205q0 -187 -80.5 -280t-233.5 -93q-57 0 -104 19t-78.5 46.5t-60 54.5t-62.5 46t-71 19q-64 0 -95.5 -50.5t-31.5 -125.5h-207z" />
+<glyph unicode="&#xa1;" horiz-adv-x="679" d="M205 -410l22 1033h228l20 -1033h-270zM215 801v241h250v-241h-250z" />
+<glyph unicode="&#xa2;" horiz-adv-x="1198" d="M113 727q0 222 117 383t307 195v223h182v-223q132 -25 231.5 -112.5t147.5 -219.5l-234 -90q-32 81 -90 131.5t-139 50.5q-115 0 -187.5 -95t-72.5 -243q0 -154 70 -246t190 -92q81 0 139.5 50t89.5 132l234 -90q-23 -58 -56.5 -110.5t-80 -99.5t-109 -78.5t-133.5 -40.5 v-228h-182v228q-190 32 -307 192.5t-117 382.5z" />
+<glyph unicode="&#xa3;" horiz-adv-x="1200" d="M96 0v227h119v410h-90v178h90v248q0 181 132 298.5t335 117.5q61 0 121.5 -15t102.5 -37t75 -44t49 -37l17 -15l-150 -180q-11 10 -30 24.5t-74.5 39t-106.5 24.5q-90 0 -146.5 -52.5t-56.5 -131.5v-240h363v-178h-363v-410h344q45 0 45 45v88h242v-221q0 -73 -32.5 -106 t-104.5 -33h-881z" />
+<glyph unicode="&#xa5;" horiz-adv-x="1271" d="M27 1227v227h133q74 0 115 -20.5t81 -85.5l191 -320q23 -38 45 -78t32 -61l11 -21h4q37 74 88 160l191 320q38 65 79 85.5t115 20.5h133v-227h-43q-36 0 -52 -8t-34 -37l-188 -301v-4h168v-156h-271l-55 -86v-82h326v-156h-326v-397h-268v397h-328v156h328v82l-56 86 h-274v156h172v4l-188 301q-18 29 -34 37t-52 8h-43z" />
+<glyph unicode="&#xa7;" horiz-adv-x="1030" d="M125 -2l111 176q4 -4 11.5 -10t32 -21.5t50 -27.5t63 -21.5t74.5 -9.5q92 0 151.5 52.5t59.5 154.5q0 46 -19 117l-137 661h205l145 -704q15 -77 15 -117q0 -166 -111.5 -270.5t-308.5 -104.5q-60 0 -117.5 13t-96.5 31.5t-69 36.5t-44 31zM164 1104q0 165 111.5 270 t308.5 105q60 0 117.5 -13t96.5 -31.5t69 -37.5t45 -32l14 -13l-117 -166q-11 9 -30 22.5t-77.5 35.5t-115.5 22q-95 0 -153 -47.5t-58 -145.5q0 -47 14 -102l141 -688h-202l-150 704q-14 68 -14 117z" />
+<glyph unicode="&#xa8;" horiz-adv-x="1042" d="M260 1591v238h180v-238h-180zM627 1591v238h182v-238h-182z" />
+<glyph unicode="&#xa9;" horiz-adv-x="1599" d="M66 727q0 153 58 292t156 239.5t233 159.5t284 59q151 0 287.5 -59t235 -159.5t156.5 -239.5t58 -292t-58 -292.5t-156.5 -240t-235 -160t-287.5 -59.5q-149 0 -284 59.5t-233 160t-156 240t-58 292.5zM248 727q0 -162 72.5 -296.5t198.5 -212t278 -77.5q155 0 283 77.5 t201 212t73 296.5q0 161 -73 295t-201 211.5t-283 77.5q-114 0 -216 -45.5t-175 -123.5t-115.5 -186.5t-42.5 -228.5zM424 723q0 166 108.5 282.5t274.5 116.5q51 0 96.5 -12t78 -31t60 -41.5t45 -45.5t30 -42t17.5 -31l5 -12l-156 -73q-2 5 -6.5 13t-20 28t-33.5 35.5 t-47.5 28.5t-62.5 13q-90 0 -145.5 -65.5t-55.5 -163.5q0 -101 54 -165t147 -64q33 0 63 12t48.5 29.5t32.5 35t20 29.5l6 12l156 -71q-2 -5 -5.5 -12.5t-17 -30t-30 -43t-45 -45.5t-60.5 -43t-77.5 -30.5t-96.5 -12.5q-166 0 -274.5 116.5t-108.5 282.5z" />
+<glyph unicode="&#xaa;" horiz-adv-x="851" d="M100 993q0 46 18.5 83t50.5 59.5t68.5 38t81 23t79 10.5t69.5 3h29q-3 64 -25.5 88.5t-75.5 24.5q-69 0 -69 -31v-30h-176v86q0 38 27.5 65.5t70.5 39.5t79 17t68 5q287 0 287 -269v-221q0 -24 23 -24h53v-164h-140q-91 0 -104 71l-2 19h-4q-2 -4 -7 -11t-21.5 -25 t-36 -31.5t-51.5 -24.5t-68 -11q-92 0 -158 56t-66 153zM102 545v139h660v-139h-660zM291 1001q0 -30 19.5 -49.5t58.5 -19.5q56 0 89.5 45t39.5 113h-21q-186 0 -186 -89z" />
+<glyph unicode="&#xab;" horiz-adv-x="1257" d="M94 578l336 421h248l-336 -421l336 -420h-248zM553 578l336 421h248l-336 -421l336 -420h-248z" />
+<glyph unicode="&#xac;" d="M135 694v201h1000v-602h-209v401h-791z" />
+<glyph unicode="&#xad;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
+<glyph unicode="&#xae;" horiz-adv-x="1599" d="M66 727q0 153 58 292t156 239.5t233 159.5t284 59q151 0 287.5 -59t235 -159.5t156.5 -239.5t58 -292t-58 -292.5t-156.5 -240t-235 -160t-287.5 -59.5q-149 0 -284 59.5t-233 160t-156 240t-58 292.5zM248 727q0 -162 72.5 -296.5t198.5 -212t278 -77.5q155 0 283 77.5 t201 212t73 296.5q0 161 -73 295t-201 211.5t-283 77.5q-114 0 -216 -45.5t-175 -123.5t-115.5 -186.5t-42.5 -228.5zM475 979v127h377q110 0 178 -65.5t68 -172.5q0 -79 -42 -130t-91 -64v-4q27 -6 47 -41l65 -123q14 -25 45 -25h23v-125h-98q-43 0 -66 11.5t-41 44.5 l-100 188q-11 21 -26.5 27t-41.5 6h-57v-277h-174v623h-66zM715 756h96q51 0 80 30t29 82q0 53 -28.5 82t-78.5 29h-98v-223z" />
+<glyph unicode="&#xaf;" horiz-adv-x="956" d="M213 1604v172h537v-172h-537z" />
+<glyph unicode="&#xb0;" horiz-adv-x="839" d="M86 1157q0 133 97.5 228.5t236.5 95.5q138 0 236 -96t98 -228q0 -134 -97.5 -227.5t-236.5 -93.5q-140 0 -237 93t-97 228zM285 1157q0 -57 39 -96t96 -39t97 39t40 96q0 56 -40 95.5t-97 39.5t-96 -39.5t-39 -95.5z" />
+<glyph unicode="&#xb1;" d="M86 483v203h442v485h211v-485h443v-203h-443v-483h-211v483h-442zM115 -174h1040v-201h-1040v201z" />
+<glyph unicode="&#xb2;" horiz-adv-x="894" d="M106 686q0 51 16 95.5t37 74.5t59.5 62t65 48.5t72.5 43.5q86 48 130 88.5t44 97.5q0 44 -29 70t-77 26q-44 0 -71 -18t-27 -43v-45h-181v102q0 60 50 103.5t111.5 61t119.5 17.5q128 0 215.5 -72.5t87.5 -197.5q0 -30 -6 -58t-13.5 -50t-24.5 -45t-28.5 -38t-36.5 -35 l-37.5 -30t-42 -27.5t-40 -23.5t-41.5 -23q-75 -40 -113.5 -71t-38.5 -70q0 -12 23 -12h245q13 0 13 12v68h180v-150q0 -53 -24 -76.5t-76 -23.5h-459q-60 0 -81.5 27t-21.5 112z" />
+<glyph unicode="&#xb3;" horiz-adv-x="894" d="M111 713l135 121q3 -5 9.5 -13t27.5 -29t43 -37t55 -29t65 -13q56 0 94 33t38 83q0 49 -39 79t-101 30h-71l-27 109l147 198q8 10 18 21t17 16l6 6v4q-30 -4 -63 -4h-115q-18 0 -18 -18v-49h-180v133q0 56 21 78t77 22h504v-133l-189 -234q95 -20 153 -94.5t58 -167.5 q0 -132 -97 -213.5t-230 -81.5q-57 0 -113 19t-95 45.5t-69.5 53.5t-45.5 46z" />
+<glyph unicode="&#xb4;" horiz-adv-x="827" d="M252 1550l156 279h249l-215 -279h-190z" />
+<glyph unicode="&#xb6;" horiz-adv-x="1280" d="M80 975q0 201 141 340t340 139h625v-227h-436v-1329h-189v596q-199 0 -340 140t-141 341zM877 -102v1216h190v-1216h-190z" />
+<glyph unicode="&#xb7;" horiz-adv-x="542" d="M145 469v258h252v-258h-252z" />
+<glyph unicode="&#xb8;" horiz-adv-x="860" d="M231 -268q44 -17 91 -17q88 0 88 58q0 55 -99 55l-43 -4l64 227l119 -26v-15l-21 -100q66 -8 108 -48t42 -108q0 -49 -19 -85t-51.5 -56t-70.5 -29.5t-81 -9.5q-31 0 -63 3.5t-48 6.5l-16 4v144z" />
+<glyph unicode="&#xb9;" horiz-adv-x="894" d="M127 1229l235 225h170v-737h187v-170h-572v170h189v420l2 63h-4q-9 -19 -23 -31l-69 -65z" />
+<glyph unicode="&#xba;" horiz-adv-x="931" d="M106 1133q0 148 104.5 245t254.5 97q151 0 255.5 -96.5t104.5 -245.5q0 -150 -104.5 -248.5t-255.5 -98.5q-150 0 -254.5 98.5t-104.5 248.5zM137 545v139h660v-139h-660zM293 1133q0 -80 50 -131.5t122 -51.5q73 0 123.5 51.5t50.5 131.5q0 78 -50.5 129t-123.5 51 q-72 0 -122 -51t-50 -129z" />
+<glyph unicode="&#xbb;" horiz-adv-x="1257" d="M119 158l336 420l-336 421h248l335 -421l-335 -420h-248zM580 158l335 420l-335 421h247l336 -421l-336 -420h-247z" />
+<glyph unicode="&#xbc;" horiz-adv-x="1931" d="M137 1229l234 225h170v-737h178v-170h-561v170h188v420l2 63h-4q-8 -19 -22 -31l-70 -65zM614 0l568 1454h202l-567 -1454h-203zM1102 221v115l358 573h236v-516h133v-172h-133v-221h-197v221h-397zM1300 391q25 2 39 2h164v244l2 70h-4q-12 -31 -28 -58l-144 -219 l-29 -35v-4z" />
+<glyph unicode="&#xbd;" horiz-adv-x="1931" d="M137 1229l234 225h170v-737h178v-170h-561v170h188v420l2 63h-4q-8 -19 -22 -31l-70 -65zM590 0l567 1454h201l-567 -1454h-201zM1161 141q0 50 16 94.5t37.5 75t59.5 62t66 49t73 43.5q43 25 66.5 40t52.5 39t42 50t13 57q0 43 -29.5 68.5t-78.5 25.5q-43 0 -70 -17.5 t-27 -41.5v-47h-180v102q0 46 29 83t73 58.5t90.5 32.5t88.5 11q128 0 215.5 -74t87.5 -199q0 -43 -10 -80.5t-32.5 -68.5t-43 -53.5t-57 -47t-57.5 -37t-62 -34.5q-7 -4 -11 -6q-72 -39 -110.5 -72t-38.5 -72q0 -12 22 -12h244q12 0 12 14v66h183v-150q0 -52 -25 -76 t-78 -24h-456q-61 0 -83 27.5t-22 113.5z" />
+<glyph unicode="&#xbe;" horiz-adv-x="1931" d="M119 713l133 121q4 -5 10 -13t27.5 -29t43.5 -37t55 -29t65 -13q56 0 93.5 32.5t37.5 83.5q0 49 -39 79t-101 30h-71l-27 109l148 198q8 10 18 21t16 16l7 6v4q-31 -4 -64 -4h-115q-18 0 -18 -18v-49h-180v133q0 56 21 78t77 22h504v-133l-189 -234q95 -20 153 -94.5 t58 -167.5q0 -132 -97 -213.5t-230 -81.5q-57 0 -113 19t-94.5 45.5t-69 53.5t-44.5 46zM608 0l568 1454h200l-565 -1454h-203zM1102 221v115l358 573h236v-516h133v-172h-133v-221h-197v221h-397zM1300 391q25 2 39 2h164v244l2 70h-4q-12 -31 -28 -58l-144 -219l-29 -35 v-4z" />
+<glyph unicode="&#xbf;" horiz-adv-x="974" d="M68 -45q0 68 19.5 126.5t51.5 100.5t70 79t76 70t70 65t51.5 72t19.5 85v72h250v-90q0 -60 -18.5 -112.5t-48 -91t-65.5 -73.5t-72 -66t-65.5 -62t-48 -69.5t-18.5 -80.5q0 -72 57.5 -122.5t141.5 -50.5q52 0 106 22.5t83 44.5l28 22l145 -181q-6 -6 -17 -15.5 t-48.5 -34.5t-79.5 -44.5t-107 -35t-133 -15.5q-118 0 -218.5 44.5t-165 134t-64.5 206.5zM426 803v241h250v-241h-250z" />
+<glyph unicode="&#xc0;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM377 1829h250l155 -279h-192zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5 l-8 36h-4q-30 -138 -57 -218z" />
+<glyph unicode="&#xc1;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z M590 1550l155 279h250l-215 -279h-190z" />
+<glyph unicode="&#xc2;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM393 1550l187 279h223l188 -279h-194l-103 166h-4l-104 -166h-193zM506 594h368 l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z" />
+<glyph unicode="&#xc3;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM319 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21 q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z" />
+<glyph unicode="&#xc4;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM418 1591v238h180v-238h-180zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5 l-8 36h-4q-30 -138 -57 -218zM784 1591v238h183v-238h-183z" />
+<glyph unicode="&#xc5;" horiz-adv-x="1380" d="M23 0v227h32q27 0 41 9t23 36l432 1182h280l431 -1182q9 -27 22.5 -36t40.5 -9h33v-227h-160q-76 0 -111.5 25t-60.5 94l-90 254h-492l-90 -254q-25 -70 -59.5 -94.5t-110.5 -24.5h-161zM506 594h368l-124 364q-12 36 -26.5 90.5t-23.5 91.5l-8 36h-4q-30 -138 -57 -218z M508 1686q0 75 54 118t128 43t128 -43t54 -118q0 -74 -54 -117t-128 -43t-128 43t-54 117zM618 1686q0 -31 20.5 -50.5t51.5 -19.5t51.5 19.5t20.5 50.5q0 32 -20.5 51.5t-51.5 19.5t-51.5 -19.5t-20.5 -51.5z" />
+<glyph unicode="&#xc6;" horiz-adv-x="1824" d="M23 0v227h28q28 0 41 9t23 36l485 1182h989q73 0 106.5 -33.5t33.5 -105.5v-221h-244v88q0 45 -45 45h-320v-381h465v-228h-465v-346q0 -24 12 -34.5t39 -10.5h324q45 0 45 45v88h242v-221q0 -73 -33 -106t-107 -33h-645q-79 0 -113 31t-34 108v479h-326l-186 -499 q-27 -69 -62 -94t-110 -25h-143zM610 846h240v381h-96z" />
+<glyph unicode="&#xc7;" horiz-adv-x="1452" d="M61 739q0 207 96 376.5t265 266.5t377 97q60 0 129 -9.5t145 -34t136.5 -60t100.5 -93.5t40 -129v-162h-244v82q0 50 -50 87t-116.5 53t-134.5 16q-200 0 -332.5 -134t-132.5 -356q0 -105 36 -200t98 -164t149 -109.5t184 -40.5q77 0 151.5 19.5t125.5 48t91 56.5t59 47 l19 20l142 -191q-8 -10 -23.5 -26t-69.5 -57t-114 -73.5t-157 -60.5t-200 -31l-14 -67q66 -8 108 -48t42 -108q0 -94 -64 -137t-158 -43q-31 0 -62 3.5t-47 6.5l-15 4v144q43 -17 88 -17q90 0 90 58q0 55 -99 55l-43 -4l43 158q-191 22 -337 127t-224 268.5t-78 361.5z" />
+<glyph unicode="&#xc8;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM295 1829h250l155 -279h-192z" />
+<glyph unicode="&#xc9;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM508 1550l156 279h249l-215 -279h-190z" />
+<glyph unicode="&#xca;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM309 1550l187 279h223l188 -279h-194 l-103 166h-4l-104 -166h-193z" />
+<glyph unicode="&#xcb;" horiz-adv-x="1183" d="M70 1227v227h878q72 0 105.5 -33.5t33.5 -105.5v-221h-243v88q0 45 -45 45h-328v-381h471v-228h-471v-346q0 -45 45 -45h336q45 0 45 45v88h244v-221q0 -73 -33.5 -106t-106.5 -33h-659q-74 0 -106.5 33t-32.5 106v1088h-133zM336 1591v238h180v-238h-180zM702 1591v238 h183v-238h-183z" />
+<glyph unicode="&#xcc;" horiz-adv-x="700" d="M37 1829h250l155 -279h-192zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
+<glyph unicode="&#xcd;" horiz-adv-x="700" d="M78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545zM250 1550l156 279h249l-215 -279h-190z" />
+<glyph unicode="&#xce;" horiz-adv-x="700" d="M51 1550l187 279h223l188 -279h-194l-103 166h-4l-104 -166h-193zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545z" />
+<glyph unicode="&#xcf;" horiz-adv-x="700" d="M76 1591v238h180v-238h-180zM78 0v227h145v1000h-145v227h545v-227h-146v-1000h146v-227h-545zM442 1591v238h183v-238h-183z" />
+<glyph unicode="&#xd0;" horiz-adv-x="1464" d="M70 1227v227h592q340 0 540.5 -192t200.5 -533t-200.5 -535t-540.5 -194h-320q-74 0 -106.5 33t-32.5 106v477h-99v215h99v396h-133zM471 272q0 -45 45 -45h131q222 0 349.5 130t127.5 372q0 239 -128.5 368.5t-348.5 129.5h-176v-396h252v-215h-252v-344z" />
+<glyph unicode="&#xd1;" horiz-adv-x="1576" d="M70 0v227h88q45 0 45 45v1182h241l551 -805q25 -37 55.5 -88.5t47.5 -84.5l18 -32h4q-14 121 -14 205v666q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-1182h-239l-553 803q-25 36 -55.5 87.5t-48.5 84.5l-17 33h-4q14 -121 14 -205v-664q0 -73 -32.5 -106 t-106.5 -33h-262zM434 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
+<glyph unicode="&#xd2;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM496 1829h249l156 -279h-192z" />
+<glyph unicode="&#xd3;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM709 1550l155 279h250l-215 -279h-190z" />
+<glyph unicode="&#xd4;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM510 1550l186 279h224l188 -279h-195l-102 166h-4l-105 -166h-192z" />
+<glyph unicode="&#xd5;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM436 1552q0 281 234 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-48 0 -88.5 21t-63.5 45.5t-52.5 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
+<glyph unicode="&#xd6;" horiz-adv-x="1626" d="M61 737q0 154 58 291t157.5 236t239 157t297.5 58t297.5 -58t239 -157t157.5 -236t58 -291q0 -158 -58 -299t-157.5 -242.5t-239 -161t-297.5 -59.5t-297.5 59.5t-239 161t-157.5 242.5t-58 299zM340 737q0 -143 63.5 -261t172 -184.5t237.5 -66.5t237.5 66.5t172 184.5 t63.5 261q0 208 -137.5 350t-335.5 142t-335.5 -142t-137.5 -350zM535 1591v238h180v-238h-180zM901 1591v238h182v-238h-182z" />
+<glyph unicode="&#xd7;" d="M94 141l404 445l-404 442l142 143l399 -438l399 438l142 -143l-406 -442l406 -445l-142 -141l-399 438l-399 -438z" />
+<glyph unicode="&#xd8;" horiz-adv-x="1628" d="M63 737q0 154 58 291t157.5 236t239 157t297.5 58q203 0 381 -101l94 129l117 -80l-94 -129q119 -105 186.5 -250t67.5 -311q0 -158 -58 -299t-158 -242.5t-239.5 -161t-296.5 -59.5q-206 0 -381 101l-94 -129l-117 80l92 131q-119 106 -185.5 255.5t-66.5 323.5z M342 737q0 -213 135 -358l567 788q-108 62 -229 62q-198 0 -335.5 -142t-137.5 -350zM586 287q103 -62 229 -62q196 0 333.5 147.5t137.5 364.5q0 199 -133 338z" />
+<glyph unicode="&#xd9;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M446 1829h250l156 -279h-193z" />
+<glyph unicode="&#xda;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M659 1550l156 279h250l-215 -279h-191z" />
+<glyph unicode="&#xdb;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M461 1550l186 279h223l189 -279h-195l-102 166h-4l-105 -166h-192z" />
+<glyph unicode="&#xdc;" horiz-adv-x="1515" d="M53 1227v227h262q73 0 106.5 -33.5t33.5 -105.5v-789q0 -141 82.5 -221t220.5 -80q139 0 221 80t82 223v787q0 72 33 105.5t106 33.5h262v-227h-88q-45 0 -45 -45v-664q0 -242 -156.5 -392.5t-412.5 -150.5q-259 0 -416.5 150.5t-157.5 392.5v664q0 45 -45 45h-88z M485 1591v238h181v-238h-181zM852 1591v238h182v-238h-182z" />
+<glyph unicode="&#xdd;" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48zM530 1550l156 279h250l-215 -279h-191 z" />
+<glyph unicode="&#xde;" horiz-adv-x="1249" d="M70 1227v227h262q73 0 106 -33.5t33 -105.5v-96h264q205 0 334 -131.5t129 -342.5q0 -212 -129.5 -344.5t-335.5 -132.5h-262v-268h-268v1182q0 45 -45 45h-88zM471 496h215q113 0 175.5 67t62.5 182q0 114 -62 180t-172 66h-219v-495z" />
+<glyph unicode="&#xdf;" horiz-adv-x="1224" d="M37 0v219h72q45 0 45 45v819q0 124 69 216t175 136t229 44q178 0 301 -102t123 -255q0 -50 -19 -94.5t-46.5 -75.5t-54.5 -59.5t-46 -60.5t-19 -64q0 -25 18.5 -50t47.5 -48.5t64.5 -50t71 -58t64.5 -67.5t47.5 -85t18.5 -104q0 -80 -30.5 -144t-82 -104t-117 -61 t-139.5 -21q-56 0 -107.5 9t-85.5 21.5t-60 25t-38 21.5l-12 9l60 201q11 -7 29.5 -18t72.5 -29t103 -18q64 0 104.5 29t40.5 93q0 33 -24.5 66.5t-61.5 61t-80 62t-80 68.5t-61.5 82.5t-24.5 102.5q0 44 19 85t46 72.5t54 62t46 65.5t19 71q0 57 -45.5 98t-124.5 41 q-86 0 -145 -48.5t-59 -143.5v-926q0 -73 -33 -106t-107 -33h-237z" />
+<glyph unicode="&#xe0;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM242 1452h250l155 -278h-192zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
+<glyph unicode="&#xe1;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM455 1174l155 278h250l-215 -278h-190z " />
+<glyph unicode="&#xe2;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM258 1174l186 278h224l188 -278h-194l-103 165h-4l-104 -165h-193zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127 v24h-45q-350 0 -350 -164z" />
+<glyph unicode="&#xe3;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM184 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -234 -281q-39 0 -72.5 14 t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164z" />
+<glyph unicode="&#xe4;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM283 1214v238h180v-238h-180zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM649 1214 v238h182v-238h-182z" />
+<glyph unicode="&#xe5;" horiz-adv-x="1146" d="M68 301q0 68 26 123t66.5 91t98.5 63t113 41t119.5 23t108 11t88.5 2h33v9q0 111 -45.5 157.5t-147.5 46.5q-21 0 -42 -3t-44.5 -10t-38 -21.5t-14.5 -34.5v-56h-242v111q0 47 20 83.5t55.5 59t74.5 38t86 22.5t80.5 9.5t66.5 2.5q451 0 451 -416v-389q0 -45 45 -45h82 v-219h-234q-68 0 -100.5 32.5t-32.5 82.5l2 45h-4q-3 -8 -10 -20t-33 -44t-59 -56.5t-90 -44.5t-123 -20q-147 0 -251.5 88t-104.5 238zM330 313q0 -56 41 -95.5t116 -39.5q66 0 122 42.5t86 105.5t30 127v24h-45q-350 0 -350 -164zM373 1309q0 75 54 118t128 43t128 -43 t54 -118q0 -74 -54 -117t-128 -43t-128 43t-54 117zM483 1309q0 -31 20.5 -50.5t51.5 -19.5t51.5 19.5t20.5 50.5q0 32 -20.5 51.5t-51.5 19.5t-51.5 -19.5t-20.5 -51.5z" />
+<glyph unicode="&#xe6;" horiz-adv-x="1773" d="M70 301q0 67 24.5 121.5t63 90.5t94.5 62.5t109.5 41t118.5 23t111.5 11t96.5 2.5h35v15q0 110 -48.5 155t-146.5 45q-21 0 -42.5 -3t-44.5 -10t-37.5 -21.5t-14.5 -34.5v-56h-242v111q0 61 35.5 105.5t95.5 67t122 32.5t130 10q252 0 349 -154h4q126 154 348 154 q111 0 200 -40.5t144.5 -111t85 -162.5t29.5 -198l-4 -84h-715q17 -135 100.5 -205.5t206.5 -70.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l108 -180q-6 -6 -18.5 -17t-54 -38t-87 -48t-116 -38t-143.5 -17q-151 0 -261.5 60.5t-177.5 169.5h-4q-8 -19 -23 -43 t-48.5 -58t-75 -61t-106 -46.5t-138.5 -19.5q-151 0 -253.5 87.5t-102.5 236.5zM332 313q0 -58 41 -96.5t119 -38.5q101 0 168 87t67 190v18h-74q-59 0 -110 -6.5t-101.5 -23t-80 -50t-29.5 -80.5zM981 653h444q-3 94 -59 153.5t-139 59.5q-97 0 -161 -57t-85 -156z" />
+<glyph unicode="&#xe7;" horiz-adv-x="1101" d="M66 522q0 149 67 272.5t199 199t305 75.5q56 0 117 -12t122 -37.5t100.5 -73.5t39.5 -112v-123h-230v57q0 39 -47 60.5t-102 21.5q-135 0 -222 -92.5t-87 -233.5q0 -77 27 -139.5t72.5 -101.5t103.5 -59.5t122 -20.5q50 0 100 14.5t86.5 35.5t65.5 41.5t43 35.5l15 14 l108 -180q-6 -8 -18 -20.5t-53 -44.5t-87.5 -56.5t-120.5 -45.5t-153 -22l-14 -65q65 -8 106 -47.5t41 -108.5q0 -64 -33 -106t-80 -58t-106 -16q-32 0 -63.5 3.5t-47.5 6.5l-16 4v144q43 -17 90 -17q88 0 88 58q0 55 -98 55l-43 -4l45 164q-202 36 -322 183.5t-120 350.5z " />
+<glyph unicode="&#xe8;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM276 1452h250l156 -278h-193zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
+<glyph unicode="&#xe9;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155zM489 1174l156 278h250l-215 -278h-191z" />
+<glyph unicode="&#xea;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM291 1174l186 278h223l189 -278h-195l-102 165h-4l-105 -165h-192zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155z" />
+<glyph unicode="&#xeb;" horiz-adv-x="1140" d="M66 522q0 242 147.5 394.5t382.5 152.5q145 0 251.5 -67t159 -178t52.5 -251l-6 -96h-721q14 -133 101.5 -206.5t211.5 -73.5q47 0 94.5 12t81.5 29t61.5 34t41.5 29l14 12l109 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17q-168 0 -297.5 75t-196.5 199 t-67 273zM315 1214v238h181v-238h-181zM340 657h453q-3 92 -59.5 151.5t-137.5 59.5q-99 0 -166.5 -56t-89.5 -155zM682 1214v238h182v-238h-182z" />
+<glyph unicode="&#xec;" horiz-adv-x="618" d="M-18 1454h247l156 -280h-190zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82z" />
+<glyph unicode="&#xed;" horiz-adv-x="618" d="M53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82zM195 1174l155 280h248l-213 -280h-190z" />
+<glyph unicode="&#xee;" horiz-adv-x="618" d="M-6 1174l188 280h224l188 -280h-197l-102 167h-4l-103 -167h-194zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82z" />
+<glyph unicode="&#xef;" horiz-adv-x="618" d="M41 1214v240h180v-240h-180zM53 823v221h248q72 0 105.5 -33.5t33.5 -105.5v-641q0 -45 45 -45h80v-219h-246q-73 0 -106 33t-33 106v639q0 45 -45 45h-82zM356 1214v240h183v-240h-183z" />
+<glyph unicode="&#xf0;" horiz-adv-x="1198" d="M78 485q0 123 55 228t166.5 172t259.5 67q58 0 110.5 -15t75.5 -29l23 -15h4q-60 133 -192 217l-379 -164l-13 154l228 100q-104 51 -236 82l72 205q259 -58 442 -170l303 129l13 -152l-181 -80q281 -246 281 -645q0 -87 -17.5 -169t-58.5 -160t-101 -136.5t-151.5 -93.5 t-203.5 -35q-116 0 -212 43t-158 114.5t-96 163t-34 189.5zM340 479q0 -117 63.5 -200.5t180.5 -83.5q55 0 100 19.5t75 51.5t50.5 74.5t29.5 88t9 93.5q0 100 -65.5 164t-176.5 64q-127 0 -196.5 -79.5t-69.5 -191.5z" />
+<glyph unicode="&#xf1;" horiz-adv-x="1316" d="M43 823v221h240q137 0 137 -116v-31l-4 -45h4q15 29 35 56.5t53 57.5t72 52t93 36.5t115 14.5q365 0 365 -397v-408q0 -45 45 -45h82v-219h-248q-74 0 -106.5 33t-32.5 106v479q0 104 -36 158.5t-128 54.5q-102 0 -177 -58.5t-103 -154.5q-21 -64 -21 -139v-479h-258v778 q0 45 -45 45h-82zM301 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h161q0 -281 -233 -281q-39 0 -72.5 14t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162z" />
+<glyph unicode="&#xf2;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM324 1452h249l156 -278h-192zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234 q0 142 -90.5 234t-220.5 92q-129 0 -219 -92t-90 -234z" />
+<glyph unicode="&#xf3;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM539 1174l155 278h250l-215 -278h-190z" />
+<glyph unicode="&#xf4;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM340 1174l186 278h224l188 -278h-195l-102 165h-4l-105 -165h-192z" />
+<glyph unicode="&#xf5;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM266 1176q0 280 234 280q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90 h162q0 -281 -234 -281q-39 0 -72.5 14t-56.5 33.5t-43.5 39t-43.5 33.5t-46 14q-41 0 -62.5 -36.5t-21.5 -90.5h-162zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92q-129 0 -219 -92t-90 -234z" />
+<glyph unicode="&#xf6;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q158 0 289 -69.5t207.5 -195.5t76.5 -282q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-158 0 -288 69t-206.5 194.5t-76.5 283.5zM328 522q0 -143 90 -234t219 -91q130 0 220.5 91t90.5 234q0 142 -90.5 234t-220.5 92 q-129 0 -219 -92t-90 -234zM365 1214v238h180v-238h-180zM731 1214v238h182v-238h-182z" />
+<glyph unicode="&#xf7;" d="M94 483v203h1067v-203h-1067zM510 55v221h233v-221h-233zM510 895v221h233v-221h-233z" />
+<glyph unicode="&#xf8;" horiz-adv-x="1275" d="M66 522q0 156 76.5 282t207 195.5t287.5 69.5q147 0 274 -65l84 116l113 -78l-82 -112q87 -75 135.5 -180t48.5 -228q0 -158 -76.5 -283.5t-207 -194.5t-289.5 -69q-141 0 -256 56l-84 -119l-113 80l78 108q-93 75 -144.5 183.5t-51.5 238.5zM328 522q0 -128 80 -221 l366 514q-68 33 -137 33q-129 0 -219 -92t-90 -234zM518 221q56 -24 119 -24q130 0 220.5 91t90.5 234q0 119 -69 201z" />
+<glyph unicode="&#xf9;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M328 1452h250l155 -278h-192z" />
+<glyph unicode="&#xfa;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M541 1174l155 278h250l-215 -278h-190z" />
+<glyph unicode="&#xfb;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M342 1174l186 278h224l188 -278h-195l-102 165h-4l-104 -165h-193z" />
+<glyph unicode="&#xfc;" horiz-adv-x="1306" d="M39 823v221h248q72 0 104.5 -33t32.5 -104v-481q0 -104 35.5 -158.5t126.5 -54.5q135 0 214 102.5t79 249.5v479h260v-780q0 -45 45 -45h82v-219h-240q-67 0 -102 30.5t-35 86.5v28l2 48h-4q-40 -89 -137 -153.5t-224 -64.5q-360 0 -360 398v405q0 45 -45 45h-82z M369 1214v238h180v-238h-180zM735 1214v238h183v-238h-183z" />
+<glyph unicode="&#xfd;" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5zM471 1174l156 278h250l-215 -278h-191z" />
+<glyph unicode="&#xfe;" horiz-adv-x="1265" d="M37 1233v221h248q73 0 106 -33.5t33 -105.5v-297l-4 -90h4q98 141 305 141q212 0 341.5 -153.5t129.5 -393.5q0 -238 -129.5 -392.5t-341.5 -154.5q-63 0 -117.5 14.5t-87.5 35t-57 41t-33 34.5l-10 15h-4q4 -37 4 -90v-435h-260v1598q0 45 -45 45h-82zM416 522 q0 -171 74.5 -248t191.5 -77q115 0 185.5 91.5t70.5 233.5q0 143 -70 234.5t-186 91.5q-119 0 -192.5 -78t-73.5 -248z" />
+<glyph unicode="&#xff;" horiz-adv-x="1132" d="M2 -324l100 185q7 -8 20 -20t52.5 -32t77.5 -20q117 0 172 133l35 80l-348 784q-9 22 -21 29.5t-35 7.5h-30v221h172q55 0 86 -22t51 -76l205 -522q9 -24 18 -58.5t13 -57.5l5 -23h5q16 86 34 139l179 522q18 53 51 75.5t88 22.5h176v-221h-31q-25 0 -37.5 -7.5 t-21.5 -29.5l-375 -944q-53 -136 -153.5 -204t-223.5 -68q-46 0 -90 11t-74 26.5t-53.5 31t-34.5 26.5zM297 1214v238h180v-238h-180zM664 1214v238h182v-238h-182z" />
+<glyph unicode="&#x152;" horiz-adv-x="1945" d="M61 729q0 206 96.5 376t264 267.5t369.5 97.5q70 0 162.5 -8t133.5 -8h621q73 0 106 -33.5t33 -105.5v-221h-241v88q0 45 -45 45h-322v-381h465v-228h-465v-391h375q45 0 45 45v88h242v-221q0 -73 -32.5 -106t-101.5 -33h-680q-40 0 -132.5 -9t-163.5 -9 q-202 0 -369.5 99t-264 270.5t-96.5 377.5zM340 729q0 -216 127 -357t324 -141q119 0 180 15v960q-76 17 -180 17q-197 0 -324 -140.5t-127 -353.5z" />
+<glyph unicode="&#x153;" horiz-adv-x="2035" d="M66 520q0 160 77 286.5t206.5 194.5t285.5 68q283 0 440 -215h4q135 215 412 215q146 0 252.5 -67t158.5 -178t52 -251l-6 -96h-721q18 -134 105 -207t208 -73q47 0 94.5 12t82 29t62.5 34t42 29l14 12l107 -180q-7 -6 -19 -17t-53.5 -38t-87 -48t-116.5 -38t-144 -17 q-292 0 -437 222h-4q-159 -222 -444 -222q-158 0 -287.5 66.5t-206.5 192t-77 286.5zM328 520q0 -145 89.5 -234t219.5 -89t220.5 89.5t90.5 235.5q0 145 -91 235.5t-220 90.5t-219 -91t-90 -237zM1235 657h453q-5 94 -59 152.5t-138 58.5q-99 0 -166.5 -56t-89.5 -155z" />
+<glyph unicode="&#x178;" horiz-adv-x="1259" d="M20 1227v227h138q74 0 112 -20t78 -86l193 -320q23 -37 45 -78t32 -64l11 -22h4q37 78 88 164l190 320q38 66 77 86t114 20h137v-227h-47q-33 0 -48.5 -9t-35.5 -40l-344 -543v-635h-268v635l-344 543q-20 31 -35.5 40t-48.5 9h-48zM358 1591v238h181v-238h-181z M725 1591v238h182v-238h-182z" />
+<glyph unicode="&#x2c6;" horiz-adv-x="1026" d="M215 1550l186 279h224l188 -279h-195l-102 166h-4l-104 -166h-193z" />
+<glyph unicode="&#x2dc;" horiz-adv-x="1122" d="M197 1552q0 281 233 281q48 0 88.5 -21t63.5 -45.5t52.5 -45.5t57.5 -21q40 0 62 37t22 90h162q0 -281 -233 -281q-48 0 -88.5 21t-64 45.5t-53 45.5t-57.5 21q-41 0 -62.5 -36.5t-21.5 -90.5h-161z" />
+<glyph unicode="&#x2000;" horiz-adv-x="923" />
+<glyph unicode="&#x2001;" horiz-adv-x="1847" />
+<glyph unicode="&#x2002;" horiz-adv-x="923" />
+<glyph unicode="&#x2003;" horiz-adv-x="1847" />
+<glyph unicode="&#x2004;" horiz-adv-x="615" />
+<glyph unicode="&#x2005;" horiz-adv-x="461" />
+<glyph unicode="&#x2006;" horiz-adv-x="307" />
+<glyph unicode="&#x2007;" horiz-adv-x="307" />
+<glyph unicode="&#x2008;" horiz-adv-x="230" />
+<glyph unicode="&#x2009;" horiz-adv-x="369" />
+<glyph unicode="&#x200a;" horiz-adv-x="102" />
+<glyph unicode="&#x2010;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
+<glyph unicode="&#x2011;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
+<glyph unicode="&#x2012;" horiz-adv-x="882" d="M133 471v227h617v-227h-617z" />
+<glyph unicode="&#x2013;" horiz-adv-x="1357" d="M113 483v203h1132v-203h-1132z" />
+<glyph unicode="&#x2014;" horiz-adv-x="1767" d="M113 483v203h1542v-203h-1542z" />
+<glyph unicode="&#x2018;" horiz-adv-x="501" d="M86 1032l154 447h176l-97 -447h-233z" />
+<glyph unicode="&#x2019;" horiz-adv-x="501" d="M86 1032l96 449h234l-154 -449h-176z" />
+<glyph unicode="&#x201a;" horiz-adv-x="501" d="M86 -182l96 446h234l-154 -446h-176z" />
+<glyph unicode="&#x201c;" horiz-adv-x="827" d="M86 1032l154 447h176l-97 -447h-233zM414 1032l151 447h176l-96 -447h-231z" />
+<glyph unicode="&#x201d;" horiz-adv-x="827" d="M86 1032l96 449h234l-154 -449h-176zM414 1032l96 449h231l-151 -449h-176z" />
+<glyph unicode="&#x201e;" horiz-adv-x="827" d="M86 -182l96 446h234l-154 -446h-176zM414 -182l96 446h231l-151 -446h-176z" />
+<glyph unicode="&#x2022;" horiz-adv-x="960" d="M137 596q0 141 100.5 241.5t241.5 100.5q142 0 242 -100.5t100 -241.5t-100 -241.5t-242 -100.5q-141 0 -241.5 100.5t-100.5 241.5z" />
+<glyph unicode="&#x2026;" horiz-adv-x="2033" d="M309 0v260h250v-260h-250zM891 0v260h252v-260h-252zM1475 0v260h251v-260h-251z" />
+<glyph unicode="&#x202f;" horiz-adv-x="369" />
+<glyph unicode="&#x2039;" horiz-adv-x="802" d="M94 578l336 421h248l-336 -421l336 -420h-248z" />
+<glyph unicode="&#x203a;" horiz-adv-x="802" d="M119 158l336 420l-336 421h248l335 -421l-335 -420h-248z" />
+<glyph unicode="&#x205f;" horiz-adv-x="461" />
+<glyph unicode="&#x20ac;" horiz-adv-x="1253" d="M78 512v156h127q-4 34 -4 61l4 66h-127v157h153q67 233 259 380t442 147q48 0 99 -6.5t77 -13.5l27 -7l-64 -240q-69 21 -145 21q-145 0 -253.5 -75.5t-158.5 -205.5h510l-33 -157h-514q-4 -31 -4 -62l6 -65h488l-31 -156h-410q47 -131 158 -209t252 -78q47 0 96.5 7.5 t75.5 15.5l25 8l47 -242q-107 -39 -248 -39q-259 0 -448 148t-253 389h-153z" />
+<glyph unicode="&#x2122;" horiz-adv-x="2029" d="M70 1206v156q0 53 20 72.5t78 19.5h606q56 0 76 -19.5t20 -72.5v-156h-163v60q0 16 -15 16h-123v-735h-196v735h-119q-16 0 -16 -16v-60h-168zM874 547v170h46q17 0 20 18l57 719h183l186 -428l29 -86h4q12 51 26 86l189 428h180l57 -719q3 -18 21 -18h47v-170h-154 q-57 0 -78.5 17.5t-25.5 74.5l-27 375l2 63h-4l-159 -364h-154l-160 364h-4l2 -63l-27 -375q-4 -57 -24.5 -74.5t-77.5 -17.5h-154z" />
+<glyph unicode="&#x25fc;" horiz-adv-x="1044" d="M0 0v1044h1044v-1044h-1044z" />
+<hkern u1="&#x20;" u2="&#x2026;" k="102" />
+<hkern u1="&#x20;" u2="&#x201e;" k="102" />
+<hkern u1="&#x20;" u2="&#x201d;" k="143" />
+<hkern u1="&#x20;" u2="&#x201c;" k="143" />
+<hkern u1="&#x20;" u2="&#x201a;" k="102" />
+<hkern u1="&#x20;" u2="&#x2019;" k="143" />
+<hkern u1="&#x20;" u2="&#x2018;" k="143" />
+<hkern u1="&#x20;" u2="&#x178;" k="72" />
+<hkern u1="&#x20;" u2="&#xdd;" k="72" />
+<hkern u1="&#x20;" u2="Y" k="72" />
+<hkern u1="&#x20;" u2="W" k="47" />
+<hkern u1="&#x20;" u2="V" k="47" />
+<hkern u1="&#x20;" u2="T" k="41" />
+<hkern u1="&#x20;" u2="&#x2e;" k="102" />
+<hkern u1="&#x20;" u2="&#x2c;" k="102" />
+<hkern u1="&#x22;" u2="X" k="-41" />
+<hkern u1="&#x22;" u2="&#x34;" k="102" />
+<hkern u1="&#x24;" u2="&#x37;" k="41" />
+<hkern u1="&#x27;" u2="X" k="-41" />
+<hkern u1="&#x27;" u2="&#x34;" k="102" />
+<hkern u1="&#x28;" u2="j" k="-43" />
+<hkern u1="&#x28;" u2="&#x34;" k="82" />
+<hkern u1="&#x2b;" u2="&#x37;" k="35" />
+<hkern u1="&#x2c;" u2="&#x39;" k="10" />
+<hkern u1="&#x2c;" u2="&#x37;" k="35" />
+<hkern u1="&#x2c;" u2="&#x36;" k="20" />
+<hkern u1="&#x2c;" u2="&#x34;" k="20" />
+<hkern u1="&#x2c;" u2="&#x30;" k="41" />
+<hkern u1="&#x2d;" u2="x" k="35" />
+<hkern u1="&#x2d;" u2="X" k="20" />
+<hkern u1="&#x2d;" u2="&#x39;" k="57" />
+<hkern u1="&#x2d;" u2="&#x37;" k="123" />
+<hkern u1="&#x2d;" u2="&#x35;" k="49" />
+<hkern u1="&#x2d;" u2="&#x33;" k="82" />
+<hkern u1="&#x2d;" u2="&#x31;" k="61" />
+<hkern u1="&#x2e;" u2="&#x39;" k="10" />
+<hkern u1="&#x2e;" u2="&#x37;" k="35" />
+<hkern u1="&#x2e;" u2="&#x36;" k="20" />
+<hkern u1="&#x2e;" u2="&#x34;" k="20" />
+<hkern u1="&#x2e;" u2="&#x30;" k="41" />
+<hkern u1="&#x2f;" u2="&#x37;" k="-33" />
+<hkern u1="&#x30;" u2="&#x2026;" k="82" />
+<hkern u1="&#x30;" u2="&#x201e;" k="82" />
+<hkern u1="&#x30;" u2="&#x201a;" k="82" />
+<hkern u1="&#x30;" u2="&#xb0;" k="20" />
+<hkern u1="&#x30;" u2="&#x38;" k="23" />
+<hkern u1="&#x30;" u2="&#x37;" k="49" />
+<hkern u1="&#x30;" u2="&#x33;" k="20" />
+<hkern u1="&#x30;" u2="&#x32;" k="23" />
+<hkern u1="&#x30;" u2="&#x31;" k="31" />
+<hkern u1="&#x30;" u2="&#x2e;" k="82" />
+<hkern u1="&#x30;" u2="&#x2c;" k="82" />
+<hkern u1="&#x31;" u2="&#x201d;" k="102" />
+<hkern u1="&#x31;" u2="&#x201c;" k="102" />
+<hkern u1="&#x31;" u2="&#x2019;" k="102" />
+<hkern u1="&#x31;" u2="&#x2018;" k="102" />
+<hkern u1="&#x31;" u2="&#x2014;" k="102" />
+<hkern u1="&#x31;" u2="&#x2013;" k="102" />
+<hkern u1="&#x31;" u2="&#xb0;" k="143" />
+<hkern u1="&#x31;" u2="&#x39;" k="27" />
+<hkern u1="&#x31;" u2="&#x38;" k="14" />
+<hkern u1="&#x31;" u2="&#x37;" k="20" />
+<hkern u1="&#x31;" u2="&#x36;" k="27" />
+<hkern u1="&#x31;" u2="&#x35;" k="14" />
+<hkern u1="&#x31;" u2="&#x34;" k="37" />
+<hkern u1="&#x31;" u2="&#x33;" k="8" />
+<hkern u1="&#x31;" u2="&#x30;" k="31" />
+<hkern u1="&#x31;" u2="&#x2f;" k="-49" />
+<hkern u1="&#x31;" u2="&#x2d;" k="102" />
+<hkern u1="&#x31;" u2="&#x27;" k="123" />
+<hkern u1="&#x31;" u2="&#x25;" k="53" />
+<hkern u1="&#x31;" u2="&#x22;" k="123" />
+<hkern u1="&#x32;" u2="&#x2014;" k="35" />
+<hkern u1="&#x32;" u2="&#x2013;" k="35" />
+<hkern u1="&#x32;" u2="&#x39;" k="37" />
+<hkern u1="&#x32;" u2="&#x37;" k="6" />
+<hkern u1="&#x32;" u2="&#x34;" k="41" />
+<hkern u1="&#x32;" u2="&#x30;" k="10" />
+<hkern u1="&#x32;" u2="&#x2d;" k="35" />
+<hkern u1="&#x33;" u2="&#x39;" k="10" />
+<hkern u1="&#x33;" u2="&#x37;" k="10" />
+<hkern u1="&#x34;" u2="&#x2026;" k="20" />
+<hkern u1="&#x34;" u2="&#x201e;" k="20" />
+<hkern u1="&#x34;" u2="&#x201d;" k="41" />
+<hkern u1="&#x34;" u2="&#x201c;" k="41" />
+<hkern u1="&#x34;" u2="&#x201a;" k="20" />
+<hkern u1="&#x34;" u2="&#x2019;" k="41" />
+<hkern u1="&#x34;" u2="&#x2018;" k="41" />
+<hkern u1="&#x34;" u2="&#xb0;" k="41" />
+<hkern u1="&#x34;" u2="&#x39;" k="20" />
+<hkern u1="&#x34;" u2="&#x34;" k="-61" />
+<hkern u1="&#x34;" u2="&#x32;" k="-41" />
+<hkern u1="&#x34;" u2="&#x31;" k="14" />
+<hkern u1="&#x34;" u2="&#x2e;" k="20" />
+<hkern u1="&#x34;" u2="&#x2c;" k="20" />
+<hkern u1="&#x35;" u2="&#x2026;" k="27" />
+<hkern u1="&#x35;" u2="&#x201e;" k="27" />
+<hkern u1="&#x35;" u2="&#x201a;" k="27" />
+<hkern u1="&#x35;" u2="&#xb0;" k="41" />
+<hkern u1="&#x35;" u2="&#x39;" k="6" />
+<hkern u1="&#x35;" u2="&#x37;" k="35" />
+<hkern u1="&#x35;" u2="&#x35;" k="18" />
+<hkern u1="&#x35;" u2="&#x33;" k="18" />
+<hkern u1="&#x35;" u2="&#x32;" k="10" />
+<hkern u1="&#x35;" u2="&#x31;" k="41" />
+<hkern u1="&#x35;" u2="&#x30;" k="14" />
+<hkern u1="&#x35;" u2="&#x2e;" k="27" />
+<hkern u1="&#x35;" u2="&#x2c;" k="27" />
+<hkern u1="&#x36;" u2="&#x2014;" k="27" />
+<hkern u1="&#x36;" u2="&#x2013;" k="27" />
+<hkern u1="&#x36;" u2="&#x39;" k="20" />
+<hkern u1="&#x36;" u2="&#x37;" k="18" />
+<hkern u1="&#x36;" u2="&#x35;" k="10" />
+<hkern u1="&#x36;" u2="&#x33;" k="10" />
+<hkern u1="&#x36;" u2="&#x30;" k="16" />
+<hkern u1="&#x36;" u2="&#x2d;" k="27" />
+<hkern u1="&#x37;" u2="&#x203a;" k="23" />
+<hkern u1="&#x37;" u2="&#x2039;" k="23" />
+<hkern u1="&#x37;" u2="&#x2026;" k="246" />
+<hkern u1="&#x37;" u2="&#x201e;" k="246" />
+<hkern u1="&#x37;" u2="&#x201d;" k="-72" />
+<hkern u1="&#x37;" u2="&#x201c;" k="-72" />
+<hkern u1="&#x37;" u2="&#x201a;" k="246" />
+<hkern u1="&#x37;" u2="&#x2019;" k="-72" />
+<hkern u1="&#x37;" u2="&#x2018;" k="-72" />
+<hkern u1="&#x37;" u2="&#x2014;" k="111" />
+<hkern u1="&#x37;" u2="&#x2013;" k="111" />
+<hkern u1="&#x37;" u2="&#xbb;" k="23" />
+<hkern u1="&#x37;" u2="&#xb0;" k="-61" />
+<hkern u1="&#x37;" u2="&#xab;" k="23" />
+<hkern u1="&#x37;" u2="&#x3f;" k="-29" />
+<hkern u1="&#x37;" u2="&#x3e;" k="76" />
+<hkern u1="&#x37;" u2="&#x3d;" k="76" />
+<hkern u1="&#x37;" u2="&#x3c;" k="76" />
+<hkern u1="&#x37;" u2="&#x3b;" k="31" />
+<hkern u1="&#x37;" u2="&#x3a;" k="31" />
+<hkern u1="&#x37;" u2="&#x39;" k="18" />
+<hkern u1="&#x37;" u2="&#x38;" k="14" />
+<hkern u1="&#x37;" u2="&#x37;" k="-10" />
+<hkern u1="&#x37;" u2="&#x35;" k="8" />
+<hkern u1="&#x37;" u2="&#x34;" k="119" />
+<hkern u1="&#x37;" u2="&#x32;" k="14" />
+<hkern u1="&#x37;" u2="&#x31;" k="6" />
+<hkern u1="&#x37;" u2="&#x30;" k="41" />
+<hkern u1="&#x37;" u2="&#x2f;" k="123" />
+<hkern u1="&#x37;" u2="&#x2e;" k="246" />
+<hkern u1="&#x37;" u2="&#x2d;" k="111" />
+<hkern u1="&#x37;" u2="&#x2c;" k="246" />
+<hkern u1="&#x37;" u2="&#x2b;" k="76" />
+<hkern u1="&#x38;" u2="&#x39;" k="14" />
+<hkern u1="&#x38;" u2="&#x37;" k="25" />
+<hkern u1="&#x38;" u2="&#x34;" k="-6" />
+<hkern u1="&#x38;" u2="&#x30;" k="23" />
+<hkern u1="&#x39;" u2="&#x2026;" k="82" />
+<hkern u1="&#x39;" u2="&#x201e;" k="82" />
+<hkern u1="&#x39;" u2="&#x201a;" k="82" />
+<hkern u1="&#x39;" u2="&#x38;" k="10" />
+<hkern u1="&#x39;" u2="&#x37;" k="27" />
+<hkern u1="&#x39;" u2="&#x33;" k="10" />
+<hkern u1="&#x39;" u2="&#x32;" k="10" />
+<hkern u1="&#x39;" u2="&#x31;" k="6" />
+<hkern u1="&#x39;" u2="&#x30;" k="10" />
+<hkern u1="&#x39;" u2="&#x2e;" k="82" />
+<hkern u1="&#x39;" u2="&#x2c;" k="82" />
+<hkern u1="&#x3c;" u2="&#x37;" k="35" />
+<hkern u1="&#x3d;" u2="&#x37;" k="35" />
+<hkern u1="&#x3e;" u2="&#x37;" k="35" />
+<hkern u1="A" u2="X" k="14" />
+<hkern u1="B" u2="&#x201d;" k="35" />
+<hkern u1="B" u2="&#x201c;" k="35" />
+<hkern u1="B" u2="&#x2019;" k="35" />
+<hkern u1="B" u2="&#x2018;" k="35" />
+<hkern u1="B" u2="&#x178;" k="51" />
+<hkern u1="B" u2="&#xdd;" k="51" />
+<hkern u1="B" u2="w" k="10" />
+<hkern u1="B" u2="v" k="10" />
+<hkern u1="B" u2="Y" k="51" />
+<hkern u1="B" u2="W" k="25" />
+<hkern u1="B" u2="V" k="25" />
+<hkern u1="B" u2="T" k="39" />
+<hkern u1="B" u2="&#x27;" k="12" />
+<hkern u1="B" u2="&#x22;" k="12" />
+<hkern u1="D" u2="i" k="-14" />
+<hkern u1="D" u2="X" k="23" />
+<hkern u1="F" u2="&#x2026;" k="205" />
+<hkern u1="F" u2="&#x201e;" k="205" />
+<hkern u1="F" u2="&#x201d;" k="-51" />
+<hkern u1="F" u2="&#x201c;" k="-51" />
+<hkern u1="F" u2="&#x201a;" k="205" />
+<hkern u1="F" u2="&#x2019;" k="-51" />
+<hkern u1="F" u2="&#x2018;" k="-51" />
+<hkern u1="F" u2="&#x153;" k="10" />
+<hkern u1="F" u2="&#x152;" k="20" />
+<hkern u1="F" u2="&#xf8;" k="10" />
+<hkern u1="F" u2="&#xf6;" k="10" />
+<hkern u1="F" u2="&#xf5;" k="10" />
+<hkern u1="F" u2="&#xf4;" k="10" />
+<hkern u1="F" u2="&#xf3;" k="10" />
+<hkern u1="F" u2="&#xf2;" k="10" />
+<hkern u1="F" u2="&#xeb;" k="10" />
+<hkern u1="F" u2="&#xea;" k="10" />
+<hkern u1="F" u2="&#xe9;" k="10" />
+<hkern u1="F" u2="&#xe8;" k="10" />
+<hkern u1="F" u2="&#xe7;" k="10" />
+<hkern u1="F" u2="&#xe6;" k="31" />
+<hkern u1="F" u2="&#xe5;" k="31" />
+<hkern u1="F" u2="&#xe4;" k="31" />
+<hkern u1="F" u2="&#xe3;" k="31" />
+<hkern u1="F" u2="&#xe2;" k="31" />
+<hkern u1="F" u2="&#xe1;" k="31" />
+<hkern u1="F" u2="&#xe0;" k="31" />
+<hkern u1="F" u2="&#xd8;" k="20" />
+<hkern u1="F" u2="&#xd6;" k="20" />
+<hkern u1="F" u2="&#xd5;" k="20" />
+<hkern u1="F" u2="&#xd4;" k="20" />
+<hkern u1="F" u2="&#xd3;" k="20" />
+<hkern u1="F" u2="&#xd2;" k="20" />
+<hkern u1="F" u2="&#xc7;" k="20" />
+<hkern u1="F" u2="&#xc6;" k="94" />
+<hkern u1="F" u2="&#xc5;" k="94" />
+<hkern u1="F" u2="&#xc4;" k="94" />
+<hkern u1="F" u2="&#xc3;" k="94" />
+<hkern u1="F" u2="&#xc2;" k="94" />
+<hkern u1="F" u2="&#xc1;" k="94" />
+<hkern u1="F" u2="&#xc0;" k="94" />
+<hkern u1="F" u2="q" k="10" />
+<hkern u1="F" u2="o" k="10" />
+<hkern u1="F" u2="g" k="10" />
+<hkern u1="F" u2="e" k="10" />
+<hkern u1="F" u2="d" k="10" />
+<hkern u1="F" u2="c" k="10" />
+<hkern u1="F" u2="a" k="31" />
+<hkern u1="F" u2="Q" k="20" />
+<hkern u1="F" u2="O" k="20" />
+<hkern u1="F" u2="N" k="14" />
+<hkern u1="F" u2="M" k="14" />
+<hkern u1="F" u2="J" k="37" />
+<hkern u1="F" u2="G" k="20" />
+<hkern u1="F" u2="C" k="20" />
+<hkern u1="F" u2="A" k="94" />
+<hkern u1="F" u2="&#x40;" k="10" />
+<hkern u1="F" u2="&#x2e;" k="205" />
+<hkern u1="F" u2="&#x2c;" k="205" />
+<hkern u1="F" u2="&#x27;" k="-39" />
+<hkern u1="F" u2="&#x22;" k="-39" />
+<hkern u1="K" u2="x" k="10" />
+<hkern u1="L" u2="&#x2a;" k="143" />
+<hkern u1="M" u2="&#x201d;" k="59" />
+<hkern u1="M" u2="&#x201c;" k="59" />
+<hkern u1="M" u2="&#x2019;" k="59" />
+<hkern u1="M" u2="&#x2018;" k="59" />
+<hkern u1="M" u2="&#xfc;" k="-8" />
+<hkern u1="M" u2="&#xfb;" k="-8" />
+<hkern u1="M" u2="&#xfa;" k="-8" />
+<hkern u1="M" u2="&#xf9;" k="-8" />
+<hkern u1="M" u2="&#xf1;" k="-8" />
+<hkern u1="M" u2="u" k="-8" />
+<hkern u1="M" u2="r" k="-8" />
+<hkern u1="M" u2="p" k="-8" />
+<hkern u1="M" u2="n" k="-8" />
+<hkern u1="M" u2="m" k="-8" />
+<hkern u1="M" u2="T" k="35" />
+<hkern u1="M" u2="&#x27;" k="61" />
+<hkern u1="M" u2="&#x22;" k="61" />
+<hkern u1="O" u2="i" k="-14" />
+<hkern u1="O" u2="X" k="23" />
+<hkern u1="P" u2="&#x2026;" k="215" />
+<hkern u1="P" u2="&#x201e;" k="215" />
+<hkern u1="P" u2="&#x201a;" k="215" />
+<hkern u1="P" u2="&#x153;" k="41" />
+<hkern u1="P" u2="&#xf8;" k="41" />
+<hkern u1="P" u2="&#xf6;" k="41" />
+<hkern u1="P" u2="&#xf5;" k="41" />
+<hkern u1="P" u2="&#xf4;" k="41" />
+<hkern u1="P" u2="&#xf3;" k="41" />
+<hkern u1="P" u2="&#xf2;" k="41" />
+<hkern u1="P" u2="&#xeb;" k="41" />
+<hkern u1="P" u2="&#xea;" k="41" />
+<hkern u1="P" u2="&#xe9;" k="41" />
+<hkern u1="P" u2="&#xe8;" k="41" />
+<hkern u1="P" u2="&#xe7;" k="41" />
+<hkern u1="P" u2="&#xe6;" k="41" />
+<hkern u1="P" u2="&#xe5;" k="41" />
+<hkern u1="P" u2="&#xe4;" k="41" />
+<hkern u1="P" u2="&#xe3;" k="41" />
+<hkern u1="P" u2="&#xe2;" k="41" />
+<hkern u1="P" u2="&#xe1;" k="41" />
+<hkern u1="P" u2="&#xe0;" k="41" />
+<hkern u1="P" u2="&#xc6;" k="117" />
+<hkern u1="P" u2="&#xc5;" k="117" />
+<hkern u1="P" u2="&#xc4;" k="117" />
+<hkern u1="P" u2="&#xc3;" k="117" />
+<hkern u1="P" u2="&#xc2;" k="117" />
+<hkern u1="P" u2="&#xc1;" k="117" />
+<hkern u1="P" u2="&#xc0;" k="117" />
+<hkern u1="P" u2="z" k="10" />
+<hkern u1="P" u2="s" k="23" />
+<hkern u1="P" u2="q" k="41" />
+<hkern u1="P" u2="o" k="41" />
+<hkern u1="P" u2="g" k="41" />
+<hkern u1="P" u2="e" k="41" />
+<hkern u1="P" u2="d" k="41" />
+<hkern u1="P" u2="c" k="41" />
+<hkern u1="P" u2="a" k="41" />
+<hkern u1="P" u2="N" k="14" />
+<hkern u1="P" u2="M" k="14" />
+<hkern u1="P" u2="J" k="31" />
+<hkern u1="P" u2="A" k="117" />
+<hkern u1="P" u2="&#x40;" k="41" />
+<hkern u1="P" u2="&#x2e;" k="215" />
+<hkern u1="P" u2="&#x2c;" k="215" />
+<hkern u1="P" u2="&#x27;" k="-10" />
+<hkern u1="P" u2="&#x22;" k="-10" />
+<hkern u1="Q" u2="i" k="-14" />
+<hkern u1="Q" u2="X" k="23" />
+<hkern u1="T" u2="&#xef;" k="-61" />
+<hkern u1="T" u2="j" k="82" />
+<hkern u1="T" u2="i" k="55" />
+<hkern u1="T" u2="&#x20;" k="41" />
+<hkern u1="V" u2="&#x20;" k="47" />
+<hkern u1="W" u2="&#x20;" k="47" />
+<hkern u1="X" u2="&#x201d;" k="-27" />
+<hkern u1="X" u2="&#x201c;" k="-27" />
+<hkern u1="X" u2="&#x2019;" k="-27" />
+<hkern u1="X" u2="&#x2018;" k="-27" />
+<hkern u1="X" u2="&#x2014;" k="20" />
+<hkern u1="X" u2="&#x2013;" k="20" />
+<hkern u1="X" u2="&#x153;" k="14" />
+<hkern u1="X" u2="&#x152;" k="23" />
+<hkern u1="X" u2="&#xf8;" k="14" />
+<hkern u1="X" u2="&#xf6;" k="14" />
+<hkern u1="X" u2="&#xf5;" k="14" />
+<hkern u1="X" u2="&#xf4;" k="14" />
+<hkern u1="X" u2="&#xf3;" k="14" />
+<hkern u1="X" u2="&#xf2;" k="14" />
+<hkern u1="X" u2="&#xeb;" k="14" />
+<hkern u1="X" u2="&#xea;" k="14" />
+<hkern u1="X" u2="&#xe9;" k="14" />
+<hkern u1="X" u2="&#xe8;" k="14" />
+<hkern u1="X" u2="&#xe7;" k="14" />
+<hkern u1="X" u2="&#xd8;" k="23" />
+<hkern u1="X" u2="&#xd6;" k="23" />
+<hkern u1="X" u2="&#xd5;" k="23" />
+<hkern u1="X" u2="&#xd4;" k="23" />
+<hkern u1="X" u2="&#xd3;" k="23" />
+<hkern u1="X" u2="&#xd2;" k="23" />
+<hkern u1="X" u2="&#xc7;" k="23" />
+<hkern u1="X" u2="&#xc6;" k="14" />
+<hkern u1="X" u2="&#xc5;" k="14" />
+<hkern u1="X" u2="&#xc4;" k="14" />
+<hkern u1="X" u2="&#xc3;" k="14" />
+<hkern u1="X" u2="&#xc2;" k="14" />
+<hkern u1="X" u2="&#xc1;" k="14" />
+<hkern u1="X" u2="&#xc0;" k="14" />
+<hkern u1="X" u2="&#x7d;" k="-41" />
+<hkern u1="X" u2="&#x7c;" k="-41" />
+<hkern u1="X" u2="q" k="14" />
+<hkern u1="X" u2="o" k="14" />
+<hkern u1="X" u2="g" k="14" />
+<hkern u1="X" u2="e" k="14" />
+<hkern u1="X" u2="d" k="14" />
+<hkern u1="X" u2="c" k="14" />
+<hkern u1="X" u2="]" k="-41" />
+<hkern u1="X" u2="Q" k="23" />
+<hkern u1="X" u2="O" k="23" />
+<hkern u1="X" u2="G" k="23" />
+<hkern u1="X" u2="C" k="23" />
+<hkern u1="X" u2="A" k="14" />
+<hkern u1="X" u2="&#x40;" k="14" />
+<hkern u1="X" u2="&#x2d;" k="20" />
+<hkern u1="X" u2="&#x29;" k="-41" />
+<hkern u1="X" u2="&#x27;" k="-41" />
+<hkern u1="X" u2="&#x22;" k="-41" />
+<hkern u1="Y" u2="&#x20;" k="72" />
+<hkern u1="[" u2="j" k="-43" />
+<hkern u1="[" u2="&#x34;" k="82" />
+<hkern u1="c" u2="&#xff;" k="10" />
+<hkern u1="c" u2="&#xfd;" k="10" />
+<hkern u1="c" u2="y" k="10" />
+<hkern u1="c" u2="l" k="6" />
+<hkern u1="c" u2="k" k="6" />
+<hkern u1="c" u2="h" k="6" />
+<hkern u1="c" u2="b" k="6" />
+<hkern u1="c" u2="T" k="61" />
+<hkern u1="k" u2="&#x201d;" k="-20" />
+<hkern u1="k" u2="&#x201c;" k="-20" />
+<hkern u1="k" u2="&#x2019;" k="-20" />
+<hkern u1="k" u2="&#x2018;" k="-20" />
+<hkern u1="k" u2="&#x153;" k="16" />
+<hkern u1="k" u2="&#xff;" k="23" />
+<hkern u1="k" u2="&#xfd;" k="23" />
+<hkern u1="k" u2="&#xf8;" k="16" />
+<hkern u1="k" u2="&#xf6;" k="16" />
+<hkern u1="k" u2="&#xf5;" k="16" />
+<hkern u1="k" u2="&#xf4;" k="16" />
+<hkern u1="k" u2="&#xf3;" k="16" />
+<hkern u1="k" u2="&#xf2;" k="16" />
+<hkern u1="k" u2="&#xeb;" k="16" />
+<hkern u1="k" u2="&#xea;" k="16" />
+<hkern u1="k" u2="&#xe9;" k="16" />
+<hkern u1="k" u2="&#xe8;" k="16" />
+<hkern u1="k" u2="&#xe7;" k="16" />
+<hkern u1="k" u2="&#xe6;" k="6" />
+<hkern u1="k" u2="&#xe5;" k="6" />
+<hkern u1="k" u2="&#xe4;" k="6" />
+<hkern u1="k" u2="&#xe3;" k="6" />
+<hkern u1="k" u2="&#xe2;" k="6" />
+<hkern u1="k" u2="&#xe1;" k="6" />
+<hkern u1="k" u2="&#xe0;" k="6" />
+<hkern u1="k" u2="y" k="23" />
+<hkern u1="k" u2="w" k="23" />
+<hkern u1="k" u2="v" k="23" />
+<hkern u1="k" u2="q" k="16" />
+<hkern u1="k" u2="o" k="16" />
+<hkern u1="k" u2="l" k="12" />
+<hkern u1="k" u2="k" k="12" />
+<hkern u1="k" u2="h" k="12" />
+<hkern u1="k" u2="g" k="16" />
+<hkern u1="k" u2="e" k="16" />
+<hkern u1="k" u2="d" k="16" />
+<hkern u1="k" u2="c" k="16" />
+<hkern u1="k" u2="b" k="12" />
+<hkern u1="k" u2="a" k="6" />
+<hkern u1="k" u2="T" k="41" />
+<hkern u1="k" u2="&#x40;" k="16" />
+<hkern u1="x" u2="&#x201d;" k="-41" />
+<hkern u1="x" u2="&#x201c;" k="-41" />
+<hkern u1="x" u2="&#x2019;" k="-41" />
+<hkern u1="x" u2="&#x2018;" k="-41" />
+<hkern u1="x" u2="&#x2014;" k="35" />
+<hkern u1="x" u2="&#x2013;" k="35" />
+<hkern u1="x" u2="&#x2d;" k="35" />
+<hkern u1="&#x7b;" u2="j" k="-43" />
+<hkern u1="&#x7b;" u2="&#x34;" k="82" />
+<hkern u1="&#x7c;" u2="j" k="-43" />
+<hkern u1="&#x7c;" u2="&#x34;" k="82" />
+<hkern u1="&#xa3;" u2="&#x37;" k="20" />
+<hkern u1="&#xa5;" u2="&#x37;" k="-33" />
+<hkern u1="&#xa5;" u2="&#x34;" k="41" />
+<hkern u1="&#xab;" u2="&#x37;" k="74" />
+<hkern u1="&#xbb;" u2="&#x37;" k="74" />
+<hkern u1="&#xc0;" u2="X" k="14" />
+<hkern u1="&#xc1;" u2="X" k="14" />
+<hkern u1="&#xc2;" u2="X" k="14" />
+<hkern u1="&#xc3;" u2="X" k="14" />
+<hkern u1="&#xc4;" u2="X" k="14" />
+<hkern u1="&#xc5;" u2="X" k="14" />
+<hkern u1="&#xd0;" u2="i" k="-14" />
+<hkern u1="&#xd0;" u2="X" k="23" />
+<hkern u1="&#xd2;" u2="i" k="-14" />
+<hkern u1="&#xd2;" u2="X" k="23" />
+<hkern u1="&#xd3;" u2="i" k="-14" />
+<hkern u1="&#xd3;" u2="X" k="23" />
+<hkern u1="&#xd4;" u2="i" k="-14" />
+<hkern u1="&#xd4;" u2="X" k="23" />
+<hkern u1="&#xd5;" u2="i" k="-14" />
+<hkern u1="&#xd5;" u2="X" k="23" />
+<hkern u1="&#xd6;" u2="i" k="-14" />
+<hkern u1="&#xd6;" u2="X" k="23" />
+<hkern u1="&#xd8;" u2="i" k="-14" />
+<hkern u1="&#xd8;" u2="X" k="23" />
+<hkern u1="&#xdd;" u2="&#x20;" k="72" />
+<hkern u1="&#x178;" u2="&#x20;" k="72" />
+<hkern u1="&#x2013;" u2="x" k="35" />
+<hkern u1="&#x2013;" u2="X" k="20" />
+<hkern u1="&#x2013;" u2="&#x39;" k="57" />
+<hkern u1="&#x2013;" u2="&#x37;" k="123" />
+<hkern u1="&#x2013;" u2="&#x35;" k="49" />
+<hkern u1="&#x2013;" u2="&#x33;" k="82" />
+<hkern u1="&#x2013;" u2="&#x31;" k="61" />
+<hkern u1="&#x2014;" u2="x" k="35" />
+<hkern u1="&#x2014;" u2="X" k="20" />
+<hkern u1="&#x2014;" u2="&#x39;" k="57" />
+<hkern u1="&#x2014;" u2="&#x37;" k="123" />
+<hkern u1="&#x2014;" u2="&#x35;" k="49" />
+<hkern u1="&#x2014;" u2="&#x33;" k="82" />
+<hkern u1="&#x2014;" u2="&#x31;" k="61" />
+<hkern u1="&#x2018;" u2="X" k="-27" />
+<hkern u1="&#x2018;" u2="&#x38;" k="49" />
+<hkern u1="&#x2018;" u2="&#x37;" k="-47" />
+<hkern u1="&#x2018;" u2="&#x36;" k="82" />
+<hkern u1="&#x2018;" u2="&#x34;" k="172" />
+<hkern u1="&#x2018;" u2="&#x30;" k="49" />
+<hkern u1="&#x2019;" u2="X" k="-27" />
+<hkern u1="&#x2019;" u2="&#x38;" k="49" />
+<hkern u1="&#x2019;" u2="&#x37;" k="-47" />
+<hkern u1="&#x2019;" u2="&#x36;" k="82" />
+<hkern u1="&#x2019;" u2="&#x34;" k="172" />
+<hkern u1="&#x2019;" u2="&#x30;" k="49" />
+<hkern u1="&#x201a;" u2="&#x39;" k="10" />
+<hkern u1="&#x201a;" u2="&#x37;" k="35" />
+<hkern u1="&#x201a;" u2="&#x36;" k="20" />
+<hkern u1="&#x201a;" u2="&#x34;" k="20" />
+<hkern u1="&#x201a;" u2="&#x30;" k="41" />
+<hkern u1="&#x201c;" u2="X" k="-27" />
+<hkern u1="&#x201c;" u2="&#x38;" k="49" />
+<hkern u1="&#x201c;" u2="&#x37;" k="-47" />
+<hkern u1="&#x201c;" u2="&#x36;" k="82" />
+<hkern u1="&#x201c;" u2="&#x34;" k="172" />
+<hkern u1="&#x201c;" u2="&#x30;" k="49" />
+<hkern u1="&#x201d;" u2="X" k="-27" />
+<hkern u1="&#x201d;" u2="&#x38;" k="49" />
+<hkern u1="&#x201d;" u2="&#x37;" k="-47" />
+<hkern u1="&#x201d;" u2="&#x36;" k="82" />
+<hkern u1="&#x201d;" u2="&#x34;" k="172" />
+<hkern u1="&#x201d;" u2="&#x30;" k="49" />
+<hkern u1="&#x201e;" u2="&#x39;" k="10" />
+<hkern u1="&#x201e;" u2="&#x37;" k="35" />
+<hkern u1="&#x201e;" u2="&#x36;" k="20" />
+<hkern u1="&#x201e;" u2="&#x34;" k="20" />
+<hkern u1="&#x201e;" u2="&#x30;" k="41" />
+<hkern u1="&#x2026;" u2="&#x39;" k="10" />
+<hkern u1="&#x2026;" u2="&#x37;" k="35" />
+<hkern u1="&#x2026;" u2="&#x36;" k="20" />
+<hkern u1="&#x2026;" u2="&#x34;" k="20" />
+<hkern u1="&#x2026;" u2="&#x30;" k="41" />
+<hkern u1="&#x2039;" u2="&#x37;" k="74" />
+<hkern u1="&#x203a;" u2="&#x37;" k="74" />
+<hkern g1="C,Ccedilla"         g2="Y,Yacute,Ydieresis"         k="20" />
+<hkern g1="C,Ccedilla"         g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="10" />
+<hkern g1="C,Ccedilla"         g2="quotedbl,quotesingle"       k="-47" />
+<hkern g1="C,Ccedilla"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-51" />
+<hkern g1="C,Ccedilla"         g2="parenright,bracketright,bar,braceright"     k="-35" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="T"  k="39" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="Y,Yacute,Ydieresis"         k="72" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="V,W"        k="20" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-10" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="v,w"        k="-6" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="y,yacute,ydieresis"         k="-6" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="hyphen,endash,emdash"       k="-31" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quotedbl,quotesingle"       k="20" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="14" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="27" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
+<hkern g1="D,O,Q,Eth,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="T"  k="14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="V,W"        k="31" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="v,w"        k="6" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="J"  k="-14" />
+<hkern g1="E,Egrave,Eacute,Ecircumflex,Edieresis"      g2="f,uniFB01,uniFB02,uniFB03,uniFB04"  k="-12" />
+<hkern g1="G"  g2="T"  k="33" />
+<hkern g1="G"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="16" />
+<hkern g1="G"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="-18" />
+<hkern g1="G"  g2="hyphen,endash,emdash"       k="-41" />
+<hkern g1="G"  g2="quotedbl,quotesingle"       k="10" />
+<hkern g1="G"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="41" />
+<hkern g1="G"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-18" />
+<hkern g1="G"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-18" />
+<hkern g1="G"  g2="colon,semicolon"    k="-55" />
+<hkern g1="G"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="12" />
+<hkern g1="H,N,Ntilde"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="20" />
+<hkern g1="H,N,Ntilde"         g2="v,w"        k="20" />
+<hkern g1="H,N,Ntilde"         g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="H,N,Ntilde"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="41" />
+<hkern g1="H,N,Ntilde"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="10" />
+<hkern g1="J"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="27" />
+<hkern g1="J"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
+<hkern g1="J"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="20" />
+<hkern g1="J"  g2="colon,semicolon"    k="35" />
+<hkern g1="K"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="47" />
+<hkern g1="K"  g2="v,w"        k="61" />
+<hkern g1="K"  g2="y,yacute,ydieresis"         k="41" />
+<hkern g1="K"  g2="hyphen,endash,emdash"       k="66" />
+<hkern g1="K"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="6" />
+<hkern g1="K"  g2="parenright,bracketright,bar,braceright"     k="-51" />
+<hkern g1="K"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
+<hkern g1="K"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="K"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="18" />
+<hkern g1="K"  g2="colon,semicolon"    k="-61" />
+<hkern g1="K"  g2="z"  k="20" />
+<hkern g1="K"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="16" />
+<hkern g1="L"  g2="T"  k="205" />
+<hkern g1="L"  g2="Y,Yacute,Ydieresis"         k="164" />
+<hkern g1="L"  g2="V,W"        k="82" />
+<hkern g1="L"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="41" />
+<hkern g1="L"  g2="U,Ugrave,Uacute,Ucircumflex,Udieresis"      k="76" />
+<hkern g1="L"  g2="v,w"        k="98" />
+<hkern g1="L"  g2="y,yacute,ydieresis"         k="80" />
+<hkern g1="L"  g2="hyphen,endash,emdash"       k="39" />
+<hkern g1="L"  g2="quotedbl,quotesingle"       k="166" />
+<hkern g1="L"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="123" />
+<hkern g1="L"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-20" />
+<hkern g1="L"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="L"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
+<hkern g1="L"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="10" />
+<hkern g1="L"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="63" />
+<hkern g1="L"  g2="b,h,k,l"    k="27" />
+<hkern g1="R"  g2="T"  k="47" />
+<hkern g1="R"  g2="Y,Yacute,Ydieresis"         k="61" />
+<hkern g1="R"  g2="V,W"        k="10" />
+<hkern g1="R"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="6" />
+<hkern g1="R"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="37" />
+<hkern g1="R"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="-41" />
+<hkern g1="R"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="-20" />
+<hkern g1="R"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="14" />
+<hkern g1="R"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-14" />
+<hkern g1="S"  g2="hyphen,endash,emdash"       k="-23" />
+<hkern g1="S"  g2="quotedbl,quotesingle"       k="-14" />
+<hkern g1="S"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="-10" />
+<hkern g1="S"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-10" />
+<hkern g1="S"  g2="z"  k="10" />
+<hkern g1="T"  g2="Y,Yacute,Ydieresis"         k="-20" />
+<hkern g1="T"  g2="V,W"        k="-14" />
+<hkern g1="T"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="39" />
+<hkern g1="T"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="123" />
+<hkern g1="T"  g2="v,w"        k="127" />
+<hkern g1="T"  g2="y,yacute,ydieresis"         k="133" />
+<hkern g1="T"  g2="hyphen,endash,emdash"       k="123" />
+<hkern g1="T"  g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="T"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
+<hkern g1="T"  g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="176" />
+<hkern g1="T"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="154" />
+<hkern g1="T"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="92" />
+<hkern g1="T"  g2="J"  k="102" />
+<hkern g1="T"  g2="z"  k="127" />
+<hkern g1="T"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="61" />
+<hkern g1="T"  g2="M,N"        k="23" />
+<hkern g1="T"  g2="s"  k="96" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="20" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="41" />
+<hkern g1="U,Ugrave,Uacute,Ucircumflex,Udieresis"      g2="M,N"        k="10" />
+<hkern g1="V,W"        g2="T"  k="-14" />
+<hkern g1="V,W"        g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="V,W"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="96" />
+<hkern g1="V,W"        g2="hyphen,endash,emdash"       k="61" />
+<hkern g1="V,W"        g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="V,W"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-10" />
+<hkern g1="V,W"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="143" />
+<hkern g1="V,W"        g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="63" />
+<hkern g1="V,W"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="109" />
+<hkern g1="V,W"        g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="41" />
+<hkern g1="V,W"        g2="J"  k="59" />
+<hkern g1="V,W"        g2="M,N"        k="12" />
+<hkern g1="V,W"        g2="S"  k="10" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="T"  k="-20" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="hyphen,endash,emdash"       k="123" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="quotedbl,quotesingle"       k="-41" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-6" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="164" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="158" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="143" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="76" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="J"  k="72" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="z"  k="61" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="41" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="M,N"        k="35" />
+<hkern g1="Y,Yacute,Ydieresis"         g2="s"  k="98" />
+<hkern g1="Z"  g2="hyphen,endash,emdash"       k="35" />
+<hkern g1="Z"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="20" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="T"  k="174" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="v,w"        k="20" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quotedbl,quotesingle"       k="143" />
+<hkern g1="a,h,m,n,agrave,aacute,acircumflex,atilde,adieresis,aring,ntilde"    g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="76" />
+<hkern g1="f"  g2="T"  k="-41" />
+<hkern g1="f"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="37" />
+<hkern g1="f"  g2="hyphen,endash,emdash"       k="35" />
+<hkern g1="f"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-90" />
+<hkern g1="f"  g2="parenright,bracketright,bar,braceright"     k="-27" />
+<hkern g1="f"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="102" />
+<hkern g1="f"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="45" />
+<hkern g1="f"  g2="s"  k="14" />
+<hkern g1="g"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-41" />
+<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="v,w"        k="10" />
+<hkern g1="i,igrave,iacute,icircumflex,idieresis,uniFB01,uniFB03"      g2="y,yacute,ydieresis"         k="10" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="T"  k="82" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="Y,Yacute,Ydieresis"         k="61" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="v,w"        k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quotedbl,quotesingle"       k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="82" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="27" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="z"  k="20" />
+<hkern g1="b,o,p,ograve,oacute,ocircumflex,otilde,odieresis,oslash,thorn"      g2="b,h,k,l"    k="16" />
+<hkern g1="r"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="61" />
+<hkern g1="r"  g2="v,w"        k="-27" />
+<hkern g1="r"  g2="y,yacute,ydieresis"         k="-27" />
+<hkern g1="r"  g2="hyphen,endash,emdash"       k="41" />
+<hkern g1="r"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-72" />
+<hkern g1="r"  g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="113" />
+<hkern g1="r"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="39" />
+<hkern g1="r"  g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-12" />
+<hkern g1="r"  g2="b,h,k,l"    k="20" />
+<hkern g1="s"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="20" />
+<hkern g1="t"  g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="6" />
+<hkern g1="t"  g2="v,w"        k="20" />
+<hkern g1="t"  g2="y,yacute,ydieresis"         k="20" />
+<hkern g1="t"  g2="hyphen,endash,emdash"       k="31" />
+<hkern g1="t"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="16" />
+<hkern g1="t"  g2="b,h,k,l"    k="12" />
+<hkern g1="v,w"        g2="T"  k="61" />
+<hkern g1="v,w"        g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="10" />
+<hkern g1="v,w"        g2="hyphen,endash,emdash"       k="29" />
+<hkern g1="v,w"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-47" />
+<hkern g1="v,w"        g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="82" />
+<hkern g1="v,w"        g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="y,yacute,ydieresis"         g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="14" />
+<hkern g1="y,yacute,ydieresis"         g2="hyphen,endash,emdash"       k="29" />
+<hkern g1="y,yacute,ydieresis"         g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-57" />
+<hkern g1="y,yacute,ydieresis"         g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="92" />
+<hkern g1="y,yacute,ydieresis"         g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="z"  g2="v,w"        k="37" />
+<hkern g1="z"  g2="y,yacute,ydieresis"         k="31" />
+<hkern g1="z"  g2="hyphen,endash,emdash"       k="29" />
+<hkern g1="z"  g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="-82" />
+<hkern g1="z"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="T"  k="143" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="Y,Yacute,Ydieresis"         k="164" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="V,W"        k="143" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="v,w"        k="82" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="y,yacute,ydieresis"         k="82" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="hyphen,endash,emdash"       k="145" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="27" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="J"  k="-51" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="B,D,E,F,H,K,L,P,R,Egrave,Eacute,Ecircumflex,Edieresis"      k="41" />
+<hkern g1="comma,period,quotesinglbase,quotedblbase,ellipsis"  g2="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  k="102" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="T"  k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Y,Yacute,Ydieresis"         k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="V,W"        k="-33" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="72" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="92" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="v,w"        k="-14" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="comma,period,quotesinglbase,quotedblbase,ellipsis"  k="205" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="145" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="m,n,p,r,u,ntilde,ugrave,uacute,ucircumflex,udieresis"       k="-20" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="J"  k="123" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="z"  k="6" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="b,h,k,l"    k="-55" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="M,N"        k="61" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="s"  k="92" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="S"  k="29" />
+<hkern g1="quoteleft,quoteright,quotedblleft,quotedblright"    g2="Z"  k="-20" />
+<hkern g1="quotedbl,quotesingle"       g2="T"  k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="Y,Yacute,Ydieresis"         k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="V,W"        k="-41" />
+<hkern g1="quotedbl,quotesingle"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="a,agrave,aacute,acircumflex,atilde,adieresis,aring,ae"      k="90" />
+<hkern g1="quotedbl,quotesingle"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="184" />
+<hkern g1="quotedbl,quotesingle"       g2="at,c,d,e,g,o,q,ccedilla,egrave,eacute,ecircumflex,edieresis,ograve,oacute,ocircumflex,otilde,odieresis,oslash,oe"   k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="J"  k="141" />
+<hkern g1="quotedbl,quotesingle"       g2="M,N"        k="47" />
+<hkern g1="quotedbl,quotesingle"       g2="s"  k="20" />
+<hkern g1="quotedbl,quotesingle"       g2="Z"  k="-27" />
+<hkern g1="hyphen,endash,emdash"       g2="T"  k="123" />
+<hkern g1="hyphen,endash,emdash"       g2="Y,Yacute,Ydieresis"         k="123" />
+<hkern g1="hyphen,endash,emdash"       g2="V,W"        k="61" />
+<hkern g1="hyphen,endash,emdash"       g2="C,G,O,Q,Ccedilla,Ograve,Oacute,Ocircumflex,Otilde,Odieresis,Oslash,OE"      k="-31" />
+<hkern g1="hyphen,endash,emdash"       g2="v,w"        k="29" />
+<hkern g1="hyphen,endash,emdash"       g2="y,yacute,ydieresis"         k="29" />
+<hkern g1="hyphen,endash,emdash"       g2="A,Agrave,Aacute,Acircumflex,Atilde,Adieresis,Aring,AE"      k="18" />
+<hkern g1="hyphen,endash,emdash"       g2="z"  k="29" />
+<hkern g1="hyphen,endash,emdash"       g2="S"  k="35" />
+<hkern g1="hyphen,endash,emdash"       g2="Z"  k="20" />
+<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="T"  k="61" />
+<hkern g1="guillemotleft,guillemotright,guilsinglleft,guilsinglright"  g2="Y,Yacute,Ydieresis"         k="41" />
+<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="T"  k="82" />
+<hkern g1="u,ugrave,uacute,ucircumflex,udieresis"      g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="61" />
+<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="T"  k="82" />
+<hkern g1="e,ae,egrave,eacute,ecircumflex,edieresis,oe"        g2="quoteleft,quoteright,quotedblleft,quotedblright"    k="53" />
+</font>
+</defs></svg> 
\ No newline at end of file
diff --git a/karmaworld/assets/css/fonts/museo700-regular-webfont.ttf b/karmaworld/assets/css/fonts/museo700-regular-webfont.ttf
new file mode 100644 (file)
index 0000000..e8203c6
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo700-regular-webfont.ttf differ
diff --git a/karmaworld/assets/css/fonts/museo700-regular-webfont.woff b/karmaworld/assets/css/fonts/museo700-regular-webfont.woff
new file mode 100644 (file)
index 0000000..fc95afd
Binary files /dev/null and b/karmaworld/assets/css/fonts/museo700-regular-webfont.woff differ
diff --git a/karmaworld/assets/css/foundation.css b/karmaworld/assets/css/foundation.css
new file mode 100644 (file)
index 0000000..5609aa4
--- /dev/null
@@ -0,0 +1,6371 @@
+meta.foundation-version {
+  font-family: "/5.2.1/"; }
+
+meta.foundation-mq-small {
+  font-family: "/only screen and (max-width: 40em)/";
+  width: 0em; }
+
+meta.foundation-mq-medium {
+  font-family: "/only screen and (min-width:40.063em)/";
+  width: 40.063em; }
+
+meta.foundation-mq-large {
+  font-family: "/only screen and (min-width:64.063em)/";
+  width: 64.063em; }
+
+meta.foundation-mq-xlarge {
+  font-family: "/only screen and (min-width:90.063em)/";
+  width: 90.063em; }
+
+meta.foundation-mq-xxlarge {
+  font-family: "/only screen and (min-width:120.063em)/";
+  width: 120.063em; }
+
+meta.foundation-data-attribute-namespace {
+  font-family: false; }
+
+html, body {
+  height: 100%; }
+
+*,
+*:before,
+*:after {
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box; }
+
+html,
+body {
+  font-size: 100%; }
+
+body {
+  background: white;
+  color: #222222;
+  padding: 0;
+  margin: 0;
+  font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+  font-weight: normal;
+  font-style: normal;
+  line-height: 1;
+  position: relative;
+  cursor: default; }
+
+a:hover {
+  cursor: pointer; }
+
+img {
+  max-width: 100%;
+  height: auto; }
+
+img {
+  -ms-interpolation-mode: bicubic; }
+
+#map_canvas img,
+#map_canvas embed,
+#map_canvas object,
+.map_canvas img,
+.map_canvas embed,
+.map_canvas object {
+  max-width: none !important; }
+
+.left {
+  float: left !important; }
+
+.right {
+  float: right !important; }
+
+.clearfix {
+  *zoom: 1; }
+  .clearfix:before, .clearfix:after {
+    content: " ";
+    display: table; }
+  .clearfix:after {
+    clear: both; }
+
+.hide {
+  display: none; }
+
+.antialiased {
+  -webkit-font-smoothing: antialiased;
+  -moz-osx-font-smoothing: grayscale; }
+
+img {
+  display: inline-block;
+  vertical-align: middle; }
+
+textarea {
+  height: auto;
+  min-height: 50px; }
+
+select {
+  width: 100%; }
+
+.xy-center {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+  -ms-transform: translate(-50%, -50%);
+  transform: translate(-50%, -50%); }
+
+.x-center {
+  position: absolute;
+  left: 50%;
+  -webkit-transform: translateX(-50%);
+  -ms-transform: translateX(-50%);
+  transform: translateX(-50%); }
+
+.y-center {
+  position: relative;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+  -ms-transform: translateY(-50%);
+  transform: translateY(-50%); }
+
+.row {
+  width: 100%;
+  margin-left: auto;
+  margin-right: auto;
+  margin-top: 0;
+  margin-bottom: 0;
+  max-width: 62.5rem;
+  *zoom: 1; }
+  .row:before, .row:after {
+    content: " ";
+    display: table; }
+  .row:after {
+    clear: both; }
+  .row.collapse > .column,
+  .row.collapse > .columns {
+    padding-left: 0;
+    padding-right: 0; }
+  .row.collapse .row {
+    margin-left: 0;
+    margin-right: 0; }
+  .row .row {
+    width: auto;
+    margin-left: -0.9375rem;
+    margin-right: -0.9375rem;
+    margin-top: 0;
+    margin-bottom: 0;
+    max-width: none;
+    *zoom: 1; }
+    .row .row:before, .row .row:after {
+      content: " ";
+      display: table; }
+    .row .row:after {
+      clear: both; }
+    .row .row.collapse {
+      width: auto;
+      margin: 0;
+      max-width: none;
+      *zoom: 1; }
+      .row .row.collapse:before, .row .row.collapse:after {
+        content: " ";
+        display: table; }
+      .row .row.collapse:after {
+        clear: both; }
+
+.column,
+.columns {
+  padding-left: 0.9375rem;
+  padding-right: 0.9375rem;
+  width: 100%;
+  float: left; }
+
+@media only screen {
+  .column.small-centered,
+  .columns.small-centered {
+    margin-left: auto;
+    margin-right: auto;
+    float: none !important; }
+
+  .column.small-uncentered,
+  .columns.small-uncentered {
+    margin-left: 0;
+    margin-right: 0;
+    float: left !important; }
+
+  .column.small-uncentered.opposite,
+  .columns.small-uncentered.opposite {
+    float: right; }
+
+  .small-push-0 {
+    position: relative;
+    left: 0%;
+    right: auto; }
+
+  .small-pull-0 {
+    position: relative;
+    right: 0%;
+    left: auto; }
+
+  .small-push-1 {
+    position: relative;
+    left: 8.33333%;
+    right: auto; }
+
+  .small-pull-1 {
+    position: relative;
+    right: 8.33333%;
+    left: auto; }
+
+  .small-push-2 {
+    position: relative;
+    left: 16.66667%;
+    right: auto; }
+
+  .small-pull-2 {
+    position: relative;
+    right: 16.66667%;
+    left: auto; }
+
+  .small-push-3 {
+    position: relative;
+    left: 25%;
+    right: auto; }
+
+  .small-pull-3 {
+    position: relative;
+    right: 25%;
+    left: auto; }
+
+  .small-push-4 {
+    position: relative;
+    left: 33.33333%;
+    right: auto; }
+
+  .small-pull-4 {
+    position: relative;
+    right: 33.33333%;
+    left: auto; }
+
+  .small-push-5 {
+    position: relative;
+    left: 41.66667%;
+    right: auto; }
+
+  .small-pull-5 {
+    position: relative;
+    right: 41.66667%;
+    left: auto; }
+
+  .small-push-6 {
+    position: relative;
+    left: 50%;
+    right: auto; }
+
+  .small-pull-6 {
+    position: relative;
+    right: 50%;
+    left: auto; }
+
+  .small-push-7 {
+    position: relative;
+    left: 58.33333%;
+    right: auto; }
+
+  .small-pull-7 {
+    position: relative;
+    right: 58.33333%;
+    left: auto; }
+
+  .small-push-8 {
+    position: relative;
+    left: 66.66667%;
+    right: auto; }
+
+  .small-pull-8 {
+    position: relative;
+    right: 66.66667%;
+    left: auto; }
+
+  .small-push-9 {
+    position: relative;
+    left: 75%;
+    right: auto; }
+
+  .small-pull-9 {
+    position: relative;
+    right: 75%;
+    left: auto; }
+
+  .small-push-10 {
+    position: relative;
+    left: 83.33333%;
+    right: auto; }
+
+  .small-pull-10 {
+    position: relative;
+    right: 83.33333%;
+    left: auto; }
+
+  .small-push-11 {
+    position: relative;
+    left: 91.66667%;
+    right: auto; }
+
+  .small-pull-11 {
+    position: relative;
+    right: 91.66667%;
+    left: auto; }
+
+  .column,
+  .columns {
+    position: relative;
+    padding-left: 0.9375rem;
+    padding-right: 0.9375rem;
+    float: left; }
+
+  .small-1 {
+    width: 8.33333%; }
+
+  .small-2 {
+    width: 16.66667%; }
+
+  .small-3 {
+    width: 25%; }
+
+  .small-4 {
+    width: 33.33333%; }
+
+  .small-5 {
+    width: 41.66667%; }
+
+  .small-6 {
+    width: 50%; }
+
+  .small-7 {
+    width: 58.33333%; }
+
+  .small-8 {
+    width: 66.66667%; }
+
+  .small-9 {
+    width: 75%; }
+
+  .small-10 {
+    width: 83.33333%; }
+
+  .small-11 {
+    width: 91.66667%; }
+
+  .small-12 {
+    width: 100%; }
+
+  [class*="column"] + [class*="column"]:last-child {
+    float: right; }
+
+  [class*="column"] + [class*="column"].end {
+    float: left; }
+
+  .small-offset-0 {
+    margin-left: 0% !important; }
+
+  .small-offset-1 {
+    margin-left: 8.33333% !important; }
+
+  .small-offset-2 {
+    margin-left: 16.66667% !important; }
+
+  .small-offset-3 {
+    margin-left: 25% !important; }
+
+  .small-offset-4 {
+    margin-left: 33.33333% !important; }
+
+  .small-offset-5 {
+    margin-left: 41.66667% !important; }
+
+  .small-offset-6 {
+    margin-left: 50% !important; }
+
+  .small-offset-7 {
+    margin-left: 58.33333% !important; }
+
+  .small-offset-8 {
+    margin-left: 66.66667% !important; }
+
+  .small-offset-9 {
+    margin-left: 75% !important; }
+
+  .small-offset-10 {
+    margin-left: 83.33333% !important; }
+
+  .small-offset-11 {
+    margin-left: 91.66667% !important; }
+
+  .small-reset-order,
+  .small-reset-order {
+    margin-left: 0;
+    margin-right: 0;
+    left: auto;
+    right: auto;
+    float: left; } }
+@media only screen and (min-width: 40.063em) {
+  .column.medium-centered,
+  .columns.medium-centered {
+    margin-left: auto;
+    margin-right: auto;
+    float: none !important; }
+
+  .column.medium-uncentered,
+  .columns.medium-uncentered {
+    margin-left: 0;
+    margin-right: 0;
+    float: left !important; }
+
+  .column.medium-uncentered.opposite,
+  .columns.medium-uncentered.opposite {
+    float: right; }
+
+  .medium-push-0 {
+    position: relative;
+    left: 0%;
+    right: auto; }
+
+  .medium-pull-0 {
+    position: relative;
+    right: 0%;
+    left: auto; }
+
+  .medium-push-1 {
+    position: relative;
+    left: 8.33333%;
+    right: auto; }
+
+  .medium-pull-1 {
+    position: relative;
+    right: 8.33333%;
+    left: auto; }
+
+  .medium-push-2 {
+    position: relative;
+    left: 16.66667%;
+    right: auto; }
+
+  .medium-pull-2 {
+    position: relative;
+    right: 16.66667%;
+    left: auto; }
+
+  .medium-push-3 {
+    position: relative;
+    left: 25%;
+    right: auto; }
+
+  .medium-pull-3 {
+    position: relative;
+    right: 25%;
+    left: auto; }
+
+  .medium-push-4 {
+    position: relative;
+    left: 33.33333%;
+    right: auto; }
+
+  .medium-pull-4 {
+    position: relative;
+    right: 33.33333%;
+    left: auto; }
+
+  .medium-push-5 {
+    position: relative;
+    left: 41.66667%;
+    right: auto; }
+
+  .medium-pull-5 {
+    position: relative;
+    right: 41.66667%;
+    left: auto; }
+
+  .medium-push-6 {
+    position: relative;
+    left: 50%;
+    right: auto; }
+
+  .medium-pull-6 {
+    position: relative;
+    right: 50%;
+    left: auto; }
+
+  .medium-push-7 {
+    position: relative;
+    left: 58.33333%;
+    right: auto; }
+
+  .medium-pull-7 {
+    position: relative;
+    right: 58.33333%;
+    left: auto; }
+
+  .medium-push-8 {
+    position: relative;
+    left: 66.66667%;
+    right: auto; }
+
+  .medium-pull-8 {
+    position: relative;
+    right: 66.66667%;
+    left: auto; }
+
+  .medium-push-9 {
+    position: relative;
+    left: 75%;
+    right: auto; }
+
+  .medium-pull-9 {
+    position: relative;
+    right: 75%;
+    left: auto; }
+
+  .medium-push-10 {
+    position: relative;
+    left: 83.33333%;
+    right: auto; }
+
+  .medium-pull-10 {
+    position: relative;
+    right: 83.33333%;
+    left: auto; }
+
+  .medium-push-11 {
+    position: relative;
+    left: 91.66667%;
+    right: auto; }
+
+  .medium-pull-11 {
+    position: relative;
+    right: 91.66667%;
+    left: auto; }
+
+  .column,
+  .columns {
+    position: relative;
+    padding-left: 0.9375rem;
+    padding-right: 0.9375rem;
+    float: left; }
+
+  .medium-1 {
+    width: 8.33333%; }
+
+  .medium-2 {
+    width: 16.66667%; }
+
+  .medium-3 {
+    width: 25%; }
+
+  .medium-4 {
+    width: 33.33333%; }
+
+  .medium-5 {
+    width: 41.66667%; }
+
+  .medium-6 {
+    width: 50%; }
+
+  .medium-7 {
+    width: 58.33333%; }
+
+  .medium-8 {
+    width: 66.66667%; }
+
+  .medium-9 {
+    width: 75%; }
+
+  .medium-10 {
+    width: 83.33333%; }
+
+  .medium-11 {
+    width: 91.66667%; }
+
+  .medium-12 {
+    width: 100%; }
+
+  [class*="column"] + [class*="column"]:last-child {
+    float: right; }
+
+  [class*="column"] + [class*="column"].end {
+    float: left; }
+
+  .medium-offset-0 {
+    margin-left: 0% !important; }
+
+  .medium-offset-1 {
+    margin-left: 8.33333% !important; }
+
+  .medium-offset-2 {
+    margin-left: 16.66667% !important; }
+
+  .medium-offset-3 {
+    margin-left: 25% !important; }
+
+  .medium-offset-4 {
+    margin-left: 33.33333% !important; }
+
+  .medium-offset-5 {
+    margin-left: 41.66667% !important; }
+
+  .medium-offset-6 {
+    margin-left: 50% !important; }
+
+  .medium-offset-7 {
+    margin-left: 58.33333% !important; }
+
+  .medium-offset-8 {
+    margin-left: 66.66667% !important; }
+
+  .medium-offset-9 {
+    margin-left: 75% !important; }
+
+  .medium-offset-10 {
+    margin-left: 83.33333% !important; }
+
+  .medium-offset-11 {
+    margin-left: 91.66667% !important; }
+
+  .medium-reset-order,
+  .medium-reset-order {
+    margin-left: 0;
+    margin-right: 0;
+    left: auto;
+    right: auto;
+    float: left; }
+
+  .push-0 {
+    position: relative;
+    left: 0%;
+    right: auto; }
+
+  .pull-0 {
+    position: relative;
+    right: 0%;
+    left: auto; }
+
+  .push-1 {
+    position: relative;
+    left: 8.33333%;
+    right: auto; }
+
+  .pull-1 {
+    position: relative;
+    right: 8.33333%;
+    left: auto; }
+
+  .push-2 {
+    position: relative;
+    left: 16.66667%;
+    right: auto; }
+
+  .pull-2 {
+    position: relative;
+    right: 16.66667%;
+    left: auto; }
+
+  .push-3 {
+    position: relative;
+    left: 25%;
+    right: auto; }
+
+  .pull-3 {
+    position: relative;
+    right: 25%;
+    left: auto; }
+
+  .push-4 {
+    position: relative;
+    left: 33.33333%;
+    right: auto; }
+
+  .pull-4 {
+    position: relative;
+    right: 33.33333%;
+    left: auto; }
+
+  .push-5 {
+    position: relative;
+    left: 41.66667%;
+    right: auto; }
+
+  .pull-5 {
+    position: relative;
+    right: 41.66667%;
+    left: auto; }
+
+  .push-6 {
+    position: relative;
+    left: 50%;
+    right: auto; }
+
+  .pull-6 {
+    position: relative;
+    right: 50%;
+    left: auto; }
+
+  .push-7 {
+    position: relative;
+    left: 58.33333%;
+    right: auto; }
+
+  .pull-7 {
+    position: relative;
+    right: 58.33333%;
+    left: auto; }
+
+  .push-8 {
+    position: relative;
+    left: 66.66667%;
+    right: auto; }
+
+  .pull-8 {
+    position: relative;
+    right: 66.66667%;
+    left: auto; }
+
+  .push-9 {
+    position: relative;
+    left: 75%;
+    right: auto; }
+
+  .pull-9 {
+    position: relative;
+    right: 75%;
+    left: auto; }
+
+  .push-10 {
+    position: relative;
+    left: 83.33333%;
+    right: auto; }
+
+  .pull-10 {
+    position: relative;
+    right: 83.33333%;
+    left: auto; }
+
+  .push-11 {
+    position: relative;
+    left: 91.66667%;
+    right: auto; }
+
+  .pull-11 {
+    position: relative;
+    right: 91.66667%;
+    left: auto; } }
+@media only screen and (min-width: 64.063em) {
+  .column.large-centered,
+  .columns.large-centered {
+    margin-left: auto;
+    margin-right: auto;
+    float: none !important; }
+
+  .column.large-uncentered,
+  .columns.large-uncentered {
+    margin-left: 0;
+    margin-right: 0;
+    float: left !important; }
+
+  .column.large-uncentered.opposite,
+  .columns.large-uncentered.opposite {
+    float: right; }
+
+  .large-push-0 {
+    position: relative;
+    left: 0%;
+    right: auto; }
+
+  .large-pull-0 {
+    position: relative;
+    right: 0%;
+    left: auto; }
+
+  .large-push-1 {
+    position: relative;
+    left: 8.33333%;
+    right: auto; }
+
+  .large-pull-1 {
+    position: relative;
+    right: 8.33333%;
+    left: auto; }
+
+  .large-push-2 {
+    position: relative;
+    left: 16.66667%;
+    right: auto; }
+
+  .large-pull-2 {
+    position: relative;
+    right: 16.66667%;
+    left: auto; }
+
+  .large-push-3 {
+    position: relative;
+    left: 25%;
+    right: auto; }
+
+  .large-pull-3 {
+    position: relative;
+    right: 25%;
+    left: auto; }
+
+  .large-push-4 {
+    position: relative;
+    left: 33.33333%;
+    right: auto; }
+
+  .large-pull-4 {
+    position: relative;
+    right: 33.33333%;
+    left: auto; }
+
+  .large-push-5 {
+    position: relative;
+    left: 41.66667%;
+    right: auto; }
+
+  .large-pull-5 {
+    position: relative;
+    right: 41.66667%;
+    left: auto; }
+
+  .large-push-6 {
+    position: relative;
+    left: 50%;
+    right: auto; }
+
+  .large-pull-6 {
+    position: relative;
+    right: 50%;
+    left: auto; }
+
+  .large-push-7 {
+    position: relative;
+    left: 58.33333%;
+    right: auto; }
+
+  .large-pull-7 {
+    position: relative;
+    right: 58.33333%;
+    left: auto; }
+
+  .large-push-8 {
+    position: relative;
+    left: 66.66667%;
+    right: auto; }
+
+  .large-pull-8 {
+    position: relative;
+    right: 66.66667%;
+    left: auto; }
+
+  .large-push-9 {
+    position: relative;
+    left: 75%;
+    right: auto; }
+
+  .large-pull-9 {
+    position: relative;
+    right: 75%;
+    left: auto; }
+
+  .large-push-10 {
+    position: relative;
+    left: 83.33333%;
+    right: auto; }
+
+  .large-pull-10 {
+    position: relative;
+    right: 83.33333%;
+    left: auto; }
+
+  .large-push-11 {
+    position: relative;
+    left: 91.66667%;
+    right: auto; }
+
+  .large-pull-11 {
+    position: relative;
+    right: 91.66667%;
+    left: auto; }
+
+  .column,
+  .columns {
+    position: relative;
+    padding-left: 0.9375rem;
+    padding-right: 0.9375rem;
+    float: left; }
+
+  .large-1 {
+    width: 8.33333%; }
+
+  .large-2 {
+    width: 16.66667%; }
+
+  .large-3 {
+    width: 25%; }
+
+  .large-4 {
+    width: 33.33333%; }
+
+  .large-5 {
+    width: 41.66667%; }
+
+  .large-6 {
+    width: 50%; }
+
+  .large-7 {
+    width: 58.33333%; }
+
+  .large-8 {
+    width: 66.66667%; }
+
+  .large-9 {
+    width: 75%; }
+
+  .large-10 {
+    width: 83.33333%; }
+
+  .large-11 {
+    width: 91.66667%; }
+
+  .large-12 {
+    width: 100%; }
+
+  [class*="column"] + [class*="column"]:last-child {
+    float: right; }
+
+  [class*="column"] + [class*="column"].end {
+    float: left; }
+
+  .large-offset-0 {
+    margin-left: 0% !important; }
+
+  .large-offset-1 {
+    margin-left: 8.33333% !important; }
+
+  .large-offset-2 {
+    margin-left: 16.66667% !important; }
+
+  .large-offset-3 {
+    margin-left: 25% !important; }
+
+  .large-offset-4 {
+    margin-left: 33.33333% !important; }
+
+  .large-offset-5 {
+    margin-left: 41.66667% !important; }
+
+  .large-offset-6 {
+    margin-left: 50% !important; }
+
+  .large-offset-7 {
+    margin-left: 58.33333% !important; }
+
+  .large-offset-8 {
+    margin-left: 66.66667% !important; }
+
+  .large-offset-9 {
+    margin-left: 75% !important; }
+
+  .large-offset-10 {
+    margin-left: 83.33333% !important; }
+
+  .large-offset-11 {
+    margin-left: 91.66667% !important; }
+
+  .large-reset-order,
+  .large-reset-order {
+    margin-left: 0;
+    margin-right: 0;
+    left: auto;
+    right: auto;
+    float: left; }
+
+  .push-0 {
+    position: relative;
+    left: 0%;
+    right: auto; }
+
+  .pull-0 {
+    position: relative;
+    right: 0%;
+    left: auto; }
+
+  .push-1 {
+    position: relative;
+    left: 8.33333%;
+    right: auto; }
+
+  .pull-1 {
+    position: relative;
+    right: 8.33333%;
+    left: auto; }
+
+  .push-2 {
+    position: relative;
+    left: 16.66667%;
+    right: auto; }
+
+  .pull-2 {
+    position: relative;
+    right: 16.66667%;
+    left: auto; }
+
+  .push-3 {
+    position: relative;
+    left: 25%;
+    right: auto; }
+
+  .pull-3 {
+    position: relative;
+    right: 25%;
+    left: auto; }
+
+  .push-4 {
+    position: relative;
+    left: 33.33333%;
+    right: auto; }
+
+  .pull-4 {
+    position: relative;
+    right: 33.33333%;
+    left: auto; }
+
+  .push-5 {
+    position: relative;
+    left: 41.66667%;
+    right: auto; }
+
+  .pull-5 {
+    position: relative;
+    right: 41.66667%;
+    left: auto; }
+
+  .push-6 {
+    position: relative;
+    left: 50%;
+    right: auto; }
+
+  .pull-6 {
+    position: relative;
+    right: 50%;
+    left: auto; }
+
+  .push-7 {
+    position: relative;
+    left: 58.33333%;
+    right: auto; }
+
+  .pull-7 {
+    position: relative;
+    right: 58.33333%;
+    left: auto; }
+
+  .push-8 {
+    position: relative;
+    left: 66.66667%;
+    right: auto; }
+
+  .pull-8 {
+    position: relative;
+    right: 66.66667%;
+    left: auto; }
+
+  .push-9 {
+    position: relative;
+    left: 75%;
+    right: auto; }
+
+  .pull-9 {
+    position: relative;
+    right: 75%;
+    left: auto; }
+
+  .push-10 {
+    position: relative;
+    left: 83.33333%;
+    right: auto; }
+
+  .pull-10 {
+    position: relative;
+    right: 83.33333%;
+    left: auto; }
+
+  .push-11 {
+    position: relative;
+    left: 91.66667%;
+    right: auto; }
+
+  .pull-11 {
+    position: relative;
+    right: 91.66667%;
+    left: auto; } }
+meta.foundation-mq-topbar {
+  font-family: "/only screen and (min-width:40.063em)/";
+  width: 40.063em; }
+
+/* Wrapped around .top-bar to contain to grid width */
+.contain-to-grid {
+  width: 100%;
+  background: #333333; }
+  .contain-to-grid .top-bar {
+    margin-bottom: 0; }
+
+.fixed {
+  width: 100%;
+  left: 0;
+  position: fixed;
+  top: 0;
+  z-index: 99; }
+  .fixed.expanded:not(.top-bar) {
+    overflow-y: auto;
+    height: auto;
+    width: 100%;
+    max-height: 100%; }
+    .fixed.expanded:not(.top-bar) .title-area {
+      position: fixed;
+      width: 100%;
+      z-index: 99; }
+    .fixed.expanded:not(.top-bar) .top-bar-section {
+      z-index: 98;
+      margin-top: 45px; }
+
+.top-bar {
+  overflow: hidden;
+  height: 45px;
+  line-height: 45px;
+  position: relative;
+  background: #333333;
+  margin-bottom: 0; }
+  .top-bar ul {
+    margin-bottom: 0;
+    list-style: none; }
+  .top-bar .row {
+    max-width: none; }
+  .top-bar form,
+  .top-bar input {
+    margin-bottom: 0; }
+  .top-bar input {
+    height: auto;
+    padding-top: .35rem;
+    padding-bottom: .35rem;
+    font-size: 0.75rem; }
+  .top-bar .button {
+    padding-top: .45rem;
+    padding-bottom: .35rem;
+    margin-bottom: 0;
+    font-size: 0.75rem; }
+  .top-bar .title-area {
+    position: relative;
+    margin: 0; }
+  .top-bar .name {
+    height: 45px;
+    margin: 0;
+    font-size: 16px; }
+    .top-bar .name h1 {
+      line-height: 45px;
+      font-size: 1.0625rem;
+      margin: 0; }
+      .top-bar .name h1 a {
+        font-weight: normal;
+        color: white;
+        width: 50%;
+        display: block;
+        padding: 0 15px; }
+  .top-bar .toggle-topbar {
+    position: absolute;
+    right: 0;
+    top: 0; }
+    .top-bar .toggle-topbar a {
+      color: white;
+      text-transform: uppercase;
+      font-size: 0.8125rem;
+      font-weight: bold;
+      position: relative;
+      display: block;
+      padding: 0 15px;
+      height: 45px;
+      line-height: 45px; }
+    .top-bar .toggle-topbar.menu-icon {
+      right: 15px;
+      top: 50%;
+      margin-top: -16px;
+      padding-left: 40px; }
+      .top-bar .toggle-topbar.menu-icon a {
+        height: 34px;
+        line-height: 33px;
+        padding: 0;
+        padding-right: 25px;
+        color: white;
+        position: relative; }
+        .top-bar .toggle-topbar.menu-icon a::after {
+          content: "";
+          position: absolute;
+          right: 0;
+          display: block;
+          width: 16px;
+          top: 0;
+          height: 0;
+          -webkit-box-shadow: 1px 10px 1px 1px white, 1px 16px 1px 1px white, 1px 22px 1px 1px white;
+          box-shadow: 0 10px 0 1px white, 0 16px 0 1px white, 0 22px 0 1px white; }
+  .top-bar.expanded {
+    height: auto;
+    background: transparent; }
+    .top-bar.expanded .title-area {
+      background: #333333; }
+    .top-bar.expanded .toggle-topbar a {
+      color: #888888; }
+      .top-bar.expanded .toggle-topbar a::after {
+        -webkit-box-shadow: 1px 10px 1px 1px #888888, 1px 16px 1px 1px #888888, 1px 22px 1px 1px #888888;
+        box-shadow: 0 10px 0 1px #888888, 0 16px 0 1px #888888, 0 22px 0 1px #888888; }
+
+.top-bar-section {
+  left: 0;
+  position: relative;
+  width: auto;
+  -webkit-transition: left 300ms ease-out;
+  -moz-transition: left 300ms ease-out;
+  transition: left 300ms ease-out; }
+  .top-bar-section ul {
+    width: 100%;
+    height: auto;
+    display: block;
+    background: #333333;
+    font-size: 16px;
+    margin: 0; }
+  .top-bar-section .divider,
+  .top-bar-section [role="separator"] {
+    border-top: solid 1px #1a1a1a;
+    clear: both;
+    height: 1px;
+    width: 100%; }
+  .top-bar-section ul li > a {
+    display: block;
+    width: 100%;
+    color: white;
+    padding: 12px 0 12px 0;
+    padding-left: 15px;
+    font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+    font-size: 0.8125rem;
+    font-weight: normal;
+    text-transform: none;
+    background: #333333; }
+    .top-bar-section ul li > a.button {
+      background: #008cba;
+      font-size: 0.8125rem;
+      padding-right: 15px;
+      padding-left: 15px; }
+      .top-bar-section ul li > a.button:hover {
+        background: #006688; }
+    .top-bar-section ul li > a.button.secondary {
+      background: #e7e7e7; }
+      .top-bar-section ul li > a.button.secondary:hover {
+        background: #cecece; }
+    .top-bar-section ul li > a.button.success {
+      background: #43ac6a; }
+      .top-bar-section ul li > a.button.success:hover {
+        background: #358854; }
+    .top-bar-section ul li > a.button.alert {
+      background: #f04124; }
+      .top-bar-section ul li > a.button.alert:hover {
+        background: #d42b0f; }
+  .top-bar-section ul li:hover:not(.has-form) > a {
+    background: #272727;
+    color: white; }
+  .top-bar-section ul li.active > a {
+    background: #008cba;
+    color: white; }
+    .top-bar-section ul li.active > a:hover {
+      background: #0078a0;
+      color: white; }
+  .top-bar-section .has-form {
+    padding: 15px; }
+  .top-bar-section .has-dropdown {
+    position: relative; }
+    .top-bar-section .has-dropdown > a:after {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 5px;
+      border-color: transparent transparent transparent rgba(255, 255, 255, 0.4);
+      border-left-style: solid;
+      margin-right: 15px;
+      margin-top: -4.5px;
+      position: absolute;
+      top: 50%;
+      right: 0; }
+    .top-bar-section .has-dropdown.moved {
+      position: static; }
+      .top-bar-section .has-dropdown.moved > .dropdown {
+        display: block;
+        position: static !important;
+        height: auto;
+        width: auto;
+        overflow: visible;
+        clip: auto;
+        position: absolute !important;
+        width: 100%; }
+      .top-bar-section .has-dropdown.moved > a:after {
+        display: none; }
+  .top-bar-section .dropdown {
+    position: absolute;
+    left: 100%;
+    top: 0;
+    z-index: 99;
+    display: block;
+    position: absolute !important;
+    height: 1px;
+    width: 1px;
+    overflow: hidden;
+    clip: rect(1px, 1px, 1px, 1px); }
+    .top-bar-section .dropdown li {
+      width: 100%;
+      height: auto; }
+      .top-bar-section .dropdown li a {
+        font-weight: normal;
+        padding: 8px 15px; }
+        .top-bar-section .dropdown li a.parent-link {
+          font-weight: normal; }
+      .top-bar-section .dropdown li.title h5 {
+        margin-bottom: 0; }
+        .top-bar-section .dropdown li.title h5 a {
+          color: white;
+          line-height: 22.5px;
+          display: block; }
+      .top-bar-section .dropdown li.has-form {
+        padding: 8px 15px; }
+      .top-bar-section .dropdown li .button {
+        top: auto; }
+    .top-bar-section .dropdown label {
+      padding: 8px 15px 2px;
+      margin-bottom: 0;
+      text-transform: uppercase;
+      color: #777777;
+      font-weight: bold;
+      font-size: 0.625rem; }
+
+.js-generated {
+  display: block; }
+
+@media only screen and (min-width: 40.063em) {
+  .top-bar {
+    background: #333333;
+    *zoom: 1;
+    overflow: visible; }
+    .top-bar:before, .top-bar:after {
+      content: " ";
+      display: table; }
+    .top-bar:after {
+      clear: both; }
+    .top-bar .toggle-topbar {
+      display: none; }
+    .top-bar .title-area {
+      float: left; }
+    .top-bar .name h1 a {
+      width: auto; }
+    .top-bar input,
+    .top-bar .button {
+      font-size: 0.875rem;
+      position: relative;
+      top: 7px; }
+    .top-bar.expanded {
+      background: #333333; }
+
+  .contain-to-grid .top-bar {
+    max-width: 62.5rem;
+    margin: 0 auto;
+    margin-bottom: 0; }
+
+  .top-bar-section {
+    -webkit-transition: none 0 0;
+    -moz-transition: none 0 0;
+    transition: none 0 0;
+    left: 0 !important; }
+    .top-bar-section ul {
+      width: auto;
+      height: auto !important;
+      display: inline; }
+      .top-bar-section ul li {
+        float: left; }
+        .top-bar-section ul li .js-generated {
+          display: none; }
+    .top-bar-section li.hover > a:not(.button) {
+      background: #272727;
+      color: white; }
+    .top-bar-section li:not(.has-form) a:not(.button) {
+      padding: 0 15px;
+      line-height: 45px;
+      background: #333333; }
+      .top-bar-section li:not(.has-form) a:not(.button):hover {
+        background: #272727; }
+    .top-bar-section li.active:not(.has-form) a:not(.button) {
+      padding: 0 15px;
+      line-height: 45px;
+      color: white;
+      background: #008cba; }
+      .top-bar-section li.active:not(.has-form) a:not(.button):hover {
+        background: #0078a0; }
+    .top-bar-section .has-dropdown > a {
+      padding-right: 35px !important; }
+      .top-bar-section .has-dropdown > a:after {
+        content: "";
+        display: block;
+        width: 0;
+        height: 0;
+        border: inset 5px;
+        border-color: rgba(255, 255, 255, 0.4) transparent transparent transparent;
+        border-top-style: solid;
+        margin-top: -2.5px;
+        top: 22.5px; }
+    .top-bar-section .has-dropdown.moved {
+      position: relative; }
+      .top-bar-section .has-dropdown.moved > .dropdown {
+        display: block;
+        position: absolute !important;
+        height: 1px;
+        width: 1px;
+        overflow: hidden;
+        clip: rect(1px, 1px, 1px, 1px); }
+    .top-bar-section .has-dropdown.hover > .dropdown, .top-bar-section .has-dropdown.not-click:hover > .dropdown {
+      display: block;
+      position: static !important;
+      height: auto;
+      width: auto;
+      overflow: visible;
+      clip: auto;
+      position: absolute !important; }
+    .top-bar-section .has-dropdown .dropdown li.has-dropdown > a:after {
+      border: none;
+      content: "\00bb";
+      top: 1rem;
+      margin-top: -1px;
+      right: 5px;
+      line-height: 1.2; }
+    .top-bar-section .dropdown {
+      left: 0;
+      top: auto;
+      background: transparent;
+      min-width: 100%; }
+      .top-bar-section .dropdown li a {
+        color: white;
+        line-height: 1;
+        white-space: nowrap;
+        padding: 12px 15px;
+        background: #333333; }
+      .top-bar-section .dropdown li label {
+        white-space: nowrap;
+        background: #333333; }
+      .top-bar-section .dropdown li .dropdown {
+        left: 100%;
+        top: 0; }
+    .top-bar-section > ul > .divider, .top-bar-section > ul > [role="separator"] {
+      border-bottom: none;
+      border-top: none;
+      border-right: solid 1px #4e4e4e;
+      clear: none;
+      height: 45px;
+      width: 0; }
+    .top-bar-section .has-form {
+      background: #333333;
+      padding: 0 15px;
+      height: 45px; }
+    .top-bar-section .right li .dropdown {
+      left: auto;
+      right: 0; }
+      .top-bar-section .right li .dropdown li .dropdown {
+        right: 100%; }
+    .top-bar-section .left li .dropdown {
+      right: auto;
+      left: 0; }
+      .top-bar-section .left li .dropdown li .dropdown {
+        left: 100%; }
+
+  .no-js .top-bar-section ul li:hover > a {
+    background: #272727;
+    color: white; }
+  .no-js .top-bar-section ul li:active > a {
+    background: #008cba;
+    color: white; }
+  .no-js .top-bar-section .has-dropdown:hover > .dropdown {
+    display: block;
+    position: static !important;
+    height: auto;
+    width: auto;
+    overflow: visible;
+    clip: auto;
+    position: absolute !important; } }
+.breadcrumbs {
+  display: block;
+  padding: 0.5625rem 0.875rem 0.5625rem;
+  overflow: hidden;
+  margin-left: 0;
+  list-style: none;
+  border-style: solid;
+  border-width: 1px;
+  background-color: #f4f4f4;
+  border-color: gainsboro;
+  -webkit-border-radius: 3px;
+  border-radius: 3px; }
+  .breadcrumbs > * {
+    margin: 0;
+    float: left;
+    font-size: 0.6875rem;
+    text-transform: uppercase; }
+    .breadcrumbs > *:hover a, .breadcrumbs > *:focus a {
+      text-decoration: underline; }
+    .breadcrumbs > * a,
+    .breadcrumbs > * span {
+      text-transform: uppercase;
+      color: #008cba; }
+    .breadcrumbs > *.current {
+      cursor: default;
+      color: #333333; }
+      .breadcrumbs > *.current a {
+        cursor: default;
+        color: #333333; }
+      .breadcrumbs > *.current:hover, .breadcrumbs > *.current:hover a, .breadcrumbs > *.current:focus, .breadcrumbs > *.current:focus a {
+        text-decoration: none; }
+    .breadcrumbs > *.unavailable {
+      color: #999999; }
+      .breadcrumbs > *.unavailable a {
+        color: #999999; }
+      .breadcrumbs > *.unavailable:hover, .breadcrumbs > *.unavailable:hover a, .breadcrumbs > *.unavailable:focus,
+      .breadcrumbs > *.unavailable a:focus {
+        text-decoration: none;
+        color: #999999;
+        cursor: default; }
+    .breadcrumbs > *:before {
+      content: "/";
+      color: #aaaaaa;
+      margin: 0 0.75rem;
+      position: relative;
+      top: 1px; }
+    .breadcrumbs > *:first-child:before {
+      content: " ";
+      margin: 0; }
+
+.alert-box {
+  border-style: solid;
+  border-width: 1px;
+  display: block;
+  font-weight: normal;
+  margin-bottom: 1.25rem;
+  position: relative;
+  padding: 0.875rem 1.5rem 0.875rem 0.875rem;
+  font-size: 0.8125rem;
+  background-color: #008cba;
+  border-color: #0078a0;
+  color: white; }
+  .alert-box .close {
+    font-size: 1.375rem;
+    padding: 9px 6px 4px;
+    line-height: 0;
+    position: absolute;
+    top: 50%;
+    margin-top: -0.6875rem;
+    right: 0.25rem;
+    color: #333333;
+    opacity: 0.3; }
+    .alert-box .close:hover, .alert-box .close:focus {
+      opacity: 0.5; }
+  .alert-box.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+  .alert-box.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+  .alert-box.success {
+    background-color: #43ac6a;
+    border-color: #3a945b;
+    color: white; }
+  .alert-box.alert {
+    background-color: #f04124;
+    border-color: #de2d0f;
+    color: white; }
+  .alert-box.secondary {
+    background-color: #e7e7e7;
+    border-color: #c7c7c7;
+    color: #4f4f4f; }
+  .alert-box.warning {
+    background-color: #f08a24;
+    border-color: #de770f;
+    color: white; }
+  .alert-box.info {
+    background-color: #a0d3e8;
+    border-color: #74bfdd;
+    color: #4f4f4f; }
+
+.inline-list {
+  margin: 0 auto 1.0625rem auto;
+  margin-left: -1.375rem;
+  margin-right: 0;
+  padding: 0;
+  list-style: none;
+  overflow: hidden; }
+  .inline-list > li {
+    list-style: none;
+    float: left;
+    margin-left: 1.375rem;
+    display: block; }
+    .inline-list > li > * {
+      display: block; }
+
+button, .button {
+  border-style: solid;
+  border-width: 0px;
+  cursor: pointer;
+  font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+  font-weight: normal;
+  line-height: normal;
+  margin: 0 0 1.25rem;
+  position: relative;
+  text-decoration: none;
+  text-align: center;
+  display: inline-block;
+  padding-top: 1rem;
+  padding-right: 2rem;
+  padding-bottom: 1.0625rem;
+  padding-left: 2rem;
+  font-size: 1rem;
+  /*     @else                            { font-size: $padding - rem-calc(2); } */
+  background-color: #008cba;
+  border-color: #007095;
+  color: white;
+  -webkit-transition: background-color 300ms ease-out;
+  -moz-transition: background-color 300ms ease-out;
+  transition: background-color 300ms ease-out;
+  padding-top: 1rem;
+  padding-right: 2rem;
+  padding-bottom: 1.0625rem;
+  padding-left: 2rem;
+  font-size: 1rem;
+  /*     @else                            { font-size: $padding - rem-calc(2); } */ }
+  button:hover, button:focus, .button:hover, .button:focus {
+    background-color: #007095; }
+  button:hover, button:focus, .button:hover, .button:focus {
+    color: white; }
+  button.secondary, .button.secondary {
+    background-color: #e7e7e7;
+    border-color: #b9b9b9;
+    color: #333333; }
+    button.secondary:hover, button.secondary:focus, .button.secondary:hover, .button.secondary:focus {
+      background-color: #b9b9b9; }
+    button.secondary:hover, button.secondary:focus, .button.secondary:hover, .button.secondary:focus {
+      color: #333333; }
+  button.success, .button.success {
+    background-color: #43ac6a;
+    border-color: #368a55;
+    color: white; }
+    button.success:hover, button.success:focus, .button.success:hover, .button.success:focus {
+      background-color: #368a55; }
+    button.success:hover, button.success:focus, .button.success:hover, .button.success:focus {
+      color: white; }
+  button.alert, .button.alert {
+    background-color: #f04124;
+    border-color: #cf2a0e;
+    color: white; }
+    button.alert:hover, button.alert:focus, .button.alert:hover, .button.alert:focus {
+      background-color: #cf2a0e; }
+    button.alert:hover, button.alert:focus, .button.alert:hover, .button.alert:focus {
+      color: white; }
+  button.large, .button.large {
+    padding-top: 1.125rem;
+    padding-right: 2.25rem;
+    padding-bottom: 1.1875rem;
+    padding-left: 2.25rem;
+    font-size: 1.25rem;
+    /*     @else                            { font-size: $padding - rem-calc(2); } */ }
+  button.small, .button.small {
+    padding-top: 0.875rem;
+    padding-right: 1.75rem;
+    padding-bottom: 0.9375rem;
+    padding-left: 1.75rem;
+    font-size: 0.8125rem;
+    /*     @else                            { font-size: $padding - rem-calc(2); } */ }
+  button.tiny, .button.tiny {
+    padding-top: 0.625rem;
+    padding-right: 1.25rem;
+    padding-bottom: 0.6875rem;
+    padding-left: 1.25rem;
+    font-size: 0.6875rem;
+    /*     @else                            { font-size: $padding - rem-calc(2); } */ }
+  button.expand, .button.expand {
+    padding-right: 0;
+    padding-left: 0;
+    width: 100%; }
+  button.left-align, .button.left-align {
+    text-align: left;
+    text-indent: 0.75rem; }
+  button.right-align, .button.right-align {
+    text-align: right;
+    padding-right: 0.75rem; }
+  button.radius, .button.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+  button.round, .button.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+  button.disabled, button[disabled], .button.disabled, .button[disabled] {
+    background-color: #008cba;
+    border-color: #007095;
+    color: white;
+    cursor: default;
+    opacity: 0.7;
+    -webkit-box-shadow: none;
+    box-shadow: none; }
+    button.disabled:hover, button.disabled:focus, button[disabled]:hover, button[disabled]:focus, .button.disabled:hover, .button.disabled:focus, .button[disabled]:hover, .button[disabled]:focus {
+      background-color: #007095; }
+    button.disabled:hover, button.disabled:focus, button[disabled]:hover, button[disabled]:focus, .button.disabled:hover, .button.disabled:focus, .button[disabled]:hover, .button[disabled]:focus {
+      color: white; }
+    button.disabled:hover, button.disabled:focus, button[disabled]:hover, button[disabled]:focus, .button.disabled:hover, .button.disabled:focus, .button[disabled]:hover, .button[disabled]:focus {
+      background-color: #008cba; }
+    button.disabled.secondary, button[disabled].secondary, .button.disabled.secondary, .button[disabled].secondary {
+      background-color: #e7e7e7;
+      border-color: #b9b9b9;
+      color: #333333;
+      cursor: default;
+      opacity: 0.7;
+      -webkit-box-shadow: none;
+      box-shadow: none; }
+      button.disabled.secondary:hover, button.disabled.secondary:focus, button[disabled].secondary:hover, button[disabled].secondary:focus, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
+        background-color: #b9b9b9; }
+      button.disabled.secondary:hover, button.disabled.secondary:focus, button[disabled].secondary:hover, button[disabled].secondary:focus, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
+        color: #333333; }
+      button.disabled.secondary:hover, button.disabled.secondary:focus, button[disabled].secondary:hover, button[disabled].secondary:focus, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
+        background-color: #e7e7e7; }
+    button.disabled.success, button[disabled].success, .button.disabled.success, .button[disabled].success {
+      background-color: #43ac6a;
+      border-color: #368a55;
+      color: white;
+      cursor: default;
+      opacity: 0.7;
+      -webkit-box-shadow: none;
+      box-shadow: none; }
+      button.disabled.success:hover, button.disabled.success:focus, button[disabled].success:hover, button[disabled].success:focus, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success:hover, .button[disabled].success:focus {
+        background-color: #368a55; }
+      button.disabled.success:hover, button.disabled.success:focus, button[disabled].success:hover, button[disabled].success:focus, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success:hover, .button[disabled].success:focus {
+        color: white; }
+      button.disabled.success:hover, button.disabled.success:focus, button[disabled].success:hover, button[disabled].success:focus, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success:hover, .button[disabled].success:focus {
+        background-color: #43ac6a; }
+    button.disabled.alert, button[disabled].alert, .button.disabled.alert, .button[disabled].alert {
+      background-color: #f04124;
+      border-color: #cf2a0e;
+      color: white;
+      cursor: default;
+      opacity: 0.7;
+      -webkit-box-shadow: none;
+      box-shadow: none; }
+      button.disabled.alert:hover, button.disabled.alert:focus, button[disabled].alert:hover, button[disabled].alert:focus, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert:hover, .button[disabled].alert:focus {
+        background-color: #cf2a0e; }
+      button.disabled.alert:hover, button.disabled.alert:focus, button[disabled].alert:hover, button[disabled].alert:focus, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert:hover, .button[disabled].alert:focus {
+        color: white; }
+      button.disabled.alert:hover, button.disabled.alert:focus, button[disabled].alert:hover, button[disabled].alert:focus, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert:hover, .button[disabled].alert:focus {
+        background-color: #f04124; }
+
+@media only screen and (min-width: 40.063em) {
+  button, .button {
+    display: inline-block; } }
+.button-group {
+  list-style: none;
+  margin: 0;
+  left: 0;
+  *zoom: 1; }
+  .button-group:before, .button-group:after {
+    content: " ";
+    display: table; }
+  .button-group:after {
+    clear: both; }
+  .button-group li {
+    margin: 0;
+    float: left; }
+    .button-group li > button, .button-group li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group li:first-child button, .button-group li:first-child .button {
+      border-left: 0; }
+    .button-group li:first-child {
+      margin-left: 0; }
+  .button-group.radius > * > button, .button-group.radius > * .button {
+    border-left: 1px solid;
+    border-color: rgba(255, 255, 255, 0.5); }
+  .button-group.radius > *:first-child button, .button-group.radius > *:first-child .button {
+    border-left: 0; }
+  .button-group.radius > *:first-child, .button-group.radius > *:first-child > a, .button-group.radius > *:first-child > button, .button-group.radius > *:first-child > .button {
+    -moz-border-radius-bottomleft: 3px;
+    -moz-border-radius-topleft: 3px;
+    -webkit-border-bottom-left-radius: 3px;
+    -webkit-border-top-left-radius: 3px;
+    border-bottom-left-radius: 3px;
+    border-top-left-radius: 3px; }
+  .button-group.radius > *:last-child, .button-group.radius > *:last-child > a, .button-group.radius > *:last-child > button, .button-group.radius > *:last-child > .button {
+    -moz-border-radius-bottomright: 3px;
+    -moz-border-radius-topright: 3px;
+    -webkit-border-bottom-right-radius: 3px;
+    -webkit-border-top-right-radius: 3px;
+    border-bottom-right-radius: 3px;
+    border-top-right-radius: 3px; }
+  .button-group.round > * > button, .button-group.round > * .button {
+    border-left: 1px solid;
+    border-color: rgba(255, 255, 255, 0.5); }
+  .button-group.round > *:first-child button, .button-group.round > *:first-child .button {
+    border-left: 0; }
+  .button-group.round > *:first-child, .button-group.round > *:first-child > a, .button-group.round > *:first-child > button, .button-group.round > *:first-child > .button {
+    -moz-border-radius-bottomleft: 1000px;
+    -moz-border-radius-topleft: 1000px;
+    -webkit-border-bottom-left-radius: 1000px;
+    -webkit-border-top-left-radius: 1000px;
+    border-bottom-left-radius: 1000px;
+    border-top-left-radius: 1000px; }
+  .button-group.round > *:last-child, .button-group.round > *:last-child > a, .button-group.round > *:last-child > button, .button-group.round > *:last-child > .button {
+    -moz-border-radius-bottomright: 1000px;
+    -moz-border-radius-topright: 1000px;
+    -webkit-border-bottom-right-radius: 1000px;
+    -webkit-border-top-right-radius: 1000px;
+    border-bottom-right-radius: 1000px;
+    border-top-right-radius: 1000px; }
+  .button-group.even-2 li {
+    width: 50%; }
+    .button-group.even-2 li > button, .button-group.even-2 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-2 li:first-child button, .button-group.even-2 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-2 li button, .button-group.even-2 li .button {
+      width: 100%; }
+  .button-group.even-3 li {
+    width: 33.33333%; }
+    .button-group.even-3 li > button, .button-group.even-3 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-3 li:first-child button, .button-group.even-3 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-3 li button, .button-group.even-3 li .button {
+      width: 100%; }
+  .button-group.even-4 li {
+    width: 25%; }
+    .button-group.even-4 li > button, .button-group.even-4 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-4 li:first-child button, .button-group.even-4 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-4 li button, .button-group.even-4 li .button {
+      width: 100%; }
+  .button-group.even-5 li {
+    width: 20%; }
+    .button-group.even-5 li > button, .button-group.even-5 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-5 li:first-child button, .button-group.even-5 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-5 li button, .button-group.even-5 li .button {
+      width: 100%; }
+  .button-group.even-6 li {
+    width: 16.66667%; }
+    .button-group.even-6 li > button, .button-group.even-6 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-6 li:first-child button, .button-group.even-6 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-6 li button, .button-group.even-6 li .button {
+      width: 100%; }
+  .button-group.even-7 li {
+    width: 14.28571%; }
+    .button-group.even-7 li > button, .button-group.even-7 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-7 li:first-child button, .button-group.even-7 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-7 li button, .button-group.even-7 li .button {
+      width: 100%; }
+  .button-group.even-8 li {
+    width: 12.5%; }
+    .button-group.even-8 li > button, .button-group.even-8 li .button {
+      border-left: 1px solid;
+      border-color: rgba(255, 255, 255, 0.5); }
+    .button-group.even-8 li:first-child button, .button-group.even-8 li:first-child .button {
+      border-left: 0; }
+    .button-group.even-8 li button, .button-group.even-8 li .button {
+      width: 100%; }
+
+.button-bar {
+  *zoom: 1; }
+  .button-bar:before, .button-bar:after {
+    content: " ";
+    display: table; }
+  .button-bar:after {
+    clear: both; }
+  .button-bar .button-group {
+    float: left;
+    margin-right: 0.625rem; }
+    .button-bar .button-group div {
+      overflow: hidden; }
+
+/* Panels */
+.panel {
+  border-style: solid;
+  border-width: 1px;
+  border-color: #d8d8d8;
+  margin-bottom: 1.25rem;
+  padding: 1.25rem;
+  background: #f2f2f2; }
+  .panel > :first-child {
+    margin-top: 0; }
+  .panel > :last-child {
+    margin-bottom: 0; }
+  .panel h1, .panel h2, .panel h3, .panel h4, .panel h5, .panel h6, .panel p {
+    color: #333333; }
+  .panel h1, .panel h2, .panel h3, .panel h4, .panel h5, .panel h6 {
+    line-height: 1;
+    margin-bottom: 0.625rem; }
+    .panel h1.subheader, .panel h2.subheader, .panel h3.subheader, .panel h4.subheader, .panel h5.subheader, .panel h6.subheader {
+      line-height: 1.4; }
+  .panel.callout {
+    border-style: solid;
+    border-width: 1px;
+    border-color: #b6edff;
+    margin-bottom: 1.25rem;
+    padding: 1.25rem;
+    background: #ecfaff; }
+    .panel.callout > :first-child {
+      margin-top: 0; }
+    .panel.callout > :last-child {
+      margin-bottom: 0; }
+    .panel.callout h1, .panel.callout h2, .panel.callout h3, .panel.callout h4, .panel.callout h5, .panel.callout h6, .panel.callout p {
+      color: #333333; }
+    .panel.callout h1, .panel.callout h2, .panel.callout h3, .panel.callout h4, .panel.callout h5, .panel.callout h6 {
+      line-height: 1;
+      margin-bottom: 0.625rem; }
+      .panel.callout h1.subheader, .panel.callout h2.subheader, .panel.callout h3.subheader, .panel.callout h4.subheader, .panel.callout h5.subheader, .panel.callout h6.subheader {
+        line-height: 1.4; }
+    .panel.callout a:not(.button) {
+      color: #008cba; }
+  .panel.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+
+.dropdown.button, button.dropdown {
+  position: relative;
+  padding-right: 3.5625rem; }
+  .dropdown.button:before, button.dropdown:before {
+    position: absolute;
+    content: "";
+    width: 0;
+    height: 0;
+    display: block;
+    border-style: solid;
+    border-color: white transparent transparent transparent;
+    top: 50%; }
+  .dropdown.button:before, button.dropdown:before {
+    border-width: 0.375rem;
+    right: 1.40625rem;
+    margin-top: -0.15625rem; }
+  .dropdown.button:before, button.dropdown:before {
+    border-color: white transparent transparent transparent; }
+  .dropdown.button.tiny, button.dropdown.tiny {
+    padding-right: 2.625rem; }
+    .dropdown.button.tiny:before, button.dropdown.tiny:before {
+      border-width: 0.375rem;
+      right: 1.125rem;
+      margin-top: -0.125rem; }
+    .dropdown.button.tiny:before, button.dropdown.tiny:before {
+      border-color: white transparent transparent transparent; }
+  .dropdown.button.small, button.dropdown.small {
+    padding-right: 3.0625rem; }
+    .dropdown.button.small:before, button.dropdown.small:before {
+      border-width: 0.4375rem;
+      right: 1.3125rem;
+      margin-top: -0.15625rem; }
+    .dropdown.button.small:before, button.dropdown.small:before {
+      border-color: white transparent transparent transparent; }
+  .dropdown.button.large, button.dropdown.large {
+    padding-right: 3.625rem; }
+    .dropdown.button.large:before, button.dropdown.large:before {
+      border-width: 0.3125rem;
+      right: 1.71875rem;
+      margin-top: -0.15625rem; }
+    .dropdown.button.large:before, button.dropdown.large:before {
+      border-color: white transparent transparent transparent; }
+  .dropdown.button.secondary:before, button.dropdown.secondary:before {
+    border-color: #333333 transparent transparent transparent; }
+
+div.switch {
+  position: relative;
+  padding: 0;
+  display: block;
+  overflow: hidden;
+  border-style: solid;
+  border-width: 1px;
+  margin-bottom: 1.25rem;
+  height: 2.25rem;
+  background: white;
+  border-color: #cccccc; }
+  div.switch label {
+    position: relative;
+    left: 0;
+    z-index: 2;
+    float: left;
+    width: 50%;
+    height: 100%;
+    margin: 0;
+    font-weight: bold;
+    text-align: left;
+    -webkit-transition: all 0.1s ease-out;
+    -moz-transition: all 0.1s ease-out;
+    transition: all 0.1s ease-out; }
+  div.switch input {
+    position: absolute;
+    z-index: 3;
+    opacity: 0;
+    width: 100%;
+    height: 100%;
+    -moz-appearance: none; }
+    div.switch input:hover, div.switch input:focus {
+      cursor: pointer; }
+  div.switch span:last-child {
+    position: absolute;
+    top: -1px;
+    left: -1px;
+    z-index: 1;
+    display: block;
+    padding: 0;
+    border-width: 1px;
+    border-style: solid;
+    -webkit-transition: all 0.1s ease-out;
+    -moz-transition: all 0.1s ease-out;
+    transition: all 0.1s ease-out; }
+  div.switch input:not(:checked) + label {
+    opacity: 0; }
+  div.switch input:checked {
+    display: none !important; }
+  div.switch input {
+    left: 0;
+    display: block !important; }
+  div.switch input:first-of-type + label,
+  div.switch input:first-of-type + span + label {
+    left: -50%; }
+  div.switch input:first-of-type:checked + label,
+  div.switch input:first-of-type:checked + span + label {
+    left: 0%; }
+  div.switch input:last-of-type + label,
+  div.switch input:last-of-type + span + label {
+    right: -50%;
+    left: auto;
+    text-align: right; }
+  div.switch input:last-of-type:checked + label,
+  div.switch input:last-of-type:checked + span + label {
+    right: 0%;
+    left: auto; }
+  div.switch span.custom {
+    display: none !important; }
+  form.custom div.switch .hidden-field {
+    margin-left: auto;
+    position: absolute;
+    visibility: visible; }
+  div.switch label {
+    padding: 0;
+    line-height: 2.3rem;
+    font-size: 0.875rem; }
+  div.switch input:first-of-type:checked ~ span:last-child {
+    left: 100%;
+    margin-left: -2.1875rem; }
+  div.switch span:last-child {
+    width: 2.25rem;
+    height: 2.25rem; }
+  div.switch span:last-child {
+    border-color: #b3b3b3;
+    background: white;
+    background: -moz-linear-gradient(top, white 0%, #f2f2f2 100%);
+    background: -webkit-linear-gradient(top, white 0%, #f2f2f2 100%);
+    background: linear-gradient(to bottom, white 0%, #f2f2f2 100%);
+    -webkit-box-shadow: 2px 0 10px 0 rgba(0, 0, 0, 0.07), 1000px 0 0 1000px #f3faf6, -2px 0 10px 0 rgba(0, 0, 0, 0.07), -1000px 0 0 1000px whitesmoke;
+    box-shadow: 2px 0 10px 0 rgba(0, 0, 0, 0.07), 1000px 0 0 980px #f3faf6, -2px 0 10px 0 rgba(0, 0, 0, 0.07), -1000px 0 0 1000px whitesmoke; }
+  div.switch:hover span:last-child, div.switch:focus span:last-child {
+    background: white;
+    background: -moz-linear-gradient(top, white 0%, #e6e6e6 100%);
+    background: -webkit-linear-gradient(top, white 0%, #e6e6e6 100%);
+    background: linear-gradient(to bottom, white 0%, #e6e6e6 100%); }
+  div.switch:active {
+    background: transparent; }
+  div.switch.large {
+    height: 2.75rem; }
+    div.switch.large label {
+      padding: 0;
+      line-height: 2.3rem;
+      font-size: 1.0625rem; }
+    div.switch.large input:first-of-type:checked ~ span:last-child {
+      left: 100%;
+      margin-left: -2.6875rem; }
+    div.switch.large span:last-child {
+      width: 2.75rem;
+      height: 2.75rem; }
+  div.switch.small {
+    height: 1.75rem; }
+    div.switch.small label {
+      padding: 0;
+      line-height: 2.1rem;
+      font-size: 0.75rem; }
+    div.switch.small input:first-of-type:checked ~ span:last-child {
+      left: 100%;
+      margin-left: -1.6875rem; }
+    div.switch.small span:last-child {
+      width: 1.75rem;
+      height: 1.75rem; }
+  div.switch.tiny {
+    height: 1.375rem; }
+    div.switch.tiny label {
+      padding: 0;
+      line-height: 1.9rem;
+      font-size: 0.6875rem; }
+    div.switch.tiny input:first-of-type:checked ~ span:last-child {
+      left: 100%;
+      margin-left: -1.3125rem; }
+    div.switch.tiny span:last-child {
+      width: 1.375rem;
+      height: 1.375rem; }
+  div.switch.radius {
+    -webkit-border-radius: 4px;
+    border-radius: 4px; }
+    div.switch.radius span:last-child {
+      -webkit-border-radius: 3px;
+      border-radius: 3px; }
+  div.switch.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+    div.switch.round span:last-child {
+      -webkit-border-radius: 999px;
+      border-radius: 999px; }
+    div.switch.round label {
+      padding: 0 0.5625rem; }
+
+@-webkit-keyframes webkitSiblingBugfix {
+  from {
+    position: relative; }
+
+  to {
+    position: relative; } }
+
+/* Image Thumbnails */
+.th {
+  line-height: 0;
+  display: inline-block;
+  border: solid 4px white;
+  max-width: 100%;
+  -webkit-box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
+  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
+  -webkit-transition: all 200ms ease-out;
+  -moz-transition: all 200ms ease-out;
+  transition: all 200ms ease-out; }
+  .th:hover, .th:focus {
+    -webkit-box-shadow: 0 0 6px 1px rgba(0, 140, 186, 0.5);
+    box-shadow: 0 0 6px 1px rgba(0, 140, 186, 0.5); }
+  .th.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+
+/* Pricing Tables */
+.pricing-table {
+  border: solid 1px #dddddd;
+  margin-left: 0;
+  margin-bottom: 1.25rem; }
+  .pricing-table * {
+    list-style: none;
+    line-height: 1; }
+  .pricing-table .title {
+    background-color: #333333;
+    padding: 0.9375rem 1.25rem;
+    text-align: center;
+    color: #eeeeee;
+    font-weight: normal;
+    font-size: 1rem;
+    font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif; }
+  .pricing-table .price {
+    background-color: #f6f6f6;
+    padding: 0.9375rem 1.25rem;
+    text-align: center;
+    color: #333333;
+    font-weight: normal;
+    font-size: 2rem;
+    font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif; }
+  .pricing-table .description {
+    background-color: white;
+    padding: 0.9375rem;
+    text-align: center;
+    color: #777777;
+    font-size: 0.75rem;
+    font-weight: normal;
+    line-height: 1.4;
+    border-bottom: dotted 1px #dddddd; }
+  .pricing-table .bullet-item {
+    background-color: white;
+    padding: 0.9375rem;
+    text-align: center;
+    color: #333333;
+    font-size: 0.875rem;
+    font-weight: normal;
+    border-bottom: dotted 1px #dddddd; }
+  .pricing-table .cta-button {
+    background-color: white;
+    text-align: center;
+    padding: 1.25rem 1.25rem 0; }
+
+@-webkit-keyframes rotate {
+  from {
+    -webkit-transform: rotate(0deg); }
+
+  to {
+    -webkit-transform: rotate(360deg); } }
+
+@-moz-keyframes rotate {
+  from {
+    -moz-transform: rotate(0deg); }
+
+  to {
+    -moz-transform: rotate(360deg); } }
+
+@-o-keyframes rotate {
+  from {
+    -o-transform: rotate(0deg); }
+
+  to {
+    -o-transform: rotate(360deg); } }
+
+@keyframes rotate {
+  from {
+    transform: rotate(0deg); }
+
+  to {
+    transform: rotate(360deg); } }
+
+/* Orbit Graceful Loading */
+.slideshow-wrapper {
+  position: relative; }
+  .slideshow-wrapper ul {
+    list-style-type: none;
+    margin: 0; }
+    .slideshow-wrapper ul li,
+    .slideshow-wrapper ul li .orbit-caption {
+      display: none; }
+    .slideshow-wrapper ul li:first-child {
+      display: block; }
+  .slideshow-wrapper .orbit-container {
+    background-color: transparent; }
+    .slideshow-wrapper .orbit-container li {
+      display: block; }
+      .slideshow-wrapper .orbit-container li .orbit-caption {
+        display: block; }
+
+.preloader {
+  display: block;
+  width: 40px;
+  height: 40px;
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  margin-top: -20px;
+  margin-left: -20px;
+  border: solid 3px;
+  border-color: #555555 white;
+  -webkit-border-radius: 1000px;
+  border-radius: 1000px;
+  -webkit-animation-name: rotate;
+  -webkit-animation-duration: 1.5s;
+  -webkit-animation-iteration-count: infinite;
+  -webkit-animation-timing-function: linear;
+  -moz-animation-name: rotate;
+  -moz-animation-duration: 1.5s;
+  -moz-animation-iteration-count: infinite;
+  -moz-animation-timing-function: linear;
+  -o-animation-name: rotate;
+  -o-animation-duration: 1.5s;
+  -o-animation-iteration-count: infinite;
+  -o-animation-timing-function: linear;
+  animation-name: rotate;
+  animation-duration: 1.5s;
+  animation-iteration-count: infinite;
+  animation-timing-function: linear; }
+
+.orbit-container {
+  overflow: hidden;
+  width: 100%;
+  position: relative;
+  background: none; }
+  .orbit-container .orbit-slides-container {
+    list-style: none;
+    margin: 0;
+    padding: 0;
+    position: relative;
+    -webkit-transform: translateZ(0); }
+    .orbit-container .orbit-slides-container img {
+      display: block;
+      max-width: 100%; }
+    .orbit-container .orbit-slides-container.fade > * {
+      -webkit-transform: translate3d(0, 0, 0);
+      opacity: 0.01;
+      transition: opacity 0.25s ease-in-out;
+      -moz-transition: opacity 0.25s ease-in-out;
+      -webkit-transition: opacity 0.25s ease-in-out; }
+      .orbit-container .orbit-slides-container.fade > *.animate-in {
+        opacity: 1;
+        z-index: 20;
+        transition: opacity 500ms ease-in-out;
+        -moz-transition: opacity 500ms ease-in-out;
+        -webkit-transition: opacity 500ms ease-in-out; }
+      .orbit-container .orbit-slides-container.fade > *.animate-out {
+        opacity: 0.01;
+        z-index: 10;
+        transition: opacity 500ms ease-in-out;
+        -moz-transition: opacity 500ms ease-in-out;
+        -webkit-transition: opacity 500ms ease-in-out; }
+    .orbit-container .orbit-slides-container.swipe-next > * {
+      -webkit-transform: translate3d(100%, 0, 0); }
+      .orbit-container .orbit-slides-container.swipe-next > *.animate-in {
+        -webkit-transform: translate3d(0, 0, 0);
+        -moz-transform: translate3d(0, 0, 0);
+        -ms-transform: translate3d(0, 0, 0);
+        -o-transform: translate3d(0, 0, 0);
+        transform: translate3d(0, 0, 0);
+        -webkit-transition-duration: 500ms;
+        -moz-transition-duration: 500ms;
+        -o-transition-duration: 500ms;
+        transition-duration: 500ms; }
+      .orbit-container .orbit-slides-container.swipe-next > *.animate-out {
+        -webkit-transform: translate3d(-100%, 0, 0);
+        -moz-transform: translate3d(-100%, 0, 0);
+        -ms-transform: translate3d(-100%, 0, 0);
+        -o-transform: translate3d(-100%, 0, 0);
+        transform: translate3d(-100%, 0, 0);
+        -webkit-transition-duration: 500ms;
+        -moz-transition-duration: 500ms;
+        -o-transition-duration: 500ms;
+        transition-duration: 500ms; }
+    .orbit-container .orbit-slides-container.swipe-prev > * {
+      -webkit-transform: translate3d(-100%, 0, 0);
+      -moz-transform: translate3d(-100%, 0, 0);
+      -ms-transform: translate3d(-100%, 0, 0);
+      -o-transform: translate3d(-100%, 0, 0);
+      transform: translate3d(-100%, 0, 0); }
+      .orbit-container .orbit-slides-container.swipe-prev > *.animate-in {
+        -webkit-transform: translate3d(0, 0, 0);
+        -moz-transform: translate3d(0, 0, 0);
+        -ms-transform: translate3d(0, 0, 0);
+        -o-transform: translate3d(0, 0, 0);
+        transform: translate3d(0, 0, 0);
+        -webkit-transition-duration: 500ms;
+        -moz-transition-duration: 500ms;
+        -o-transition-duration: 500ms;
+        transition-duration: 500ms; }
+      .orbit-container .orbit-slides-container.swipe-prev > *.animate-out {
+        -webkit-transform: translate3d(100%, 0, 0);
+        -moz-transform: translate3d(100%, 0, 0);
+        -ms-transform: translate3d(100%, 0, 0);
+        -o-transform: translate3d(100%, 0, 0);
+        transform: translate3d(100%, 0, 0);
+        -webkit-transition-duration: 500ms;
+        -moz-transition-duration: 500ms;
+        -o-transition-duration: 500ms;
+        transition-duration: 500ms; }
+    .orbit-container .orbit-slides-container > * {
+      position: absolute;
+      top: 0;
+      left: 0;
+      width: 100%;
+      -webkit-transform: translate3d(100%, 0, 0);
+      -moz-transform: translate3d(100%, 0, 0);
+      -ms-transform: translate3d(100%, 0, 0);
+      -o-transform: translate3d(100%, 0, 0);
+      transform: translate3d(100%, 0, 0); }
+      .orbit-container .orbit-slides-container > *.active {
+        opacity: 1;
+        top: 0;
+        left: 0;
+        -webkit-transform: translate3d(0, 0, 0);
+        -moz-transform: translate3d(0, 0, 0);
+        -ms-transform: translate3d(0, 0, 0);
+        -o-transform: translate3d(0, 0, 0);
+        transform: translate3d(0, 0, 0); }
+      .orbit-container .orbit-slides-container > * .orbit-caption {
+        position: absolute;
+        bottom: 0;
+        background-color: rgba(51, 51, 51, 0.8);
+        color: white;
+        width: 100%;
+        padding: 0.625rem 0.875rem;
+        font-size: 0.875rem; }
+  .orbit-container .orbit-slide-number {
+    position: absolute;
+    top: 10px;
+    left: 10px;
+    font-size: 12px;
+    color: white;
+    background: rgba(0, 0, 0, 0);
+    z-index: 10; }
+    .orbit-container .orbit-slide-number span {
+      font-weight: 700;
+      padding: 0.3125rem; }
+  .orbit-container .orbit-timer {
+    position: absolute;
+    top: 12px;
+    right: 10px;
+    height: 6px;
+    width: 100px;
+    z-index: 10; }
+    .orbit-container .orbit-timer .orbit-progress {
+      height: 3px;
+      background-color: rgba(255, 255, 255, 0.3);
+      display: block;
+      width: 0%;
+      position: relative;
+      right: 20px;
+      top: 5px; }
+    .orbit-container .orbit-timer > span {
+      display: none;
+      position: absolute;
+      top: 0px;
+      right: 0;
+      width: 11px;
+      height: 14px;
+      border: solid 4px white;
+      border-top: none;
+      border-bottom: none; }
+    .orbit-container .orbit-timer.paused > span {
+      right: -4px;
+      top: 0px;
+      width: 11px;
+      height: 14px;
+      border: inset 8px;
+      border-right-style: solid;
+      border-color: transparent transparent transparent white; }
+      .orbit-container .orbit-timer.paused > span.dark {
+        border-color: transparent transparent transparent #333333; }
+  .orbit-container:hover .orbit-timer > span {
+    display: block; }
+  .orbit-container .orbit-prev,
+  .orbit-container .orbit-next {
+    position: absolute;
+    top: 45%;
+    margin-top: -25px;
+    width: 36px;
+    height: 60px;
+    line-height: 50px;
+    color: white;
+    background-color: none;
+    text-indent: -9999px !important;
+    z-index: 10; }
+    .orbit-container .orbit-prev:hover,
+    .orbit-container .orbit-next:hover {
+      background-color: rgba(0, 0, 0, 0.3); }
+    .orbit-container .orbit-prev > span,
+    .orbit-container .orbit-next > span {
+      position: absolute;
+      top: 50%;
+      margin-top: -10px;
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 10px; }
+  .orbit-container .orbit-prev {
+    left: 0; }
+    .orbit-container .orbit-prev > span {
+      border-right-style: solid;
+      border-color: transparent;
+      border-right-color: white; }
+    .orbit-container .orbit-prev:hover > span {
+      border-right-color: white; }
+  .orbit-container .orbit-next {
+    right: 0; }
+    .orbit-container .orbit-next > span {
+      border-color: transparent;
+      border-left-style: solid;
+      border-left-color: white;
+      left: 50%;
+      margin-left: -4px; }
+    .orbit-container .orbit-next:hover > span {
+      border-left-color: white; }
+
+.orbit-bullets-container {
+  text-align: center; }
+
+.orbit-bullets {
+  margin: 0 auto 30px auto;
+  overflow: hidden;
+  position: relative;
+  top: 10px;
+  float: none;
+  text-align: center;
+  display: block; }
+  .orbit-bullets li {
+    display: inline-block;
+    width: 0.5625rem;
+    height: 0.5625rem;
+    background: #cccccc;
+    float: none;
+    margin-right: 6px;
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+    .orbit-bullets li.active {
+      background: #999999; }
+    .orbit-bullets li:last-child {
+      margin-right: 0; }
+
+.touch .orbit-container .orbit-prev,
+.touch .orbit-container .orbit-next {
+  display: none; }
+.touch .orbit-bullets {
+  display: none; }
+
+@media only screen and (min-width: 40.063em) {
+  .touch .orbit-container .orbit-prev,
+  .touch .orbit-container .orbit-next {
+    display: inherit; }
+  .touch .orbit-bullets {
+    display: block; } }
+@media only screen and (max-width: 40em) {
+  .orbit-stack-on-small .orbit-slides-container {
+    height: auto !important; }
+  .orbit-stack-on-small .orbit-slides-container > * {
+    position: relative;
+    margin-left: 0% !important; }
+  .orbit-stack-on-small .orbit-timer,
+  .orbit-stack-on-small .orbit-next,
+  .orbit-stack-on-small .orbit-prev,
+  .orbit-stack-on-small .orbit-bullets {
+    display: none; } }
+[data-magellan-expedition] {
+  background: white;
+  z-index: 50;
+  min-width: 100%;
+  padding: 10px; }
+  [data-magellan-expedition] .sub-nav {
+    margin-bottom: 0; }
+    [data-magellan-expedition] .sub-nav dd {
+      margin-bottom: 0; }
+    [data-magellan-expedition] .sub-nav a {
+      line-height: 1.8em; }
+
+.tabs {
+  *zoom: 1;
+  margin-bottom: 0 !important; }
+  .tabs:before, .tabs:after {
+    content: " ";
+    display: table; }
+  .tabs:after {
+    clear: both; }
+  .tabs dd {
+    position: relative;
+    margin-bottom: 0 !important;
+    float: left; }
+    .tabs dd > a {
+      display: block;
+      background: #efefef;
+      color: #222222;
+      padding: 1rem 2rem;
+      font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+      font-size: 1rem; }
+      .tabs dd > a:hover {
+        background: #e1e1e1; }
+    .tabs dd.active a {
+      background: white; }
+  .tabs.radius dd:first-child a {
+    -moz-border-radius-bottomleft: 3px;
+    -moz-border-radius-topleft: 3px;
+    -webkit-border-bottom-left-radius: 3px;
+    -webkit-border-top-left-radius: 3px;
+    border-bottom-left-radius: 3px;
+    border-top-left-radius: 3px; }
+  .tabs.radius dd:last-child a {
+    -moz-border-radius-bottomright: 3px;
+    -moz-border-radius-topright: 3px;
+    -webkit-border-bottom-right-radius: 3px;
+    -webkit-border-top-right-radius: 3px;
+    border-bottom-right-radius: 3px;
+    border-top-right-radius: 3px; }
+  .tabs.vertical dd {
+    position: inherit;
+    float: none;
+    display: block;
+    top: auto; }
+
+.tabs-content {
+  *zoom: 1;
+  margin-bottom: 1.5rem;
+  width: 100%; }
+  .tabs-content:before, .tabs-content:after {
+    content: " ";
+    display: table; }
+  .tabs-content:after {
+    clear: both; }
+  .tabs-content > .content {
+    display: none;
+    float: left;
+    padding: 0.9375rem 0;
+    width: 100%; }
+    .tabs-content > .content.active {
+      display: block;
+      float: none; }
+    .tabs-content > .content.contained {
+      padding: 0.9375rem; }
+  .tabs-content.vertical {
+    display: block; }
+    .tabs-content.vertical > .content {
+      padding: 0 0.9375rem; }
+
+@media only screen and (min-width: 40.063em) {
+  .tabs.vertical {
+    width: 20%;
+    float: left;
+    margin-bottom: 1.25rem; }
+
+  .tabs-content.vertical {
+    width: 80%;
+    float: left;
+    margin-left: -1px; } }
+.no-js .tabs-content > .content {
+  display: block;
+  float: none; }
+
+ul.pagination {
+  display: block;
+  height: 1.5rem;
+  margin-left: -0.3125rem; }
+  ul.pagination li {
+    height: 1.5rem;
+    color: #222222;
+    font-size: 0.875rem;
+    margin-left: 0.3125rem; }
+    ul.pagination li a {
+      display: block;
+      padding: 0.0625rem 0.625rem 0.0625rem;
+      color: #999999;
+      -webkit-border-radius: 3px;
+      border-radius: 3px; }
+    ul.pagination li:hover a,
+    ul.pagination li a:focus {
+      background: #e6e6e6; }
+    ul.pagination li.unavailable a {
+      cursor: default;
+      color: #999999; }
+    ul.pagination li.unavailable:hover a, ul.pagination li.unavailable a:focus {
+      background: transparent; }
+    ul.pagination li.current a {
+      background: #008cba;
+      color: white;
+      font-weight: bold;
+      cursor: default; }
+      ul.pagination li.current a:hover, ul.pagination li.current a:focus {
+        background: #008cba; }
+  ul.pagination li {
+    float: left;
+    display: block; }
+
+/* Pagination centred wrapper */
+.pagination-centered {
+  text-align: center; }
+  .pagination-centered ul.pagination li {
+    float: none;
+    display: inline-block; }
+
+.side-nav {
+  display: block;
+  margin: 0;
+  padding: 0.875rem 0;
+  list-style-type: none;
+  list-style-position: inside;
+  font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif; }
+  .side-nav li {
+    margin: 0 0 0.4375rem 0;
+    font-size: 0.875rem; }
+    .side-nav li a:not(.button) {
+      display: block;
+      color: #008cba; }
+      .side-nav li a:not(.button):hover, .side-nav li a:not(.button):focus {
+        color: #1cc7ff; }
+    .side-nav li.active > a:first-child:not(.button) {
+      color: #1cc7ff;
+      font-weight: normal;
+      font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif; }
+    .side-nav li.divider {
+      border-top: 1px solid;
+      height: 0;
+      padding: 0;
+      list-style: none;
+      border-top-color: white; }
+
+.accordion {
+  *zoom: 1;
+  margin-bottom: 0; }
+  .accordion:before, .accordion:after {
+    content: " ";
+    display: table; }
+  .accordion:after {
+    clear: both; }
+  .accordion dd {
+    display: block;
+    margin-bottom: 0 !important; }
+    .accordion dd.active > a {
+      background: #e8e8e8; }
+    .accordion dd > a {
+      background: #efefef;
+      color: #222222;
+      padding: 1rem;
+      display: block;
+      font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+      font-size: 1rem; }
+      .accordion dd > a:hover {
+        background: #e3e3e3; }
+  .accordion .content {
+    display: none;
+    padding: 0.9375rem; }
+    .accordion .content.active {
+      display: block;
+      background: white; }
+
+.text-left {
+  text-align: left !important; }
+
+.text-right {
+  text-align: right !important; }
+
+.text-center {
+  text-align: center !important; }
+
+.text-justify {
+  text-align: justify !important; }
+
+@media only screen and (max-width: 40em) {
+  .small-only-text-left {
+    text-align: left !important; }
+
+  .small-only-text-right {
+    text-align: right !important; }
+
+  .small-only-text-center {
+    text-align: center !important; }
+
+  .small-only-text-justify {
+    text-align: justify !important; } }
+@media only screen {
+  .small-text-left {
+    text-align: left !important; }
+
+  .small-text-right {
+    text-align: right !important; }
+
+  .small-text-center {
+    text-align: center !important; }
+
+  .small-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) and (max-width: 64em) {
+  .medium-only-text-left {
+    text-align: left !important; }
+
+  .medium-only-text-right {
+    text-align: right !important; }
+
+  .medium-only-text-center {
+    text-align: center !important; }
+
+  .medium-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) {
+  .medium-text-left {
+    text-align: left !important; }
+
+  .medium-text-right {
+    text-align: right !important; }
+
+  .medium-text-center {
+    text-align: center !important; }
+
+  .medium-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) and (max-width: 90em) {
+  .large-only-text-left {
+    text-align: left !important; }
+
+  .large-only-text-right {
+    text-align: right !important; }
+
+  .large-only-text-center {
+    text-align: center !important; }
+
+  .large-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) {
+  .large-text-left {
+    text-align: left !important; }
+
+  .large-text-right {
+    text-align: right !important; }
+
+  .large-text-center {
+    text-align: center !important; }
+
+  .large-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) and (max-width: 120em) {
+  .xlarge-only-text-left {
+    text-align: left !important; }
+
+  .xlarge-only-text-right {
+    text-align: right !important; }
+
+  .xlarge-only-text-center {
+    text-align: center !important; }
+
+  .xlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) {
+  .xlarge-text-left {
+    text-align: left !important; }
+
+  .xlarge-text-right {
+    text-align: right !important; }
+
+  .xlarge-text-center {
+    text-align: center !important; }
+
+  .xlarge-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) and (max-width: 99999999em) {
+  .xxlarge-only-text-left {
+    text-align: left !important; }
+
+  .xxlarge-only-text-right {
+    text-align: right !important; }
+
+  .xxlarge-only-text-center {
+    text-align: center !important; }
+
+  .xxlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) {
+  .xxlarge-text-left {
+    text-align: left !important; }
+
+  .xxlarge-text-right {
+    text-align: right !important; }
+
+  .xxlarge-text-center {
+    text-align: center !important; }
+
+  .xxlarge-text-justify {
+    text-align: justify !important; } }
+.text-left {
+  text-align: left !important; }
+
+.text-right {
+  text-align: right !important; }
+
+.text-center {
+  text-align: center !important; }
+
+.text-justify {
+  text-align: justify !important; }
+
+@media only screen and (max-width: 40em) {
+  .small-only-text-left {
+    text-align: left !important; }
+
+  .small-only-text-right {
+    text-align: right !important; }
+
+  .small-only-text-center {
+    text-align: center !important; }
+
+  .small-only-text-justify {
+    text-align: justify !important; } }
+@media only screen {
+  .small-text-left {
+    text-align: left !important; }
+
+  .small-text-right {
+    text-align: right !important; }
+
+  .small-text-center {
+    text-align: center !important; }
+
+  .small-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) and (max-width: 64em) {
+  .medium-only-text-left {
+    text-align: left !important; }
+
+  .medium-only-text-right {
+    text-align: right !important; }
+
+  .medium-only-text-center {
+    text-align: center !important; }
+
+  .medium-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) {
+  .medium-text-left {
+    text-align: left !important; }
+
+  .medium-text-right {
+    text-align: right !important; }
+
+  .medium-text-center {
+    text-align: center !important; }
+
+  .medium-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) and (max-width: 90em) {
+  .large-only-text-left {
+    text-align: left !important; }
+
+  .large-only-text-right {
+    text-align: right !important; }
+
+  .large-only-text-center {
+    text-align: center !important; }
+
+  .large-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) {
+  .large-text-left {
+    text-align: left !important; }
+
+  .large-text-right {
+    text-align: right !important; }
+
+  .large-text-center {
+    text-align: center !important; }
+
+  .large-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) and (max-width: 120em) {
+  .xlarge-only-text-left {
+    text-align: left !important; }
+
+  .xlarge-only-text-right {
+    text-align: right !important; }
+
+  .xlarge-only-text-center {
+    text-align: center !important; }
+
+  .xlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) {
+  .xlarge-text-left {
+    text-align: left !important; }
+
+  .xlarge-text-right {
+    text-align: right !important; }
+
+  .xlarge-text-center {
+    text-align: center !important; }
+
+  .xlarge-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) and (max-width: 99999999em) {
+  .xxlarge-only-text-left {
+    text-align: left !important; }
+
+  .xxlarge-only-text-right {
+    text-align: right !important; }
+
+  .xxlarge-only-text-center {
+    text-align: center !important; }
+
+  .xxlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) {
+  .xxlarge-text-left {
+    text-align: left !important; }
+
+  .xxlarge-text-right {
+    text-align: right !important; }
+
+  .xxlarge-text-center {
+    text-align: center !important; }
+
+  .xxlarge-text-justify {
+    text-align: justify !important; } }
+/* Typography resets */
+div,
+dl,
+dt,
+dd,
+ul,
+ol,
+li,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+pre,
+form,
+p,
+blockquote,
+th,
+td {
+  margin: 0;
+  padding: 0; }
+
+/* Default Link Styles */
+a {
+  color: #008cba;
+  text-decoration: none;
+  line-height: inherit; }
+  a:hover, a:focus {
+    color: #0078a0; }
+  a img {
+    border: none; }
+
+/* Default paragraph styles */
+p {
+  font-family: inherit;
+  font-weight: normal;
+  font-size: 1rem;
+  line-height: 1.6;
+  margin-bottom: 1.25rem;
+  text-rendering: optimizeLegibility; }
+  p.lead {
+    font-size: 1.21875rem;
+    line-height: 1.6; }
+  p aside {
+    font-size: 0.875rem;
+    line-height: 1.35;
+    font-style: italic; }
+
+/* Default header styles */
+h1, h2, h3, h4, h5, h6 {
+  font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+  font-weight: normal;
+  font-style: normal;
+  color: #222222;
+  text-rendering: optimizeLegibility;
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem;
+  line-height: 1.4; }
+  h1 small, h2 small, h3 small, h4 small, h5 small, h6 small {
+    font-size: 60%;
+    color: #6f6f6f;
+    line-height: 0; }
+
+h1 {
+  font-size: 2.125rem; }
+
+h2 {
+  font-size: 1.6875rem; }
+
+h3 {
+  font-size: 1.375rem; }
+
+h4 {
+  font-size: 1.125rem; }
+
+h5 {
+  font-size: 1.125rem; }
+
+h6 {
+  font-size: 1rem; }
+
+.subheader {
+  line-height: 1.4;
+  color: #6f6f6f;
+  font-weight: normal;
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem; }
+
+hr {
+  border: solid #dddddd;
+  border-width: 1px 0 0;
+  clear: both;
+  margin: 1.25rem 0 1.1875rem;
+  height: 0; }
+
+/* Helpful Typography Defaults */
+em,
+i {
+  font-style: italic;
+  line-height: inherit; }
+
+strong,
+b {
+  font-weight: bold;
+  line-height: inherit; }
+
+small {
+  font-size: 60%;
+  line-height: inherit; }
+
+code {
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-weight: bold;
+  color: #bd260d; }
+
+/* Lists */
+ul,
+ol,
+dl {
+  font-size: 1rem;
+  line-height: 1.6;
+  margin-bottom: 1.25rem;
+  list-style-position: outside;
+  font-family: inherit; }
+
+ul {
+  margin-left: 1.1rem; }
+  ul.no-bullet {
+    margin-left: 0; }
+    ul.no-bullet li ul,
+    ul.no-bullet li ol {
+      margin-left: 1.25rem;
+      margin-bottom: 0;
+      list-style: none; }
+
+/* Unordered Lists */
+ul li ul,
+ul li ol {
+  margin-left: 1.25rem;
+  margin-bottom: 0; }
+ul.square li ul, ul.circle li ul, ul.disc li ul {
+  list-style: inherit; }
+ul.square {
+  list-style-type: square;
+  margin-left: 1.1rem; }
+ul.circle {
+  list-style-type: circle;
+  margin-left: 1.1rem; }
+ul.disc {
+  list-style-type: disc;
+  margin-left: 1.1rem; }
+ul.no-bullet {
+  list-style: none; }
+
+/* Ordered Lists */
+ol {
+  margin-left: 1.4rem; }
+  ol li ul,
+  ol li ol {
+    margin-left: 1.25rem;
+    margin-bottom: 0; }
+
+/* Definition Lists */
+dl dt {
+  margin-bottom: 0.3rem;
+  font-weight: bold; }
+dl dd {
+  margin-bottom: 0.75rem; }
+
+/* Abbreviations */
+abbr,
+acronym {
+  text-transform: uppercase;
+  font-size: 90%;
+  color: #222222;
+  border-bottom: 1px dotted #dddddd;
+  cursor: help; }
+
+abbr {
+  text-transform: none; }
+
+/* Blockquotes */
+blockquote {
+  margin: 0 0 1.25rem;
+  padding: 0.5625rem 1.25rem 0 1.1875rem;
+  border-left: 1px solid #dddddd; }
+  blockquote cite {
+    display: block;
+    font-size: 0.8125rem;
+    color: #555555; }
+    blockquote cite:before {
+      content: "\2014 \0020"; }
+    blockquote cite a,
+    blockquote cite a:visited {
+      color: #555555; }
+
+blockquote,
+blockquote p {
+  line-height: 1.6;
+  color: #6f6f6f; }
+
+/* Microformats */
+.vcard {
+  display: inline-block;
+  margin: 0 0 1.25rem 0;
+  border: 1px solid #dddddd;
+  padding: 0.625rem 0.75rem; }
+  .vcard li {
+    margin: 0;
+    display: block; }
+  .vcard .fn {
+    font-weight: bold;
+    font-size: 0.9375rem; }
+
+.vevent .summary {
+  font-weight: bold; }
+.vevent abbr {
+  cursor: default;
+  text-decoration: none;
+  font-weight: bold;
+  border: none;
+  padding: 0 0.0625rem; }
+
+@media only screen and (min-width: 40.063em) {
+  h1, h2, h3, h4, h5, h6 {
+    line-height: 1.4; }
+
+  h1 {
+    font-size: 2.75rem; }
+
+  h2 {
+    font-size: 2.3125rem; }
+
+  h3 {
+    font-size: 1.6875rem; }
+
+  h4 {
+    font-size: 1.4375rem; } }
+/*
+ * Print styles.
+ *
+ * Inlined to avoid required HTTP connection: www.phpied.com/delay-loading-your-print-css/
+ * Credit to Paul Irish and HTML5 Boilerplate (html5boilerplate.com)
+*/
+.print-only {
+  display: none !important; }
+
+@media print {
+  * {
+    background: transparent !important;
+    color: black !important;
+    /* Black prints faster: h5bp.com/s */
+    box-shadow: none !important;
+    text-shadow: none !important; }
+
+  a,
+  a:visited {
+    text-decoration: underline; }
+
+  a[href]:after {
+    content: " (" attr(href) ")"; }
+
+  abbr[title]:after {
+    content: " (" attr(title) ")"; }
+
+  .ir a:after,
+  a[href^="javascript:"]:after,
+  a[href^="#"]:after {
+    content: ""; }
+
+  pre,
+  blockquote {
+    border: 1px solid #999999;
+    page-break-inside: avoid; }
+
+  thead {
+    display: table-header-group;
+    /* h5bp.com/t */ }
+
+  tr,
+  img {
+    page-break-inside: avoid; }
+
+  img {
+    max-width: 100% !important; }
+
+  @page {
+    margin: 0.5cm; }
+
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3; }
+
+  h2,
+  h3 {
+    page-break-after: avoid; }
+
+  .hide-on-print {
+    display: none !important; }
+
+  .print-only {
+    display: block !important; }
+
+  .hide-for-print {
+    display: none !important; }
+
+  .show-for-print {
+    display: inherit !important; } }
+.split.button {
+  position: relative;
+  padding-right: 5.0625rem; }
+  .split.button span {
+    display: block;
+    height: 100%;
+    position: absolute;
+    right: 0;
+    top: 0;
+    border-left: solid 1px; }
+    .split.button span:before {
+      position: absolute;
+      content: "";
+      width: 0;
+      height: 0;
+      display: block;
+      border-style: inset;
+      top: 50%;
+      left: 50%; }
+    .split.button span:active {
+      background-color: rgba(0, 0, 0, 0.1); }
+  .split.button span {
+    border-left-color: rgba(255, 255, 255, 0.5); }
+  .split.button span {
+    width: 3.09375rem; }
+    .split.button span:before {
+      border-top-style: solid;
+      border-width: 0.375rem;
+      top: 48%;
+      margin-left: -0.375rem; }
+  .split.button span:before {
+    border-color: white transparent transparent transparent; }
+  .split.button.secondary span {
+    border-left-color: rgba(255, 255, 255, 0.5); }
+  .split.button.secondary span:before {
+    border-color: white transparent transparent transparent; }
+  .split.button.alert span {
+    border-left-color: rgba(255, 255, 255, 0.5); }
+  .split.button.success span {
+    border-left-color: rgba(255, 255, 255, 0.5); }
+  .split.button.tiny {
+    padding-right: 3.75rem; }
+    .split.button.tiny span {
+      width: 2.25rem; }
+      .split.button.tiny span:before {
+        border-top-style: solid;
+        border-width: 0.375rem;
+        top: 48%;
+        margin-left: -0.375rem; }
+  .split.button.small {
+    padding-right: 4.375rem; }
+    .split.button.small span {
+      width: 2.625rem; }
+      .split.button.small span:before {
+        border-top-style: solid;
+        border-width: 0.4375rem;
+        top: 48%;
+        margin-left: -0.375rem; }
+  .split.button.large {
+    padding-right: 5.5rem; }
+    .split.button.large span {
+      width: 3.4375rem; }
+      .split.button.large span:before {
+        border-top-style: solid;
+        border-width: 0.3125rem;
+        top: 48%;
+        margin-left: -0.375rem; }
+  .split.button.expand {
+    padding-left: 2rem; }
+  .split.button.secondary span:before {
+    border-color: #333333 transparent transparent transparent; }
+  .split.button.radius span {
+    -moz-border-radius-bottomright: 3px;
+    -moz-border-radius-topright: 3px;
+    -webkit-border-bottom-right-radius: 3px;
+    -webkit-border-top-right-radius: 3px;
+    border-bottom-right-radius: 3px;
+    border-top-right-radius: 3px; }
+  .split.button.round span {
+    -moz-border-radius-bottomright: 1000px;
+    -moz-border-radius-topright: 1000px;
+    -webkit-border-bottom-right-radius: 1000px;
+    -webkit-border-top-right-radius: 1000px;
+    border-bottom-right-radius: 1000px;
+    border-top-right-radius: 1000px; }
+
+.reveal-modal-bg {
+  position: fixed;
+  height: 100%;
+  width: 100%;
+  background: black;
+  background: rgba(0, 0, 0, 0.45);
+  z-index: 99;
+  display: none;
+  top: 0;
+  left: 0; }
+
+dialog, .reveal-modal {
+  visibility: hidden;
+  display: none;
+  position: absolute;
+  z-index: 100;
+  width: 100vw;
+  top: 0;
+  left: 0;
+  background-color: white;
+  padding: 1.25rem;
+  border: solid 1px #666666;
+  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
+  box-shadow: 0 0 10px rgba(0, 0, 0, 0.4); }
+  @media only screen and (max-width: 40em) {
+    dialog, .reveal-modal {
+      height: 100vh;
+      min-height: 100vh; } }
+  @media only screen and (min-width: 40.063em) {
+    dialog, .reveal-modal {
+      left: 50%; } }
+  dialog .column,
+  dialog .columns, .reveal-modal .column,
+  .reveal-modal .columns {
+    min-width: 0; }
+  dialog > :first-child, .reveal-modal > :first-child {
+    margin-top: 0; }
+  dialog > :last-child, .reveal-modal > :last-child {
+    margin-bottom: 0; }
+  @media only screen and (min-width: 40.063em) {
+    dialog, .reveal-modal {
+      margin-left: -40%;
+      width: 80%; } }
+  @media only screen and (min-width: 40.063em) {
+    dialog, .reveal-modal {
+      top: 6.25rem; } }
+  dialog .close-reveal-modal, .reveal-modal .close-reveal-modal {
+    font-size: 2.5rem;
+    line-height: 1;
+    position: absolute;
+    top: 0.5rem;
+    right: 0.6875rem;
+    color: #aaaaaa;
+    font-weight: bold;
+    cursor: pointer; }
+
+dialog[open] {
+  display: block;
+  visibility: visible; }
+
+@media only screen and (min-width: 40.063em) {
+  dialog, .reveal-modal {
+    padding: 1.875rem; }
+  dialog.full, .reveal-modal.full {
+    top: 0;
+    left: 0;
+    height: 100vh;
+    min-height: 100vh;
+    margin-left: 0 !important; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog, .reveal-modal {
+      top: 6.25rem; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.tiny, .reveal-modal.tiny {
+      margin-left: -15%;
+      width: 30%; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.small, .reveal-modal.small {
+      margin-left: -20%;
+      width: 40%; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.medium, .reveal-modal.medium {
+      margin-left: -30%;
+      width: 60%; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.large, .reveal-modal.large {
+      margin-left: -35%;
+      width: 70%; } }
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.xlarge, .reveal-modal.xlarge {
+      margin-left: -47.5%;
+      width: 95%; } }
+
+  @media only screen and (min-width: 40.063em) and (min-width: 40.063em) {
+    dialog.full, .reveal-modal.full {
+      margin-left: -50vw;
+      width: 100vw; } }
+
+@media print {
+  dialog, .reveal-modal {
+    background: white !important; } }
+/* Tooltips */
+.has-tip {
+  border-bottom: dotted 1px #cccccc;
+  cursor: help;
+  font-weight: bold;
+  color: #333333; }
+  .has-tip:hover, .has-tip:focus {
+    border-bottom: dotted 1px #003f54;
+    color: #008cba; }
+  .has-tip.tip-left, .has-tip.tip-right {
+    float: none !important; }
+
+.tooltip {
+  display: none;
+  position: absolute;
+  z-index: 999;
+  font-weight: normal;
+  font-size: 0.875rem;
+  line-height: 1.3;
+  padding: 0.75rem;
+  max-width: 85%;
+  left: 50%;
+  width: 100%;
+  color: white;
+  background: #333333; }
+  .tooltip > .nub {
+    display: block;
+    left: 5px;
+    position: absolute;
+    width: 0;
+    height: 0;
+    border: solid 5px;
+    border-color: transparent transparent #333333 transparent;
+    top: -10px; }
+    .tooltip > .nub.rtl {
+      left: auto;
+      right: 5px; }
+  .tooltip.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+  .tooltip.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+    .tooltip.round > .nub {
+      left: 2rem; }
+  .tooltip.opened {
+    color: #008cba !important;
+    border-bottom: dotted 1px #003f54 !important; }
+
+.tap-to-close {
+  display: block;
+  font-size: 0.625rem;
+  color: #777777;
+  font-weight: normal; }
+
+@media only screen and (min-width: 40.063em) {
+  .tooltip > .nub {
+    border-color: transparent transparent #333333 transparent;
+    top: -10px; }
+  .tooltip.tip-top > .nub {
+    border-color: #333333 transparent transparent transparent;
+    top: auto;
+    bottom: -10px; }
+  .tooltip.tip-left, .tooltip.tip-right {
+    float: none !important; }
+  .tooltip.tip-left > .nub {
+    border-color: transparent transparent transparent #333333;
+    right: -10px;
+    left: auto;
+    top: 50%;
+    margin-top: -5px; }
+  .tooltip.tip-right > .nub {
+    border-color: transparent #333333 transparent transparent;
+    right: auto;
+    left: -10px;
+    top: 50%;
+    margin-top: -5px; } }
+/* Clearing Styles */
+.clearing-thumbs, [data-clearing] {
+  *zoom: 1;
+  margin-bottom: 0;
+  margin-left: 0;
+  list-style: none; }
+  .clearing-thumbs:before, .clearing-thumbs:after, [data-clearing]:before, [data-clearing]:after {
+    content: " ";
+    display: table; }
+  .clearing-thumbs:after, [data-clearing]:after {
+    clear: both; }
+  .clearing-thumbs li, [data-clearing] li {
+    float: left;
+    margin-right: 10px; }
+  .clearing-thumbs[class*="block-grid-"] li, [data-clearing][class*="block-grid-"] li {
+    margin-right: 0; }
+
+.clearing-blackout {
+  background: #333333;
+  position: fixed;
+  width: 100%;
+  height: 100%;
+  top: 0;
+  left: 0;
+  z-index: 998; }
+  .clearing-blackout .clearing-close {
+    display: block; }
+
+.clearing-container {
+  position: relative;
+  z-index: 998;
+  height: 100%;
+  overflow: hidden;
+  margin: 0; }
+
+.clearing-touch-label {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  color: #aaa;
+  font-size: 0.6em; }
+
+.visible-img {
+  height: 95%;
+  position: relative; }
+  .visible-img img {
+    position: absolute;
+    left: 50%;
+    top: 50%;
+    margin-left: -50%;
+    max-height: 100%;
+    max-width: 100%; }
+
+.clearing-caption {
+  color: #cccccc;
+  font-size: 0.875em;
+  line-height: 1.3;
+  margin-bottom: 0;
+  text-align: center;
+  bottom: 0;
+  background: #333333;
+  width: 100%;
+  padding: 10px 30px 20px;
+  position: absolute;
+  left: 0; }
+
+.clearing-close {
+  z-index: 999;
+  padding-left: 20px;
+  padding-top: 10px;
+  font-size: 30px;
+  line-height: 1;
+  color: #cccccc;
+  display: none; }
+  .clearing-close:hover, .clearing-close:focus {
+    color: #ccc; }
+
+.clearing-assembled .clearing-container {
+  height: 100%; }
+  .clearing-assembled .clearing-container .carousel > ul {
+    display: none; }
+
+.clearing-feature li {
+  display: none; }
+  .clearing-feature li.clearing-featured-img {
+    display: block; }
+
+@media only screen and (min-width: 40.063em) {
+  .clearing-main-prev,
+  .clearing-main-next {
+    position: absolute;
+    height: 100%;
+    width: 40px;
+    top: 0; }
+    .clearing-main-prev > span,
+    .clearing-main-next > span {
+      position: absolute;
+      top: 50%;
+      display: block;
+      width: 0;
+      height: 0;
+      border: solid 12px; }
+      .clearing-main-prev > span:hover,
+      .clearing-main-next > span:hover {
+        opacity: 0.8; }
+
+  .clearing-main-prev {
+    left: 0; }
+    .clearing-main-prev > span {
+      left: 5px;
+      border-color: transparent;
+      border-right-color: #cccccc; }
+
+  .clearing-main-next {
+    right: 0; }
+    .clearing-main-next > span {
+      border-color: transparent;
+      border-left-color: #cccccc; }
+
+  .clearing-main-prev.disabled,
+  .clearing-main-next.disabled {
+    opacity: 0.3; }
+
+  .clearing-assembled .clearing-container .carousel {
+    background: rgba(51, 51, 51, 0.8);
+    height: 120px;
+    margin-top: 10px;
+    text-align: center; }
+    .clearing-assembled .clearing-container .carousel > ul {
+      display: inline-block;
+      z-index: 999;
+      height: 100%;
+      position: relative;
+      float: none; }
+      .clearing-assembled .clearing-container .carousel > ul li {
+        display: block;
+        width: 120px;
+        min-height: inherit;
+        float: left;
+        overflow: hidden;
+        margin-right: 0;
+        padding: 0;
+        position: relative;
+        cursor: pointer;
+        opacity: 0.4; }
+        .clearing-assembled .clearing-container .carousel > ul li.fix-height img {
+          height: 100%;
+          max-width: none; }
+        .clearing-assembled .clearing-container .carousel > ul li a.th {
+          border: none;
+          -webkit-box-shadow: none;
+          box-shadow: none;
+          display: block; }
+        .clearing-assembled .clearing-container .carousel > ul li img {
+          cursor: pointer !important;
+          width: 100% !important; }
+        .clearing-assembled .clearing-container .carousel > ul li.visible {
+          opacity: 1; }
+        .clearing-assembled .clearing-container .carousel > ul li:hover {
+          opacity: 0.8; }
+  .clearing-assembled .clearing-container .visible-img {
+    background: #333333;
+    overflow: hidden;
+    height: 85%; }
+
+  .clearing-close {
+    position: absolute;
+    top: 10px;
+    right: 20px;
+    padding-left: 0;
+    padding-top: 0; } }
+/* Progress Bar */
+.progress {
+  background-color: #f6f6f6;
+  height: 1.5625rem;
+  border: 1px solid white;
+  padding: 0.125rem;
+  margin-bottom: 0.625rem; }
+  .progress .meter {
+    background: #008cba;
+    height: 100%;
+    display: block; }
+  .progress.secondary .meter {
+    background: #e7e7e7;
+    height: 100%;
+    display: block; }
+  .progress.success .meter {
+    background: #43ac6a;
+    height: 100%;
+    display: block; }
+  .progress.alert .meter {
+    background: #f04124;
+    height: 100%;
+    display: block; }
+  .progress.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+    .progress.radius .meter {
+      -webkit-border-radius: 2px;
+      border-radius: 2px; }
+  .progress.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+    .progress.round .meter {
+      -webkit-border-radius: 999px;
+      border-radius: 999px; }
+
+.sub-nav {
+  display: block;
+  width: auto;
+  overflow: hidden;
+  margin: -0.25rem 0 1.125rem;
+  padding-top: 0.25rem;
+  margin-right: 0;
+  margin-left: -0.75rem; }
+  .sub-nav dt {
+    text-transform: uppercase; }
+  .sub-nav dt,
+  .sub-nav dd,
+  .sub-nav li {
+    float: left;
+    display: inline;
+    margin-left: 1rem;
+    margin-bottom: 0.625rem;
+    font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+    font-weight: normal;
+    font-size: 0.875rem;
+    color: #999999; }
+    .sub-nav dt a,
+    .sub-nav dd a,
+    .sub-nav li a {
+      text-decoration: none;
+      color: #999999;
+      padding: 0.1875rem 1rem; }
+      .sub-nav dt a:hover,
+      .sub-nav dd a:hover,
+      .sub-nav li a:hover {
+        color: #737373; }
+    .sub-nav dt.active a,
+    .sub-nav dd.active a,
+    .sub-nav li.active a {
+      -webkit-border-radius: 3px;
+      border-radius: 3px;
+      font-weight: normal;
+      background: #008cba;
+      padding: 0.1875rem 1rem;
+      cursor: default;
+      color: white; }
+      .sub-nav dt.active a:hover,
+      .sub-nav dd.active a:hover,
+      .sub-nav li.active a:hover {
+        background: #0078a0; }
+
+/* Foundation Joyride */
+.joyride-list {
+  display: none; }
+
+/* Default styles for the container */
+.joyride-tip-guide {
+  display: none;
+  position: absolute;
+  background: #333333;
+  color: white;
+  z-index: 101;
+  top: 0;
+  left: 2.5%;
+  font-family: inherit;
+  font-weight: normal;
+  width: 95%; }
+
+.lt-ie9 .joyride-tip-guide {
+  max-width: 800px;
+  left: 50%;
+  margin-left: -400px; }
+
+.joyride-content-wrapper {
+  width: 100%;
+  padding: 1.125rem 1.25rem 1.5rem; }
+  .joyride-content-wrapper .button {
+    margin-bottom: 0 !important; }
+
+/* Add a little css triangle pip, older browser just miss out on the fanciness of it */
+.joyride-tip-guide .joyride-nub {
+  display: block;
+  position: absolute;
+  left: 22px;
+  width: 0;
+  height: 0;
+  border: 10px solid #333333; }
+  .joyride-tip-guide .joyride-nub.top {
+    border-top-style: solid;
+    border-color: #333333;
+    border-top-color: transparent !important;
+    border-left-color: transparent !important;
+    border-right-color: transparent !important;
+    top: -20px; }
+  .joyride-tip-guide .joyride-nub.bottom {
+    border-bottom-style: solid;
+    border-color: #333333 !important;
+    border-bottom-color: transparent !important;
+    border-left-color: transparent !important;
+    border-right-color: transparent !important;
+    bottom: -20px; }
+  .joyride-tip-guide .joyride-nub.right {
+    right: -20px; }
+  .joyride-tip-guide .joyride-nub.left {
+    left: -20px; }
+
+/* Typography */
+.joyride-tip-guide h1,
+.joyride-tip-guide h2,
+.joyride-tip-guide h3,
+.joyride-tip-guide h4,
+.joyride-tip-guide h5,
+.joyride-tip-guide h6 {
+  line-height: 1.25;
+  margin: 0;
+  font-weight: bold;
+  color: white; }
+
+.joyride-tip-guide p {
+  margin: 0 0 1.125rem 0;
+  font-size: 0.875rem;
+  line-height: 1.3; }
+
+.joyride-timer-indicator-wrap {
+  width: 50px;
+  height: 3px;
+  border: solid 1px #555555;
+  position: absolute;
+  right: 1.0625rem;
+  bottom: 1rem; }
+
+.joyride-timer-indicator {
+  display: block;
+  width: 0;
+  height: inherit;
+  background: #666666; }
+
+.joyride-close-tip {
+  position: absolute;
+  right: 12px;
+  top: 10px;
+  color: #777777 !important;
+  text-decoration: none;
+  font-size: 24px;
+  font-weight: normal;
+  line-height: 0.5 !important; }
+  .joyride-close-tip:hover, .joyride-close-tip:focus {
+    color: #eeeeee !important; }
+
+.joyride-modal-bg {
+  position: fixed;
+  height: 100%;
+  width: 100%;
+  background: transparent;
+  background: rgba(0, 0, 0, 0.5);
+  z-index: 100;
+  display: none;
+  top: 0;
+  left: 0;
+  cursor: pointer; }
+
+.joyride-expose-wrapper {
+  background-color: #ffffff;
+  position: absolute;
+  border-radius: 3px;
+  z-index: 102;
+  -moz-box-shadow: 0 0 30px white;
+  -webkit-box-shadow: 0 0 15px white;
+  box-shadow: 0 0 15px white; }
+
+.joyride-expose-cover {
+  background: transparent;
+  border-radius: 3px;
+  position: absolute;
+  z-index: 9999;
+  top: 0;
+  left: 0; }
+
+/* Styles for screens that are at least 768px; */
+@media only screen and (min-width: 40.063em) {
+  .joyride-tip-guide {
+    width: 300px;
+    left: inherit; }
+    .joyride-tip-guide .joyride-nub.bottom {
+      border-color: #333333 !important;
+      border-bottom-color: transparent !important;
+      border-left-color: transparent !important;
+      border-right-color: transparent !important;
+      bottom: -20px; }
+    .joyride-tip-guide .joyride-nub.right {
+      border-color: #333333 !important;
+      border-top-color: transparent !important;
+      border-right-color: transparent !important;
+      border-bottom-color: transparent !important;
+      top: 22px;
+      left: auto;
+      right: -20px; }
+    .joyride-tip-guide .joyride-nub.left {
+      border-color: #333333 !important;
+      border-top-color: transparent !important;
+      border-left-color: transparent !important;
+      border-bottom-color: transparent !important;
+      top: 22px;
+      left: -20px;
+      right: auto; } }
+.label {
+  font-weight: normal;
+  font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
+  text-align: center;
+  text-decoration: none;
+  line-height: 1;
+  white-space: nowrap;
+  display: inline-block;
+  position: relative;
+  margin-bottom: inherit;
+  padding: 0.25rem 0.5rem 0.375rem;
+  font-size: 0.6875rem;
+  background-color: #008cba;
+  color: white; }
+  .label.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+  .label.round {
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+  .label.alert {
+    background-color: #f04124;
+    color: white; }
+  .label.success {
+    background-color: #43ac6a;
+    color: white; }
+  .label.secondary {
+    background-color: #e7e7e7;
+    color: #333333; }
+
+.text-left {
+  text-align: left !important; }
+
+.text-right {
+  text-align: right !important; }
+
+.text-center {
+  text-align: center !important; }
+
+.text-justify {
+  text-align: justify !important; }
+
+@media only screen and (max-width: 40em) {
+  .small-only-text-left {
+    text-align: left !important; }
+
+  .small-only-text-right {
+    text-align: right !important; }
+
+  .small-only-text-center {
+    text-align: center !important; }
+
+  .small-only-text-justify {
+    text-align: justify !important; } }
+@media only screen {
+  .small-text-left {
+    text-align: left !important; }
+
+  .small-text-right {
+    text-align: right !important; }
+
+  .small-text-center {
+    text-align: center !important; }
+
+  .small-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) and (max-width: 64em) {
+  .medium-only-text-left {
+    text-align: left !important; }
+
+  .medium-only-text-right {
+    text-align: right !important; }
+
+  .medium-only-text-center {
+    text-align: center !important; }
+
+  .medium-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 40.063em) {
+  .medium-text-left {
+    text-align: left !important; }
+
+  .medium-text-right {
+    text-align: right !important; }
+
+  .medium-text-center {
+    text-align: center !important; }
+
+  .medium-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) and (max-width: 90em) {
+  .large-only-text-left {
+    text-align: left !important; }
+
+  .large-only-text-right {
+    text-align: right !important; }
+
+  .large-only-text-center {
+    text-align: center !important; }
+
+  .large-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 64.063em) {
+  .large-text-left {
+    text-align: left !important; }
+
+  .large-text-right {
+    text-align: right !important; }
+
+  .large-text-center {
+    text-align: center !important; }
+
+  .large-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) and (max-width: 120em) {
+  .xlarge-only-text-left {
+    text-align: left !important; }
+
+  .xlarge-only-text-right {
+    text-align: right !important; }
+
+  .xlarge-only-text-center {
+    text-align: center !important; }
+
+  .xlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 90.063em) {
+  .xlarge-text-left {
+    text-align: left !important; }
+
+  .xlarge-text-right {
+    text-align: right !important; }
+
+  .xlarge-text-center {
+    text-align: center !important; }
+
+  .xlarge-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) and (max-width: 99999999em) {
+  .xxlarge-only-text-left {
+    text-align: left !important; }
+
+  .xxlarge-only-text-right {
+    text-align: right !important; }
+
+  .xxlarge-only-text-center {
+    text-align: center !important; }
+
+  .xxlarge-only-text-justify {
+    text-align: justify !important; } }
+@media only screen and (min-width: 120.063em) {
+  .xxlarge-text-left {
+    text-align: left !important; }
+
+  .xxlarge-text-right {
+    text-align: right !important; }
+
+  .xxlarge-text-center {
+    text-align: center !important; }
+
+  .xxlarge-text-justify {
+    text-align: justify !important; } }
+.off-canvas-wrap {
+  -webkit-backface-visibility: hidden;
+  position: relative;
+  width: 100%;
+  overflow-x: hidden; }
+  .off-canvas-wrap.move-right, .off-canvas-wrap.move-left {
+    height: 100%; }
+
+.inner-wrap {
+  -webkit-backface-visibility: hidden;
+  position: relative;
+  width: 100%;
+  *zoom: 1;
+  -webkit-transition: -webkit-transform 500ms ease;
+  -moz-transition: -moz-transform 500ms ease;
+  -ms-transition: -ms-transform 500ms ease;
+  -o-transition: -o-transform 500ms ease;
+  transition: transform 500ms ease; }
+  .inner-wrap:before, .inner-wrap:after {
+    content: " ";
+    display: table; }
+  .inner-wrap:after {
+    clear: both; }
+
+.tab-bar {
+  -webkit-backface-visibility: hidden;
+  background: #333333;
+  color: white;
+  height: 2.8125rem;
+  line-height: 2.8125rem;
+  position: relative; }
+  .tab-bar h1, .tab-bar h2, .tab-bar h3, .tab-bar h4, .tab-bar h5, .tab-bar h6 {
+    color: white;
+    font-weight: bold;
+    line-height: 2.8125rem;
+    margin: 0; }
+  .tab-bar h1, .tab-bar h2, .tab-bar h3, .tab-bar h4 {
+    font-size: 1.125rem; }
+
+.left-small {
+  width: 2.8125rem;
+  height: 2.8125rem;
+  position: absolute;
+  top: 0;
+  border-right: solid 1px #1a1a1a;
+  left: 0; }
+
+.right-small {
+  width: 2.8125rem;
+  height: 2.8125rem;
+  position: absolute;
+  top: 0;
+  border-left: solid 1px #1a1a1a;
+  right: 0; }
+
+.tab-bar-section {
+  padding: 0 0.625rem;
+  position: absolute;
+  text-align: center;
+  height: 2.8125rem;
+  top: 0; }
+  @media only screen and (min-width: 40.063em) {
+    .tab-bar-section {
+      text-align: left; } }
+  .tab-bar-section.left {
+    left: 0;
+    right: 2.8125rem; }
+  .tab-bar-section.right {
+    left: 2.8125rem;
+    right: 0; }
+  .tab-bar-section.middle {
+    left: 2.8125rem;
+    right: 2.8125rem; }
+
+.tab-bar .menu-icon {
+  text-indent: 2.1875rem;
+  width: 2.8125rem;
+  height: 2.8125rem;
+  display: block;
+  line-height: 2.0625rem;
+  padding: 0;
+  color: white;
+  position: relative; }
+  .tab-bar .menu-icon span {
+    position: absolute;
+    display: block;
+    height: 0;
+    width: 1rem;
+    top: 0.9375rem;
+    left: 0.90625rem;
+    -webkit-box-shadow: 1px 0px 1px 1px white, 1px 7px 1px 1px white, 1px 14px 1px 1px white;
+    box-shadow: 0 0px 0 1px white, 0 7px 0 1px white, 0 14px 0 1px white; }
+  .tab-bar .menu-icon:hover span {
+    -webkit-box-shadow: 1px 0px 1px 1px #b3b3b3, 1px 7px 1px 1px #b3b3b3, 1px 14px 1px 1px #b3b3b3;
+    box-shadow: 0 0px 0 1px #b3b3b3, 0 7px 0 1px #b3b3b3, 0 14px 0 1px #b3b3b3; }
+
+.left-off-canvas-menu {
+  -webkit-backface-visibility: hidden;
+  width: 15.625rem;
+  top: 0;
+  bottom: 0;
+  position: absolute;
+  overflow-y: auto;
+  background: #333333;
+  z-index: 1001;
+  box-sizing: content-box;
+  -webkit-overflow-scrolling: touch;
+  -webkit-transform: translate3d(-100%, 0, 0);
+  -moz-transform: translate3d(-100%, 0, 0);
+  -ms-transform: translate3d(-100%, 0, 0);
+  -o-transform: translate3d(-100%, 0, 0);
+  transform: translate3d(-100%, 0, 0);
+  left: 0; }
+  .left-off-canvas-menu * {
+    -webkit-backface-visibility: hidden; }
+
+.right-off-canvas-menu {
+  -webkit-backface-visibility: hidden;
+  width: 15.625rem;
+  top: 0;
+  bottom: 0;
+  position: absolute;
+  overflow-y: auto;
+  background: #333333;
+  z-index: 1001;
+  box-sizing: content-box;
+  -webkit-overflow-scrolling: touch;
+  -webkit-transform: translate3d(100%, 0, 0);
+  -moz-transform: translate3d(100%, 0, 0);
+  -ms-transform: translate3d(100%, 0, 0);
+  -o-transform: translate3d(100%, 0, 0);
+  transform: translate3d(100%, 0, 0);
+  right: 0; }
+  .right-off-canvas-menu * {
+    -webkit-backface-visibility: hidden; }
+
+ul.off-canvas-list {
+  list-style-type: none;
+  padding: 0;
+  margin: 0; }
+  ul.off-canvas-list li label {
+    padding: 0.3rem 0.9375rem;
+    color: #999999;
+    text-transform: uppercase;
+    font-weight: bold;
+    background: #444444;
+    border-top: 1px solid #5e5e5e;
+    border-bottom: none;
+    margin: 0; }
+  ul.off-canvas-list li a {
+    display: block;
+    padding: 0.66667rem;
+    color: rgba(255, 255, 255, 0.7);
+    border-bottom: 1px solid #262626;
+    transition: background 300ms ease; }
+    ul.off-canvas-list li a:hover {
+      background: #242424; }
+
+.move-right > .inner-wrap {
+  -webkit-transform: translate3d(15.625rem, 0, 0);
+  -moz-transform: translate3d(15.625rem, 0, 0);
+  -ms-transform: translate3d(15.625rem, 0, 0);
+  -o-transform: translate3d(15.625rem, 0, 0);
+  transform: translate3d(15.625rem, 0, 0); }
+.move-right .exit-off-canvas {
+  -webkit-backface-visibility: hidden;
+  transition: background 300ms ease;
+  cursor: pointer;
+  box-shadow: -4px 0 4px rgba(0, 0, 0, 0.5), 4px 0 4px rgba(0, 0, 0, 0.5);
+  display: block;
+  position: absolute;
+  background: rgba(255, 255, 255, 0.2);
+  top: 0;
+  bottom: 0;
+  left: 0;
+  right: 0;
+  z-index: 1002;
+  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
+  @media only screen and (min-width: 40.063em) {
+    .move-right .exit-off-canvas:hover {
+      background: rgba(255, 255, 255, 0.05); } }
+
+.move-left > .inner-wrap {
+  -webkit-transform: translate3d(-15.625rem, 0, 0);
+  -moz-transform: translate3d(-15.625rem, 0, 0);
+  -ms-transform: translate3d(-15.625rem, 0, 0);
+  -o-transform: translate3d(-15.625rem, 0, 0);
+  transform: translate3d(-15.625rem, 0, 0); }
+.move-left .exit-off-canvas {
+  -webkit-backface-visibility: hidden;
+  transition: background 300ms ease;
+  cursor: pointer;
+  box-shadow: -4px 0 4px rgba(0, 0, 0, 0.5), 4px 0 4px rgba(0, 0, 0, 0.5);
+  display: block;
+  position: absolute;
+  background: rgba(255, 255, 255, 0.2);
+  top: 0;
+  bottom: 0;
+  left: 0;
+  right: 0;
+  z-index: 1002;
+  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
+  @media only screen and (min-width: 40.063em) {
+    .move-left .exit-off-canvas:hover {
+      background: rgba(255, 255, 255, 0.05); } }
+
+.csstransforms.no-csstransforms3d .left-off-canvas-menu {
+  -webkit-transform: translate(-100%, 0);
+  -moz-transform: translate(-100%, 0);
+  -ms-transform: translate(-100%, 0);
+  -o-transform: translate(-100%, 0);
+  transform: translate(-100%, 0); }
+.csstransforms.no-csstransforms3d .right-off-canvas-menu {
+  -webkit-transform: translate(100%, 0);
+  -moz-transform: translate(100%, 0);
+  -ms-transform: translate(100%, 0);
+  -o-transform: translate(100%, 0);
+  transform: translate(100%, 0); }
+.csstransforms.no-csstransforms3d .move-left > .inner-wrap {
+  -webkit-transform: translate(-15.625rem, 0);
+  -moz-transform: translate(-15.625rem, 0);
+  -ms-transform: translate(-15.625rem, 0);
+  -o-transform: translate(-15.625rem, 0);
+  transform: translate(-15.625rem, 0); }
+.csstransforms.no-csstransforms3d .move-right > .inner-wrap {
+  -webkit-transform: translate(15.625rem, 0);
+  -moz-transform: translate(15.625rem, 0);
+  -ms-transform: translate(15.625rem, 0);
+  -o-transform: translate(15.625rem, 0);
+  transform: translate(15.625rem, 0); }
+
+.no-csstransforms .left-off-canvas-menu {
+  left: -15.625rem; }
+.no-csstransforms .right-off-canvas-menu {
+  right: -15.625rem; }
+.no-csstransforms .move-left > .inner-wrap {
+  right: 15.625rem; }
+.no-csstransforms .move-right > .inner-wrap {
+  left: 15.625rem; }
+
+/* Foundation Dropdowns */
+.f-dropdown {
+  position: absolute;
+  left: -9999px;
+  list-style: none;
+  margin-left: 0;
+  width: 100%;
+  max-height: none;
+  height: auto;
+  background: white;
+  border: solid 1px #cccccc;
+  font-size: 0.875rem;
+  z-index: 99;
+  margin-top: 2px;
+  max-width: 200px; }
+  .f-dropdown > *:first-child {
+    margin-top: 0; }
+  .f-dropdown > *:last-child {
+    margin-bottom: 0; }
+  .f-dropdown:before {
+    content: "";
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    border-color: transparent transparent white transparent;
+    border-bottom-style: solid;
+    position: absolute;
+    top: -12px;
+    left: 10px;
+    z-index: 99; }
+  .f-dropdown:after {
+    content: "";
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 7px;
+    border-color: transparent transparent #cccccc transparent;
+    border-bottom-style: solid;
+    position: absolute;
+    top: -14px;
+    left: 9px;
+    z-index: 98; }
+  .f-dropdown.right:before {
+    left: auto;
+    right: 10px; }
+  .f-dropdown.right:after {
+    left: auto;
+    right: 9px; }
+  .f-dropdown.drop-right {
+    position: absolute;
+    left: -9999px;
+    list-style: none;
+    margin-left: 0;
+    width: 100%;
+    max-height: none;
+    height: auto;
+    background: white;
+    border: solid 1px #cccccc;
+    font-size: 0.875rem;
+    z-index: 99;
+    margin-top: 0;
+    margin-left: 2px;
+    max-width: 200px; }
+    .f-dropdown.drop-right > *:first-child {
+      margin-top: 0; }
+    .f-dropdown.drop-right > *:last-child {
+      margin-bottom: 0; }
+    .f-dropdown.drop-right:before {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 6px;
+      border-color: transparent white transparent transparent;
+      border-right-style: solid;
+      position: absolute;
+      top: 10px;
+      left: -12px;
+      z-index: 99; }
+    .f-dropdown.drop-right:after {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 7px;
+      border-color: transparent #cccccc transparent transparent;
+      border-right-style: solid;
+      position: absolute;
+      top: 9px;
+      left: -14px;
+      z-index: 98; }
+  .f-dropdown.drop-left {
+    position: absolute;
+    left: -9999px;
+    list-style: none;
+    margin-left: 0;
+    width: 100%;
+    max-height: none;
+    height: auto;
+    background: white;
+    border: solid 1px #cccccc;
+    font-size: 0.875rem;
+    z-index: 99;
+    margin-top: 0;
+    margin-left: -2px;
+    max-width: 200px; }
+    .f-dropdown.drop-left > *:first-child {
+      margin-top: 0; }
+    .f-dropdown.drop-left > *:last-child {
+      margin-bottom: 0; }
+    .f-dropdown.drop-left:before {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 6px;
+      border-color: transparent transparent transparent white;
+      border-left-style: solid;
+      position: absolute;
+      top: 10px;
+      right: -12px;
+      left: auto;
+      z-index: 99; }
+    .f-dropdown.drop-left:after {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 7px;
+      border-color: transparent transparent transparent #cccccc;
+      border-left-style: solid;
+      position: absolute;
+      top: 9px;
+      right: -14px;
+      left: auto;
+      z-index: 98; }
+  .f-dropdown.drop-top {
+    position: absolute;
+    left: -9999px;
+    list-style: none;
+    margin-left: 0;
+    width: 100%;
+    max-height: none;
+    height: auto;
+    background: white;
+    border: solid 1px #cccccc;
+    font-size: 0.875rem;
+    z-index: 99;
+    margin-top: -2px;
+    margin-left: 0;
+    max-width: 200px; }
+    .f-dropdown.drop-top > *:first-child {
+      margin-top: 0; }
+    .f-dropdown.drop-top > *:last-child {
+      margin-bottom: 0; }
+    .f-dropdown.drop-top:before {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 6px;
+      border-color: white transparent transparent transparent;
+      border-top-style: solid;
+      position: absolute;
+      top: auto;
+      bottom: -12px;
+      left: 10px;
+      right: auto;
+      z-index: 99; }
+    .f-dropdown.drop-top:after {
+      content: "";
+      display: block;
+      width: 0;
+      height: 0;
+      border: inset 7px;
+      border-color: #cccccc transparent transparent transparent;
+      border-top-style: solid;
+      position: absolute;
+      top: auto;
+      bottom: -14px;
+      left: 9px;
+      right: auto;
+      z-index: 98; }
+  .f-dropdown li {
+    font-size: 0.875rem;
+    cursor: pointer;
+    line-height: 1.125rem;
+    margin: 0; }
+    .f-dropdown li:hover, .f-dropdown li:focus {
+      background: #eeeeee; }
+    .f-dropdown li a {
+      display: block;
+      padding: 0.5rem;
+      color: #555555; }
+  .f-dropdown.content {
+    position: absolute;
+    left: -9999px;
+    list-style: none;
+    margin-left: 0;
+    padding: 1.25rem;
+    width: 100%;
+    height: auto;
+    max-height: none;
+    background: white;
+    border: solid 1px #cccccc;
+    font-size: 0.875rem;
+    z-index: 99;
+    max-width: 200px; }
+    .f-dropdown.content > *:first-child {
+      margin-top: 0; }
+    .f-dropdown.content > *:last-child {
+      margin-bottom: 0; }
+  .f-dropdown.tiny {
+    max-width: 200px; }
+  .f-dropdown.small {
+    max-width: 300px; }
+  .f-dropdown.medium {
+    max-width: 500px; }
+  .f-dropdown.large {
+    max-width: 800px; }
+
+table {
+  background: white;
+  margin-bottom: 1.25rem;
+  border: solid 1px #dddddd; }
+  table thead,
+  table tfoot {
+    background: whitesmoke; }
+    table thead tr th,
+    table thead tr td,
+    table tfoot tr th,
+    table tfoot tr td {
+      padding: 0.5rem 0.625rem 0.625rem;
+      font-size: 0.875rem;
+      font-weight: bold;
+      color: #222222;
+      text-align: left; }
+  table tr th,
+  table tr td {
+    padding: 0.5625rem 0.625rem;
+    font-size: 0.875rem;
+    color: #222222; }
+  table tr.even, table tr.alt, table tr:nth-of-type(even) {
+    background: #f9f9f9; }
+  table thead tr th,
+  table tfoot tr th,
+  table tbody tr td,
+  table tr td,
+  table tfoot tr td {
+    display: table-cell;
+    line-height: 1.125rem; }
+
+/* Standard Forms */
+form {
+  margin: 0 0 1rem; }
+
+/* Using forms within rows, we need to set some defaults */
+form .row .row {
+  margin: 0 -0.5rem; }
+  form .row .row .column,
+  form .row .row .columns {
+    padding: 0 0.5rem; }
+  form .row .row.collapse {
+    margin: 0; }
+    form .row .row.collapse .column,
+    form .row .row.collapse .columns {
+      padding: 0; }
+    form .row .row.collapse input {
+      -moz-border-radius-bottomright: 0;
+      -moz-border-radius-topright: 0;
+      -webkit-border-bottom-right-radius: 0;
+      -webkit-border-top-right-radius: 0; }
+form .row input.column,
+form .row input.columns,
+form .row textarea.column,
+form .row textarea.columns {
+  padding-left: 0.5rem; }
+
+/* Label Styles */
+label {
+  font-size: 0.875rem;
+  color: #4d4d4d;
+  cursor: pointer;
+  display: block;
+  font-weight: normal;
+  line-height: 1.5;
+  margin-bottom: 0;
+  /* Styles for required inputs */ }
+  label.right {
+    float: none;
+    text-align: right; }
+  label.inline {
+    margin: 0 0 1rem 0;
+    padding: 0.625rem 0; }
+  label small {
+    text-transform: capitalize;
+    color: #676767; }
+
+select {
+  -webkit-appearance: none !important;
+  background-color: #fafafa;
+  background-image: url("data:image/svg+xml;base64, PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZlcnNpb249IjEuMSIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iM3B4IiB2aWV3Qm94PSIwIDAgNiAzIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCA2IDMiIHhtbDpzcGFjZT0icHJlc2VydmUiPjxwb2x5Z29uIHBvaW50cz0iNS45OTIsMCAyLjk5MiwzIC0wLjAwOCwwICIvPjwvc3ZnPg==");
+  background-repeat: no-repeat;
+  background-position: 97% center;
+  border: 1px solid #cccccc;
+  padding: 0.5rem;
+  font-size: 0.875rem;
+  -webkit-border-radius: 0;
+  border-radius: 0; }
+  select.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+  select:hover {
+    background-color: #f3f3f3;
+    border-color: #999999; }
+
+select::-ms-expand {
+  display: none; }
+
+@-moz-document url-prefix() {
+  select {
+    background: #fafafa; }
+
+  select:hover {
+    background: #f3f3f3; } }
+
+/* Attach elements to the beginning or end of an input */
+.prefix,
+.postfix {
+  display: block;
+  position: relative;
+  z-index: 2;
+  text-align: center;
+  width: 100%;
+  padding-top: 0;
+  padding-bottom: 0;
+  border-style: solid;
+  border-width: 1px;
+  overflow: hidden;
+  font-size: 0.875rem;
+  height: 2.3125rem;
+  line-height: 2.3125rem; }
+
+/* Adjust padding, alignment and radius if pre/post element is a button */
+.postfix.button {
+  padding-left: 0;
+  padding-right: 0;
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  line-height: 2.125rem;
+  border: none; }
+
+.prefix.button {
+  padding-left: 0;
+  padding-right: 0;
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  line-height: 2.125rem;
+  border: none; }
+
+.prefix.button.radius {
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  -moz-border-radius-bottomleft: 3px;
+  -moz-border-radius-topleft: 3px;
+  -webkit-border-bottom-left-radius: 3px;
+  -webkit-border-top-left-radius: 3px;
+  border-bottom-left-radius: 3px;
+  border-top-left-radius: 3px; }
+
+.postfix.button.radius {
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  -moz-border-radius-bottomright: 3px;
+  -moz-border-radius-topright: 3px;
+  -webkit-border-bottom-right-radius: 3px;
+  -webkit-border-top-right-radius: 3px;
+  border-bottom-right-radius: 3px;
+  border-top-right-radius: 3px; }
+
+.prefix.button.round {
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  -moz-border-radius-bottomleft: 1000px;
+  -moz-border-radius-topleft: 1000px;
+  -webkit-border-bottom-left-radius: 1000px;
+  -webkit-border-top-left-radius: 1000px;
+  border-bottom-left-radius: 1000px;
+  border-top-left-radius: 1000px; }
+
+.postfix.button.round {
+  -webkit-border-radius: 0;
+  border-radius: 0;
+  -moz-border-radius-bottomright: 1000px;
+  -moz-border-radius-topright: 1000px;
+  -webkit-border-bottom-right-radius: 1000px;
+  -webkit-border-top-right-radius: 1000px;
+  border-bottom-right-radius: 1000px;
+  border-top-right-radius: 1000px; }
+
+/* Separate prefix and postfix styles when on span or label so buttons keep their own */
+span.prefix, label.prefix {
+  background: #f2f2f2;
+  border-right: none;
+  color: #333333;
+  border-color: #cccccc; }
+  span.prefix.radius, label.prefix.radius {
+    -webkit-border-radius: 0;
+    border-radius: 0;
+    -moz-border-radius-bottomleft: 3px;
+    -moz-border-radius-topleft: 3px;
+    -webkit-border-bottom-left-radius: 3px;
+    -webkit-border-top-left-radius: 3px;
+    border-bottom-left-radius: 3px;
+    border-top-left-radius: 3px; }
+
+span.postfix, label.postfix {
+  background: #f2f2f2;
+  border-left: none;
+  color: #333333;
+  border-color: #cccccc; }
+  span.postfix.radius, label.postfix.radius {
+    -webkit-border-radius: 0;
+    border-radius: 0;
+    -moz-border-radius-bottomright: 3px;
+    -moz-border-radius-topright: 3px;
+    -webkit-border-bottom-right-radius: 3px;
+    -webkit-border-top-right-radius: 3px;
+    border-bottom-right-radius: 3px;
+    border-top-right-radius: 3px; }
+
+/* We use this to get basic styling on all basic form elements */
+input[type="text"],
+input[type="password"],
+input[type="date"],
+input[type="datetime"],
+input[type="datetime-local"],
+input[type="month"],
+input[type="week"],
+input[type="email"],
+input[type="number"],
+input[type="search"],
+input[type="tel"],
+input[type="time"],
+input[type="url"],
+textarea {
+  -webkit-appearance: none;
+  background-color: white;
+  font-family: inherit;
+  border: 1px solid #cccccc;
+  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
+  color: rgba(0, 0, 0, 0.75);
+  display: block;
+  font-size: 0.875rem;
+  margin: 0 0 1rem 0;
+  padding: 0.5rem;
+  height: 2.3125rem;
+  width: 100%;
+  -moz-box-sizing: border-box;
+  -webkit-box-sizing: border-box;
+  box-sizing: border-box;
+  -webkit-transition: -webkit-box-shadow 0.45s, border-color 0.45s ease-in-out;
+  -moz-transition: -moz-box-shadow 0.45s, border-color 0.45s ease-in-out;
+  transition: box-shadow 0.45s, border-color 0.45s ease-in-out; }
+  input[type="text"]:focus,
+  input[type="password"]:focus,
+  input[type="date"]:focus,
+  input[type="datetime"]:focus,
+  input[type="datetime-local"]:focus,
+  input[type="month"]:focus,
+  input[type="week"]:focus,
+  input[type="email"]:focus,
+  input[type="number"]:focus,
+  input[type="search"]:focus,
+  input[type="tel"]:focus,
+  input[type="time"]:focus,
+  input[type="url"]:focus,
+  textarea:focus {
+    -webkit-box-shadow: 0 0 5px #999999;
+    -moz-box-shadow: 0 0 5px #999999;
+    box-shadow: 0 0 5px #999999;
+    border-color: #999999; }
+  input[type="text"]:focus,
+  input[type="password"]:focus,
+  input[type="date"]:focus,
+  input[type="datetime"]:focus,
+  input[type="datetime-local"]:focus,
+  input[type="month"]:focus,
+  input[type="week"]:focus,
+  input[type="email"]:focus,
+  input[type="number"]:focus,
+  input[type="search"]:focus,
+  input[type="tel"]:focus,
+  input[type="time"]:focus,
+  input[type="url"]:focus,
+  textarea:focus {
+    background: #fafafa;
+    border-color: #999999;
+    outline: none; }
+  input[type="text"][disabled], fieldset[disabled] input[type="text"],
+  input[type="password"][disabled], fieldset[disabled]
+  input[type="password"],
+  input[type="date"][disabled], fieldset[disabled]
+  input[type="date"],
+  input[type="datetime"][disabled], fieldset[disabled]
+  input[type="datetime"],
+  input[type="datetime-local"][disabled], fieldset[disabled]
+  input[type="datetime-local"],
+  input[type="month"][disabled], fieldset[disabled]
+  input[type="month"],
+  input[type="week"][disabled], fieldset[disabled]
+  input[type="week"],
+  input[type="email"][disabled], fieldset[disabled]
+  input[type="email"],
+  input[type="number"][disabled], fieldset[disabled]
+  input[type="number"],
+  input[type="search"][disabled], fieldset[disabled]
+  input[type="search"],
+  input[type="tel"][disabled], fieldset[disabled]
+  input[type="tel"],
+  input[type="time"][disabled], fieldset[disabled]
+  input[type="time"],
+  input[type="url"][disabled], fieldset[disabled]
+  input[type="url"],
+  textarea[disabled], fieldset[disabled]
+  textarea {
+    background-color: #dddddd; }
+  input[type="text"].radius,
+  input[type="password"].radius,
+  input[type="date"].radius,
+  input[type="datetime"].radius,
+  input[type="datetime-local"].radius,
+  input[type="month"].radius,
+  input[type="week"].radius,
+  input[type="email"].radius,
+  input[type="number"].radius,
+  input[type="search"].radius,
+  input[type="tel"].radius,
+  input[type="time"].radius,
+  input[type="url"].radius,
+  textarea.radius {
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+
+/* Respect enforced amount of rows for textarea */
+textarea[rows] {
+  height: auto; }
+
+/* Add height value for select elements to match text input height */
+select {
+  height: 2.3125rem; }
+
+/* Adjust margin for form elements below */
+input[type="file"],
+input[type="checkbox"],
+input[type="radio"],
+select {
+  margin: 0 0 1rem 0; }
+
+input[type="checkbox"] + label,
+input[type="radio"] + label {
+  display: inline-block;
+  margin-left: 0.5rem;
+  margin-right: 1rem;
+  margin-bottom: 0;
+  vertical-align: baseline; }
+
+/* Normalize file input width */
+input[type="file"] {
+  width: 100%; }
+
+/* We add basic fieldset styling */
+fieldset {
+  border: 1px solid #dddddd;
+  padding: 1.25rem;
+  margin: 1.125rem 0; }
+  fieldset legend {
+    font-weight: bold;
+    background: white;
+    padding: 0 0.1875rem;
+    margin: 0;
+    margin-left: -0.1875rem; }
+
+/* Error Handling */
+[data-abide] .error small.error, [data-abide] span.error, [data-abide] small.error {
+  display: block;
+  padding: 0.375rem 0.5625rem 0.5625rem;
+  margin-top: -1px;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: normal;
+  font-style: italic;
+  background: #f04124;
+  color: white; }
+[data-abide] span.error, [data-abide] small.error {
+  display: none; }
+
+span.error, small.error {
+  display: block;
+  padding: 0.375rem 0.5625rem 0.5625rem;
+  margin-top: -1px;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: normal;
+  font-style: italic;
+  background: #f04124;
+  color: white; }
+
+.error input,
+.error textarea,
+.error select {
+  margin-bottom: 0; }
+.error input[type="checkbox"],
+.error input[type="radio"] {
+  margin-bottom: 1rem; }
+.error label,
+.error label.error {
+  color: #f04124; }
+.error small.error {
+  display: block;
+  padding: 0.375rem 0.5625rem 0.5625rem;
+  margin-top: -1px;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: normal;
+  font-style: italic;
+  background: #f04124;
+  color: white; }
+.error > label > small {
+  color: #676767;
+  background: transparent;
+  padding: 0;
+  text-transform: capitalize;
+  font-style: normal;
+  font-size: 60%;
+  margin: 0;
+  display: inline; }
+.error span.error-message {
+  display: block; }
+
+input.error,
+textarea.error {
+  margin-bottom: 0; }
+
+label.error {
+  color: #f04124; }
+
+.range-slider {
+  display: block;
+  position: relative;
+  width: 100%;
+  height: 1rem;
+  border: 1px solid #dddddd;
+  margin: 1.25rem 0;
+  touch-action: none;
+  -ms-touch-action: none;
+  background: #fafafa; }
+  .range-slider.vertical-range {
+    display: block;
+    position: relative;
+    width: 100%;
+    height: 1rem;
+    border: 1px solid #dddddd;
+    margin: 1.25rem 0;
+    touch-action: none;
+    -ms-touch-action: none;
+    display: inline-block;
+    width: 1rem;
+    height: 12.5rem; }
+    .range-slider.vertical-range .range-slider-handle {
+      margin-top: 0;
+      margin-left: -0.5rem;
+      position: absolute;
+      bottom: -10.5rem; }
+    .range-slider.vertical-range .range-slider-active-segment {
+      width: 0.875rem;
+      height: auto;
+      bottom: 0; }
+  .range-slider.radius {
+    background: #fafafa;
+    -webkit-border-radius: 3px;
+    border-radius: 3px; }
+    .range-slider.radius .range-slider-handle {
+      background: #008cba;
+      -webkit-border-radius: 3px;
+      border-radius: 3px; }
+      .range-slider.radius .range-slider-handle:hover {
+        background: #007ba4; }
+  .range-slider.round {
+    background: #fafafa;
+    -webkit-border-radius: 1000px;
+    border-radius: 1000px; }
+    .range-slider.round .range-slider-handle {
+      background: #008cba;
+      -webkit-border-radius: 1000px;
+      border-radius: 1000px; }
+      .range-slider.round .range-slider-handle:hover {
+        background: #007ba4; }
+
+.range-slider-active-segment {
+  display: inline-block;
+  position: absolute;
+  height: 0.875rem;
+  background: #e5e5e5; }
+
+.range-slider-handle {
+  display: inline-block;
+  position: absolute;
+  z-index: 1;
+  top: -0.3125rem;
+  width: 2rem;
+  height: 1.375rem;
+  border: 1px solid none;
+  cursor: pointer;
+  background: #008cba; }
+  .range-slider-handle:hover {
+    background: #007ba4; }
+
+[class*="block-grid-"] {
+  display: block;
+  padding: 0;
+  margin: 0;
+  *zoom: 1; }
+  [class*="block-grid-"]:before, [class*="block-grid-"]:after {
+    content: " ";
+    display: table; }
+  [class*="block-grid-"]:after {
+    clear: both; }
+  [class*="block-grid-"] > li {
+    display: block;
+    height: auto;
+    float: left;
+    padding: 0 0.9375rem 1.875rem; }
+
+@media only screen {
+  .small-block-grid-1 > li {
+    width: 100%;
+    list-style: none; }
+    .small-block-grid-1 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-1 > li:nth-of-type(1n+1) {
+      clear: both; }
+    .small-block-grid-1 > li:nth-child(1n) {
+      padding-left: 0rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-2 > li {
+    width: 50%;
+    list-style: none; }
+    .small-block-grid-2 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-2 > li:nth-of-type(2n+1) {
+      clear: both; }
+    .small-block-grid-2 > li:nth-child(2n+1) {
+      padding-left: 0rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-2 > li:nth-child(2n) {
+      padding-left: 0.9375rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-3 > li {
+    width: 33.33333%;
+    list-style: none; }
+    .small-block-grid-3 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-3 > li:nth-of-type(3n+1) {
+      clear: both; }
+    .small-block-grid-3 > li:nth-child(3n+1) {
+      padding-left: 0rem;
+      padding-right: 1.25rem; }
+    .small-block-grid-3 > li:nth-child(3n+2) {
+      padding-left: 0.625rem;
+      padding-right: 0.625rem; }
+    .small-block-grid-3 > li:nth-child(3n) {
+      padding-left: 1.25rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-4 > li {
+    width: 25%;
+    list-style: none; }
+    .small-block-grid-4 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-4 > li:nth-of-type(4n+1) {
+      clear: both; }
+    .small-block-grid-4 > li:nth-child(4n+1) {
+      padding-left: 0rem;
+      padding-right: 1.40625rem; }
+    .small-block-grid-4 > li:nth-child(4n+2) {
+      padding-left: 0.46875rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-4 > li:nth-child(4n+3) {
+      padding-left: 0.9375rem;
+      padding-right: 0.46875rem; }
+    .small-block-grid-4 > li:nth-child(4n) {
+      padding-left: 1.40625rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-5 > li {
+    width: 20%;
+    list-style: none; }
+    .small-block-grid-5 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-5 > li:nth-of-type(5n+1) {
+      clear: both; }
+    .small-block-grid-5 > li:nth-child(5n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5rem; }
+    .small-block-grid-5 > li:nth-child(5n+2) {
+      padding-left: 0.375rem;
+      padding-right: 1.125rem; }
+    .small-block-grid-5 > li:nth-child(5n+3) {
+      padding-left: 0.75rem;
+      padding-right: 0.75rem; }
+    .small-block-grid-5 > li:nth-child(5n+4) {
+      padding-left: 1.125rem;
+      padding-right: 0.375rem; }
+    .small-block-grid-5 > li:nth-child(5n) {
+      padding-left: 1.5rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-6 > li {
+    width: 16.66667%;
+    list-style: none; }
+    .small-block-grid-6 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-6 > li:nth-of-type(6n+1) {
+      clear: both; }
+    .small-block-grid-6 > li:nth-child(6n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5625rem; }
+    .small-block-grid-6 > li:nth-child(6n+2) {
+      padding-left: 0.3125rem;
+      padding-right: 1.25rem; }
+    .small-block-grid-6 > li:nth-child(6n+3) {
+      padding-left: 0.625rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-6 > li:nth-child(6n+4) {
+      padding-left: 0.9375rem;
+      padding-right: 0.625rem; }
+    .small-block-grid-6 > li:nth-child(6n+5) {
+      padding-left: 1.25rem;
+      padding-right: 0.3125rem; }
+    .small-block-grid-6 > li:nth-child(6n) {
+      padding-left: 1.5625rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-7 > li {
+    width: 14.28571%;
+    list-style: none; }
+    .small-block-grid-7 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-7 > li:nth-of-type(7n+1) {
+      clear: both; }
+    .small-block-grid-7 > li:nth-child(7n+1) {
+      padding-left: 0rem;
+      padding-right: 1.60714rem; }
+    .small-block-grid-7 > li:nth-child(7n+2) {
+      padding-left: 0.26786rem;
+      padding-right: 1.33929rem; }
+    .small-block-grid-7 > li:nth-child(7n+3) {
+      padding-left: 0.53571rem;
+      padding-right: 1.07143rem; }
+    .small-block-grid-7 > li:nth-child(7n+4) {
+      padding-left: 0.80357rem;
+      padding-right: 0.80357rem; }
+    .small-block-grid-7 > li:nth-child(7n+5) {
+      padding-left: 1.07143rem;
+      padding-right: 0.53571rem; }
+    .small-block-grid-7 > li:nth-child(7n+6) {
+      padding-left: 1.33929rem;
+      padding-right: 0.26786rem; }
+    .small-block-grid-7 > li:nth-child(7n) {
+      padding-left: 1.60714rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-8 > li {
+    width: 12.5%;
+    list-style: none; }
+    .small-block-grid-8 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-8 > li:nth-of-type(8n+1) {
+      clear: both; }
+    .small-block-grid-8 > li:nth-child(8n+1) {
+      padding-left: 0rem;
+      padding-right: 1.64063rem; }
+    .small-block-grid-8 > li:nth-child(8n+2) {
+      padding-left: 0.23438rem;
+      padding-right: 1.40625rem; }
+    .small-block-grid-8 > li:nth-child(8n+3) {
+      padding-left: 0.46875rem;
+      padding-right: 1.17188rem; }
+    .small-block-grid-8 > li:nth-child(8n+4) {
+      padding-left: 0.70313rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-8 > li:nth-child(8n+5) {
+      padding-left: 0.9375rem;
+      padding-right: 0.70313rem; }
+    .small-block-grid-8 > li:nth-child(8n+6) {
+      padding-left: 1.17188rem;
+      padding-right: 0.46875rem; }
+    .small-block-grid-8 > li:nth-child(8n+7) {
+      padding-left: 1.40625rem;
+      padding-right: 0.23438rem; }
+    .small-block-grid-8 > li:nth-child(8n) {
+      padding-left: 1.64063rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-9 > li {
+    width: 11.11111%;
+    list-style: none; }
+    .small-block-grid-9 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-9 > li:nth-of-type(9n+1) {
+      clear: both; }
+    .small-block-grid-9 > li:nth-child(9n+1) {
+      padding-left: 0rem;
+      padding-right: 1.66667rem; }
+    .small-block-grid-9 > li:nth-child(9n+2) {
+      padding-left: 0.20833rem;
+      padding-right: 1.45833rem; }
+    .small-block-grid-9 > li:nth-child(9n+3) {
+      padding-left: 0.41667rem;
+      padding-right: 1.25rem; }
+    .small-block-grid-9 > li:nth-child(9n+4) {
+      padding-left: 0.625rem;
+      padding-right: 1.04167rem; }
+    .small-block-grid-9 > li:nth-child(9n+5) {
+      padding-left: 0.83333rem;
+      padding-right: 0.83333rem; }
+    .small-block-grid-9 > li:nth-child(9n+6) {
+      padding-left: 1.04167rem;
+      padding-right: 0.625rem; }
+    .small-block-grid-9 > li:nth-child(9n+7) {
+      padding-left: 1.25rem;
+      padding-right: 0.41667rem; }
+    .small-block-grid-9 > li:nth-child(9n+8) {
+      padding-left: 1.45833rem;
+      padding-right: 0.20833rem; }
+    .small-block-grid-9 > li:nth-child(9n) {
+      padding-left: 1.66667rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-10 > li {
+    width: 10%;
+    list-style: none; }
+    .small-block-grid-10 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-10 > li:nth-of-type(10n+1) {
+      clear: both; }
+    .small-block-grid-10 > li:nth-child(10n+1) {
+      padding-left: 0rem;
+      padding-right: 1.6875rem; }
+    .small-block-grid-10 > li:nth-child(10n+2) {
+      padding-left: 0.1875rem;
+      padding-right: 1.5rem; }
+    .small-block-grid-10 > li:nth-child(10n+3) {
+      padding-left: 0.375rem;
+      padding-right: 1.3125rem; }
+    .small-block-grid-10 > li:nth-child(10n+4) {
+      padding-left: 0.5625rem;
+      padding-right: 1.125rem; }
+    .small-block-grid-10 > li:nth-child(10n+5) {
+      padding-left: 0.75rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-10 > li:nth-child(10n+6) {
+      padding-left: 0.9375rem;
+      padding-right: 0.75rem; }
+    .small-block-grid-10 > li:nth-child(10n+7) {
+      padding-left: 1.125rem;
+      padding-right: 0.5625rem; }
+    .small-block-grid-10 > li:nth-child(10n+8) {
+      padding-left: 1.3125rem;
+      padding-right: 0.375rem; }
+    .small-block-grid-10 > li:nth-child(10n+9) {
+      padding-left: 1.5rem;
+      padding-right: 0.1875rem; }
+    .small-block-grid-10 > li:nth-child(10n) {
+      padding-left: 1.6875rem;
+      padding-right: 0rem; }
+
+  .small-block-grid-11 > li {
+    width: 9.09091%;
+    list-style: none; }
+    .small-block-grid-11 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-11 > li:nth-of-type(11n+1) {
+      clear: both; }
+    .small-block-grid-11 > li:nth-child(11n+1) {
+      padding-left: 0.0rem;
+      padding-right: 1.70455rem; }
+    .small-block-grid-11 > li:nth-child(11n+2) {
+      padding-left: 0.17045rem;
+      padding-right: 1.53409rem; }
+    .small-block-grid-11 > li:nth-child(11n+3) {
+      padding-left: 0.34091rem;
+      padding-right: 1.36364rem; }
+    .small-block-grid-11 > li:nth-child(11n+4) {
+      padding-left: 0.51136rem;
+      padding-right: 1.19318rem; }
+    .small-block-grid-11 > li:nth-child(11n+5) {
+      padding-left: 0.68182rem;
+      padding-right: 1.02273rem; }
+    .small-block-grid-11 > li:nth-child(11n+6) {
+      padding-left: 0.85227rem;
+      padding-right: 0.85227rem; }
+    .small-block-grid-11 > li:nth-child(11n+7) {
+      padding-left: 1.02273rem;
+      padding-right: 0.68182rem; }
+    .small-block-grid-11 > li:nth-child(11n+8) {
+      padding-left: 1.19318rem;
+      padding-right: 0.51136rem; }
+    .small-block-grid-11 > li:nth-child(11n+9) {
+      padding-left: 1.36364rem;
+      padding-right: 0.34091rem; }
+    .small-block-grid-11 > li:nth-child(11n+10) {
+      padding-left: 1.53409rem;
+      padding-right: 0.17045rem; }
+    .small-block-grid-11 > li:nth-child(11n) {
+      padding-left: 1.70455rem;
+      padding-right: 0.0rem; }
+
+  .small-block-grid-12 > li {
+    width: 8.33333%;
+    list-style: none; }
+    .small-block-grid-12 > li:nth-of-type(n) {
+      clear: none; }
+    .small-block-grid-12 > li:nth-of-type(12n+1) {
+      clear: both; }
+    .small-block-grid-12 > li:nth-child(12n+1) {
+      padding-left: 0rem;
+      padding-right: 1.71875rem; }
+    .small-block-grid-12 > li:nth-child(12n+2) {
+      padding-left: 0.15625rem;
+      padding-right: 1.5625rem; }
+    .small-block-grid-12 > li:nth-child(12n+3) {
+      padding-left: 0.3125rem;
+      padding-right: 1.40625rem; }
+    .small-block-grid-12 > li:nth-child(12n+4) {
+      padding-left: 0.46875rem;
+      padding-right: 1.25rem; }
+    .small-block-grid-12 > li:nth-child(12n+5) {
+      padding-left: 0.625rem;
+      padding-right: 1.09375rem; }
+    .small-block-grid-12 > li:nth-child(12n+6) {
+      padding-left: 0.78125rem;
+      padding-right: 0.9375rem; }
+    .small-block-grid-12 > li:nth-child(12n+7) {
+      padding-left: 0.9375rem;
+      padding-right: 0.78125rem; }
+    .small-block-grid-12 > li:nth-child(12n+8) {
+      padding-left: 1.09375rem;
+      padding-right: 0.625rem; }
+    .small-block-grid-12 > li:nth-child(12n+9) {
+      padding-left: 1.25rem;
+      padding-right: 0.46875rem; }
+    .small-block-grid-12 > li:nth-child(12n+10) {
+      padding-left: 1.40625rem;
+      padding-right: 0.3125rem; }
+    .small-block-grid-12 > li:nth-child(12n+11) {
+      padding-left: 1.5625rem;
+      padding-right: 0.15625rem; }
+    .small-block-grid-12 > li:nth-child(12n) {
+      padding-left: 1.71875rem;
+      padding-right: 0rem; } }
+@media only screen and (min-width: 40.063em) {
+  .medium-block-grid-1 > li {
+    width: 100%;
+    list-style: none; }
+    .medium-block-grid-1 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-1 > li:nth-of-type(1n+1) {
+      clear: both; }
+    .medium-block-grid-1 > li:nth-child(1n) {
+      padding-left: 0rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-2 > li {
+    width: 50%;
+    list-style: none; }
+    .medium-block-grid-2 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-2 > li:nth-of-type(2n+1) {
+      clear: both; }
+    .medium-block-grid-2 > li:nth-child(2n+1) {
+      padding-left: 0rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-2 > li:nth-child(2n) {
+      padding-left: 0.9375rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-3 > li {
+    width: 33.33333%;
+    list-style: none; }
+    .medium-block-grid-3 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-3 > li:nth-of-type(3n+1) {
+      clear: both; }
+    .medium-block-grid-3 > li:nth-child(3n+1) {
+      padding-left: 0rem;
+      padding-right: 1.25rem; }
+    .medium-block-grid-3 > li:nth-child(3n+2) {
+      padding-left: 0.625rem;
+      padding-right: 0.625rem; }
+    .medium-block-grid-3 > li:nth-child(3n) {
+      padding-left: 1.25rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-4 > li {
+    width: 25%;
+    list-style: none; }
+    .medium-block-grid-4 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-4 > li:nth-of-type(4n+1) {
+      clear: both; }
+    .medium-block-grid-4 > li:nth-child(4n+1) {
+      padding-left: 0rem;
+      padding-right: 1.40625rem; }
+    .medium-block-grid-4 > li:nth-child(4n+2) {
+      padding-left: 0.46875rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-4 > li:nth-child(4n+3) {
+      padding-left: 0.9375rem;
+      padding-right: 0.46875rem; }
+    .medium-block-grid-4 > li:nth-child(4n) {
+      padding-left: 1.40625rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-5 > li {
+    width: 20%;
+    list-style: none; }
+    .medium-block-grid-5 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-5 > li:nth-of-type(5n+1) {
+      clear: both; }
+    .medium-block-grid-5 > li:nth-child(5n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5rem; }
+    .medium-block-grid-5 > li:nth-child(5n+2) {
+      padding-left: 0.375rem;
+      padding-right: 1.125rem; }
+    .medium-block-grid-5 > li:nth-child(5n+3) {
+      padding-left: 0.75rem;
+      padding-right: 0.75rem; }
+    .medium-block-grid-5 > li:nth-child(5n+4) {
+      padding-left: 1.125rem;
+      padding-right: 0.375rem; }
+    .medium-block-grid-5 > li:nth-child(5n) {
+      padding-left: 1.5rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-6 > li {
+    width: 16.66667%;
+    list-style: none; }
+    .medium-block-grid-6 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-6 > li:nth-of-type(6n+1) {
+      clear: both; }
+    .medium-block-grid-6 > li:nth-child(6n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5625rem; }
+    .medium-block-grid-6 > li:nth-child(6n+2) {
+      padding-left: 0.3125rem;
+      padding-right: 1.25rem; }
+    .medium-block-grid-6 > li:nth-child(6n+3) {
+      padding-left: 0.625rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-6 > li:nth-child(6n+4) {
+      padding-left: 0.9375rem;
+      padding-right: 0.625rem; }
+    .medium-block-grid-6 > li:nth-child(6n+5) {
+      padding-left: 1.25rem;
+      padding-right: 0.3125rem; }
+    .medium-block-grid-6 > li:nth-child(6n) {
+      padding-left: 1.5625rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-7 > li {
+    width: 14.28571%;
+    list-style: none; }
+    .medium-block-grid-7 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-7 > li:nth-of-type(7n+1) {
+      clear: both; }
+    .medium-block-grid-7 > li:nth-child(7n+1) {
+      padding-left: 0rem;
+      padding-right: 1.60714rem; }
+    .medium-block-grid-7 > li:nth-child(7n+2) {
+      padding-left: 0.26786rem;
+      padding-right: 1.33929rem; }
+    .medium-block-grid-7 > li:nth-child(7n+3) {
+      padding-left: 0.53571rem;
+      padding-right: 1.07143rem; }
+    .medium-block-grid-7 > li:nth-child(7n+4) {
+      padding-left: 0.80357rem;
+      padding-right: 0.80357rem; }
+    .medium-block-grid-7 > li:nth-child(7n+5) {
+      padding-left: 1.07143rem;
+      padding-right: 0.53571rem; }
+    .medium-block-grid-7 > li:nth-child(7n+6) {
+      padding-left: 1.33929rem;
+      padding-right: 0.26786rem; }
+    .medium-block-grid-7 > li:nth-child(7n) {
+      padding-left: 1.60714rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-8 > li {
+    width: 12.5%;
+    list-style: none; }
+    .medium-block-grid-8 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-8 > li:nth-of-type(8n+1) {
+      clear: both; }
+    .medium-block-grid-8 > li:nth-child(8n+1) {
+      padding-left: 0rem;
+      padding-right: 1.64063rem; }
+    .medium-block-grid-8 > li:nth-child(8n+2) {
+      padding-left: 0.23438rem;
+      padding-right: 1.40625rem; }
+    .medium-block-grid-8 > li:nth-child(8n+3) {
+      padding-left: 0.46875rem;
+      padding-right: 1.17188rem; }
+    .medium-block-grid-8 > li:nth-child(8n+4) {
+      padding-left: 0.70313rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-8 > li:nth-child(8n+5) {
+      padding-left: 0.9375rem;
+      padding-right: 0.70313rem; }
+    .medium-block-grid-8 > li:nth-child(8n+6) {
+      padding-left: 1.17188rem;
+      padding-right: 0.46875rem; }
+    .medium-block-grid-8 > li:nth-child(8n+7) {
+      padding-left: 1.40625rem;
+      padding-right: 0.23438rem; }
+    .medium-block-grid-8 > li:nth-child(8n) {
+      padding-left: 1.64063rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-9 > li {
+    width: 11.11111%;
+    list-style: none; }
+    .medium-block-grid-9 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-9 > li:nth-of-type(9n+1) {
+      clear: both; }
+    .medium-block-grid-9 > li:nth-child(9n+1) {
+      padding-left: 0rem;
+      padding-right: 1.66667rem; }
+    .medium-block-grid-9 > li:nth-child(9n+2) {
+      padding-left: 0.20833rem;
+      padding-right: 1.45833rem; }
+    .medium-block-grid-9 > li:nth-child(9n+3) {
+      padding-left: 0.41667rem;
+      padding-right: 1.25rem; }
+    .medium-block-grid-9 > li:nth-child(9n+4) {
+      padding-left: 0.625rem;
+      padding-right: 1.04167rem; }
+    .medium-block-grid-9 > li:nth-child(9n+5) {
+      padding-left: 0.83333rem;
+      padding-right: 0.83333rem; }
+    .medium-block-grid-9 > li:nth-child(9n+6) {
+      padding-left: 1.04167rem;
+      padding-right: 0.625rem; }
+    .medium-block-grid-9 > li:nth-child(9n+7) {
+      padding-left: 1.25rem;
+      padding-right: 0.41667rem; }
+    .medium-block-grid-9 > li:nth-child(9n+8) {
+      padding-left: 1.45833rem;
+      padding-right: 0.20833rem; }
+    .medium-block-grid-9 > li:nth-child(9n) {
+      padding-left: 1.66667rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-10 > li {
+    width: 10%;
+    list-style: none; }
+    .medium-block-grid-10 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-10 > li:nth-of-type(10n+1) {
+      clear: both; }
+    .medium-block-grid-10 > li:nth-child(10n+1) {
+      padding-left: 0rem;
+      padding-right: 1.6875rem; }
+    .medium-block-grid-10 > li:nth-child(10n+2) {
+      padding-left: 0.1875rem;
+      padding-right: 1.5rem; }
+    .medium-block-grid-10 > li:nth-child(10n+3) {
+      padding-left: 0.375rem;
+      padding-right: 1.3125rem; }
+    .medium-block-grid-10 > li:nth-child(10n+4) {
+      padding-left: 0.5625rem;
+      padding-right: 1.125rem; }
+    .medium-block-grid-10 > li:nth-child(10n+5) {
+      padding-left: 0.75rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-10 > li:nth-child(10n+6) {
+      padding-left: 0.9375rem;
+      padding-right: 0.75rem; }
+    .medium-block-grid-10 > li:nth-child(10n+7) {
+      padding-left: 1.125rem;
+      padding-right: 0.5625rem; }
+    .medium-block-grid-10 > li:nth-child(10n+8) {
+      padding-left: 1.3125rem;
+      padding-right: 0.375rem; }
+    .medium-block-grid-10 > li:nth-child(10n+9) {
+      padding-left: 1.5rem;
+      padding-right: 0.1875rem; }
+    .medium-block-grid-10 > li:nth-child(10n) {
+      padding-left: 1.6875rem;
+      padding-right: 0rem; }
+
+  .medium-block-grid-11 > li {
+    width: 9.09091%;
+    list-style: none; }
+    .medium-block-grid-11 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-11 > li:nth-of-type(11n+1) {
+      clear: both; }
+    .medium-block-grid-11 > li:nth-child(11n+1) {
+      padding-left: 0.0rem;
+      padding-right: 1.70455rem; }
+    .medium-block-grid-11 > li:nth-child(11n+2) {
+      padding-left: 0.17045rem;
+      padding-right: 1.53409rem; }
+    .medium-block-grid-11 > li:nth-child(11n+3) {
+      padding-left: 0.34091rem;
+      padding-right: 1.36364rem; }
+    .medium-block-grid-11 > li:nth-child(11n+4) {
+      padding-left: 0.51136rem;
+      padding-right: 1.19318rem; }
+    .medium-block-grid-11 > li:nth-child(11n+5) {
+      padding-left: 0.68182rem;
+      padding-right: 1.02273rem; }
+    .medium-block-grid-11 > li:nth-child(11n+6) {
+      padding-left: 0.85227rem;
+      padding-right: 0.85227rem; }
+    .medium-block-grid-11 > li:nth-child(11n+7) {
+      padding-left: 1.02273rem;
+      padding-right: 0.68182rem; }
+    .medium-block-grid-11 > li:nth-child(11n+8) {
+      padding-left: 1.19318rem;
+      padding-right: 0.51136rem; }
+    .medium-block-grid-11 > li:nth-child(11n+9) {
+      padding-left: 1.36364rem;
+      padding-right: 0.34091rem; }
+    .medium-block-grid-11 > li:nth-child(11n+10) {
+      padding-left: 1.53409rem;
+      padding-right: 0.17045rem; }
+    .medium-block-grid-11 > li:nth-child(11n) {
+      padding-left: 1.70455rem;
+      padding-right: 0.0rem; }
+
+  .medium-block-grid-12 > li {
+    width: 8.33333%;
+    list-style: none; }
+    .medium-block-grid-12 > li:nth-of-type(n) {
+      clear: none; }
+    .medium-block-grid-12 > li:nth-of-type(12n+1) {
+      clear: both; }
+    .medium-block-grid-12 > li:nth-child(12n+1) {
+      padding-left: 0rem;
+      padding-right: 1.71875rem; }
+    .medium-block-grid-12 > li:nth-child(12n+2) {
+      padding-left: 0.15625rem;
+      padding-right: 1.5625rem; }
+    .medium-block-grid-12 > li:nth-child(12n+3) {
+      padding-left: 0.3125rem;
+      padding-right: 1.40625rem; }
+    .medium-block-grid-12 > li:nth-child(12n+4) {
+      padding-left: 0.46875rem;
+      padding-right: 1.25rem; }
+    .medium-block-grid-12 > li:nth-child(12n+5) {
+      padding-left: 0.625rem;
+      padding-right: 1.09375rem; }
+    .medium-block-grid-12 > li:nth-child(12n+6) {
+      padding-left: 0.78125rem;
+      padding-right: 0.9375rem; }
+    .medium-block-grid-12 > li:nth-child(12n+7) {
+      padding-left: 0.9375rem;
+      padding-right: 0.78125rem; }
+    .medium-block-grid-12 > li:nth-child(12n+8) {
+      padding-left: 1.09375rem;
+      padding-right: 0.625rem; }
+    .medium-block-grid-12 > li:nth-child(12n+9) {
+      padding-left: 1.25rem;
+      padding-right: 0.46875rem; }
+    .medium-block-grid-12 > li:nth-child(12n+10) {
+      padding-left: 1.40625rem;
+      padding-right: 0.3125rem; }
+    .medium-block-grid-12 > li:nth-child(12n+11) {
+      padding-left: 1.5625rem;
+      padding-right: 0.15625rem; }
+    .medium-block-grid-12 > li:nth-child(12n) {
+      padding-left: 1.71875rem;
+      padding-right: 0rem; } }
+@media only screen and (min-width: 64.063em) {
+  .large-block-grid-1 > li {
+    width: 100%;
+    list-style: none; }
+    .large-block-grid-1 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-1 > li:nth-of-type(1n+1) {
+      clear: both; }
+    .large-block-grid-1 > li:nth-child(1n) {
+      padding-left: 0rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-2 > li {
+    width: 50%;
+    list-style: none; }
+    .large-block-grid-2 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-2 > li:nth-of-type(2n+1) {
+      clear: both; }
+    .large-block-grid-2 > li:nth-child(2n+1) {
+      padding-left: 0rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-2 > li:nth-child(2n) {
+      padding-left: 0.9375rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-3 > li {
+    width: 33.33333%;
+    list-style: none; }
+    .large-block-grid-3 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-3 > li:nth-of-type(3n+1) {
+      clear: both; }
+    .large-block-grid-3 > li:nth-child(3n+1) {
+      padding-left: 0rem;
+      padding-right: 1.25rem; }
+    .large-block-grid-3 > li:nth-child(3n+2) {
+      padding-left: 0.625rem;
+      padding-right: 0.625rem; }
+    .large-block-grid-3 > li:nth-child(3n) {
+      padding-left: 1.25rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-4 > li {
+    width: 25%;
+    list-style: none; }
+    .large-block-grid-4 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-4 > li:nth-of-type(4n+1) {
+      clear: both; }
+    .large-block-grid-4 > li:nth-child(4n+1) {
+      padding-left: 0rem;
+      padding-right: 1.40625rem; }
+    .large-block-grid-4 > li:nth-child(4n+2) {
+      padding-left: 0.46875rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-4 > li:nth-child(4n+3) {
+      padding-left: 0.9375rem;
+      padding-right: 0.46875rem; }
+    .large-block-grid-4 > li:nth-child(4n) {
+      padding-left: 1.40625rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-5 > li {
+    width: 20%;
+    list-style: none; }
+    .large-block-grid-5 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-5 > li:nth-of-type(5n+1) {
+      clear: both; }
+    .large-block-grid-5 > li:nth-child(5n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5rem; }
+    .large-block-grid-5 > li:nth-child(5n+2) {
+      padding-left: 0.375rem;
+      padding-right: 1.125rem; }
+    .large-block-grid-5 > li:nth-child(5n+3) {
+      padding-left: 0.75rem;
+      padding-right: 0.75rem; }
+    .large-block-grid-5 > li:nth-child(5n+4) {
+      padding-left: 1.125rem;
+      padding-right: 0.375rem; }
+    .large-block-grid-5 > li:nth-child(5n) {
+      padding-left: 1.5rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-6 > li {
+    width: 16.66667%;
+    list-style: none; }
+    .large-block-grid-6 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-6 > li:nth-of-type(6n+1) {
+      clear: both; }
+    .large-block-grid-6 > li:nth-child(6n+1) {
+      padding-left: 0rem;
+      padding-right: 1.5625rem; }
+    .large-block-grid-6 > li:nth-child(6n+2) {
+      padding-left: 0.3125rem;
+      padding-right: 1.25rem; }
+    .large-block-grid-6 > li:nth-child(6n+3) {
+      padding-left: 0.625rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-6 > li:nth-child(6n+4) {
+      padding-left: 0.9375rem;
+      padding-right: 0.625rem; }
+    .large-block-grid-6 > li:nth-child(6n+5) {
+      padding-left: 1.25rem;
+      padding-right: 0.3125rem; }
+    .large-block-grid-6 > li:nth-child(6n) {
+      padding-left: 1.5625rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-7 > li {
+    width: 14.28571%;
+    list-style: none; }
+    .large-block-grid-7 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-7 > li:nth-of-type(7n+1) {
+      clear: both; }
+    .large-block-grid-7 > li:nth-child(7n+1) {
+      padding-left: 0rem;
+      padding-right: 1.60714rem; }
+    .large-block-grid-7 > li:nth-child(7n+2) {
+      padding-left: 0.26786rem;
+      padding-right: 1.33929rem; }
+    .large-block-grid-7 > li:nth-child(7n+3) {
+      padding-left: 0.53571rem;
+      padding-right: 1.07143rem; }
+    .large-block-grid-7 > li:nth-child(7n+4) {
+      padding-left: 0.80357rem;
+      padding-right: 0.80357rem; }
+    .large-block-grid-7 > li:nth-child(7n+5) {
+      padding-left: 1.07143rem;
+      padding-right: 0.53571rem; }
+    .large-block-grid-7 > li:nth-child(7n+6) {
+      padding-left: 1.33929rem;
+      padding-right: 0.26786rem; }
+    .large-block-grid-7 > li:nth-child(7n) {
+      padding-left: 1.60714rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-8 > li {
+    width: 12.5%;
+    list-style: none; }
+    .large-block-grid-8 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-8 > li:nth-of-type(8n+1) {
+      clear: both; }
+    .large-block-grid-8 > li:nth-child(8n+1) {
+      padding-left: 0rem;
+      padding-right: 1.64063rem; }
+    .large-block-grid-8 > li:nth-child(8n+2) {
+      padding-left: 0.23438rem;
+      padding-right: 1.40625rem; }
+    .large-block-grid-8 > li:nth-child(8n+3) {
+      padding-left: 0.46875rem;
+      padding-right: 1.17188rem; }
+    .large-block-grid-8 > li:nth-child(8n+4) {
+      padding-left: 0.70313rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-8 > li:nth-child(8n+5) {
+      padding-left: 0.9375rem;
+      padding-right: 0.70313rem; }
+    .large-block-grid-8 > li:nth-child(8n+6) {
+      padding-left: 1.17188rem;
+      padding-right: 0.46875rem; }
+    .large-block-grid-8 > li:nth-child(8n+7) {
+      padding-left: 1.40625rem;
+      padding-right: 0.23438rem; }
+    .large-block-grid-8 > li:nth-child(8n) {
+      padding-left: 1.64063rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-9 > li {
+    width: 11.11111%;
+    list-style: none; }
+    .large-block-grid-9 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-9 > li:nth-of-type(9n+1) {
+      clear: both; }
+    .large-block-grid-9 > li:nth-child(9n+1) {
+      padding-left: 0rem;
+      padding-right: 1.66667rem; }
+    .large-block-grid-9 > li:nth-child(9n+2) {
+      padding-left: 0.20833rem;
+      padding-right: 1.45833rem; }
+    .large-block-grid-9 > li:nth-child(9n+3) {
+      padding-left: 0.41667rem;
+      padding-right: 1.25rem; }
+    .large-block-grid-9 > li:nth-child(9n+4) {
+      padding-left: 0.625rem;
+      padding-right: 1.04167rem; }
+    .large-block-grid-9 > li:nth-child(9n+5) {
+      padding-left: 0.83333rem;
+      padding-right: 0.83333rem; }
+    .large-block-grid-9 > li:nth-child(9n+6) {
+      padding-left: 1.04167rem;
+      padding-right: 0.625rem; }
+    .large-block-grid-9 > li:nth-child(9n+7) {
+      padding-left: 1.25rem;
+      padding-right: 0.41667rem; }
+    .large-block-grid-9 > li:nth-child(9n+8) {
+      padding-left: 1.45833rem;
+      padding-right: 0.20833rem; }
+    .large-block-grid-9 > li:nth-child(9n) {
+      padding-left: 1.66667rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-10 > li {
+    width: 10%;
+    list-style: none; }
+    .large-block-grid-10 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-10 > li:nth-of-type(10n+1) {
+      clear: both; }
+    .large-block-grid-10 > li:nth-child(10n+1) {
+      padding-left: 0rem;
+      padding-right: 1.6875rem; }
+    .large-block-grid-10 > li:nth-child(10n+2) {
+      padding-left: 0.1875rem;
+      padding-right: 1.5rem; }
+    .large-block-grid-10 > li:nth-child(10n+3) {
+      padding-left: 0.375rem;
+      padding-right: 1.3125rem; }
+    .large-block-grid-10 > li:nth-child(10n+4) {
+      padding-left: 0.5625rem;
+      padding-right: 1.125rem; }
+    .large-block-grid-10 > li:nth-child(10n+5) {
+      padding-left: 0.75rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-10 > li:nth-child(10n+6) {
+      padding-left: 0.9375rem;
+      padding-right: 0.75rem; }
+    .large-block-grid-10 > li:nth-child(10n+7) {
+      padding-left: 1.125rem;
+      padding-right: 0.5625rem; }
+    .large-block-grid-10 > li:nth-child(10n+8) {
+      padding-left: 1.3125rem;
+      padding-right: 0.375rem; }
+    .large-block-grid-10 > li:nth-child(10n+9) {
+      padding-left: 1.5rem;
+      padding-right: 0.1875rem; }
+    .large-block-grid-10 > li:nth-child(10n) {
+      padding-left: 1.6875rem;
+      padding-right: 0rem; }
+
+  .large-block-grid-11 > li {
+    width: 9.09091%;
+    list-style: none; }
+    .large-block-grid-11 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-11 > li:nth-of-type(11n+1) {
+      clear: both; }
+    .large-block-grid-11 > li:nth-child(11n+1) {
+      padding-left: 0.0rem;
+      padding-right: 1.70455rem; }
+    .large-block-grid-11 > li:nth-child(11n+2) {
+      padding-left: 0.17045rem;
+      padding-right: 1.53409rem; }
+    .large-block-grid-11 > li:nth-child(11n+3) {
+      padding-left: 0.34091rem;
+      padding-right: 1.36364rem; }
+    .large-block-grid-11 > li:nth-child(11n+4) {
+      padding-left: 0.51136rem;
+      padding-right: 1.19318rem; }
+    .large-block-grid-11 > li:nth-child(11n+5) {
+      padding-left: 0.68182rem;
+      padding-right: 1.02273rem; }
+    .large-block-grid-11 > li:nth-child(11n+6) {
+      padding-left: 0.85227rem;
+      padding-right: 0.85227rem; }
+    .large-block-grid-11 > li:nth-child(11n+7) {
+      padding-left: 1.02273rem;
+      padding-right: 0.68182rem; }
+    .large-block-grid-11 > li:nth-child(11n+8) {
+      padding-left: 1.19318rem;
+      padding-right: 0.51136rem; }
+    .large-block-grid-11 > li:nth-child(11n+9) {
+      padding-left: 1.36364rem;
+      padding-right: 0.34091rem; }
+    .large-block-grid-11 > li:nth-child(11n+10) {
+      padding-left: 1.53409rem;
+      padding-right: 0.17045rem; }
+    .large-block-grid-11 > li:nth-child(11n) {
+      padding-left: 1.70455rem;
+      padding-right: 0.0rem; }
+
+  .large-block-grid-12 > li {
+    width: 8.33333%;
+    list-style: none; }
+    .large-block-grid-12 > li:nth-of-type(n) {
+      clear: none; }
+    .large-block-grid-12 > li:nth-of-type(12n+1) {
+      clear: both; }
+    .large-block-grid-12 > li:nth-child(12n+1) {
+      padding-left: 0rem;
+      padding-right: 1.71875rem; }
+    .large-block-grid-12 > li:nth-child(12n+2) {
+      padding-left: 0.15625rem;
+      padding-right: 1.5625rem; }
+    .large-block-grid-12 > li:nth-child(12n+3) {
+      padding-left: 0.3125rem;
+      padding-right: 1.40625rem; }
+    .large-block-grid-12 > li:nth-child(12n+4) {
+      padding-left: 0.46875rem;
+      padding-right: 1.25rem; }
+    .large-block-grid-12 > li:nth-child(12n+5) {
+      padding-left: 0.625rem;
+      padding-right: 1.09375rem; }
+    .large-block-grid-12 > li:nth-child(12n+6) {
+      padding-left: 0.78125rem;
+      padding-right: 0.9375rem; }
+    .large-block-grid-12 > li:nth-child(12n+7) {
+      padding-left: 0.9375rem;
+      padding-right: 0.78125rem; }
+    .large-block-grid-12 > li:nth-child(12n+8) {
+      padding-left: 1.09375rem;
+      padding-right: 0.625rem; }
+    .large-block-grid-12 > li:nth-child(12n+9) {
+      padding-left: 1.25rem;
+      padding-right: 0.46875rem; }
+    .large-block-grid-12 > li:nth-child(12n+10) {
+      padding-left: 1.40625rem;
+      padding-right: 0.3125rem; }
+    .large-block-grid-12 > li:nth-child(12n+11) {
+      padding-left: 1.5625rem;
+      padding-right: 0.15625rem; }
+    .large-block-grid-12 > li:nth-child(12n) {
+      padding-left: 1.71875rem;
+      padding-right: 0rem; } }
+.flex-video {
+  position: relative;
+  padding-top: 1.5625rem;
+  padding-bottom: 67.5%;
+  height: 0;
+  margin-bottom: 1rem;
+  overflow: hidden; }
+  .flex-video.widescreen {
+    padding-bottom: 56.34%; }
+  .flex-video.vimeo {
+    padding-top: 0; }
+  .flex-video iframe,
+  .flex-video object,
+  .flex-video embed,
+  .flex-video video {
+    position: absolute;
+    top: 0;
+    left: 0;
+    width: 100%;
+    height: 100%; }
+
+.keystroke,
+kbd {
+  background-color: #ededed;
+  border-color: #dddddd;
+  color: #222222;
+  border-style: solid;
+  border-width: 1px;
+  margin: 0;
+  font-family: "Consolas", "Menlo", "Courier", monospace;
+  font-size: inherit;
+  padding: 0.125rem 0.25rem 0;
+  -webkit-border-radius: 3px;
+  border-radius: 3px; }
+
+/* small displays */
+@media only screen {
+  .show-for-small-only, .show-for-small-up, .show-for-small, .show-for-small-down, .hide-for-medium-only, .hide-for-medium-up, .hide-for-medium, .show-for-medium-down, .hide-for-large-only, .hide-for-large-up, .hide-for-large, .show-for-large-down, .hide-for-xlarge-only, .hide-for-xlarge-up, .hide-for-xlarge, .show-for-xlarge-down, .hide-for-xxlarge-only, .hide-for-xxlarge-up, .hide-for-xxlarge, .show-for-xxlarge-down {
+    display: inherit !important; }
+
+  .hide-for-small-only, .hide-for-small-up, .hide-for-small, .hide-for-small-down, .show-for-medium-only, .show-for-medium-up, .show-for-medium, .hide-for-medium-down, .show-for-large-only, .show-for-large-up, .show-for-large, .hide-for-large-down, .show-for-xlarge-only, .show-for-xlarge-up, .show-for-xlarge, .hide-for-xlarge-down, .show-for-xxlarge-only, .show-for-xxlarge-up, .show-for-xxlarge, .hide-for-xxlarge-down {
+    display: none !important; }
+
+  table.show-for-small-only, table.show-for-small-up, table.show-for-small, table.show-for-small-down, table.hide-for-medium-only, table.hide-for-medium-up, table.hide-for-medium, table.show-for-medium-down, table.hide-for-large-only, table.hide-for-large-up, table.hide-for-large, table.show-for-large-down, table.hide-for-xlarge-only, table.hide-for-xlarge-up, table.hide-for-xlarge, table.show-for-xlarge-down, table.hide-for-xxlarge-only, table.hide-for-xxlarge-up, table.hide-for-xxlarge, table.show-for-xxlarge-down {
+    display: table; }
+
+  thead.show-for-small-only, thead.show-for-small-up, thead.show-for-small, thead.show-for-small-down, thead.hide-for-medium-only, thead.hide-for-medium-up, thead.hide-for-medium, thead.show-for-medium-down, thead.hide-for-large-only, thead.hide-for-large-up, thead.hide-for-large, thead.show-for-large-down, thead.hide-for-xlarge-only, thead.hide-for-xlarge-up, thead.hide-for-xlarge, thead.show-for-xlarge-down, thead.hide-for-xxlarge-only, thead.hide-for-xxlarge-up, thead.hide-for-xxlarge, thead.show-for-xxlarge-down {
+    display: table-header-group !important; }
+
+  tbody.show-for-small-only, tbody.show-for-small-up, tbody.show-for-small, tbody.show-for-small-down, tbody.hide-for-medium-only, tbody.hide-for-medium-up, tbody.hide-for-medium, tbody.show-for-medium-down, tbody.hide-for-large-only, tbody.hide-for-large-up, tbody.hide-for-large, tbody.show-for-large-down, tbody.hide-for-xlarge-only, tbody.hide-for-xlarge-up, tbody.hide-for-xlarge, tbody.show-for-xlarge-down, tbody.hide-for-xxlarge-only, tbody.hide-for-xxlarge-up, tbody.hide-for-xxlarge, tbody.show-for-xxlarge-down {
+    display: table-row-group !important; }
+
+  tr.show-for-small-only, tr.show-for-small-up, tr.show-for-small, tr.show-for-small-down, tr.hide-for-medium-only, tr.hide-for-medium-up, tr.hide-for-medium, tr.show-for-medium-down, tr.hide-for-large-only, tr.hide-for-large-up, tr.hide-for-large, tr.show-for-large-down, tr.hide-for-xlarge-only, tr.hide-for-xlarge-up, tr.hide-for-xlarge, tr.show-for-xlarge-down, tr.hide-for-xxlarge-only, tr.hide-for-xxlarge-up, tr.hide-for-xxlarge, tr.show-for-xxlarge-down {
+    display: table-row !important; }
+
+  th.show-for-small-only, td.show-for-small-only, th.show-for-small-up, td.show-for-small-up, th.show-for-small, td.show-for-small, th.show-for-small-down, td.show-for-small-down, th.hide-for-medium-only, td.hide-for-medium-only, th.hide-for-medium-up, td.hide-for-medium-up, th.hide-for-medium, td.hide-for-medium, th.show-for-medium-down, td.show-for-medium-down, th.hide-for-large-only, td.hide-for-large-only, th.hide-for-large-up, td.hide-for-large-up, th.hide-for-large, td.hide-for-large, th.show-for-large-down, td.show-for-large-down, th.hide-for-xlarge-only, td.hide-for-xlarge-only, th.hide-for-xlarge-up, td.hide-for-xlarge-up, th.hide-for-xlarge, td.hide-for-xlarge, th.show-for-xlarge-down, td.show-for-xlarge-down, th.hide-for-xxlarge-only, td.hide-for-xxlarge-only, th.hide-for-xxlarge-up, td.hide-for-xxlarge-up, th.hide-for-xxlarge, td.hide-for-xxlarge, th.show-for-xxlarge-down, td.show-for-xxlarge-down {
+    display: table-cell !important; } }
+/* medium displays */
+@media only screen and (min-width: 40.063em) {
+  .hide-for-small-only, .show-for-small-up, .hide-for-small, .hide-for-small-down, .show-for-medium-only, .show-for-medium-up, .show-for-medium, .show-for-medium-down, .hide-for-large-only, .hide-for-large-up, .hide-for-large, .show-for-large-down, .hide-for-xlarge-only, .hide-for-xlarge-up, .hide-for-xlarge, .show-for-xlarge-down, .hide-for-xxlarge-only, .hide-for-xxlarge-up, .hide-for-xxlarge, .show-for-xxlarge-down {
+    display: inherit !important; }
+
+  .show-for-small-only, .hide-for-small-up, .show-for-small, .show-for-small-down, .hide-for-medium-only, .hide-for-medium-up, .hide-for-medium, .hide-for-medium-down, .show-for-large-only, .show-for-large-up, .show-for-large, .hide-for-large-down, .show-for-xlarge-only, .show-for-xlarge-up, .show-for-xlarge, .hide-for-xlarge-down, .show-for-xxlarge-only, .show-for-xxlarge-up, .show-for-xxlarge, .hide-for-xxlarge-down {
+    display: none !important; }
+
+  table.hide-for-small-only, table.show-for-small-up, table.hide-for-small, table.hide-for-small-down, table.show-for-medium-only, table.show-for-medium-up, table.show-for-medium, table.show-for-medium-down, table.hide-for-large-only, table.hide-for-large-up, table.hide-for-large, table.show-for-large-down, table.hide-for-xlarge-only, table.hide-for-xlarge-up, table.hide-for-xlarge, table.show-for-xlarge-down, table.hide-for-xxlarge-only, table.hide-for-xxlarge-up, table.hide-for-xxlarge, table.show-for-xxlarge-down {
+    display: table; }
+
+  thead.hide-for-small-only, thead.show-for-small-up, thead.hide-for-small, thead.hide-for-small-down, thead.show-for-medium-only, thead.show-for-medium-up, thead.show-for-medium, thead.show-for-medium-down, thead.hide-for-large-only, thead.hide-for-large-up, thead.hide-for-large, thead.show-for-large-down, thead.hide-for-xlarge-only, thead.hide-for-xlarge-up, thead.hide-for-xlarge, thead.show-for-xlarge-down, thead.hide-for-xxlarge-only, thead.hide-for-xxlarge-up, thead.hide-for-xxlarge, thead.show-for-xxlarge-down {
+    display: table-header-group !important; }
+
+  tbody.hide-for-small-only, tbody.show-for-small-up, tbody.hide-for-small, tbody.hide-for-small-down, tbody.show-for-medium-only, tbody.show-for-medium-up, tbody.show-for-medium, tbody.show-for-medium-down, tbody.hide-for-large-only, tbody.hide-for-large-up, tbody.hide-for-large, tbody.show-for-large-down, tbody.hide-for-xlarge-only, tbody.hide-for-xlarge-up, tbody.hide-for-xlarge, tbody.show-for-xlarge-down, tbody.hide-for-xxlarge-only, tbody.hide-for-xxlarge-up, tbody.hide-for-xxlarge, tbody.show-for-xxlarge-down {
+    display: table-row-group !important; }
+
+  tr.hide-for-small-only, tr.show-for-small-up, tr.hide-for-small, tr.hide-for-small-down, tr.show-for-medium-only, tr.show-for-medium-up, tr.show-for-medium, tr.show-for-medium-down, tr.hide-for-large-only, tr.hide-for-large-up, tr.hide-for-large, tr.show-for-large-down, tr.hide-for-xlarge-only, tr.hide-for-xlarge-up, tr.hide-for-xlarge, tr.show-for-xlarge-down, tr.hide-for-xxlarge-only, tr.hide-for-xxlarge-up, tr.hide-for-xxlarge, tr.show-for-xxlarge-down {
+    display: table-row !important; }
+
+  th.hide-for-small-only, td.hide-for-small-only, th.show-for-small-up, td.show-for-small-up, th.hide-for-small, td.hide-for-small, th.hide-for-small-down, td.hide-for-small-down, th.show-for-medium-only, td.show-for-medium-only, th.show-for-medium-up, td.show-for-medium-up, th.show-for-medium, td.show-for-medium, th.show-for-medium-down, td.show-for-medium-down, th.hide-for-large-only, td.hide-for-large-only, th.hide-for-large-up, td.hide-for-large-up, th.hide-for-large, td.hide-for-large, th.show-for-large-down, td.show-for-large-down, th.hide-for-xlarge-only, td.hide-for-xlarge-only, th.hide-for-xlarge-up, td.hide-for-xlarge-up, th.hide-for-xlarge, td.hide-for-xlarge, th.show-for-xlarge-down, td.show-for-xlarge-down, th.hide-for-xxlarge-only, td.hide-for-xxlarge-only, th.hide-for-xxlarge-up, td.hide-for-xxlarge-up, th.hide-for-xxlarge, td.hide-for-xxlarge, th.show-for-xxlarge-down, td.show-for-xxlarge-down {
+    display: table-cell !important; } }
+/* large displays */
+@media only screen and (min-width: 64.063em) {
+  .hide-for-small-only, .show-for-small-up, .hide-for-small, .hide-for-small-down, .hide-for-medium-only, .show-for-medium-up, .hide-for-medium, .hide-for-medium-down, .show-for-large-only, .show-for-large-up, .show-for-large, .show-for-large-down, .hide-for-xlarge-only, .hide-for-xlarge-up, .hide-for-xlarge, .show-for-xlarge-down, .hide-for-xxlarge-only, .hide-for-xxlarge-up, .hide-for-xxlarge, .show-for-xxlarge-down {
+    display: inherit !important; }
+
+  .show-for-small-only, .hide-for-small-up, .show-for-small, .show-for-small-down, .show-for-medium-only, .hide-for-medium-up, .show-for-medium, .show-for-medium-down, .hide-for-large-only, .hide-for-large-up, .hide-for-large, .hide-for-large-down, .show-for-xlarge-only, .show-for-xlarge-up, .show-for-xlarge, .hide-for-xlarge-down, .show-for-xxlarge-only, .show-for-xxlarge-up, .show-for-xxlarge, .hide-for-xxlarge-down {
+    display: none !important; }
+
+  table.hide-for-small-only, table.show-for-small-up, table.hide-for-small, table.hide-for-small-down, table.hide-for-medium-only, table.show-for-medium-up, table.hide-for-medium, table.hide-for-medium-down, table.show-for-large-only, table.show-for-large-up, table.show-for-large, table.show-for-large-down, table.hide-for-xlarge-only, table.hide-for-xlarge-up, table.hide-for-xlarge, table.show-for-xlarge-down, table.hide-for-xxlarge-only, table.hide-for-xxlarge-up, table.hide-for-xxlarge, table.show-for-xxlarge-down {
+    display: table; }
+
+  thead.hide-for-small-only, thead.show-for-small-up, thead.hide-for-small, thead.hide-for-small-down, thead.hide-for-medium-only, thead.show-for-medium-up, thead.hide-for-medium, thead.hide-for-medium-down, thead.show-for-large-only, thead.show-for-large-up, thead.show-for-large, thead.show-for-large-down, thead.hide-for-xlarge-only, thead.hide-for-xlarge-up, thead.hide-for-xlarge, thead.show-for-xlarge-down, thead.hide-for-xxlarge-only, thead.hide-for-xxlarge-up, thead.hide-for-xxlarge, thead.show-for-xxlarge-down {
+    display: table-header-group !important; }
+
+  tbody.hide-for-small-only, tbody.show-for-small-up, tbody.hide-for-small, tbody.hide-for-small-down, tbody.hide-for-medium-only, tbody.show-for-medium-up, tbody.hide-for-medium, tbody.hide-for-medium-down, tbody.show-for-large-only, tbody.show-for-large-up, tbody.show-for-large, tbody.show-for-large-down, tbody.hide-for-xlarge-only, tbody.hide-for-xlarge-up, tbody.hide-for-xlarge, tbody.show-for-xlarge-down, tbody.hide-for-xxlarge-only, tbody.hide-for-xxlarge-up, tbody.hide-for-xxlarge, tbody.show-for-xxlarge-down {
+    display: table-row-group !important; }
+
+  tr.hide-for-small-only, tr.show-for-small-up, tr.hide-for-small, tr.hide-for-small-down, tr.hide-for-medium-only, tr.show-for-medium-up, tr.hide-for-medium, tr.hide-for-medium-down, tr.show-for-large-only, tr.show-for-large-up, tr.show-for-large, tr.show-for-large-down, tr.hide-for-xlarge-only, tr.hide-for-xlarge-up, tr.hide-for-xlarge, tr.show-for-xlarge-down, tr.hide-for-xxlarge-only, tr.hide-for-xxlarge-up, tr.hide-for-xxlarge, tr.show-for-xxlarge-down {
+    display: table-row !important; }
+
+  th.hide-for-small-only, td.hide-for-small-only, th.show-for-small-up, td.show-for-small-up, th.hide-for-small, td.hide-for-small, th.hide-for-small-down, td.hide-for-small-down, th.hide-for-medium-only, td.hide-for-medium-only, th.show-for-medium-up, td.show-for-medium-up, th.hide-for-medium, td.hide-for-medium, th.hide-for-medium-down, td.hide-for-medium-down, th.show-for-large-only, td.show-for-large-only, th.show-for-large-up, td.show-for-large-up, th.show-for-large, td.show-for-large, th.show-for-large-down, td.show-for-large-down, th.hide-for-xlarge-only, td.hide-for-xlarge-only, th.hide-for-xlarge-up, td.hide-for-xlarge-up, th.hide-for-xlarge, td.hide-for-xlarge, th.show-for-xlarge-down, td.show-for-xlarge-down, th.hide-for-xxlarge-only, td.hide-for-xxlarge-only, th.hide-for-xxlarge-up, td.hide-for-xxlarge-up, th.hide-for-xxlarge, td.hide-for-xxlarge, th.show-for-xxlarge-down, td.show-for-xxlarge-down {
+    display: table-cell !important; } }
+/* xlarge displays */
+@media only screen and (min-width: 90.063em) {
+  .hide-for-small-only, .show-for-small-up, .hide-for-small, .hide-for-small-down, .hide-for-medium-only, .show-for-medium-up, .hide-for-medium, .hide-for-medium-down, .hide-for-large-only, .show-for-large-up, .hide-for-large, .hide-for-large-down, .show-for-xlarge-only, .show-for-xlarge-up, .show-for-xlarge, .show-for-xlarge-down, .hide-for-xxlarge-only, .hide-for-xxlarge-up, .hide-for-xxlarge, .show-for-xxlarge-down {
+    display: inherit !important; }
+
+  .show-for-small-only, .hide-for-small-up, .show-for-small, .show-for-small-down, .show-for-medium-only, .hide-for-medium-up, .show-for-medium, .show-for-medium-down, .show-for-large-only, .hide-for-large-up, .show-for-large, .show-for-large-down, .hide-for-xlarge-only, .hide-for-xlarge-up, .hide-for-xlarge, .hide-for-xlarge-down, .show-for-xxlarge-only, .show-for-xxlarge-up, .show-for-xxlarge, .hide-for-xxlarge-down {
+    display: none !important; }
+
+  table.hide-for-small-only, table.show-for-small-up, table.hide-for-small, table.hide-for-small-down, table.hide-for-medium-only, table.show-for-medium-up, table.hide-for-medium, table.hide-for-medium-down, table.hide-for-large-only, table.show-for-large-up, table.hide-for-large, table.hide-for-large-down, table.show-for-xlarge-only, table.show-for-xlarge-up, table.show-for-xlarge, table.show-for-xlarge-down, table.hide-for-xxlarge-only, table.hide-for-xxlarge-up, table.hide-for-xxlarge, table.show-for-xxlarge-down {
+    display: table; }
+
+  thead.hide-for-small-only, thead.show-for-small-up, thead.hide-for-small, thead.hide-for-small-down, thead.hide-for-medium-only, thead.show-for-medium-up, thead.hide-for-medium, thead.hide-for-medium-down, thead.hide-for-large-only, thead.show-for-large-up, thead.hide-for-large, thead.hide-for-large-down, thead.show-for-xlarge-only, thead.show-for-xlarge-up, thead.show-for-xlarge, thead.show-for-xlarge-down, thead.hide-for-xxlarge-only, thead.hide-for-xxlarge-up, thead.hide-for-xxlarge, thead.show-for-xxlarge-down {
+    display: table-header-group !important; }
+
+  tbody.hide-for-small-only, tbody.show-for-small-up, tbody.hide-for-small, tbody.hide-for-small-down, tbody.hide-for-medium-only, tbody.show-for-medium-up, tbody.hide-for-medium, tbody.hide-for-medium-down, tbody.hide-for-large-only, tbody.show-for-large-up, tbody.hide-for-large, tbody.hide-for-large-down, tbody.show-for-xlarge-only, tbody.show-for-xlarge-up, tbody.show-for-xlarge, tbody.show-for-xlarge-down, tbody.hide-for-xxlarge-only, tbody.hide-for-xxlarge-up, tbody.hide-for-xxlarge, tbody.show-for-xxlarge-down {
+    display: table-row-group !important; }
+
+  tr.hide-for-small-only, tr.show-for-small-up, tr.hide-for-small, tr.hide-for-small-down, tr.hide-for-medium-only, tr.show-for-medium-up, tr.hide-for-medium, tr.hide-for-medium-down, tr.hide-for-large-only, tr.show-for-large-up, tr.hide-for-large, tr.hide-for-large-down, tr.show-for-xlarge-only, tr.show-for-xlarge-up, tr.show-for-xlarge, tr.show-for-xlarge-down, tr.hide-for-xxlarge-only, tr.hide-for-xxlarge-up, tr.hide-for-xxlarge, tr.show-for-xxlarge-down {
+    display: table-row !important; }
+
+  th.hide-for-small-only, td.hide-for-small-only, th.show-for-small-up, td.show-for-small-up, th.hide-for-small, td.hide-for-small, th.hide-for-small-down, td.hide-for-small-down, th.hide-for-medium-only, td.hide-for-medium-only, th.show-for-medium-up, td.show-for-medium-up, th.hide-for-medium, td.hide-for-medium, th.hide-for-medium-down, td.hide-for-medium-down, th.hide-for-large-only, td.hide-for-large-only, th.show-for-large-up, td.show-for-large-up, th.hide-for-large, td.hide-for-large, th.hide-for-large-down, td.hide-for-large-down, th.show-for-xlarge-only, td.show-for-xlarge-only, th.show-for-xlarge-up, td.show-for-xlarge-up, th.show-for-xlarge, td.show-for-xlarge, th.show-for-xlarge-down, td.show-for-xlarge-down, th.hide-for-xxlarge-only, td.hide-for-xxlarge-only, th.hide-for-xxlarge-up, td.hide-for-xxlarge-up, th.hide-for-xxlarge, td.hide-for-xxlarge, th.show-for-xxlarge-down, td.show-for-xxlarge-down {
+    display: table-cell !important; } }
+/* xxlarge displays */
+@media only screen and (min-width: 120.063em) {
+  .hide-for-small-only, .show-for-small-up, .hide-for-small, .hide-for-small-down, .hide-for-medium-only, .show-for-medium-up, .hide-for-medium, .hide-for-medium-down, .hide-for-large-only, .show-for-large-up, .hide-for-large, .hide-for-large-down, .hide-for-xlarge-only, .show-for-xlarge-up, .hide-for-xlarge, .hide-for-xlarge-down, .show-for-xxlarge-only, .show-for-xxlarge-up, .show-for-xxlarge, .show-for-xxlarge-down {
+    display: inherit !important; }
+
+  .show-for-small-only, .hide-for-small-up, .show-for-small, .show-for-small-down, .show-for-medium-only, .hide-for-medium-up, .show-for-medium, .show-for-medium-down, .show-for-large-only, .hide-for-large-up, .show-for-large, .show-for-large-down, .show-for-xlarge-only, .hide-for-xlarge-up, .show-for-xlarge, .show-for-xlarge-down, .hide-for-xxlarge-only, .hide-for-xxlarge-up, .hide-for-xxlarge, .hide-for-xxlarge-down {
+    display: none !important; }
+
+  table.hide-for-small-only, table.show-for-small-up, table.hide-for-small, table.hide-for-small-down, table.hide-for-medium-only, table.show-for-medium-up, table.hide-for-medium, table.hide-for-medium-down, table.hide-for-large-only, table.show-for-large-up, table.hide-for-large, table.hide-for-large-down, table.hide-for-xlarge-only, table.show-for-xlarge-up, table.hide-for-xlarge, table.hide-for-xlarge-down, table.show-for-xxlarge-only, table.show-for-xxlarge-up, table.show-for-xxlarge, table.show-for-xxlarge-down {
+    display: table; }
+
+  thead.hide-for-small-only, thead.show-for-small-up, thead.hide-for-small, thead.hide-for-small-down, thead.hide-for-medium-only, thead.show-for-medium-up, thead.hide-for-medium, thead.hide-for-medium-down, thead.hide-for-large-only, thead.show-for-large-up, thead.hide-for-large, thead.hide-for-large-down, thead.hide-for-xlarge-only, thead.show-for-xlarge-up, thead.hide-for-xlarge, thead.hide-for-xlarge-down, thead.show-for-xxlarge-only, thead.show-for-xxlarge-up, thead.show-for-xxlarge, thead.show-for-xxlarge-down {
+    display: table-header-group !important; }
+
+  tbody.hide-for-small-only, tbody.show-for-small-up, tbody.hide-for-small, tbody.hide-for-small-down, tbody.hide-for-medium-only, tbody.show-for-medium-up, tbody.hide-for-medium, tbody.hide-for-medium-down, tbody.hide-for-large-only, tbody.show-for-large-up, tbody.hide-for-large, tbody.hide-for-large-down, tbody.hide-for-xlarge-only, tbody.show-for-xlarge-up, tbody.hide-for-xlarge, tbody.hide-for-xlarge-down, tbody.show-for-xxlarge-only, tbody.show-for-xxlarge-up, tbody.show-for-xxlarge, tbody.show-for-xxlarge-down {
+    display: table-row-group !important; }
+
+  tr.hide-for-small-only, tr.show-for-small-up, tr.hide-for-small, tr.hide-for-small-down, tr.hide-for-medium-only, tr.show-for-medium-up, tr.hide-for-medium, tr.hide-for-medium-down, tr.hide-for-large-only, tr.show-for-large-up, tr.hide-for-large, tr.hide-for-large-down, tr.hide-for-xlarge-only, tr.show-for-xlarge-up, tr.hide-for-xlarge, tr.hide-for-xlarge-down, tr.show-for-xxlarge-only, tr.show-for-xxlarge-up, tr.show-for-xxlarge, tr.show-for-xxlarge-down {
+    display: table-row !important; }
+
+  th.hide-for-small-only, td.hide-for-small-only, th.show-for-small-up, td.show-for-small-up, th.hide-for-small, td.hide-for-small, th.hide-for-small-down, td.hide-for-small-down, th.hide-for-medium-only, td.hide-for-medium-only, th.show-for-medium-up, td.show-for-medium-up, th.hide-for-medium, td.hide-for-medium, th.hide-for-medium-down, td.hide-for-medium-down, th.hide-for-large-only, td.hide-for-large-only, th.show-for-large-up, td.show-for-large-up, th.hide-for-large, td.hide-for-large, th.hide-for-large-down, td.hide-for-large-down, th.hide-for-xlarge-only, td.hide-for-xlarge-only, th.show-for-xlarge-up, td.show-for-xlarge-up, th.hide-for-xlarge, td.hide-for-xlarge, th.hide-for-xlarge-down, td.hide-for-xlarge-down, th.show-for-xxlarge-only, td.show-for-xxlarge-only, th.show-for-xxlarge-up, td.show-for-xxlarge-up, th.show-for-xxlarge, td.show-for-xxlarge, th.show-for-xxlarge-down, td.show-for-xxlarge-down {
+    display: table-cell !important; } }
+/* Orientation targeting */
+.show-for-landscape,
+.hide-for-portrait {
+  display: inherit !important; }
+
+.hide-for-landscape,
+.show-for-portrait {
+  display: none !important; }
+
+/* Specific visibility for tables */
+table.hide-for-landscape, table.show-for-portrait {
+  display: table; }
+
+thead.hide-for-landscape, thead.show-for-portrait {
+  display: table-header-group !important; }
+
+tbody.hide-for-landscape, tbody.show-for-portrait {
+  display: table-row-group !important; }
+
+tr.hide-for-landscape, tr.show-for-portrait {
+  display: table-row !important; }
+
+td.hide-for-landscape, td.show-for-portrait,
+th.hide-for-landscape,
+th.show-for-portrait {
+  display: table-cell !important; }
+
+@media only screen and (orientation: landscape) {
+  .show-for-landscape,
+  .hide-for-portrait {
+    display: inherit !important; }
+
+  .hide-for-landscape,
+  .show-for-portrait {
+    display: none !important; }
+
+  /* Specific visibility for tables */
+  table.show-for-landscape, table.hide-for-portrait {
+    display: table; }
+
+  thead.show-for-landscape, thead.hide-for-portrait {
+    display: table-header-group !important; }
+
+  tbody.show-for-landscape, tbody.hide-for-portrait {
+    display: table-row-group !important; }
+
+  tr.show-for-landscape, tr.hide-for-portrait {
+    display: table-row !important; }
+
+  td.show-for-landscape, td.hide-for-portrait,
+  th.show-for-landscape,
+  th.hide-for-portrait {
+    display: table-cell !important; } }
+@media only screen and (orientation: portrait) {
+  .show-for-portrait,
+  .hide-for-landscape {
+    display: inherit !important; }
+
+  .hide-for-portrait,
+  .show-for-landscape {
+    display: none !important; }
+
+  /* Specific visibility for tables */
+  table.show-for-portrait, table.hide-for-landscape {
+    display: table; }
+
+  thead.show-for-portrait, thead.hide-for-landscape {
+    display: table-header-group !important; }
+
+  tbody.show-for-portrait, tbody.hide-for-landscape {
+    display: table-row-group !important; }
+
+  tr.show-for-portrait, tr.hide-for-landscape {
+    display: table-row !important; }
+
+  td.show-for-portrait, td.hide-for-landscape,
+  th.show-for-portrait,
+  th.hide-for-landscape {
+    display: table-cell !important; } }
+/* Touch-enabled device targeting */
+.show-for-touch {
+  display: none !important; }
+
+.hide-for-touch {
+  display: inherit !important; }
+
+.touch .show-for-touch {
+  display: inherit !important; }
+
+.touch .hide-for-touch {
+  display: none !important; }
+
+/* Specific visibility for tables */
+table.hide-for-touch {
+  display: table; }
+
+.touch table.show-for-touch {
+  display: table; }
+
+thead.hide-for-touch {
+  display: table-header-group !important; }
+
+.touch thead.show-for-touch {
+  display: table-header-group !important; }
+
+tbody.hide-for-touch {
+  display: table-row-group !important; }
+
+.touch tbody.show-for-touch {
+  display: table-row-group !important; }
+
+tr.hide-for-touch {
+  display: table-row !important; }
+
+.touch tr.show-for-touch {
+  display: table-row !important; }
+
+td.hide-for-touch {
+  display: table-cell !important; }
+
+.touch td.show-for-touch {
+  display: table-cell !important; }
+
+th.hide-for-touch {
+  display: table-cell !important; }
+
+.touch th.show-for-touch {
+  display: table-cell !important; }
diff --git a/karmaworld/assets/css/foundation.min.css b/karmaworld/assets/css/foundation.min.css
deleted file mode 100644 (file)
index 1ca4174..0000000
+++ /dev/null
@@ -1 +0,0 @@
-meta.foundation-version{font-family:"/5.2.1/"}meta.foundation-mq-small{font-family:"/only screen and (max-width: 40em)/";width:0em}meta.foundation-mq-medium{font-family:"/only screen and (min-width:40.063em)/";width:40.063em}meta.foundation-mq-large{font-family:"/only screen and (min-width:64.063em)/";width:64.063em}meta.foundation-mq-xlarge{font-family:"/only screen and (min-width:90.063em)/";width:90.063em}meta.foundation-mq-xxlarge{font-family:"/only screen and (min-width:120.063em)/";width:120.063em}meta.foundation-data-attribute-namespace{font-family:false}html,body{height:100%}*,*:before,*:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}html,body{font-size:100%}body{background:#fff;color:#222;padding:0;margin:0;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;font-style:normal;line-height:1;position:relative;cursor:default}a:hover{cursor:pointer}img{max-width:100%;height:auto}img{-ms-interpolation-mode:bicubic}#map_canvas img,#map_canvas embed,#map_canvas object,.map_canvas img,.map_canvas embed,.map_canvas object{max-width:none !important}.left{float:left !important}.right{float:right !important}.clearfix{*zoom:1}.clearfix:before,.clearfix:after{content:" ";display:table}.clearfix:after{clear:both}.hide{display:none}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle}textarea{height:auto;min-height:50px}select{width:100%}.xy-center{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%, -50%);-ms-transform:translate(-50%, -50%);transform:translate(-50%, -50%)}.x-center{position:absolute;left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.y-center{position:relative;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.row{width:100%;margin-left:auto;margin-right:auto;margin-top:0;margin-bottom:0;max-width:62.5rem;*zoom:1}.row:before,.row:after{content:" ";display:table}.row:after{clear:both}.row.collapse>.column,.row.collapse>.columns{padding-left:0;padding-right:0}.row.collapse .row{margin-left:0;margin-right:0}.row .row{width:auto;margin-left:-0.9375rem;margin-right:-0.9375rem;margin-top:0;margin-bottom:0;max-width:none;*zoom:1}.row .row:before,.row .row:after{content:" ";display:table}.row .row:after{clear:both}.row .row.collapse{width:auto;margin:0;max-width:none;*zoom:1}.row .row.collapse:before,.row .row.collapse:after{content:" ";display:table}.row .row.collapse:after{clear:both}.column,.columns{padding-left:0.9375rem;padding-right:0.9375rem;width:100%;float:left}@media only screen{.column.small-centered,.columns.small-centered{margin-left:auto;margin-right:auto;float:none !important}.column.small-uncentered,.columns.small-uncentered{margin-left:0;margin-right:0;float:left !important}.column.small-uncentered.opposite,.columns.small-uncentered.opposite{float:right}.small-push-0{position:relative;left:0%;right:auto}.small-pull-0{position:relative;right:0%;left:auto}.small-push-1{position:relative;left:8.33333%;right:auto}.small-pull-1{position:relative;right:8.33333%;left:auto}.small-push-2{position:relative;left:16.66667%;right:auto}.small-pull-2{position:relative;right:16.66667%;left:auto}.small-push-3{position:relative;left:25%;right:auto}.small-pull-3{position:relative;right:25%;left:auto}.small-push-4{position:relative;left:33.33333%;right:auto}.small-pull-4{position:relative;right:33.33333%;left:auto}.small-push-5{position:relative;left:41.66667%;right:auto}.small-pull-5{position:relative;right:41.66667%;left:auto}.small-push-6{position:relative;left:50%;right:auto}.small-pull-6{position:relative;right:50%;left:auto}.small-push-7{position:relative;left:58.33333%;right:auto}.small-pull-7{position:relative;right:58.33333%;left:auto}.small-push-8{position:relative;left:66.66667%;right:auto}.small-pull-8{position:relative;right:66.66667%;left:auto}.small-push-9{position:relative;left:75%;right:auto}.small-pull-9{position:relative;right:75%;left:auto}.small-push-10{position:relative;left:83.33333%;right:auto}.small-pull-10{position:relative;right:83.33333%;left:auto}.small-push-11{position:relative;left:91.66667%;right:auto}.small-pull-11{position:relative;right:91.66667%;left:auto}.column,.columns{position:relative;padding-left:0.9375rem;padding-right:0.9375rem;float:left}.small-1{width:8.33333%}.small-2{width:16.66667%}.small-3{width:25%}.small-4{width:33.33333%}.small-5{width:41.66667%}.small-6{width:50%}.small-7{width:58.33333%}.small-8{width:66.66667%}.small-9{width:75%}.small-10{width:83.33333%}.small-11{width:91.66667%}.small-12{width:100%}[class*="column"]+[class*="column"]:last-child{float:right}[class*="column"]+[class*="column"].end{float:left}.small-offset-0{margin-left:0% !important}.small-offset-1{margin-left:8.33333% !important}.small-offset-2{margin-left:16.66667% !important}.small-offset-3{margin-left:25% !important}.small-offset-4{margin-left:33.33333% !important}.small-offset-5{margin-left:41.66667% !important}.small-offset-6{margin-left:50% !important}.small-offset-7{margin-left:58.33333% !important}.small-offset-8{margin-left:66.66667% !important}.small-offset-9{margin-left:75% !important}.small-offset-10{margin-left:83.33333% !important}.small-offset-11{margin-left:91.66667% !important}.small-reset-order,.small-reset-order{margin-left:0;margin-right:0;left:auto;right:auto;float:left}}@media only screen and (min-width: 40.063em){.column.medium-centered,.columns.medium-centered{margin-left:auto;margin-right:auto;float:none !important}.column.medium-uncentered,.columns.medium-uncentered{margin-left:0;margin-right:0;float:left !important}.column.medium-uncentered.opposite,.columns.medium-uncentered.opposite{float:right}.medium-push-0{position:relative;left:0%;right:auto}.medium-pull-0{position:relative;right:0%;left:auto}.medium-push-1{position:relative;left:8.33333%;right:auto}.medium-pull-1{position:relative;right:8.33333%;left:auto}.medium-push-2{position:relative;left:16.66667%;right:auto}.medium-pull-2{position:relative;right:16.66667%;left:auto}.medium-push-3{position:relative;left:25%;right:auto}.medium-pull-3{position:relative;right:25%;left:auto}.medium-push-4{position:relative;left:33.33333%;right:auto}.medium-pull-4{position:relative;right:33.33333%;left:auto}.medium-push-5{position:relative;left:41.66667%;right:auto}.medium-pull-5{position:relative;right:41.66667%;left:auto}.medium-push-6{position:relative;left:50%;right:auto}.medium-pull-6{position:relative;right:50%;left:auto}.medium-push-7{position:relative;left:58.33333%;right:auto}.medium-pull-7{position:relative;right:58.33333%;left:auto}.medium-push-8{position:relative;left:66.66667%;right:auto}.medium-pull-8{position:relative;right:66.66667%;left:auto}.medium-push-9{position:relative;left:75%;right:auto}.medium-pull-9{position:relative;right:75%;left:auto}.medium-push-10{position:relative;left:83.33333%;right:auto}.medium-pull-10{position:relative;right:83.33333%;left:auto}.medium-push-11{position:relative;left:91.66667%;right:auto}.medium-pull-11{position:relative;right:91.66667%;left:auto}.column,.columns{position:relative;padding-left:0.9375rem;padding-right:0.9375rem;float:left}.medium-1{width:8.33333%}.medium-2{width:16.66667%}.medium-3{width:25%}.medium-4{width:33.33333%}.medium-5{width:41.66667%}.medium-6{width:50%}.medium-7{width:58.33333%}.medium-8{width:66.66667%}.medium-9{width:75%}.medium-10{width:83.33333%}.medium-11{width:91.66667%}.medium-12{width:100%}[class*="column"]+[class*="column"]:last-child{float:right}[class*="column"]+[class*="column"].end{float:left}.medium-offset-0{margin-left:0% !important}.medium-offset-1{margin-left:8.33333% !important}.medium-offset-2{margin-left:16.66667% !important}.medium-offset-3{margin-left:25% !important}.medium-offset-4{margin-left:33.33333% !important}.medium-offset-5{margin-left:41.66667% !important}.medium-offset-6{margin-left:50% !important}.medium-offset-7{margin-left:58.33333% !important}.medium-offset-8{margin-left:66.66667% !important}.medium-offset-9{margin-left:75% !important}.medium-offset-10{margin-left:83.33333% !important}.medium-offset-11{margin-left:91.66667% !important}.medium-reset-order,.medium-reset-order{margin-left:0;margin-right:0;left:auto;right:auto;float:left}.push-0{position:relative;left:0%;right:auto}.pull-0{position:relative;right:0%;left:auto}.push-1{position:relative;left:8.33333%;right:auto}.pull-1{position:relative;right:8.33333%;left:auto}.push-2{position:relative;left:16.66667%;right:auto}.pull-2{position:relative;right:16.66667%;left:auto}.push-3{position:relative;left:25%;right:auto}.pull-3{position:relative;right:25%;left:auto}.push-4{position:relative;left:33.33333%;right:auto}.pull-4{position:relative;right:33.33333%;left:auto}.push-5{position:relative;left:41.66667%;right:auto}.pull-5{position:relative;right:41.66667%;left:auto}.push-6{position:relative;left:50%;right:auto}.pull-6{position:relative;right:50%;left:auto}.push-7{position:relative;left:58.33333%;right:auto}.pull-7{position:relative;right:58.33333%;left:auto}.push-8{position:relative;left:66.66667%;right:auto}.pull-8{position:relative;right:66.66667%;left:auto}.push-9{position:relative;left:75%;right:auto}.pull-9{position:relative;right:75%;left:auto}.push-10{position:relative;left:83.33333%;right:auto}.pull-10{position:relative;right:83.33333%;left:auto}.push-11{position:relative;left:91.66667%;right:auto}.pull-11{position:relative;right:91.66667%;left:auto}}@media only screen and (min-width: 64.063em){.column.large-centered,.columns.large-centered{margin-left:auto;margin-right:auto;float:none !important}.column.large-uncentered,.columns.large-uncentered{margin-left:0;margin-right:0;float:left !important}.column.large-uncentered.opposite,.columns.large-uncentered.opposite{float:right}.large-push-0{position:relative;left:0%;right:auto}.large-pull-0{position:relative;right:0%;left:auto}.large-push-1{position:relative;left:8.33333%;right:auto}.large-pull-1{position:relative;right:8.33333%;left:auto}.large-push-2{position:relative;left:16.66667%;right:auto}.large-pull-2{position:relative;right:16.66667%;left:auto}.large-push-3{position:relative;left:25%;right:auto}.large-pull-3{position:relative;right:25%;left:auto}.large-push-4{position:relative;left:33.33333%;right:auto}.large-pull-4{position:relative;right:33.33333%;left:auto}.large-push-5{position:relative;left:41.66667%;right:auto}.large-pull-5{position:relative;right:41.66667%;left:auto}.large-push-6{position:relative;left:50%;right:auto}.large-pull-6{position:relative;right:50%;left:auto}.large-push-7{position:relative;left:58.33333%;right:auto}.large-pull-7{position:relative;right:58.33333%;left:auto}.large-push-8{position:relative;left:66.66667%;right:auto}.large-pull-8{position:relative;right:66.66667%;left:auto}.large-push-9{position:relative;left:75%;right:auto}.large-pull-9{position:relative;right:75%;left:auto}.large-push-10{position:relative;left:83.33333%;right:auto}.large-pull-10{position:relative;right:83.33333%;left:auto}.large-push-11{position:relative;left:91.66667%;right:auto}.large-pull-11{position:relative;right:91.66667%;left:auto}.column,.columns{position:relative;padding-left:0.9375rem;padding-right:0.9375rem;float:left}.large-1{width:8.33333%}.large-2{width:16.66667%}.large-3{width:25%}.large-4{width:33.33333%}.large-5{width:41.66667%}.large-6{width:50%}.large-7{width:58.33333%}.large-8{width:66.66667%}.large-9{width:75%}.large-10{width:83.33333%}.large-11{width:91.66667%}.large-12{width:100%}[class*="column"]+[class*="column"]:last-child{float:right}[class*="column"]+[class*="column"].end{float:left}.large-offset-0{margin-left:0% !important}.large-offset-1{margin-left:8.33333% !important}.large-offset-2{margin-left:16.66667% !important}.large-offset-3{margin-left:25% !important}.large-offset-4{margin-left:33.33333% !important}.large-offset-5{margin-left:41.66667% !important}.large-offset-6{margin-left:50% !important}.large-offset-7{margin-left:58.33333% !important}.large-offset-8{margin-left:66.66667% !important}.large-offset-9{margin-left:75% !important}.large-offset-10{margin-left:83.33333% !important}.large-offset-11{margin-left:91.66667% !important}.large-reset-order,.large-reset-order{margin-left:0;margin-right:0;left:auto;right:auto;float:left}.push-0{position:relative;left:0%;right:auto}.pull-0{position:relative;right:0%;left:auto}.push-1{position:relative;left:8.33333%;right:auto}.pull-1{position:relative;right:8.33333%;left:auto}.push-2{position:relative;left:16.66667%;right:auto}.pull-2{position:relative;right:16.66667%;left:auto}.push-3{position:relative;left:25%;right:auto}.pull-3{position:relative;right:25%;left:auto}.push-4{position:relative;left:33.33333%;right:auto}.pull-4{position:relative;right:33.33333%;left:auto}.push-5{position:relative;left:41.66667%;right:auto}.pull-5{position:relative;right:41.66667%;left:auto}.push-6{position:relative;left:50%;right:auto}.pull-6{position:relative;right:50%;left:auto}.push-7{position:relative;left:58.33333%;right:auto}.pull-7{position:relative;right:58.33333%;left:auto}.push-8{position:relative;left:66.66667%;right:auto}.pull-8{position:relative;right:66.66667%;left:auto}.push-9{position:relative;left:75%;right:auto}.pull-9{position:relative;right:75%;left:auto}.push-10{position:relative;left:83.33333%;right:auto}.pull-10{position:relative;right:83.33333%;left:auto}.push-11{position:relative;left:91.66667%;right:auto}.pull-11{position:relative;right:91.66667%;left:auto}}meta.foundation-mq-topbar{font-family:"/only screen and (min-width:40.063em)/";width:40.063em}.contain-to-grid{width:100%;background:#333}.contain-to-grid .top-bar{margin-bottom:0}.fixed{width:100%;left:0;position:fixed;top:0;z-index:99}.fixed.expanded:not(.top-bar){overflow-y:auto;height:auto;width:100%;max-height:100%}.fixed.expanded:not(.top-bar) .title-area{position:fixed;width:100%;z-index:99}.fixed.expanded:not(.top-bar) .top-bar-section{z-index:98;margin-top:45px}.top-bar{overflow:hidden;height:45px;line-height:45px;position:relative;background:#333;margin-bottom:0}.top-bar ul{margin-bottom:0;list-style:none}.top-bar .row{max-width:none}.top-bar form,.top-bar input{margin-bottom:0}.top-bar input{height:auto;padding-top:.35rem;padding-bottom:.35rem;font-size:0.75rem}.top-bar .button{padding-top:.45rem;padding-bottom:.35rem;margin-bottom:0;font-size:0.75rem}.top-bar .title-area{position:relative;margin:0}.top-bar .name{height:45px;margin:0;font-size:16px}.top-bar .name h1{line-height:45px;font-size:1.0625rem;margin:0}.top-bar .name h1 a{font-weight:normal;color:#fff;width:50%;display:block;padding:0 15px}.top-bar .toggle-topbar{position:absolute;right:0;top:0}.top-bar .toggle-topbar a{color:#fff;text-transform:uppercase;font-size:0.8125rem;font-weight:bold;position:relative;display:block;padding:0 15px;height:45px;line-height:45px}.top-bar .toggle-topbar.menu-icon{right:15px;top:50%;margin-top:-16px;padding-left:40px}.top-bar .toggle-topbar.menu-icon a{height:34px;line-height:33px;padding:0;padding-right:25px;color:#fff;position:relative}.top-bar .toggle-topbar.menu-icon a::after{content:"";position:absolute;right:0;display:block;width:16px;top:0;height:0;-webkit-box-shadow:1px 10px 1px 1px #fff,1px 16px 1px 1px #fff,1px 22px 1px 1px #fff;box-shadow:0 10px 0 1px #fff,0 16px 0 1px #fff,0 22px 0 1px #fff}.top-bar.expanded{height:auto;background:transparent}.top-bar.expanded .title-area{background:#333}.top-bar.expanded .toggle-topbar a{color:#888}.top-bar.expanded .toggle-topbar a::after{-webkit-box-shadow:1px 10px 1px 1px #888,1px 16px 1px 1px #888,1px 22px 1px 1px #888;box-shadow:0 10px 0 1px #888,0 16px 0 1px #888,0 22px 0 1px #888}.top-bar-section{left:0;position:relative;width:auto;-webkit-transition:left 300ms ease-out;-moz-transition:left 300ms ease-out;transition:left 300ms ease-out}.top-bar-section ul{width:100%;height:auto;display:block;background:#333;font-size:16px;margin:0}.top-bar-section .divider,.top-bar-section [role="separator"]{border-top:solid 1px #1a1a1a;clear:both;height:1px;width:100%}.top-bar-section ul li>a{display:block;width:100%;color:#fff;padding:12px 0 12px 0;padding-left:15px;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-size:0.8125rem;font-weight:normal;text-transform:none;background:#333}.top-bar-section ul li>a.button{background:#008cba;font-size:0.8125rem;padding-right:15px;padding-left:15px}.top-bar-section ul li>a.button:hover{background:#068}.top-bar-section ul li>a.button.secondary{background:#e7e7e7}.top-bar-section ul li>a.button.secondary:hover{background:#cecece}.top-bar-section ul li>a.button.success{background:#43ac6a}.top-bar-section ul li>a.button.success:hover{background:#358854}.top-bar-section ul li>a.button.alert{background:#f04124}.top-bar-section ul li>a.button.alert:hover{background:#d42b0f}.top-bar-section ul li:hover:not(.has-form)>a{background:#272727;color:#fff}.top-bar-section ul li.active>a{background:#008cba;color:#fff}.top-bar-section ul li.active>a:hover{background:#0078a0;color:#fff}.top-bar-section .has-form{padding:15px}.top-bar-section .has-dropdown{position:relative}.top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:transparent transparent transparent rgba(255,255,255,0.4);border-left-style:solid;margin-right:15px;margin-top:-4.5px;position:absolute;top:50%;right:0}.top-bar-section .has-dropdown.moved{position:static}.top-bar-section .has-dropdown.moved>.dropdown{display:block;position:static !important;height:auto;width:auto;overflow:visible;clip:auto;position:absolute !important;width:100%}.top-bar-section .has-dropdown.moved>a:after{display:none}.top-bar-section .dropdown{position:absolute;left:100%;top:0;z-index:99;display:block;position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px, 1px, 1px, 1px)}.top-bar-section .dropdown li{width:100%;height:auto}.top-bar-section .dropdown li a{font-weight:normal;padding:8px 15px}.top-bar-section .dropdown li a.parent-link{font-weight:normal}.top-bar-section .dropdown li.title h5{margin-bottom:0}.top-bar-section .dropdown li.title h5 a{color:#fff;line-height:22.5px;display:block}.top-bar-section .dropdown li.has-form{padding:8px 15px}.top-bar-section .dropdown li .button{top:auto}.top-bar-section .dropdown label{padding:8px 15px 2px;margin-bottom:0;text-transform:uppercase;color:#777;font-weight:bold;font-size:0.625rem}.js-generated{display:block}@media only screen and (min-width: 40.063em){.top-bar{background:#333;*zoom:1;overflow:visible}.top-bar:before,.top-bar:after{content:" ";display:table}.top-bar:after{clear:both}.top-bar .toggle-topbar{display:none}.top-bar .title-area{float:left}.top-bar .name h1 a{width:auto}.top-bar input,.top-bar .button{font-size:0.875rem;position:relative;top:7px}.top-bar.expanded{background:#333}.contain-to-grid .top-bar{max-width:62.5rem;margin:0 auto;margin-bottom:0}.top-bar-section{-webkit-transition:none 0 0;-moz-transition:none 0 0;transition:none 0 0;left:0 !important}.top-bar-section ul{width:auto;height:auto !important;display:inline}.top-bar-section ul li{float:left}.top-bar-section ul li .js-generated{display:none}.top-bar-section li.hover>a:not(.button){background:#272727;color:#fff}.top-bar-section li:not(.has-form) a:not(.button){padding:0 15px;line-height:45px;background:#333}.top-bar-section li:not(.has-form) a:not(.button):hover{background:#272727}.top-bar-section li.active:not(.has-form) a:not(.button){padding:0 15px;line-height:45px;color:#fff;background:#008cba}.top-bar-section li.active:not(.has-form) a:not(.button):hover{background:#0078a0}.top-bar-section .has-dropdown>a{padding-right:35px !important}.top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:rgba(255,255,255,0.4) transparent transparent transparent;border-top-style:solid;margin-top:-2.5px;top:22.5px}.top-bar-section .has-dropdown.moved{position:relative}.top-bar-section .has-dropdown.moved>.dropdown{display:block;position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px, 1px, 1px, 1px)}.top-bar-section .has-dropdown.hover>.dropdown,.top-bar-section .has-dropdown.not-click:hover>.dropdown{display:block;position:static !important;height:auto;width:auto;overflow:visible;clip:auto;position:absolute !important}.top-bar-section .has-dropdown .dropdown li.has-dropdown>a:after{border:none;content:"\00bb";top:1rem;margin-top:-1px;right:5px;line-height:1.2}.top-bar-section .dropdown{left:0;top:auto;background:transparent;min-width:100%}.top-bar-section .dropdown li a{color:#fff;line-height:1;white-space:nowrap;padding:12px 15px;background:#333}.top-bar-section .dropdown li label{white-space:nowrap;background:#333}.top-bar-section .dropdown li .dropdown{left:100%;top:0}.top-bar-section>ul>.divider,.top-bar-section>ul>[role="separator"]{border-bottom:none;border-top:none;border-right:solid 1px #4e4e4e;clear:none;height:45px;width:0}.top-bar-section .has-form{background:#333;padding:0 15px;height:45px}.top-bar-section .right li .dropdown{left:auto;right:0}.top-bar-section .right li .dropdown li .dropdown{right:100%}.top-bar-section .left li .dropdown{right:auto;left:0}.top-bar-section .left li .dropdown li .dropdown{left:100%}.no-js .top-bar-section ul li:hover>a{background:#272727;color:#fff}.no-js .top-bar-section ul li:active>a{background:#008cba;color:#fff}.no-js .top-bar-section .has-dropdown:hover>.dropdown{display:block;position:static !important;height:auto;width:auto;overflow:visible;clip:auto;position:absolute !important}}.breadcrumbs{display:block;padding:0.5625rem 0.875rem 0.5625rem;overflow:hidden;margin-left:0;list-style:none;border-style:solid;border-width:1px;background-color:#f4f4f4;border-color:#dcdcdc;-webkit-border-radius:3px;border-radius:3px}.breadcrumbs>*{margin:0;float:left;font-size:0.6875rem;text-transform:uppercase}.breadcrumbs>*:hover a,.breadcrumbs>*:focus a{text-decoration:underline}.breadcrumbs>* a,.breadcrumbs>* span{text-transform:uppercase;color:#008cba}.breadcrumbs>*.current{cursor:default;color:#333}.breadcrumbs>*.current a{cursor:default;color:#333}.breadcrumbs>*.current:hover,.breadcrumbs>*.current:hover a,.breadcrumbs>*.current:focus,.breadcrumbs>*.current:focus a{text-decoration:none}.breadcrumbs>*.unavailable{color:#999}.breadcrumbs>*.unavailable a{color:#999}.breadcrumbs>*.unavailable:hover,.breadcrumbs>*.unavailable:hover a,.breadcrumbs>*.unavailable:focus,.breadcrumbs>*.unavailable a:focus{text-decoration:none;color:#999;cursor:default}.breadcrumbs>*:before{content:"/";color:#aaa;margin:0 0.75rem;position:relative;top:1px}.breadcrumbs>*:first-child:before{content:" ";margin:0}.alert-box{border-style:solid;border-width:1px;display:block;font-weight:normal;margin-bottom:1.25rem;position:relative;padding:0.875rem 1.5rem 0.875rem 0.875rem;font-size:0.8125rem;background-color:#008cba;border-color:#0078a0;color:#fff}.alert-box .close{font-size:1.375rem;padding:9px 6px 4px;line-height:0;position:absolute;top:50%;margin-top:-0.6875rem;right:0.25rem;color:#333;opacity:0.3}.alert-box .close:hover,.alert-box .close:focus{opacity:0.5}.alert-box.radius{-webkit-border-radius:3px;border-radius:3px}.alert-box.round{-webkit-border-radius:1000px;border-radius:1000px}.alert-box.success{background-color:#43ac6a;border-color:#3a945b;color:#fff}.alert-box.alert{background-color:#f04124;border-color:#de2d0f;color:#fff}.alert-box.secondary{background-color:#e7e7e7;border-color:#c7c7c7;color:#4f4f4f}.alert-box.warning{background-color:#f08a24;border-color:#de770f;color:#fff}.alert-box.info{background-color:#a0d3e8;border-color:#74bfdd;color:#4f4f4f}.inline-list{margin:0 auto 1.0625rem auto;margin-left:-1.375rem;margin-right:0;padding:0;list-style:none;overflow:hidden}.inline-list>li{list-style:none;float:left;margin-left:1.375rem;display:block}.inline-list>li>*{display:block}button,.button{border-style:solid;border-width:0px;cursor:pointer;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;line-height:normal;margin:0 0 1.25rem;position:relative;text-decoration:none;text-align:center;display:inline-block;padding-top:1rem;padding-right:2rem;padding-bottom:1.0625rem;padding-left:2rem;font-size:1rem;background-color:#008cba;border-color:#007095;color:#fff;-webkit-transition:background-color 300ms ease-out;-moz-transition:background-color 300ms ease-out;transition:background-color 300ms ease-out;padding-top:1rem;padding-right:2rem;padding-bottom:1.0625rem;padding-left:2rem;font-size:1rem}button:hover,button:focus,.button:hover,.button:focus{background-color:#007095}button:hover,button:focus,.button:hover,.button:focus{color:#fff}button.secondary,.button.secondary{background-color:#e7e7e7;border-color:#b9b9b9;color:#333}button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{background-color:#b9b9b9}button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{color:#333}button.success,.button.success{background-color:#43ac6a;border-color:#368a55;color:#fff}button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{background-color:#368a55}button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{color:#fff}button.alert,.button.alert{background-color:#f04124;border-color:#cf2a0e;color:#fff}button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{background-color:#cf2a0e}button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{color:#fff}button.large,.button.large{padding-top:1.125rem;padding-right:2.25rem;padding-bottom:1.1875rem;padding-left:2.25rem;font-size:1.25rem}button.small,.button.small{padding-top:0.875rem;padding-right:1.75rem;padding-bottom:0.9375rem;padding-left:1.75rem;font-size:0.8125rem}button.tiny,.button.tiny{padding-top:0.625rem;padding-right:1.25rem;padding-bottom:0.6875rem;padding-left:1.25rem;font-size:0.6875rem}button.expand,.button.expand{padding-right:0;padding-left:0;width:100%}button.left-align,.button.left-align{text-align:left;text-indent:0.75rem}button.right-align,.button.right-align{text-align:right;padding-right:0.75rem}button.radius,.button.radius{-webkit-border-radius:3px;border-radius:3px}button.round,.button.round{-webkit-border-radius:1000px;border-radius:1000px}button.disabled,button[disabled],.button.disabled,.button[disabled]{background-color:#008cba;border-color:#007095;color:#fff;cursor:default;opacity:0.7;-webkit-box-shadow:none;box-shadow:none}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#007095}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{color:#fff}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#008cba}button.disabled.secondary,button[disabled].secondary,.button.disabled.secondary,.button[disabled].secondary{background-color:#e7e7e7;border-color:#b9b9b9;color:#333;cursor:default;opacity:0.7;-webkit-box-shadow:none;box-shadow:none}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#b9b9b9}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{color:#333}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#e7e7e7}button.disabled.success,button[disabled].success,.button.disabled.success,.button[disabled].success{background-color:#43ac6a;border-color:#368a55;color:#fff;cursor:default;opacity:0.7;-webkit-box-shadow:none;box-shadow:none}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#368a55}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{color:#fff}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#43ac6a}button.disabled.alert,button[disabled].alert,.button.disabled.alert,.button[disabled].alert{background-color:#f04124;border-color:#cf2a0e;color:#fff;cursor:default;opacity:0.7;-webkit-box-shadow:none;box-shadow:none}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#cf2a0e}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{color:#fff}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#f04124}@media only screen and (min-width: 40.063em){button,.button{display:inline-block}}.button-group{list-style:none;margin:0;left:0;*zoom:1}.button-group:before,.button-group:after{content:" ";display:table}.button-group:after{clear:both}.button-group li{margin:0;float:left}.button-group li>button,.button-group li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group li:first-child button,.button-group li:first-child .button{border-left:0}.button-group li:first-child{margin-left:0}.button-group.radius>*>button,.button-group.radius>* .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.radius>*:first-child button,.button-group.radius>*:first-child .button{border-left:0}.button-group.radius>*:first-child,.button-group.radius>*:first-child>a,.button-group.radius>*:first-child>button,.button-group.radius>*:first-child>.button{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.button-group.radius>*:last-child,.button-group.radius>*:last-child>a,.button-group.radius>*:last-child>button,.button-group.radius>*:last-child>.button{-moz-border-radius-bottomright:3px;-moz-border-radius-topright:3px;-webkit-border-bottom-right-radius:3px;-webkit-border-top-right-radius:3px;border-bottom-right-radius:3px;border-top-right-radius:3px}.button-group.round>*>button,.button-group.round>* .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.round>*:first-child button,.button-group.round>*:first-child .button{border-left:0}.button-group.round>*:first-child,.button-group.round>*:first-child>a,.button-group.round>*:first-child>button,.button-group.round>*:first-child>.button{-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px}.button-group.round>*:last-child,.button-group.round>*:last-child>a,.button-group.round>*:last-child>button,.button-group.round>*:last-child>.button{-moz-border-radius-bottomright:1000px;-moz-border-radius-topright:1000px;-webkit-border-bottom-right-radius:1000px;-webkit-border-top-right-radius:1000px;border-bottom-right-radius:1000px;border-top-right-radius:1000px}.button-group.even-2 li{width:50%}.button-group.even-2 li>button,.button-group.even-2 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-2 li:first-child button,.button-group.even-2 li:first-child .button{border-left:0}.button-group.even-2 li button,.button-group.even-2 li .button{width:100%}.button-group.even-3 li{width:33.33333%}.button-group.even-3 li>button,.button-group.even-3 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-3 li:first-child button,.button-group.even-3 li:first-child .button{border-left:0}.button-group.even-3 li button,.button-group.even-3 li .button{width:100%}.button-group.even-4 li{width:25%}.button-group.even-4 li>button,.button-group.even-4 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-4 li:first-child button,.button-group.even-4 li:first-child .button{border-left:0}.button-group.even-4 li button,.button-group.even-4 li .button{width:100%}.button-group.even-5 li{width:20%}.button-group.even-5 li>button,.button-group.even-5 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-5 li:first-child button,.button-group.even-5 li:first-child .button{border-left:0}.button-group.even-5 li button,.button-group.even-5 li .button{width:100%}.button-group.even-6 li{width:16.66667%}.button-group.even-6 li>button,.button-group.even-6 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-6 li:first-child button,.button-group.even-6 li:first-child .button{border-left:0}.button-group.even-6 li button,.button-group.even-6 li .button{width:100%}.button-group.even-7 li{width:14.28571%}.button-group.even-7 li>button,.button-group.even-7 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-7 li:first-child button,.button-group.even-7 li:first-child .button{border-left:0}.button-group.even-7 li button,.button-group.even-7 li .button{width:100%}.button-group.even-8 li{width:12.5%}.button-group.even-8 li>button,.button-group.even-8 li .button{border-left:1px solid;border-color:rgba(255,255,255,0.5)}.button-group.even-8 li:first-child button,.button-group.even-8 li:first-child .button{border-left:0}.button-group.even-8 li button,.button-group.even-8 li .button{width:100%}.button-bar{*zoom:1}.button-bar:before,.button-bar:after{content:" ";display:table}.button-bar:after{clear:both}.button-bar .button-group{float:left;margin-right:0.625rem}.button-bar .button-group div{overflow:hidden}.panel{border-style:solid;border-width:1px;border-color:#d8d8d8;margin-bottom:1.25rem;padding:1.25rem;background:#f2f2f2}.panel>:first-child{margin-top:0}.panel>:last-child{margin-bottom:0}.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6,.panel p{color:#333}.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6{line-height:1;margin-bottom:0.625rem}.panel h1.subheader,.panel h2.subheader,.panel h3.subheader,.panel h4.subheader,.panel h5.subheader,.panel h6.subheader{line-height:1.4}.panel.callout{border-style:solid;border-width:1px;border-color:#b6edff;margin-bottom:1.25rem;padding:1.25rem;background:#ecfaff}.panel.callout>:first-child{margin-top:0}.panel.callout>:last-child{margin-bottom:0}.panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6,.panel.callout p{color:#333}.panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6{line-height:1;margin-bottom:0.625rem}.panel.callout h1.subheader,.panel.callout h2.subheader,.panel.callout h3.subheader,.panel.callout h4.subheader,.panel.callout h5.subheader,.panel.callout h6.subheader{line-height:1.4}.panel.callout a:not(.button){color:#008cba}.panel.radius{-webkit-border-radius:3px;border-radius:3px}.dropdown.button,button.dropdown{position:relative;padding-right:3.5625rem}.dropdown.button:before,button.dropdown:before{position:absolute;content:"";width:0;height:0;display:block;border-style:solid;border-color:#fff transparent transparent transparent;top:50%}.dropdown.button:before,button.dropdown:before{border-width:0.375rem;right:1.40625rem;margin-top:-0.15625rem}.dropdown.button:before,button.dropdown:before{border-color:#fff transparent transparent transparent}.dropdown.button.tiny,button.dropdown.tiny{padding-right:2.625rem}.dropdown.button.tiny:before,button.dropdown.tiny:before{border-width:0.375rem;right:1.125rem;margin-top:-0.125rem}.dropdown.button.tiny:before,button.dropdown.tiny:before{border-color:#fff transparent transparent transparent}.dropdown.button.small,button.dropdown.small{padding-right:3.0625rem}.dropdown.button.small:before,button.dropdown.small:before{border-width:0.4375rem;right:1.3125rem;margin-top:-0.15625rem}.dropdown.button.small:before,button.dropdown.small:before{border-color:#fff transparent transparent transparent}.dropdown.button.large,button.dropdown.large{padding-right:3.625rem}.dropdown.button.large:before,button.dropdown.large:before{border-width:0.3125rem;right:1.71875rem;margin-top:-0.15625rem}.dropdown.button.large:before,button.dropdown.large:before{border-color:#fff transparent transparent transparent}.dropdown.button.secondary:before,button.dropdown.secondary:before{border-color:#333 transparent transparent transparent}div.switch{position:relative;padding:0;display:block;overflow:hidden;border-style:solid;border-width:1px;margin-bottom:1.25rem;height:2.25rem;background:#fff;border-color:#ccc}div.switch label{position:relative;left:0;z-index:2;float:left;width:50%;height:100%;margin:0;font-weight:bold;text-align:left;-webkit-transition:all 0.1s ease-out;-moz-transition:all 0.1s ease-out;transition:all 0.1s ease-out}div.switch input{position:absolute;z-index:3;opacity:0;width:100%;height:100%;-moz-appearance:none}div.switch input:hover,div.switch input:focus{cursor:pointer}div.switch span:last-child{position:absolute;top:-1px;left:-1px;z-index:1;display:block;padding:0;border-width:1px;border-style:solid;-webkit-transition:all 0.1s ease-out;-moz-transition:all 0.1s ease-out;transition:all 0.1s ease-out}div.switch input:not(:checked)+label{opacity:0}div.switch input:checked{display:none !important}div.switch input{left:0;display:block !important}div.switch input:first-of-type+label,div.switch input:first-of-type+span+label{left:-50%}div.switch input:first-of-type:checked+label,div.switch input:first-of-type:checked+span+label{left:0%}div.switch input:last-of-type+label,div.switch input:last-of-type+span+label{right:-50%;left:auto;text-align:right}div.switch input:last-of-type:checked+label,div.switch input:last-of-type:checked+span+label{right:0%;left:auto}div.switch span.custom{display:none !important}form.custom div.switch .hidden-field{margin-left:auto;position:absolute;visibility:visible}div.switch label{padding:0;line-height:2.3rem;font-size:0.875rem}div.switch input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-2.1875rem}div.switch span:last-child{width:2.25rem;height:2.25rem}div.switch span:last-child{border-color:#b3b3b3;background:#fff;background:-moz-linear-gradient(top, #fff 0%, #f2f2f2 100%);background:-webkit-linear-gradient(top, #fff 0%, #f2f2f2 100%);background:linear-gradient(to bottom, #fff 0%, #f2f2f2 100%);-webkit-box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 1000px #f3faf6,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px #f5f5f5;box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 980px #f3faf6,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px #f5f5f5}div.switch:hover span:last-child,div.switch:focus span:last-child{background:#fff;background:-moz-linear-gradient(top, #fff 0%, #e6e6e6 100%);background:-webkit-linear-gradient(top, #fff 0%, #e6e6e6 100%);background:linear-gradient(to bottom, #fff 0%, #e6e6e6 100%)}div.switch:active{background:transparent}div.switch.large{height:2.75rem}div.switch.large label{padding:0;line-height:2.3rem;font-size:1.0625rem}div.switch.large input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-2.6875rem}div.switch.large span:last-child{width:2.75rem;height:2.75rem}div.switch.small{height:1.75rem}div.switch.small label{padding:0;line-height:2.1rem;font-size:0.75rem}div.switch.small input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-1.6875rem}div.switch.small span:last-child{width:1.75rem;height:1.75rem}div.switch.tiny{height:1.375rem}div.switch.tiny label{padding:0;line-height:1.9rem;font-size:0.6875rem}div.switch.tiny input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-1.3125rem}div.switch.tiny span:last-child{width:1.375rem;height:1.375rem}div.switch.radius{-webkit-border-radius:4px;border-radius:4px}div.switch.radius span:last-child{-webkit-border-radius:3px;border-radius:3px}div.switch.round{-webkit-border-radius:1000px;border-radius:1000px}div.switch.round span:last-child{-webkit-border-radius:999px;border-radius:999px}div.switch.round label{padding:0 0.5625rem}@-webkit-keyframes webkitSiblingBugfix{from{position:relative}to{position:relative}}.th{line-height:0;display:inline-block;border:solid 4px #fff;max-width:100%;-webkit-box-shadow:0 0 0 1px rgba(0,0,0,0.2);box-shadow:0 0 0 1px rgba(0,0,0,0.2);-webkit-transition:all 200ms ease-out;-moz-transition:all 200ms ease-out;transition:all 200ms ease-out}.th:hover,.th:focus{-webkit-box-shadow:0 0 6px 1px rgba(0,140,186,0.5);box-shadow:0 0 6px 1px rgba(0,140,186,0.5)}.th.radius{-webkit-border-radius:3px;border-radius:3px}.pricing-table{border:solid 1px #ddd;margin-left:0;margin-bottom:1.25rem}.pricing-table *{list-style:none;line-height:1}.pricing-table .title{background-color:#333;padding:0.9375rem 1.25rem;text-align:center;color:#eee;font-weight:normal;font-size:1rem;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif}.pricing-table .price{background-color:#f6f6f6;padding:0.9375rem 1.25rem;text-align:center;color:#333;font-weight:normal;font-size:2rem;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif}.pricing-table .description{background-color:#fff;padding:0.9375rem;text-align:center;color:#777;font-size:0.75rem;font-weight:normal;line-height:1.4;border-bottom:dotted 1px #ddd}.pricing-table .bullet-item{background-color:#fff;padding:0.9375rem;text-align:center;color:#333;font-size:0.875rem;font-weight:normal;border-bottom:dotted 1px #ddd}.pricing-table .cta-button{background-color:#fff;text-align:center;padding:1.25rem 1.25rem 0}@-webkit-keyframes rotate{from{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@-moz-keyframes rotate{from{-moz-transform:rotate(0deg)}to{-moz-transform:rotate(360deg)}}@-o-keyframes rotate{from{-o-transform:rotate(0deg)}to{-o-transform:rotate(360deg)}}@keyframes rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.slideshow-wrapper{position:relative}.slideshow-wrapper ul{list-style-type:none;margin:0}.slideshow-wrapper ul li,.slideshow-wrapper ul li .orbit-caption{display:none}.slideshow-wrapper ul li:first-child{display:block}.slideshow-wrapper .orbit-container{background-color:transparent}.slideshow-wrapper .orbit-container li{display:block}.slideshow-wrapper .orbit-container li .orbit-caption{display:block}.preloader{display:block;width:40px;height:40px;position:absolute;top:50%;left:50%;margin-top:-20px;margin-left:-20px;border:solid 3px;border-color:#555 #fff;-webkit-border-radius:1000px;border-radius:1000px;-webkit-animation-name:rotate;-webkit-animation-duration:1.5s;-webkit-animation-iteration-count:infinite;-webkit-animation-timing-function:linear;-moz-animation-name:rotate;-moz-animation-duration:1.5s;-moz-animation-iteration-count:infinite;-moz-animation-timing-function:linear;-o-animation-name:rotate;-o-animation-duration:1.5s;-o-animation-iteration-count:infinite;-o-animation-timing-function:linear;animation-name:rotate;animation-duration:1.5s;animation-iteration-count:infinite;animation-timing-function:linear}.orbit-container{overflow:hidden;width:100%;position:relative;background:none}.orbit-container .orbit-slides-container{list-style:none;margin:0;padding:0;position:relative;-webkit-transform:translateZ(0)}.orbit-container .orbit-slides-container img{display:block;max-width:100%}.orbit-container .orbit-slides-container.fade>*{-webkit-transform:translate3d(0, 0, 0);opacity:0.01;transition:opacity 0.25s ease-in-out;-moz-transition:opacity 0.25s ease-in-out;-webkit-transition:opacity 0.25s ease-in-out}.orbit-container .orbit-slides-container.fade>*.animate-in{opacity:1;z-index:20;transition:opacity 500ms ease-in-out;-moz-transition:opacity 500ms ease-in-out;-webkit-transition:opacity 500ms ease-in-out}.orbit-container .orbit-slides-container.fade>*.animate-out{opacity:0.01;z-index:10;transition:opacity 500ms ease-in-out;-moz-transition:opacity 500ms ease-in-out;-webkit-transition:opacity 500ms ease-in-out}.orbit-container .orbit-slides-container.swipe-next>*{-webkit-transform:translate3d(100%, 0, 0)}.orbit-container .orbit-slides-container.swipe-next>*.animate-in{-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0);-webkit-transition-duration:500ms;-moz-transition-duration:500ms;-o-transition-duration:500ms;transition-duration:500ms}.orbit-container .orbit-slides-container.swipe-next>*.animate-out{-webkit-transform:translate3d(-100%, 0, 0);-moz-transform:translate3d(-100%, 0, 0);-ms-transform:translate3d(-100%, 0, 0);-o-transform:translate3d(-100%, 0, 0);transform:translate3d(-100%, 0, 0);-webkit-transition-duration:500ms;-moz-transition-duration:500ms;-o-transition-duration:500ms;transition-duration:500ms}.orbit-container .orbit-slides-container.swipe-prev>*{-webkit-transform:translate3d(-100%, 0, 0);-moz-transform:translate3d(-100%, 0, 0);-ms-transform:translate3d(-100%, 0, 0);-o-transform:translate3d(-100%, 0, 0);transform:translate3d(-100%, 0, 0)}.orbit-container .orbit-slides-container.swipe-prev>*.animate-in{-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0);-webkit-transition-duration:500ms;-moz-transition-duration:500ms;-o-transition-duration:500ms;transition-duration:500ms}.orbit-container .orbit-slides-container.swipe-prev>*.animate-out{-webkit-transform:translate3d(100%, 0, 0);-moz-transform:translate3d(100%, 0, 0);-ms-transform:translate3d(100%, 0, 0);-o-transform:translate3d(100%, 0, 0);transform:translate3d(100%, 0, 0);-webkit-transition-duration:500ms;-moz-transition-duration:500ms;-o-transition-duration:500ms;transition-duration:500ms}.orbit-container .orbit-slides-container>*{position:absolute;top:0;left:0;width:100%;-webkit-transform:translate3d(100%, 0, 0);-moz-transform:translate3d(100%, 0, 0);-ms-transform:translate3d(100%, 0, 0);-o-transform:translate3d(100%, 0, 0);transform:translate3d(100%, 0, 0)}.orbit-container .orbit-slides-container>*.active{opacity:1;top:0;left:0;-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0)}.orbit-container .orbit-slides-container>* .orbit-caption{position:absolute;bottom:0;background-color:rgba(51,51,51,0.8);color:#fff;width:100%;padding:0.625rem 0.875rem;font-size:0.875rem}.orbit-container .orbit-slide-number{position:absolute;top:10px;left:10px;font-size:12px;color:#fff;background:rgba(0,0,0,0);z-index:10}.orbit-container .orbit-slide-number span{font-weight:700;padding:0.3125rem}.orbit-container .orbit-timer{position:absolute;top:12px;right:10px;height:6px;width:100px;z-index:10}.orbit-container .orbit-timer .orbit-progress{height:3px;background-color:rgba(255,255,255,0.3);display:block;width:0%;position:relative;right:20px;top:5px}.orbit-container .orbit-timer>span{display:none;position:absolute;top:0px;right:0;width:11px;height:14px;border:solid 4px #fff;border-top:none;border-bottom:none}.orbit-container .orbit-timer.paused>span{right:-4px;top:0px;width:11px;height:14px;border:inset 8px;border-right-style:solid;border-color:transparent transparent transparent #fff}.orbit-container .orbit-timer.paused>span.dark{border-color:transparent transparent transparent #333}.orbit-container:hover .orbit-timer>span{display:block}.orbit-container .orbit-prev,.orbit-container .orbit-next{position:absolute;top:45%;margin-top:-25px;width:36px;height:60px;line-height:50px;color:white;background-color:none;text-indent:-9999px !important;z-index:10}.orbit-container .orbit-prev:hover,.orbit-container .orbit-next:hover{background-color:rgba(0,0,0,0.3)}.orbit-container .orbit-prev>span,.orbit-container .orbit-next>span{position:absolute;top:50%;margin-top:-10px;display:block;width:0;height:0;border:inset 10px}.orbit-container .orbit-prev{left:0}.orbit-container .orbit-prev>span{border-right-style:solid;border-color:transparent;border-right-color:#fff}.orbit-container .orbit-prev:hover>span{border-right-color:#fff}.orbit-container .orbit-next{right:0}.orbit-container .orbit-next>span{border-color:transparent;border-left-style:solid;border-left-color:#fff;left:50%;margin-left:-4px}.orbit-container .orbit-next:hover>span{border-left-color:#fff}.orbit-bullets-container{text-align:center}.orbit-bullets{margin:0 auto 30px auto;overflow:hidden;position:relative;top:10px;float:none;text-align:center;display:block}.orbit-bullets li{display:inline-block;width:0.5625rem;height:0.5625rem;background:#ccc;float:none;margin-right:6px;-webkit-border-radius:1000px;border-radius:1000px}.orbit-bullets li.active{background:#999}.orbit-bullets li:last-child{margin-right:0}.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:none}.touch .orbit-bullets{display:none}@media only screen and (min-width: 40.063em){.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:inherit}.touch .orbit-bullets{display:block}}@media only screen and (max-width: 40em){.orbit-stack-on-small .orbit-slides-container{height:auto !important}.orbit-stack-on-small .orbit-slides-container>*{position:relative;margin-left:0% !important}.orbit-stack-on-small .orbit-timer,.orbit-stack-on-small .orbit-next,.orbit-stack-on-small .orbit-prev,.orbit-stack-on-small .orbit-bullets{display:none}}[data-magellan-expedition]{background:#fff;z-index:50;min-width:100%;padding:10px}[data-magellan-expedition] .sub-nav{margin-bottom:0}[data-magellan-expedition] .sub-nav dd{margin-bottom:0}[data-magellan-expedition] .sub-nav a{line-height:1.8em}.tabs{*zoom:1;margin-bottom:0 !important}.tabs:before,.tabs:after{content:" ";display:table}.tabs:after{clear:both}.tabs dd{position:relative;margin-bottom:0 !important;float:left}.tabs dd>a{display:block;background:#efefef;color:#222;padding:1rem 2rem;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-size:1rem}.tabs dd>a:hover{background:#e1e1e1}.tabs dd.active a{background:#fff}.tabs.radius dd:first-child a{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.tabs.radius dd:last-child a{-moz-border-radius-bottomright:3px;-moz-border-radius-topright:3px;-webkit-border-bottom-right-radius:3px;-webkit-border-top-right-radius:3px;border-bottom-right-radius:3px;border-top-right-radius:3px}.tabs.vertical dd{position:inherit;float:none;display:block;top:auto}.tabs-content{*zoom:1;margin-bottom:1.5rem;width:100%}.tabs-content:before,.tabs-content:after{content:" ";display:table}.tabs-content:after{clear:both}.tabs-content>.content{display:none;float:left;padding:0.9375rem 0;width:100%}.tabs-content>.content.active{display:block;float:none}.tabs-content>.content.contained{padding:0.9375rem}.tabs-content.vertical{display:block}.tabs-content.vertical>.content{padding:0 0.9375rem}@media only screen and (min-width: 40.063em){.tabs.vertical{width:20%;float:left;margin-bottom:1.25rem}.tabs-content.vertical{width:80%;float:left;margin-left:-1px}}.no-js .tabs-content>.content{display:block;float:none}ul.pagination{display:block;height:1.5rem;margin-left:-0.3125rem}ul.pagination li{height:1.5rem;color:#222;font-size:0.875rem;margin-left:0.3125rem}ul.pagination li a{display:block;padding:0.0625rem 0.625rem 0.0625rem;color:#999;-webkit-border-radius:3px;border-radius:3px}ul.pagination li:hover a,ul.pagination li a:focus{background:#e6e6e6}ul.pagination li.unavailable a{cursor:default;color:#999}ul.pagination li.unavailable:hover a,ul.pagination li.unavailable a:focus{background:transparent}ul.pagination li.current a{background:#008cba;color:#fff;font-weight:bold;cursor:default}ul.pagination li.current a:hover,ul.pagination li.current a:focus{background:#008cba}ul.pagination li{float:left;display:block}.pagination-centered{text-align:center}.pagination-centered ul.pagination li{float:none;display:inline-block}.side-nav{display:block;margin:0;padding:0.875rem 0;list-style-type:none;list-style-position:inside;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif}.side-nav li{margin:0 0 0.4375rem 0;font-size:0.875rem}.side-nav li a:not(.button){display:block;color:#008cba}.side-nav li a:not(.button):hover,.side-nav li a:not(.button):focus{color:#1cc7ff}.side-nav li.active>a:first-child:not(.button){color:#1cc7ff;font-weight:normal;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif}.side-nav li.divider{border-top:1px solid;height:0;padding:0;list-style:none;border-top-color:#fff}.accordion{*zoom:1;margin-bottom:0}.accordion:before,.accordion:after{content:" ";display:table}.accordion:after{clear:both}.accordion dd{display:block;margin-bottom:0 !important}.accordion dd.active>a{background:#e8e8e8}.accordion dd>a{background:#efefef;color:#222;padding:1rem;display:block;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-size:1rem}.accordion dd>a:hover{background:#e3e3e3}.accordion .content{display:none;padding:0.9375rem}.accordion .content.active{display:block;background:#fff}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}.text-justify{text-align:justify !important}@media only screen and (max-width: 40em){.small-only-text-left{text-align:left !important}.small-only-text-right{text-align:right !important}.small-only-text-center{text-align:center !important}.small-only-text-justify{text-align:justify !important}}@media only screen{.small-text-left{text-align:left !important}.small-text-right{text-align:right !important}.small-text-center{text-align:center !important}.small-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em) and (max-width: 64em){.medium-only-text-left{text-align:left !important}.medium-only-text-right{text-align:right !important}.medium-only-text-center{text-align:center !important}.medium-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em){.medium-text-left{text-align:left !important}.medium-text-right{text-align:right !important}.medium-text-center{text-align:center !important}.medium-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em) and (max-width: 90em){.large-only-text-left{text-align:left !important}.large-only-text-right{text-align:right !important}.large-only-text-center{text-align:center !important}.large-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em){.large-text-left{text-align:left !important}.large-text-right{text-align:right !important}.large-text-center{text-align:center !important}.large-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em) and (max-width: 120em){.xlarge-only-text-left{text-align:left !important}.xlarge-only-text-right{text-align:right !important}.xlarge-only-text-center{text-align:center !important}.xlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em){.xlarge-text-left{text-align:left !important}.xlarge-text-right{text-align:right !important}.xlarge-text-center{text-align:center !important}.xlarge-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em) and (max-width: 99999999em){.xxlarge-only-text-left{text-align:left !important}.xxlarge-only-text-right{text-align:right !important}.xxlarge-only-text-center{text-align:center !important}.xxlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em){.xxlarge-text-left{text-align:left !important}.xxlarge-text-right{text-align:right !important}.xxlarge-text-center{text-align:center !important}.xxlarge-text-justify{text-align:justify !important}}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}.text-justify{text-align:justify !important}@media only screen and (max-width: 40em){.small-only-text-left{text-align:left !important}.small-only-text-right{text-align:right !important}.small-only-text-center{text-align:center !important}.small-only-text-justify{text-align:justify !important}}@media only screen{.small-text-left{text-align:left !important}.small-text-right{text-align:right !important}.small-text-center{text-align:center !important}.small-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em) and (max-width: 64em){.medium-only-text-left{text-align:left !important}.medium-only-text-right{text-align:right !important}.medium-only-text-center{text-align:center !important}.medium-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em){.medium-text-left{text-align:left !important}.medium-text-right{text-align:right !important}.medium-text-center{text-align:center !important}.medium-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em) and (max-width: 90em){.large-only-text-left{text-align:left !important}.large-only-text-right{text-align:right !important}.large-only-text-center{text-align:center !important}.large-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em){.large-text-left{text-align:left !important}.large-text-right{text-align:right !important}.large-text-center{text-align:center !important}.large-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em) and (max-width: 120em){.xlarge-only-text-left{text-align:left !important}.xlarge-only-text-right{text-align:right !important}.xlarge-only-text-center{text-align:center !important}.xlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em){.xlarge-text-left{text-align:left !important}.xlarge-text-right{text-align:right !important}.xlarge-text-center{text-align:center !important}.xlarge-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em) and (max-width: 99999999em){.xxlarge-only-text-left{text-align:left !important}.xxlarge-only-text-right{text-align:right !important}.xxlarge-only-text-center{text-align:center !important}.xxlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em){.xxlarge-text-left{text-align:left !important}.xxlarge-text-right{text-align:right !important}.xxlarge-text-center{text-align:center !important}.xxlarge-text-justify{text-align:justify !important}}div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0}a{color:#008cba;text-decoration:none;line-height:inherit}a:hover,a:focus{color:#0078a0}a img{border:none}p{font-family:inherit;font-weight:normal;font-size:1rem;line-height:1.6;margin-bottom:1.25rem;text-rendering:optimizeLegibility}p.lead{font-size:1.21875rem;line-height:1.6}p aside{font-size:0.875rem;line-height:1.35;font-style:italic}h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;font-style:normal;color:#222;text-rendering:optimizeLegibility;margin-top:0.2rem;margin-bottom:0.5rem;line-height:1.4}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-size:60%;color:#6f6f6f;line-height:0}h1{font-size:2.125rem}h2{font-size:1.6875rem}h3{font-size:1.375rem}h4{font-size:1.125rem}h5{font-size:1.125rem}h6{font-size:1rem}.subheader{line-height:1.4;color:#6f6f6f;font-weight:normal;margin-top:0.2rem;margin-bottom:0.5rem}hr{border:solid #ddd;border-width:1px 0 0;clear:both;margin:1.25rem 0 1.1875rem;height:0}em,i{font-style:italic;line-height:inherit}strong,b{font-weight:bold;line-height:inherit}small{font-size:60%;line-height:inherit}code{font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:bold;color:#bd260d}ul,ol,dl{font-size:1rem;line-height:1.6;margin-bottom:1.25rem;list-style-position:outside;font-family:inherit}ul{margin-left:1.1rem}ul.no-bullet{margin-left:0}ul.no-bullet li ul,ul.no-bullet li ol{margin-left:1.25rem;margin-bottom:0;list-style:none}ul li ul,ul li ol{margin-left:1.25rem;margin-bottom:0}ul.square li ul,ul.circle li ul,ul.disc li ul{list-style:inherit}ul.square{list-style-type:square;margin-left:1.1rem}ul.circle{list-style-type:circle;margin-left:1.1rem}ul.disc{list-style-type:disc;margin-left:1.1rem}ul.no-bullet{list-style:none}ol{margin-left:1.4rem}ol li ul,ol li ol{margin-left:1.25rem;margin-bottom:0}dl dt{margin-bottom:0.3rem;font-weight:bold}dl dd{margin-bottom:0.75rem}abbr,acronym{text-transform:uppercase;font-size:90%;color:#222;border-bottom:1px dotted #ddd;cursor:help}abbr{text-transform:none}blockquote{margin:0 0 1.25rem;padding:0.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #ddd}blockquote cite{display:block;font-size:0.8125rem;color:#555}blockquote cite:before{content:"\2014 \0020"}blockquote cite a,blockquote cite a:visited{color:#555}blockquote,blockquote p{line-height:1.6;color:#6f6f6f}.vcard{display:inline-block;margin:0 0 1.25rem 0;border:1px solid #ddd;padding:0.625rem 0.75rem}.vcard li{margin:0;display:block}.vcard .fn{font-weight:bold;font-size:0.9375rem}.vevent .summary{font-weight:bold}.vevent abbr{cursor:default;text-decoration:none;font-weight:bold;border:none;padding:0 0.0625rem}@media only screen and (min-width: 40.063em){h1,h2,h3,h4,h5,h6{line-height:1.4}h1{font-size:2.75rem}h2{font-size:2.3125rem}h3{font-size:1.6875rem}h4{font-size:1.4375rem}}.print-only{display:none !important}@media print{*{background:transparent !important;color:#000 !important;box-shadow:none !important;text-shadow:none !important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100% !important}@page{margin:0.5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}.hide-on-print{display:none !important}.print-only{display:block !important}.hide-for-print{display:none !important}.show-for-print{display:inherit !important}}.split.button{position:relative;padding-right:5.0625rem}.split.button span{display:block;height:100%;position:absolute;right:0;top:0;border-left:solid 1px}.split.button span:before{position:absolute;content:"";width:0;height:0;display:block;border-style:inset;top:50%;left:50%}.split.button span:active{background-color:rgba(0,0,0,0.1)}.split.button span{border-left-color:rgba(255,255,255,0.5)}.split.button span{width:3.09375rem}.split.button span:before{border-top-style:solid;border-width:0.375rem;top:48%;margin-left:-0.375rem}.split.button span:before{border-color:#fff transparent transparent transparent}.split.button.secondary span{border-left-color:rgba(255,255,255,0.5)}.split.button.secondary span:before{border-color:#fff transparent transparent transparent}.split.button.alert span{border-left-color:rgba(255,255,255,0.5)}.split.button.success span{border-left-color:rgba(255,255,255,0.5)}.split.button.tiny{padding-right:3.75rem}.split.button.tiny span{width:2.25rem}.split.button.tiny span:before{border-top-style:solid;border-width:0.375rem;top:48%;margin-left:-0.375rem}.split.button.small{padding-right:4.375rem}.split.button.small span{width:2.625rem}.split.button.small span:before{border-top-style:solid;border-width:0.4375rem;top:48%;margin-left:-0.375rem}.split.button.large{padding-right:5.5rem}.split.button.large span{width:3.4375rem}.split.button.large span:before{border-top-style:solid;border-width:0.3125rem;top:48%;margin-left:-0.375rem}.split.button.expand{padding-left:2rem}.split.button.secondary span:before{border-color:#333 transparent transparent transparent}.split.button.radius span{-moz-border-radius-bottomright:3px;-moz-border-radius-topright:3px;-webkit-border-bottom-right-radius:3px;-webkit-border-top-right-radius:3px;border-bottom-right-radius:3px;border-top-right-radius:3px}.split.button.round span{-moz-border-radius-bottomright:1000px;-moz-border-radius-topright:1000px;-webkit-border-bottom-right-radius:1000px;-webkit-border-top-right-radius:1000px;border-bottom-right-radius:1000px;border-top-right-radius:1000px}.reveal-modal-bg{position:fixed;height:100%;width:100%;background:#000;background:rgba(0,0,0,0.45);z-index:99;display:none;top:0;left:0}dialog,.reveal-modal{visibility:hidden;display:none;position:absolute;z-index:100;width:100vw;top:0;left:0;background-color:#fff;padding:1.25rem;border:solid 1px #666;-webkit-box-shadow:0 0 10px rgba(0,0,0,0.4);box-shadow:0 0 10px rgba(0,0,0,0.4)}@media only screen and (max-width: 40em){dialog,.reveal-modal{height:100vh;min-height:100vh}}@media only screen and (min-width: 40.063em){dialog,.reveal-modal{left:50%}}dialog .column,dialog .columns,.reveal-modal .column,.reveal-modal .columns{min-width:0}dialog>:first-child,.reveal-modal>:first-child{margin-top:0}dialog>:last-child,.reveal-modal>:last-child{margin-bottom:0}@media only screen and (min-width: 40.063em){dialog,.reveal-modal{margin-left:-40%;width:80%}}@media only screen and (min-width: 40.063em){dialog,.reveal-modal{top:6.25rem}}dialog .close-reveal-modal,.reveal-modal .close-reveal-modal{font-size:2.5rem;line-height:1;position:absolute;top:0.5rem;right:0.6875rem;color:#aaa;font-weight:bold;cursor:pointer}dialog[open]{display:block;visibility:visible}@media only screen and (min-width: 40.063em){dialog,.reveal-modal{padding:1.875rem}dialog.full,.reveal-modal.full{top:0;left:0;height:100vh;min-height:100vh;margin-left:0 !important}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog,.reveal-modal{top:6.25rem}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.tiny,.reveal-modal.tiny{margin-left:-15%;width:30%}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.small,.reveal-modal.small{margin-left:-20%;width:40%}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.medium,.reveal-modal.medium{margin-left:-30%;width:60%}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.large,.reveal-modal.large{margin-left:-35%;width:70%}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.xlarge,.reveal-modal.xlarge{margin-left:-47.5%;width:95%}}@media only screen and (min-width: 40.063em) and (min-width: 40.063em){dialog.full,.reveal-modal.full{margin-left:-50vw;width:100vw}}@media print{dialog,.reveal-modal{background:#fff !important}}.has-tip{border-bottom:dotted 1px #ccc;cursor:help;font-weight:bold;color:#333}.has-tip:hover,.has-tip:focus{border-bottom:dotted 1px #003f54;color:#008cba}.has-tip.tip-left,.has-tip.tip-right{float:none !important}.tooltip{display:none;position:absolute;z-index:999;font-weight:normal;font-size:0.875rem;line-height:1.3;padding:0.75rem;max-width:85%;left:50%;width:100%;color:#fff;background:#333}.tooltip>.nub{display:block;left:5px;position:absolute;width:0;height:0;border:solid 5px;border-color:transparent transparent #333 transparent;top:-10px}.tooltip>.nub.rtl{left:auto;right:5px}.tooltip.radius{-webkit-border-radius:3px;border-radius:3px}.tooltip.round{-webkit-border-radius:1000px;border-radius:1000px}.tooltip.round>.nub{left:2rem}.tooltip.opened{color:#008cba !important;border-bottom:dotted 1px #003f54 !important}.tap-to-close{display:block;font-size:0.625rem;color:#777;font-weight:normal}@media only screen and (min-width: 40.063em){.tooltip>.nub{border-color:transparent transparent #333 transparent;top:-10px}.tooltip.tip-top>.nub{border-color:#333 transparent transparent transparent;top:auto;bottom:-10px}.tooltip.tip-left,.tooltip.tip-right{float:none !important}.tooltip.tip-left>.nub{border-color:transparent transparent transparent #333;right:-10px;left:auto;top:50%;margin-top:-5px}.tooltip.tip-right>.nub{border-color:transparent #333 transparent transparent;right:auto;left:-10px;top:50%;margin-top:-5px}}.clearing-thumbs,[data-clearing]{*zoom:1;margin-bottom:0;margin-left:0;list-style:none}.clearing-thumbs:before,.clearing-thumbs:after,[data-clearing]:before,[data-clearing]:after{content:" ";display:table}.clearing-thumbs:after,[data-clearing]:after{clear:both}.clearing-thumbs li,[data-clearing] li{float:left;margin-right:10px}.clearing-thumbs[class*="block-grid-"] li,[data-clearing][class*="block-grid-"] li{margin-right:0}.clearing-blackout{background:#333;position:fixed;width:100%;height:100%;top:0;left:0;z-index:998}.clearing-blackout .clearing-close{display:block}.clearing-container{position:relative;z-index:998;height:100%;overflow:hidden;margin:0}.clearing-touch-label{position:absolute;top:50%;left:50%;color:#aaa;font-size:0.6em}.visible-img{height:95%;position:relative}.visible-img img{position:absolute;left:50%;top:50%;margin-left:-50%;max-height:100%;max-width:100%}.clearing-caption{color:#ccc;font-size:0.875em;line-height:1.3;margin-bottom:0;text-align:center;bottom:0;background:#333;width:100%;padding:10px 30px 20px;position:absolute;left:0}.clearing-close{z-index:999;padding-left:20px;padding-top:10px;font-size:30px;line-height:1;color:#ccc;display:none}.clearing-close:hover,.clearing-close:focus{color:#ccc}.clearing-assembled .clearing-container{height:100%}.clearing-assembled .clearing-container .carousel>ul{display:none}.clearing-feature li{display:none}.clearing-feature li.clearing-featured-img{display:block}@media only screen and (min-width: 40.063em){.clearing-main-prev,.clearing-main-next{position:absolute;height:100%;width:40px;top:0}.clearing-main-prev>span,.clearing-main-next>span{position:absolute;top:50%;display:block;width:0;height:0;border:solid 12px}.clearing-main-prev>span:hover,.clearing-main-next>span:hover{opacity:0.8}.clearing-main-prev{left:0}.clearing-main-prev>span{left:5px;border-color:transparent;border-right-color:#ccc}.clearing-main-next{right:0}.clearing-main-next>span{border-color:transparent;border-left-color:#ccc}.clearing-main-prev.disabled,.clearing-main-next.disabled{opacity:0.3}.clearing-assembled .clearing-container .carousel{background:rgba(51,51,51,0.8);height:120px;margin-top:10px;text-align:center}.clearing-assembled .clearing-container .carousel>ul{display:inline-block;z-index:999;height:100%;position:relative;float:none}.clearing-assembled .clearing-container .carousel>ul li{display:block;width:120px;min-height:inherit;float:left;overflow:hidden;margin-right:0;padding:0;position:relative;cursor:pointer;opacity:0.4}.clearing-assembled .clearing-container .carousel>ul li.fix-height img{height:100%;max-width:none}.clearing-assembled .clearing-container .carousel>ul li a.th{border:none;-webkit-box-shadow:none;box-shadow:none;display:block}.clearing-assembled .clearing-container .carousel>ul li img{cursor:pointer !important;width:100% !important}.clearing-assembled .clearing-container .carousel>ul li.visible{opacity:1}.clearing-assembled .clearing-container .carousel>ul li:hover{opacity:0.8}.clearing-assembled .clearing-container .visible-img{background:#333;overflow:hidden;height:85%}.clearing-close{position:absolute;top:10px;right:20px;padding-left:0;padding-top:0}}.progress{background-color:#f6f6f6;height:1.5625rem;border:1px solid #fff;padding:0.125rem;margin-bottom:0.625rem}.progress .meter{background:#008cba;height:100%;display:block}.progress.secondary .meter{background:#e7e7e7;height:100%;display:block}.progress.success .meter{background:#43ac6a;height:100%;display:block}.progress.alert .meter{background:#f04124;height:100%;display:block}.progress.radius{-webkit-border-radius:3px;border-radius:3px}.progress.radius .meter{-webkit-border-radius:2px;border-radius:2px}.progress.round{-webkit-border-radius:1000px;border-radius:1000px}.progress.round .meter{-webkit-border-radius:999px;border-radius:999px}.sub-nav{display:block;width:auto;overflow:hidden;margin:-0.25rem 0 1.125rem;padding-top:0.25rem;margin-right:0;margin-left:-0.75rem}.sub-nav dt{text-transform:uppercase}.sub-nav dt,.sub-nav dd,.sub-nav li{float:left;display:inline;margin-left:1rem;margin-bottom:0.625rem;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;font-size:0.875rem;color:#999}.sub-nav dt a,.sub-nav dd a,.sub-nav li a{text-decoration:none;color:#999;padding:0.1875rem 1rem}.sub-nav dt a:hover,.sub-nav dd a:hover,.sub-nav li a:hover{color:#737373}.sub-nav dt.active a,.sub-nav dd.active a,.sub-nav li.active a{-webkit-border-radius:3px;border-radius:3px;font-weight:normal;background:#008cba;padding:0.1875rem 1rem;cursor:default;color:#fff}.sub-nav dt.active a:hover,.sub-nav dd.active a:hover,.sub-nav li.active a:hover{background:#0078a0}.joyride-list{display:none}.joyride-tip-guide{display:none;position:absolute;background:#333;color:#fff;z-index:101;top:0;left:2.5%;font-family:inherit;font-weight:normal;width:95%}.lt-ie9 .joyride-tip-guide{max-width:800px;left:50%;margin-left:-400px}.joyride-content-wrapper{width:100%;padding:1.125rem 1.25rem 1.5rem}.joyride-content-wrapper .button{margin-bottom:0 !important}.joyride-tip-guide .joyride-nub{display:block;position:absolute;left:22px;width:0;height:0;border:10px solid #333}.joyride-tip-guide .joyride-nub.top{border-top-style:solid;border-color:#333;border-top-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;top:-20px}.joyride-tip-guide .joyride-nub.bottom{border-bottom-style:solid;border-color:#333 !important;border-bottom-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;bottom:-20px}.joyride-tip-guide .joyride-nub.right{right:-20px}.joyride-tip-guide .joyride-nub.left{left:-20px}.joyride-tip-guide h1,.joyride-tip-guide h2,.joyride-tip-guide h3,.joyride-tip-guide h4,.joyride-tip-guide h5,.joyride-tip-guide h6{line-height:1.25;margin:0;font-weight:bold;color:#fff}.joyride-tip-guide p{margin:0 0 1.125rem 0;font-size:0.875rem;line-height:1.3}.joyride-timer-indicator-wrap{width:50px;height:3px;border:solid 1px #555;position:absolute;right:1.0625rem;bottom:1rem}.joyride-timer-indicator{display:block;width:0;height:inherit;background:#666}.joyride-close-tip{position:absolute;right:12px;top:10px;color:#777 !important;text-decoration:none;font-size:24px;font-weight:normal;line-height:0.5 !important}.joyride-close-tip:hover,.joyride-close-tip:focus{color:#eee !important}.joyride-modal-bg{position:fixed;height:100%;width:100%;background:transparent;background:rgba(0,0,0,0.5);z-index:100;display:none;top:0;left:0;cursor:pointer}.joyride-expose-wrapper{background-color:#ffffff;position:absolute;border-radius:3px;z-index:102;-moz-box-shadow:0 0 30px #fff;-webkit-box-shadow:0 0 15px #fff;box-shadow:0 0 15px #fff}.joyride-expose-cover{background:transparent;border-radius:3px;position:absolute;z-index:9999;top:0;left:0}@media only screen and (min-width: 40.063em){.joyride-tip-guide{width:300px;left:inherit}.joyride-tip-guide .joyride-nub.bottom{border-color:#333 !important;border-bottom-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;bottom:-20px}.joyride-tip-guide .joyride-nub.right{border-color:#333 !important;border-top-color:transparent !important;border-right-color:transparent !important;border-bottom-color:transparent !important;top:22px;left:auto;right:-20px}.joyride-tip-guide .joyride-nub.left{border-color:#333 !important;border-top-color:transparent !important;border-left-color:transparent !important;border-bottom-color:transparent !important;top:22px;left:-20px;right:auto}}.label{font-weight:normal;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;text-align:center;text-decoration:none;line-height:1;white-space:nowrap;display:inline-block;position:relative;margin-bottom:inherit;padding:0.25rem 0.5rem 0.375rem;font-size:0.6875rem;background-color:#008cba;color:#fff}.label.radius{-webkit-border-radius:3px;border-radius:3px}.label.round{-webkit-border-radius:1000px;border-radius:1000px}.label.alert{background-color:#f04124;color:#fff}.label.success{background-color:#43ac6a;color:#fff}.label.secondary{background-color:#e7e7e7;color:#333}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}.text-justify{text-align:justify !important}@media only screen and (max-width: 40em){.small-only-text-left{text-align:left !important}.small-only-text-right{text-align:right !important}.small-only-text-center{text-align:center !important}.small-only-text-justify{text-align:justify !important}}@media only screen{.small-text-left{text-align:left !important}.small-text-right{text-align:right !important}.small-text-center{text-align:center !important}.small-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em) and (max-width: 64em){.medium-only-text-left{text-align:left !important}.medium-only-text-right{text-align:right !important}.medium-only-text-center{text-align:center !important}.medium-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 40.063em){.medium-text-left{text-align:left !important}.medium-text-right{text-align:right !important}.medium-text-center{text-align:center !important}.medium-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em) and (max-width: 90em){.large-only-text-left{text-align:left !important}.large-only-text-right{text-align:right !important}.large-only-text-center{text-align:center !important}.large-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 64.063em){.large-text-left{text-align:left !important}.large-text-right{text-align:right !important}.large-text-center{text-align:center !important}.large-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em) and (max-width: 120em){.xlarge-only-text-left{text-align:left !important}.xlarge-only-text-right{text-align:right !important}.xlarge-only-text-center{text-align:center !important}.xlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 90.063em){.xlarge-text-left{text-align:left !important}.xlarge-text-right{text-align:right !important}.xlarge-text-center{text-align:center !important}.xlarge-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em) and (max-width: 99999999em){.xxlarge-only-text-left{text-align:left !important}.xxlarge-only-text-right{text-align:right !important}.xxlarge-only-text-center{text-align:center !important}.xxlarge-only-text-justify{text-align:justify !important}}@media only screen and (min-width: 120.063em){.xxlarge-text-left{text-align:left !important}.xxlarge-text-right{text-align:right !important}.xxlarge-text-center{text-align:center !important}.xxlarge-text-justify{text-align:justify !important}}.off-canvas-wrap{-webkit-backface-visibility:hidden;position:relative;width:100%;overflow-x:hidden}.off-canvas-wrap.move-right,.off-canvas-wrap.move-left{height:100%}.inner-wrap{-webkit-backface-visibility:hidden;position:relative;width:100%;*zoom:1;-webkit-transition:-webkit-transform 500ms ease;-moz-transition:-moz-transform 500ms ease;-ms-transition:-ms-transform 500ms ease;-o-transition:-o-transform 500ms ease;transition:transform 500ms ease}.inner-wrap:before,.inner-wrap:after{content:" ";display:table}.inner-wrap:after{clear:both}.tab-bar{-webkit-backface-visibility:hidden;background:#333;color:#fff;height:2.8125rem;line-height:2.8125rem;position:relative}.tab-bar h1,.tab-bar h2,.tab-bar h3,.tab-bar h4,.tab-bar h5,.tab-bar h6{color:#fff;font-weight:bold;line-height:2.8125rem;margin:0}.tab-bar h1,.tab-bar h2,.tab-bar h3,.tab-bar h4{font-size:1.125rem}.left-small{width:2.8125rem;height:2.8125rem;position:absolute;top:0;border-right:solid 1px #1a1a1a;left:0}.right-small{width:2.8125rem;height:2.8125rem;position:absolute;top:0;border-left:solid 1px #1a1a1a;right:0}.tab-bar-section{padding:0 0.625rem;position:absolute;text-align:center;height:2.8125rem;top:0}@media only screen and (min-width: 40.063em){.tab-bar-section{text-align:left}}.tab-bar-section.left{left:0;right:2.8125rem}.tab-bar-section.right{left:2.8125rem;right:0}.tab-bar-section.middle{left:2.8125rem;right:2.8125rem}.tab-bar .menu-icon{text-indent:2.1875rem;width:2.8125rem;height:2.8125rem;display:block;line-height:2.0625rem;padding:0;color:#fff;position:relative}.tab-bar .menu-icon span{position:absolute;display:block;height:0;width:1rem;top:0.9375rem;left:0.90625rem;-webkit-box-shadow:1px 0px 1px 1px #fff,1px 7px 1px 1px #fff,1px 14px 1px 1px #fff;box-shadow:0 0px 0 1px #fff,0 7px 0 1px #fff,0 14px 0 1px #fff}.tab-bar .menu-icon:hover span{-webkit-box-shadow:1px 0px 1px 1px #b3b3b3,1px 7px 1px 1px #b3b3b3,1px 14px 1px 1px #b3b3b3;box-shadow:0 0px 0 1px #b3b3b3,0 7px 0 1px #b3b3b3,0 14px 0 1px #b3b3b3}.left-off-canvas-menu{-webkit-backface-visibility:hidden;width:15.625rem;top:0;bottom:0;position:absolute;overflow-y:auto;background:#333;z-index:1001;box-sizing:content-box;-webkit-overflow-scrolling:touch;-webkit-transform:translate3d(-100%, 0, 0);-moz-transform:translate3d(-100%, 0, 0);-ms-transform:translate3d(-100%, 0, 0);-o-transform:translate3d(-100%, 0, 0);transform:translate3d(-100%, 0, 0);left:0}.left-off-canvas-menu *{-webkit-backface-visibility:hidden}.right-off-canvas-menu{-webkit-backface-visibility:hidden;width:15.625rem;top:0;bottom:0;position:absolute;overflow-y:auto;background:#333;z-index:1001;box-sizing:content-box;-webkit-overflow-scrolling:touch;-webkit-transform:translate3d(100%, 0, 0);-moz-transform:translate3d(100%, 0, 0);-ms-transform:translate3d(100%, 0, 0);-o-transform:translate3d(100%, 0, 0);transform:translate3d(100%, 0, 0);right:0}.right-off-canvas-menu *{-webkit-backface-visibility:hidden}ul.off-canvas-list{list-style-type:none;padding:0;margin:0}ul.off-canvas-list li label{padding:0.3rem 0.9375rem;color:#999;text-transform:uppercase;font-weight:bold;background:#444;border-top:1px solid #5e5e5e;border-bottom:none;margin:0}ul.off-canvas-list li a{display:block;padding:0.66667rem;color:rgba(255,255,255,0.7);border-bottom:1px solid #262626;transition:background 300ms ease}ul.off-canvas-list li a:hover{background:#242424}.move-right>.inner-wrap{-webkit-transform:translate3d(15.625rem, 0, 0);-moz-transform:translate3d(15.625rem, 0, 0);-ms-transform:translate3d(15.625rem, 0, 0);-o-transform:translate3d(15.625rem, 0, 0);transform:translate3d(15.625rem, 0, 0)}.move-right .exit-off-canvas{-webkit-backface-visibility:hidden;transition:background 300ms ease;cursor:pointer;box-shadow:-4px 0 4px rgba(0,0,0,0.5),4px 0 4px rgba(0,0,0,0.5);display:block;position:absolute;background:rgba(255,255,255,0.2);top:0;bottom:0;left:0;right:0;z-index:1002;-webkit-tap-highlight-color:rgba(0,0,0,0)}@media only screen and (min-width: 40.063em){.move-right .exit-off-canvas:hover{background:rgba(255,255,255,0.05)}}.move-left>.inner-wrap{-webkit-transform:translate3d(-15.625rem, 0, 0);-moz-transform:translate3d(-15.625rem, 0, 0);-ms-transform:translate3d(-15.625rem, 0, 0);-o-transform:translate3d(-15.625rem, 0, 0);transform:translate3d(-15.625rem, 0, 0)}.move-left .exit-off-canvas{-webkit-backface-visibility:hidden;transition:background 300ms ease;cursor:pointer;box-shadow:-4px 0 4px rgba(0,0,0,0.5),4px 0 4px rgba(0,0,0,0.5);display:block;position:absolute;background:rgba(255,255,255,0.2);top:0;bottom:0;left:0;right:0;z-index:1002;-webkit-tap-highlight-color:rgba(0,0,0,0)}@media only screen and (min-width: 40.063em){.move-left .exit-off-canvas:hover{background:rgba(255,255,255,0.05)}}.csstransforms.no-csstransforms3d .left-off-canvas-menu{-webkit-transform:translate(-100%, 0);-moz-transform:translate(-100%, 0);-ms-transform:translate(-100%, 0);-o-transform:translate(-100%, 0);transform:translate(-100%, 0)}.csstransforms.no-csstransforms3d .right-off-canvas-menu{-webkit-transform:translate(100%, 0);-moz-transform:translate(100%, 0);-ms-transform:translate(100%, 0);-o-transform:translate(100%, 0);transform:translate(100%, 0)}.csstransforms.no-csstransforms3d .move-left>.inner-wrap{-webkit-transform:translate(-15.625rem, 0);-moz-transform:translate(-15.625rem, 0);-ms-transform:translate(-15.625rem, 0);-o-transform:translate(-15.625rem, 0);transform:translate(-15.625rem, 0)}.csstransforms.no-csstransforms3d .move-right>.inner-wrap{-webkit-transform:translate(15.625rem, 0);-moz-transform:translate(15.625rem, 0);-ms-transform:translate(15.625rem, 0);-o-transform:translate(15.625rem, 0);transform:translate(15.625rem, 0)}.no-csstransforms .left-off-canvas-menu{left:-15.625rem}.no-csstransforms .right-off-canvas-menu{right:-15.625rem}.no-csstransforms .move-left>.inner-wrap{right:15.625rem}.no-csstransforms .move-right>.inner-wrap{left:15.625rem}.f-dropdown{position:absolute;left:-9999px;list-style:none;margin-left:0;width:100%;max-height:none;height:auto;background:#fff;border:solid 1px #ccc;font-size:0.875rem;z-index:99;margin-top:2px;max-width:200px}.f-dropdown>*:first-child{margin-top:0}.f-dropdown>*:last-child{margin-bottom:0}.f-dropdown:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:transparent transparent #fff transparent;border-bottom-style:solid;position:absolute;top:-12px;left:10px;z-index:99}.f-dropdown:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:transparent transparent #ccc transparent;border-bottom-style:solid;position:absolute;top:-14px;left:9px;z-index:98}.f-dropdown.right:before{left:auto;right:10px}.f-dropdown.right:after{left:auto;right:9px}.f-dropdown.drop-right{position:absolute;left:-9999px;list-style:none;margin-left:0;width:100%;max-height:none;height:auto;background:#fff;border:solid 1px #ccc;font-size:0.875rem;z-index:99;margin-top:0;margin-left:2px;max-width:200px}.f-dropdown.drop-right>*:first-child{margin-top:0}.f-dropdown.drop-right>*:last-child{margin-bottom:0}.f-dropdown.drop-right:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:transparent #fff transparent transparent;border-right-style:solid;position:absolute;top:10px;left:-12px;z-index:99}.f-dropdown.drop-right:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:transparent #ccc transparent transparent;border-right-style:solid;position:absolute;top:9px;left:-14px;z-index:98}.f-dropdown.drop-left{position:absolute;left:-9999px;list-style:none;margin-left:0;width:100%;max-height:none;height:auto;background:#fff;border:solid 1px #ccc;font-size:0.875rem;z-index:99;margin-top:0;margin-left:-2px;max-width:200px}.f-dropdown.drop-left>*:first-child{margin-top:0}.f-dropdown.drop-left>*:last-child{margin-bottom:0}.f-dropdown.drop-left:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:transparent transparent transparent #fff;border-left-style:solid;position:absolute;top:10px;right:-12px;left:auto;z-index:99}.f-dropdown.drop-left:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:transparent transparent transparent #ccc;border-left-style:solid;position:absolute;top:9px;right:-14px;left:auto;z-index:98}.f-dropdown.drop-top{position:absolute;left:-9999px;list-style:none;margin-left:0;width:100%;max-height:none;height:auto;background:#fff;border:solid 1px #ccc;font-size:0.875rem;z-index:99;margin-top:-2px;margin-left:0;max-width:200px}.f-dropdown.drop-top>*:first-child{margin-top:0}.f-dropdown.drop-top>*:last-child{margin-bottom:0}.f-dropdown.drop-top:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:#fff transparent transparent transparent;border-top-style:solid;position:absolute;top:auto;bottom:-12px;left:10px;right:auto;z-index:99}.f-dropdown.drop-top:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:#ccc transparent transparent transparent;border-top-style:solid;position:absolute;top:auto;bottom:-14px;left:9px;right:auto;z-index:98}.f-dropdown li{font-size:0.875rem;cursor:pointer;line-height:1.125rem;margin:0}.f-dropdown li:hover,.f-dropdown li:focus{background:#eee}.f-dropdown li a{display:block;padding:0.5rem;color:#555}.f-dropdown.content{position:absolute;left:-9999px;list-style:none;margin-left:0;padding:1.25rem;width:100%;height:auto;max-height:none;background:#fff;border:solid 1px #ccc;font-size:0.875rem;z-index:99;max-width:200px}.f-dropdown.content>*:first-child{margin-top:0}.f-dropdown.content>*:last-child{margin-bottom:0}.f-dropdown.tiny{max-width:200px}.f-dropdown.small{max-width:300px}.f-dropdown.medium{max-width:500px}.f-dropdown.large{max-width:800px}table{background:#fff;margin-bottom:1.25rem;border:solid 1px #ddd}table thead,table tfoot{background:#f5f5f5}table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:0.5rem 0.625rem 0.625rem;font-size:0.875rem;font-weight:bold;color:#222;text-align:left}table tr th,table tr td{padding:0.5625rem 0.625rem;font-size:0.875rem;color:#222}table tr.even,table tr.alt,table tr:nth-of-type(even){background:#f9f9f9}table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{display:table-cell;line-height:1.125rem}form{margin:0 0 1rem}form .row .row{margin:0 -0.5rem}form .row .row .column,form .row .row .columns{padding:0 0.5rem}form .row .row.collapse{margin:0}form .row .row.collapse .column,form .row .row.collapse .columns{padding:0}form .row .row.collapse input{-moz-border-radius-bottomright:0;-moz-border-radius-topright:0;-webkit-border-bottom-right-radius:0;-webkit-border-top-right-radius:0}form .row input.column,form .row input.columns,form .row textarea.column,form .row textarea.columns{padding-left:0.5rem}label{font-size:0.875rem;color:#4d4d4d;cursor:pointer;display:block;font-weight:normal;line-height:1.5;margin-bottom:0}label.right{float:none;text-align:right}label.inline{margin:0 0 1rem 0;padding:0.625rem 0}label small{text-transform:capitalize;color:#676767}select{-webkit-appearance:none !important;background-color:#fafafa;background-image:url("data:image/svg+xml;base64, PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZlcnNpb249IjEuMSIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iM3B4IiB2aWV3Qm94PSIwIDAgNiAzIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCA2IDMiIHhtbDpzcGFjZT0icHJlc2VydmUiPjxwb2x5Z29uIHBvaW50cz0iNS45OTIsMCAyLjk5MiwzIC0wLjAwOCwwICIvPjwvc3ZnPg==");background-repeat:no-repeat;background-position:97% center;border:1px solid #ccc;padding:0.5rem;font-size:0.875rem;-webkit-border-radius:0;border-radius:0}select.radius{-webkit-border-radius:3px;border-radius:3px}select:hover{background-color:#f3f3f3;border-color:#999}select::-ms-expand{display:none}@-moz-document url-prefix(){select{background:#fafafa}select:hover{background:#f3f3f3}}.prefix,.postfix{display:block;position:relative;z-index:2;text-align:center;width:100%;padding-top:0;padding-bottom:0;border-style:solid;border-width:1px;overflow:hidden;font-size:0.875rem;height:2.3125rem;line-height:2.3125rem}.postfix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125rem;border:none}.prefix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125rem;border:none}.prefix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.postfix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomright:3px;-moz-border-radius-topright:3px;-webkit-border-bottom-right-radius:3px;-webkit-border-top-right-radius:3px;border-bottom-right-radius:3px;border-top-right-radius:3px}.prefix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px}.postfix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomright:1000px;-moz-border-radius-topright:1000px;-webkit-border-bottom-right-radius:1000px;-webkit-border-top-right-radius:1000px;border-bottom-right-radius:1000px;border-top-right-radius:1000px}span.prefix,label.prefix{background:#f2f2f2;border-right:none;color:#333;border-color:#ccc}span.prefix.radius,label.prefix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}span.postfix,label.postfix{background:#f2f2f2;border-left:none;color:#333;border-color:#ccc}span.postfix.radius,label.postfix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomright:3px;-moz-border-radius-topright:3px;-webkit-border-bottom-right-radius:3px;-webkit-border-top-right-radius:3px;border-bottom-right-radius:3px;border-top-right-radius:3px}input[type="text"],input[type="password"],input[type="date"],input[type="datetime"],input[type="datetime-local"],input[type="month"],input[type="week"],input[type="email"],input[type="number"],input[type="search"],input[type="tel"],input[type="time"],input[type="url"],textarea{-webkit-appearance:none;background-color:#fff;font-family:inherit;border:1px solid #ccc;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);color:rgba(0,0,0,0.75);display:block;font-size:0.875rem;margin:0 0 1rem 0;padding:0.5rem;height:2.3125rem;width:100%;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transition:-webkit-box-shadow 0.45s,border-color 0.45s ease-in-out;-moz-transition:-moz-box-shadow 0.45s,border-color 0.45s ease-in-out;transition:box-shadow 0.45s,border-color 0.45s ease-in-out}input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{-webkit-box-shadow:0 0 5px #999;-moz-box-shadow:0 0 5px #999;box-shadow:0 0 5px #999;border-color:#999}input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{background:#fafafa;border-color:#999;outline:none}input[type="text"][disabled],fieldset[disabled] input[type="text"],input[type="password"][disabled],fieldset[disabled] input[type="password"],input[type="date"][disabled],fieldset[disabled] input[type="date"],input[type="datetime"][disabled],fieldset[disabled] input[type="datetime"],input[type="datetime-local"][disabled],fieldset[disabled] input[type="datetime-local"],input[type="month"][disabled],fieldset[disabled] input[type="month"],input[type="week"][disabled],fieldset[disabled] input[type="week"],input[type="email"][disabled],fieldset[disabled] input[type="email"],input[type="number"][disabled],fieldset[disabled] input[type="number"],input[type="search"][disabled],fieldset[disabled] input[type="search"],input[type="tel"][disabled],fieldset[disabled] input[type="tel"],input[type="time"][disabled],fieldset[disabled] input[type="time"],input[type="url"][disabled],fieldset[disabled] input[type="url"],textarea[disabled],fieldset[disabled] textarea{background-color:#ddd}input[type="text"].radius,input[type="password"].radius,input[type="date"].radius,input[type="datetime"].radius,input[type="datetime-local"].radius,input[type="month"].radius,input[type="week"].radius,input[type="email"].radius,input[type="number"].radius,input[type="search"].radius,input[type="tel"].radius,input[type="time"].radius,input[type="url"].radius,textarea.radius{-webkit-border-radius:3px;border-radius:3px}textarea[rows]{height:auto}select{height:2.3125rem}input[type="file"],input[type="checkbox"],input[type="radio"],select{margin:0 0 1rem 0}input[type="checkbox"]+label,input[type="radio"]+label{display:inline-block;margin-left:0.5rem;margin-right:1rem;margin-bottom:0;vertical-align:baseline}input[type="file"]{width:100%}fieldset{border:1px solid #ddd;padding:1.25rem;margin:1.125rem 0}fieldset legend{font-weight:bold;background:#fff;padding:0 0.1875rem;margin:0;margin-left:-0.1875rem}[data-abide] .error small.error,[data-abide] span.error,[data-abide] small.error{display:block;padding:0.375rem 0.5625rem 0.5625rem;margin-top:-1px;margin-bottom:1rem;font-size:0.75rem;font-weight:normal;font-style:italic;background:#f04124;color:#fff}[data-abide] span.error,[data-abide] small.error{display:none}span.error,small.error{display:block;padding:0.375rem 0.5625rem 0.5625rem;margin-top:-1px;margin-bottom:1rem;font-size:0.75rem;font-weight:normal;font-style:italic;background:#f04124;color:#fff}.error input,.error textarea,.error select{margin-bottom:0}.error input[type="checkbox"],.error input[type="radio"]{margin-bottom:1rem}.error label,.error label.error{color:#f04124}.error small.error{display:block;padding:0.375rem 0.5625rem 0.5625rem;margin-top:-1px;margin-bottom:1rem;font-size:0.75rem;font-weight:normal;font-style:italic;background:#f04124;color:#fff}.error>label>small{color:#676767;background:transparent;padding:0;text-transform:capitalize;font-style:normal;font-size:60%;margin:0;display:inline}.error span.error-message{display:block}input.error,textarea.error{margin-bottom:0}label.error{color:#f04124}.range-slider{display:block;position:relative;width:100%;height:1rem;border:1px solid #ddd;margin:1.25rem 0;touch-action:none;-ms-touch-action:none;background:#fafafa}.range-slider.vertical-range{display:block;position:relative;width:100%;height:1rem;border:1px solid #ddd;margin:1.25rem 0;touch-action:none;-ms-touch-action:none;display:inline-block;width:1rem;height:12.5rem}.range-slider.vertical-range .range-slider-handle{margin-top:0;margin-left:-0.5rem;position:absolute;bottom:-10.5rem}.range-slider.vertical-range .range-slider-active-segment{width:0.875rem;height:auto;bottom:0}.range-slider.radius{background:#fafafa;-webkit-border-radius:3px;border-radius:3px}.range-slider.radius .range-slider-handle{background:#008cba;-webkit-border-radius:3px;border-radius:3px}.range-slider.radius .range-slider-handle:hover{background:#007ba4}.range-slider.round{background:#fafafa;-webkit-border-radius:1000px;border-radius:1000px}.range-slider.round .range-slider-handle{background:#008cba;-webkit-border-radius:1000px;border-radius:1000px}.range-slider.round .range-slider-handle:hover{background:#007ba4}.range-slider-active-segment{display:inline-block;position:absolute;height:0.875rem;background:#e5e5e5}.range-slider-handle{display:inline-block;position:absolute;z-index:1;top:-0.3125rem;width:2rem;height:1.375rem;border:1px solid none;cursor:pointer;background:#008cba}.range-slider-handle:hover{background:#007ba4}[class*="block-grid-"]{display:block;padding:0;margin:0;*zoom:1}[class*="block-grid-"]:before,[class*="block-grid-"]:after{content:" ";display:table}[class*="block-grid-"]:after{clear:both}[class*="block-grid-"]>li{display:block;height:auto;float:left;padding:0 0.9375rem 1.875rem}@media only screen{.small-block-grid-1>li{width:100%;list-style:none}.small-block-grid-1>li:nth-of-type(n){clear:none}.small-block-grid-1>li:nth-of-type(1n+1){clear:both}.small-block-grid-1>li:nth-child(1n){padding-left:0rem;padding-right:0rem}.small-block-grid-2>li{width:50%;list-style:none}.small-block-grid-2>li:nth-of-type(n){clear:none}.small-block-grid-2>li:nth-of-type(2n+1){clear:both}.small-block-grid-2>li:nth-child(2n+1){padding-left:0rem;padding-right:0.9375rem}.small-block-grid-2>li:nth-child(2n){padding-left:0.9375rem;padding-right:0rem}.small-block-grid-3>li{width:33.33333%;list-style:none}.small-block-grid-3>li:nth-of-type(n){clear:none}.small-block-grid-3>li:nth-of-type(3n+1){clear:both}.small-block-grid-3>li:nth-child(3n+1){padding-left:0rem;padding-right:1.25rem}.small-block-grid-3>li:nth-child(3n+2){padding-left:0.625rem;padding-right:0.625rem}.small-block-grid-3>li:nth-child(3n){padding-left:1.25rem;padding-right:0rem}.small-block-grid-4>li{width:25%;list-style:none}.small-block-grid-4>li:nth-of-type(n){clear:none}.small-block-grid-4>li:nth-of-type(4n+1){clear:both}.small-block-grid-4>li:nth-child(4n+1){padding-left:0rem;padding-right:1.40625rem}.small-block-grid-4>li:nth-child(4n+2){padding-left:0.46875rem;padding-right:0.9375rem}.small-block-grid-4>li:nth-child(4n+3){padding-left:0.9375rem;padding-right:0.46875rem}.small-block-grid-4>li:nth-child(4n){padding-left:1.40625rem;padding-right:0rem}.small-block-grid-5>li{width:20%;list-style:none}.small-block-grid-5>li:nth-of-type(n){clear:none}.small-block-grid-5>li:nth-of-type(5n+1){clear:both}.small-block-grid-5>li:nth-child(5n+1){padding-left:0rem;padding-right:1.5rem}.small-block-grid-5>li:nth-child(5n+2){padding-left:0.375rem;padding-right:1.125rem}.small-block-grid-5>li:nth-child(5n+3){padding-left:0.75rem;padding-right:0.75rem}.small-block-grid-5>li:nth-child(5n+4){padding-left:1.125rem;padding-right:0.375rem}.small-block-grid-5>li:nth-child(5n){padding-left:1.5rem;padding-right:0rem}.small-block-grid-6>li{width:16.66667%;list-style:none}.small-block-grid-6>li:nth-of-type(n){clear:none}.small-block-grid-6>li:nth-of-type(6n+1){clear:both}.small-block-grid-6>li:nth-child(6n+1){padding-left:0rem;padding-right:1.5625rem}.small-block-grid-6>li:nth-child(6n+2){padding-left:0.3125rem;padding-right:1.25rem}.small-block-grid-6>li:nth-child(6n+3){padding-left:0.625rem;padding-right:0.9375rem}.small-block-grid-6>li:nth-child(6n+4){padding-left:0.9375rem;padding-right:0.625rem}.small-block-grid-6>li:nth-child(6n+5){padding-left:1.25rem;padding-right:0.3125rem}.small-block-grid-6>li:nth-child(6n){padding-left:1.5625rem;padding-right:0rem}.small-block-grid-7>li{width:14.28571%;list-style:none}.small-block-grid-7>li:nth-of-type(n){clear:none}.small-block-grid-7>li:nth-of-type(7n+1){clear:both}.small-block-grid-7>li:nth-child(7n+1){padding-left:0rem;padding-right:1.60714rem}.small-block-grid-7>li:nth-child(7n+2){padding-left:0.26786rem;padding-right:1.33929rem}.small-block-grid-7>li:nth-child(7n+3){padding-left:0.53571rem;padding-right:1.07143rem}.small-block-grid-7>li:nth-child(7n+4){padding-left:0.80357rem;padding-right:0.80357rem}.small-block-grid-7>li:nth-child(7n+5){padding-left:1.07143rem;padding-right:0.53571rem}.small-block-grid-7>li:nth-child(7n+6){padding-left:1.33929rem;padding-right:0.26786rem}.small-block-grid-7>li:nth-child(7n){padding-left:1.60714rem;padding-right:0rem}.small-block-grid-8>li{width:12.5%;list-style:none}.small-block-grid-8>li:nth-of-type(n){clear:none}.small-block-grid-8>li:nth-of-type(8n+1){clear:both}.small-block-grid-8>li:nth-child(8n+1){padding-left:0rem;padding-right:1.64063rem}.small-block-grid-8>li:nth-child(8n+2){padding-left:0.23438rem;padding-right:1.40625rem}.small-block-grid-8>li:nth-child(8n+3){padding-left:0.46875rem;padding-right:1.17188rem}.small-block-grid-8>li:nth-child(8n+4){padding-left:0.70313rem;padding-right:0.9375rem}.small-block-grid-8>li:nth-child(8n+5){padding-left:0.9375rem;padding-right:0.70313rem}.small-block-grid-8>li:nth-child(8n+6){padding-left:1.17188rem;padding-right:0.46875rem}.small-block-grid-8>li:nth-child(8n+7){padding-left:1.40625rem;padding-right:0.23438rem}.small-block-grid-8>li:nth-child(8n){padding-left:1.64063rem;padding-right:0rem}.small-block-grid-9>li{width:11.11111%;list-style:none}.small-block-grid-9>li:nth-of-type(n){clear:none}.small-block-grid-9>li:nth-of-type(9n+1){clear:both}.small-block-grid-9>li:nth-child(9n+1){padding-left:0rem;padding-right:1.66667rem}.small-block-grid-9>li:nth-child(9n+2){padding-left:0.20833rem;padding-right:1.45833rem}.small-block-grid-9>li:nth-child(9n+3){padding-left:0.41667rem;padding-right:1.25rem}.small-block-grid-9>li:nth-child(9n+4){padding-left:0.625rem;padding-right:1.04167rem}.small-block-grid-9>li:nth-child(9n+5){padding-left:0.83333rem;padding-right:0.83333rem}.small-block-grid-9>li:nth-child(9n+6){padding-left:1.04167rem;padding-right:0.625rem}.small-block-grid-9>li:nth-child(9n+7){padding-left:1.25rem;padding-right:0.41667rem}.small-block-grid-9>li:nth-child(9n+8){padding-left:1.45833rem;padding-right:0.20833rem}.small-block-grid-9>li:nth-child(9n){padding-left:1.66667rem;padding-right:0rem}.small-block-grid-10>li{width:10%;list-style:none}.small-block-grid-10>li:nth-of-type(n){clear:none}.small-block-grid-10>li:nth-of-type(10n+1){clear:both}.small-block-grid-10>li:nth-child(10n+1){padding-left:0rem;padding-right:1.6875rem}.small-block-grid-10>li:nth-child(10n+2){padding-left:0.1875rem;padding-right:1.5rem}.small-block-grid-10>li:nth-child(10n+3){padding-left:0.375rem;padding-right:1.3125rem}.small-block-grid-10>li:nth-child(10n+4){padding-left:0.5625rem;padding-right:1.125rem}.small-block-grid-10>li:nth-child(10n+5){padding-left:0.75rem;padding-right:0.9375rem}.small-block-grid-10>li:nth-child(10n+6){padding-left:0.9375rem;padding-right:0.75rem}.small-block-grid-10>li:nth-child(10n+7){padding-left:1.125rem;padding-right:0.5625rem}.small-block-grid-10>li:nth-child(10n+8){padding-left:1.3125rem;padding-right:0.375rem}.small-block-grid-10>li:nth-child(10n+9){padding-left:1.5rem;padding-right:0.1875rem}.small-block-grid-10>li:nth-child(10n){padding-left:1.6875rem;padding-right:0rem}.small-block-grid-11>li{width:9.09091%;list-style:none}.small-block-grid-11>li:nth-of-type(n){clear:none}.small-block-grid-11>li:nth-of-type(11n+1){clear:both}.small-block-grid-11>li:nth-child(11n+1){padding-left:0.0rem;padding-right:1.70455rem}.small-block-grid-11>li:nth-child(11n+2){padding-left:0.17045rem;padding-right:1.53409rem}.small-block-grid-11>li:nth-child(11n+3){padding-left:0.34091rem;padding-right:1.36364rem}.small-block-grid-11>li:nth-child(11n+4){padding-left:0.51136rem;padding-right:1.19318rem}.small-block-grid-11>li:nth-child(11n+5){padding-left:0.68182rem;padding-right:1.02273rem}.small-block-grid-11>li:nth-child(11n+6){padding-left:0.85227rem;padding-right:0.85227rem}.small-block-grid-11>li:nth-child(11n+7){padding-left:1.02273rem;padding-right:0.68182rem}.small-block-grid-11>li:nth-child(11n+8){padding-left:1.19318rem;padding-right:0.51136rem}.small-block-grid-11>li:nth-child(11n+9){padding-left:1.36364rem;padding-right:0.34091rem}.small-block-grid-11>li:nth-child(11n+10){padding-left:1.53409rem;padding-right:0.17045rem}.small-block-grid-11>li:nth-child(11n){padding-left:1.70455rem;padding-right:0.0rem}.small-block-grid-12>li{width:8.33333%;list-style:none}.small-block-grid-12>li:nth-of-type(n){clear:none}.small-block-grid-12>li:nth-of-type(12n+1){clear:both}.small-block-grid-12>li:nth-child(12n+1){padding-left:0rem;padding-right:1.71875rem}.small-block-grid-12>li:nth-child(12n+2){padding-left:0.15625rem;padding-right:1.5625rem}.small-block-grid-12>li:nth-child(12n+3){padding-left:0.3125rem;padding-right:1.40625rem}.small-block-grid-12>li:nth-child(12n+4){padding-left:0.46875rem;padding-right:1.25rem}.small-block-grid-12>li:nth-child(12n+5){padding-left:0.625rem;padding-right:1.09375rem}.small-block-grid-12>li:nth-child(12n+6){padding-left:0.78125rem;padding-right:0.9375rem}.small-block-grid-12>li:nth-child(12n+7){padding-left:0.9375rem;padding-right:0.78125rem}.small-block-grid-12>li:nth-child(12n+8){padding-left:1.09375rem;padding-right:0.625rem}.small-block-grid-12>li:nth-child(12n+9){padding-left:1.25rem;padding-right:0.46875rem}.small-block-grid-12>li:nth-child(12n+10){padding-left:1.40625rem;padding-right:0.3125rem}.small-block-grid-12>li:nth-child(12n+11){padding-left:1.5625rem;padding-right:0.15625rem}.small-block-grid-12>li:nth-child(12n){padding-left:1.71875rem;padding-right:0rem}}@media only screen and (min-width: 40.063em){.medium-block-grid-1>li{width:100%;list-style:none}.medium-block-grid-1>li:nth-of-type(n){clear:none}.medium-block-grid-1>li:nth-of-type(1n+1){clear:both}.medium-block-grid-1>li:nth-child(1n){padding-left:0rem;padding-right:0rem}.medium-block-grid-2>li{width:50%;list-style:none}.medium-block-grid-2>li:nth-of-type(n){clear:none}.medium-block-grid-2>li:nth-of-type(2n+1){clear:both}.medium-block-grid-2>li:nth-child(2n+1){padding-left:0rem;padding-right:0.9375rem}.medium-block-grid-2>li:nth-child(2n){padding-left:0.9375rem;padding-right:0rem}.medium-block-grid-3>li{width:33.33333%;list-style:none}.medium-block-grid-3>li:nth-of-type(n){clear:none}.medium-block-grid-3>li:nth-of-type(3n+1){clear:both}.medium-block-grid-3>li:nth-child(3n+1){padding-left:0rem;padding-right:1.25rem}.medium-block-grid-3>li:nth-child(3n+2){padding-left:0.625rem;padding-right:0.625rem}.medium-block-grid-3>li:nth-child(3n){padding-left:1.25rem;padding-right:0rem}.medium-block-grid-4>li{width:25%;list-style:none}.medium-block-grid-4>li:nth-of-type(n){clear:none}.medium-block-grid-4>li:nth-of-type(4n+1){clear:both}.medium-block-grid-4>li:nth-child(4n+1){padding-left:0rem;padding-right:1.40625rem}.medium-block-grid-4>li:nth-child(4n+2){padding-left:0.46875rem;padding-right:0.9375rem}.medium-block-grid-4>li:nth-child(4n+3){padding-left:0.9375rem;padding-right:0.46875rem}.medium-block-grid-4>li:nth-child(4n){padding-left:1.40625rem;padding-right:0rem}.medium-block-grid-5>li{width:20%;list-style:none}.medium-block-grid-5>li:nth-of-type(n){clear:none}.medium-block-grid-5>li:nth-of-type(5n+1){clear:both}.medium-block-grid-5>li:nth-child(5n+1){padding-left:0rem;padding-right:1.5rem}.medium-block-grid-5>li:nth-child(5n+2){padding-left:0.375rem;padding-right:1.125rem}.medium-block-grid-5>li:nth-child(5n+3){padding-left:0.75rem;padding-right:0.75rem}.medium-block-grid-5>li:nth-child(5n+4){padding-left:1.125rem;padding-right:0.375rem}.medium-block-grid-5>li:nth-child(5n){padding-left:1.5rem;padding-right:0rem}.medium-block-grid-6>li{width:16.66667%;list-style:none}.medium-block-grid-6>li:nth-of-type(n){clear:none}.medium-block-grid-6>li:nth-of-type(6n+1){clear:both}.medium-block-grid-6>li:nth-child(6n+1){padding-left:0rem;padding-right:1.5625rem}.medium-block-grid-6>li:nth-child(6n+2){padding-left:0.3125rem;padding-right:1.25rem}.medium-block-grid-6>li:nth-child(6n+3){padding-left:0.625rem;padding-right:0.9375rem}.medium-block-grid-6>li:nth-child(6n+4){padding-left:0.9375rem;padding-right:0.625rem}.medium-block-grid-6>li:nth-child(6n+5){padding-left:1.25rem;padding-right:0.3125rem}.medium-block-grid-6>li:nth-child(6n){padding-left:1.5625rem;padding-right:0rem}.medium-block-grid-7>li{width:14.28571%;list-style:none}.medium-block-grid-7>li:nth-of-type(n){clear:none}.medium-block-grid-7>li:nth-of-type(7n+1){clear:both}.medium-block-grid-7>li:nth-child(7n+1){padding-left:0rem;padding-right:1.60714rem}.medium-block-grid-7>li:nth-child(7n+2){padding-left:0.26786rem;padding-right:1.33929rem}.medium-block-grid-7>li:nth-child(7n+3){padding-left:0.53571rem;padding-right:1.07143rem}.medium-block-grid-7>li:nth-child(7n+4){padding-left:0.80357rem;padding-right:0.80357rem}.medium-block-grid-7>li:nth-child(7n+5){padding-left:1.07143rem;padding-right:0.53571rem}.medium-block-grid-7>li:nth-child(7n+6){padding-left:1.33929rem;padding-right:0.26786rem}.medium-block-grid-7>li:nth-child(7n){padding-left:1.60714rem;padding-right:0rem}.medium-block-grid-8>li{width:12.5%;list-style:none}.medium-block-grid-8>li:nth-of-type(n){clear:none}.medium-block-grid-8>li:nth-of-type(8n+1){clear:both}.medium-block-grid-8>li:nth-child(8n+1){padding-left:0rem;padding-right:1.64063rem}.medium-block-grid-8>li:nth-child(8n+2){padding-left:0.23438rem;padding-right:1.40625rem}.medium-block-grid-8>li:nth-child(8n+3){padding-left:0.46875rem;padding-right:1.17188rem}.medium-block-grid-8>li:nth-child(8n+4){padding-left:0.70313rem;padding-right:0.9375rem}.medium-block-grid-8>li:nth-child(8n+5){padding-left:0.9375rem;padding-right:0.70313rem}.medium-block-grid-8>li:nth-child(8n+6){padding-left:1.17188rem;padding-right:0.46875rem}.medium-block-grid-8>li:nth-child(8n+7){padding-left:1.40625rem;padding-right:0.23438rem}.medium-block-grid-8>li:nth-child(8n){padding-left:1.64063rem;padding-right:0rem}.medium-block-grid-9>li{width:11.11111%;list-style:none}.medium-block-grid-9>li:nth-of-type(n){clear:none}.medium-block-grid-9>li:nth-of-type(9n+1){clear:both}.medium-block-grid-9>li:nth-child(9n+1){padding-left:0rem;padding-right:1.66667rem}.medium-block-grid-9>li:nth-child(9n+2){padding-left:0.20833rem;padding-right:1.45833rem}.medium-block-grid-9>li:nth-child(9n+3){padding-left:0.41667rem;padding-right:1.25rem}.medium-block-grid-9>li:nth-child(9n+4){padding-left:0.625rem;padding-right:1.04167rem}.medium-block-grid-9>li:nth-child(9n+5){padding-left:0.83333rem;padding-right:0.83333rem}.medium-block-grid-9>li:nth-child(9n+6){padding-left:1.04167rem;padding-right:0.625rem}.medium-block-grid-9>li:nth-child(9n+7){padding-left:1.25rem;padding-right:0.41667rem}.medium-block-grid-9>li:nth-child(9n+8){padding-left:1.45833rem;padding-right:0.20833rem}.medium-block-grid-9>li:nth-child(9n){padding-left:1.66667rem;padding-right:0rem}.medium-block-grid-10>li{width:10%;list-style:none}.medium-block-grid-10>li:nth-of-type(n){clear:none}.medium-block-grid-10>li:nth-of-type(10n+1){clear:both}.medium-block-grid-10>li:nth-child(10n+1){padding-left:0rem;padding-right:1.6875rem}.medium-block-grid-10>li:nth-child(10n+2){padding-left:0.1875rem;padding-right:1.5rem}.medium-block-grid-10>li:nth-child(10n+3){padding-left:0.375rem;padding-right:1.3125rem}.medium-block-grid-10>li:nth-child(10n+4){padding-left:0.5625rem;padding-right:1.125rem}.medium-block-grid-10>li:nth-child(10n+5){padding-left:0.75rem;padding-right:0.9375rem}.medium-block-grid-10>li:nth-child(10n+6){padding-left:0.9375rem;padding-right:0.75rem}.medium-block-grid-10>li:nth-child(10n+7){padding-left:1.125rem;padding-right:0.5625rem}.medium-block-grid-10>li:nth-child(10n+8){padding-left:1.3125rem;padding-right:0.375rem}.medium-block-grid-10>li:nth-child(10n+9){padding-left:1.5rem;padding-right:0.1875rem}.medium-block-grid-10>li:nth-child(10n){padding-left:1.6875rem;padding-right:0rem}.medium-block-grid-11>li{width:9.09091%;list-style:none}.medium-block-grid-11>li:nth-of-type(n){clear:none}.medium-block-grid-11>li:nth-of-type(11n+1){clear:both}.medium-block-grid-11>li:nth-child(11n+1){padding-left:0.0rem;padding-right:1.70455rem}.medium-block-grid-11>li:nth-child(11n+2){padding-left:0.17045rem;padding-right:1.53409rem}.medium-block-grid-11>li:nth-child(11n+3){padding-left:0.34091rem;padding-right:1.36364rem}.medium-block-grid-11>li:nth-child(11n+4){padding-left:0.51136rem;padding-right:1.19318rem}.medium-block-grid-11>li:nth-child(11n+5){padding-left:0.68182rem;padding-right:1.02273rem}.medium-block-grid-11>li:nth-child(11n+6){padding-left:0.85227rem;padding-right:0.85227rem}.medium-block-grid-11>li:nth-child(11n+7){padding-left:1.02273rem;padding-right:0.68182rem}.medium-block-grid-11>li:nth-child(11n+8){padding-left:1.19318rem;padding-right:0.51136rem}.medium-block-grid-11>li:nth-child(11n+9){padding-left:1.36364rem;padding-right:0.34091rem}.medium-block-grid-11>li:nth-child(11n+10){padding-left:1.53409rem;padding-right:0.17045rem}.medium-block-grid-11>li:nth-child(11n){padding-left:1.70455rem;padding-right:0.0rem}.medium-block-grid-12>li{width:8.33333%;list-style:none}.medium-block-grid-12>li:nth-of-type(n){clear:none}.medium-block-grid-12>li:nth-of-type(12n+1){clear:both}.medium-block-grid-12>li:nth-child(12n+1){padding-left:0rem;padding-right:1.71875rem}.medium-block-grid-12>li:nth-child(12n+2){padding-left:0.15625rem;padding-right:1.5625rem}.medium-block-grid-12>li:nth-child(12n+3){padding-left:0.3125rem;padding-right:1.40625rem}.medium-block-grid-12>li:nth-child(12n+4){padding-left:0.46875rem;padding-right:1.25rem}.medium-block-grid-12>li:nth-child(12n+5){padding-left:0.625rem;padding-right:1.09375rem}.medium-block-grid-12>li:nth-child(12n+6){padding-left:0.78125rem;padding-right:0.9375rem}.medium-block-grid-12>li:nth-child(12n+7){padding-left:0.9375rem;padding-right:0.78125rem}.medium-block-grid-12>li:nth-child(12n+8){padding-left:1.09375rem;padding-right:0.625rem}.medium-block-grid-12>li:nth-child(12n+9){padding-left:1.25rem;padding-right:0.46875rem}.medium-block-grid-12>li:nth-child(12n+10){padding-left:1.40625rem;padding-right:0.3125rem}.medium-block-grid-12>li:nth-child(12n+11){padding-left:1.5625rem;padding-right:0.15625rem}.medium-block-grid-12>li:nth-child(12n){padding-left:1.71875rem;padding-right:0rem}}@media only screen and (min-width: 64.063em){.large-block-grid-1>li{width:100%;list-style:none}.large-block-grid-1>li:nth-of-type(n){clear:none}.large-block-grid-1>li:nth-of-type(1n+1){clear:both}.large-block-grid-1>li:nth-child(1n){padding-left:0rem;padding-right:0rem}.large-block-grid-2>li{width:50%;list-style:none}.large-block-grid-2>li:nth-of-type(n){clear:none}.large-block-grid-2>li:nth-of-type(2n+1){clear:both}.large-block-grid-2>li:nth-child(2n+1){padding-left:0rem;padding-right:0.9375rem}.large-block-grid-2>li:nth-child(2n){padding-left:0.9375rem;padding-right:0rem}.large-block-grid-3>li{width:33.33333%;list-style:none}.large-block-grid-3>li:nth-of-type(n){clear:none}.large-block-grid-3>li:nth-of-type(3n+1){clear:both}.large-block-grid-3>li:nth-child(3n+1){padding-left:0rem;padding-right:1.25rem}.large-block-grid-3>li:nth-child(3n+2){padding-left:0.625rem;padding-right:0.625rem}.large-block-grid-3>li:nth-child(3n){padding-left:1.25rem;padding-right:0rem}.large-block-grid-4>li{width:25%;list-style:none}.large-block-grid-4>li:nth-of-type(n){clear:none}.large-block-grid-4>li:nth-of-type(4n+1){clear:both}.large-block-grid-4>li:nth-child(4n+1){padding-left:0rem;padding-right:1.40625rem}.large-block-grid-4>li:nth-child(4n+2){padding-left:0.46875rem;padding-right:0.9375rem}.large-block-grid-4>li:nth-child(4n+3){padding-left:0.9375rem;padding-right:0.46875rem}.large-block-grid-4>li:nth-child(4n){padding-left:1.40625rem;padding-right:0rem}.large-block-grid-5>li{width:20%;list-style:none}.large-block-grid-5>li:nth-of-type(n){clear:none}.large-block-grid-5>li:nth-of-type(5n+1){clear:both}.large-block-grid-5>li:nth-child(5n+1){padding-left:0rem;padding-right:1.5rem}.large-block-grid-5>li:nth-child(5n+2){padding-left:0.375rem;padding-right:1.125rem}.large-block-grid-5>li:nth-child(5n+3){padding-left:0.75rem;padding-right:0.75rem}.large-block-grid-5>li:nth-child(5n+4){padding-left:1.125rem;padding-right:0.375rem}.large-block-grid-5>li:nth-child(5n){padding-left:1.5rem;padding-right:0rem}.large-block-grid-6>li{width:16.66667%;list-style:none}.large-block-grid-6>li:nth-of-type(n){clear:none}.large-block-grid-6>li:nth-of-type(6n+1){clear:both}.large-block-grid-6>li:nth-child(6n+1){padding-left:0rem;padding-right:1.5625rem}.large-block-grid-6>li:nth-child(6n+2){padding-left:0.3125rem;padding-right:1.25rem}.large-block-grid-6>li:nth-child(6n+3){padding-left:0.625rem;padding-right:0.9375rem}.large-block-grid-6>li:nth-child(6n+4){padding-left:0.9375rem;padding-right:0.625rem}.large-block-grid-6>li:nth-child(6n+5){padding-left:1.25rem;padding-right:0.3125rem}.large-block-grid-6>li:nth-child(6n){padding-left:1.5625rem;padding-right:0rem}.large-block-grid-7>li{width:14.28571%;list-style:none}.large-block-grid-7>li:nth-of-type(n){clear:none}.large-block-grid-7>li:nth-of-type(7n+1){clear:both}.large-block-grid-7>li:nth-child(7n+1){padding-left:0rem;padding-right:1.60714rem}.large-block-grid-7>li:nth-child(7n+2){padding-left:0.26786rem;padding-right:1.33929rem}.large-block-grid-7>li:nth-child(7n+3){padding-left:0.53571rem;padding-right:1.07143rem}.large-block-grid-7>li:nth-child(7n+4){padding-left:0.80357rem;padding-right:0.80357rem}.large-block-grid-7>li:nth-child(7n+5){padding-left:1.07143rem;padding-right:0.53571rem}.large-block-grid-7>li:nth-child(7n+6){padding-left:1.33929rem;padding-right:0.26786rem}.large-block-grid-7>li:nth-child(7n){padding-left:1.60714rem;padding-right:0rem}.large-block-grid-8>li{width:12.5%;list-style:none}.large-block-grid-8>li:nth-of-type(n){clear:none}.large-block-grid-8>li:nth-of-type(8n+1){clear:both}.large-block-grid-8>li:nth-child(8n+1){padding-left:0rem;padding-right:1.64063rem}.large-block-grid-8>li:nth-child(8n+2){padding-left:0.23438rem;padding-right:1.40625rem}.large-block-grid-8>li:nth-child(8n+3){padding-left:0.46875rem;padding-right:1.17188rem}.large-block-grid-8>li:nth-child(8n+4){padding-left:0.70313rem;padding-right:0.9375rem}.large-block-grid-8>li:nth-child(8n+5){padding-left:0.9375rem;padding-right:0.70313rem}.large-block-grid-8>li:nth-child(8n+6){padding-left:1.17188rem;padding-right:0.46875rem}.large-block-grid-8>li:nth-child(8n+7){padding-left:1.40625rem;padding-right:0.23438rem}.large-block-grid-8>li:nth-child(8n){padding-left:1.64063rem;padding-right:0rem}.large-block-grid-9>li{width:11.11111%;list-style:none}.large-block-grid-9>li:nth-of-type(n){clear:none}.large-block-grid-9>li:nth-of-type(9n+1){clear:both}.large-block-grid-9>li:nth-child(9n+1){padding-left:0rem;padding-right:1.66667rem}.large-block-grid-9>li:nth-child(9n+2){padding-left:0.20833rem;padding-right:1.45833rem}.large-block-grid-9>li:nth-child(9n+3){padding-left:0.41667rem;padding-right:1.25rem}.large-block-grid-9>li:nth-child(9n+4){padding-left:0.625rem;padding-right:1.04167rem}.large-block-grid-9>li:nth-child(9n+5){padding-left:0.83333rem;padding-right:0.83333rem}.large-block-grid-9>li:nth-child(9n+6){padding-left:1.04167rem;padding-right:0.625rem}.large-block-grid-9>li:nth-child(9n+7){padding-left:1.25rem;padding-right:0.41667rem}.large-block-grid-9>li:nth-child(9n+8){padding-left:1.45833rem;padding-right:0.20833rem}.large-block-grid-9>li:nth-child(9n){padding-left:1.66667rem;padding-right:0rem}.large-block-grid-10>li{width:10%;list-style:none}.large-block-grid-10>li:nth-of-type(n){clear:none}.large-block-grid-10>li:nth-of-type(10n+1){clear:both}.large-block-grid-10>li:nth-child(10n+1){padding-left:0rem;padding-right:1.6875rem}.large-block-grid-10>li:nth-child(10n+2){padding-left:0.1875rem;padding-right:1.5rem}.large-block-grid-10>li:nth-child(10n+3){padding-left:0.375rem;padding-right:1.3125rem}.large-block-grid-10>li:nth-child(10n+4){padding-left:0.5625rem;padding-right:1.125rem}.large-block-grid-10>li:nth-child(10n+5){padding-left:0.75rem;padding-right:0.9375rem}.large-block-grid-10>li:nth-child(10n+6){padding-left:0.9375rem;padding-right:0.75rem}.large-block-grid-10>li:nth-child(10n+7){padding-left:1.125rem;padding-right:0.5625rem}.large-block-grid-10>li:nth-child(10n+8){padding-left:1.3125rem;padding-right:0.375rem}.large-block-grid-10>li:nth-child(10n+9){padding-left:1.5rem;padding-right:0.1875rem}.large-block-grid-10>li:nth-child(10n){padding-left:1.6875rem;padding-right:0rem}.large-block-grid-11>li{width:9.09091%;list-style:none}.large-block-grid-11>li:nth-of-type(n){clear:none}.large-block-grid-11>li:nth-of-type(11n+1){clear:both}.large-block-grid-11>li:nth-child(11n+1){padding-left:0.0rem;padding-right:1.70455rem}.large-block-grid-11>li:nth-child(11n+2){padding-left:0.17045rem;padding-right:1.53409rem}.large-block-grid-11>li:nth-child(11n+3){padding-left:0.34091rem;padding-right:1.36364rem}.large-block-grid-11>li:nth-child(11n+4){padding-left:0.51136rem;padding-right:1.19318rem}.large-block-grid-11>li:nth-child(11n+5){padding-left:0.68182rem;padding-right:1.02273rem}.large-block-grid-11>li:nth-child(11n+6){padding-left:0.85227rem;padding-right:0.85227rem}.large-block-grid-11>li:nth-child(11n+7){padding-left:1.02273rem;padding-right:0.68182rem}.large-block-grid-11>li:nth-child(11n+8){padding-left:1.19318rem;padding-right:0.51136rem}.large-block-grid-11>li:nth-child(11n+9){padding-left:1.36364rem;padding-right:0.34091rem}.large-block-grid-11>li:nth-child(11n+10){padding-left:1.53409rem;padding-right:0.17045rem}.large-block-grid-11>li:nth-child(11n){padding-left:1.70455rem;padding-right:0.0rem}.large-block-grid-12>li{width:8.33333%;list-style:none}.large-block-grid-12>li:nth-of-type(n){clear:none}.large-block-grid-12>li:nth-of-type(12n+1){clear:both}.large-block-grid-12>li:nth-child(12n+1){padding-left:0rem;padding-right:1.71875rem}.large-block-grid-12>li:nth-child(12n+2){padding-left:0.15625rem;padding-right:1.5625rem}.large-block-grid-12>li:nth-child(12n+3){padding-left:0.3125rem;padding-right:1.40625rem}.large-block-grid-12>li:nth-child(12n+4){padding-left:0.46875rem;padding-right:1.25rem}.large-block-grid-12>li:nth-child(12n+5){padding-left:0.625rem;padding-right:1.09375rem}.large-block-grid-12>li:nth-child(12n+6){padding-left:0.78125rem;padding-right:0.9375rem}.large-block-grid-12>li:nth-child(12n+7){padding-left:0.9375rem;padding-right:0.78125rem}.large-block-grid-12>li:nth-child(12n+8){padding-left:1.09375rem;padding-right:0.625rem}.large-block-grid-12>li:nth-child(12n+9){padding-left:1.25rem;padding-right:0.46875rem}.large-block-grid-12>li:nth-child(12n+10){padding-left:1.40625rem;padding-right:0.3125rem}.large-block-grid-12>li:nth-child(12n+11){padding-left:1.5625rem;padding-right:0.15625rem}.large-block-grid-12>li:nth-child(12n){padding-left:1.71875rem;padding-right:0rem}}.flex-video{position:relative;padding-top:1.5625rem;padding-bottom:67.5%;height:0;margin-bottom:1rem;overflow:hidden}.flex-video.widescreen{padding-bottom:56.34%}.flex-video.vimeo{padding-top:0}.flex-video iframe,.flex-video object,.flex-video embed,.flex-video video{position:absolute;top:0;left:0;width:100%;height:100%}.keystroke,kbd{background-color:#ededed;border-color:#ddd;color:#222;border-style:solid;border-width:1px;margin:0;font-family:"Consolas","Menlo","Courier",monospace;font-size:inherit;padding:0.125rem 0.25rem 0;-webkit-border-radius:3px;border-radius:3px}@media only screen{.show-for-small-only,.show-for-small-up,.show-for-small,.show-for-small-down,.hide-for-medium-only,.hide-for-medium-up,.hide-for-medium,.show-for-medium-down,.hide-for-large-only,.hide-for-large-up,.hide-for-large,.show-for-large-down,.hide-for-xlarge-only,.hide-for-xlarge-up,.hide-for-xlarge,.show-for-xlarge-down,.hide-for-xxlarge-only,.hide-for-xxlarge-up,.hide-for-xxlarge,.show-for-xxlarge-down{display:inherit !important}.hide-for-small-only,.hide-for-small-up,.hide-for-small,.hide-for-small-down,.show-for-medium-only,.show-for-medium-up,.show-for-medium,.hide-for-medium-down,.show-for-large-only,.show-for-large-up,.show-for-large,.hide-for-large-down,.show-for-xlarge-only,.show-for-xlarge-up,.show-for-xlarge,.hide-for-xlarge-down,.show-for-xxlarge-only,.show-for-xxlarge-up,.show-for-xxlarge,.hide-for-xxlarge-down{display:none !important}table.show-for-small-only,table.show-for-small-up,table.show-for-small,table.show-for-small-down,table.hide-for-medium-only,table.hide-for-medium-up,table.hide-for-medium,table.show-for-medium-down,table.hide-for-large-only,table.hide-for-large-up,table.hide-for-large,table.show-for-large-down,table.hide-for-xlarge-only,table.hide-for-xlarge-up,table.hide-for-xlarge,table.show-for-xlarge-down,table.hide-for-xxlarge-only,table.hide-for-xxlarge-up,table.hide-for-xxlarge,table.show-for-xxlarge-down{display:table}thead.show-for-small-only,thead.show-for-small-up,thead.show-for-small,thead.show-for-small-down,thead.hide-for-medium-only,thead.hide-for-medium-up,thead.hide-for-medium,thead.show-for-medium-down,thead.hide-for-large-only,thead.hide-for-large-up,thead.hide-for-large,thead.show-for-large-down,thead.hide-for-xlarge-only,thead.hide-for-xlarge-up,thead.hide-for-xlarge,thead.show-for-xlarge-down,thead.hide-for-xxlarge-only,thead.hide-for-xxlarge-up,thead.hide-for-xxlarge,thead.show-for-xxlarge-down{display:table-header-group !important}tbody.show-for-small-only,tbody.show-for-small-up,tbody.show-for-small,tbody.show-for-small-down,tbody.hide-for-medium-only,tbody.hide-for-medium-up,tbody.hide-for-medium,tbody.show-for-medium-down,tbody.hide-for-large-only,tbody.hide-for-large-up,tbody.hide-for-large,tbody.show-for-large-down,tbody.hide-for-xlarge-only,tbody.hide-for-xlarge-up,tbody.hide-for-xlarge,tbody.show-for-xlarge-down,tbody.hide-for-xxlarge-only,tbody.hide-for-xxlarge-up,tbody.hide-for-xxlarge,tbody.show-for-xxlarge-down{display:table-row-group !important}tr.show-for-small-only,tr.show-for-small-up,tr.show-for-small,tr.show-for-small-down,tr.hide-for-medium-only,tr.hide-for-medium-up,tr.hide-for-medium,tr.show-for-medium-down,tr.hide-for-large-only,tr.hide-for-large-up,tr.hide-for-large,tr.show-for-large-down,tr.hide-for-xlarge-only,tr.hide-for-xlarge-up,tr.hide-for-xlarge,tr.show-for-xlarge-down,tr.hide-for-xxlarge-only,tr.hide-for-xxlarge-up,tr.hide-for-xxlarge,tr.show-for-xxlarge-down{display:table-row !important}th.show-for-small-only,td.show-for-small-only,th.show-for-small-up,td.show-for-small-up,th.show-for-small,td.show-for-small,th.show-for-small-down,td.show-for-small-down,th.hide-for-medium-only,td.hide-for-medium-only,th.hide-for-medium-up,td.hide-for-medium-up,th.hide-for-medium,td.hide-for-medium,th.show-for-medium-down,td.show-for-medium-down,th.hide-for-large-only,td.hide-for-large-only,th.hide-for-large-up,td.hide-for-large-up,th.hide-for-large,td.hide-for-large,th.show-for-large-down,td.show-for-large-down,th.hide-for-xlarge-only,td.hide-for-xlarge-only,th.hide-for-xlarge-up,td.hide-for-xlarge-up,th.hide-for-xlarge,td.hide-for-xlarge,th.show-for-xlarge-down,td.show-for-xlarge-down,th.hide-for-xxlarge-only,td.hide-for-xxlarge-only,th.hide-for-xxlarge-up,td.hide-for-xxlarge-up,th.hide-for-xxlarge,td.hide-for-xxlarge,th.show-for-xxlarge-down,td.show-for-xxlarge-down{display:table-cell !important}}@media only screen and (min-width: 40.063em){.hide-for-small-only,.show-for-small-up,.hide-for-small,.hide-for-small-down,.show-for-medium-only,.show-for-medium-up,.show-for-medium,.show-for-medium-down,.hide-for-large-only,.hide-for-large-up,.hide-for-large,.show-for-large-down,.hide-for-xlarge-only,.hide-for-xlarge-up,.hide-for-xlarge,.show-for-xlarge-down,.hide-for-xxlarge-only,.hide-for-xxlarge-up,.hide-for-xxlarge,.show-for-xxlarge-down{display:inherit !important}.show-for-small-only,.hide-for-small-up,.show-for-small,.show-for-small-down,.hide-for-medium-only,.hide-for-medium-up,.hide-for-medium,.hide-for-medium-down,.show-for-large-only,.show-for-large-up,.show-for-large,.hide-for-large-down,.show-for-xlarge-only,.show-for-xlarge-up,.show-for-xlarge,.hide-for-xlarge-down,.show-for-xxlarge-only,.show-for-xxlarge-up,.show-for-xxlarge,.hide-for-xxlarge-down{display:none !important}table.hide-for-small-only,table.show-for-small-up,table.hide-for-small,table.hide-for-small-down,table.show-for-medium-only,table.show-for-medium-up,table.show-for-medium,table.show-for-medium-down,table.hide-for-large-only,table.hide-for-large-up,table.hide-for-large,table.show-for-large-down,table.hide-for-xlarge-only,table.hide-for-xlarge-up,table.hide-for-xlarge,table.show-for-xlarge-down,table.hide-for-xxlarge-only,table.hide-for-xxlarge-up,table.hide-for-xxlarge,table.show-for-xxlarge-down{display:table}thead.hide-for-small-only,thead.show-for-small-up,thead.hide-for-small,thead.hide-for-small-down,thead.show-for-medium-only,thead.show-for-medium-up,thead.show-for-medium,thead.show-for-medium-down,thead.hide-for-large-only,thead.hide-for-large-up,thead.hide-for-large,thead.show-for-large-down,thead.hide-for-xlarge-only,thead.hide-for-xlarge-up,thead.hide-for-xlarge,thead.show-for-xlarge-down,thead.hide-for-xxlarge-only,thead.hide-for-xxlarge-up,thead.hide-for-xxlarge,thead.show-for-xxlarge-down{display:table-header-group !important}tbody.hide-for-small-only,tbody.show-for-small-up,tbody.hide-for-small,tbody.hide-for-small-down,tbody.show-for-medium-only,tbody.show-for-medium-up,tbody.show-for-medium,tbody.show-for-medium-down,tbody.hide-for-large-only,tbody.hide-for-large-up,tbody.hide-for-large,tbody.show-for-large-down,tbody.hide-for-xlarge-only,tbody.hide-for-xlarge-up,tbody.hide-for-xlarge,tbody.show-for-xlarge-down,tbody.hide-for-xxlarge-only,tbody.hide-for-xxlarge-up,tbody.hide-for-xxlarge,tbody.show-for-xxlarge-down{display:table-row-group !important}tr.hide-for-small-only,tr.show-for-small-up,tr.hide-for-small,tr.hide-for-small-down,tr.show-for-medium-only,tr.show-for-medium-up,tr.show-for-medium,tr.show-for-medium-down,tr.hide-for-large-only,tr.hide-for-large-up,tr.hide-for-large,tr.show-for-large-down,tr.hide-for-xlarge-only,tr.hide-for-xlarge-up,tr.hide-for-xlarge,tr.show-for-xlarge-down,tr.hide-for-xxlarge-only,tr.hide-for-xxlarge-up,tr.hide-for-xxlarge,tr.show-for-xxlarge-down{display:table-row !important}th.hide-for-small-only,td.hide-for-small-only,th.show-for-small-up,td.show-for-small-up,th.hide-for-small,td.hide-for-small,th.hide-for-small-down,td.hide-for-small-down,th.show-for-medium-only,td.show-for-medium-only,th.show-for-medium-up,td.show-for-medium-up,th.show-for-medium,td.show-for-medium,th.show-for-medium-down,td.show-for-medium-down,th.hide-for-large-only,td.hide-for-large-only,th.hide-for-large-up,td.hide-for-large-up,th.hide-for-large,td.hide-for-large,th.show-for-large-down,td.show-for-large-down,th.hide-for-xlarge-only,td.hide-for-xlarge-only,th.hide-for-xlarge-up,td.hide-for-xlarge-up,th.hide-for-xlarge,td.hide-for-xlarge,th.show-for-xlarge-down,td.show-for-xlarge-down,th.hide-for-xxlarge-only,td.hide-for-xxlarge-only,th.hide-for-xxlarge-up,td.hide-for-xxlarge-up,th.hide-for-xxlarge,td.hide-for-xxlarge,th.show-for-xxlarge-down,td.show-for-xxlarge-down{display:table-cell !important}}@media only screen and (min-width: 64.063em){.hide-for-small-only,.show-for-small-up,.hide-for-small,.hide-for-small-down,.hide-for-medium-only,.show-for-medium-up,.hide-for-medium,.hide-for-medium-down,.show-for-large-only,.show-for-large-up,.show-for-large,.show-for-large-down,.hide-for-xlarge-only,.hide-for-xlarge-up,.hide-for-xlarge,.show-for-xlarge-down,.hide-for-xxlarge-only,.hide-for-xxlarge-up,.hide-for-xxlarge,.show-for-xxlarge-down{display:inherit !important}.show-for-small-only,.hide-for-small-up,.show-for-small,.show-for-small-down,.show-for-medium-only,.hide-for-medium-up,.show-for-medium,.show-for-medium-down,.hide-for-large-only,.hide-for-large-up,.hide-for-large,.hide-for-large-down,.show-for-xlarge-only,.show-for-xlarge-up,.show-for-xlarge,.hide-for-xlarge-down,.show-for-xxlarge-only,.show-for-xxlarge-up,.show-for-xxlarge,.hide-for-xxlarge-down{display:none !important}table.hide-for-small-only,table.show-for-small-up,table.hide-for-small,table.hide-for-small-down,table.hide-for-medium-only,table.show-for-medium-up,table.hide-for-medium,table.hide-for-medium-down,table.show-for-large-only,table.show-for-large-up,table.show-for-large,table.show-for-large-down,table.hide-for-xlarge-only,table.hide-for-xlarge-up,table.hide-for-xlarge,table.show-for-xlarge-down,table.hide-for-xxlarge-only,table.hide-for-xxlarge-up,table.hide-for-xxlarge,table.show-for-xxlarge-down{display:table}thead.hide-for-small-only,thead.show-for-small-up,thead.hide-for-small,thead.hide-for-small-down,thead.hide-for-medium-only,thead.show-for-medium-up,thead.hide-for-medium,thead.hide-for-medium-down,thead.show-for-large-only,thead.show-for-large-up,thead.show-for-large,thead.show-for-large-down,thead.hide-for-xlarge-only,thead.hide-for-xlarge-up,thead.hide-for-xlarge,thead.show-for-xlarge-down,thead.hide-for-xxlarge-only,thead.hide-for-xxlarge-up,thead.hide-for-xxlarge,thead.show-for-xxlarge-down{display:table-header-group !important}tbody.hide-for-small-only,tbody.show-for-small-up,tbody.hide-for-small,tbody.hide-for-small-down,tbody.hide-for-medium-only,tbody.show-for-medium-up,tbody.hide-for-medium,tbody.hide-for-medium-down,tbody.show-for-large-only,tbody.show-for-large-up,tbody.show-for-large,tbody.show-for-large-down,tbody.hide-for-xlarge-only,tbody.hide-for-xlarge-up,tbody.hide-for-xlarge,tbody.show-for-xlarge-down,tbody.hide-for-xxlarge-only,tbody.hide-for-xxlarge-up,tbody.hide-for-xxlarge,tbody.show-for-xxlarge-down{display:table-row-group !important}tr.hide-for-small-only,tr.show-for-small-up,tr.hide-for-small,tr.hide-for-small-down,tr.hide-for-medium-only,tr.show-for-medium-up,tr.hide-for-medium,tr.hide-for-medium-down,tr.show-for-large-only,tr.show-for-large-up,tr.show-for-large,tr.show-for-large-down,tr.hide-for-xlarge-only,tr.hide-for-xlarge-up,tr.hide-for-xlarge,tr.show-for-xlarge-down,tr.hide-for-xxlarge-only,tr.hide-for-xxlarge-up,tr.hide-for-xxlarge,tr.show-for-xxlarge-down{display:table-row !important}th.hide-for-small-only,td.hide-for-small-only,th.show-for-small-up,td.show-for-small-up,th.hide-for-small,td.hide-for-small,th.hide-for-small-down,td.hide-for-small-down,th.hide-for-medium-only,td.hide-for-medium-only,th.show-for-medium-up,td.show-for-medium-up,th.hide-for-medium,td.hide-for-medium,th.hide-for-medium-down,td.hide-for-medium-down,th.show-for-large-only,td.show-for-large-only,th.show-for-large-up,td.show-for-large-up,th.show-for-large,td.show-for-large,th.show-for-large-down,td.show-for-large-down,th.hide-for-xlarge-only,td.hide-for-xlarge-only,th.hide-for-xlarge-up,td.hide-for-xlarge-up,th.hide-for-xlarge,td.hide-for-xlarge,th.show-for-xlarge-down,td.show-for-xlarge-down,th.hide-for-xxlarge-only,td.hide-for-xxlarge-only,th.hide-for-xxlarge-up,td.hide-for-xxlarge-up,th.hide-for-xxlarge,td.hide-for-xxlarge,th.show-for-xxlarge-down,td.show-for-xxlarge-down{display:table-cell !important}}@media only screen and (min-width: 90.063em){.hide-for-small-only,.show-for-small-up,.hide-for-small,.hide-for-small-down,.hide-for-medium-only,.show-for-medium-up,.hide-for-medium,.hide-for-medium-down,.hide-for-large-only,.show-for-large-up,.hide-for-large,.hide-for-large-down,.show-for-xlarge-only,.show-for-xlarge-up,.show-for-xlarge,.show-for-xlarge-down,.hide-for-xxlarge-only,.hide-for-xxlarge-up,.hide-for-xxlarge,.show-for-xxlarge-down{display:inherit !important}.show-for-small-only,.hide-for-small-up,.show-for-small,.show-for-small-down,.show-for-medium-only,.hide-for-medium-up,.show-for-medium,.show-for-medium-down,.show-for-large-only,.hide-for-large-up,.show-for-large,.show-for-large-down,.hide-for-xlarge-only,.hide-for-xlarge-up,.hide-for-xlarge,.hide-for-xlarge-down,.show-for-xxlarge-only,.show-for-xxlarge-up,.show-for-xxlarge,.hide-for-xxlarge-down{display:none !important}table.hide-for-small-only,table.show-for-small-up,table.hide-for-small,table.hide-for-small-down,table.hide-for-medium-only,table.show-for-medium-up,table.hide-for-medium,table.hide-for-medium-down,table.hide-for-large-only,table.show-for-large-up,table.hide-for-large,table.hide-for-large-down,table.show-for-xlarge-only,table.show-for-xlarge-up,table.show-for-xlarge,table.show-for-xlarge-down,table.hide-for-xxlarge-only,table.hide-for-xxlarge-up,table.hide-for-xxlarge,table.show-for-xxlarge-down{display:table}thead.hide-for-small-only,thead.show-for-small-up,thead.hide-for-small,thead.hide-for-small-down,thead.hide-for-medium-only,thead.show-for-medium-up,thead.hide-for-medium,thead.hide-for-medium-down,thead.hide-for-large-only,thead.show-for-large-up,thead.hide-for-large,thead.hide-for-large-down,thead.show-for-xlarge-only,thead.show-for-xlarge-up,thead.show-for-xlarge,thead.show-for-xlarge-down,thead.hide-for-xxlarge-only,thead.hide-for-xxlarge-up,thead.hide-for-xxlarge,thead.show-for-xxlarge-down{display:table-header-group !important}tbody.hide-for-small-only,tbody.show-for-small-up,tbody.hide-for-small,tbody.hide-for-small-down,tbody.hide-for-medium-only,tbody.show-for-medium-up,tbody.hide-for-medium,tbody.hide-for-medium-down,tbody.hide-for-large-only,tbody.show-for-large-up,tbody.hide-for-large,tbody.hide-for-large-down,tbody.show-for-xlarge-only,tbody.show-for-xlarge-up,tbody.show-for-xlarge,tbody.show-for-xlarge-down,tbody.hide-for-xxlarge-only,tbody.hide-for-xxlarge-up,tbody.hide-for-xxlarge,tbody.show-for-xxlarge-down{display:table-row-group !important}tr.hide-for-small-only,tr.show-for-small-up,tr.hide-for-small,tr.hide-for-small-down,tr.hide-for-medium-only,tr.show-for-medium-up,tr.hide-for-medium,tr.hide-for-medium-down,tr.hide-for-large-only,tr.show-for-large-up,tr.hide-for-large,tr.hide-for-large-down,tr.show-for-xlarge-only,tr.show-for-xlarge-up,tr.show-for-xlarge,tr.show-for-xlarge-down,tr.hide-for-xxlarge-only,tr.hide-for-xxlarge-up,tr.hide-for-xxlarge,tr.show-for-xxlarge-down{display:table-row !important}th.hide-for-small-only,td.hide-for-small-only,th.show-for-small-up,td.show-for-small-up,th.hide-for-small,td.hide-for-small,th.hide-for-small-down,td.hide-for-small-down,th.hide-for-medium-only,td.hide-for-medium-only,th.show-for-medium-up,td.show-for-medium-up,th.hide-for-medium,td.hide-for-medium,th.hide-for-medium-down,td.hide-for-medium-down,th.hide-for-large-only,td.hide-for-large-only,th.show-for-large-up,td.show-for-large-up,th.hide-for-large,td.hide-for-large,th.hide-for-large-down,td.hide-for-large-down,th.show-for-xlarge-only,td.show-for-xlarge-only,th.show-for-xlarge-up,td.show-for-xlarge-up,th.show-for-xlarge,td.show-for-xlarge,th.show-for-xlarge-down,td.show-for-xlarge-down,th.hide-for-xxlarge-only,td.hide-for-xxlarge-only,th.hide-for-xxlarge-up,td.hide-for-xxlarge-up,th.hide-for-xxlarge,td.hide-for-xxlarge,th.show-for-xxlarge-down,td.show-for-xxlarge-down{display:table-cell !important}}@media only screen and (min-width: 120.063em){.hide-for-small-only,.show-for-small-up,.hide-for-small,.hide-for-small-down,.hide-for-medium-only,.show-for-medium-up,.hide-for-medium,.hide-for-medium-down,.hide-for-large-only,.show-for-large-up,.hide-for-large,.hide-for-large-down,.hide-for-xlarge-only,.show-for-xlarge-up,.hide-for-xlarge,.hide-for-xlarge-down,.show-for-xxlarge-only,.show-for-xxlarge-up,.show-for-xxlarge,.show-for-xxlarge-down{display:inherit !important}.show-for-small-only,.hide-for-small-up,.show-for-small,.show-for-small-down,.show-for-medium-only,.hide-for-medium-up,.show-for-medium,.show-for-medium-down,.show-for-large-only,.hide-for-large-up,.show-for-large,.show-for-large-down,.show-for-xlarge-only,.hide-for-xlarge-up,.show-for-xlarge,.show-for-xlarge-down,.hide-for-xxlarge-only,.hide-for-xxlarge-up,.hide-for-xxlarge,.hide-for-xxlarge-down{display:none !important}table.hide-for-small-only,table.show-for-small-up,table.hide-for-small,table.hide-for-small-down,table.hide-for-medium-only,table.show-for-medium-up,table.hide-for-medium,table.hide-for-medium-down,table.hide-for-large-only,table.show-for-large-up,table.hide-for-large,table.hide-for-large-down,table.hide-for-xlarge-only,table.show-for-xlarge-up,table.hide-for-xlarge,table.hide-for-xlarge-down,table.show-for-xxlarge-only,table.show-for-xxlarge-up,table.show-for-xxlarge,table.show-for-xxlarge-down{display:table}thead.hide-for-small-only,thead.show-for-small-up,thead.hide-for-small,thead.hide-for-small-down,thead.hide-for-medium-only,thead.show-for-medium-up,thead.hide-for-medium,thead.hide-for-medium-down,thead.hide-for-large-only,thead.show-for-large-up,thead.hide-for-large,thead.hide-for-large-down,thead.hide-for-xlarge-only,thead.show-for-xlarge-up,thead.hide-for-xlarge,thead.hide-for-xlarge-down,thead.show-for-xxlarge-only,thead.show-for-xxlarge-up,thead.show-for-xxlarge,thead.show-for-xxlarge-down{display:table-header-group !important}tbody.hide-for-small-only,tbody.show-for-small-up,tbody.hide-for-small,tbody.hide-for-small-down,tbody.hide-for-medium-only,tbody.show-for-medium-up,tbody.hide-for-medium,tbody.hide-for-medium-down,tbody.hide-for-large-only,tbody.show-for-large-up,tbody.hide-for-large,tbody.hide-for-large-down,tbody.hide-for-xlarge-only,tbody.show-for-xlarge-up,tbody.hide-for-xlarge,tbody.hide-for-xlarge-down,tbody.show-for-xxlarge-only,tbody.show-for-xxlarge-up,tbody.show-for-xxlarge,tbody.show-for-xxlarge-down{display:table-row-group !important}tr.hide-for-small-only,tr.show-for-small-up,tr.hide-for-small,tr.hide-for-small-down,tr.hide-for-medium-only,tr.show-for-medium-up,tr.hide-for-medium,tr.hide-for-medium-down,tr.hide-for-large-only,tr.show-for-large-up,tr.hide-for-large,tr.hide-for-large-down,tr.hide-for-xlarge-only,tr.show-for-xlarge-up,tr.hide-for-xlarge,tr.hide-for-xlarge-down,tr.show-for-xxlarge-only,tr.show-for-xxlarge-up,tr.show-for-xxlarge,tr.show-for-xxlarge-down{display:table-row !important}th.hide-for-small-only,td.hide-for-small-only,th.show-for-small-up,td.show-for-small-up,th.hide-for-small,td.hide-for-small,th.hide-for-small-down,td.hide-for-small-down,th.hide-for-medium-only,td.hide-for-medium-only,th.show-for-medium-up,td.show-for-medium-up,th.hide-for-medium,td.hide-for-medium,th.hide-for-medium-down,td.hide-for-medium-down,th.hide-for-large-only,td.hide-for-large-only,th.show-for-large-up,td.show-for-large-up,th.hide-for-large,td.hide-for-large,th.hide-for-large-down,td.hide-for-large-down,th.hide-for-xlarge-only,td.hide-for-xlarge-only,th.show-for-xlarge-up,td.show-for-xlarge-up,th.hide-for-xlarge,td.hide-for-xlarge,th.hide-for-xlarge-down,td.hide-for-xlarge-down,th.show-for-xxlarge-only,td.show-for-xxlarge-only,th.show-for-xxlarge-up,td.show-for-xxlarge-up,th.show-for-xxlarge,td.show-for-xxlarge,th.show-for-xxlarge-down,td.show-for-xxlarge-down{display:table-cell !important}}.show-for-landscape,.hide-for-portrait{display:inherit !important}.hide-for-landscape,.show-for-portrait{display:none !important}table.hide-for-landscape,table.show-for-portrait{display:table}thead.hide-for-landscape,thead.show-for-portrait{display:table-header-group !important}tbody.hide-for-landscape,tbody.show-for-portrait{display:table-row-group !important}tr.hide-for-landscape,tr.show-for-portrait{display:table-row !important}td.hide-for-landscape,td.show-for-portrait,th.hide-for-landscape,th.show-for-portrait{display:table-cell !important}@media only screen and (orientation: landscape){.show-for-landscape,.hide-for-portrait{display:inherit !important}.hide-for-landscape,.show-for-portrait{display:none !important}table.show-for-landscape,table.hide-for-portrait{display:table}thead.show-for-landscape,thead.hide-for-portrait{display:table-header-group !important}tbody.show-for-landscape,tbody.hide-for-portrait{display:table-row-group !important}tr.show-for-landscape,tr.hide-for-portrait{display:table-row !important}td.show-for-landscape,td.hide-for-portrait,th.show-for-landscape,th.hide-for-portrait{display:table-cell !important}}@media only screen and (orientation: portrait){.show-for-portrait,.hide-for-landscape{display:inherit !important}.hide-for-portrait,.show-for-landscape{display:none !important}table.show-for-portrait,table.hide-for-landscape{display:table}thead.show-for-portrait,thead.hide-for-landscape{display:table-header-group !important}tbody.show-for-portrait,tbody.hide-for-landscape{display:table-row-group !important}tr.show-for-portrait,tr.hide-for-landscape{display:table-row !important}td.show-for-portrait,td.hide-for-landscape,th.show-for-portrait,th.hide-for-landscape{display:table-cell !important}}.show-for-touch{display:none !important}.hide-for-touch{display:inherit !important}.touch .show-for-touch{display:inherit !important}.touch .hide-for-touch{display:none !important}table.hide-for-touch{display:table}.touch table.show-for-touch{display:table}thead.hide-for-touch{display:table-header-group !important}.touch thead.show-for-touch{display:table-header-group !important}tbody.hide-for-touch{display:table-row-group !important}.touch tbody.show-for-touch{display:table-row-group !important}tr.hide-for-touch{display:table-row !important}.touch tr.show-for-touch{display:table-row !important}td.hide-for-touch{display:table-cell !important}.touch td.show-for-touch{display:table-cell !important}th.hide-for-touch{display:table-cell !important}.touch th.show-for-touch{display:table-cell !important}
index ac943c13ba203134a7569f5fed30cd569c7af995..2d1ba03064bb3f919c0b30d285c0d0be5c70f05b 100644 (file)
@@ -9,13 +9,13 @@
 
 @media only screen and (max-width: 500px) {
   #splash {
-    background-image: url('../img/banner_small.jpg');
+    background-image: url('//karma-prod.s3.amazonaws.com/img/banner_small.jpg');
   }
 }
 
 @media only screen and (min-width: 501px) {
   #splash {
-    background-image: url('../img/banner_large.jpg');
+    background-image: url('//karma-prod.s3.amazonaws.com/img/banner_large.jpg');
   }
 }
 
diff --git a/karmaworld/assets/css/images/animated-overlay.gif b/karmaworld/assets/css/images/animated-overlay.gif
new file mode 100644 (file)
index 0000000..d441f75
Binary files /dev/null and b/karmaworld/assets/css/images/animated-overlay.gif differ
diff --git a/karmaworld/assets/css/images/back_disabled.png b/karmaworld/assets/css/images/back_disabled.png
new file mode 100644 (file)
index 0000000..881de79
Binary files /dev/null and b/karmaworld/assets/css/images/back_disabled.png differ
diff --git a/karmaworld/assets/css/images/back_enabled.png b/karmaworld/assets/css/images/back_enabled.png
new file mode 100644 (file)
index 0000000..c608682
Binary files /dev/null and b/karmaworld/assets/css/images/back_enabled.png differ
diff --git a/karmaworld/assets/css/images/back_enabled_hover.png b/karmaworld/assets/css/images/back_enabled_hover.png
new file mode 100644 (file)
index 0000000..d300f10
Binary files /dev/null and b/karmaworld/assets/css/images/back_enabled_hover.png differ
diff --git a/karmaworld/assets/css/images/forward_disabled.png b/karmaworld/assets/css/images/forward_disabled.png
new file mode 100644 (file)
index 0000000..6a6ded7
Binary files /dev/null and b/karmaworld/assets/css/images/forward_disabled.png differ
diff --git a/karmaworld/assets/css/images/forward_enabled.png b/karmaworld/assets/css/images/forward_enabled.png
new file mode 100644 (file)
index 0000000..a4e6b53
Binary files /dev/null and b/karmaworld/assets/css/images/forward_enabled.png differ
diff --git a/karmaworld/assets/css/images/forward_enabled_hover.png b/karmaworld/assets/css/images/forward_enabled_hover.png
new file mode 100644 (file)
index 0000000..fc46c5e
Binary files /dev/null and b/karmaworld/assets/css/images/forward_enabled_hover.png differ
diff --git a/karmaworld/assets/css/images/sort_asc.png b/karmaworld/assets/css/images/sort_asc.png
new file mode 100644 (file)
index 0000000..a88d797
Binary files /dev/null and b/karmaworld/assets/css/images/sort_asc.png differ
diff --git a/karmaworld/assets/css/images/sort_asc_disabled.png b/karmaworld/assets/css/images/sort_asc_disabled.png
new file mode 100644 (file)
index 0000000..4e144cf
Binary files /dev/null and b/karmaworld/assets/css/images/sort_asc_disabled.png differ
diff --git a/karmaworld/assets/css/images/sort_both.png b/karmaworld/assets/css/images/sort_both.png
new file mode 100644 (file)
index 0000000..1867040
Binary files /dev/null and b/karmaworld/assets/css/images/sort_both.png differ
diff --git a/karmaworld/assets/css/images/sort_desc.png b/karmaworld/assets/css/images/sort_desc.png
new file mode 100644 (file)
index 0000000..def071e
Binary files /dev/null and b/karmaworld/assets/css/images/sort_desc.png differ
diff --git a/karmaworld/assets/css/images/sort_desc_disabled.png b/karmaworld/assets/css/images/sort_desc_disabled.png
new file mode 100644 (file)
index 0000000..7824973
Binary files /dev/null and b/karmaworld/assets/css/images/sort_desc_disabled.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png b/karmaworld/assets/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png
new file mode 100644 (file)
index 0000000..a6ee35d
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_diagonals-thick_20_666666_40x40.png b/karmaworld/assets/css/images/ui-bg_diagonals-thick_20_666666_40x40.png
new file mode 100644 (file)
index 0000000..e0556dd
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_diagonals-thick_20_666666_40x40.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_flat_10_000000_40x100.png b/karmaworld/assets/css/images/ui-bg_flat_10_000000_40x100.png
new file mode 100644 (file)
index 0000000..0b938a0
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_flat_10_000000_40x100.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_glass_100_f6f6f6_1x400.png b/karmaworld/assets/css/images/ui-bg_glass_100_f6f6f6_1x400.png
new file mode 100644 (file)
index 0000000..a7a9c52
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_glass_100_f6f6f6_1x400.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_glass_100_fdf5ce_1x400.png b/karmaworld/assets/css/images/ui-bg_glass_100_fdf5ce_1x400.png
new file mode 100644 (file)
index 0000000..1154353
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_glass_100_fdf5ce_1x400.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_glass_65_ffffff_1x400.png b/karmaworld/assets/css/images/ui-bg_glass_65_ffffff_1x400.png
new file mode 100644 (file)
index 0000000..2e35ccc
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_glass_65_ffffff_1x400.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png b/karmaworld/assets/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png
new file mode 100644 (file)
index 0000000..7183fb7
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png b/karmaworld/assets/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png
new file mode 100644 (file)
index 0000000..387cf54
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png differ
diff --git a/karmaworld/assets/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png b/karmaworld/assets/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png
new file mode 100644 (file)
index 0000000..d34360b
Binary files /dev/null and b/karmaworld/assets/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png differ
diff --git a/karmaworld/assets/css/images/ui-icons_222222_256x240.png b/karmaworld/assets/css/images/ui-icons_222222_256x240.png
new file mode 100644 (file)
index 0000000..c1cb117
Binary files /dev/null and b/karmaworld/assets/css/images/ui-icons_222222_256x240.png differ
diff --git a/karmaworld/assets/css/images/ui-icons_228ef1_256x240.png b/karmaworld/assets/css/images/ui-icons_228ef1_256x240.png
new file mode 100644 (file)
index 0000000..3a0140c
Binary files /dev/null and b/karmaworld/assets/css/images/ui-icons_228ef1_256x240.png differ
diff --git a/karmaworld/assets/css/images/ui-icons_ef8c08_256x240.png b/karmaworld/assets/css/images/ui-icons_ef8c08_256x240.png
new file mode 100644 (file)
index 0000000..036ee07
Binary files /dev/null and b/karmaworld/assets/css/images/ui-icons_ef8c08_256x240.png differ
diff --git a/karmaworld/assets/css/images/ui-icons_ffd27a_256x240.png b/karmaworld/assets/css/images/ui-icons_ffd27a_256x240.png
new file mode 100644 (file)
index 0000000..8b6c058
Binary files /dev/null and b/karmaworld/assets/css/images/ui-icons_ffd27a_256x240.png differ
diff --git a/karmaworld/assets/css/images/ui-icons_ffffff_256x240.png b/karmaworld/assets/css/images/ui-icons_ffffff_256x240.png
new file mode 100644 (file)
index 0000000..4f624bb
Binary files /dev/null and b/karmaworld/assets/css/images/ui-icons_ffffff_256x240.png differ
index 7ffb205ae4ac9bd48b7b63578b7ad3af7ff51957..46e68e3eac26b9828b778a7ede0fa0c1bdab206b 100644 (file)
-/*! jQuery UI - v1.9.2 - 2012-11-23
+/*! jQuery UI - v1.10.4 - 2014-04-23
 * http://jqueryui.com
-* Includes: jquery.ui.core.css, jquery.ui.accordion.css, jquery.ui.autocomplete.css, jquery.ui.button.css, jquery.ui.datepicker.css, jquery.ui.dialog.css, jquery.ui.menu.css, jquery.ui.progressbar.css, jquery.ui.resizable.css, jquery.ui.selectable.css, jquery.ui.slider.css, jquery.ui.spinner.css, jquery.ui.tabs.css, jquery.ui.tooltip.css, jquery.ui.theme.css
-* Copyright 2012 jQuery Foundation and other contributors; Licensed MIT */
+* Includes: jquery.ui.core.css, jquery.ui.autocomplete.css, jquery.ui.menu.css, jquery.ui.theme.css
+* To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Trebuchet%20MS%2CTahoma%2CVerdana%2CArial%2Csans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=f6a828&bgTextureHeader=gloss_wave&bgImgOpacityHeader=35&borderColorHeader=e78f08&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=eeeeee&bgTextureContent=highlight_soft&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=333333&iconColorContent=222222&bgColorDefault=f6f6f6&bgTextureDefault=glass&bgImgOpacityDefault=100&borderColorDefault=cccccc&fcDefault=1c94c4&iconColorDefault=ef8c08&bgColorHover=fdf5ce&bgTextureHover=glass&bgImgOpacityHover=100&borderColorHover=fbcb09&fcHover=c77405&iconColorHover=ef8c08&bgColorActive=ffffff&bgTextureActive=glass&bgImgOpacityActive=65&borderColorActive=fbd850&fcActive=eb8f00&iconColorActive=ef8c08&bgColorHighlight=ffe45c&bgTextureHighlight=highlight_soft&bgImgOpacityHighlight=75&borderColorHighlight=fed22f&fcHighlight=363636&iconColorHighlight=228ef1&bgColorError=b81900&bgTextureError=diagonals_thick&bgImgOpacityError=18&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffd27a&bgColorOverlay=666666&bgTextureOverlay=diagonals_thick&bgImgOpacityOverlay=20&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=flat&bgImgOpacityShadow=10&opacityShadow=20&thicknessShadow=5px&offsetTopShadow=-5px&offsetLeftShadow=-5px&cornerRadiusShadow=5px
+* Copyright 2014 jQuery Foundation and other contributors; Licensed MIT */
 
 /* Layout helpers
 ----------------------------------*/
-.ui-helper-hidden { display: none; }
-.ui-helper-hidden-accessible { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }
-.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
-.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
-.ui-helper-clearfix:after { clear: both; }
-.ui-helper-clearfix { zoom: 1; }
-.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
+.ui-helper-hidden {
+       display: none;
+}
+.ui-helper-hidden-accessible {
+       border: 0;
+       clip: rect(0 0 0 0);
+       height: 1px;
+       margin: -1px;
+       overflow: hidden;
+       padding: 0;
+       position: absolute;
+       width: 1px;
+}
+.ui-helper-reset {
+       margin: 0;
+       padding: 0;
+       border: 0;
+       outline: 0;
+       line-height: 1.3;
+       text-decoration: none;
+       font-size: 100%;
+       list-style: none;
+}
+.ui-helper-clearfix:before,
+.ui-helper-clearfix:after {
+       content: "";
+       display: table;
+       border-collapse: collapse;
+}
+.ui-helper-clearfix:after {
+       clear: both;
+}
+.ui-helper-clearfix {
+       min-height: 0; /* support: IE7 */
+}
+.ui-helper-zfix {
+       width: 100%;
+       height: 100%;
+       top: 0;
+       left: 0;
+       position: absolute;
+       opacity: 0;
+       filter:Alpha(Opacity=0);
+}
+
+.ui-front {
+       z-index: 100;
+}
 
 
 /* Interaction Cues
 ----------------------------------*/
-.ui-state-disabled { cursor: default !important; }
+.ui-state-disabled {
+       cursor: default !important;
+}
 
 
 /* Icons
 ----------------------------------*/
 
 /* states and images */
-.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
+.ui-icon {
+       display: block;
+       text-indent: -99999px;
+       overflow: hidden;
+       background-repeat: no-repeat;
+}
 
 
 /* Misc visuals
 ----------------------------------*/
 
 /* Overlays */
-.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
-
-.ui-accordion .ui-accordion-header { display: block; cursor: pointer; position: relative; margin-top: 2px; padding: .5em .5em .5em .7em; zoom: 1; }
-.ui-accordion .ui-accordion-icons { padding-left: 2.2em; }
-.ui-accordion .ui-accordion-noicons { padding-left: .7em; }
-.ui-accordion .ui-accordion-icons .ui-accordion-icons { padding-left: 2.2em; }
-.ui-accordion .ui-accordion-header .ui-accordion-header-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
-.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; overflow: auto; zoom: 1; }
-
+.ui-widget-overlay {
+       position: fixed;
+       top: 0;
+       left: 0;
+       width: 100%;
+       height: 100%;
+}
 .ui-autocomplete {
        position: absolute;
        top: 0;
        left: 0;
        cursor: default;
 }
-
-/* workarounds */
-* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
-
-.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
-.ui-button, .ui-button:link, .ui-button:visited, .ui-button:hover, .ui-button:active { text-decoration: none; }
-.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
-button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
-.ui-button-icons-only { width: 3.4em; } 
-button.ui-button-icons-only { width: 3.7em; } 
-
-/*button text element */
-.ui-button .ui-button-text { display: block; line-height: 1.4;  }
-.ui-button-text-only .ui-button-text { padding: .4em 1em; }
-.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
-.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
-.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
-.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
-/* no icon support for input elements, provide padding by default */
-input.ui-button { padding: .4em 1em; }
-
-/*button icon element(s) */
-.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
-.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
-.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
-.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
-.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
-
-/*button sets*/
-.ui-buttonset { margin-right: 7px; }
-.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }
-
-/* workarounds */
-button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
-
-.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
-.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
-.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
-.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
-.ui-datepicker .ui-datepicker-prev { left:2px; }
-.ui-datepicker .ui-datepicker-next { right:2px; }
-.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
-.ui-datepicker .ui-datepicker-next-hover { right:1px; }
-.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px;  }
-.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
-.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
-.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
-.ui-datepicker select.ui-datepicker-month, 
-.ui-datepicker select.ui-datepicker-year { width: 49%;}
-.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
-.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0;  }
-.ui-datepicker td { border: 0; padding: 1px; }
-.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
-.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
-.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
-.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
-
-/* with multiple calendars */
-.ui-datepicker.ui-datepicker-multi { width:auto; }
-.ui-datepicker-multi .ui-datepicker-group { float:left; }
-.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
-.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
-.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
-.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
-.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
-.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
-.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
-.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
-
-/* RTL support */
-.ui-datepicker-rtl { direction: rtl; }
-.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
-.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
-.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
-.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
-.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
-.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
-.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
-.ui-datepicker-rtl .ui-datepicker-group { float:right; }
-.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
-.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
-
-/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
-.ui-datepicker-cover {
-    position: absolute; /*must have*/
-    z-index: -1; /*must have*/
-    filter: mask(); /*must have*/
-    top: -4px; /*must have*/
-    left: -4px; /*must have*/
-    width: 200px; /*must have*/
-    height: 200px; /*must have*/
-}
-.ui-dialog { position: absolute; top: 0; left: 0; padding: .2em; width: 300px; overflow: hidden; }
-.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative;  }
-.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
-.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
-.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
-.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
-.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
-.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
-.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
-.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
-.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
-.ui-draggable .ui-dialog-titlebar { cursor: move; }
-
-.ui-menu { list-style:none; padding: 2px; margin: 0; display:block; outline: none; }
-.ui-menu .ui-menu { margin-top: -3px; position: absolute; }
-.ui-menu .ui-menu-item { margin: 0; padding: 0; zoom: 1; width: 100%; }
-.ui-menu .ui-menu-divider { margin: 5px -2px 5px -2px; height: 0; font-size: 0; line-height: 0; border-width: 1px 0 0 0; }
-.ui-menu .ui-menu-item a { text-decoration: none; display: block; padding: 2px .4em; line-height: 1.5; zoom: 1; font-weight: normal; }
+.ui-menu {
+       list-style: none;
+       padding: 2px;
+       margin: 0;
+       display: block;
+       outline: none;
+}
+.ui-menu .ui-menu {
+       margin-top: -3px;
+       position: absolute;
+}
+.ui-menu .ui-menu-item {
+       margin: 0;
+       padding: 0;
+       width: 100%;
+       /* support: IE10, see #8844 */
+       list-style-image: url(data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7);
+}
+.ui-menu .ui-menu-divider {
+       margin: 5px -2px 5px -2px;
+       height: 0;
+       font-size: 0;
+       line-height: 0;
+       border-width: 1px 0 0 0;
+}
+.ui-menu .ui-menu-item a {
+       text-decoration: none;
+       display: block;
+       padding: 2px .4em;
+       line-height: 1.5;
+       min-height: 0; /* support: IE7 */
+       font-weight: normal;
+}
 .ui-menu .ui-menu-item a.ui-state-focus,
-.ui-menu .ui-menu-item a.ui-state-active { font-weight: normal; margin: -1px; }
+.ui-menu .ui-menu-item a.ui-state-active {
+       font-weight: normal;
+       margin: -1px;
+}
 
-.ui-menu .ui-state-disabled { font-weight: normal; margin: .4em 0 .2em; line-height: 1.5; }
-.ui-menu .ui-state-disabled a { cursor: default; }
+.ui-menu .ui-state-disabled {
+       font-weight: normal;
+       margin: .4em 0 .2em;
+       line-height: 1.5;
+}
+.ui-menu .ui-state-disabled a {
+       cursor: default;
+}
 
 /* icon support */
-.ui-menu-icons { position: relative; }
-.ui-menu-icons .ui-menu-item a { position: relative; padding-left: 2em; }
-
-/* left-aligned */
-.ui-menu .ui-icon { position: absolute; top: .2em; left: .2em; }
-
-/* right-aligned */
-.ui-menu .ui-menu-icon { position: static; float: right; }
-
-.ui-progressbar { height:2em; text-align: left; overflow: hidden; }
-.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }
-.ui-resizable { position: relative;}
-.ui-resizable-handle { position: absolute;font-size: 0.1px; display: block; }
-.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
-.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
-.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
-.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
-.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
-.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
-.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
-.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
-.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}
-.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
-
-.ui-slider { position: relative; text-align: left; }
-.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
-.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
-
-.ui-slider-horizontal { height: .8em; }
-.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
-.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
-.ui-slider-horizontal .ui-slider-range-min { left: 0; }
-.ui-slider-horizontal .ui-slider-range-max { right: 0; }
-
-.ui-slider-vertical { width: .8em; height: 100px; }
-.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
-.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
-.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
-.ui-slider-vertical .ui-slider-range-max { top: 0; }
-.ui-spinner { position:relative; display: inline-block; overflow: hidden; padding: 0; vertical-align: middle; }
-.ui-spinner-input { border: none; background: none; padding: 0; margin: .2em 0; vertical-align: middle; margin-left: .4em; margin-right: 22px; }
-.ui-spinner-button { width: 16px; height: 50%; font-size: .5em; padding: 0; margin: 0; text-align: center; position: absolute; cursor: default; display: block; overflow: hidden; right: 0; }
-.ui-spinner a.ui-spinner-button { border-top: none; border-bottom: none; border-right: none; } /* more specificity required here to overide default borders */
-.ui-spinner .ui-icon { position: absolute; margin-top: -8px; top: 50%; left: 0; } /* vertical centre icon */
-.ui-spinner-up { top: 0; }
-.ui-spinner-down { bottom: 0; }
-
-/* TR overrides */
-.ui-spinner .ui-icon-triangle-1-s {
-       /* need to fix icons sprite */
-       background-position:-65px -16px;
+.ui-menu-icons {
+       position: relative;
+}
+.ui-menu-icons .ui-menu-item a {
+       position: relative;
+       padding-left: 2em;
 }
 
-.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
-.ui-tabs .ui-tabs-nav { margin: 0; padding: 0; }
-.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 0; border-bottom: 0; padding: 0; white-space: nowrap; }
-.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
-.ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: -1px; padding-bottom: 1px; }
-.ui-tabs .ui-tabs-nav li.ui-tabs-active a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-tabs-loading a { cursor: text; }
-.ui-tabs .ui-tabs-nav li a, .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
-.ui-tabs { display: block; border-width: 0; background: none; }
-.ui-tabs-panel { display: block; }
-
-.ui-tooltip {
-       padding: 8px;
+/* left-aligned */
+.ui-menu .ui-icon {
        position: absolute;
-       z-index: 9999;
-       max-width: 300px;
-       -webkit-box-shadow: 0 0 5px #aaa;
-       box-shadow: 0 0 5px #aaa;
+       top: .2em;
+       left: .2em;
 }
-/* Fades and background-images don't work well together in IE6, drop the image */
-* html .ui-tooltip {
-       background-image: none;
+
+/* right-aligned */
+.ui-menu .ui-menu-icon {
+       position: static;
+       float: right;
 }
-body .ui-tooltip { border-width: 2px; }
 
 /* Component containers
 ----------------------------------*/
-.ui-widget { font-size: 1.1em/*{fsDefault}*/; }
-.ui-widget .ui-widget { font-size: 1em; }
-.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-size: 1em; }
-.ui-widget-content { border: 1px solid #aaaaaa/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repeat-x/*{bgContentRepeat}*/; color: #222222/*{fcContent}*/; }
-.ui-widget-content a { color: #222222/*{fcContent}*/; }
-.ui-widget-header { border: none; background: transparent; color: #222222/*{fcHeader}*/; font-weight: bold; }
-.ui-widget-header a { color: #222222/*{fcHeader}*/; }
+.ui-widget {
+       font-family: Trebuchet MS,Tahoma,Verdana,Arial,sans-serif;
+       font-size: 1.1em;
+}
+.ui-widget .ui-widget {
+       font-size: 1em;
+}
+.ui-widget input,
+.ui-widget select,
+.ui-widget textarea,
+.ui-widget button {
+       font-family: Trebuchet MS,Tahoma,Verdana,Arial,sans-serif;
+       font-size: 1em;
+}
+.ui-widget-content {
+       border: 1px solid #dddddd;
+       background: #eeeeee url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png") 50% top repeat-x;
+       color: #333333;
+}
+.ui-widget-content a {
+       color: #333333;
+}
+.ui-widget-header {
+       border: 1px solid #e78f08;
+       background: #f6a828 url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png") 50% 50% repeat-x;
+       color: #ffffff;
+       font-weight: bold;
+}
+.ui-widget-header a {
+       color: #ffffff;
+}
 
 /* Interaction states
 ----------------------------------*/
-.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #d3d3d3/*{borderColorDefault}*/; background: #e6e6e6/*{bgColorDefault}*/ url(images/ui-bg_glass_75_e6e6e6_1x400.png)/*{bgImgUrlDefault}*/ 50%/*{bgDefaultXPos}*/ 50%/*{bgDefaultYPos}*/ repeat-x/*{bgDefaultRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #555555/*{fcDefault}*/; }
-.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555/*{fcDefault}*/; text-decoration: none; }
-.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999/*{borderColorHover}*/; background: #dadada/*{bgColorHover}*/ url(images/ui-bg_glass_75_dadada_1x400.png)/*{bgImgUrlHover}*/ 50%/*{bgHoverXPos}*/ 50%/*{bgHoverYPos}*/ repeat-x/*{bgHoverRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcHover}*/; }
-.ui-state-hover a, .ui-state-hover a:hover, .ui-state-hover a:link, .ui-state-hover a:visited { color: #212121/*{fcHover}*/; text-decoration: none; }
-.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { background: #ffffff/*{bgColorActive}*/ url(images/ui-bg_glass_65_ffffff_1x400.png)/*{bgImgUrlActive}*/ 50%/*{bgActiveXPos}*/ 50%/*{bgActiveYPos}*/ repeat-x/*{bgActiveRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcActive}*/; }
-.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121/*{fcActive}*/; text-decoration: none; }
+.ui-state-default,
+.ui-widget-content .ui-state-default,
+.ui-widget-header .ui-state-default {
+       border: 1px solid #cccccc;
+       background: #f6f6f6 url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_glass_100_f6f6f6_1x400.png") 50% 50% repeat-x;
+       font-weight: bold;
+       color: #1c94c4;
+}
+.ui-state-default a,
+.ui-state-default a:link,
+.ui-state-default a:visited {
+       color: #1c94c4;
+       text-decoration: none;
+}
+.ui-state-hover,
+.ui-widget-content .ui-state-hover,
+.ui-widget-header .ui-state-hover,
+.ui-state-focus,
+.ui-widget-content .ui-state-focus,
+.ui-widget-header .ui-state-focus {
+       border: 1px solid #fbcb09;
+       background: #fdf5ce url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_glass_100_fdf5ce_1x400.png") 50% 50% repeat-x;
+       font-weight: bold;
+       color: #c77405;
+}
+.ui-state-hover a,
+.ui-state-hover a:hover,
+.ui-state-hover a:link,
+.ui-state-hover a:visited,
+.ui-state-focus a,
+.ui-state-focus a:hover,
+.ui-state-focus a:link,
+.ui-state-focus a:visited {
+       color: #c77405;
+       text-decoration: none;
+}
+.ui-state-active,
+.ui-widget-content .ui-state-active,
+.ui-widget-header .ui-state-active {
+       border: 1px solid #fbd850;
+       background: #ffffff url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_glass_65_ffffff_1x400.png") 50% 50% repeat-x;
+       font-weight: bold;
+       color: #eb8f00;
+}
+.ui-state-active a,
+.ui-state-active a:link,
+.ui-state-active a:visited {
+       color: #eb8f00;
+       text-decoration: none;
+}
 
 /* Interaction Cues
 ----------------------------------*/
-.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight  {border: 1px solid #fcefa1/*{borderColorHighlight}*/; background: #fbf9ee/*{bgColorHighlight}*/ url(images/ui-bg_glass_55_fbf9ee_1x400.png)/*{bgImgUrlHighlight}*/ 50%/*{bgHighlightXPos}*/ 50%/*{bgHighlightYPos}*/ repeat-x/*{bgHighlightRepeat}*/; color: #363636/*{fcHighlight}*/; }
-.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636/*{fcHighlight}*/; }
-.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a/*{borderColorError}*/; background: #fef1ec/*{bgColorError}*/ url(images/ui-bg_glass_95_fef1ec_1x400.png)/*{bgImgUrlError}*/ 50%/*{bgErrorXPos}*/ 50%/*{bgErrorYPos}*/ repeat-x/*{bgErrorRepeat}*/; color: #cd0a0a/*{fcError}*/; }
-.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a/*{fcError}*/; }
-.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a/*{fcError}*/; }
-.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
-.ui-priority-secondary, .ui-widget-content .ui-priority-secondary,  .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
-.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
-.ui-state-disabled .ui-icon { filter:Alpha(Opacity=35); } /* For IE8 - See #6059 */
+.ui-state-highlight,
+.ui-widget-content .ui-state-highlight,
+.ui-widget-header .ui-state-highlight {
+       border: 1px solid #fed22f;
+       background: #ffe45c url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png") 50% top repeat-x;
+       color: #363636;
+}
+.ui-state-highlight a,
+.ui-widget-content .ui-state-highlight a,
+.ui-widget-header .ui-state-highlight a {
+       color: #363636;
+}
+.ui-state-error,
+.ui-widget-content .ui-state-error,
+.ui-widget-header .ui-state-error {
+       border: 1px solid #cd0a0a;
+       background: #b81900 url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png") 50% 50% repeat;
+       color: #ffffff;
+}
+.ui-state-error a,
+.ui-widget-content .ui-state-error a,
+.ui-widget-header .ui-state-error a {
+       color: #ffffff;
+}
+.ui-state-error-text,
+.ui-widget-content .ui-state-error-text,
+.ui-widget-header .ui-state-error-text {
+       color: #ffffff;
+}
+.ui-priority-primary,
+.ui-widget-content .ui-priority-primary,
+.ui-widget-header .ui-priority-primary {
+       font-weight: bold;
+}
+.ui-priority-secondary,
+.ui-widget-content .ui-priority-secondary,
+.ui-widget-header .ui-priority-secondary {
+       opacity: .7;
+       filter:Alpha(Opacity=70);
+       font-weight: normal;
+}
+.ui-state-disabled,
+.ui-widget-content .ui-state-disabled,
+.ui-widget-header .ui-state-disabled {
+       opacity: .35;
+       filter:Alpha(Opacity=35);
+       background-image: none;
+}
+.ui-state-disabled .ui-icon {
+       filter:Alpha(Opacity=35); /* For IE8 - See #6059 */
+}
 
 /* Icons
 ----------------------------------*/
 
 /* states and images */
-.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
-.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
-.ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsHeader}*/; }
-.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png)/*{iconsDefault}*/; }
-.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsHover}*/; }
-.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsActive}*/; }
-.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png)/*{iconsHighlight}*/; }
-.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png)/*{iconsError}*/; }
+.ui-icon {
+       width: 16px;
+       height: 16px;
+}
+.ui-icon,
+.ui-widget-content .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_222222_256x240.png");
+}
+.ui-widget-header .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_ffffff_256x240.png");
+}
+.ui-state-default .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_ef8c08_256x240.png");
+}
+.ui-state-hover .ui-icon,
+.ui-state-focus .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_ef8c08_256x240.png");
+}
+.ui-state-active .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_ef8c08_256x240.png");
+}
+.ui-state-highlight .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_228ef1_256x240.png");
+}
+.ui-state-error .ui-icon,
+.ui-state-error-text .ui-icon {
+       background-image: url("//karma-prod.s3.amazonaws.com/css/images/ui-icons_ffd27a_256x240.png");
+}
 
 /* positioning */
+.ui-icon-blank { background-position: 16px 16px; }
 .ui-icon-carat-1-n { background-position: 0 0; }
 .ui-icon-carat-1-ne { background-position: -16px 0; }
 .ui-icon-carat-1-e { background-position: -32px 0; }
@@ -465,11 +519,42 @@ body .ui-tooltip { border-width: 2px; }
 ----------------------------------*/
 
 /* Corner radius */
-.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px/*{cornerRadius}*/; -webkit-border-top-left-radius: 4px/*{cornerRadius}*/; -khtml-border-top-left-radius: 4px/*{cornerRadius}*/; border-top-left-radius: 4px/*{cornerRadius}*/; }
-.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px/*{cornerRadius}*/; -webkit-border-top-right-radius: 4px/*{cornerRadius}*/; -khtml-border-top-right-radius: 4px/*{cornerRadius}*/; border-top-right-radius: 4px/*{cornerRadius}*/; }
-.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px/*{cornerRadius}*/; -webkit-border-bottom-left-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-left-radius: 4px/*{cornerRadius}*/; border-bottom-left-radius: 4px/*{cornerRadius}*/; }
-.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px/*{cornerRadius}*/; -webkit-border-bottom-right-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-right-radius: 4px/*{cornerRadius}*/; border-bottom-right-radius: 4px/*{cornerRadius}*/; }
+.ui-corner-all,
+.ui-corner-top,
+.ui-corner-left,
+.ui-corner-tl {
+       border-top-left-radius: 4px;
+}
+.ui-corner-all,
+.ui-corner-top,
+.ui-corner-right,
+.ui-corner-tr {
+       border-top-right-radius: 4px;
+}
+.ui-corner-all,
+.ui-corner-bottom,
+.ui-corner-left,
+.ui-corner-bl {
+       border-bottom-left-radius: 4px;
+}
+.ui-corner-all,
+.ui-corner-bottom,
+.ui-corner-right,
+.ui-corner-br {
+       border-bottom-right-radius: 4px;
+}
 
 /* Overlays */
-.ui-widget-overlay { background: #aaaaaa/*{bgColorOverlay}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlOverlay}*/ 50%/*{bgOverlayXPos}*/ 50%/*{bgOverlayYPos}*/ repeat-x/*{bgOverlayRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityOverlay}*/; }
-.ui-widget-shadow { margin: -8px/*{offsetTopShadow}*/ 0 0 -8px/*{offsetLeftShadow}*/; padding: 8px/*{thicknessShadow}*/; background: #aaaaaa/*{bgColorShadow}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlShadow}*/ 50%/*{bgShadowXPos}*/ 50%/*{bgShadowYPos}*/ repeat-x/*{bgShadowRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityShadow}*/; -moz-border-radius: 8px/*{cornerRadiusShadow}*/; -khtml-border-radius: 8px/*{cornerRadiusShadow}*/; -webkit-border-radius: 8px/*{cornerRadiusShadow}*/; border-radius: 8px/*{cornerRadiusShadow}*/; }
\ No newline at end of file
+.ui-widget-overlay {
+       background: #666666 url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_diagonals-thick_20_666666_40x40.png") 50% 50% repeat;
+       opacity: .5;
+       filter: Alpha(Opacity=50);
+}
+.ui-widget-shadow {
+       margin: -5px 0 0 -5px;
+       padding: 5px;
+       background: #000000 url("//karma-prod.s3.amazonaws.com/css/images/ui-bg_flat_10_000000_40x100.png") 50% 50% repeat-x;
+       opacity: .2;
+       filter: Alpha(Opacity=20);
+       border-radius: 5px;
+}
diff --git a/karmaworld/assets/css/jquery.dataTables.css b/karmaworld/assets/css/jquery.dataTables.css
new file mode 100644 (file)
index 0000000..71fff7c
--- /dev/null
@@ -0,0 +1,221 @@
+
+/*
+ * Table
+ */
+table.dataTable {
+       margin: 0 auto;
+       clear: both;
+       width: 100%;
+}
+
+table.dataTable thead th {
+       padding: 3px 18px 3px 10px;
+       border-bottom: 1px solid black;
+       font-weight: bold;
+       cursor: pointer;
+       *cursor: hand;
+}
+
+table.dataTable tfoot th {
+       padding: 3px 18px 3px 10px;
+       border-top: 1px solid black;
+       font-weight: bold;
+}
+
+table.dataTable td {
+       padding: 3px 10px;
+}
+
+table.dataTable td.center,
+table.dataTable td.dataTables_empty {
+       text-align: center;
+}
+
+table.dataTable tr.odd { background-color: #E2E4FF; }
+table.dataTable tr.even { background-color: white; }
+
+table.dataTable tr.odd td.sorting_1 { background-color: #D3D6FF; }
+table.dataTable tr.odd td.sorting_2 { background-color: #DADCFF; }
+table.dataTable tr.odd td.sorting_3 { background-color: #E0E2FF; }
+table.dataTable tr.even td.sorting_1 { background-color: #EAEBFF; }
+table.dataTable tr.even td.sorting_2 { background-color: #F2F3FF; }
+table.dataTable tr.even td.sorting_3 { background-color: #F9F9FF; }
+
+
+/*
+ * Table wrapper
+ */
+.dataTables_wrapper {
+       position: relative;
+       clear: both;
+       *zoom: 1;
+}
+
+
+/*
+ * Page length menu
+ */
+.dataTables_length {
+       float: left;
+}
+
+
+/*
+ * Filter
+ */
+.dataTables_filter {
+       float: right;
+       text-align: right;
+}
+
+
+/*
+ * Table information
+ */
+.dataTables_info {
+       clear: both;
+       float: left;
+}
+
+
+/*
+ * Pagination
+ */
+.dataTables_paginate {
+       float: right;
+       text-align: right;
+}
+
+/* Two button pagination - previous / next */
+.paginate_disabled_previous,
+.paginate_enabled_previous,
+.paginate_disabled_next,
+.paginate_enabled_next {
+       height: 19px;
+       float: left;
+       cursor: pointer;
+       *cursor: hand;
+       color: #111 !important;
+}
+.paginate_disabled_previous:hover,
+.paginate_enabled_previous:hover,
+.paginate_disabled_next:hover,
+.paginate_enabled_next:hover {
+       text-decoration: none !important;
+}
+.paginate_disabled_previous:active,
+.paginate_enabled_previous:active,
+.paginate_disabled_next:active,
+.paginate_enabled_next:active {
+       outline: none;
+}
+
+.paginate_disabled_previous,
+.paginate_disabled_next {
+       color: #666 !important;
+}
+.paginate_disabled_previous,
+.paginate_enabled_previous {
+       padding-left: 23px;
+}
+.paginate_disabled_next,
+.paginate_enabled_next {
+       padding-right: 23px;
+       margin-left: 10px;
+}
+
+.paginate_enabled_previous { background: url('//karma-prod.s3.amazonaws.com/css/images/back_enabled.png') no-repeat top left; }
+.paginate_enabled_previous:hover { background: url('//karma-prod.s3.amazonaws.com/css/images/back_enabled_hover.png') no-repeat top left; }
+.paginate_disabled_previous { background: url('//karma-prod.s3.amazonaws.com/css/images/back_disabled.png') no-repeat top left; }
+
+.paginate_enabled_next { background: url('//karma-prod.s3.amazonaws.com/css/images/forward_enabled.png') no-repeat top right; }
+.paginate_enabled_next:hover { background: url('//karma-prod.s3.amazonaws.com/css/images/forward_enabled_hover.png') no-repeat top right; }
+.paginate_disabled_next { background: url('//karma-prod.s3.amazonaws.com/css/images/forward_disabled.png') no-repeat top right; }
+
+/* Full number pagination */
+.paging_full_numbers {
+       height: 22px;
+       line-height: 22px;
+}
+.paging_full_numbers a:active {
+       outline: none
+}
+.paging_full_numbers a:hover {
+       text-decoration: none;
+}
+
+.paging_full_numbers a.paginate_button,
+.paging_full_numbers a.paginate_active {
+       border: 1px solid #aaa;
+       -webkit-border-radius: 5px;
+       -moz-border-radius: 5px;
+       border-radius: 5px;
+       padding: 2px 5px;
+       margin: 0 3px;
+       cursor: pointer;
+       *cursor: hand;
+       color: #333 !important;
+}
+
+.paging_full_numbers a.paginate_button {
+       background-color: #ddd;
+}
+
+.paging_full_numbers a.paginate_button:hover {
+       background-color: #ccc;
+       text-decoration: none !important;
+}
+
+.paging_full_numbers a.paginate_active {
+       background-color: #99B3FF;
+}
+
+
+/*
+ * Processing indicator
+ */
+.dataTables_processing {
+       position: absolute;
+       top: 50%;
+       left: 50%;
+       width: 250px;
+       height: 30px;
+       margin-left: -125px;
+       margin-top: -15px;
+       padding: 14px 0 2px 0;
+       border: 1px solid #ddd;
+       text-align: center;
+       color: #999;
+       font-size: 14px;
+       background-color: white;
+}
+
+
+/*
+ * Sorting
+ */
+.sorting { background: url('//karma-prod.s3.amazonaws.com/css/images/sort_both.png') no-repeat center right; }
+.sorting_asc { background: url('//karma-prod.s3.amazonaws.com/css/images/sort_asc.png') no-repeat center right; }
+.sorting_desc { background: url('//karma-prod.s3.amazonaws.com/css/images/sort_desc.png') no-repeat center right; }
+
+.sorting_asc_disabled { background: url('//karma-prod.s3.amazonaws.com/css/images/sort_asc_disabled.png') no-repeat center right; }
+.sorting_desc_disabled { background: url('//karma-prod.s3.amazonaws.com/css/images/sort_desc_disabled.png') no-repeat center right; }
+table.dataTable thead th:active,
+table.dataTable thead td:active {
+       outline: none;
+}
+
+
+/*
+ * Scrolling
+ */
+.dataTables_scroll {
+       clear: both;
+}
+
+.dataTables_scrollBody {
+       *margin-top: -1px;
+       -webkit-overflow-scrolling: touch;
+}
+
index 3b7be385c692819dc53301f4bf7f2cfb321c6e90..f29e79daff217591cee87cc4b0eb954c3211484e 100644 (file)
@@ -41,9 +41,9 @@ $(function() {
           if (data['status'] === 'success') {
             response($.map(data['schools'], function(item) {
               return {
-                  value: item.name,
-                  real_value: item.id,
-                  label: item.name,
+                  'value': item.name,
+                  'real_value': item.id,
+                  'label': item.name
               };
             }));
           } else {
index b0ddc762fc05c9feee7caf8120b46b68d9ac9661..59949c5cf84a5760180f15503059bec54dacc2ef 100644 (file)
@@ -11,8 +11,8 @@ window.KARMAWORLD.Course = {
             if (data['status'] === 'success') {
               response($.map(data['courses'], function(item) {
                 return {
-                    value: item.name,
-                    label: item.name,
+                    'value': item.name,
+                    'label': item.name
                 };
               }));
             }
@@ -39,9 +39,9 @@ window.KARMAWORLD.Course = {
               // Fill in the autocomplete entries
               response($.map(data['instructors'], function(item) {
                 return {
-                    value: item.name,
-                    label: item.name,
-                    url:   item.url
+                    'value': item.name,
+                    'label': item.name,
+                    'url':   item.url
                 };
               }));
             }
diff --git a/karmaworld/assets/js/foundation.reveal.js b/karmaworld/assets/js/foundation.reveal.js
new file mode 100644 (file)
index 0000000..288a4a7
--- /dev/null
@@ -0,0 +1,427 @@
+;(function ($, window, document, undefined) {
+  'use strict';
+
+  Foundation.libs.reveal = {
+    name : 'reveal',
+
+    version : '5.2.1',
+
+    locked : false,
+
+    settings : {
+      animation: 'fadeAndPop',
+      animation_speed: 250,
+      close_on_background_click: true,
+      close_on_esc: true,
+      dismiss_modal_class: 'close-reveal-modal',
+      bg_class: 'reveal-modal-bg',
+      open: function(){},
+      opened: function(){},
+      close: function(){},
+      closed: function(){},
+      bg : $('.reveal-modal-bg'),
+      css : {
+        open : {
+          'opacity': 0,
+          'visibility': 'visible',
+          'display' : 'block'
+        },
+        close : {
+          'opacity': 1,
+          'visibility': 'hidden',
+          'display': 'none'
+        }
+      }
+    },
+
+    init : function (scope, method, options) {
+      $.extend(true, this.settings, method, options);
+      this.bindings(method, options);
+    },
+
+    events : function (scope) {
+      var self = this,
+          S = self.S;
+
+      S(this.scope)
+        .off('.reveal')
+        .on('click.fndtn.reveal', '[' + this.add_namespace('data-reveal-id') + ']', function (e) {
+          e.preventDefault();
+
+          if (!self.locked) {
+            var element = S(this),
+                ajax = element.data(self.data_attr('reveal-ajax'));
+
+            self.locked = true;
+
+            if (typeof ajax === 'undefined') {
+              self.open.call(self, element);
+            } else {
+              var url = ajax === true ? element.attr('href') : ajax;
+
+              self.open.call(self, element, {url: url});
+            }
+          }
+        });
+
+      S(document)
+        .on('touchend.fndtn.reveal click.fndtn.reveal', this.close_targets(), function (e) {
+
+          e.preventDefault();
+
+          if (!self.locked) {
+            var settings = S('[' + self.attr_name() + '].open').data(self.attr_name(true) + '-init'),
+                bg_clicked = S(e.target)[0] === S('.' + settings.bg_class)[0];
+
+            if (bg_clicked) {
+              if (settings.close_on_background_click) {
+                e.stopPropagation();
+              } else {
+                return;
+              }
+            }
+
+            self.locked = true;
+            self.close.call(self, bg_clicked ? S('[' + self.attr_name() + '].open') : S(this).closest('[' + self.attr_name() + ']'));
+          }
+        });
+
+      if(S('[' + self.attr_name() + ']', this.scope).length > 0) {
+        S(this.scope)
+          // .off('.reveal')
+          .on('open.fndtn.reveal', this.settings.open)
+          .on('opened.fndtn.reveal', this.settings.opened)
+          .on('opened.fndtn.reveal', this.open_video)
+          .on('close.fndtn.reveal', this.settings.close)
+          .on('closed.fndtn.reveal', this.settings.closed)
+          .on('closed.fndtn.reveal', this.close_video);
+      } else {
+        S(this.scope)
+          // .off('.reveal')
+          .on('open.fndtn.reveal', '[' + self.attr_name() + ']', this.settings.open)
+          .on('opened.fndtn.reveal', '[' + self.attr_name() + ']', this.settings.opened)
+          .on('opened.fndtn.reveal', '[' + self.attr_name() + ']', this.open_video)
+          .on('close.fndtn.reveal', '[' + self.attr_name() + ']', this.settings.close)
+          .on('closed.fndtn.reveal', '[' + self.attr_name() + ']', this.settings.closed)
+          .on('closed.fndtn.reveal', '[' + self.attr_name() + ']', this.close_video);
+      }
+
+      return true;
+    },
+
+    // PATCH #3: turning on key up capture only when a reveal window is open
+    key_up_on : function (scope) {
+      var self = this;
+
+      // PATCH #1: fixing multiple keyup event trigger from single key press
+      self.S('body').off('keyup.fndtn.reveal').on('keyup.fndtn.reveal', function ( event ) {
+        var open_modal = self.S('[' + self.attr_name() + '].open'),
+            settings = open_modal.data(self.attr_name(true) + '-init');
+        // PATCH #2: making sure that the close event can be called only while unlocked,
+        //           so that multiple keyup.fndtn.reveal events don't prevent clean closing of the reveal window.
+        if ( settings && event.which === 27  && settings.close_on_esc && !self.locked) { // 27 is the keycode for the Escape key
+          self.close.call(self, open_modal);
+        }
+      });
+
+      return true;
+    },
+
+    // PATCH #3: turning on key up capture only when a reveal window is open
+    key_up_off : function (scope) {
+      this.S('body').off('keyup.fndtn.reveal');
+      return true;
+    },
+
+    open : function (target, ajax_settings) {
+      var self = this;
+      if (target) {
+        if (typeof target.selector !== 'undefined') {
+          var modal = self.S('#' + target.data(self.data_attr('reveal-id')));
+        } else {
+          var modal = self.S(this.scope);
+
+          ajax_settings = target;
+        }
+      } else {
+        var modal = self.S(this.scope);
+      }
+
+      var settings = modal.data(self.attr_name(true) + '-init');
+
+      if (!modal.hasClass('open')) {
+        var open_modal = self.S('[' + self.attr_name() + '].open');
+
+        if (typeof modal.data('css-top') === 'undefined') {
+          modal.data('css-top', parseInt(modal.css('top'), 10))
+            .data('offset', this.cache_offset(modal));
+        }
+
+        this.key_up_on(modal);    // PATCH #3: turning on key up capture only when a reveal window is open
+        modal.trigger('open');
+
+        if (open_modal.length < 1) {
+          this.toggle_bg(modal);
+        }
+
+        if (typeof ajax_settings === 'string') {
+          ajax_settings = {
+            url: ajax_settings
+          };
+        }
+
+        if (typeof ajax_settings === 'undefined' || !ajax_settings.url) {
+          if (open_modal.length > 0) {
+            this.hide(open_modal, settings.css.close);
+          }
+
+          this.show(modal, settings.css.open);
+        } else {
+          var old_success = typeof ajax_settings.success !== 'undefined' ? ajax_settings.success : null;
+
+          $.extend(ajax_settings, {
+            success: function (data, textStatus, jqXHR) {
+              if ( $.isFunction(old_success) ) {
+                old_success(data, textStatus, jqXHR);
+              }
+
+              modal.html(data);
+              self.S(modal).foundation('section', 'reflow');
+
+              if (open_modal.length > 0) {
+                self.hide(open_modal, settings.css.close);
+              }
+              self.show(modal, settings.css.open);
+            }
+          });
+
+          $.ajax(ajax_settings);
+        }
+      }
+    },
+
+    close : function (modal) {
+      var modal = modal && modal.length ? modal : this.S(this.scope),
+          open_modals = this.S('[' + this.attr_name() + '].open'),
+          settings = modal.data(this.attr_name(true) + '-init');
+
+      if (open_modals.length > 0) {
+        this.locked = true;
+        this.key_up_off(modal);   // PATCH #3: turning on key up capture only when a reveal window is open
+        modal.trigger('close');
+        this.toggle_bg(modal);
+        this.hide(open_modals, settings.css.close, settings);
+      }
+    },
+
+    close_targets : function () {
+      var base = '.' + this.settings.dismiss_modal_class;
+
+      if (this.settings.close_on_background_click) {
+        return base + ', .' + this.settings.bg_class;
+      }
+
+      return base;
+    },
+
+    toggle_bg : function (modal) {
+      var settings = modal.data(this.attr_name(true));
+
+      if (this.S('.' + this.settings.bg_class).length === 0) {
+        this.settings.bg = $('<div />', {'class': this.settings.bg_class})
+          .appendTo('body').hide();
+      }
+
+      if (this.settings.bg.filter(':visible').length > 0) {
+        this.hide(this.settings.bg);
+      } else {
+        this.show(this.settings.bg);
+      }
+    },
+
+    show : function (el, css) {
+      // is modal
+      if (css) {
+        var settings = el.data(this.attr_name(true) + '-init');
+        if (el.parent('body').length === 0) {
+          var placeholder = el.wrap('<div style="display: none;" />').parent(),
+              rootElement = this.settings.rootElement || 'body';
+
+          el.on('closed.fndtn.reveal.wrapped', function() {
+            el.detach().appendTo(placeholder);
+            el.unwrap().unbind('closed.fndtn.reveal.wrapped');
+          });
+
+          el.detach().appendTo(rootElement);
+        }
+
+        var animData = getAnimationData(settings.animation);
+        if (!animData.animate) {
+          this.locked = false;
+        }
+        if (animData.pop) {
+          css.top = $(window).scrollTop() - el.data('offset') + 'px';
+          var end_css = {
+            top: $(window).scrollTop() + el.data('css-top') + 'px',
+            opacity: 1
+          };
+
+          return setTimeout(function () {
+            return el
+              .css(css)
+              .animate(end_css, settings.animation_speed, 'linear', function () {
+                this.locked = false;
+                el.trigger('opened');
+              }.bind(this))
+              .addClass('open');
+          }.bind(this), settings.animation_speed / 2);
+        }
+
+        if (animData.fade) {
+          css.top = $(window).scrollTop() + el.data('css-top') + 'px';
+          var end_css = {opacity: 1};
+
+          return setTimeout(function () {
+            return el
+              .css(css)
+              .animate(end_css, settings.animation_speed, 'linear', function () {
+                this.locked = false;
+                el.trigger('opened');
+              }.bind(this))
+              .addClass('open');
+          }.bind(this), settings.animation_speed / 2);
+        }
+
+        return el.css(css).show().css({opacity: 1}).addClass('open').trigger('opened');
+      }
+
+      var settings = this.settings;
+
+      // should we animate the background?
+      if (getAnimationData(settings.animation).fade) {
+        return el.fadeIn(settings.animation_speed / 2);
+      }
+
+      this.locked = false;
+
+      return el.show();
+    },
+
+    hide : function (el, css) {
+      // is modal
+      if (css) {
+        var settings = el.data(this.attr_name(true) + '-init');
+        var animData = getAnimationData(settings.animation);
+        if (!animData.animate) {
+          this.locked = false;
+        }
+        if (animData.pop) {
+          var end_css = {
+            top: - $(window).scrollTop() - el.data('offset') + 'px',
+            opacity: 0
+          };
+
+          return setTimeout(function () {
+            return el
+              .animate(end_css, settings.animation_speed, 'linear', function () {
+                this.locked = false;
+                el.css(css).trigger('closed');
+              }.bind(this))
+              .removeClass('open');
+          }.bind(this), settings.animation_speed / 2);
+        }
+
+        if (animData.fade) {
+          var end_css = {opacity: 0};
+
+          return setTimeout(function () {
+            return el
+              .animate(end_css, settings.animation_speed, 'linear', function () {
+                this.locked = false;
+                el.css(css).trigger('closed');
+              }.bind(this))
+              .removeClass('open');
+          }.bind(this), settings.animation_speed / 2);
+        }
+
+        return el.hide().css(css).removeClass('open').trigger('closed');
+      }
+
+      var settings = this.settings;
+
+      // should we animate the background?
+      if (getAnimationData(settings.animation).fade) {
+        return el.fadeOut(settings.animation_speed / 2);
+      }
+
+      return el.hide();
+    },
+
+    close_video : function (e) {
+      var video = $('.flex-video', e.target),
+          iframe = $('iframe', video);
+
+      if (iframe.length > 0) {
+        iframe.attr('data-src', iframe[0].src);
+        iframe.attr('src', 'about:blank');
+        video.hide();
+      }
+    },
+
+    open_video : function (e) {
+      var video = $('.flex-video', e.target),
+          iframe = video.find('iframe');
+
+      if (iframe.length > 0) {
+        var data_src = iframe.attr('data-src');
+        if (typeof data_src === 'string') {
+          iframe[0].src = iframe.attr('data-src');
+        } else {
+          var src = iframe[0].src;
+          iframe[0].src = undefined;
+          iframe[0].src = src;
+        }
+        video.show();
+      }
+    },
+
+    data_attr: function (str) {
+      if (this.namespace.length > 0) {
+        return this.namespace + '-' + str;
+      }
+
+      return str;
+    },
+
+    cache_offset : function (modal) {
+      var offset = modal.show().height() + parseInt(modal.css('top'), 10);
+
+      modal.hide();
+
+      return offset;
+    },
+
+    off : function () {
+      $(this.scope).off('.fndtn.reveal');
+    },
+
+    reflow : function () {}
+  };
+
+  /*
+   * getAnimationData('popAndFade') // {animate: true,  pop: true,  fade: true}
+   * getAnimationData('fade')       // {animate: true,  pop: false, fade: true}
+   * getAnimationData('pop')        // {animate: true,  pop: true,  fade: false}
+   * getAnimationData('foo')        // {animate: false, pop: false, fade: false}
+   * getAnimationData(null)         // {animate: false, pop: false, fade: false}
+   */
+  function getAnimationData(str) {
+    var fade = /fade/i.test(str);
+    var pop = /pop/i.test(str);
+    return {
+      animate: fade || pop,
+      pop: pop,
+      fade: fade
+    };
+  }
+}(jQuery, this, this.document));
index eb4ec72365fbd6706c1373c9e14ff899d561967a..4d9adece85d986d5de7b13541c0caac7e2feca07 100644 (file)
@@ -1,6 +1,6 @@
-/*! jQuery UI - v1.10.4 - 2014-01-17
+/*! jQuery UI - v1.10.4 - 2014-04-23
 * http://jqueryui.com
-* Includes: jquery.ui.core.js, jquery.ui.widget.js, jquery.ui.mouse.js, jquery.ui.position.js, jquery.ui.accordion.js, jquery.ui.autocomplete.js, jquery.ui.button.js, jquery.ui.datepicker.js, jquery.ui.dialog.js, jquery.ui.draggable.js, jquery.ui.droppable.js, jquery.ui.effect.js, jquery.ui.effect-blind.js, jquery.ui.effect-bounce.js, jquery.ui.effect-clip.js, jquery.ui.effect-drop.js, jquery.ui.effect-explode.js, jquery.ui.effect-fade.js, jquery.ui.effect-fold.js, jquery.ui.effect-highlight.js, jquery.ui.effect-pulsate.js, jquery.ui.effect-scale.js, jquery.ui.effect-shake.js, jquery.ui.effect-slide.js, jquery.ui.effect-transfer.js, jquery.ui.menu.js, jquery.ui.progressbar.js, jquery.ui.resizable.js, jquery.ui.selectable.js, jquery.ui.slider.js, jquery.ui.sortable.js, jquery.ui.spinner.js, jquery.ui.tabs.js, jquery.ui.tooltip.js
+* Includes: jquery.ui.core.js, jquery.ui.widget.js, jquery.ui.mouse.js, jquery.ui.position.js, jquery.ui.autocomplete.js, jquery.ui.menu.js
 * Copyright 2014 jQuery Foundation and other contributors; Licensed MIT */
 
 (function( $, undefined ) {
@@ -1473,562 +1473,6 @@ $.ui.position = {
 }( jQuery ) );
 (function( $, undefined ) {
 
-var uid = 0,
-       hideProps = {},
-       showProps = {};
-
-hideProps.height = hideProps.paddingTop = hideProps.paddingBottom =
-       hideProps.borderTopWidth = hideProps.borderBottomWidth = "hide";
-showProps.height = showProps.paddingTop = showProps.paddingBottom =
-       showProps.borderTopWidth = showProps.borderBottomWidth = "show";
-
-$.widget( "ui.accordion", {
-       version: "1.10.4",
-       options: {
-               active: 0,
-               animate: {},
-               collapsible: false,
-               event: "click",
-               header: "> li > :first-child,> :not(li):even",
-               heightStyle: "auto",
-               icons: {
-                       activeHeader: "ui-icon-triangle-1-s",
-                       header: "ui-icon-triangle-1-e"
-               },
-
-               // callbacks
-               activate: null,
-               beforeActivate: null
-       },
-
-       _create: function() {
-               var options = this.options;
-               this.prevShow = this.prevHide = $();
-               this.element.addClass( "ui-accordion ui-widget ui-helper-reset" )
-                       // ARIA
-                       .attr( "role", "tablist" );
-
-               // don't allow collapsible: false and active: false / null
-               if ( !options.collapsible && (options.active === false || options.active == null) ) {
-                       options.active = 0;
-               }
-
-               this._processPanels();
-               // handle negative values
-               if ( options.active < 0 ) {
-                       options.active += this.headers.length;
-               }
-               this._refresh();
-       },
-
-       _getCreateEventData: function() {
-               return {
-                       header: this.active,
-                       panel: !this.active.length ? $() : this.active.next(),
-                       content: !this.active.length ? $() : this.active.next()
-               };
-       },
-
-       _createIcons: function() {
-               var icons = this.options.icons;
-               if ( icons ) {
-                       $( "<span>" )
-                               .addClass( "ui-accordion-header-icon ui-icon " + icons.header )
-                               .prependTo( this.headers );
-                       this.active.children( ".ui-accordion-header-icon" )
-                               .removeClass( icons.header )
-                               .addClass( icons.activeHeader );
-                       this.headers.addClass( "ui-accordion-icons" );
-               }
-       },
-
-       _destroyIcons: function() {
-               this.headers
-                       .removeClass( "ui-accordion-icons" )
-                       .children( ".ui-accordion-header-icon" )
-                               .remove();
-       },
-
-       _destroy: function() {
-               var contents;
-
-               // clean up main element
-               this.element
-                       .removeClass( "ui-accordion ui-widget ui-helper-reset" )
-                       .removeAttr( "role" );
-
-               // clean up headers
-               this.headers
-                       .removeClass( "ui-accordion-header ui-accordion-header-active ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top" )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-expanded" )
-                       .removeAttr( "aria-selected" )
-                       .removeAttr( "aria-controls" )
-                       .removeAttr( "tabIndex" )
-                       .each(function() {
-                               if ( /^ui-accordion/.test( this.id ) ) {
-                                       this.removeAttribute( "id" );
-                               }
-                       });
-               this._destroyIcons();
-
-               // clean up content panels
-               contents = this.headers.next()
-                       .css( "display", "" )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-hidden" )
-                       .removeAttr( "aria-labelledby" )
-                       .removeClass( "ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-state-disabled" )
-                       .each(function() {
-                               if ( /^ui-accordion/.test( this.id ) ) {
-                                       this.removeAttribute( "id" );
-                               }
-                       });
-               if ( this.options.heightStyle !== "content" ) {
-                       contents.css( "height", "" );
-               }
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "active" ) {
-                       // _activate() will handle invalid values and update this.options
-                       this._activate( value );
-                       return;
-               }
-
-               if ( key === "event" ) {
-                       if ( this.options.event ) {
-                               this._off( this.headers, this.options.event );
-                       }
-                       this._setupEvents( value );
-               }
-
-               this._super( key, value );
-
-               // setting collapsible: false while collapsed; open first panel
-               if ( key === "collapsible" && !value && this.options.active === false ) {
-                       this._activate( 0 );
-               }
-
-               if ( key === "icons" ) {
-                       this._destroyIcons();
-                       if ( value ) {
-                               this._createIcons();
-                       }
-               }
-
-               // #5332 - opacity doesn't cascade to positioned elements in IE
-               // so we need to add the disabled class to the headers and panels
-               if ( key === "disabled" ) {
-                       this.headers.add( this.headers.next() )
-                               .toggleClass( "ui-state-disabled", !!value );
-               }
-       },
-
-       _keydown: function( event ) {
-               if ( event.altKey || event.ctrlKey ) {
-                       return;
-               }
-
-               var keyCode = $.ui.keyCode,
-                       length = this.headers.length,
-                       currentIndex = this.headers.index( event.target ),
-                       toFocus = false;
-
-               switch ( event.keyCode ) {
-                       case keyCode.RIGHT:
-                       case keyCode.DOWN:
-                               toFocus = this.headers[ ( currentIndex + 1 ) % length ];
-                               break;
-                       case keyCode.LEFT:
-                       case keyCode.UP:
-                               toFocus = this.headers[ ( currentIndex - 1 + length ) % length ];
-                               break;
-                       case keyCode.SPACE:
-                       case keyCode.ENTER:
-                               this._eventHandler( event );
-                               break;
-                       case keyCode.HOME:
-                               toFocus = this.headers[ 0 ];
-                               break;
-                       case keyCode.END:
-                               toFocus = this.headers[ length - 1 ];
-                               break;
-               }
-
-               if ( toFocus ) {
-                       $( event.target ).attr( "tabIndex", -1 );
-                       $( toFocus ).attr( "tabIndex", 0 );
-                       toFocus.focus();
-                       event.preventDefault();
-               }
-       },
-
-       _panelKeyDown : function( event ) {
-               if ( event.keyCode === $.ui.keyCode.UP && event.ctrlKey ) {
-                       $( event.currentTarget ).prev().focus();
-               }
-       },
-
-       refresh: function() {
-               var options = this.options;
-               this._processPanels();
-
-               // was collapsed or no panel
-               if ( ( options.active === false && options.collapsible === true ) || !this.headers.length ) {
-                       options.active = false;
-                       this.active = $();
-               // active false only when collapsible is true
-               } else if ( options.active === false ) {
-                       this._activate( 0 );
-               // was active, but active panel is gone
-               } else if ( this.active.length && !$.contains( this.element[ 0 ], this.active[ 0 ] ) ) {
-                       // all remaining panel are disabled
-                       if ( this.headers.length === this.headers.find(".ui-state-disabled").length ) {
-                               options.active = false;
-                               this.active = $();
-                       // activate previous panel
-                       } else {
-                               this._activate( Math.max( 0, options.active - 1 ) );
-                       }
-               // was active, active panel still exists
-               } else {
-                       // make sure active index is correct
-                       options.active = this.headers.index( this.active );
-               }
-
-               this._destroyIcons();
-
-               this._refresh();
-       },
-
-       _processPanels: function() {
-               this.headers = this.element.find( this.options.header )
-                       .addClass( "ui-accordion-header ui-helper-reset ui-state-default ui-corner-all" );
-
-               this.headers.next()
-                       .addClass( "ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom" )
-                       .filter(":not(.ui-accordion-content-active)")
-                       .hide();
-       },
-
-       _refresh: function() {
-               var maxHeight,
-                       options = this.options,
-                       heightStyle = options.heightStyle,
-                       parent = this.element.parent(),
-                       accordionId = this.accordionId = "ui-accordion-" +
-                               (this.element.attr( "id" ) || ++uid);
-
-               this.active = this._findActive( options.active )
-                       .addClass( "ui-accordion-header-active ui-state-active ui-corner-top" )
-                       .removeClass( "ui-corner-all" );
-               this.active.next()
-                       .addClass( "ui-accordion-content-active" )
-                       .show();
-
-               this.headers
-                       .attr( "role", "tab" )
-                       .each(function( i ) {
-                               var header = $( this ),
-                                       headerId = header.attr( "id" ),
-                                       panel = header.next(),
-                                       panelId = panel.attr( "id" );
-                               if ( !headerId ) {
-                                       headerId = accordionId + "-header-" + i;
-                                       header.attr( "id", headerId );
-                               }
-                               if ( !panelId ) {
-                                       panelId = accordionId + "-panel-" + i;
-                                       panel.attr( "id", panelId );
-                               }
-                               header.attr( "aria-controls", panelId );
-                               panel.attr( "aria-labelledby", headerId );
-                       })
-                       .next()
-                               .attr( "role", "tabpanel" );
-
-               this.headers
-                       .not( this.active )
-                       .attr({
-                               "aria-selected": "false",
-                               "aria-expanded": "false",
-                               tabIndex: -1
-                       })
-                       .next()
-                               .attr({
-                                       "aria-hidden": "true"
-                               })
-                               .hide();
-
-               // make sure at least one header is in the tab order
-               if ( !this.active.length ) {
-                       this.headers.eq( 0 ).attr( "tabIndex", 0 );
-               } else {
-                       this.active.attr({
-                               "aria-selected": "true",
-                               "aria-expanded": "true",
-                               tabIndex: 0
-                       })
-                       .next()
-                               .attr({
-                                       "aria-hidden": "false"
-                               });
-               }
-
-               this._createIcons();
-
-               this._setupEvents( options.event );
-
-               if ( heightStyle === "fill" ) {
-                       maxHeight = parent.height();
-                       this.element.siblings( ":visible" ).each(function() {
-                               var elem = $( this ),
-                                       position = elem.css( "position" );
-
-                               if ( position === "absolute" || position === "fixed" ) {
-                                       return;
-                               }
-                               maxHeight -= elem.outerHeight( true );
-                       });
-
-                       this.headers.each(function() {
-                               maxHeight -= $( this ).outerHeight( true );
-                       });
-
-                       this.headers.next()
-                               .each(function() {
-                                       $( this ).height( Math.max( 0, maxHeight -
-                                               $( this ).innerHeight() + $( this ).height() ) );
-                               })
-                               .css( "overflow", "auto" );
-               } else if ( heightStyle === "auto" ) {
-                       maxHeight = 0;
-                       this.headers.next()
-                               .each(function() {
-                                       maxHeight = Math.max( maxHeight, $( this ).css( "height", "" ).height() );
-                               })
-                               .height( maxHeight );
-               }
-       },
-
-       _activate: function( index ) {
-               var active = this._findActive( index )[ 0 ];
-
-               // trying to activate the already active panel
-               if ( active === this.active[ 0 ] ) {
-                       return;
-               }
-
-               // trying to collapse, simulate a click on the currently active header
-               active = active || this.active[ 0 ];
-
-               this._eventHandler({
-                       target: active,
-                       currentTarget: active,
-                       preventDefault: $.noop
-               });
-       },
-
-       _findActive: function( selector ) {
-               return typeof selector === "number" ? this.headers.eq( selector ) : $();
-       },
-
-       _setupEvents: function( event ) {
-               var events = {
-                       keydown: "_keydown"
-               };
-               if ( event ) {
-                       $.each( event.split(" "), function( index, eventName ) {
-                               events[ eventName ] = "_eventHandler";
-                       });
-               }
-
-               this._off( this.headers.add( this.headers.next() ) );
-               this._on( this.headers, events );
-               this._on( this.headers.next(), { keydown: "_panelKeyDown" });
-               this._hoverable( this.headers );
-               this._focusable( this.headers );
-       },
-
-       _eventHandler: function( event ) {
-               var options = this.options,
-                       active = this.active,
-                       clicked = $( event.currentTarget ),
-                       clickedIsActive = clicked[ 0 ] === active[ 0 ],
-                       collapsing = clickedIsActive && options.collapsible,
-                       toShow = collapsing ? $() : clicked.next(),
-                       toHide = active.next(),
-                       eventData = {
-                               oldHeader: active,
-                               oldPanel: toHide,
-                               newHeader: collapsing ? $() : clicked,
-                               newPanel: toShow
-                       };
-
-               event.preventDefault();
-
-               if (
-                               // click on active header, but not collapsible
-                               ( clickedIsActive && !options.collapsible ) ||
-                               // allow canceling activation
-                               ( this._trigger( "beforeActivate", event, eventData ) === false ) ) {
-                       return;
-               }
-
-               options.active = collapsing ? false : this.headers.index( clicked );
-
-               // when the call to ._toggle() comes after the class changes
-               // it causes a very odd bug in IE 8 (see #6720)
-               this.active = clickedIsActive ? $() : clicked;
-               this._toggle( eventData );
-
-               // switch classes
-               // corner classes on the previously active header stay after the animation
-               active.removeClass( "ui-accordion-header-active ui-state-active" );
-               if ( options.icons ) {
-                       active.children( ".ui-accordion-header-icon" )
-                               .removeClass( options.icons.activeHeader )
-                               .addClass( options.icons.header );
-               }
-
-               if ( !clickedIsActive ) {
-                       clicked
-                               .removeClass( "ui-corner-all" )
-                               .addClass( "ui-accordion-header-active ui-state-active ui-corner-top" );
-                       if ( options.icons ) {
-                               clicked.children( ".ui-accordion-header-icon" )
-                                       .removeClass( options.icons.header )
-                                       .addClass( options.icons.activeHeader );
-                       }
-
-                       clicked
-                               .next()
-                               .addClass( "ui-accordion-content-active" );
-               }
-       },
-
-       _toggle: function( data ) {
-               var toShow = data.newPanel,
-                       toHide = this.prevShow.length ? this.prevShow : data.oldPanel;
-
-               // handle activating a panel during the animation for another activation
-               this.prevShow.add( this.prevHide ).stop( true, true );
-               this.prevShow = toShow;
-               this.prevHide = toHide;
-
-               if ( this.options.animate ) {
-                       this._animate( toShow, toHide, data );
-               } else {
-                       toHide.hide();
-                       toShow.show();
-                       this._toggleComplete( data );
-               }
-
-               toHide.attr({
-                       "aria-hidden": "true"
-               });
-               toHide.prev().attr( "aria-selected", "false" );
-               // if we're switching panels, remove the old header from the tab order
-               // if we're opening from collapsed state, remove the previous header from the tab order
-               // if we're collapsing, then keep the collapsing header in the tab order
-               if ( toShow.length && toHide.length ) {
-                       toHide.prev().attr({
-                               "tabIndex": -1,
-                               "aria-expanded": "false"
-                       });
-               } else if ( toShow.length ) {
-                       this.headers.filter(function() {
-                               return $( this ).attr( "tabIndex" ) === 0;
-                       })
-                       .attr( "tabIndex", -1 );
-               }
-
-               toShow
-                       .attr( "aria-hidden", "false" )
-                       .prev()
-                               .attr({
-                                       "aria-selected": "true",
-                                       tabIndex: 0,
-                                       "aria-expanded": "true"
-                               });
-       },
-
-       _animate: function( toShow, toHide, data ) {
-               var total, easing, duration,
-                       that = this,
-                       adjust = 0,
-                       down = toShow.length &&
-                               ( !toHide.length || ( toShow.index() < toHide.index() ) ),
-                       animate = this.options.animate || {},
-                       options = down && animate.down || animate,
-                       complete = function() {
-                               that._toggleComplete( data );
-                       };
-
-               if ( typeof options === "number" ) {
-                       duration = options;
-               }
-               if ( typeof options === "string" ) {
-                       easing = options;
-               }
-               // fall back from options to animation in case of partial down settings
-               easing = easing || options.easing || animate.easing;
-               duration = duration || options.duration || animate.duration;
-
-               if ( !toHide.length ) {
-                       return toShow.animate( showProps, duration, easing, complete );
-               }
-               if ( !toShow.length ) {
-                       return toHide.animate( hideProps, duration, easing, complete );
-               }
-
-               total = toShow.show().outerHeight();
-               toHide.animate( hideProps, {
-                       duration: duration,
-                       easing: easing,
-                       step: function( now, fx ) {
-                               fx.now = Math.round( now );
-                       }
-               });
-               toShow
-                       .hide()
-                       .animate( showProps, {
-                               duration: duration,
-                               easing: easing,
-                               complete: complete,
-                               step: function( now, fx ) {
-                                       fx.now = Math.round( now );
-                                       if ( fx.prop !== "height" ) {
-                                               adjust += fx.now;
-                                       } else if ( that.options.heightStyle !== "content" ) {
-                                               fx.now = Math.round( total - toHide.outerHeight() - adjust );
-                                               adjust = 0;
-                                       }
-                               }
-                       });
-       },
-
-       _toggleComplete: function( data ) {
-               var toHide = data.oldPanel;
-
-               toHide
-                       .removeClass( "ui-accordion-content-active" )
-                       .prev()
-                               .removeClass( "ui-corner-top" )
-                               .addClass( "ui-corner-all" );
-
-               // Work around for rendering bug in IE (#5421)
-               if ( toHide.length ) {
-                       toHide.parent()[0].className = toHide.parent()[0].className;
-               }
-               this._trigger( "activate", null, data );
-       }
-});
-
-})( jQuery );
-(function( $, undefined ) {
-
 $.widget( "ui.autocomplete", {
        version: "1.10.4",
        defaultElement: "<input>",
@@ -2619,12390 +2063,613 @@ $.widget( "ui.autocomplete", $.ui.autocomplete, {
 }( jQuery ));
 (function( $, undefined ) {
 
-var lastActive,
-       baseClasses = "ui-button ui-widget ui-state-default ui-corner-all",
-       typeClasses = "ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only",
-       formResetHandler = function() {
-               var form = $( this );
-               setTimeout(function() {
-                       form.find( ":ui-button" ).button( "refresh" );
-               }, 1 );
-       },
-       radioGroup = function( radio ) {
-               var name = radio.name,
-                       form = radio.form,
-                       radios = $( [] );
-               if ( name ) {
-                       name = name.replace( /'/g, "\\'" );
-                       if ( form ) {
-                               radios = $( form ).find( "[name='" + name + "']" );
-                       } else {
-                               radios = $( "[name='" + name + "']", radio.ownerDocument )
-                                       .filter(function() {
-                                               return !this.form;
-                                       });
-                       }
-               }
-               return radios;
-       };
-
-$.widget( "ui.button", {
+$.widget( "ui.menu", {
        version: "1.10.4",
-       defaultElement: "<button>",
+       defaultElement: "<ul>",
+       delay: 300,
        options: {
-               disabled: null,
-               text: true,
-               label: null,
                icons: {
-                       primary: null,
-                       secondary: null
-               }
-       },
-       _create: function() {
-               this.element.closest( "form" )
-                       .unbind( "reset" + this.eventNamespace )
-                       .bind( "reset" + this.eventNamespace, formResetHandler );
-
-               if ( typeof this.options.disabled !== "boolean" ) {
-                       this.options.disabled = !!this.element.prop( "disabled" );
-               } else {
-                       this.element.prop( "disabled", this.options.disabled );
-               }
-
-               this._determineButtonType();
-               this.hasTitle = !!this.buttonElement.attr( "title" );
-
-               var that = this,
-                       options = this.options,
-                       toggleButton = this.type === "checkbox" || this.type === "radio",
-                       activeClass = !toggleButton ? "ui-state-active" : "";
-
-               if ( options.label === null ) {
-                       options.label = (this.type === "input" ? this.buttonElement.val() : this.buttonElement.html());
-               }
+                       submenu: "ui-icon-carat-1-e"
+               },
+               menus: "ul",
+               position: {
+                       my: "left top",
+                       at: "right top"
+               },
+               role: "menu",
 
-               this._hoverable( this.buttonElement );
+               // callbacks
+               blur: null,
+               focus: null,
+               select: null
+       },
 
-               this.buttonElement
-                       .addClass( baseClasses )
-                       .attr( "role", "button" )
-                       .bind( "mouseenter" + this.eventNamespace, function() {
-                               if ( options.disabled ) {
-                                       return;
-                               }
-                               if ( this === lastActive ) {
-                                       $( this ).addClass( "ui-state-active" );
-                               }
-                       })
-                       .bind( "mouseleave" + this.eventNamespace, function() {
-                               if ( options.disabled ) {
-                                       return;
-                               }
-                               $( this ).removeClass( activeClass );
+       _create: function() {
+               this.activeMenu = this.element;
+               // flag used to prevent firing of the click handler
+               // as the event bubbles up through nested menus
+               this.mouseHandled = false;
+               this.element
+                       .uniqueId()
+                       .addClass( "ui-menu ui-widget ui-widget-content ui-corner-all" )
+                       .toggleClass( "ui-menu-icons", !!this.element.find( ".ui-icon" ).length )
+                       .attr({
+                               role: this.options.role,
+                               tabIndex: 0
                        })
-                       .bind( "click" + this.eventNamespace, function( event ) {
-                               if ( options.disabled ) {
+                       // need to catch all clicks on disabled menu
+                       // not possible through _on
+                       .bind( "click" + this.eventNamespace, $.proxy(function( event ) {
+                               if ( this.options.disabled ) {
                                        event.preventDefault();
-                                       event.stopImmediatePropagation();
                                }
-                       });
+                       }, this ));
+
+               if ( this.options.disabled ) {
+                       this.element
+                               .addClass( "ui-state-disabled" )
+                               .attr( "aria-disabled", "true" );
+               }
 
-               // Can't use _focusable() because the element that receives focus
-               // and the element that gets the ui-state-focus class are different
                this._on({
-                       focus: function() {
-                               this.buttonElement.addClass( "ui-state-focus" );
+                       // Prevent focus from sticking to links inside menu after clicking
+                       // them (focus should always stay on UL during navigation).
+                       "mousedown .ui-menu-item > a": function( event ) {
+                               event.preventDefault();
                        },
-                       blur: function() {
-                               this.buttonElement.removeClass( "ui-state-focus" );
-                       }
-               });
-
-               if ( toggleButton ) {
-                       this.element.bind( "change" + this.eventNamespace, function() {
-                               that.refresh();
-                       });
-               }
-
-               if ( this.type === "checkbox" ) {
-                       this.buttonElement.bind( "click" + this.eventNamespace, function() {
-                               if ( options.disabled ) {
-                                       return false;
-                               }
-                       });
-               } else if ( this.type === "radio" ) {
-                       this.buttonElement.bind( "click" + this.eventNamespace, function() {
-                               if ( options.disabled ) {
-                                       return false;
-                               }
-                               $( this ).addClass( "ui-state-active" );
-                               that.buttonElement.attr( "aria-pressed", "true" );
-
-                               var radio = that.element[ 0 ];
-                               radioGroup( radio )
-                                       .not( radio )
-                                       .map(function() {
-                                               return $( this ).button( "widget" )[ 0 ];
-                                       })
-                                       .removeClass( "ui-state-active" )
-                                       .attr( "aria-pressed", "false" );
-                       });
-               } else {
-                       this.buttonElement
-                               .bind( "mousedown" + this.eventNamespace, function() {
-                                       if ( options.disabled ) {
-                                               return false;
-                                       }
-                                       $( this ).addClass( "ui-state-active" );
-                                       lastActive = this;
-                                       that.document.one( "mouseup", function() {
-                                               lastActive = null;
-                                       });
-                               })
-                               .bind( "mouseup" + this.eventNamespace, function() {
-                                       if ( options.disabled ) {
-                                               return false;
-                                       }
-                                       $( this ).removeClass( "ui-state-active" );
-                               })
-                               .bind( "keydown" + this.eventNamespace, function(event) {
-                                       if ( options.disabled ) {
-                                               return false;
-                                       }
-                                       if ( event.keyCode === $.ui.keyCode.SPACE || event.keyCode === $.ui.keyCode.ENTER ) {
-                                               $( this ).addClass( "ui-state-active" );
-                                       }
-                               })
-                               // see #8559, we bind to blur here in case the button element loses
-                               // focus between keydown and keyup, it would be left in an "active" state
-                               .bind( "keyup" + this.eventNamespace + " blur" + this.eventNamespace, function() {
-                                       $( this ).removeClass( "ui-state-active" );
-                               });
+                       "click .ui-state-disabled > a": function( event ) {
+                               event.preventDefault();
+                       },
+                       "click .ui-menu-item:has(a)": function( event ) {
+                               var target = $( event.target ).closest( ".ui-menu-item" );
+                               if ( !this.mouseHandled && target.not( ".ui-state-disabled" ).length ) {
+                                       this.select( event );
 
-                       if ( this.buttonElement.is("a") ) {
-                               this.buttonElement.keyup(function(event) {
-                                       if ( event.keyCode === $.ui.keyCode.SPACE ) {
-                                               // TODO pass through original event correctly (just as 2nd argument doesn't work)
-                                               $( this ).click();
+                                       // Only set the mouseHandled flag if the event will bubble, see #9469.
+                                       if ( !event.isPropagationStopped() ) {
+                                               this.mouseHandled = true;
                                        }
-                               });
-                       }
-               }
-
-               // TODO: pull out $.Widget's handling for the disabled option into
-               // $.Widget.prototype._setOptionDisabled so it's easy to proxy and can
-               // be overridden by individual plugins
-               this._setOption( "disabled", options.disabled );
-               this._resetButton();
-       },
-
-       _determineButtonType: function() {
-               var ancestor, labelSelector, checked;
-
-               if ( this.element.is("[type=checkbox]") ) {
-                       this.type = "checkbox";
-               } else if ( this.element.is("[type=radio]") ) {
-                       this.type = "radio";
-               } else if ( this.element.is("input") ) {
-                       this.type = "input";
-               } else {
-                       this.type = "button";
-               }
-
-               if ( this.type === "checkbox" || this.type === "radio" ) {
-                       // we don't search against the document in case the element
-                       // is disconnected from the DOM
-                       ancestor = this.element.parents().last();
-                       labelSelector = "label[for='" + this.element.attr("id") + "']";
-                       this.buttonElement = ancestor.find( labelSelector );
-                       if ( !this.buttonElement.length ) {
-                               ancestor = ancestor.length ? ancestor.siblings() : this.element.siblings();
-                               this.buttonElement = ancestor.filter( labelSelector );
-                               if ( !this.buttonElement.length ) {
-                                       this.buttonElement = ancestor.find( labelSelector );
-                               }
-                       }
-                       this.element.addClass( "ui-helper-hidden-accessible" );
-
-                       checked = this.element.is( ":checked" );
-                       if ( checked ) {
-                               this.buttonElement.addClass( "ui-state-active" );
-                       }
-                       this.buttonElement.prop( "aria-pressed", checked );
-               } else {
-                       this.buttonElement = this.element;
-               }
-       },
-
-       widget: function() {
-               return this.buttonElement;
-       },
-
-       _destroy: function() {
-               this.element
-                       .removeClass( "ui-helper-hidden-accessible" );
-               this.buttonElement
-                       .removeClass( baseClasses + " ui-state-active " + typeClasses )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-pressed" )
-                       .html( this.buttonElement.find(".ui-button-text").html() );
-
-               if ( !this.hasTitle ) {
-                       this.buttonElement.removeAttr( "title" );
-               }
-       },
 
-       _setOption: function( key, value ) {
-               this._super( key, value );
-               if ( key === "disabled" ) {
-                       this.element.prop( "disabled", !!value );
-                       if ( value ) {
-                               this.buttonElement.removeClass( "ui-state-focus" );
-                       }
-                       return;
-               }
-               this._resetButton();
-       },
+                                       // Open submenu on click
+                                       if ( target.has( ".ui-menu" ).length ) {
+                                               this.expand( event );
+                                       } else if ( !this.element.is( ":focus" ) && $( this.document[ 0 ].activeElement ).closest( ".ui-menu" ).length ) {
 
-       refresh: function() {
-               //See #8237 & #8828
-               var isDisabled = this.element.is( "input, button" ) ? this.element.is( ":disabled" ) : this.element.hasClass( "ui-button-disabled" );
+                                               // Redirect focus to the menu
+                                               this.element.trigger( "focus", [ true ] );
 
-               if ( isDisabled !== this.options.disabled ) {
-                       this._setOption( "disabled", isDisabled );
-               }
-               if ( this.type === "radio" ) {
-                       radioGroup( this.element[0] ).each(function() {
-                               if ( $( this ).is( ":checked" ) ) {
-                                       $( this ).button( "widget" )
-                                               .addClass( "ui-state-active" )
-                                               .attr( "aria-pressed", "true" );
-                               } else {
-                                       $( this ).button( "widget" )
-                                               .removeClass( "ui-state-active" )
-                                               .attr( "aria-pressed", "false" );
+                                               // If the active item is on the top level, let it stay active.
+                                               // Otherwise, blur the active item since it is no longer visible.
+                                               if ( this.active && this.active.parents( ".ui-menu" ).length === 1 ) {
+                                                       clearTimeout( this.timer );
+                                               }
+                                       }
                                }
-                       });
-               } else if ( this.type === "checkbox" ) {
-                       if ( this.element.is( ":checked" ) ) {
-                               this.buttonElement
-                                       .addClass( "ui-state-active" )
-                                       .attr( "aria-pressed", "true" );
-                       } else {
-                               this.buttonElement
-                                       .removeClass( "ui-state-active" )
-                                       .attr( "aria-pressed", "false" );
-                       }
-               }
-       },
-
-       _resetButton: function() {
-               if ( this.type === "input" ) {
-                       if ( this.options.label ) {
-                               this.element.val( this.options.label );
-                       }
-                       return;
-               }
-               var buttonElement = this.buttonElement.removeClass( typeClasses ),
-                       buttonText = $( "<span></span>", this.document[0] )
-                               .addClass( "ui-button-text" )
-                               .html( this.options.label )
-                               .appendTo( buttonElement.empty() )
-                               .text(),
-                       icons = this.options.icons,
-                       multipleIcons = icons.primary && icons.secondary,
-                       buttonClasses = [];
-
-               if ( icons.primary || icons.secondary ) {
-                       if ( this.options.text ) {
-                               buttonClasses.push( "ui-button-text-icon" + ( multipleIcons ? "s" : ( icons.primary ? "-primary" : "-secondary" ) ) );
-                       }
-
-                       if ( icons.primary ) {
-                               buttonElement.prepend( "<span class='ui-button-icon-primary ui-icon " + icons.primary + "'></span>" );
-                       }
-
-                       if ( icons.secondary ) {
-                               buttonElement.append( "<span class='ui-button-icon-secondary ui-icon " + icons.secondary + "'></span>" );
-                       }
-
-                       if ( !this.options.text ) {
-                               buttonClasses.push( multipleIcons ? "ui-button-icons-only" : "ui-button-icon-only" );
+                       },
+                       "mouseenter .ui-menu-item": function( event ) {
+                               var target = $( event.currentTarget );
+                               // Remove ui-state-active class from siblings of the newly focused menu item
+                               // to avoid a jump caused by adjacent elements both having a class with a border
+                               target.siblings().children( ".ui-state-active" ).removeClass( "ui-state-active" );
+                               this.focus( event, target );
+                       },
+                       mouseleave: "collapseAll",
+                       "mouseleave .ui-menu": "collapseAll",
+                       focus: function( event, keepActiveItem ) {
+                               // If there's already an active item, keep it active
+                               // If not, activate the first item
+                               var item = this.active || this.element.children( ".ui-menu-item" ).eq( 0 );
 
-                               if ( !this.hasTitle ) {
-                                       buttonElement.attr( "title", $.trim( buttonText ) );
+                               if ( !keepActiveItem ) {
+                                       this.focus( event, item );
                                }
-                       }
-               } else {
-                       buttonClasses.push( "ui-button-text-only" );
-               }
-               buttonElement.addClass( buttonClasses.join( " " ) );
-       }
-});
-
-$.widget( "ui.buttonset", {
-       version: "1.10.4",
-       options: {
-               items: "button, input[type=button], input[type=submit], input[type=reset], input[type=checkbox], input[type=radio], a, :data(ui-button)"
-       },
-
-       _create: function() {
-               this.element.addClass( "ui-buttonset" );
-       },
+                       },
+                       blur: function( event ) {
+                               this._delay(function() {
+                                       if ( !$.contains( this.element[0], this.document[0].activeElement ) ) {
+                                               this.collapseAll( event );
+                                       }
+                               });
+                       },
+                       keydown: "_keydown"
+               });
 
-       _init: function() {
                this.refresh();
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "disabled" ) {
-                       this.buttons.button( "option", key, value );
-               }
-
-               this._super( key, value );
-       },
-
-       refresh: function() {
-               var rtl = this.element.css( "direction" ) === "rtl";
-
-               this.buttons = this.element.find( this.options.items )
-                       .filter( ":ui-button" )
-                               .button( "refresh" )
-                       .end()
-                       .not( ":ui-button" )
-                               .button()
-                       .end()
-                       .map(function() {
-                               return $( this ).button( "widget" )[ 0 ];
-                       })
-                               .removeClass( "ui-corner-all ui-corner-left ui-corner-right" )
-                               .filter( ":first" )
-                                       .addClass( rtl ? "ui-corner-right" : "ui-corner-left" )
-                               .end()
-                               .filter( ":last" )
-                                       .addClass( rtl ? "ui-corner-left" : "ui-corner-right" )
-                               .end()
-                       .end();
-       },
-
-       _destroy: function() {
-               this.element.removeClass( "ui-buttonset" );
-               this.buttons
-                       .map(function() {
-                               return $( this ).button( "widget" )[ 0 ];
-                       })
-                               .removeClass( "ui-corner-left ui-corner-right" )
-                       .end()
-                       .button( "destroy" );
-       }
-});
-
-}( jQuery ) );
-(function( $, undefined ) {
-
-$.extend($.ui, { datepicker: { version: "1.10.4" } });
-
-var PROP_NAME = "datepicker",
-       instActive;
-
-/* Date picker manager.
-   Use the singleton instance of this class, $.datepicker, to interact with the date picker.
-   Settings for (groups of) date pickers are maintained in an instance object,
-   allowing multiple different settings on the same page. */
-
-function Datepicker() {
-       this._curInst = null; // The current instance in use
-       this._keyEvent = false; // If the last event was a key event
-       this._disabledInputs = []; // List of date picker inputs that have been disabled
-       this._datepickerShowing = false; // True if the popup picker is showing , false if not
-       this._inDialog = false; // True if showing within a "dialog", false if not
-       this._mainDivId = "ui-datepicker-div"; // The ID of the main datepicker division
-       this._inlineClass = "ui-datepicker-inline"; // The name of the inline marker class
-       this._appendClass = "ui-datepicker-append"; // The name of the append marker class
-       this._triggerClass = "ui-datepicker-trigger"; // The name of the trigger marker class
-       this._dialogClass = "ui-datepicker-dialog"; // The name of the dialog marker class
-       this._disableClass = "ui-datepicker-disabled"; // The name of the disabled covering marker class
-       this._unselectableClass = "ui-datepicker-unselectable"; // The name of the unselectable cell marker class
-       this._currentClass = "ui-datepicker-current-day"; // The name of the current day marker class
-       this._dayOverClass = "ui-datepicker-days-cell-over"; // The name of the day hover marker class
-       this.regional = []; // Available regional settings, indexed by language code
-       this.regional[""] = { // Default regional settings
-               closeText: "Done", // Display text for close link
-               prevText: "Prev", // Display text for previous month link
-               nextText: "Next", // Display text for next month link
-               currentText: "Today", // Display text for current month link
-               monthNames: ["January","February","March","April","May","June",
-                       "July","August","September","October","November","December"], // Names of months for drop-down and formatting
-               monthNamesShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], // For formatting
-               dayNames: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], // For formatting
-               dayNamesShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], // For formatting
-               dayNamesMin: ["Su","Mo","Tu","We","Th","Fr","Sa"], // Column headings for days starting at Sunday
-               weekHeader: "Wk", // Column header for week of the year
-               dateFormat: "mm/dd/yy", // See format options on parseDate
-               firstDay: 0, // The first day of the week, Sun = 0, Mon = 1, ...
-               isRTL: false, // True if right-to-left language, false if left-to-right
-               showMonthAfterYear: false, // True if the year select precedes month, false for month then year
-               yearSuffix: "" // Additional text to append to the year in the month headers
-       };
-       this._defaults = { // Global defaults for all the date picker instances
-               showOn: "focus", // "focus" for popup on focus,
-                       // "button" for trigger button, or "both" for either
-               showAnim: "fadeIn", // Name of jQuery animation for popup
-               showOptions: {}, // Options for enhanced animations
-               defaultDate: null, // Used when field is blank: actual date,
-                       // +/-number for offset from today, null for today
-               appendText: "", // Display text following the input box, e.g. showing the format
-               buttonText: "...", // Text for trigger button
-               buttonImage: "", // URL for trigger button image
-               buttonImageOnly: false, // True if the image appears alone, false if it appears on a button
-               hideIfNoPrevNext: false, // True to hide next/previous month links
-                       // if not applicable, false to just disable them
-               navigationAsDateFormat: false, // True if date formatting applied to prev/today/next links
-               gotoCurrent: false, // True if today link goes back to current selection instead
-               changeMonth: false, // True if month can be selected directly, false if only prev/next
-               changeYear: false, // True if year can be selected directly, false if only prev/next
-               yearRange: "c-10:c+10", // Range of years to display in drop-down,
-                       // either relative to today's year (-nn:+nn), relative to currently displayed year
-                       // (c-nn:c+nn), absolute (nnnn:nnnn), or a combination of the above (nnnn:-n)
-               showOtherMonths: false, // True to show dates in other months, false to leave blank
-               selectOtherMonths: false, // True to allow selection of dates in other months, false for unselectable
-               showWeek: false, // True to show week of the year, false to not show it
-               calculateWeek: this.iso8601Week, // How to calculate the week of the year,
-                       // takes a Date and returns the number of the week for it
-               shortYearCutoff: "+10", // Short year values < this are in the current century,
-                       // > this are in the previous century,
-                       // string value starting with "+" for current year + value
-               minDate: null, // The earliest selectable date, or null for no limit
-               maxDate: null, // The latest selectable date, or null for no limit
-               duration: "fast", // Duration of display/closure
-               beforeShowDay: null, // Function that takes a date and returns an array with
-                       // [0] = true if selectable, false if not, [1] = custom CSS class name(s) or "",
-                       // [2] = cell title (optional), e.g. $.datepicker.noWeekends
-               beforeShow: null, // Function that takes an input field and
-                       // returns a set of custom settings for the date picker
-               onSelect: null, // Define a callback function when a date is selected
-               onChangeMonthYear: null, // Define a callback function when the month or year is changed
-               onClose: null, // Define a callback function when the datepicker is closed
-               numberOfMonths: 1, // Number of months to show at a time
-               showCurrentAtPos: 0, // The position in multipe months at which to show the current month (starting at 0)
-               stepMonths: 1, // Number of months to step back/forward
-               stepBigMonths: 12, // Number of months to step back/forward for the big links
-               altField: "", // Selector for an alternate field to store selected dates into
-               altFormat: "", // The date format to use for the alternate field
-               constrainInput: true, // The input is constrained by the current date format
-               showButtonPanel: false, // True to show button panel, false to not show it
-               autoSize: false, // True to size the input for the date format, false to leave as is
-               disabled: false // The initial disabled state
-       };
-       $.extend(this._defaults, this.regional[""]);
-       this.dpDiv = bindHover($("<div id='" + this._mainDivId + "' class='ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all'></div>"));
-}
-
-$.extend(Datepicker.prototype, {
-       /* Class name added to elements to indicate already configured with a date picker. */
-       markerClassName: "hasDatepicker",
-
-       //Keep track of the maximum number of rows displayed (see #7043)
-       maxRows: 4,
-
-       // TODO rename to "widget" when switching to widget factory
-       _widgetDatepicker: function() {
-               return this.dpDiv;
-       },
-
-       /* Override the default settings for all instances of the date picker.
-        * @param  settings  object - the new settings to use as defaults (anonymous object)
-        * @return the manager object
-        */
-       setDefaults: function(settings) {
-               extendRemove(this._defaults, settings || {});
-               return this;
-       },
-
-       /* Attach the date picker to a jQuery selection.
-        * @param  target       element - the target input field or division or span
-        * @param  settings  object - the new settings to use for this date picker instance (anonymous)
-        */
-       _attachDatepicker: function(target, settings) {
-               var nodeName, inline, inst;
-               nodeName = target.nodeName.toLowerCase();
-               inline = (nodeName === "div" || nodeName === "span");
-               if (!target.id) {
-                       this.uuid += 1;
-                       target.id = "dp" + this.uuid;
-               }
-               inst = this._newInst($(target), inline);
-               inst.settings = $.extend({}, settings || {});
-               if (nodeName === "input") {
-                       this._connectDatepicker(target, inst);
-               } else if (inline) {
-                       this._inlineDatepicker(target, inst);
-               }
-       },
-
-       /* Create a new instance object. */
-       _newInst: function(target, inline) {
-               var id = target[0].id.replace(/([^A-Za-z0-9_\-])/g, "\\\\$1"); // escape jQuery meta chars
-               return {id: id, input: target, // associated target
-                       selectedDay: 0, selectedMonth: 0, selectedYear: 0, // current selection
-                       drawMonth: 0, drawYear: 0, // month being drawn
-                       inline: inline, // is datepicker inline or not
-                       dpDiv: (!inline ? this.dpDiv : // presentation div
-                       bindHover($("<div class='" + this._inlineClass + " ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all'></div>")))};
-       },
 
-       /* Attach the date picker to an input field. */
-       _connectDatepicker: function(target, inst) {
-               var input = $(target);
-               inst.append = $([]);
-               inst.trigger = $([]);
-               if (input.hasClass(this.markerClassName)) {
-                       return;
-               }
-               this._attachments(input, inst);
-               input.addClass(this.markerClassName).keydown(this._doKeyDown).
-                       keypress(this._doKeyPress).keyup(this._doKeyUp);
-               this._autoSize(inst);
-               $.data(target, PROP_NAME, inst);
-               //If disabled option is true, disable the datepicker once it has been attached to the input (see ticket #5665)
-               if( inst.settings.disabled ) {
-                       this._disableDatepicker( target );
-               }
-       },
-
-       /* Make attachments based on settings. */
-       _attachments: function(input, inst) {
-               var showOn, buttonText, buttonImage,
-                       appendText = this._get(inst, "appendText"),
-                       isRTL = this._get(inst, "isRTL");
-
-               if (inst.append) {
-                       inst.append.remove();
-               }
-               if (appendText) {
-                       inst.append = $("<span class='" + this._appendClass + "'>" + appendText + "</span>");
-                       input[isRTL ? "before" : "after"](inst.append);
-               }
-
-               input.unbind("focus", this._showDatepicker);
-
-               if (inst.trigger) {
-                       inst.trigger.remove();
-               }
-
-               showOn = this._get(inst, "showOn");
-               if (showOn === "focus" || showOn === "both") { // pop-up date picker when in the marked field
-                       input.focus(this._showDatepicker);
-               }
-               if (showOn === "button" || showOn === "both") { // pop-up date picker when button clicked
-                       buttonText = this._get(inst, "buttonText");
-                       buttonImage = this._get(inst, "buttonImage");
-                       inst.trigger = $(this._get(inst, "buttonImageOnly") ?
-                               $("<img/>").addClass(this._triggerClass).
-                                       attr({ src: buttonImage, alt: buttonText, title: buttonText }) :
-                               $("<button type='button'></button>").addClass(this._triggerClass).
-                                       html(!buttonImage ? buttonText : $("<img/>").attr(
-                                       { src:buttonImage, alt:buttonText, title:buttonText })));
-                       input[isRTL ? "before" : "after"](inst.trigger);
-                       inst.trigger.click(function() {
-                               if ($.datepicker._datepickerShowing && $.datepicker._lastInput === input[0]) {
-                                       $.datepicker._hideDatepicker();
-                               } else if ($.datepicker._datepickerShowing && $.datepicker._lastInput !== input[0]) {
-                                       $.datepicker._hideDatepicker();
-                                       $.datepicker._showDatepicker(input[0]);
-                               } else {
-                                       $.datepicker._showDatepicker(input[0]);
+               // Clicks outside of a menu collapse any open menus
+               this._on( this.document, {
+                       click: function( event ) {
+                               if ( !$( event.target ).closest( ".ui-menu" ).length ) {
+                                       this.collapseAll( event );
                                }
-                               return false;
-                       });
-               }
-       },
 
-       /* Apply the maximum length for the date format. */
-       _autoSize: function(inst) {
-               if (this._get(inst, "autoSize") && !inst.inline) {
-                       var findMax, max, maxI, i,
-                               date = new Date(2009, 12 - 1, 20), // Ensure double digits
-                               dateFormat = this._get(inst, "dateFormat");
-
-                       if (dateFormat.match(/[DM]/)) {
-                               findMax = function(names) {
-                                       max = 0;
-                                       maxI = 0;
-                                       for (i = 0; i < names.length; i++) {
-                                               if (names[i].length > max) {
-                                                       max = names[i].length;
-                                                       maxI = i;
-                                               }
-                                       }
-                                       return maxI;
-                               };
-                               date.setMonth(findMax(this._get(inst, (dateFormat.match(/MM/) ?
-                                       "monthNames" : "monthNamesShort"))));
-                               date.setDate(findMax(this._get(inst, (dateFormat.match(/DD/) ?
-                                       "dayNames" : "dayNamesShort"))) + 20 - date.getDay());
+                               // Reset the mouseHandled flag
+                               this.mouseHandled = false;
                        }
-                       inst.input.attr("size", this._formatDate(inst, date).length);
-               }
+               });
        },
 
-       /* Attach an inline date picker to a div. */
-       _inlineDatepicker: function(target, inst) {
-               var divSpan = $(target);
-               if (divSpan.hasClass(this.markerClassName)) {
-                       return;
-               }
-               divSpan.addClass(this.markerClassName).append(inst.dpDiv);
-               $.data(target, PROP_NAME, inst);
-               this._setDate(inst, this._getDefaultDate(inst), true);
-               this._updateDatepicker(inst);
-               this._updateAlternate(inst);
-               //If disabled option is true, disable the datepicker before showing it (see ticket #5665)
-               if( inst.settings.disabled ) {
-                       this._disableDatepicker( target );
-               }
-               // Set display:block in place of inst.dpDiv.show() which won't work on disconnected elements
-               // http://bugs.jqueryui.com/ticket/7552 - A Datepicker created on a detached div has zero height
-               inst.dpDiv.css( "display", "block" );
-       },
+       _destroy: function() {
+               // Destroy (sub)menus
+               this.element
+                       .removeAttr( "aria-activedescendant" )
+                       .find( ".ui-menu" ).addBack()
+                               .removeClass( "ui-menu ui-widget ui-widget-content ui-corner-all ui-menu-icons" )
+                               .removeAttr( "role" )
+                               .removeAttr( "tabIndex" )
+                               .removeAttr( "aria-labelledby" )
+                               .removeAttr( "aria-expanded" )
+                               .removeAttr( "aria-hidden" )
+                               .removeAttr( "aria-disabled" )
+                               .removeUniqueId()
+                               .show();
 
-       /* Pop-up the date picker in a "dialog" box.
-        * @param  input element - ignored
-        * @param  date string or Date - the initial date to display
-        * @param  onSelect  function - the function to call when a date is selected
-        * @param  settings  object - update the dialog date picker instance's settings (anonymous object)
-        * @param  pos int[2] - coordinates for the dialog's position within the screen or
-        *                                      event - with x/y coordinates or
-        *                                      leave empty for default (screen centre)
-        * @return the manager object
-        */
-       _dialogDatepicker: function(input, date, onSelect, settings, pos) {
-               var id, browserWidth, browserHeight, scrollX, scrollY,
-                       inst = this._dialogInst; // internal instance
-
-               if (!inst) {
-                       this.uuid += 1;
-                       id = "dp" + this.uuid;
-                       this._dialogInput = $("<input type='text' id='" + id +
-                               "' style='position: absolute; top: -100px; width: 0px;'/>");
-                       this._dialogInput.keydown(this._doKeyDown);
-                       $("body").append(this._dialogInput);
-                       inst = this._dialogInst = this._newInst(this._dialogInput, false);
-                       inst.settings = {};
-                       $.data(this._dialogInput[0], PROP_NAME, inst);
-               }
-               extendRemove(inst.settings, settings || {});
-               date = (date && date.constructor === Date ? this._formatDate(inst, date) : date);
-               this._dialogInput.val(date);
-
-               this._pos = (pos ? (pos.length ? pos : [pos.pageX, pos.pageY]) : null);
-               if (!this._pos) {
-                       browserWidth = document.documentElement.clientWidth;
-                       browserHeight = document.documentElement.clientHeight;
-                       scrollX = document.documentElement.scrollLeft || document.body.scrollLeft;
-                       scrollY = document.documentElement.scrollTop || document.body.scrollTop;
-                       this._pos = // should use actual width/height below
-                               [(browserWidth / 2) - 100 + scrollX, (browserHeight / 2) - 150 + scrollY];
-               }
+               // Destroy menu items
+               this.element.find( ".ui-menu-item" )
+                       .removeClass( "ui-menu-item" )
+                       .removeAttr( "role" )
+                       .removeAttr( "aria-disabled" )
+                       .children( "a" )
+                               .removeUniqueId()
+                               .removeClass( "ui-corner-all ui-state-hover" )
+                               .removeAttr( "tabIndex" )
+                               .removeAttr( "role" )
+                               .removeAttr( "aria-haspopup" )
+                               .children().each( function() {
+                                       var elem = $( this );
+                                       if ( elem.data( "ui-menu-submenu-carat" ) ) {
+                                               elem.remove();
+                                       }
+                               });
 
-               // move input on screen for focus, but hidden behind dialog
-               this._dialogInput.css("left", (this._pos[0] + 20) + "px").css("top", this._pos[1] + "px");
-               inst.settings.onSelect = onSelect;
-               this._inDialog = true;
-               this.dpDiv.addClass(this._dialogClass);
-               this._showDatepicker(this._dialogInput[0]);
-               if ($.blockUI) {
-                       $.blockUI(this.dpDiv);
-               }
-               $.data(this._dialogInput[0], PROP_NAME, inst);
-               return this;
+               // Destroy menu dividers
+               this.element.find( ".ui-menu-divider" ).removeClass( "ui-menu-divider ui-widget-content" );
        },
 
-       /* Detach a datepicker from its control.
-        * @param  target       element - the target input field or division or span
-        */
-       _destroyDatepicker: function(target) {
-               var nodeName,
-                       $target = $(target),
-                       inst = $.data(target, PROP_NAME);
-
-               if (!$target.hasClass(this.markerClassName)) {
-                       return;
-               }
+       _keydown: function( event ) {
+               var match, prev, character, skip, regex,
+                       preventDefault = true;
 
-               nodeName = target.nodeName.toLowerCase();
-               $.removeData(target, PROP_NAME);
-               if (nodeName === "input") {
-                       inst.append.remove();
-                       inst.trigger.remove();
-                       $target.removeClass(this.markerClassName).
-                               unbind("focus", this._showDatepicker).
-                               unbind("keydown", this._doKeyDown).
-                               unbind("keypress", this._doKeyPress).
-                               unbind("keyup", this._doKeyUp);
-               } else if (nodeName === "div" || nodeName === "span") {
-                       $target.removeClass(this.markerClassName).empty();
-               }
-       },
-
-       /* Enable the date picker to a jQuery selection.
-        * @param  target       element - the target input field or division or span
-        */
-       _enableDatepicker: function(target) {
-               var nodeName, inline,
-                       $target = $(target),
-                       inst = $.data(target, PROP_NAME);
-
-               if (!$target.hasClass(this.markerClassName)) {
-                       return;
-               }
-
-               nodeName = target.nodeName.toLowerCase();
-               if (nodeName === "input") {
-                       target.disabled = false;
-                       inst.trigger.filter("button").
-                               each(function() { this.disabled = false; }).end().
-                               filter("img").css({opacity: "1.0", cursor: ""});
-               } else if (nodeName === "div" || nodeName === "span") {
-                       inline = $target.children("." + this._inlineClass);
-                       inline.children().removeClass("ui-state-disabled");
-                       inline.find("select.ui-datepicker-month, select.ui-datepicker-year").
-                               prop("disabled", false);
-               }
-               this._disabledInputs = $.map(this._disabledInputs,
-                       function(value) { return (value === target ? null : value); }); // delete entry
-       },
-
-       /* Disable the date picker to a jQuery selection.
-        * @param  target       element - the target input field or division or span
-        */
-       _disableDatepicker: function(target) {
-               var nodeName, inline,
-                       $target = $(target),
-                       inst = $.data(target, PROP_NAME);
-
-               if (!$target.hasClass(this.markerClassName)) {
-                       return;
-               }
-
-               nodeName = target.nodeName.toLowerCase();
-               if (nodeName === "input") {
-                       target.disabled = true;
-                       inst.trigger.filter("button").
-                               each(function() { this.disabled = true; }).end().
-                               filter("img").css({opacity: "0.5", cursor: "default"});
-               } else if (nodeName === "div" || nodeName === "span") {
-                       inline = $target.children("." + this._inlineClass);
-                       inline.children().addClass("ui-state-disabled");
-                       inline.find("select.ui-datepicker-month, select.ui-datepicker-year").
-                               prop("disabled", true);
-               }
-               this._disabledInputs = $.map(this._disabledInputs,
-                       function(value) { return (value === target ? null : value); }); // delete entry
-               this._disabledInputs[this._disabledInputs.length] = target;
-       },
-
-       /* Is the first field in a jQuery collection disabled as a datepicker?
-        * @param  target       element - the target input field or division or span
-        * @return boolean - true if disabled, false if enabled
-        */
-       _isDisabledDatepicker: function(target) {
-               if (!target) {
-                       return false;
-               }
-               for (var i = 0; i < this._disabledInputs.length; i++) {
-                       if (this._disabledInputs[i] === target) {
-                               return true;
-                       }
-               }
-               return false;
-       },
-
-       /* Retrieve the instance data for the target control.
-        * @param  target  element - the target input field or division or span
-        * @return  object - the associated instance data
-        * @throws  error if a jQuery problem getting data
-        */
-       _getInst: function(target) {
-               try {
-                       return $.data(target, PROP_NAME);
-               }
-               catch (err) {
-                       throw "Missing instance data for this datepicker";
-               }
-       },
-
-       /* Update or retrieve the settings for a date picker attached to an input field or division.
-        * @param  target  element - the target input field or division or span
-        * @param  name object - the new settings to update or
-        *                              string - the name of the setting to change or retrieve,
-        *                              when retrieving also "all" for all instance settings or
-        *                              "defaults" for all global defaults
-        * @param  value   any - the new value for the setting
-        *                              (omit if above is an object or to retrieve a value)
-        */
-       _optionDatepicker: function(target, name, value) {
-               var settings, date, minDate, maxDate,
-                       inst = this._getInst(target);
-
-               if (arguments.length === 2 && typeof name === "string") {
-                       return (name === "defaults" ? $.extend({}, $.datepicker._defaults) :
-                               (inst ? (name === "all" ? $.extend({}, inst.settings) :
-                               this._get(inst, name)) : null));
-               }
-
-               settings = name || {};
-               if (typeof name === "string") {
-                       settings = {};
-                       settings[name] = value;
-               }
-
-               if (inst) {
-                       if (this._curInst === inst) {
-                               this._hideDatepicker();
-                       }
-
-                       date = this._getDateDatepicker(target, true);
-                       minDate = this._getMinMaxDate(inst, "min");
-                       maxDate = this._getMinMaxDate(inst, "max");
-                       extendRemove(inst.settings, settings);
-                       // reformat the old minDate/maxDate values if dateFormat changes and a new minDate/maxDate isn't provided
-                       if (minDate !== null && settings.dateFormat !== undefined && settings.minDate === undefined) {
-                               inst.settings.minDate = this._formatDate(inst, minDate);
-                       }
-                       if (maxDate !== null && settings.dateFormat !== undefined && settings.maxDate === undefined) {
-                               inst.settings.maxDate = this._formatDate(inst, maxDate);
-                       }
-                       if ( "disabled" in settings ) {
-                               if ( settings.disabled ) {
-                                       this._disableDatepicker(target);
-                               } else {
-                                       this._enableDatepicker(target);
-                               }
-                       }
-                       this._attachments($(target), inst);
-                       this._autoSize(inst);
-                       this._setDate(inst, date);
-                       this._updateAlternate(inst);
-                       this._updateDatepicker(inst);
-               }
-       },
-
-       // change method deprecated
-       _changeDatepicker: function(target, name, value) {
-               this._optionDatepicker(target, name, value);
-       },
-
-       /* Redraw the date picker attached to an input field or division.
-        * @param  target  element - the target input field or division or span
-        */
-       _refreshDatepicker: function(target) {
-               var inst = this._getInst(target);
-               if (inst) {
-                       this._updateDatepicker(inst);
-               }
-       },
-
-       /* Set the dates for a jQuery selection.
-        * @param  target element - the target input field or division or span
-        * @param  date Date - the new date
-        */
-       _setDateDatepicker: function(target, date) {
-               var inst = this._getInst(target);
-               if (inst) {
-                       this._setDate(inst, date);
-                       this._updateDatepicker(inst);
-                       this._updateAlternate(inst);
-               }
-       },
-
-       /* Get the date(s) for the first entry in a jQuery selection.
-        * @param  target element - the target input field or division or span
-        * @param  noDefault boolean - true if no default date is to be used
-        * @return Date - the current date
-        */
-       _getDateDatepicker: function(target, noDefault) {
-               var inst = this._getInst(target);
-               if (inst && !inst.inline) {
-                       this._setDateFromField(inst, noDefault);
-               }
-               return (inst ? this._getDate(inst) : null);
-       },
-
-       /* Handle keystrokes. */
-       _doKeyDown: function(event) {
-               var onSelect, dateStr, sel,
-                       inst = $.datepicker._getInst(event.target),
-                       handled = true,
-                       isRTL = inst.dpDiv.is(".ui-datepicker-rtl");
-
-               inst._keyEvent = true;
-               if ($.datepicker._datepickerShowing) {
-                       switch (event.keyCode) {
-                               case 9: $.datepicker._hideDatepicker();
-                                               handled = false;
-                                               break; // hide on tab out
-                               case 13: sel = $("td." + $.datepicker._dayOverClass + ":not(." +
-                                                                       $.datepicker._currentClass + ")", inst.dpDiv);
-                                               if (sel[0]) {
-                                                       $.datepicker._selectDay(event.target, inst.selectedMonth, inst.selectedYear, sel[0]);
-                                               }
-
-                                               onSelect = $.datepicker._get(inst, "onSelect");
-                                               if (onSelect) {
-                                                       dateStr = $.datepicker._formatDate(inst);
-
-                                                       // trigger custom callback
-                                                       onSelect.apply((inst.input ? inst.input[0] : null), [dateStr, inst]);
-                                               } else {
-                                                       $.datepicker._hideDatepicker();
-                                               }
-
-                                               return false; // don't submit the form
-                               case 27: $.datepicker._hideDatepicker();
-                                               break; // hide on escape
-                               case 33: $.datepicker._adjustDate(event.target, (event.ctrlKey ?
-                                                       -$.datepicker._get(inst, "stepBigMonths") :
-                                                       -$.datepicker._get(inst, "stepMonths")), "M");
-                                               break; // previous month/year on page up/+ ctrl
-                               case 34: $.datepicker._adjustDate(event.target, (event.ctrlKey ?
-                                                       +$.datepicker._get(inst, "stepBigMonths") :
-                                                       +$.datepicker._get(inst, "stepMonths")), "M");
-                                               break; // next month/year on page down/+ ctrl
-                               case 35: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._clearDate(event.target);
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               break; // clear on ctrl or command +end
-                               case 36: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._gotoToday(event.target);
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               break; // current on ctrl or command +home
-                               case 37: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._adjustDate(event.target, (isRTL ? +1 : -1), "D");
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               // -1 day on ctrl or command +left
-                                               if (event.originalEvent.altKey) {
-                                                       $.datepicker._adjustDate(event.target, (event.ctrlKey ?
-                                                               -$.datepicker._get(inst, "stepBigMonths") :
-                                                               -$.datepicker._get(inst, "stepMonths")), "M");
-                                               }
-                                               // next month/year on alt +left on Mac
-                                               break;
-                               case 38: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._adjustDate(event.target, -7, "D");
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               break; // -1 week on ctrl or command +up
-                               case 39: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._adjustDate(event.target, (isRTL ? -1 : +1), "D");
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               // +1 day on ctrl or command +right
-                                               if (event.originalEvent.altKey) {
-                                                       $.datepicker._adjustDate(event.target, (event.ctrlKey ?
-                                                               +$.datepicker._get(inst, "stepBigMonths") :
-                                                               +$.datepicker._get(inst, "stepMonths")), "M");
-                                               }
-                                               // next month/year on alt +right
-                                               break;
-                               case 40: if (event.ctrlKey || event.metaKey) {
-                                                       $.datepicker._adjustDate(event.target, +7, "D");
-                                               }
-                                               handled = event.ctrlKey || event.metaKey;
-                                               break; // +1 week on ctrl or command +down
-                               default: handled = false;
-                       }
-               } else if (event.keyCode === 36 && event.ctrlKey) { // display the date picker on ctrl+home
-                       $.datepicker._showDatepicker(this);
-               } else {
-                       handled = false;
-               }
-
-               if (handled) {
-                       event.preventDefault();
-                       event.stopPropagation();
-               }
-       },
-
-       /* Filter entered characters - based on date format. */
-       _doKeyPress: function(event) {
-               var chars, chr,
-                       inst = $.datepicker._getInst(event.target);
-
-               if ($.datepicker._get(inst, "constrainInput")) {
-                       chars = $.datepicker._possibleChars($.datepicker._get(inst, "dateFormat"));
-                       chr = String.fromCharCode(event.charCode == null ? event.keyCode : event.charCode);
-                       return event.ctrlKey || event.metaKey || (chr < " " || !chars || chars.indexOf(chr) > -1);
-               }
-       },
-
-       /* Synchronise manual entry and field/alternate field. */
-       _doKeyUp: function(event) {
-               var date,
-                       inst = $.datepicker._getInst(event.target);
-
-               if (inst.input.val() !== inst.lastVal) {
-                       try {
-                               date = $.datepicker.parseDate($.datepicker._get(inst, "dateFormat"),
-                                       (inst.input ? inst.input.val() : null),
-                                       $.datepicker._getFormatConfig(inst));
-
-                               if (date) { // only if valid
-                                       $.datepicker._setDateFromField(inst);
-                                       $.datepicker._updateAlternate(inst);
-                                       $.datepicker._updateDatepicker(inst);
-                               }
-                       }
-                       catch (err) {
-                       }
-               }
-               return true;
-       },
-
-       /* Pop-up the date picker for a given input field.
-        * If false returned from beforeShow event handler do not show.
-        * @param  input  element - the input field attached to the date picker or
-        *                                      event - if triggered by focus
-        */
-       _showDatepicker: function(input) {
-               input = input.target || input;
-               if (input.nodeName.toLowerCase() !== "input") { // find from button/image trigger
-                       input = $("input", input.parentNode)[0];
-               }
-
-               if ($.datepicker._isDisabledDatepicker(input) || $.datepicker._lastInput === input) { // already here
-                       return;
-               }
-
-               var inst, beforeShow, beforeShowSettings, isFixed,
-                       offset, showAnim, duration;
-
-               inst = $.datepicker._getInst(input);
-               if ($.datepicker._curInst && $.datepicker._curInst !== inst) {
-                       $.datepicker._curInst.dpDiv.stop(true, true);
-                       if ( inst && $.datepicker._datepickerShowing ) {
-                               $.datepicker._hideDatepicker( $.datepicker._curInst.input[0] );
-                       }
-               }
-
-               beforeShow = $.datepicker._get(inst, "beforeShow");
-               beforeShowSettings = beforeShow ? beforeShow.apply(input, [input, inst]) : {};
-               if(beforeShowSettings === false){
-                       return;
-               }
-               extendRemove(inst.settings, beforeShowSettings);
-
-               inst.lastVal = null;
-               $.datepicker._lastInput = input;
-               $.datepicker._setDateFromField(inst);
-
-               if ($.datepicker._inDialog) { // hide cursor
-                       input.value = "";
-               }
-               if (!$.datepicker._pos) { // position below input
-                       $.datepicker._pos = $.datepicker._findPos(input);
-                       $.datepicker._pos[1] += input.offsetHeight; // add the height
-               }
-
-               isFixed = false;
-               $(input).parents().each(function() {
-                       isFixed |= $(this).css("position") === "fixed";
-                       return !isFixed;
-               });
-
-               offset = {left: $.datepicker._pos[0], top: $.datepicker._pos[1]};
-               $.datepicker._pos = null;
-               //to avoid flashes on Firefox
-               inst.dpDiv.empty();
-               // determine sizing offscreen
-               inst.dpDiv.css({position: "absolute", display: "block", top: "-1000px"});
-               $.datepicker._updateDatepicker(inst);
-               // fix width for dynamic number of date pickers
-               // and adjust position before showing
-               offset = $.datepicker._checkOffset(inst, offset, isFixed);
-               inst.dpDiv.css({position: ($.datepicker._inDialog && $.blockUI ?
-                       "static" : (isFixed ? "fixed" : "absolute")), display: "none",
-                       left: offset.left + "px", top: offset.top + "px"});
-
-               if (!inst.inline) {
-                       showAnim = $.datepicker._get(inst, "showAnim");
-                       duration = $.datepicker._get(inst, "duration");
-                       inst.dpDiv.zIndex($(input).zIndex()+1);
-                       $.datepicker._datepickerShowing = true;
-
-                       if ( $.effects && $.effects.effect[ showAnim ] ) {
-                               inst.dpDiv.show(showAnim, $.datepicker._get(inst, "showOptions"), duration);
-                       } else {
-                               inst.dpDiv[showAnim || "show"](showAnim ? duration : null);
-                       }
-
-                       if ( $.datepicker._shouldFocusInput( inst ) ) {
-                               inst.input.focus();
-                       }
-
-                       $.datepicker._curInst = inst;
-               }
-       },
-
-       /* Generate the date picker content. */
-       _updateDatepicker: function(inst) {
-               this.maxRows = 4; //Reset the max number of rows being displayed (see #7043)
-               instActive = inst; // for delegate hover events
-               inst.dpDiv.empty().append(this._generateHTML(inst));
-               this._attachHandlers(inst);
-               inst.dpDiv.find("." + this._dayOverClass + " a").mouseover();
-
-               var origyearshtml,
-                       numMonths = this._getNumberOfMonths(inst),
-                       cols = numMonths[1],
-                       width = 17;
-
-               inst.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width("");
-               if (cols > 1) {
-                       inst.dpDiv.addClass("ui-datepicker-multi-" + cols).css("width", (width * cols) + "em");
-               }
-               inst.dpDiv[(numMonths[0] !== 1 || numMonths[1] !== 1 ? "add" : "remove") +
-                       "Class"]("ui-datepicker-multi");
-               inst.dpDiv[(this._get(inst, "isRTL") ? "add" : "remove") +
-                       "Class"]("ui-datepicker-rtl");
-
-               if (inst === $.datepicker._curInst && $.datepicker._datepickerShowing && $.datepicker._shouldFocusInput( inst ) ) {
-                       inst.input.focus();
-               }
-
-               // deffered render of the years select (to avoid flashes on Firefox)
-               if( inst.yearshtml ){
-                       origyearshtml = inst.yearshtml;
-                       setTimeout(function(){
-                               //assure that inst.yearshtml didn't change.
-                               if( origyearshtml === inst.yearshtml && inst.yearshtml ){
-                                       inst.dpDiv.find("select.ui-datepicker-year:first").replaceWith(inst.yearshtml);
-                               }
-                               origyearshtml = inst.yearshtml = null;
-                       }, 0);
-               }
-       },
-
-       // #6694 - don't focus the input if it's already focused
-       // this breaks the change event in IE
-       // Support: IE and jQuery <1.9
-       _shouldFocusInput: function( inst ) {
-               return inst.input && inst.input.is( ":visible" ) && !inst.input.is( ":disabled" ) && !inst.input.is( ":focus" );
-       },
-
-       /* Check positioning to remain on screen. */
-       _checkOffset: function(inst, offset, isFixed) {
-               var dpWidth = inst.dpDiv.outerWidth(),
-                       dpHeight = inst.dpDiv.outerHeight(),
-                       inputWidth = inst.input ? inst.input.outerWidth() : 0,
-                       inputHeight = inst.input ? inst.input.outerHeight() : 0,
-                       viewWidth = document.documentElement.clientWidth + (isFixed ? 0 : $(document).scrollLeft()),
-                       viewHeight = document.documentElement.clientHeight + (isFixed ? 0 : $(document).scrollTop());
-
-               offset.left -= (this._get(inst, "isRTL") ? (dpWidth - inputWidth) : 0);
-               offset.left -= (isFixed && offset.left === inst.input.offset().left) ? $(document).scrollLeft() : 0;
-               offset.top -= (isFixed && offset.top === (inst.input.offset().top + inputHeight)) ? $(document).scrollTop() : 0;
-
-               // now check if datepicker is showing outside window viewport - move to a better place if so.
-               offset.left -= Math.min(offset.left, (offset.left + dpWidth > viewWidth && viewWidth > dpWidth) ?
-                       Math.abs(offset.left + dpWidth - viewWidth) : 0);
-               offset.top -= Math.min(offset.top, (offset.top + dpHeight > viewHeight && viewHeight > dpHeight) ?
-                       Math.abs(dpHeight + inputHeight) : 0);
-
-               return offset;
-       },
-
-       /* Find an object's position on the screen. */
-       _findPos: function(obj) {
-               var position,
-                       inst = this._getInst(obj),
-                       isRTL = this._get(inst, "isRTL");
-
-               while (obj && (obj.type === "hidden" || obj.nodeType !== 1 || $.expr.filters.hidden(obj))) {
-                       obj = obj[isRTL ? "previousSibling" : "nextSibling"];
-               }
-
-               position = $(obj).offset();
-               return [position.left, position.top];
-       },
-
-       /* Hide the date picker from view.
-        * @param  input  element - the input field attached to the date picker
-        */
-       _hideDatepicker: function(input) {
-               var showAnim, duration, postProcess, onClose,
-                       inst = this._curInst;
-
-               if (!inst || (input && inst !== $.data(input, PROP_NAME))) {
-                       return;
-               }
-
-               if (this._datepickerShowing) {
-                       showAnim = this._get(inst, "showAnim");
-                       duration = this._get(inst, "duration");
-                       postProcess = function() {
-                               $.datepicker._tidyDialog(inst);
-                       };
-
-                       // DEPRECATED: after BC for 1.8.x $.effects[ showAnim ] is not needed
-                       if ( $.effects && ( $.effects.effect[ showAnim ] || $.effects[ showAnim ] ) ) {
-                               inst.dpDiv.hide(showAnim, $.datepicker._get(inst, "showOptions"), duration, postProcess);
-                       } else {
-                               inst.dpDiv[(showAnim === "slideDown" ? "slideUp" :
-                                       (showAnim === "fadeIn" ? "fadeOut" : "hide"))]((showAnim ? duration : null), postProcess);
-                       }
-
-                       if (!showAnim) {
-                               postProcess();
-                       }
-                       this._datepickerShowing = false;
-
-                       onClose = this._get(inst, "onClose");
-                       if (onClose) {
-                               onClose.apply((inst.input ? inst.input[0] : null), [(inst.input ? inst.input.val() : ""), inst]);
-                       }
-
-                       this._lastInput = null;
-                       if (this._inDialog) {
-                               this._dialogInput.css({ position: "absolute", left: "0", top: "-100px" });
-                               if ($.blockUI) {
-                                       $.unblockUI();
-                                       $("body").append(this.dpDiv);
-                               }
-                       }
-                       this._inDialog = false;
-               }
-       },
-
-       /* Tidy up after a dialog display. */
-       _tidyDialog: function(inst) {
-               inst.dpDiv.removeClass(this._dialogClass).unbind(".ui-datepicker-calendar");
-       },
-
-       /* Close date picker if clicked elsewhere. */
-       _checkExternalClick: function(event) {
-               if (!$.datepicker._curInst) {
-                       return;
-               }
-
-               var $target = $(event.target),
-                       inst = $.datepicker._getInst($target[0]);
-
-               if ( ( ( $target[0].id !== $.datepicker._mainDivId &&
-                               $target.parents("#" + $.datepicker._mainDivId).length === 0 &&
-                               !$target.hasClass($.datepicker.markerClassName) &&
-                               !$target.closest("." + $.datepicker._triggerClass).length &&
-                               $.datepicker._datepickerShowing && !($.datepicker._inDialog && $.blockUI) ) ) ||
-                       ( $target.hasClass($.datepicker.markerClassName) && $.datepicker._curInst !== inst ) ) {
-                               $.datepicker._hideDatepicker();
-               }
-       },
-
-       /* Adjust one of the date sub-fields. */
-       _adjustDate: function(id, offset, period) {
-               var target = $(id),
-                       inst = this._getInst(target[0]);
-
-               if (this._isDisabledDatepicker(target[0])) {
-                       return;
-               }
-               this._adjustInstDate(inst, offset +
-                       (period === "M" ? this._get(inst, "showCurrentAtPos") : 0), // undo positioning
-                       period);
-               this._updateDatepicker(inst);
-       },
-
-       /* Action for current link. */
-       _gotoToday: function(id) {
-               var date,
-                       target = $(id),
-                       inst = this._getInst(target[0]);
-
-               if (this._get(inst, "gotoCurrent") && inst.currentDay) {
-                       inst.selectedDay = inst.currentDay;
-                       inst.drawMonth = inst.selectedMonth = inst.currentMonth;
-                       inst.drawYear = inst.selectedYear = inst.currentYear;
-               } else {
-                       date = new Date();
-                       inst.selectedDay = date.getDate();
-                       inst.drawMonth = inst.selectedMonth = date.getMonth();
-                       inst.drawYear = inst.selectedYear = date.getFullYear();
-               }
-               this._notifyChange(inst);
-               this._adjustDate(target);
-       },
-
-       /* Action for selecting a new month/year. */
-       _selectMonthYear: function(id, select, period) {
-               var target = $(id),
-                       inst = this._getInst(target[0]);
-
-               inst["selected" + (period === "M" ? "Month" : "Year")] =
-               inst["draw" + (period === "M" ? "Month" : "Year")] =
-                       parseInt(select.options[select.selectedIndex].value,10);
-
-               this._notifyChange(inst);
-               this._adjustDate(target);
-       },
-
-       /* Action for selecting a day. */
-       _selectDay: function(id, month, year, td) {
-               var inst,
-                       target = $(id);
-
-               if ($(td).hasClass(this._unselectableClass) || this._isDisabledDatepicker(target[0])) {
-                       return;
-               }
-
-               inst = this._getInst(target[0]);
-               inst.selectedDay = inst.currentDay = $("a", td).html();
-               inst.selectedMonth = inst.currentMonth = month;
-               inst.selectedYear = inst.currentYear = year;
-               this._selectDate(id, this._formatDate(inst,
-                       inst.currentDay, inst.currentMonth, inst.currentYear));
-       },
-
-       /* Erase the input field and hide the date picker. */
-       _clearDate: function(id) {
-               var target = $(id);
-               this._selectDate(target, "");
-       },
-
-       /* Update the input field with the selected date. */
-       _selectDate: function(id, dateStr) {
-               var onSelect,
-                       target = $(id),
-                       inst = this._getInst(target[0]);
-
-               dateStr = (dateStr != null ? dateStr : this._formatDate(inst));
-               if (inst.input) {
-                       inst.input.val(dateStr);
-               }
-               this._updateAlternate(inst);
-
-               onSelect = this._get(inst, "onSelect");
-               if (onSelect) {
-                       onSelect.apply((inst.input ? inst.input[0] : null), [dateStr, inst]);  // trigger custom callback
-               } else if (inst.input) {
-                       inst.input.trigger("change"); // fire the change event
-               }
-
-               if (inst.inline){
-                       this._updateDatepicker(inst);
-               } else {
-                       this._hideDatepicker();
-                       this._lastInput = inst.input[0];
-                       if (typeof(inst.input[0]) !== "object") {
-                               inst.input.focus(); // restore focus
-                       }
-                       this._lastInput = null;
-               }
-       },
-
-       /* Update any alternate field to synchronise with the main field. */
-       _updateAlternate: function(inst) {
-               var altFormat, date, dateStr,
-                       altField = this._get(inst, "altField");
-
-               if (altField) { // update alternate field too
-                       altFormat = this._get(inst, "altFormat") || this._get(inst, "dateFormat");
-                       date = this._getDate(inst);
-                       dateStr = this.formatDate(altFormat, date, this._getFormatConfig(inst));
-                       $(altField).each(function() { $(this).val(dateStr); });
-               }
-       },
-
-       /* Set as beforeShowDay function to prevent selection of weekends.
-        * @param  date  Date - the date to customise
-        * @return [boolean, string] - is this date selectable?, what is its CSS class?
-        */
-       noWeekends: function(date) {
-               var day = date.getDay();
-               return [(day > 0 && day < 6), ""];
-       },
-
-       /* Set as calculateWeek to determine the week of the year based on the ISO 8601 definition.
-        * @param  date  Date - the date to get the week for
-        * @return  number - the number of the week within the year that contains this date
-        */
-       iso8601Week: function(date) {
-               var time,
-                       checkDate = new Date(date.getTime());
-
-               // Find Thursday of this week starting on Monday
-               checkDate.setDate(checkDate.getDate() + 4 - (checkDate.getDay() || 7));
-
-               time = checkDate.getTime();
-               checkDate.setMonth(0); // Compare with Jan 1
-               checkDate.setDate(1);
-               return Math.floor(Math.round((time - checkDate) / 86400000) / 7) + 1;
-       },
-
-       /* Parse a string value into a date object.
-        * See formatDate below for the possible formats.
-        *
-        * @param  format string - the expected format of the date
-        * @param  value string - the date in the above format
-        * @param  settings Object - attributes include:
-        *                                      shortYearCutoff  number - the cutoff year for determining the century (optional)
-        *                                      dayNamesShort   string[7] - abbreviated names of the days from Sunday (optional)
-        *                                      dayNames                string[7] - names of the days from Sunday (optional)
-        *                                      monthNamesShort string[12] - abbreviated names of the months (optional)
-        *                                      monthNames              string[12] - names of the months (optional)
-        * @return  Date - the extracted date value or null if value is blank
-        */
-       parseDate: function (format, value, settings) {
-               if (format == null || value == null) {
-                       throw "Invalid arguments";
-               }
-
-               value = (typeof value === "object" ? value.toString() : value + "");
-               if (value === "") {
-                       return null;
-               }
-
-               var iFormat, dim, extra,
-                       iValue = 0,
-                       shortYearCutoffTemp = (settings ? settings.shortYearCutoff : null) || this._defaults.shortYearCutoff,
-                       shortYearCutoff = (typeof shortYearCutoffTemp !== "string" ? shortYearCutoffTemp :
-                               new Date().getFullYear() % 100 + parseInt(shortYearCutoffTemp, 10)),
-                       dayNamesShort = (settings ? settings.dayNamesShort : null) || this._defaults.dayNamesShort,
-                       dayNames = (settings ? settings.dayNames : null) || this._defaults.dayNames,
-                       monthNamesShort = (settings ? settings.monthNamesShort : null) || this._defaults.monthNamesShort,
-                       monthNames = (settings ? settings.monthNames : null) || this._defaults.monthNames,
-                       year = -1,
-                       month = -1,
-                       day = -1,
-                       doy = -1,
-                       literal = false,
-                       date,
-                       // Check whether a format character is doubled
-                       lookAhead = function(match) {
-                               var matches = (iFormat + 1 < format.length && format.charAt(iFormat + 1) === match);
-                               if (matches) {
-                                       iFormat++;
-                               }
-                               return matches;
-                       },
-                       // Extract a number from the string value
-                       getNumber = function(match) {
-                               var isDoubled = lookAhead(match),
-                                       size = (match === "@" ? 14 : (match === "!" ? 20 :
-                                       (match === "y" && isDoubled ? 4 : (match === "o" ? 3 : 2)))),
-                                       digits = new RegExp("^\\d{1," + size + "}"),
-                                       num = value.substring(iValue).match(digits);
-                               if (!num) {
-                                       throw "Missing number at position " + iValue;
-                               }
-                               iValue += num[0].length;
-                               return parseInt(num[0], 10);
-                       },
-                       // Extract a name from the string value and convert to an index
-                       getName = function(match, shortNames, longNames) {
-                               var index = -1,
-                                       names = $.map(lookAhead(match) ? longNames : shortNames, function (v, k) {
-                                               return [ [k, v] ];
-                                       }).sort(function (a, b) {
-                                               return -(a[1].length - b[1].length);
-                                       });
-
-                               $.each(names, function (i, pair) {
-                                       var name = pair[1];
-                                       if (value.substr(iValue, name.length).toLowerCase() === name.toLowerCase()) {
-                                               index = pair[0];
-                                               iValue += name.length;
-                                               return false;
-                                       }
-                               });
-                               if (index !== -1) {
-                                       return index + 1;
-                               } else {
-                                       throw "Unknown name at position " + iValue;
-                               }
-                       },
-                       // Confirm that a literal character matches the string value
-                       checkLiteral = function() {
-                               if (value.charAt(iValue) !== format.charAt(iFormat)) {
-                                       throw "Unexpected literal at position " + iValue;
-                               }
-                               iValue++;
-                       };
-
-               for (iFormat = 0; iFormat < format.length; iFormat++) {
-                       if (literal) {
-                               if (format.charAt(iFormat) === "'" && !lookAhead("'")) {
-                                       literal = false;
-                               } else {
-                                       checkLiteral();
-                               }
-                       } else {
-                               switch (format.charAt(iFormat)) {
-                                       case "d":
-                                               day = getNumber("d");
-                                               break;
-                                       case "D":
-                                               getName("D", dayNamesShort, dayNames);
-                                               break;
-                                       case "o":
-                                               doy = getNumber("o");
-                                               break;
-                                       case "m":
-                                               month = getNumber("m");
-                                               break;
-                                       case "M":
-                                               month = getName("M", monthNamesShort, monthNames);
-                                               break;
-                                       case "y":
-                                               year = getNumber("y");
-                                               break;
-                                       case "@":
-                                               date = new Date(getNumber("@"));
-                                               year = date.getFullYear();
-                                               month = date.getMonth() + 1;
-                                               day = date.getDate();
-                                               break;
-                                       case "!":
-                                               date = new Date((getNumber("!") - this._ticksTo1970) / 10000);
-                                               year = date.getFullYear();
-                                               month = date.getMonth() + 1;
-                                               day = date.getDate();
-                                               break;
-                                       case "'":
-                                               if (lookAhead("'")){
-                                                       checkLiteral();
-                                               } else {
-                                                       literal = true;
-                                               }
-                                               break;
-                                       default:
-                                               checkLiteral();
-                               }
-                       }
-               }
-
-               if (iValue < value.length){
-                       extra = value.substr(iValue);
-                       if (!/^\s+/.test(extra)) {
-                               throw "Extra/unparsed characters found in date: " + extra;
-                       }
-               }
-
-               if (year === -1) {
-                       year = new Date().getFullYear();
-               } else if (year < 100) {
-                       year += new Date().getFullYear() - new Date().getFullYear() % 100 +
-                               (year <= shortYearCutoff ? 0 : -100);
-               }
-
-               if (doy > -1) {
-                       month = 1;
-                       day = doy;
-                       do {
-                               dim = this._getDaysInMonth(year, month - 1);
-                               if (day <= dim) {
-                                       break;
-                               }
-                               month++;
-                               day -= dim;
-                       } while (true);
-               }
-
-               date = this._daylightSavingAdjust(new Date(year, month - 1, day));
-               if (date.getFullYear() !== year || date.getMonth() + 1 !== month || date.getDate() !== day) {
-                       throw "Invalid date"; // E.g. 31/02/00
-               }
-               return date;
-       },
-
-       /* Standard date formats. */
-       ATOM: "yy-mm-dd", // RFC 3339 (ISO 8601)
-       COOKIE: "D, dd M yy",
-       ISO_8601: "yy-mm-dd",
-       RFC_822: "D, d M y",
-       RFC_850: "DD, dd-M-y",
-       RFC_1036: "D, d M y",
-       RFC_1123: "D, d M yy",
-       RFC_2822: "D, d M yy",
-       RSS: "D, d M y", // RFC 822
-       TICKS: "!",
-       TIMESTAMP: "@",
-       W3C: "yy-mm-dd", // ISO 8601
-
-       _ticksTo1970: (((1970 - 1) * 365 + Math.floor(1970 / 4) - Math.floor(1970 / 100) +
-               Math.floor(1970 / 400)) * 24 * 60 * 60 * 10000000),
-
-       /* Format a date object into a string value.
-        * The format can be combinations of the following:
-        * d  - day of month (no leading zero)
-        * dd - day of month (two digit)
-        * o  - day of year (no leading zeros)
-        * oo - day of year (three digit)
-        * D  - day name short
-        * DD - day name long
-        * m  - month of year (no leading zero)
-        * mm - month of year (two digit)
-        * M  - month name short
-        * MM - month name long
-        * y  - year (two digit)
-        * yy - year (four digit)
-        * @ - Unix timestamp (ms since 01/01/1970)
-        * ! - Windows ticks (100ns since 01/01/0001)
-        * "..." - literal text
-        * '' - single quote
-        *
-        * @param  format string - the desired format of the date
-        * @param  date Date - the date value to format
-        * @param  settings Object - attributes include:
-        *                                      dayNamesShort   string[7] - abbreviated names of the days from Sunday (optional)
-        *                                      dayNames                string[7] - names of the days from Sunday (optional)
-        *                                      monthNamesShort string[12] - abbreviated names of the months (optional)
-        *                                      monthNames              string[12] - names of the months (optional)
-        * @return  string - the date in the above format
-        */
-       formatDate: function (format, date, settings) {
-               if (!date) {
-                       return "";
-               }
-
-               var iFormat,
-                       dayNamesShort = (settings ? settings.dayNamesShort : null) || this._defaults.dayNamesShort,
-                       dayNames = (settings ? settings.dayNames : null) || this._defaults.dayNames,
-                       monthNamesShort = (settings ? settings.monthNamesShort : null) || this._defaults.monthNamesShort,
-                       monthNames = (settings ? settings.monthNames : null) || this._defaults.monthNames,
-                       // Check whether a format character is doubled
-                       lookAhead = function(match) {
-                               var matches = (iFormat + 1 < format.length && format.charAt(iFormat + 1) === match);
-                               if (matches) {
-                                       iFormat++;
-                               }
-                               return matches;
-                       },
-                       // Format a number, with leading zero if necessary
-                       formatNumber = function(match, value, len) {
-                               var num = "" + value;
-                               if (lookAhead(match)) {
-                                       while (num.length < len) {
-                                               num = "0" + num;
-                                       }
-                               }
-                               return num;
-                       },
-                       // Format a name, short or long as requested
-                       formatName = function(match, value, shortNames, longNames) {
-                               return (lookAhead(match) ? longNames[value] : shortNames[value]);
-                       },
-                       output = "",
-                       literal = false;
-
-               if (date) {
-                       for (iFormat = 0; iFormat < format.length; iFormat++) {
-                               if (literal) {
-                                       if (format.charAt(iFormat) === "'" && !lookAhead("'")) {
-                                               literal = false;
-                                       } else {
-                                               output += format.charAt(iFormat);
-                                       }
-                               } else {
-                                       switch (format.charAt(iFormat)) {
-                                               case "d":
-                                                       output += formatNumber("d", date.getDate(), 2);
-                                                       break;
-                                               case "D":
-                                                       output += formatName("D", date.getDay(), dayNamesShort, dayNames);
-                                                       break;
-                                               case "o":
-                                                       output += formatNumber("o",
-                                                               Math.round((new Date(date.getFullYear(), date.getMonth(), date.getDate()).getTime() - new Date(date.getFullYear(), 0, 0).getTime()) / 86400000), 3);
-                                                       break;
-                                               case "m":
-                                                       output += formatNumber("m", date.getMonth() + 1, 2);
-                                                       break;
-                                               case "M":
-                                                       output += formatName("M", date.getMonth(), monthNamesShort, monthNames);
-                                                       break;
-                                               case "y":
-                                                       output += (lookAhead("y") ? date.getFullYear() :
-                                                               (date.getYear() % 100 < 10 ? "0" : "") + date.getYear() % 100);
-                                                       break;
-                                               case "@":
-                                                       output += date.getTime();
-                                                       break;
-                                               case "!":
-                                                       output += date.getTime() * 10000 + this._ticksTo1970;
-                                                       break;
-                                               case "'":
-                                                       if (lookAhead("'")) {
-                                                               output += "'";
-                                                       } else {
-                                                               literal = true;
-                                                       }
-                                                       break;
-                                               default:
-                                                       output += format.charAt(iFormat);
-                                       }
-                               }
-                       }
-               }
-               return output;
-       },
-
-       /* Extract all possible characters from the date format. */
-       _possibleChars: function (format) {
-               var iFormat,
-                       chars = "",
-                       literal = false,
-                       // Check whether a format character is doubled
-                       lookAhead = function(match) {
-                               var matches = (iFormat + 1 < format.length && format.charAt(iFormat + 1) === match);
-                               if (matches) {
-                                       iFormat++;
-                               }
-                               return matches;
-                       };
-
-               for (iFormat = 0; iFormat < format.length; iFormat++) {
-                       if (literal) {
-                               if (format.charAt(iFormat) === "'" && !lookAhead("'")) {
-                                       literal = false;
-                               } else {
-                                       chars += format.charAt(iFormat);
-                               }
-                       } else {
-                               switch (format.charAt(iFormat)) {
-                                       case "d": case "m": case "y": case "@":
-                                               chars += "0123456789";
-                                               break;
-                                       case "D": case "M":
-                                               return null; // Accept anything
-                                       case "'":
-                                               if (lookAhead("'")) {
-                                                       chars += "'";
-                                               } else {
-                                                       literal = true;
-                                               }
-                                               break;
-                                       default:
-                                               chars += format.charAt(iFormat);
-                               }
-                       }
-               }
-               return chars;
-       },
-
-       /* Get a setting value, defaulting if necessary. */
-       _get: function(inst, name) {
-               return inst.settings[name] !== undefined ?
-                       inst.settings[name] : this._defaults[name];
-       },
-
-       /* Parse existing date and initialise date picker. */
-       _setDateFromField: function(inst, noDefault) {
-               if (inst.input.val() === inst.lastVal) {
-                       return;
-               }
-
-               var dateFormat = this._get(inst, "dateFormat"),
-                       dates = inst.lastVal = inst.input ? inst.input.val() : null,
-                       defaultDate = this._getDefaultDate(inst),
-                       date = defaultDate,
-                       settings = this._getFormatConfig(inst);
-
-               try {
-                       date = this.parseDate(dateFormat, dates, settings) || defaultDate;
-               } catch (event) {
-                       dates = (noDefault ? "" : dates);
-               }
-               inst.selectedDay = date.getDate();
-               inst.drawMonth = inst.selectedMonth = date.getMonth();
-               inst.drawYear = inst.selectedYear = date.getFullYear();
-               inst.currentDay = (dates ? date.getDate() : 0);
-               inst.currentMonth = (dates ? date.getMonth() : 0);
-               inst.currentYear = (dates ? date.getFullYear() : 0);
-               this._adjustInstDate(inst);
-       },
-
-       /* Retrieve the default date shown on opening. */
-       _getDefaultDate: function(inst) {
-               return this._restrictMinMax(inst,
-                       this._determineDate(inst, this._get(inst, "defaultDate"), new Date()));
-       },
-
-       /* A date may be specified as an exact value or a relative one. */
-       _determineDate: function(inst, date, defaultDate) {
-               var offsetNumeric = function(offset) {
-                               var date = new Date();
-                               date.setDate(date.getDate() + offset);
-                               return date;
-                       },
-                       offsetString = function(offset) {
-                               try {
-                                       return $.datepicker.parseDate($.datepicker._get(inst, "dateFormat"),
-                                               offset, $.datepicker._getFormatConfig(inst));
-                               }
-                               catch (e) {
-                                       // Ignore
-                               }
-
-                               var date = (offset.toLowerCase().match(/^c/) ?
-                                       $.datepicker._getDate(inst) : null) || new Date(),
-                                       year = date.getFullYear(),
-                                       month = date.getMonth(),
-                                       day = date.getDate(),
-                                       pattern = /([+\-]?[0-9]+)\s*(d|D|w|W|m|M|y|Y)?/g,
-                                       matches = pattern.exec(offset);
-
-                               while (matches) {
-                                       switch (matches[2] || "d") {
-                                               case "d" : case "D" :
-                                                       day += parseInt(matches[1],10); break;
-                                               case "w" : case "W" :
-                                                       day += parseInt(matches[1],10) * 7; break;
-                                               case "m" : case "M" :
-                                                       month += parseInt(matches[1],10);
-                                                       day = Math.min(day, $.datepicker._getDaysInMonth(year, month));
-                                                       break;
-                                               case "y": case "Y" :
-                                                       year += parseInt(matches[1],10);
-                                                       day = Math.min(day, $.datepicker._getDaysInMonth(year, month));
-                                                       break;
-                                       }
-                                       matches = pattern.exec(offset);
-                               }
-                               return new Date(year, month, day);
-                       },
-                       newDate = (date == null || date === "" ? defaultDate : (typeof date === "string" ? offsetString(date) :
-                               (typeof date === "number" ? (isNaN(date) ? defaultDate : offsetNumeric(date)) : new Date(date.getTime()))));
-
-               newDate = (newDate && newDate.toString() === "Invalid Date" ? defaultDate : newDate);
-               if (newDate) {
-                       newDate.setHours(0);
-                       newDate.setMinutes(0);
-                       newDate.setSeconds(0);
-                       newDate.setMilliseconds(0);
-               }
-               return this._daylightSavingAdjust(newDate);
-       },
-
-       /* Handle switch to/from daylight saving.
-        * Hours may be non-zero on daylight saving cut-over:
-        * > 12 when midnight changeover, but then cannot generate
-        * midnight datetime, so jump to 1AM, otherwise reset.
-        * @param  date  (Date) the date to check
-        * @return  (Date) the corrected date
-        */
-       _daylightSavingAdjust: function(date) {
-               if (!date) {
-                       return null;
-               }
-               date.setHours(date.getHours() > 12 ? date.getHours() + 2 : 0);
-               return date;
-       },
-
-       /* Set the date(s) directly. */
-       _setDate: function(inst, date, noChange) {
-               var clear = !date,
-                       origMonth = inst.selectedMonth,
-                       origYear = inst.selectedYear,
-                       newDate = this._restrictMinMax(inst, this._determineDate(inst, date, new Date()));
-
-               inst.selectedDay = inst.currentDay = newDate.getDate();
-               inst.drawMonth = inst.selectedMonth = inst.currentMonth = newDate.getMonth();
-               inst.drawYear = inst.selectedYear = inst.currentYear = newDate.getFullYear();
-               if ((origMonth !== inst.selectedMonth || origYear !== inst.selectedYear) && !noChange) {
-                       this._notifyChange(inst);
-               }
-               this._adjustInstDate(inst);
-               if (inst.input) {
-                       inst.input.val(clear ? "" : this._formatDate(inst));
-               }
-       },
-
-       /* Retrieve the date(s) directly. */
-       _getDate: function(inst) {
-               var startDate = (!inst.currentYear || (inst.input && inst.input.val() === "") ? null :
-                       this._daylightSavingAdjust(new Date(
-                       inst.currentYear, inst.currentMonth, inst.currentDay)));
-                       return startDate;
-       },
-
-       /* Attach the onxxx handlers.  These are declared statically so
-        * they work with static code transformers like Caja.
-        */
-       _attachHandlers: function(inst) {
-               var stepMonths = this._get(inst, "stepMonths"),
-                       id = "#" + inst.id.replace( /\\\\/g, "\\" );
-               inst.dpDiv.find("[data-handler]").map(function () {
-                       var handler = {
-                               prev: function () {
-                                       $.datepicker._adjustDate(id, -stepMonths, "M");
-                               },
-                               next: function () {
-                                       $.datepicker._adjustDate(id, +stepMonths, "M");
-                               },
-                               hide: function () {
-                                       $.datepicker._hideDatepicker();
-                               },
-                               today: function () {
-                                       $.datepicker._gotoToday(id);
-                               },
-                               selectDay: function () {
-                                       $.datepicker._selectDay(id, +this.getAttribute("data-month"), +this.getAttribute("data-year"), this);
-                                       return false;
-                               },
-                               selectMonth: function () {
-                                       $.datepicker._selectMonthYear(id, this, "M");
-                                       return false;
-                               },
-                               selectYear: function () {
-                                       $.datepicker._selectMonthYear(id, this, "Y");
-                                       return false;
-                               }
-                       };
-                       $(this).bind(this.getAttribute("data-event"), handler[this.getAttribute("data-handler")]);
-               });
-       },
-
-       /* Generate the HTML for the current state of the date picker. */
-       _generateHTML: function(inst) {
-               var maxDraw, prevText, prev, nextText, next, currentText, gotoDate,
-                       controls, buttonPanel, firstDay, showWeek, dayNames, dayNamesMin,
-                       monthNames, monthNamesShort, beforeShowDay, showOtherMonths,
-                       selectOtherMonths, defaultDate, html, dow, row, group, col, selectedDate,
-                       cornerClass, calender, thead, day, daysInMonth, leadDays, curRows, numRows,
-                       printDate, dRow, tbody, daySettings, otherMonth, unselectable,
-                       tempDate = new Date(),
-                       today = this._daylightSavingAdjust(
-                               new Date(tempDate.getFullYear(), tempDate.getMonth(), tempDate.getDate())), // clear time
-                       isRTL = this._get(inst, "isRTL"),
-                       showButtonPanel = this._get(inst, "showButtonPanel"),
-                       hideIfNoPrevNext = this._get(inst, "hideIfNoPrevNext"),
-                       navigationAsDateFormat = this._get(inst, "navigationAsDateFormat"),
-                       numMonths = this._getNumberOfMonths(inst),
-                       showCurrentAtPos = this._get(inst, "showCurrentAtPos"),
-                       stepMonths = this._get(inst, "stepMonths"),
-                       isMultiMonth = (numMonths[0] !== 1 || numMonths[1] !== 1),
-                       currentDate = this._daylightSavingAdjust((!inst.currentDay ? new Date(9999, 9, 9) :
-                               new Date(inst.currentYear, inst.currentMonth, inst.currentDay))),
-                       minDate = this._getMinMaxDate(inst, "min"),
-                       maxDate = this._getMinMaxDate(inst, "max"),
-                       drawMonth = inst.drawMonth - showCurrentAtPos,
-                       drawYear = inst.drawYear;
-
-               if (drawMonth < 0) {
-                       drawMonth += 12;
-                       drawYear--;
-               }
-               if (maxDate) {
-                       maxDraw = this._daylightSavingAdjust(new Date(maxDate.getFullYear(),
-                               maxDate.getMonth() - (numMonths[0] * numMonths[1]) + 1, maxDate.getDate()));
-                       maxDraw = (minDate && maxDraw < minDate ? minDate : maxDraw);
-                       while (this._daylightSavingAdjust(new Date(drawYear, drawMonth, 1)) > maxDraw) {
-                               drawMonth--;
-                               if (drawMonth < 0) {
-                                       drawMonth = 11;
-                                       drawYear--;
-                               }
-                       }
-               }
-               inst.drawMonth = drawMonth;
-               inst.drawYear = drawYear;
-
-               prevText = this._get(inst, "prevText");
-               prevText = (!navigationAsDateFormat ? prevText : this.formatDate(prevText,
-                       this._daylightSavingAdjust(new Date(drawYear, drawMonth - stepMonths, 1)),
-                       this._getFormatConfig(inst)));
-
-               prev = (this._canAdjustMonth(inst, -1, drawYear, drawMonth) ?
-                       "<a class='ui-datepicker-prev ui-corner-all' data-handler='prev' data-event='click'" +
-                       " title='" + prevText + "'><span class='ui-icon ui-icon-circle-triangle-" + ( isRTL ? "e" : "w") + "'>" + prevText + "</span></a>" :
-                       (hideIfNoPrevNext ? "" : "<a class='ui-datepicker-prev ui-corner-all ui-state-disabled' title='"+ prevText +"'><span class='ui-icon ui-icon-circle-triangle-" + ( isRTL ? "e" : "w") + "'>" + prevText + "</span></a>"));
-
-               nextText = this._get(inst, "nextText");
-               nextText = (!navigationAsDateFormat ? nextText : this.formatDate(nextText,
-                       this._daylightSavingAdjust(new Date(drawYear, drawMonth + stepMonths, 1)),
-                       this._getFormatConfig(inst)));
-
-               next = (this._canAdjustMonth(inst, +1, drawYear, drawMonth) ?
-                       "<a class='ui-datepicker-next ui-corner-all' data-handler='next' data-event='click'" +
-                       " title='" + nextText + "'><span class='ui-icon ui-icon-circle-triangle-" + ( isRTL ? "w" : "e") + "'>" + nextText + "</span></a>" :
-                       (hideIfNoPrevNext ? "" : "<a class='ui-datepicker-next ui-corner-all ui-state-disabled' title='"+ nextText + "'><span class='ui-icon ui-icon-circle-triangle-" + ( isRTL ? "w" : "e") + "'>" + nextText + "</span></a>"));
-
-               currentText = this._get(inst, "currentText");
-               gotoDate = (this._get(inst, "gotoCurrent") && inst.currentDay ? currentDate : today);
-               currentText = (!navigationAsDateFormat ? currentText :
-                       this.formatDate(currentText, gotoDate, this._getFormatConfig(inst)));
-
-               controls = (!inst.inline ? "<button type='button' class='ui-datepicker-close ui-state-default ui-priority-primary ui-corner-all' data-handler='hide' data-event='click'>" +
-                       this._get(inst, "closeText") + "</button>" : "");
-
-               buttonPanel = (showButtonPanel) ? "<div class='ui-datepicker-buttonpane ui-widget-content'>" + (isRTL ? controls : "") +
-                       (this._isInRange(inst, gotoDate) ? "<button type='button' class='ui-datepicker-current ui-state-default ui-priority-secondary ui-corner-all' data-handler='today' data-event='click'" +
-                       ">" + currentText + "</button>" : "") + (isRTL ? "" : controls) + "</div>" : "";
-
-               firstDay = parseInt(this._get(inst, "firstDay"),10);
-               firstDay = (isNaN(firstDay) ? 0 : firstDay);
-
-               showWeek = this._get(inst, "showWeek");
-               dayNames = this._get(inst, "dayNames");
-               dayNamesMin = this._get(inst, "dayNamesMin");
-               monthNames = this._get(inst, "monthNames");
-               monthNamesShort = this._get(inst, "monthNamesShort");
-               beforeShowDay = this._get(inst, "beforeShowDay");
-               showOtherMonths = this._get(inst, "showOtherMonths");
-               selectOtherMonths = this._get(inst, "selectOtherMonths");
-               defaultDate = this._getDefaultDate(inst);
-               html = "";
-               dow;
-               for (row = 0; row < numMonths[0]; row++) {
-                       group = "";
-                       this.maxRows = 4;
-                       for (col = 0; col < numMonths[1]; col++) {
-                               selectedDate = this._daylightSavingAdjust(new Date(drawYear, drawMonth, inst.selectedDay));
-                               cornerClass = " ui-corner-all";
-                               calender = "";
-                               if (isMultiMonth) {
-                                       calender += "<div class='ui-datepicker-group";
-                                       if (numMonths[1] > 1) {
-                                               switch (col) {
-                                                       case 0: calender += " ui-datepicker-group-first";
-                                                               cornerClass = " ui-corner-" + (isRTL ? "right" : "left"); break;
-                                                       case numMonths[1]-1: calender += " ui-datepicker-group-last";
-                                                               cornerClass = " ui-corner-" + (isRTL ? "left" : "right"); break;
-                                                       default: calender += " ui-datepicker-group-middle"; cornerClass = ""; break;
-                                               }
-                                       }
-                                       calender += "'>";
-                               }
-                               calender += "<div class='ui-datepicker-header ui-widget-header ui-helper-clearfix" + cornerClass + "'>" +
-                                       (/all|left/.test(cornerClass) && row === 0 ? (isRTL ? next : prev) : "") +
-                                       (/all|right/.test(cornerClass) && row === 0 ? (isRTL ? prev : next) : "") +
-                                       this._generateMonthYearHeader(inst, drawMonth, drawYear, minDate, maxDate,
-                                       row > 0 || col > 0, monthNames, monthNamesShort) + // draw month headers
-                                       "</div><table class='ui-datepicker-calendar'><thead>" +
-                                       "<tr>";
-                               thead = (showWeek ? "<th class='ui-datepicker-week-col'>" + this._get(inst, "weekHeader") + "</th>" : "");
-                               for (dow = 0; dow < 7; dow++) { // days of the week
-                                       day = (dow + firstDay) % 7;
-                                       thead += "<th" + ((dow + firstDay + 6) % 7 >= 5 ? " class='ui-datepicker-week-end'" : "") + ">" +
-                                               "<span title='" + dayNames[day] + "'>" + dayNamesMin[day] + "</span></th>";
-                               }
-                               calender += thead + "</tr></thead><tbody>";
-                               daysInMonth = this._getDaysInMonth(drawYear, drawMonth);
-                               if (drawYear === inst.selectedYear && drawMonth === inst.selectedMonth) {
-                                       inst.selectedDay = Math.min(inst.selectedDay, daysInMonth);
-                               }
-                               leadDays = (this._getFirstDayOfMonth(drawYear, drawMonth) - firstDay + 7) % 7;
-                               curRows = Math.ceil((leadDays + daysInMonth) / 7); // calculate the number of rows to generate
-                               numRows = (isMultiMonth ? this.maxRows > curRows ? this.maxRows : curRows : curRows); //If multiple months, use the higher number of rows (see #7043)
-                               this.maxRows = numRows;
-                               printDate = this._daylightSavingAdjust(new Date(drawYear, drawMonth, 1 - leadDays));
-                               for (dRow = 0; dRow < numRows; dRow++) { // create date picker rows
-                                       calender += "<tr>";
-                                       tbody = (!showWeek ? "" : "<td class='ui-datepicker-week-col'>" +
-                                               this._get(inst, "calculateWeek")(printDate) + "</td>");
-                                       for (dow = 0; dow < 7; dow++) { // create date picker days
-                                               daySettings = (beforeShowDay ?
-                                                       beforeShowDay.apply((inst.input ? inst.input[0] : null), [printDate]) : [true, ""]);
-                                               otherMonth = (printDate.getMonth() !== drawMonth);
-                                               unselectable = (otherMonth && !selectOtherMonths) || !daySettings[0] ||
-                                                       (minDate && printDate < minDate) || (maxDate && printDate > maxDate);
-                                               tbody += "<td class='" +
-                                                       ((dow + firstDay + 6) % 7 >= 5 ? " ui-datepicker-week-end" : "") + // highlight weekends
-                                                       (otherMonth ? " ui-datepicker-other-month" : "") + // highlight days from other months
-                                                       ((printDate.getTime() === selectedDate.getTime() && drawMonth === inst.selectedMonth && inst._keyEvent) || // user pressed key
-                                                       (defaultDate.getTime() === printDate.getTime() && defaultDate.getTime() === selectedDate.getTime()) ?
-                                                       // or defaultDate is current printedDate and defaultDate is selectedDate
-                                                       " " + this._dayOverClass : "") + // highlight selected day
-                                                       (unselectable ? " " + this._unselectableClass + " ui-state-disabled": "") +  // highlight unselectable days
-                                                       (otherMonth && !showOtherMonths ? "" : " " + daySettings[1] + // highlight custom dates
-                                                       (printDate.getTime() === currentDate.getTime() ? " " + this._currentClass : "") + // highlight selected day
-                                                       (printDate.getTime() === today.getTime() ? " ui-datepicker-today" : "")) + "'" + // highlight today (if different)
-                                                       ((!otherMonth || showOtherMonths) && daySettings[2] ? " title='" + daySettings[2].replace(/'/g, "&#39;") + "'" : "") + // cell title
-                                                       (unselectable ? "" : " data-handler='selectDay' data-event='click' data-month='" + printDate.getMonth() + "' data-year='" + printDate.getFullYear() + "'") + ">" + // actions
-                                                       (otherMonth && !showOtherMonths ? "&#xa0;" : // display for other months
-                                                       (unselectable ? "<span class='ui-state-default'>" + printDate.getDate() + "</span>" : "<a class='ui-state-default" +
-                                                       (printDate.getTime() === today.getTime() ? " ui-state-highlight" : "") +
-                                                       (printDate.getTime() === currentDate.getTime() ? " ui-state-active" : "") + // highlight selected day
-                                                       (otherMonth ? " ui-priority-secondary" : "") + // distinguish dates from other months
-                                                       "' href='#'>" + printDate.getDate() + "</a>")) + "</td>"; // display selectable date
-                                               printDate.setDate(printDate.getDate() + 1);
-                                               printDate = this._daylightSavingAdjust(printDate);
-                                       }
-                                       calender += tbody + "</tr>";
-                               }
-                               drawMonth++;
-                               if (drawMonth > 11) {
-                                       drawMonth = 0;
-                                       drawYear++;
-                               }
-                               calender += "</tbody></table>" + (isMultiMonth ? "</div>" +
-                                                       ((numMonths[0] > 0 && col === numMonths[1]-1) ? "<div class='ui-datepicker-row-break'></div>" : "") : "");
-                               group += calender;
-                       }
-                       html += group;
-               }
-               html += buttonPanel;
-               inst._keyEvent = false;
-               return html;
-       },
-
-       /* Generate the month and year header. */
-       _generateMonthYearHeader: function(inst, drawMonth, drawYear, minDate, maxDate,
-                       secondary, monthNames, monthNamesShort) {
-
-               var inMinYear, inMaxYear, month, years, thisYear, determineYear, year, endYear,
-                       changeMonth = this._get(inst, "changeMonth"),
-                       changeYear = this._get(inst, "changeYear"),
-                       showMonthAfterYear = this._get(inst, "showMonthAfterYear"),
-                       html = "<div class='ui-datepicker-title'>",
-                       monthHtml = "";
-
-               // month selection
-               if (secondary || !changeMonth) {
-                       monthHtml += "<span class='ui-datepicker-month'>" + monthNames[drawMonth] + "</span>";
-               } else {
-                       inMinYear = (minDate && minDate.getFullYear() === drawYear);
-                       inMaxYear = (maxDate && maxDate.getFullYear() === drawYear);
-                       monthHtml += "<select class='ui-datepicker-month' data-handler='selectMonth' data-event='change'>";
-                       for ( month = 0; month < 12; month++) {
-                               if ((!inMinYear || month >= minDate.getMonth()) && (!inMaxYear || month <= maxDate.getMonth())) {
-                                       monthHtml += "<option value='" + month + "'" +
-                                               (month === drawMonth ? " selected='selected'" : "") +
-                                               ">" + monthNamesShort[month] + "</option>";
-                               }
-                       }
-                       monthHtml += "</select>";
-               }
-
-               if (!showMonthAfterYear) {
-                       html += monthHtml + (secondary || !(changeMonth && changeYear) ? "&#xa0;" : "");
-               }
-
-               // year selection
-               if ( !inst.yearshtml ) {
-                       inst.yearshtml = "";
-                       if (secondary || !changeYear) {
-                               html += "<span class='ui-datepicker-year'>" + drawYear + "</span>";
-                       } else {
-                               // determine range of years to display
-                               years = this._get(inst, "yearRange").split(":");
-                               thisYear = new Date().getFullYear();
-                               determineYear = function(value) {
-                                       var year = (value.match(/c[+\-].*/) ? drawYear + parseInt(value.substring(1), 10) :
-                                               (value.match(/[+\-].*/) ? thisYear + parseInt(value, 10) :
-                                               parseInt(value, 10)));
-                                       return (isNaN(year) ? thisYear : year);
-                               };
-                               year = determineYear(years[0]);
-                               endYear = Math.max(year, determineYear(years[1] || ""));
-                               year = (minDate ? Math.max(year, minDate.getFullYear()) : year);
-                               endYear = (maxDate ? Math.min(endYear, maxDate.getFullYear()) : endYear);
-                               inst.yearshtml += "<select class='ui-datepicker-year' data-handler='selectYear' data-event='change'>";
-                               for (; year <= endYear; year++) {
-                                       inst.yearshtml += "<option value='" + year + "'" +
-                                               (year === drawYear ? " selected='selected'" : "") +
-                                               ">" + year + "</option>";
-                               }
-                               inst.yearshtml += "</select>";
-
-                               html += inst.yearshtml;
-                               inst.yearshtml = null;
-                       }
-               }
-
-               html += this._get(inst, "yearSuffix");
-               if (showMonthAfterYear) {
-                       html += (secondary || !(changeMonth && changeYear) ? "&#xa0;" : "") + monthHtml;
-               }
-               html += "</div>"; // Close datepicker_header
-               return html;
-       },
-
-       /* Adjust one of the date sub-fields. */
-       _adjustInstDate: function(inst, offset, period) {
-               var year = inst.drawYear + (period === "Y" ? offset : 0),
-                       month = inst.drawMonth + (period === "M" ? offset : 0),
-                       day = Math.min(inst.selectedDay, this._getDaysInMonth(year, month)) + (period === "D" ? offset : 0),
-                       date = this._restrictMinMax(inst, this._daylightSavingAdjust(new Date(year, month, day)));
-
-               inst.selectedDay = date.getDate();
-               inst.drawMonth = inst.selectedMonth = date.getMonth();
-               inst.drawYear = inst.selectedYear = date.getFullYear();
-               if (period === "M" || period === "Y") {
-                       this._notifyChange(inst);
-               }
-       },
-
-       /* Ensure a date is within any min/max bounds. */
-       _restrictMinMax: function(inst, date) {
-               var minDate = this._getMinMaxDate(inst, "min"),
-                       maxDate = this._getMinMaxDate(inst, "max"),
-                       newDate = (minDate && date < minDate ? minDate : date);
-               return (maxDate && newDate > maxDate ? maxDate : newDate);
-       },
-
-       /* Notify change of month/year. */
-       _notifyChange: function(inst) {
-               var onChange = this._get(inst, "onChangeMonthYear");
-               if (onChange) {
-                       onChange.apply((inst.input ? inst.input[0] : null),
-                               [inst.selectedYear, inst.selectedMonth + 1, inst]);
-               }
-       },
-
-       /* Determine the number of months to show. */
-       _getNumberOfMonths: function(inst) {
-               var numMonths = this._get(inst, "numberOfMonths");
-               return (numMonths == null ? [1, 1] : (typeof numMonths === "number" ? [1, numMonths] : numMonths));
-       },
-
-       /* Determine the current maximum date - ensure no time components are set. */
-       _getMinMaxDate: function(inst, minMax) {
-               return this._determineDate(inst, this._get(inst, minMax + "Date"), null);
-       },
-
-       /* Find the number of days in a given month. */
-       _getDaysInMonth: function(year, month) {
-               return 32 - this._daylightSavingAdjust(new Date(year, month, 32)).getDate();
-       },
-
-       /* Find the day of the week of the first of a month. */
-       _getFirstDayOfMonth: function(year, month) {
-               return new Date(year, month, 1).getDay();
-       },
-
-       /* Determines if we should allow a "next/prev" month display change. */
-       _canAdjustMonth: function(inst, offset, curYear, curMonth) {
-               var numMonths = this._getNumberOfMonths(inst),
-                       date = this._daylightSavingAdjust(new Date(curYear,
-                       curMonth + (offset < 0 ? offset : numMonths[0] * numMonths[1]), 1));
-
-               if (offset < 0) {
-                       date.setDate(this._getDaysInMonth(date.getFullYear(), date.getMonth()));
-               }
-               return this._isInRange(inst, date);
-       },
-
-       /* Is the given date in the accepted range? */
-       _isInRange: function(inst, date) {
-               var yearSplit, currentYear,
-                       minDate = this._getMinMaxDate(inst, "min"),
-                       maxDate = this._getMinMaxDate(inst, "max"),
-                       minYear = null,
-                       maxYear = null,
-                       years = this._get(inst, "yearRange");
-                       if (years){
-                               yearSplit = years.split(":");
-                               currentYear = new Date().getFullYear();
-                               minYear = parseInt(yearSplit[0], 10);
-                               maxYear = parseInt(yearSplit[1], 10);
-                               if ( yearSplit[0].match(/[+\-].*/) ) {
-                                       minYear += currentYear;
-                               }
-                               if ( yearSplit[1].match(/[+\-].*/) ) {
-                                       maxYear += currentYear;
-                               }
-                       }
-
-               return ((!minDate || date.getTime() >= minDate.getTime()) &&
-                       (!maxDate || date.getTime() <= maxDate.getTime()) &&
-                       (!minYear || date.getFullYear() >= minYear) &&
-                       (!maxYear || date.getFullYear() <= maxYear));
-       },
-
-       /* Provide the configuration settings for formatting/parsing. */
-       _getFormatConfig: function(inst) {
-               var shortYearCutoff = this._get(inst, "shortYearCutoff");
-               shortYearCutoff = (typeof shortYearCutoff !== "string" ? shortYearCutoff :
-                       new Date().getFullYear() % 100 + parseInt(shortYearCutoff, 10));
-               return {shortYearCutoff: shortYearCutoff,
-                       dayNamesShort: this._get(inst, "dayNamesShort"), dayNames: this._get(inst, "dayNames"),
-                       monthNamesShort: this._get(inst, "monthNamesShort"), monthNames: this._get(inst, "monthNames")};
-       },
-
-       /* Format the given date for display. */
-       _formatDate: function(inst, day, month, year) {
-               if (!day) {
-                       inst.currentDay = inst.selectedDay;
-                       inst.currentMonth = inst.selectedMonth;
-                       inst.currentYear = inst.selectedYear;
-               }
-               var date = (day ? (typeof day === "object" ? day :
-                       this._daylightSavingAdjust(new Date(year, month, day))) :
-                       this._daylightSavingAdjust(new Date(inst.currentYear, inst.currentMonth, inst.currentDay)));
-               return this.formatDate(this._get(inst, "dateFormat"), date, this._getFormatConfig(inst));
-       }
-});
-
-/*
- * Bind hover events for datepicker elements.
- * Done via delegate so the binding only occurs once in the lifetime of the parent div.
- * Global instActive, set by _updateDatepicker allows the handlers to find their way back to the active picker.
- */
-function bindHover(dpDiv) {
-       var selector = "button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a";
-       return dpDiv.delegate(selector, "mouseout", function() {
-                       $(this).removeClass("ui-state-hover");
-                       if (this.className.indexOf("ui-datepicker-prev") !== -1) {
-                               $(this).removeClass("ui-datepicker-prev-hover");
-                       }
-                       if (this.className.indexOf("ui-datepicker-next") !== -1) {
-                               $(this).removeClass("ui-datepicker-next-hover");
-                       }
-               })
-               .delegate(selector, "mouseover", function(){
-                       if (!$.datepicker._isDisabledDatepicker( instActive.inline ? dpDiv.parent()[0] : instActive.input[0])) {
-                               $(this).parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover");
-                               $(this).addClass("ui-state-hover");
-                               if (this.className.indexOf("ui-datepicker-prev") !== -1) {
-                                       $(this).addClass("ui-datepicker-prev-hover");
-                               }
-                               if (this.className.indexOf("ui-datepicker-next") !== -1) {
-                                       $(this).addClass("ui-datepicker-next-hover");
-                               }
-                       }
-               });
-}
-
-/* jQuery extend now ignores nulls! */
-function extendRemove(target, props) {
-       $.extend(target, props);
-       for (var name in props) {
-               if (props[name] == null) {
-                       target[name] = props[name];
-               }
-       }
-       return target;
-}
-
-/* Invoke the datepicker functionality.
-   @param  options  string - a command, optionally followed by additional parameters or
-                                       Object - settings for attaching new datepicker functionality
-   @return  jQuery object */
-$.fn.datepicker = function(options){
-
-       /* Verify an empty collection wasn't passed - Fixes #6976 */
-       if ( !this.length ) {
-               return this;
-       }
-
-       /* Initialise the date picker. */
-       if (!$.datepicker.initialized) {
-               $(document).mousedown($.datepicker._checkExternalClick);
-               $.datepicker.initialized = true;
-       }
-
-       /* Append datepicker main container to body if not exist. */
-       if ($("#"+$.datepicker._mainDivId).length === 0) {
-               $("body").append($.datepicker.dpDiv);
-       }
-
-       var otherArgs = Array.prototype.slice.call(arguments, 1);
-       if (typeof options === "string" && (options === "isDisabled" || options === "getDate" || options === "widget")) {
-               return $.datepicker["_" + options + "Datepicker"].
-                       apply($.datepicker, [this[0]].concat(otherArgs));
-       }
-       if (options === "option" && arguments.length === 2 && typeof arguments[1] === "string") {
-               return $.datepicker["_" + options + "Datepicker"].
-                       apply($.datepicker, [this[0]].concat(otherArgs));
-       }
-       return this.each(function() {
-               typeof options === "string" ?
-                       $.datepicker["_" + options + "Datepicker"].
-                               apply($.datepicker, [this].concat(otherArgs)) :
-                       $.datepicker._attachDatepicker(this, options);
-       });
-};
-
-$.datepicker = new Datepicker(); // singleton instance
-$.datepicker.initialized = false;
-$.datepicker.uuid = new Date().getTime();
-$.datepicker.version = "1.10.4";
-
-})(jQuery);
-(function( $, undefined ) {
-
-var sizeRelatedOptions = {
-               buttons: true,
-               height: true,
-               maxHeight: true,
-               maxWidth: true,
-               minHeight: true,
-               minWidth: true,
-               width: true
-       },
-       resizableRelatedOptions = {
-               maxHeight: true,
-               maxWidth: true,
-               minHeight: true,
-               minWidth: true
-       };
-
-$.widget( "ui.dialog", {
-       version: "1.10.4",
-       options: {
-               appendTo: "body",
-               autoOpen: true,
-               buttons: [],
-               closeOnEscape: true,
-               closeText: "close",
-               dialogClass: "",
-               draggable: true,
-               hide: null,
-               height: "auto",
-               maxHeight: null,
-               maxWidth: null,
-               minHeight: 150,
-               minWidth: 150,
-               modal: false,
-               position: {
-                       my: "center",
-                       at: "center",
-                       of: window,
-                       collision: "fit",
-                       // Ensure the titlebar is always visible
-                       using: function( pos ) {
-                               var topOffset = $( this ).css( pos ).offset().top;
-                               if ( topOffset < 0 ) {
-                                       $( this ).css( "top", pos.top - topOffset );
-                               }
-                       }
-               },
-               resizable: true,
-               show: null,
-               title: null,
-               width: 300,
-
-               // callbacks
-               beforeClose: null,
-               close: null,
-               drag: null,
-               dragStart: null,
-               dragStop: null,
-               focus: null,
-               open: null,
-               resize: null,
-               resizeStart: null,
-               resizeStop: null
-       },
-
-       _create: function() {
-               this.originalCss = {
-                       display: this.element[0].style.display,
-                       width: this.element[0].style.width,
-                       minHeight: this.element[0].style.minHeight,
-                       maxHeight: this.element[0].style.maxHeight,
-                       height: this.element[0].style.height
-               };
-               this.originalPosition = {
-                       parent: this.element.parent(),
-                       index: this.element.parent().children().index( this.element )
-               };
-               this.originalTitle = this.element.attr("title");
-               this.options.title = this.options.title || this.originalTitle;
-
-               this._createWrapper();
-
-               this.element
-                       .show()
-                       .removeAttr("title")
-                       .addClass("ui-dialog-content ui-widget-content")
-                       .appendTo( this.uiDialog );
-
-               this._createTitlebar();
-               this._createButtonPane();
-
-               if ( this.options.draggable && $.fn.draggable ) {
-                       this._makeDraggable();
-               }
-               if ( this.options.resizable && $.fn.resizable ) {
-                       this._makeResizable();
-               }
-
-               this._isOpen = false;
-       },
-
-       _init: function() {
-               if ( this.options.autoOpen ) {
-                       this.open();
-               }
-       },
-
-       _appendTo: function() {
-               var element = this.options.appendTo;
-               if ( element && (element.jquery || element.nodeType) ) {
-                       return $( element );
-               }
-               return this.document.find( element || "body" ).eq( 0 );
-       },
-
-       _destroy: function() {
-               var next,
-                       originalPosition = this.originalPosition;
-
-               this._destroyOverlay();
-
-               this.element
-                       .removeUniqueId()
-                       .removeClass("ui-dialog-content ui-widget-content")
-                       .css( this.originalCss )
-                       // Without detaching first, the following becomes really slow
-                       .detach();
-
-               this.uiDialog.stop( true, true ).remove();
-
-               if ( this.originalTitle ) {
-                       this.element.attr( "title", this.originalTitle );
-               }
-
-               next = originalPosition.parent.children().eq( originalPosition.index );
-               // Don't try to place the dialog next to itself (#8613)
-               if ( next.length && next[0] !== this.element[0] ) {
-                       next.before( this.element );
-               } else {
-                       originalPosition.parent.append( this.element );
-               }
-       },
-
-       widget: function() {
-               return this.uiDialog;
-       },
-
-       disable: $.noop,
-       enable: $.noop,
-
-       close: function( event ) {
-               var activeElement,
-                       that = this;
-
-               if ( !this._isOpen || this._trigger( "beforeClose", event ) === false ) {
-                       return;
-               }
-
-               this._isOpen = false;
-               this._destroyOverlay();
-
-               if ( !this.opener.filter(":focusable").focus().length ) {
-
-                       // support: IE9
-                       // IE9 throws an "Unspecified error" accessing document.activeElement from an <iframe>
-                       try {
-                               activeElement = this.document[ 0 ].activeElement;
-
-                               // Support: IE9, IE10
-                               // If the <body> is blurred, IE will switch windows, see #4520
-                               if ( activeElement && activeElement.nodeName.toLowerCase() !== "body" ) {
-
-                                       // Hiding a focused element doesn't trigger blur in WebKit
-                                       // so in case we have nothing to focus on, explicitly blur the active element
-                                       // https://bugs.webkit.org/show_bug.cgi?id=47182
-                                       $( activeElement ).blur();
-                               }
-                       } catch ( error ) {}
-               }
-
-               this._hide( this.uiDialog, this.options.hide, function() {
-                       that._trigger( "close", event );
-               });
-       },
-
-       isOpen: function() {
-               return this._isOpen;
-       },
-
-       moveToTop: function() {
-               this._moveToTop();
-       },
-
-       _moveToTop: function( event, silent ) {
-               var moved = !!this.uiDialog.nextAll(":visible").insertBefore( this.uiDialog ).length;
-               if ( moved && !silent ) {
-                       this._trigger( "focus", event );
-               }
-               return moved;
-       },
-
-       open: function() {
-               var that = this;
-               if ( this._isOpen ) {
-                       if ( this._moveToTop() ) {
-                               this._focusTabbable();
-                       }
-                       return;
-               }
-
-               this._isOpen = true;
-               this.opener = $( this.document[0].activeElement );
-
-               this._size();
-               this._position();
-               this._createOverlay();
-               this._moveToTop( null, true );
-               this._show( this.uiDialog, this.options.show, function() {
-                       that._focusTabbable();
-                       that._trigger("focus");
-               });
-
-               this._trigger("open");
-       },
-
-       _focusTabbable: function() {
-               // Set focus to the first match:
-               // 1. First element inside the dialog matching [autofocus]
-               // 2. Tabbable element inside the content element
-               // 3. Tabbable element inside the buttonpane
-               // 4. The close button
-               // 5. The dialog itself
-               var hasFocus = this.element.find("[autofocus]");
-               if ( !hasFocus.length ) {
-                       hasFocus = this.element.find(":tabbable");
-               }
-               if ( !hasFocus.length ) {
-                       hasFocus = this.uiDialogButtonPane.find(":tabbable");
-               }
-               if ( !hasFocus.length ) {
-                       hasFocus = this.uiDialogTitlebarClose.filter(":tabbable");
-               }
-               if ( !hasFocus.length ) {
-                       hasFocus = this.uiDialog;
-               }
-               hasFocus.eq( 0 ).focus();
-       },
-
-       _keepFocus: function( event ) {
-               function checkFocus() {
-                       var activeElement = this.document[0].activeElement,
-                               isActive = this.uiDialog[0] === activeElement ||
-                                       $.contains( this.uiDialog[0], activeElement );
-                       if ( !isActive ) {
-                               this._focusTabbable();
-                       }
-               }
-               event.preventDefault();
-               checkFocus.call( this );
-               // support: IE
-               // IE <= 8 doesn't prevent moving focus even with event.preventDefault()
-               // so we check again later
-               this._delay( checkFocus );
-       },
-
-       _createWrapper: function() {
-               this.uiDialog = $("<div>")
-                       .addClass( "ui-dialog ui-widget ui-widget-content ui-corner-all ui-front " +
-                               this.options.dialogClass )
-                       .hide()
-                       .attr({
-                               // Setting tabIndex makes the div focusable
-                               tabIndex: -1,
-                               role: "dialog"
-                       })
-                       .appendTo( this._appendTo() );
-
-               this._on( this.uiDialog, {
-                       keydown: function( event ) {
-                               if ( this.options.closeOnEscape && !event.isDefaultPrevented() && event.keyCode &&
-                                               event.keyCode === $.ui.keyCode.ESCAPE ) {
-                                       event.preventDefault();
-                                       this.close( event );
-                                       return;
-                               }
-
-                               // prevent tabbing out of dialogs
-                               if ( event.keyCode !== $.ui.keyCode.TAB ) {
-                                       return;
-                               }
-                               var tabbables = this.uiDialog.find(":tabbable"),
-                                       first = tabbables.filter(":first"),
-                                       last  = tabbables.filter(":last");
-
-                               if ( ( event.target === last[0] || event.target === this.uiDialog[0] ) && !event.shiftKey ) {
-                                       first.focus( 1 );
-                                       event.preventDefault();
-                               } else if ( ( event.target === first[0] || event.target === this.uiDialog[0] ) && event.shiftKey ) {
-                                       last.focus( 1 );
-                                       event.preventDefault();
-                               }
-                       },
-                       mousedown: function( event ) {
-                               if ( this._moveToTop( event ) ) {
-                                       this._focusTabbable();
-                               }
-                       }
-               });
-
-               // We assume that any existing aria-describedby attribute means
-               // that the dialog content is marked up properly
-               // otherwise we brute force the content as the description
-               if ( !this.element.find("[aria-describedby]").length ) {
-                       this.uiDialog.attr({
-                               "aria-describedby": this.element.uniqueId().attr("id")
-                       });
-               }
-       },
-
-       _createTitlebar: function() {
-               var uiDialogTitle;
-
-               this.uiDialogTitlebar = $("<div>")
-                       .addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix")
-                       .prependTo( this.uiDialog );
-               this._on( this.uiDialogTitlebar, {
-                       mousedown: function( event ) {
-                               // Don't prevent click on close button (#8838)
-                               // Focusing a dialog that is partially scrolled out of view
-                               // causes the browser to scroll it into view, preventing the click event
-                               if ( !$( event.target ).closest(".ui-dialog-titlebar-close") ) {
-                                       // Dialog isn't getting focus when dragging (#8063)
-                                       this.uiDialog.focus();
-                               }
-                       }
-               });
-
-               // support: IE
-               // Use type="button" to prevent enter keypresses in textboxes from closing the
-               // dialog in IE (#9312)
-               this.uiDialogTitlebarClose = $( "<button type='button'></button>" )
-                       .button({
-                               label: this.options.closeText,
-                               icons: {
-                                       primary: "ui-icon-closethick"
-                               },
-                               text: false
-                       })
-                       .addClass("ui-dialog-titlebar-close")
-                       .appendTo( this.uiDialogTitlebar );
-               this._on( this.uiDialogTitlebarClose, {
-                       click: function( event ) {
-                               event.preventDefault();
-                               this.close( event );
-                       }
-               });
-
-               uiDialogTitle = $("<span>")
-                       .uniqueId()
-                       .addClass("ui-dialog-title")
-                       .prependTo( this.uiDialogTitlebar );
-               this._title( uiDialogTitle );
-
-               this.uiDialog.attr({
-                       "aria-labelledby": uiDialogTitle.attr("id")
-               });
-       },
-
-       _title: function( title ) {
-               if ( !this.options.title ) {
-                       title.html("&#160;");
-               }
-               title.text( this.options.title );
-       },
-
-       _createButtonPane: function() {
-               this.uiDialogButtonPane = $("<div>")
-                       .addClass("ui-dialog-buttonpane ui-widget-content ui-helper-clearfix");
-
-               this.uiButtonSet = $("<div>")
-                       .addClass("ui-dialog-buttonset")
-                       .appendTo( this.uiDialogButtonPane );
-
-               this._createButtons();
-       },
-
-       _createButtons: function() {
-               var that = this,
-                       buttons = this.options.buttons;
-
-               // if we already have a button pane, remove it
-               this.uiDialogButtonPane.remove();
-               this.uiButtonSet.empty();
-
-               if ( $.isEmptyObject( buttons ) || ($.isArray( buttons ) && !buttons.length) ) {
-                       this.uiDialog.removeClass("ui-dialog-buttons");
-                       return;
-               }
-
-               $.each( buttons, function( name, props ) {
-                       var click, buttonOptions;
-                       props = $.isFunction( props ) ?
-                               { click: props, text: name } :
-                               props;
-                       // Default to a non-submitting button
-                       props = $.extend( { type: "button" }, props );
-                       // Change the context for the click callback to be the main element
-                       click = props.click;
-                       props.click = function() {
-                               click.apply( that.element[0], arguments );
-                       };
-                       buttonOptions = {
-                               icons: props.icons,
-                               text: props.showText
-                       };
-                       delete props.icons;
-                       delete props.showText;
-                       $( "<button></button>", props )
-                               .button( buttonOptions )
-                               .appendTo( that.uiButtonSet );
-               });
-               this.uiDialog.addClass("ui-dialog-buttons");
-               this.uiDialogButtonPane.appendTo( this.uiDialog );
-       },
-
-       _makeDraggable: function() {
-               var that = this,
-                       options = this.options;
-
-               function filteredUi( ui ) {
-                       return {
-                               position: ui.position,
-                               offset: ui.offset
-                       };
-               }
-
-               this.uiDialog.draggable({
-                       cancel: ".ui-dialog-content, .ui-dialog-titlebar-close",
-                       handle: ".ui-dialog-titlebar",
-                       containment: "document",
-                       start: function( event, ui ) {
-                               $( this ).addClass("ui-dialog-dragging");
-                               that._blockFrames();
-                               that._trigger( "dragStart", event, filteredUi( ui ) );
-                       },
-                       drag: function( event, ui ) {
-                               that._trigger( "drag", event, filteredUi( ui ) );
-                       },
-                       stop: function( event, ui ) {
-                               options.position = [
-                                       ui.position.left - that.document.scrollLeft(),
-                                       ui.position.top - that.document.scrollTop()
-                               ];
-                               $( this ).removeClass("ui-dialog-dragging");
-                               that._unblockFrames();
-                               that._trigger( "dragStop", event, filteredUi( ui ) );
-                       }
-               });
-       },
-
-       _makeResizable: function() {
-               var that = this,
-                       options = this.options,
-                       handles = options.resizable,
-                       // .ui-resizable has position: relative defined in the stylesheet
-                       // but dialogs have to use absolute or fixed positioning
-                       position = this.uiDialog.css("position"),
-                       resizeHandles = typeof handles === "string" ?
-                               handles :
-                               "n,e,s,w,se,sw,ne,nw";
-
-               function filteredUi( ui ) {
-                       return {
-                               originalPosition: ui.originalPosition,
-                               originalSize: ui.originalSize,
-                               position: ui.position,
-                               size: ui.size
-                       };
-               }
-
-               this.uiDialog.resizable({
-                       cancel: ".ui-dialog-content",
-                       containment: "document",
-                       alsoResize: this.element,
-                       maxWidth: options.maxWidth,
-                       maxHeight: options.maxHeight,
-                       minWidth: options.minWidth,
-                       minHeight: this._minHeight(),
-                       handles: resizeHandles,
-                       start: function( event, ui ) {
-                               $( this ).addClass("ui-dialog-resizing");
-                               that._blockFrames();
-                               that._trigger( "resizeStart", event, filteredUi( ui ) );
-                       },
-                       resize: function( event, ui ) {
-                               that._trigger( "resize", event, filteredUi( ui ) );
-                       },
-                       stop: function( event, ui ) {
-                               options.height = $( this ).height();
-                               options.width = $( this ).width();
-                               $( this ).removeClass("ui-dialog-resizing");
-                               that._unblockFrames();
-                               that._trigger( "resizeStop", event, filteredUi( ui ) );
-                       }
-               })
-               .css( "position", position );
-       },
-
-       _minHeight: function() {
-               var options = this.options;
-
-               return options.height === "auto" ?
-                       options.minHeight :
-                       Math.min( options.minHeight, options.height );
-       },
-
-       _position: function() {
-               // Need to show the dialog to get the actual offset in the position plugin
-               var isVisible = this.uiDialog.is(":visible");
-               if ( !isVisible ) {
-                       this.uiDialog.show();
-               }
-               this.uiDialog.position( this.options.position );
-               if ( !isVisible ) {
-                       this.uiDialog.hide();
-               }
-       },
-
-       _setOptions: function( options ) {
-               var that = this,
-                       resize = false,
-                       resizableOptions = {};
-
-               $.each( options, function( key, value ) {
-                       that._setOption( key, value );
-
-                       if ( key in sizeRelatedOptions ) {
-                               resize = true;
-                       }
-                       if ( key in resizableRelatedOptions ) {
-                               resizableOptions[ key ] = value;
-                       }
-               });
-
-               if ( resize ) {
-                       this._size();
-                       this._position();
-               }
-               if ( this.uiDialog.is(":data(ui-resizable)") ) {
-                       this.uiDialog.resizable( "option", resizableOptions );
-               }
-       },
-
-       _setOption: function( key, value ) {
-               var isDraggable, isResizable,
-                       uiDialog = this.uiDialog;
-
-               if ( key === "dialogClass" ) {
-                       uiDialog
-                               .removeClass( this.options.dialogClass )
-                               .addClass( value );
-               }
-
-               if ( key === "disabled" ) {
-                       return;
-               }
-
-               this._super( key, value );
-
-               if ( key === "appendTo" ) {
-                       this.uiDialog.appendTo( this._appendTo() );
-               }
-
-               if ( key === "buttons" ) {
-                       this._createButtons();
-               }
-
-               if ( key === "closeText" ) {
-                       this.uiDialogTitlebarClose.button({
-                               // Ensure that we always pass a string
-                               label: "" + value
-                       });
-               }
-
-               if ( key === "draggable" ) {
-                       isDraggable = uiDialog.is(":data(ui-draggable)");
-                       if ( isDraggable && !value ) {
-                               uiDialog.draggable("destroy");
-                       }
-
-                       if ( !isDraggable && value ) {
-                               this._makeDraggable();
-                       }
-               }
-
-               if ( key === "position" ) {
-                       this._position();
-               }
-
-               if ( key === "resizable" ) {
-                       // currently resizable, becoming non-resizable
-                       isResizable = uiDialog.is(":data(ui-resizable)");
-                       if ( isResizable && !value ) {
-                               uiDialog.resizable("destroy");
-                       }
-
-                       // currently resizable, changing handles
-                       if ( isResizable && typeof value === "string" ) {
-                               uiDialog.resizable( "option", "handles", value );
-                       }
-
-                       // currently non-resizable, becoming resizable
-                       if ( !isResizable && value !== false ) {
-                               this._makeResizable();
-                       }
-               }
-
-               if ( key === "title" ) {
-                       this._title( this.uiDialogTitlebar.find(".ui-dialog-title") );
-               }
-       },
-
-       _size: function() {
-               // If the user has resized the dialog, the .ui-dialog and .ui-dialog-content
-               // divs will both have width and height set, so we need to reset them
-               var nonContentHeight, minContentHeight, maxContentHeight,
-                       options = this.options;
-
-               // Reset content sizing
-               this.element.show().css({
-                       width: "auto",
-                       minHeight: 0,
-                       maxHeight: "none",
-                       height: 0
-               });
-
-               if ( options.minWidth > options.width ) {
-                       options.width = options.minWidth;
-               }
-
-               // reset wrapper sizing
-               // determine the height of all the non-content elements
-               nonContentHeight = this.uiDialog.css({
-                               height: "auto",
-                               width: options.width
-                       })
-                       .outerHeight();
-               minContentHeight = Math.max( 0, options.minHeight - nonContentHeight );
-               maxContentHeight = typeof options.maxHeight === "number" ?
-                       Math.max( 0, options.maxHeight - nonContentHeight ) :
-                       "none";
-
-               if ( options.height === "auto" ) {
-                       this.element.css({
-                               minHeight: minContentHeight,
-                               maxHeight: maxContentHeight,
-                               height: "auto"
-                       });
-               } else {
-                       this.element.height( Math.max( 0, options.height - nonContentHeight ) );
-               }
-
-               if (this.uiDialog.is(":data(ui-resizable)") ) {
-                       this.uiDialog.resizable( "option", "minHeight", this._minHeight() );
-               }
-       },
-
-       _blockFrames: function() {
-               this.iframeBlocks = this.document.find( "iframe" ).map(function() {
-                       var iframe = $( this );
-
-                       return $( "<div>" )
-                               .css({
-                                       position: "absolute",
-                                       width: iframe.outerWidth(),
-                                       height: iframe.outerHeight()
-                               })
-                               .appendTo( iframe.parent() )
-                               .offset( iframe.offset() )[0];
-               });
-       },
-
-       _unblockFrames: function() {
-               if ( this.iframeBlocks ) {
-                       this.iframeBlocks.remove();
-                       delete this.iframeBlocks;
-               }
-       },
-
-       _allowInteraction: function( event ) {
-               if ( $( event.target ).closest(".ui-dialog").length ) {
-                       return true;
-               }
-
-               // TODO: Remove hack when datepicker implements
-               // the .ui-front logic (#8989)
-               return !!$( event.target ).closest(".ui-datepicker").length;
-       },
-
-       _createOverlay: function() {
-               if ( !this.options.modal ) {
-                       return;
-               }
-
-               var that = this,
-                       widgetFullName = this.widgetFullName;
-               if ( !$.ui.dialog.overlayInstances ) {
-                       // Prevent use of anchors and inputs.
-                       // We use a delay in case the overlay is created from an
-                       // event that we're going to be cancelling. (#2804)
-                       this._delay(function() {
-                               // Handle .dialog().dialog("close") (#4065)
-                               if ( $.ui.dialog.overlayInstances ) {
-                                       this.document.bind( "focusin.dialog", function( event ) {
-                                               if ( !that._allowInteraction( event ) ) {
-                                                       event.preventDefault();
-                                                       $(".ui-dialog:visible:last .ui-dialog-content")
-                                                               .data( widgetFullName )._focusTabbable();
-                                               }
-                                       });
-                               }
-                       });
-               }
-
-               this.overlay = $("<div>")
-                       .addClass("ui-widget-overlay ui-front")
-                       .appendTo( this._appendTo() );
-               this._on( this.overlay, {
-                       mousedown: "_keepFocus"
-               });
-               $.ui.dialog.overlayInstances++;
-       },
-
-       _destroyOverlay: function() {
-               if ( !this.options.modal ) {
-                       return;
-               }
-
-               if ( this.overlay ) {
-                       $.ui.dialog.overlayInstances--;
-
-                       if ( !$.ui.dialog.overlayInstances ) {
-                               this.document.unbind( "focusin.dialog" );
-                       }
-                       this.overlay.remove();
-                       this.overlay = null;
-               }
-       }
-});
-
-$.ui.dialog.overlayInstances = 0;
-
-// DEPRECATED
-if ( $.uiBackCompat !== false ) {
-       // position option with array notation
-       // just override with old implementation
-       $.widget( "ui.dialog", $.ui.dialog, {
-               _position: function() {
-                       var position = this.options.position,
-                               myAt = [],
-                               offset = [ 0, 0 ],
-                               isVisible;
-
-                       if ( position ) {
-                               if ( typeof position === "string" || (typeof position === "object" && "0" in position ) ) {
-                                       myAt = position.split ? position.split(" ") : [ position[0], position[1] ];
-                                       if ( myAt.length === 1 ) {
-                                               myAt[1] = myAt[0];
-                                       }
-
-                                       $.each( [ "left", "top" ], function( i, offsetPosition ) {
-                                               if ( +myAt[ i ] === myAt[ i ] ) {
-                                                       offset[ i ] = myAt[ i ];
-                                                       myAt[ i ] = offsetPosition;
-                                               }
-                                       });
-
-                                       position = {
-                                               my: myAt[0] + (offset[0] < 0 ? offset[0] : "+" + offset[0]) + " " +
-                                                       myAt[1] + (offset[1] < 0 ? offset[1] : "+" + offset[1]),
-                                               at: myAt.join(" ")
-                                       };
-                               }
-
-                               position = $.extend( {}, $.ui.dialog.prototype.options.position, position );
-                       } else {
-                               position = $.ui.dialog.prototype.options.position;
-                       }
-
-                       // need to show the dialog to get the actual offset in the position plugin
-                       isVisible = this.uiDialog.is(":visible");
-                       if ( !isVisible ) {
-                               this.uiDialog.show();
-                       }
-                       this.uiDialog.position( position );
-                       if ( !isVisible ) {
-                               this.uiDialog.hide();
-                       }
-               }
-       });
-}
-
-}( jQuery ) );
-(function( $, undefined ) {
-
-$.widget("ui.draggable", $.ui.mouse, {
-       version: "1.10.4",
-       widgetEventPrefix: "drag",
-       options: {
-               addClasses: true,
-               appendTo: "parent",
-               axis: false,
-               connectToSortable: false,
-               containment: false,
-               cursor: "auto",
-               cursorAt: false,
-               grid: false,
-               handle: false,
-               helper: "original",
-               iframeFix: false,
-               opacity: false,
-               refreshPositions: false,
-               revert: false,
-               revertDuration: 500,
-               scope: "default",
-               scroll: true,
-               scrollSensitivity: 20,
-               scrollSpeed: 20,
-               snap: false,
-               snapMode: "both",
-               snapTolerance: 20,
-               stack: false,
-               zIndex: false,
-
-               // callbacks
-               drag: null,
-               start: null,
-               stop: null
-       },
-       _create: function() {
-
-               if (this.options.helper === "original" && !(/^(?:r|a|f)/).test(this.element.css("position"))) {
-                       this.element[0].style.position = "relative";
-               }
-               if (this.options.addClasses){
-                       this.element.addClass("ui-draggable");
-               }
-               if (this.options.disabled){
-                       this.element.addClass("ui-draggable-disabled");
-               }
-
-               this._mouseInit();
-
-       },
-
-       _destroy: function() {
-               this.element.removeClass( "ui-draggable ui-draggable-dragging ui-draggable-disabled" );
-               this._mouseDestroy();
-       },
-
-       _mouseCapture: function(event) {
-
-               var o = this.options;
-
-               // among others, prevent a drag on a resizable-handle
-               if (this.helper || o.disabled || $(event.target).closest(".ui-resizable-handle").length > 0) {
-                       return false;
-               }
-
-               //Quit if we're not on a valid handle
-               this.handle = this._getHandle(event);
-               if (!this.handle) {
-                       return false;
-               }
-
-               $(o.iframeFix === true ? "iframe" : o.iframeFix).each(function() {
-                       $("<div class='ui-draggable-iframeFix' style='background: #fff;'></div>")
-                       .css({
-                               width: this.offsetWidth+"px", height: this.offsetHeight+"px",
-                               position: "absolute", opacity: "0.001", zIndex: 1000
-                       })
-                       .css($(this).offset())
-                       .appendTo("body");
-               });
-
-               return true;
-
-       },
-
-       _mouseStart: function(event) {
-
-               var o = this.options;
-
-               //Create and append the visible helper
-               this.helper = this._createHelper(event);
-
-               this.helper.addClass("ui-draggable-dragging");
-
-               //Cache the helper size
-               this._cacheHelperProportions();
-
-               //If ddmanager is used for droppables, set the global draggable
-               if($.ui.ddmanager) {
-                       $.ui.ddmanager.current = this;
-               }
-
-               /*
-                * - Position generation -
-                * This block generates everything position related - it's the core of draggables.
-                */
-
-               //Cache the margins of the original element
-               this._cacheMargins();
-
-               //Store the helper's css position
-               this.cssPosition = this.helper.css( "position" );
-               this.scrollParent = this.helper.scrollParent();
-               this.offsetParent = this.helper.offsetParent();
-               this.offsetParentCssPosition = this.offsetParent.css( "position" );
-
-               //The element's absolute position on the page minus margins
-               this.offset = this.positionAbs = this.element.offset();
-               this.offset = {
-                       top: this.offset.top - this.margins.top,
-                       left: this.offset.left - this.margins.left
-               };
-
-               //Reset scroll cache
-               this.offset.scroll = false;
-
-               $.extend(this.offset, {
-                       click: { //Where the click happened, relative to the element
-                               left: event.pageX - this.offset.left,
-                               top: event.pageY - this.offset.top
-                       },
-                       parent: this._getParentOffset(),
-                       relative: this._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper
-               });
-
-               //Generate the original position
-               this.originalPosition = this.position = this._generatePosition(event);
-               this.originalPageX = event.pageX;
-               this.originalPageY = event.pageY;
-
-               //Adjust the mouse offset relative to the helper if "cursorAt" is supplied
-               (o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));
-
-               //Set a containment if given in the options
-               this._setContainment();
-
-               //Trigger event + callbacks
-               if(this._trigger("start", event) === false) {
-                       this._clear();
-                       return false;
-               }
-
-               //Recache the helper size
-               this._cacheHelperProportions();
-
-               //Prepare the droppable offsets
-               if ($.ui.ddmanager && !o.dropBehaviour) {
-                       $.ui.ddmanager.prepareOffsets(this, event);
-               }
-
-
-               this._mouseDrag(event, true); //Execute the drag once - this causes the helper not to be visible before getting its correct position
-
-               //If the ddmanager is used for droppables, inform the manager that dragging has started (see #5003)
-               if ( $.ui.ddmanager ) {
-                       $.ui.ddmanager.dragStart(this, event);
-               }
-
-               return true;
-       },
-
-       _mouseDrag: function(event, noPropagation) {
-               // reset any necessary cached properties (see #5009)
-               if ( this.offsetParentCssPosition === "fixed" ) {
-                       this.offset.parent = this._getParentOffset();
-               }
-
-               //Compute the helpers position
-               this.position = this._generatePosition(event);
-               this.positionAbs = this._convertPositionTo("absolute");
-
-               //Call plugins and callbacks and use the resulting position if something is returned
-               if (!noPropagation) {
-                       var ui = this._uiHash();
-                       if(this._trigger("drag", event, ui) === false) {
-                               this._mouseUp({});
-                               return false;
-                       }
-                       this.position = ui.position;
-               }
-
-               if(!this.options.axis || this.options.axis !== "y") {
-                       this.helper[0].style.left = this.position.left+"px";
-               }
-               if(!this.options.axis || this.options.axis !== "x") {
-                       this.helper[0].style.top = this.position.top+"px";
-               }
-               if($.ui.ddmanager) {
-                       $.ui.ddmanager.drag(this, event);
-               }
-
-               return false;
-       },
-
-       _mouseStop: function(event) {
-
-               //If we are using droppables, inform the manager about the drop
-               var that = this,
-                       dropped = false;
-               if ($.ui.ddmanager && !this.options.dropBehaviour) {
-                       dropped = $.ui.ddmanager.drop(this, event);
-               }
-
-               //if a drop comes from outside (a sortable)
-               if(this.dropped) {
-                       dropped = this.dropped;
-                       this.dropped = false;
-               }
-
-               //if the original element is no longer in the DOM don't bother to continue (see #8269)
-               if ( this.options.helper === "original" && !$.contains( this.element[ 0 ].ownerDocument, this.element[ 0 ] ) ) {
-                       return false;
-               }
-
-               if((this.options.revert === "invalid" && !dropped) || (this.options.revert === "valid" && dropped) || this.options.revert === true || ($.isFunction(this.options.revert) && this.options.revert.call(this.element, dropped))) {
-                       $(this.helper).animate(this.originalPosition, parseInt(this.options.revertDuration, 10), function() {
-                               if(that._trigger("stop", event) !== false) {
-                                       that._clear();
-                               }
-                       });
-               } else {
-                       if(this._trigger("stop", event) !== false) {
-                               this._clear();
-                       }
-               }
-
-               return false;
-       },
-
-       _mouseUp: function(event) {
-               //Remove frame helpers
-               $("div.ui-draggable-iframeFix").each(function() {
-                       this.parentNode.removeChild(this);
-               });
-
-               //If the ddmanager is used for droppables, inform the manager that dragging has stopped (see #5003)
-               if( $.ui.ddmanager ) {
-                       $.ui.ddmanager.dragStop(this, event);
-               }
-
-               return $.ui.mouse.prototype._mouseUp.call(this, event);
-       },
-
-       cancel: function() {
-
-               if(this.helper.is(".ui-draggable-dragging")) {
-                       this._mouseUp({});
-               } else {
-                       this._clear();
-               }
-
-               return this;
-
-       },
-
-       _getHandle: function(event) {
-               return this.options.handle ?
-                       !!$( event.target ).closest( this.element.find( this.options.handle ) ).length :
-                       true;
-       },
-
-       _createHelper: function(event) {
-
-               var o = this.options,
-                       helper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [event])) : (o.helper === "clone" ? this.element.clone().removeAttr("id") : this.element);
-
-               if(!helper.parents("body").length) {
-                       helper.appendTo((o.appendTo === "parent" ? this.element[0].parentNode : o.appendTo));
-               }
-
-               if(helper[0] !== this.element[0] && !(/(fixed|absolute)/).test(helper.css("position"))) {
-                       helper.css("position", "absolute");
-               }
-
-               return helper;
-
-       },
-
-       _adjustOffsetFromHelper: function(obj) {
-               if (typeof obj === "string") {
-                       obj = obj.split(" ");
-               }
-               if ($.isArray(obj)) {
-                       obj = {left: +obj[0], top: +obj[1] || 0};
-               }
-               if ("left" in obj) {
-                       this.offset.click.left = obj.left + this.margins.left;
-               }
-               if ("right" in obj) {
-                       this.offset.click.left = this.helperProportions.width - obj.right + this.margins.left;
-               }
-               if ("top" in obj) {
-                       this.offset.click.top = obj.top + this.margins.top;
-               }
-               if ("bottom" in obj) {
-                       this.offset.click.top = this.helperProportions.height - obj.bottom + this.margins.top;
-               }
-       },
-
-       _getParentOffset: function() {
-
-               //Get the offsetParent and cache its position
-               var po = this.offsetParent.offset();
-
-               // This is a special case where we need to modify a offset calculated on start, since the following happened:
-               // 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent
-               // 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that
-               //    the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag
-               if(this.cssPosition === "absolute" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {
-                       po.left += this.scrollParent.scrollLeft();
-                       po.top += this.scrollParent.scrollTop();
-               }
-
-               //This needs to be actually done for all browsers, since pageX/pageY includes this information
-               //Ugly IE fix
-               if((this.offsetParent[0] === document.body) ||
-                       (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === "html" && $.ui.ie)) {
-                       po = { top: 0, left: 0 };
-               }
-
-               return {
-                       top: po.top + (parseInt(this.offsetParent.css("borderTopWidth"),10) || 0),
-                       left: po.left + (parseInt(this.offsetParent.css("borderLeftWidth"),10) || 0)
-               };
-
-       },
-
-       _getRelativeOffset: function() {
-
-               if(this.cssPosition === "relative") {
-                       var p = this.element.position();
-                       return {
-                               top: p.top - (parseInt(this.helper.css("top"),10) || 0) + this.scrollParent.scrollTop(),
-                               left: p.left - (parseInt(this.helper.css("left"),10) || 0) + this.scrollParent.scrollLeft()
-                       };
-               } else {
-                       return { top: 0, left: 0 };
-               }
-
-       },
-
-       _cacheMargins: function() {
-               this.margins = {
-                       left: (parseInt(this.element.css("marginLeft"),10) || 0),
-                       top: (parseInt(this.element.css("marginTop"),10) || 0),
-                       right: (parseInt(this.element.css("marginRight"),10) || 0),
-                       bottom: (parseInt(this.element.css("marginBottom"),10) || 0)
-               };
-       },
-
-       _cacheHelperProportions: function() {
-               this.helperProportions = {
-                       width: this.helper.outerWidth(),
-                       height: this.helper.outerHeight()
-               };
-       },
-
-       _setContainment: function() {
-
-               var over, c, ce,
-                       o = this.options;
-
-               if ( !o.containment ) {
-                       this.containment = null;
-                       return;
-               }
-
-               if ( o.containment === "window" ) {
-                       this.containment = [
-                               $( window ).scrollLeft() - this.offset.relative.left - this.offset.parent.left,
-                               $( window ).scrollTop() - this.offset.relative.top - this.offset.parent.top,
-                               $( window ).scrollLeft() + $( window ).width() - this.helperProportions.width - this.margins.left,
-                               $( window ).scrollTop() + ( $( window ).height() || document.body.parentNode.scrollHeight ) - this.helperProportions.height - this.margins.top
-                       ];
-                       return;
-               }
-
-               if ( o.containment === "document") {
-                       this.containment = [
-                               0,
-                               0,
-                               $( document ).width() - this.helperProportions.width - this.margins.left,
-                               ( $( document ).height() || document.body.parentNode.scrollHeight ) - this.helperProportions.height - this.margins.top
-                       ];
-                       return;
-               }
-
-               if ( o.containment.constructor === Array ) {
-                       this.containment = o.containment;
-                       return;
-               }
-
-               if ( o.containment === "parent" ) {
-                       o.containment = this.helper[ 0 ].parentNode;
-               }
-
-               c = $( o.containment );
-               ce = c[ 0 ];
-
-               if( !ce ) {
-                       return;
-               }
-
-               over = c.css( "overflow" ) !== "hidden";
-
-               this.containment = [
-                       ( parseInt( c.css( "borderLeftWidth" ), 10 ) || 0 ) + ( parseInt( c.css( "paddingLeft" ), 10 ) || 0 ),
-                       ( parseInt( c.css( "borderTopWidth" ), 10 ) || 0 ) + ( parseInt( c.css( "paddingTop" ), 10 ) || 0 ) ,
-                       ( over ? Math.max( ce.scrollWidth, ce.offsetWidth ) : ce.offsetWidth ) - ( parseInt( c.css( "borderRightWidth" ), 10 ) || 0 ) - ( parseInt( c.css( "paddingRight" ), 10 ) || 0 ) - this.helperProportions.width - this.margins.left - this.margins.right,
-                       ( over ? Math.max( ce.scrollHeight, ce.offsetHeight ) : ce.offsetHeight ) - ( parseInt( c.css( "borderBottomWidth" ), 10 ) || 0 ) - ( parseInt( c.css( "paddingBottom" ), 10 ) || 0 ) - this.helperProportions.height - this.margins.top  - this.margins.bottom
-               ];
-               this.relative_container = c;
-       },
-
-       _convertPositionTo: function(d, pos) {
-
-               if(!pos) {
-                       pos = this.position;
-               }
-
-               var mod = d === "absolute" ? 1 : -1,
-                       scroll = this.cssPosition === "absolute" && !( this.scrollParent[ 0 ] !== document && $.contains( this.scrollParent[ 0 ], this.offsetParent[ 0 ] ) ) ? this.offsetParent : this.scrollParent;
-
-               //Cache the scroll
-               if (!this.offset.scroll) {
-                       this.offset.scroll = {top : scroll.scrollTop(), left : scroll.scrollLeft()};
-               }
-
-               return {
-                       top: (
-                               pos.top +                                                                                                                               // The absolute mouse position
-                               this.offset.relative.top * mod +                                                                                // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.top * mod -                                                                          // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : this.offset.scroll.top ) * mod )
-                       ),
-                       left: (
-                               pos.left +                                                                                                                              // The absolute mouse position
-                               this.offset.relative.left * mod +                                                                               // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.left * mod   -                                                                               // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : this.offset.scroll.left ) * mod )
-                       )
-               };
-
-       },
-
-       _generatePosition: function(event) {
-
-               var containment, co, top, left,
-                       o = this.options,
-                       scroll = this.cssPosition === "absolute" && !( this.scrollParent[ 0 ] !== document && $.contains( this.scrollParent[ 0 ], this.offsetParent[ 0 ] ) ) ? this.offsetParent : this.scrollParent,
-                       pageX = event.pageX,
-                       pageY = event.pageY;
-
-               //Cache the scroll
-               if (!this.offset.scroll) {
-                       this.offset.scroll = {top : scroll.scrollTop(), left : scroll.scrollLeft()};
-               }
-
-               /*
-                * - Position constraining -
-                * Constrain the position to a mix of grid, containment.
-                */
-
-               // If we are not dragging yet, we won't check for options
-               if ( this.originalPosition ) {
-                       if ( this.containment ) {
-                               if ( this.relative_container ){
-                                       co = this.relative_container.offset();
-                                       containment = [
-                                               this.containment[ 0 ] + co.left,
-                                               this.containment[ 1 ] + co.top,
-                                               this.containment[ 2 ] + co.left,
-                                               this.containment[ 3 ] + co.top
-                                       ];
-                               }
-                               else {
-                                       containment = this.containment;
-                               }
-
-                               if(event.pageX - this.offset.click.left < containment[0]) {
-                                       pageX = containment[0] + this.offset.click.left;
-                               }
-                               if(event.pageY - this.offset.click.top < containment[1]) {
-                                       pageY = containment[1] + this.offset.click.top;
-                               }
-                               if(event.pageX - this.offset.click.left > containment[2]) {
-                                       pageX = containment[2] + this.offset.click.left;
-                               }
-                               if(event.pageY - this.offset.click.top > containment[3]) {
-                                       pageY = containment[3] + this.offset.click.top;
-                               }
-                       }
-
-                       if(o.grid) {
-                               //Check for grid elements set to 0 to prevent divide by 0 error causing invalid argument errors in IE (see ticket #6950)
-                               top = o.grid[1] ? this.originalPageY + Math.round((pageY - this.originalPageY) / o.grid[1]) * o.grid[1] : this.originalPageY;
-                               pageY = containment ? ((top - this.offset.click.top >= containment[1] || top - this.offset.click.top > containment[3]) ? top : ((top - this.offset.click.top >= containment[1]) ? top - o.grid[1] : top + o.grid[1])) : top;
-
-                               left = o.grid[0] ? this.originalPageX + Math.round((pageX - this.originalPageX) / o.grid[0]) * o.grid[0] : this.originalPageX;
-                               pageX = containment ? ((left - this.offset.click.left >= containment[0] || left - this.offset.click.left > containment[2]) ? left : ((left - this.offset.click.left >= containment[0]) ? left - o.grid[0] : left + o.grid[0])) : left;
-                       }
-
-               }
-
-               return {
-                       top: (
-                               pageY -                                                                                                                                 // The absolute mouse position
-                               this.offset.click.top   -                                                                                               // Click offset (relative to the element)
-                               this.offset.relative.top -                                                                                              // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.top +                                                                                                // The offsetParent's offset without borders (offset + border)
-                               ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : this.offset.scroll.top )
-                       ),
-                       left: (
-                               pageX -                                                                                                                                 // The absolute mouse position
-                               this.offset.click.left -                                                                                                // Click offset (relative to the element)
-                               this.offset.relative.left -                                                                                             // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.left +                                                                                               // The offsetParent's offset without borders (offset + border)
-                               ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : this.offset.scroll.left )
-                       )
-               };
-
-       },
-
-       _clear: function() {
-               this.helper.removeClass("ui-draggable-dragging");
-               if(this.helper[0] !== this.element[0] && !this.cancelHelperRemoval) {
-                       this.helper.remove();
-               }
-               this.helper = null;
-               this.cancelHelperRemoval = false;
-       },
-
-       // From now on bulk stuff - mainly helpers
-
-       _trigger: function(type, event, ui) {
-               ui = ui || this._uiHash();
-               $.ui.plugin.call(this, type, [event, ui]);
-               //The absolute position has to be recalculated after plugins
-               if(type === "drag") {
-                       this.positionAbs = this._convertPositionTo("absolute");
-               }
-               return $.Widget.prototype._trigger.call(this, type, event, ui);
-       },
-
-       plugins: {},
-
-       _uiHash: function() {
-               return {
-                       helper: this.helper,
-                       position: this.position,
-                       originalPosition: this.originalPosition,
-                       offset: this.positionAbs
-               };
-       }
-
-});
-
-$.ui.plugin.add("draggable", "connectToSortable", {
-       start: function(event, ui) {
-
-               var inst = $(this).data("ui-draggable"), o = inst.options,
-                       uiSortable = $.extend({}, ui, { item: inst.element });
-               inst.sortables = [];
-               $(o.connectToSortable).each(function() {
-                       var sortable = $.data(this, "ui-sortable");
-                       if (sortable && !sortable.options.disabled) {
-                               inst.sortables.push({
-                                       instance: sortable,
-                                       shouldRevert: sortable.options.revert
-                               });
-                               sortable.refreshPositions();    // Call the sortable's refreshPositions at drag start to refresh the containerCache since the sortable container cache is used in drag and needs to be up to date (this will ensure it's initialised as well as being kept in step with any changes that might have happened on the page).
-                               sortable._trigger("activate", event, uiSortable);
-                       }
-               });
-
-       },
-       stop: function(event, ui) {
-
-               //If we are still over the sortable, we fake the stop event of the sortable, but also remove helper
-               var inst = $(this).data("ui-draggable"),
-                       uiSortable = $.extend({}, ui, { item: inst.element });
-
-               $.each(inst.sortables, function() {
-                       if(this.instance.isOver) {
-
-                               this.instance.isOver = 0;
-
-                               inst.cancelHelperRemoval = true; //Don't remove the helper in the draggable instance
-                               this.instance.cancelHelperRemoval = false; //Remove it in the sortable instance (so sortable plugins like revert still work)
-
-                               //The sortable revert is supported, and we have to set a temporary dropped variable on the draggable to support revert: "valid/invalid"
-                               if(this.shouldRevert) {
-                                       this.instance.options.revert = this.shouldRevert;
-                               }
-
-                               //Trigger the stop of the sortable
-                               this.instance._mouseStop(event);
-
-                               this.instance.options.helper = this.instance.options._helper;
-
-                               //If the helper has been the original item, restore properties in the sortable
-                               if(inst.options.helper === "original") {
-                                       this.instance.currentItem.css({ top: "auto", left: "auto" });
-                               }
-
-                       } else {
-                               this.instance.cancelHelperRemoval = false; //Remove the helper in the sortable instance
-                               this.instance._trigger("deactivate", event, uiSortable);
-                       }
-
-               });
-
-       },
-       drag: function(event, ui) {
-
-               var inst = $(this).data("ui-draggable"), that = this;
-
-               $.each(inst.sortables, function() {
-
-                       var innermostIntersecting = false,
-                               thisSortable = this;
-
-                       //Copy over some variables to allow calling the sortable's native _intersectsWith
-                       this.instance.positionAbs = inst.positionAbs;
-                       this.instance.helperProportions = inst.helperProportions;
-                       this.instance.offset.click = inst.offset.click;
-
-                       if(this.instance._intersectsWith(this.instance.containerCache)) {
-                               innermostIntersecting = true;
-                               $.each(inst.sortables, function () {
-                                       this.instance.positionAbs = inst.positionAbs;
-                                       this.instance.helperProportions = inst.helperProportions;
-                                       this.instance.offset.click = inst.offset.click;
-                                       if (this !== thisSortable &&
-                                               this.instance._intersectsWith(this.instance.containerCache) &&
-                                               $.contains(thisSortable.instance.element[0], this.instance.element[0])
-                                       ) {
-                                               innermostIntersecting = false;
-                                       }
-                                       return innermostIntersecting;
-                               });
-                       }
-
-
-                       if(innermostIntersecting) {
-                               //If it intersects, we use a little isOver variable and set it once, so our move-in stuff gets fired only once
-                               if(!this.instance.isOver) {
-
-                                       this.instance.isOver = 1;
-                                       //Now we fake the start of dragging for the sortable instance,
-                                       //by cloning the list group item, appending it to the sortable and using it as inst.currentItem
-                                       //We can then fire the start event of the sortable with our passed browser event, and our own helper (so it doesn't create a new one)
-                                       this.instance.currentItem = $(that).clone().removeAttr("id").appendTo(this.instance.element).data("ui-sortable-item", true);
-                                       this.instance.options._helper = this.instance.options.helper; //Store helper option to later restore it
-                                       this.instance.options.helper = function() { return ui.helper[0]; };
-
-                                       event.target = this.instance.currentItem[0];
-                                       this.instance._mouseCapture(event, true);
-                                       this.instance._mouseStart(event, true, true);
-
-                                       //Because the browser event is way off the new appended portlet, we modify a couple of variables to reflect the changes
-                                       this.instance.offset.click.top = inst.offset.click.top;
-                                       this.instance.offset.click.left = inst.offset.click.left;
-                                       this.instance.offset.parent.left -= inst.offset.parent.left - this.instance.offset.parent.left;
-                                       this.instance.offset.parent.top -= inst.offset.parent.top - this.instance.offset.parent.top;
-
-                                       inst._trigger("toSortable", event);
-                                       inst.dropped = this.instance.element; //draggable revert needs that
-                                       //hack so receive/update callbacks work (mostly)
-                                       inst.currentItem = inst.element;
-                                       this.instance.fromOutside = inst;
-
-                               }
-
-                               //Provided we did all the previous steps, we can fire the drag event of the sortable on every draggable drag, when it intersects with the sortable
-                               if(this.instance.currentItem) {
-                                       this.instance._mouseDrag(event);
-                               }
-
-                       } else {
-
-                               //If it doesn't intersect with the sortable, and it intersected before,
-                               //we fake the drag stop of the sortable, but make sure it doesn't remove the helper by using cancelHelperRemoval
-                               if(this.instance.isOver) {
-
-                                       this.instance.isOver = 0;
-                                       this.instance.cancelHelperRemoval = true;
-
-                                       //Prevent reverting on this forced stop
-                                       this.instance.options.revert = false;
-
-                                       // The out event needs to be triggered independently
-                                       this.instance._trigger("out", event, this.instance._uiHash(this.instance));
-
-                                       this.instance._mouseStop(event, true);
-                                       this.instance.options.helper = this.instance.options._helper;
-
-                                       //Now we remove our currentItem, the list group clone again, and the placeholder, and animate the helper back to it's original size
-                                       this.instance.currentItem.remove();
-                                       if(this.instance.placeholder) {
-                                               this.instance.placeholder.remove();
-                                       }
-
-                                       inst._trigger("fromSortable", event);
-                                       inst.dropped = false; //draggable revert needs that
-                               }
-
-                       }
-
-               });
-
-       }
-});
-
-$.ui.plugin.add("draggable", "cursor", {
-       start: function() {
-               var t = $("body"), o = $(this).data("ui-draggable").options;
-               if (t.css("cursor")) {
-                       o._cursor = t.css("cursor");
-               }
-               t.css("cursor", o.cursor);
-       },
-       stop: function() {
-               var o = $(this).data("ui-draggable").options;
-               if (o._cursor) {
-                       $("body").css("cursor", o._cursor);
-               }
-       }
-});
-
-$.ui.plugin.add("draggable", "opacity", {
-       start: function(event, ui) {
-               var t = $(ui.helper), o = $(this).data("ui-draggable").options;
-               if(t.css("opacity")) {
-                       o._opacity = t.css("opacity");
-               }
-               t.css("opacity", o.opacity);
-       },
-       stop: function(event, ui) {
-               var o = $(this).data("ui-draggable").options;
-               if(o._opacity) {
-                       $(ui.helper).css("opacity", o._opacity);
-               }
-       }
-});
-
-$.ui.plugin.add("draggable", "scroll", {
-       start: function() {
-               var i = $(this).data("ui-draggable");
-               if(i.scrollParent[0] !== document && i.scrollParent[0].tagName !== "HTML") {
-                       i.overflowOffset = i.scrollParent.offset();
-               }
-       },
-       drag: function( event ) {
-
-               var i = $(this).data("ui-draggable"), o = i.options, scrolled = false;
-
-               if(i.scrollParent[0] !== document && i.scrollParent[0].tagName !== "HTML") {
-
-                       if(!o.axis || o.axis !== "x") {
-                               if((i.overflowOffset.top + i.scrollParent[0].offsetHeight) - event.pageY < o.scrollSensitivity) {
-                                       i.scrollParent[0].scrollTop = scrolled = i.scrollParent[0].scrollTop + o.scrollSpeed;
-                               } else if(event.pageY - i.overflowOffset.top < o.scrollSensitivity) {
-                                       i.scrollParent[0].scrollTop = scrolled = i.scrollParent[0].scrollTop - o.scrollSpeed;
-                               }
-                       }
-
-                       if(!o.axis || o.axis !== "y") {
-                               if((i.overflowOffset.left + i.scrollParent[0].offsetWidth) - event.pageX < o.scrollSensitivity) {
-                                       i.scrollParent[0].scrollLeft = scrolled = i.scrollParent[0].scrollLeft + o.scrollSpeed;
-                               } else if(event.pageX - i.overflowOffset.left < o.scrollSensitivity) {
-                                       i.scrollParent[0].scrollLeft = scrolled = i.scrollParent[0].scrollLeft - o.scrollSpeed;
-                               }
-                       }
-
-               } else {
-
-                       if(!o.axis || o.axis !== "x") {
-                               if(event.pageY - $(document).scrollTop() < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);
-                               } else if($(window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);
-                               }
-                       }
-
-                       if(!o.axis || o.axis !== "y") {
-                               if(event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);
-                               } else if($(window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);
-                               }
-                       }
-
-               }
-
-               if(scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {
-                       $.ui.ddmanager.prepareOffsets(i, event);
-               }
-
-       }
-});
-
-$.ui.plugin.add("draggable", "snap", {
-       start: function() {
-
-               var i = $(this).data("ui-draggable"),
-                       o = i.options;
-
-               i.snapElements = [];
-
-               $(o.snap.constructor !== String ? ( o.snap.items || ":data(ui-draggable)" ) : o.snap).each(function() {
-                       var $t = $(this),
-                               $o = $t.offset();
-                       if(this !== i.element[0]) {
-                               i.snapElements.push({
-                                       item: this,
-                                       width: $t.outerWidth(), height: $t.outerHeight(),
-                                       top: $o.top, left: $o.left
-                               });
-                       }
-               });
-
-       },
-       drag: function(event, ui) {
-
-               var ts, bs, ls, rs, l, r, t, b, i, first,
-                       inst = $(this).data("ui-draggable"),
-                       o = inst.options,
-                       d = o.snapTolerance,
-                       x1 = ui.offset.left, x2 = x1 + inst.helperProportions.width,
-                       y1 = ui.offset.top, y2 = y1 + inst.helperProportions.height;
-
-               for (i = inst.snapElements.length - 1; i >= 0; i--){
-
-                       l = inst.snapElements[i].left;
-                       r = l + inst.snapElements[i].width;
-                       t = inst.snapElements[i].top;
-                       b = t + inst.snapElements[i].height;
-
-                       if ( x2 < l - d || x1 > r + d || y2 < t - d || y1 > b + d || !$.contains( inst.snapElements[ i ].item.ownerDocument, inst.snapElements[ i ].item ) ) {
-                               if(inst.snapElements[i].snapping) {
-                                       (inst.options.snap.release && inst.options.snap.release.call(inst.element, event, $.extend(inst._uiHash(), { snapItem: inst.snapElements[i].item })));
-                               }
-                               inst.snapElements[i].snapping = false;
-                               continue;
-                       }
-
-                       if(o.snapMode !== "inner") {
-                               ts = Math.abs(t - y2) <= d;
-                               bs = Math.abs(b - y1) <= d;
-                               ls = Math.abs(l - x2) <= d;
-                               rs = Math.abs(r - x1) <= d;
-                               if(ts) {
-                                       ui.position.top = inst._convertPositionTo("relative", { top: t - inst.helperProportions.height, left: 0 }).top - inst.margins.top;
-                               }
-                               if(bs) {
-                                       ui.position.top = inst._convertPositionTo("relative", { top: b, left: 0 }).top - inst.margins.top;
-                               }
-                               if(ls) {
-                                       ui.position.left = inst._convertPositionTo("relative", { top: 0, left: l - inst.helperProportions.width }).left - inst.margins.left;
-                               }
-                               if(rs) {
-                                       ui.position.left = inst._convertPositionTo("relative", { top: 0, left: r }).left - inst.margins.left;
-                               }
-                       }
-
-                       first = (ts || bs || ls || rs);
-
-                       if(o.snapMode !== "outer") {
-                               ts = Math.abs(t - y1) <= d;
-                               bs = Math.abs(b - y2) <= d;
-                               ls = Math.abs(l - x1) <= d;
-                               rs = Math.abs(r - x2) <= d;
-                               if(ts) {
-                                       ui.position.top = inst._convertPositionTo("relative", { top: t, left: 0 }).top - inst.margins.top;
-                               }
-                               if(bs) {
-                                       ui.position.top = inst._convertPositionTo("relative", { top: b - inst.helperProportions.height, left: 0 }).top - inst.margins.top;
-                               }
-                               if(ls) {
-                                       ui.position.left = inst._convertPositionTo("relative", { top: 0, left: l }).left - inst.margins.left;
-                               }
-                               if(rs) {
-                                       ui.position.left = inst._convertPositionTo("relative", { top: 0, left: r - inst.helperProportions.width }).left - inst.margins.left;
-                               }
-                       }
-
-                       if(!inst.snapElements[i].snapping && (ts || bs || ls || rs || first)) {
-                               (inst.options.snap.snap && inst.options.snap.snap.call(inst.element, event, $.extend(inst._uiHash(), { snapItem: inst.snapElements[i].item })));
-                       }
-                       inst.snapElements[i].snapping = (ts || bs || ls || rs || first);
-
-               }
-
-       }
-});
-
-$.ui.plugin.add("draggable", "stack", {
-       start: function() {
-               var min,
-                       o = this.data("ui-draggable").options,
-                       group = $.makeArray($(o.stack)).sort(function(a,b) {
-                               return (parseInt($(a).css("zIndex"),10) || 0) - (parseInt($(b).css("zIndex"),10) || 0);
-                       });
-
-               if (!group.length) { return; }
-
-               min = parseInt($(group[0]).css("zIndex"), 10) || 0;
-               $(group).each(function(i) {
-                       $(this).css("zIndex", min + i);
-               });
-               this.css("zIndex", (min + group.length));
-       }
-});
-
-$.ui.plugin.add("draggable", "zIndex", {
-       start: function(event, ui) {
-               var t = $(ui.helper), o = $(this).data("ui-draggable").options;
-               if(t.css("zIndex")) {
-                       o._zIndex = t.css("zIndex");
-               }
-               t.css("zIndex", o.zIndex);
-       },
-       stop: function(event, ui) {
-               var o = $(this).data("ui-draggable").options;
-               if(o._zIndex) {
-                       $(ui.helper).css("zIndex", o._zIndex);
-               }
-       }
-});
-
-})(jQuery);
-(function( $, undefined ) {
-
-function isOverAxis( x, reference, size ) {
-       return ( x > reference ) && ( x < ( reference + size ) );
-}
-
-$.widget("ui.droppable", {
-       version: "1.10.4",
-       widgetEventPrefix: "drop",
-       options: {
-               accept: "*",
-               activeClass: false,
-               addClasses: true,
-               greedy: false,
-               hoverClass: false,
-               scope: "default",
-               tolerance: "intersect",
-
-               // callbacks
-               activate: null,
-               deactivate: null,
-               drop: null,
-               out: null,
-               over: null
-       },
-       _create: function() {
-
-               var proportions,
-                       o = this.options,
-                       accept = o.accept;
-
-               this.isover = false;
-               this.isout = true;
-
-               this.accept = $.isFunction(accept) ? accept : function(d) {
-                       return d.is(accept);
-               };
-
-               this.proportions = function( /* valueToWrite */ ) {
-                       if ( arguments.length ) {
-                               // Store the droppable's proportions
-                               proportions = arguments[ 0 ];
-                       } else {
-                               // Retrieve or derive the droppable's proportions
-                               return proportions ?
-                                       proportions :
-                                       proportions = {
-                                               width: this.element[ 0 ].offsetWidth,
-                                               height: this.element[ 0 ].offsetHeight
-                                       };
-                       }
-               };
-
-               // Add the reference and positions to the manager
-               $.ui.ddmanager.droppables[o.scope] = $.ui.ddmanager.droppables[o.scope] || [];
-               $.ui.ddmanager.droppables[o.scope].push(this);
-
-               (o.addClasses && this.element.addClass("ui-droppable"));
-
-       },
-
-       _destroy: function() {
-               var i = 0,
-                       drop = $.ui.ddmanager.droppables[this.options.scope];
-
-               for ( ; i < drop.length; i++ ) {
-                       if ( drop[i] === this ) {
-                               drop.splice(i, 1);
-                       }
-               }
-
-               this.element.removeClass("ui-droppable ui-droppable-disabled");
-       },
-
-       _setOption: function(key, value) {
-
-               if(key === "accept") {
-                       this.accept = $.isFunction(value) ? value : function(d) {
-                               return d.is(value);
-                       };
-               }
-               $.Widget.prototype._setOption.apply(this, arguments);
-       },
-
-       _activate: function(event) {
-               var draggable = $.ui.ddmanager.current;
-               if(this.options.activeClass) {
-                       this.element.addClass(this.options.activeClass);
-               }
-               if(draggable){
-                       this._trigger("activate", event, this.ui(draggable));
-               }
-       },
-
-       _deactivate: function(event) {
-               var draggable = $.ui.ddmanager.current;
-               if(this.options.activeClass) {
-                       this.element.removeClass(this.options.activeClass);
-               }
-               if(draggable){
-                       this._trigger("deactivate", event, this.ui(draggable));
-               }
-       },
-
-       _over: function(event) {
-
-               var draggable = $.ui.ddmanager.current;
-
-               // Bail if draggable and droppable are same element
-               if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
-                       return;
-               }
-
-               if (this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
-                       if(this.options.hoverClass) {
-                               this.element.addClass(this.options.hoverClass);
-                       }
-                       this._trigger("over", event, this.ui(draggable));
-               }
-
-       },
-
-       _out: function(event) {
-
-               var draggable = $.ui.ddmanager.current;
-
-               // Bail if draggable and droppable are same element
-               if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
-                       return;
-               }
-
-               if (this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
-                       if(this.options.hoverClass) {
-                               this.element.removeClass(this.options.hoverClass);
-                       }
-                       this._trigger("out", event, this.ui(draggable));
-               }
-
-       },
-
-       _drop: function(event,custom) {
-
-               var draggable = custom || $.ui.ddmanager.current,
-                       childrenIntersection = false;
-
-               // Bail if draggable and droppable are same element
-               if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
-                       return false;
-               }
-
-               this.element.find(":data(ui-droppable)").not(".ui-draggable-dragging").each(function() {
-                       var inst = $.data(this, "ui-droppable");
-                       if(
-                               inst.options.greedy &&
-                               !inst.options.disabled &&
-                               inst.options.scope === draggable.options.scope &&
-                               inst.accept.call(inst.element[0], (draggable.currentItem || draggable.element)) &&
-                               $.ui.intersect(draggable, $.extend(inst, { offset: inst.element.offset() }), inst.options.tolerance)
-                       ) { childrenIntersection = true; return false; }
-               });
-               if(childrenIntersection) {
-                       return false;
-               }
-
-               if(this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
-                       if(this.options.activeClass) {
-                               this.element.removeClass(this.options.activeClass);
-                       }
-                       if(this.options.hoverClass) {
-                               this.element.removeClass(this.options.hoverClass);
-                       }
-                       this._trigger("drop", event, this.ui(draggable));
-                       return this.element;
-               }
-
-               return false;
-
-       },
-
-       ui: function(c) {
-               return {
-                       draggable: (c.currentItem || c.element),
-                       helper: c.helper,
-                       position: c.position,
-                       offset: c.positionAbs
-               };
-       }
-
-});
-
-$.ui.intersect = function(draggable, droppable, toleranceMode) {
-
-       if (!droppable.offset) {
-               return false;
-       }
-
-       var draggableLeft, draggableTop,
-               x1 = (draggable.positionAbs || draggable.position.absolute).left,
-               y1 = (draggable.positionAbs || draggable.position.absolute).top,
-               x2 = x1 + draggable.helperProportions.width,
-               y2 = y1 + draggable.helperProportions.height,
-               l = droppable.offset.left,
-               t = droppable.offset.top,
-               r = l + droppable.proportions().width,
-               b = t + droppable.proportions().height;
-
-       switch (toleranceMode) {
-               case "fit":
-                       return (l <= x1 && x2 <= r && t <= y1 && y2 <= b);
-               case "intersect":
-                       return (l < x1 + (draggable.helperProportions.width / 2) && // Right Half
-                               x2 - (draggable.helperProportions.width / 2) < r && // Left Half
-                               t < y1 + (draggable.helperProportions.height / 2) && // Bottom Half
-                               y2 - (draggable.helperProportions.height / 2) < b ); // Top Half
-               case "pointer":
-                       draggableLeft = ((draggable.positionAbs || draggable.position.absolute).left + (draggable.clickOffset || draggable.offset.click).left);
-                       draggableTop = ((draggable.positionAbs || draggable.position.absolute).top + (draggable.clickOffset || draggable.offset.click).top);
-                       return isOverAxis( draggableTop, t, droppable.proportions().height ) && isOverAxis( draggableLeft, l, droppable.proportions().width );
-               case "touch":
-                       return (
-                               (y1 >= t && y1 <= b) || // Top edge touching
-                               (y2 >= t && y2 <= b) || // Bottom edge touching
-                               (y1 < t && y2 > b)              // Surrounded vertically
-                       ) && (
-                               (x1 >= l && x1 <= r) || // Left edge touching
-                               (x2 >= l && x2 <= r) || // Right edge touching
-                               (x1 < l && x2 > r)              // Surrounded horizontally
-                       );
-               default:
-                       return false;
-               }
-
-};
-
-/*
-       This manager tracks offsets of draggables and droppables
-*/
-$.ui.ddmanager = {
-       current: null,
-       droppables: { "default": [] },
-       prepareOffsets: function(t, event) {
-
-               var i, j,
-                       m = $.ui.ddmanager.droppables[t.options.scope] || [],
-                       type = event ? event.type : null, // workaround for #2317
-                       list = (t.currentItem || t.element).find(":data(ui-droppable)").addBack();
-
-               droppablesLoop: for (i = 0; i < m.length; i++) {
-
-                       //No disabled and non-accepted
-                       if(m[i].options.disabled || (t && !m[i].accept.call(m[i].element[0],(t.currentItem || t.element)))) {
-                               continue;
-                       }
-
-                       // Filter out elements in the current dragged item
-                       for (j=0; j < list.length; j++) {
-                               if(list[j] === m[i].element[0]) {
-                                       m[i].proportions().height = 0;
-                                       continue droppablesLoop;
-                               }
-                       }
-
-                       m[i].visible = m[i].element.css("display") !== "none";
-                       if(!m[i].visible) {
-                               continue;
-                       }
-
-                       //Activate the droppable if used directly from draggables
-                       if(type === "mousedown") {
-                               m[i]._activate.call(m[i], event);
-                       }
-
-                       m[ i ].offset = m[ i ].element.offset();
-                       m[ i ].proportions({ width: m[ i ].element[ 0 ].offsetWidth, height: m[ i ].element[ 0 ].offsetHeight });
-
-               }
-
-       },
-       drop: function(draggable, event) {
-
-               var dropped = false;
-               // Create a copy of the droppables in case the list changes during the drop (#9116)
-               $.each(($.ui.ddmanager.droppables[draggable.options.scope] || []).slice(), function() {
-
-                       if(!this.options) {
-                               return;
-                       }
-                       if (!this.options.disabled && this.visible && $.ui.intersect(draggable, this, this.options.tolerance)) {
-                               dropped = this._drop.call(this, event) || dropped;
-                       }
-
-                       if (!this.options.disabled && this.visible && this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
-                               this.isout = true;
-                               this.isover = false;
-                               this._deactivate.call(this, event);
-                       }
-
-               });
-               return dropped;
-
-       },
-       dragStart: function( draggable, event ) {
-               //Listen for scrolling so that if the dragging causes scrolling the position of the droppables can be recalculated (see #5003)
-               draggable.element.parentsUntil( "body" ).bind( "scroll.droppable", function() {
-                       if( !draggable.options.refreshPositions ) {
-                               $.ui.ddmanager.prepareOffsets( draggable, event );
-                       }
-               });
-       },
-       drag: function(draggable, event) {
-
-               //If you have a highly dynamic page, you might try this option. It renders positions every time you move the mouse.
-               if(draggable.options.refreshPositions) {
-                       $.ui.ddmanager.prepareOffsets(draggable, event);
-               }
-
-               //Run through all droppables and check their positions based on specific tolerance options
-               $.each($.ui.ddmanager.droppables[draggable.options.scope] || [], function() {
-
-                       if(this.options.disabled || this.greedyChild || !this.visible) {
-                               return;
-                       }
-
-                       var parentInstance, scope, parent,
-                               intersects = $.ui.intersect(draggable, this, this.options.tolerance),
-                               c = !intersects && this.isover ? "isout" : (intersects && !this.isover ? "isover" : null);
-                       if(!c) {
-                               return;
-                       }
-
-                       if (this.options.greedy) {
-                               // find droppable parents with same scope
-                               scope = this.options.scope;
-                               parent = this.element.parents(":data(ui-droppable)").filter(function () {
-                                       return $.data(this, "ui-droppable").options.scope === scope;
-                               });
-
-                               if (parent.length) {
-                                       parentInstance = $.data(parent[0], "ui-droppable");
-                                       parentInstance.greedyChild = (c === "isover");
-                               }
-                       }
-
-                       // we just moved into a greedy child
-                       if (parentInstance && c === "isover") {
-                               parentInstance.isover = false;
-                               parentInstance.isout = true;
-                               parentInstance._out.call(parentInstance, event);
-                       }
-
-                       this[c] = true;
-                       this[c === "isout" ? "isover" : "isout"] = false;
-                       this[c === "isover" ? "_over" : "_out"].call(this, event);
-
-                       // we just moved out of a greedy child
-                       if (parentInstance && c === "isout") {
-                               parentInstance.isout = false;
-                               parentInstance.isover = true;
-                               parentInstance._over.call(parentInstance, event);
-                       }
-               });
-
-       },
-       dragStop: function( draggable, event ) {
-               draggable.element.parentsUntil( "body" ).unbind( "scroll.droppable" );
-               //Call prepareOffsets one final time since IE does not fire return scroll events when overflow was caused by drag (see #5003)
-               if( !draggable.options.refreshPositions ) {
-                       $.ui.ddmanager.prepareOffsets( draggable, event );
-               }
-       }
-};
-
-})(jQuery);
-(function($, undefined) {
-
-var dataSpace = "ui-effects-";
-
-$.effects = {
-       effect: {}
-};
-
-/*!
- * jQuery Color Animations v2.1.2
- * https://github.com/jquery/jquery-color
- *
- * Copyright 2013 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * Date: Wed Jan 16 08:47:09 2013 -0600
- */
-(function( jQuery, undefined ) {
-
-       var stepHooks = "backgroundColor borderBottomColor borderLeftColor borderRightColor borderTopColor color columnRuleColor outlineColor textDecorationColor textEmphasisColor",
-
-       // plusequals test for += 100 -= 100
-       rplusequals = /^([\-+])=\s*(\d+\.?\d*)/,
-       // a set of RE's that can match strings and generate color tuples.
-       stringParsers = [{
-                       re: /rgba?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
-                       parse: function( execResult ) {
-                               return [
-                                       execResult[ 1 ],
-                                       execResult[ 2 ],
-                                       execResult[ 3 ],
-                                       execResult[ 4 ]
-                               ];
-                       }
-               }, {
-                       re: /rgba?\(\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
-                       parse: function( execResult ) {
-                               return [
-                                       execResult[ 1 ] * 2.55,
-                                       execResult[ 2 ] * 2.55,
-                                       execResult[ 3 ] * 2.55,
-                                       execResult[ 4 ]
-                               ];
-                       }
-               }, {
-                       // this regex ignores A-F because it's compared against an already lowercased string
-                       re: /#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})/,
-                       parse: function( execResult ) {
-                               return [
-                                       parseInt( execResult[ 1 ], 16 ),
-                                       parseInt( execResult[ 2 ], 16 ),
-                                       parseInt( execResult[ 3 ], 16 )
-                               ];
-                       }
-               }, {
-                       // this regex ignores A-F because it's compared against an already lowercased string
-                       re: /#([a-f0-9])([a-f0-9])([a-f0-9])/,
-                       parse: function( execResult ) {
-                               return [
-                                       parseInt( execResult[ 1 ] + execResult[ 1 ], 16 ),
-                                       parseInt( execResult[ 2 ] + execResult[ 2 ], 16 ),
-                                       parseInt( execResult[ 3 ] + execResult[ 3 ], 16 )
-                               ];
-                       }
-               }, {
-                       re: /hsla?\(\s*(\d+(?:\.\d+)?)\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
-                       space: "hsla",
-                       parse: function( execResult ) {
-                               return [
-                                       execResult[ 1 ],
-                                       execResult[ 2 ] / 100,
-                                       execResult[ 3 ] / 100,
-                                       execResult[ 4 ]
-                               ];
-                       }
-               }],
-
-       // jQuery.Color( )
-       color = jQuery.Color = function( color, green, blue, alpha ) {
-               return new jQuery.Color.fn.parse( color, green, blue, alpha );
-       },
-       spaces = {
-               rgba: {
-                       props: {
-                               red: {
-                                       idx: 0,
-                                       type: "byte"
-                               },
-                               green: {
-                                       idx: 1,
-                                       type: "byte"
-                               },
-                               blue: {
-                                       idx: 2,
-                                       type: "byte"
-                               }
-                       }
-               },
-
-               hsla: {
-                       props: {
-                               hue: {
-                                       idx: 0,
-                                       type: "degrees"
-                               },
-                               saturation: {
-                                       idx: 1,
-                                       type: "percent"
-                               },
-                               lightness: {
-                                       idx: 2,
-                                       type: "percent"
-                               }
-                       }
-               }
-       },
-       propTypes = {
-               "byte": {
-                       floor: true,
-                       max: 255
-               },
-               "percent": {
-                       max: 1
-               },
-               "degrees": {
-                       mod: 360,
-                       floor: true
-               }
-       },
-       support = color.support = {},
-
-       // element for support tests
-       supportElem = jQuery( "<p>" )[ 0 ],
-
-       // colors = jQuery.Color.names
-       colors,
-
-       // local aliases of functions called often
-       each = jQuery.each;
-
-// determine rgba support immediately
-supportElem.style.cssText = "background-color:rgba(1,1,1,.5)";
-support.rgba = supportElem.style.backgroundColor.indexOf( "rgba" ) > -1;
-
-// define cache name and alpha properties
-// for rgba and hsla spaces
-each( spaces, function( spaceName, space ) {
-       space.cache = "_" + spaceName;
-       space.props.alpha = {
-               idx: 3,
-               type: "percent",
-               def: 1
-       };
-});
-
-function clamp( value, prop, allowEmpty ) {
-       var type = propTypes[ prop.type ] || {};
-
-       if ( value == null ) {
-               return (allowEmpty || !prop.def) ? null : prop.def;
-       }
-
-       // ~~ is an short way of doing floor for positive numbers
-       value = type.floor ? ~~value : parseFloat( value );
-
-       // IE will pass in empty strings as value for alpha,
-       // which will hit this case
-       if ( isNaN( value ) ) {
-               return prop.def;
-       }
-
-       if ( type.mod ) {
-               // we add mod before modding to make sure that negatives values
-               // get converted properly: -10 -> 350
-               return (value + type.mod) % type.mod;
-       }
-
-       // for now all property types without mod have min and max
-       return 0 > value ? 0 : type.max < value ? type.max : value;
-}
-
-function stringParse( string ) {
-       var inst = color(),
-               rgba = inst._rgba = [];
-
-       string = string.toLowerCase();
-
-       each( stringParsers, function( i, parser ) {
-               var parsed,
-                       match = parser.re.exec( string ),
-                       values = match && parser.parse( match ),
-                       spaceName = parser.space || "rgba";
-
-               if ( values ) {
-                       parsed = inst[ spaceName ]( values );
-
-                       // if this was an rgba parse the assignment might happen twice
-                       // oh well....
-                       inst[ spaces[ spaceName ].cache ] = parsed[ spaces[ spaceName ].cache ];
-                       rgba = inst._rgba = parsed._rgba;
-
-                       // exit each( stringParsers ) here because we matched
-                       return false;
-               }
-       });
-
-       // Found a stringParser that handled it
-       if ( rgba.length ) {
-
-               // if this came from a parsed string, force "transparent" when alpha is 0
-               // chrome, (and maybe others) return "transparent" as rgba(0,0,0,0)
-               if ( rgba.join() === "0,0,0,0" ) {
-                       jQuery.extend( rgba, colors.transparent );
-               }
-               return inst;
-       }
-
-       // named colors
-       return colors[ string ];
-}
-
-color.fn = jQuery.extend( color.prototype, {
-       parse: function( red, green, blue, alpha ) {
-               if ( red === undefined ) {
-                       this._rgba = [ null, null, null, null ];
-                       return this;
-               }
-               if ( red.jquery || red.nodeType ) {
-                       red = jQuery( red ).css( green );
-                       green = undefined;
-               }
-
-               var inst = this,
-                       type = jQuery.type( red ),
-                       rgba = this._rgba = [];
-
-               // more than 1 argument specified - assume ( red, green, blue, alpha )
-               if ( green !== undefined ) {
-                       red = [ red, green, blue, alpha ];
-                       type = "array";
-               }
-
-               if ( type === "string" ) {
-                       return this.parse( stringParse( red ) || colors._default );
-               }
-
-               if ( type === "array" ) {
-                       each( spaces.rgba.props, function( key, prop ) {
-                               rgba[ prop.idx ] = clamp( red[ prop.idx ], prop );
-                       });
-                       return this;
-               }
-
-               if ( type === "object" ) {
-                       if ( red instanceof color ) {
-                               each( spaces, function( spaceName, space ) {
-                                       if ( red[ space.cache ] ) {
-                                               inst[ space.cache ] = red[ space.cache ].slice();
-                                       }
-                               });
-                       } else {
-                               each( spaces, function( spaceName, space ) {
-                                       var cache = space.cache;
-                                       each( space.props, function( key, prop ) {
-
-                                               // if the cache doesn't exist, and we know how to convert
-                                               if ( !inst[ cache ] && space.to ) {
-
-                                                       // if the value was null, we don't need to copy it
-                                                       // if the key was alpha, we don't need to copy it either
-                                                       if ( key === "alpha" || red[ key ] == null ) {
-                                                               return;
-                                                       }
-                                                       inst[ cache ] = space.to( inst._rgba );
-                                               }
-
-                                               // this is the only case where we allow nulls for ALL properties.
-                                               // call clamp with alwaysAllowEmpty
-                                               inst[ cache ][ prop.idx ] = clamp( red[ key ], prop, true );
-                                       });
-
-                                       // everything defined but alpha?
-                                       if ( inst[ cache ] && jQuery.inArray( null, inst[ cache ].slice( 0, 3 ) ) < 0 ) {
-                                               // use the default of 1
-                                               inst[ cache ][ 3 ] = 1;
-                                               if ( space.from ) {
-                                                       inst._rgba = space.from( inst[ cache ] );
-                                               }
-                                       }
-                               });
-                       }
-                       return this;
-               }
-       },
-       is: function( compare ) {
-               var is = color( compare ),
-                       same = true,
-                       inst = this;
-
-               each( spaces, function( _, space ) {
-                       var localCache,
-                               isCache = is[ space.cache ];
-                       if (isCache) {
-                               localCache = inst[ space.cache ] || space.to && space.to( inst._rgba ) || [];
-                               each( space.props, function( _, prop ) {
-                                       if ( isCache[ prop.idx ] != null ) {
-                                               same = ( isCache[ prop.idx ] === localCache[ prop.idx ] );
-                                               return same;
-                                       }
-                               });
-                       }
-                       return same;
-               });
-               return same;
-       },
-       _space: function() {
-               var used = [],
-                       inst = this;
-               each( spaces, function( spaceName, space ) {
-                       if ( inst[ space.cache ] ) {
-                               used.push( spaceName );
-                       }
-               });
-               return used.pop();
-       },
-       transition: function( other, distance ) {
-               var end = color( other ),
-                       spaceName = end._space(),
-                       space = spaces[ spaceName ],
-                       startColor = this.alpha() === 0 ? color( "transparent" ) : this,
-                       start = startColor[ space.cache ] || space.to( startColor._rgba ),
-                       result = start.slice();
-
-               end = end[ space.cache ];
-               each( space.props, function( key, prop ) {
-                       var index = prop.idx,
-                               startValue = start[ index ],
-                               endValue = end[ index ],
-                               type = propTypes[ prop.type ] || {};
-
-                       // if null, don't override start value
-                       if ( endValue === null ) {
-                               return;
-                       }
-                       // if null - use end
-                       if ( startValue === null ) {
-                               result[ index ] = endValue;
-                       } else {
-                               if ( type.mod ) {
-                                       if ( endValue - startValue > type.mod / 2 ) {
-                                               startValue += type.mod;
-                                       } else if ( startValue - endValue > type.mod / 2 ) {
-                                               startValue -= type.mod;
-                                       }
-                               }
-                               result[ index ] = clamp( ( endValue - startValue ) * distance + startValue, prop );
-                       }
-               });
-               return this[ spaceName ]( result );
-       },
-       blend: function( opaque ) {
-               // if we are already opaque - return ourself
-               if ( this._rgba[ 3 ] === 1 ) {
-                       return this;
-               }
-
-               var rgb = this._rgba.slice(),
-                       a = rgb.pop(),
-                       blend = color( opaque )._rgba;
-
-               return color( jQuery.map( rgb, function( v, i ) {
-                       return ( 1 - a ) * blend[ i ] + a * v;
-               }));
-       },
-       toRgbaString: function() {
-               var prefix = "rgba(",
-                       rgba = jQuery.map( this._rgba, function( v, i ) {
-                               return v == null ? ( i > 2 ? 1 : 0 ) : v;
-                       });
-
-               if ( rgba[ 3 ] === 1 ) {
-                       rgba.pop();
-                       prefix = "rgb(";
-               }
-
-               return prefix + rgba.join() + ")";
-       },
-       toHslaString: function() {
-               var prefix = "hsla(",
-                       hsla = jQuery.map( this.hsla(), function( v, i ) {
-                               if ( v == null ) {
-                                       v = i > 2 ? 1 : 0;
-                               }
-
-                               // catch 1 and 2
-                               if ( i && i < 3 ) {
-                                       v = Math.round( v * 100 ) + "%";
-                               }
-                               return v;
-                       });
-
-               if ( hsla[ 3 ] === 1 ) {
-                       hsla.pop();
-                       prefix = "hsl(";
-               }
-               return prefix + hsla.join() + ")";
-       },
-       toHexString: function( includeAlpha ) {
-               var rgba = this._rgba.slice(),
-                       alpha = rgba.pop();
-
-               if ( includeAlpha ) {
-                       rgba.push( ~~( alpha * 255 ) );
-               }
-
-               return "#" + jQuery.map( rgba, function( v ) {
-
-                       // default to 0 when nulls exist
-                       v = ( v || 0 ).toString( 16 );
-                       return v.length === 1 ? "0" + v : v;
-               }).join("");
-       },
-       toString: function() {
-               return this._rgba[ 3 ] === 0 ? "transparent" : this.toRgbaString();
-       }
-});
-color.fn.parse.prototype = color.fn;
-
-// hsla conversions adapted from:
-// https://code.google.com/p/maashaack/source/browse/packages/graphics/trunk/src/graphics/colors/HUE2RGB.as?r=5021
-
-function hue2rgb( p, q, h ) {
-       h = ( h + 1 ) % 1;
-       if ( h * 6 < 1 ) {
-               return p + (q - p) * h * 6;
-       }
-       if ( h * 2 < 1) {
-               return q;
-       }
-       if ( h * 3 < 2 ) {
-               return p + (q - p) * ((2/3) - h) * 6;
-       }
-       return p;
-}
-
-spaces.hsla.to = function ( rgba ) {
-       if ( rgba[ 0 ] == null || rgba[ 1 ] == null || rgba[ 2 ] == null ) {
-               return [ null, null, null, rgba[ 3 ] ];
-       }
-       var r = rgba[ 0 ] / 255,
-               g = rgba[ 1 ] / 255,
-               b = rgba[ 2 ] / 255,
-               a = rgba[ 3 ],
-               max = Math.max( r, g, b ),
-               min = Math.min( r, g, b ),
-               diff = max - min,
-               add = max + min,
-               l = add * 0.5,
-               h, s;
-
-       if ( min === max ) {
-               h = 0;
-       } else if ( r === max ) {
-               h = ( 60 * ( g - b ) / diff ) + 360;
-       } else if ( g === max ) {
-               h = ( 60 * ( b - r ) / diff ) + 120;
-       } else {
-               h = ( 60 * ( r - g ) / diff ) + 240;
-       }
-
-       // chroma (diff) == 0 means greyscale which, by definition, saturation = 0%
-       // otherwise, saturation is based on the ratio of chroma (diff) to lightness (add)
-       if ( diff === 0 ) {
-               s = 0;
-       } else if ( l <= 0.5 ) {
-               s = diff / add;
-       } else {
-               s = diff / ( 2 - add );
-       }
-       return [ Math.round(h) % 360, s, l, a == null ? 1 : a ];
-};
-
-spaces.hsla.from = function ( hsla ) {
-       if ( hsla[ 0 ] == null || hsla[ 1 ] == null || hsla[ 2 ] == null ) {
-               return [ null, null, null, hsla[ 3 ] ];
-       }
-       var h = hsla[ 0 ] / 360,
-               s = hsla[ 1 ],
-               l = hsla[ 2 ],
-               a = hsla[ 3 ],
-               q = l <= 0.5 ? l * ( 1 + s ) : l + s - l * s,
-               p = 2 * l - q;
-
-       return [
-               Math.round( hue2rgb( p, q, h + ( 1 / 3 ) ) * 255 ),
-               Math.round( hue2rgb( p, q, h ) * 255 ),
-               Math.round( hue2rgb( p, q, h - ( 1 / 3 ) ) * 255 ),
-               a
-       ];
-};
-
-
-each( spaces, function( spaceName, space ) {
-       var props = space.props,
-               cache = space.cache,
-               to = space.to,
-               from = space.from;
-
-       // makes rgba() and hsla()
-       color.fn[ spaceName ] = function( value ) {
-
-               // generate a cache for this space if it doesn't exist
-               if ( to && !this[ cache ] ) {
-                       this[ cache ] = to( this._rgba );
-               }
-               if ( value === undefined ) {
-                       return this[ cache ].slice();
-               }
-
-               var ret,
-                       type = jQuery.type( value ),
-                       arr = ( type === "array" || type === "object" ) ? value : arguments,
-                       local = this[ cache ].slice();
-
-               each( props, function( key, prop ) {
-                       var val = arr[ type === "object" ? key : prop.idx ];
-                       if ( val == null ) {
-                               val = local[ prop.idx ];
-                       }
-                       local[ prop.idx ] = clamp( val, prop );
-               });
-
-               if ( from ) {
-                       ret = color( from( local ) );
-                       ret[ cache ] = local;
-                       return ret;
-               } else {
-                       return color( local );
-               }
-       };
-
-       // makes red() green() blue() alpha() hue() saturation() lightness()
-       each( props, function( key, prop ) {
-               // alpha is included in more than one space
-               if ( color.fn[ key ] ) {
-                       return;
-               }
-               color.fn[ key ] = function( value ) {
-                       var vtype = jQuery.type( value ),
-                               fn = ( key === "alpha" ? ( this._hsla ? "hsla" : "rgba" ) : spaceName ),
-                               local = this[ fn ](),
-                               cur = local[ prop.idx ],
-                               match;
-
-                       if ( vtype === "undefined" ) {
-                               return cur;
-                       }
-
-                       if ( vtype === "function" ) {
-                               value = value.call( this, cur );
-                               vtype = jQuery.type( value );
-                       }
-                       if ( value == null && prop.empty ) {
-                               return this;
-                       }
-                       if ( vtype === "string" ) {
-                               match = rplusequals.exec( value );
-                               if ( match ) {
-                                       value = cur + parseFloat( match[ 2 ] ) * ( match[ 1 ] === "+" ? 1 : -1 );
-                               }
-                       }
-                       local[ prop.idx ] = value;
-                       return this[ fn ]( local );
-               };
-       });
-});
-
-// add cssHook and .fx.step function for each named hook.
-// accept a space separated string of properties
-color.hook = function( hook ) {
-       var hooks = hook.split( " " );
-       each( hooks, function( i, hook ) {
-               jQuery.cssHooks[ hook ] = {
-                       set: function( elem, value ) {
-                               var parsed, curElem,
-                                       backgroundColor = "";
-
-                               if ( value !== "transparent" && ( jQuery.type( value ) !== "string" || ( parsed = stringParse( value ) ) ) ) {
-                                       value = color( parsed || value );
-                                       if ( !support.rgba && value._rgba[ 3 ] !== 1 ) {
-                                               curElem = hook === "backgroundColor" ? elem.parentNode : elem;
-                                               while (
-                                                       (backgroundColor === "" || backgroundColor === "transparent") &&
-                                                       curElem && curElem.style
-                                               ) {
-                                                       try {
-                                                               backgroundColor = jQuery.css( curElem, "backgroundColor" );
-                                                               curElem = curElem.parentNode;
-                                                       } catch ( e ) {
-                                                       }
-                                               }
-
-                                               value = value.blend( backgroundColor && backgroundColor !== "transparent" ?
-                                                       backgroundColor :
-                                                       "_default" );
-                                       }
-
-                                       value = value.toRgbaString();
-                               }
-                               try {
-                                       elem.style[ hook ] = value;
-                               } catch( e ) {
-                                       // wrapped to prevent IE from throwing errors on "invalid" values like 'auto' or 'inherit'
-                               }
-                       }
-               };
-               jQuery.fx.step[ hook ] = function( fx ) {
-                       if ( !fx.colorInit ) {
-                               fx.start = color( fx.elem, hook );
-                               fx.end = color( fx.end );
-                               fx.colorInit = true;
-                       }
-                       jQuery.cssHooks[ hook ].set( fx.elem, fx.start.transition( fx.end, fx.pos ) );
-               };
-       });
-
-};
-
-color.hook( stepHooks );
-
-jQuery.cssHooks.borderColor = {
-       expand: function( value ) {
-               var expanded = {};
-
-               each( [ "Top", "Right", "Bottom", "Left" ], function( i, part ) {
-                       expanded[ "border" + part + "Color" ] = value;
-               });
-               return expanded;
-       }
-};
-
-// Basic color names only.
-// Usage of any of the other color names requires adding yourself or including
-// jquery.color.svg-names.js.
-colors = jQuery.Color.names = {
-       // 4.1. Basic color keywords
-       aqua: "#00ffff",
-       black: "#000000",
-       blue: "#0000ff",
-       fuchsia: "#ff00ff",
-       gray: "#808080",
-       green: "#008000",
-       lime: "#00ff00",
-       maroon: "#800000",
-       navy: "#000080",
-       olive: "#808000",
-       purple: "#800080",
-       red: "#ff0000",
-       silver: "#c0c0c0",
-       teal: "#008080",
-       white: "#ffffff",
-       yellow: "#ffff00",
-
-       // 4.2.3. "transparent" color keyword
-       transparent: [ null, null, null, 0 ],
-
-       _default: "#ffffff"
-};
-
-})( jQuery );
-
-
-/******************************************************************************/
-/****************************** CLASS ANIMATIONS ******************************/
-/******************************************************************************/
-(function() {
-
-var classAnimationActions = [ "add", "remove", "toggle" ],
-       shorthandStyles = {
-               border: 1,
-               borderBottom: 1,
-               borderColor: 1,
-               borderLeft: 1,
-               borderRight: 1,
-               borderTop: 1,
-               borderWidth: 1,
-               margin: 1,
-               padding: 1
-       };
-
-$.each([ "borderLeftStyle", "borderRightStyle", "borderBottomStyle", "borderTopStyle" ], function( _, prop ) {
-       $.fx.step[ prop ] = function( fx ) {
-               if ( fx.end !== "none" && !fx.setAttr || fx.pos === 1 && !fx.setAttr ) {
-                       jQuery.style( fx.elem, prop, fx.end );
-                       fx.setAttr = true;
-               }
-       };
-});
-
-function getElementStyles( elem ) {
-       var key, len,
-               style = elem.ownerDocument.defaultView ?
-                       elem.ownerDocument.defaultView.getComputedStyle( elem, null ) :
-                       elem.currentStyle,
-               styles = {};
-
-       if ( style && style.length && style[ 0 ] && style[ style[ 0 ] ] ) {
-               len = style.length;
-               while ( len-- ) {
-                       key = style[ len ];
-                       if ( typeof style[ key ] === "string" ) {
-                               styles[ $.camelCase( key ) ] = style[ key ];
-                       }
-               }
-       // support: Opera, IE <9
-       } else {
-               for ( key in style ) {
-                       if ( typeof style[ key ] === "string" ) {
-                               styles[ key ] = style[ key ];
-                       }
-               }
-       }
-
-       return styles;
-}
-
-
-function styleDifference( oldStyle, newStyle ) {
-       var diff = {},
-               name, value;
-
-       for ( name in newStyle ) {
-               value = newStyle[ name ];
-               if ( oldStyle[ name ] !== value ) {
-                       if ( !shorthandStyles[ name ] ) {
-                               if ( $.fx.step[ name ] || !isNaN( parseFloat( value ) ) ) {
-                                       diff[ name ] = value;
-                               }
-                       }
-               }
-       }
-
-       return diff;
-}
-
-// support: jQuery <1.8
-if ( !$.fn.addBack ) {
-       $.fn.addBack = function( selector ) {
-               return this.add( selector == null ?
-                       this.prevObject : this.prevObject.filter( selector )
-               );
-       };
-}
-
-$.effects.animateClass = function( value, duration, easing, callback ) {
-       var o = $.speed( duration, easing, callback );
-
-       return this.queue( function() {
-               var animated = $( this ),
-                       baseClass = animated.attr( "class" ) || "",
-                       applyClassChange,
-                       allAnimations = o.children ? animated.find( "*" ).addBack() : animated;
-
-               // map the animated objects to store the original styles.
-               allAnimations = allAnimations.map(function() {
-                       var el = $( this );
-                       return {
-                               el: el,
-                               start: getElementStyles( this )
-                       };
-               });
-
-               // apply class change
-               applyClassChange = function() {
-                       $.each( classAnimationActions, function(i, action) {
-                               if ( value[ action ] ) {
-                                       animated[ action + "Class" ]( value[ action ] );
-                               }
-                       });
-               };
-               applyClassChange();
-
-               // map all animated objects again - calculate new styles and diff
-               allAnimations = allAnimations.map(function() {
-                       this.end = getElementStyles( this.el[ 0 ] );
-                       this.diff = styleDifference( this.start, this.end );
-                       return this;
-               });
-
-               // apply original class
-               animated.attr( "class", baseClass );
-
-               // map all animated objects again - this time collecting a promise
-               allAnimations = allAnimations.map(function() {
-                       var styleInfo = this,
-                               dfd = $.Deferred(),
-                               opts = $.extend({}, o, {
-                                       queue: false,
-                                       complete: function() {
-                                               dfd.resolve( styleInfo );
-                                       }
-                               });
-
-                       this.el.animate( this.diff, opts );
-                       return dfd.promise();
-               });
-
-               // once all animations have completed:
-               $.when.apply( $, allAnimations.get() ).done(function() {
-
-                       // set the final class
-                       applyClassChange();
-
-                       // for each animated element,
-                       // clear all css properties that were animated
-                       $.each( arguments, function() {
-                               var el = this.el;
-                               $.each( this.diff, function(key) {
-                                       el.css( key, "" );
-                               });
-                       });
-
-                       // this is guarnteed to be there if you use jQuery.speed()
-                       // it also handles dequeuing the next anim...
-                       o.complete.call( animated[ 0 ] );
-               });
-       });
-};
-
-$.fn.extend({
-       addClass: (function( orig ) {
-               return function( classNames, speed, easing, callback ) {
-                       return speed ?
-                               $.effects.animateClass.call( this,
-                                       { add: classNames }, speed, easing, callback ) :
-                               orig.apply( this, arguments );
-               };
-       })( $.fn.addClass ),
-
-       removeClass: (function( orig ) {
-               return function( classNames, speed, easing, callback ) {
-                       return arguments.length > 1 ?
-                               $.effects.animateClass.call( this,
-                                       { remove: classNames }, speed, easing, callback ) :
-                               orig.apply( this, arguments );
-               };
-       })( $.fn.removeClass ),
-
-       toggleClass: (function( orig ) {
-               return function( classNames, force, speed, easing, callback ) {
-                       if ( typeof force === "boolean" || force === undefined ) {
-                               if ( !speed ) {
-                                       // without speed parameter
-                                       return orig.apply( this, arguments );
-                               } else {
-                                       return $.effects.animateClass.call( this,
-                                               (force ? { add: classNames } : { remove: classNames }),
-                                               speed, easing, callback );
-                               }
-                       } else {
-                               // without force parameter
-                               return $.effects.animateClass.call( this,
-                                       { toggle: classNames }, force, speed, easing );
-                       }
-               };
-       })( $.fn.toggleClass ),
-
-       switchClass: function( remove, add, speed, easing, callback) {
-               return $.effects.animateClass.call( this, {
-                       add: add,
-                       remove: remove
-               }, speed, easing, callback );
-       }
-});
-
-})();
-
-/******************************************************************************/
-/*********************************** EFFECTS **********************************/
-/******************************************************************************/
-
-(function() {
-
-$.extend( $.effects, {
-       version: "1.10.4",
-
-       // Saves a set of properties in a data storage
-       save: function( element, set ) {
-               for( var i=0; i < set.length; i++ ) {
-                       if ( set[ i ] !== null ) {
-                               element.data( dataSpace + set[ i ], element[ 0 ].style[ set[ i ] ] );
-                       }
-               }
-       },
-
-       // Restores a set of previously saved properties from a data storage
-       restore: function( element, set ) {
-               var val, i;
-               for( i=0; i < set.length; i++ ) {
-                       if ( set[ i ] !== null ) {
-                               val = element.data( dataSpace + set[ i ] );
-                               // support: jQuery 1.6.2
-                               // http://bugs.jquery.com/ticket/9917
-                               // jQuery 1.6.2 incorrectly returns undefined for any falsy value.
-                               // We can't differentiate between "" and 0 here, so we just assume
-                               // empty string since it's likely to be a more common value...
-                               if ( val === undefined ) {
-                                       val = "";
-                               }
-                               element.css( set[ i ], val );
-                       }
-               }
-       },
-
-       setMode: function( el, mode ) {
-               if (mode === "toggle") {
-                       mode = el.is( ":hidden" ) ? "show" : "hide";
-               }
-               return mode;
-       },
-
-       // Translates a [top,left] array into a baseline value
-       // this should be a little more flexible in the future to handle a string & hash
-       getBaseline: function( origin, original ) {
-               var y, x;
-               switch ( origin[ 0 ] ) {
-                       case "top": y = 0; break;
-                       case "middle": y = 0.5; break;
-                       case "bottom": y = 1; break;
-                       default: y = origin[ 0 ] / original.height;
-               }
-               switch ( origin[ 1 ] ) {
-                       case "left": x = 0; break;
-                       case "center": x = 0.5; break;
-                       case "right": x = 1; break;
-                       default: x = origin[ 1 ] / original.width;
-               }
-               return {
-                       x: x,
-                       y: y
-               };
-       },
-
-       // Wraps the element around a wrapper that copies position properties
-       createWrapper: function( element ) {
-
-               // if the element is already wrapped, return it
-               if ( element.parent().is( ".ui-effects-wrapper" )) {
-                       return element.parent();
-               }
-
-               // wrap the element
-               var props = {
-                               width: element.outerWidth(true),
-                               height: element.outerHeight(true),
-                               "float": element.css( "float" )
-                       },
-                       wrapper = $( "<div></div>" )
-                               .addClass( "ui-effects-wrapper" )
-                               .css({
-                                       fontSize: "100%",
-                                       background: "transparent",
-                                       border: "none",
-                                       margin: 0,
-                                       padding: 0
-                               }),
-                       // Store the size in case width/height are defined in % - Fixes #5245
-                       size = {
-                               width: element.width(),
-                               height: element.height()
-                       },
-                       active = document.activeElement;
-
-               // support: Firefox
-               // Firefox incorrectly exposes anonymous content
-               // https://bugzilla.mozilla.org/show_bug.cgi?id=561664
-               try {
-                       active.id;
-               } catch( e ) {
-                       active = document.body;
-               }
-
-               element.wrap( wrapper );
-
-               // Fixes #7595 - Elements lose focus when wrapped.
-               if ( element[ 0 ] === active || $.contains( element[ 0 ], active ) ) {
-                       $( active ).focus();
-               }
-
-               wrapper = element.parent(); //Hotfix for jQuery 1.4 since some change in wrap() seems to actually lose the reference to the wrapped element
-
-               // transfer positioning properties to the wrapper
-               if ( element.css( "position" ) === "static" ) {
-                       wrapper.css({ position: "relative" });
-                       element.css({ position: "relative" });
-               } else {
-                       $.extend( props, {
-                               position: element.css( "position" ),
-                               zIndex: element.css( "z-index" )
-                       });
-                       $.each([ "top", "left", "bottom", "right" ], function(i, pos) {
-                               props[ pos ] = element.css( pos );
-                               if ( isNaN( parseInt( props[ pos ], 10 ) ) ) {
-                                       props[ pos ] = "auto";
-                               }
-                       });
-                       element.css({
-                               position: "relative",
-                               top: 0,
-                               left: 0,
-                               right: "auto",
-                               bottom: "auto"
-                       });
-               }
-               element.css(size);
-
-               return wrapper.css( props ).show();
-       },
-
-       removeWrapper: function( element ) {
-               var active = document.activeElement;
-
-               if ( element.parent().is( ".ui-effects-wrapper" ) ) {
-                       element.parent().replaceWith( element );
-
-                       // Fixes #7595 - Elements lose focus when wrapped.
-                       if ( element[ 0 ] === active || $.contains( element[ 0 ], active ) ) {
-                               $( active ).focus();
-                       }
-               }
-
-
-               return element;
-       },
-
-       setTransition: function( element, list, factor, value ) {
-               value = value || {};
-               $.each( list, function( i, x ) {
-                       var unit = element.cssUnit( x );
-                       if ( unit[ 0 ] > 0 ) {
-                               value[ x ] = unit[ 0 ] * factor + unit[ 1 ];
-                       }
-               });
-               return value;
-       }
-});
-
-// return an effect options object for the given parameters:
-function _normalizeArguments( effect, options, speed, callback ) {
-
-       // allow passing all options as the first parameter
-       if ( $.isPlainObject( effect ) ) {
-               options = effect;
-               effect = effect.effect;
-       }
-
-       // convert to an object
-       effect = { effect: effect };
-
-       // catch (effect, null, ...)
-       if ( options == null ) {
-               options = {};
-       }
-
-       // catch (effect, callback)
-       if ( $.isFunction( options ) ) {
-               callback = options;
-               speed = null;
-               options = {};
-       }
-
-       // catch (effect, speed, ?)
-       if ( typeof options === "number" || $.fx.speeds[ options ] ) {
-               callback = speed;
-               speed = options;
-               options = {};
-       }
-
-       // catch (effect, options, callback)
-       if ( $.isFunction( speed ) ) {
-               callback = speed;
-               speed = null;
-       }
-
-       // add options to effect
-       if ( options ) {
-               $.extend( effect, options );
-       }
-
-       speed = speed || options.duration;
-       effect.duration = $.fx.off ? 0 :
-               typeof speed === "number" ? speed :
-               speed in $.fx.speeds ? $.fx.speeds[ speed ] :
-               $.fx.speeds._default;
-
-       effect.complete = callback || options.complete;
-
-       return effect;
-}
-
-function standardAnimationOption( option ) {
-       // Valid standard speeds (nothing, number, named speed)
-       if ( !option || typeof option === "number" || $.fx.speeds[ option ] ) {
-               return true;
-       }
-
-       // Invalid strings - treat as "normal" speed
-       if ( typeof option === "string" && !$.effects.effect[ option ] ) {
-               return true;
-       }
-
-       // Complete callback
-       if ( $.isFunction( option ) ) {
-               return true;
-       }
-
-       // Options hash (but not naming an effect)
-       if ( typeof option === "object" && !option.effect ) {
-               return true;
-       }
-
-       // Didn't match any standard API
-       return false;
-}
-
-$.fn.extend({
-       effect: function( /* effect, options, speed, callback */ ) {
-               var args = _normalizeArguments.apply( this, arguments ),
-                       mode = args.mode,
-                       queue = args.queue,
-                       effectMethod = $.effects.effect[ args.effect ];
-
-               if ( $.fx.off || !effectMethod ) {
-                       // delegate to the original method (e.g., .show()) if possible
-                       if ( mode ) {
-                               return this[ mode ]( args.duration, args.complete );
-                       } else {
-                               return this.each( function() {
-                                       if ( args.complete ) {
-                                               args.complete.call( this );
-                                       }
-                               });
-                       }
-               }
-
-               function run( next ) {
-                       var elem = $( this ),
-                               complete = args.complete,
-                               mode = args.mode;
-
-                       function done() {
-                               if ( $.isFunction( complete ) ) {
-                                       complete.call( elem[0] );
-                               }
-                               if ( $.isFunction( next ) ) {
-                                       next();
-                               }
-                       }
-
-                       // If the element already has the correct final state, delegate to
-                       // the core methods so the internal tracking of "olddisplay" works.
-                       if ( elem.is( ":hidden" ) ? mode === "hide" : mode === "show" ) {
-                               elem[ mode ]();
-                               done();
-                       } else {
-                               effectMethod.call( elem[0], args, done );
-                       }
-               }
-
-               return queue === false ? this.each( run ) : this.queue( queue || "fx", run );
-       },
-
-       show: (function( orig ) {
-               return function( option ) {
-                       if ( standardAnimationOption( option ) ) {
-                               return orig.apply( this, arguments );
-                       } else {
-                               var args = _normalizeArguments.apply( this, arguments );
-                               args.mode = "show";
-                               return this.effect.call( this, args );
-                       }
-               };
-       })( $.fn.show ),
-
-       hide: (function( orig ) {
-               return function( option ) {
-                       if ( standardAnimationOption( option ) ) {
-                               return orig.apply( this, arguments );
-                       } else {
-                               var args = _normalizeArguments.apply( this, arguments );
-                               args.mode = "hide";
-                               return this.effect.call( this, args );
-                       }
-               };
-       })( $.fn.hide ),
-
-       toggle: (function( orig ) {
-               return function( option ) {
-                       if ( standardAnimationOption( option ) || typeof option === "boolean" ) {
-                               return orig.apply( this, arguments );
-                       } else {
-                               var args = _normalizeArguments.apply( this, arguments );
-                               args.mode = "toggle";
-                               return this.effect.call( this, args );
-                       }
-               };
-       })( $.fn.toggle ),
-
-       // helper functions
-       cssUnit: function(key) {
-               var style = this.css( key ),
-                       val = [];
-
-               $.each( [ "em", "px", "%", "pt" ], function( i, unit ) {
-                       if ( style.indexOf( unit ) > 0 ) {
-                               val = [ parseFloat( style ), unit ];
-                       }
-               });
-               return val;
-       }
-});
-
-})();
-
-/******************************************************************************/
-/*********************************** EASING ***********************************/
-/******************************************************************************/
-
-(function() {
-
-// based on easing equations from Robert Penner (http://www.robertpenner.com/easing)
-
-var baseEasings = {};
-
-$.each( [ "Quad", "Cubic", "Quart", "Quint", "Expo" ], function( i, name ) {
-       baseEasings[ name ] = function( p ) {
-               return Math.pow( p, i + 2 );
-       };
-});
-
-$.extend( baseEasings, {
-       Sine: function ( p ) {
-               return 1 - Math.cos( p * Math.PI / 2 );
-       },
-       Circ: function ( p ) {
-               return 1 - Math.sqrt( 1 - p * p );
-       },
-       Elastic: function( p ) {
-               return p === 0 || p === 1 ? p :
-                       -Math.pow( 2, 8 * (p - 1) ) * Math.sin( ( (p - 1) * 80 - 7.5 ) * Math.PI / 15 );
-       },
-       Back: function( p ) {
-               return p * p * ( 3 * p - 2 );
-       },
-       Bounce: function ( p ) {
-               var pow2,
-                       bounce = 4;
-
-               while ( p < ( ( pow2 = Math.pow( 2, --bounce ) ) - 1 ) / 11 ) {}
-               return 1 / Math.pow( 4, 3 - bounce ) - 7.5625 * Math.pow( ( pow2 * 3 - 2 ) / 22 - p, 2 );
-       }
-});
-
-$.each( baseEasings, function( name, easeIn ) {
-       $.easing[ "easeIn" + name ] = easeIn;
-       $.easing[ "easeOut" + name ] = function( p ) {
-               return 1 - easeIn( 1 - p );
-       };
-       $.easing[ "easeInOut" + name ] = function( p ) {
-               return p < 0.5 ?
-                       easeIn( p * 2 ) / 2 :
-                       1 - easeIn( p * -2 + 2 ) / 2;
-       };
-});
-
-})();
-
-})(jQuery);
-(function( $, undefined ) {
-
-var rvertical = /up|down|vertical/,
-       rpositivemotion = /up|left|vertical|horizontal/;
-
-$.effects.effect.blind = function( o, done ) {
-       // Create element
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "height", "width" ],
-               mode = $.effects.setMode( el, o.mode || "hide" ),
-               direction = o.direction || "up",
-               vertical = rvertical.test( direction ),
-               ref = vertical ? "height" : "width",
-               ref2 = vertical ? "top" : "left",
-               motion = rpositivemotion.test( direction ),
-               animation = {},
-               show = mode === "show",
-               wrapper, distance, margin;
-
-       // if already wrapped, the wrapper's properties are my property. #6245
-       if ( el.parent().is( ".ui-effects-wrapper" ) ) {
-               $.effects.save( el.parent(), props );
-       } else {
-               $.effects.save( el, props );
-       }
-       el.show();
-       wrapper = $.effects.createWrapper( el ).css({
-               overflow: "hidden"
-       });
-
-       distance = wrapper[ ref ]();
-       margin = parseFloat( wrapper.css( ref2 ) ) || 0;
-
-       animation[ ref ] = show ? distance : 0;
-       if ( !motion ) {
-               el
-                       .css( vertical ? "bottom" : "right", 0 )
-                       .css( vertical ? "top" : "left", "auto" )
-                       .css({ position: "absolute" });
-
-               animation[ ref2 ] = show ? margin : distance + margin;
-       }
-
-       // start at 0 if we are showing
-       if ( show ) {
-               wrapper.css( ref, 0 );
-               if ( ! motion ) {
-                       wrapper.css( ref2, margin + distance );
-               }
-       }
-
-       // Animate
-       wrapper.animate( animation, {
-               duration: o.duration,
-               easing: o.easing,
-               queue: false,
-               complete: function() {
-                       if ( mode === "hide" ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               }
-       });
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.bounce = function( o, done ) {
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "height", "width" ],
-
-               // defaults:
-               mode = $.effects.setMode( el, o.mode || "effect" ),
-               hide = mode === "hide",
-               show = mode === "show",
-               direction = o.direction || "up",
-               distance = o.distance,
-               times = o.times || 5,
-
-               // number of internal animations
-               anims = times * 2 + ( show || hide ? 1 : 0 ),
-               speed = o.duration / anims,
-               easing = o.easing,
-
-               // utility:
-               ref = ( direction === "up" || direction === "down" ) ? "top" : "left",
-               motion = ( direction === "up" || direction === "left" ),
-               i,
-               upAnim,
-               downAnim,
-
-               // we will need to re-assemble the queue to stack our animations in place
-               queue = el.queue(),
-               queuelen = queue.length;
-
-       // Avoid touching opacity to prevent clearType and PNG issues in IE
-       if ( show || hide ) {
-               props.push( "opacity" );
-       }
-
-       $.effects.save( el, props );
-       el.show();
-       $.effects.createWrapper( el ); // Create Wrapper
-
-       // default distance for the BIGGEST bounce is the outer Distance / 3
-       if ( !distance ) {
-               distance = el[ ref === "top" ? "outerHeight" : "outerWidth" ]() / 3;
-       }
-
-       if ( show ) {
-               downAnim = { opacity: 1 };
-               downAnim[ ref ] = 0;
-
-               // if we are showing, force opacity 0 and set the initial position
-               // then do the "first" animation
-               el.css( "opacity", 0 )
-                       .css( ref, motion ? -distance * 2 : distance * 2 )
-                       .animate( downAnim, speed, easing );
-       }
-
-       // start at the smallest distance if we are hiding
-       if ( hide ) {
-               distance = distance / Math.pow( 2, times - 1 );
-       }
-
-       downAnim = {};
-       downAnim[ ref ] = 0;
-       // Bounces up/down/left/right then back to 0 -- times * 2 animations happen here
-       for ( i = 0; i < times; i++ ) {
-               upAnim = {};
-               upAnim[ ref ] = ( motion ? "-=" : "+=" ) + distance;
-
-               el.animate( upAnim, speed, easing )
-                       .animate( downAnim, speed, easing );
-
-               distance = hide ? distance * 2 : distance / 2;
-       }
-
-       // Last Bounce when Hiding
-       if ( hide ) {
-               upAnim = { opacity: 0 };
-               upAnim[ ref ] = ( motion ? "-=" : "+=" ) + distance;
-
-               el.animate( upAnim, speed, easing );
-       }
-
-       el.queue(function() {
-               if ( hide ) {
-                       el.hide();
-               }
-               $.effects.restore( el, props );
-               $.effects.removeWrapper( el );
-               done();
-       });
-
-       // inject all the animations we just queued to be first in line (after "inprogress")
-       if ( queuelen > 1) {
-               queue.splice.apply( queue,
-                       [ 1, 0 ].concat( queue.splice( queuelen, anims + 1 ) ) );
-       }
-       el.dequeue();
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.clip = function( o, done ) {
-       // Create element
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "height", "width" ],
-               mode = $.effects.setMode( el, o.mode || "hide" ),
-               show = mode === "show",
-               direction = o.direction || "vertical",
-               vert = direction === "vertical",
-               size = vert ? "height" : "width",
-               position = vert ? "top" : "left",
-               animation = {},
-               wrapper, animate, distance;
-
-       // Save & Show
-       $.effects.save( el, props );
-       el.show();
-
-       // Create Wrapper
-       wrapper = $.effects.createWrapper( el ).css({
-               overflow: "hidden"
-       });
-       animate = ( el[0].tagName === "IMG" ) ? wrapper : el;
-       distance = animate[ size ]();
-
-       // Shift
-       if ( show ) {
-               animate.css( size, 0 );
-               animate.css( position, distance / 2 );
-       }
-
-       // Create Animation Object:
-       animation[ size ] = show ? distance : 0;
-       animation[ position ] = show ? 0 : distance / 2;
-
-       // Animate
-       animate.animate( animation, {
-               queue: false,
-               duration: o.duration,
-               easing: o.easing,
-               complete: function() {
-                       if ( !show ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               }
-       });
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.drop = function( o, done ) {
-
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "opacity", "height", "width" ],
-               mode = $.effects.setMode( el, o.mode || "hide" ),
-               show = mode === "show",
-               direction = o.direction || "left",
-               ref = ( direction === "up" || direction === "down" ) ? "top" : "left",
-               motion = ( direction === "up" || direction === "left" ) ? "pos" : "neg",
-               animation = {
-                       opacity: show ? 1 : 0
-               },
-               distance;
-
-       // Adjust
-       $.effects.save( el, props );
-       el.show();
-       $.effects.createWrapper( el );
-
-       distance = o.distance || el[ ref === "top" ? "outerHeight": "outerWidth" ]( true ) / 2;
-
-       if ( show ) {
-               el
-                       .css( "opacity", 0 )
-                       .css( ref, motion === "pos" ? -distance : distance );
-       }
-
-       // Animation
-       animation[ ref ] = ( show ?
-               ( motion === "pos" ? "+=" : "-=" ) :
-               ( motion === "pos" ? "-=" : "+=" ) ) +
-               distance;
-
-       // Animate
-       el.animate( animation, {
-               queue: false,
-               duration: o.duration,
-               easing: o.easing,
-               complete: function() {
-                       if ( mode === "hide" ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               }
-       });
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.explode = function( o, done ) {
-
-       var rows = o.pieces ? Math.round( Math.sqrt( o.pieces ) ) : 3,
-               cells = rows,
-               el = $( this ),
-               mode = $.effects.setMode( el, o.mode || "hide" ),
-               show = mode === "show",
-
-               // show and then visibility:hidden the element before calculating offset
-               offset = el.show().css( "visibility", "hidden" ).offset(),
-
-               // width and height of a piece
-               width = Math.ceil( el.outerWidth() / cells ),
-               height = Math.ceil( el.outerHeight() / rows ),
-               pieces = [],
-
-               // loop
-               i, j, left, top, mx, my;
-
-       // children animate complete:
-       function childComplete() {
-               pieces.push( this );
-               if ( pieces.length === rows * cells ) {
-                       animComplete();
-               }
-       }
-
-       // clone the element for each row and cell.
-       for( i = 0; i < rows ; i++ ) { // ===>
-               top = offset.top + i * height;
-               my = i - ( rows - 1 ) / 2 ;
-
-               for( j = 0; j < cells ; j++ ) { // |||
-                       left = offset.left + j * width;
-                       mx = j - ( cells - 1 ) / 2 ;
-
-                       // Create a clone of the now hidden main element that will be absolute positioned
-                       // within a wrapper div off the -left and -top equal to size of our pieces
-                       el
-                               .clone()
-                               .appendTo( "body" )
-                               .wrap( "<div></div>" )
-                               .css({
-                                       position: "absolute",
-                                       visibility: "visible",
-                                       left: -j * width,
-                                       top: -i * height
-                               })
-
-                       // select the wrapper - make it overflow: hidden and absolute positioned based on
-                       // where the original was located +left and +top equal to the size of pieces
-                               .parent()
-                               .addClass( "ui-effects-explode" )
-                               .css({
-                                       position: "absolute",
-                                       overflow: "hidden",
-                                       width: width,
-                                       height: height,
-                                       left: left + ( show ? mx * width : 0 ),
-                                       top: top + ( show ? my * height : 0 ),
-                                       opacity: show ? 0 : 1
-                               }).animate({
-                                       left: left + ( show ? 0 : mx * width ),
-                                       top: top + ( show ? 0 : my * height ),
-                                       opacity: show ? 1 : 0
-                               }, o.duration || 500, o.easing, childComplete );
-               }
-       }
-
-       function animComplete() {
-               el.css({
-                       visibility: "visible"
-               });
-               $( pieces ).remove();
-               if ( !show ) {
-                       el.hide();
-               }
-               done();
-       }
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.fade = function( o, done ) {
-       var el = $( this ),
-               mode = $.effects.setMode( el, o.mode || "toggle" );
-
-       el.animate({
-               opacity: mode
-       }, {
-               queue: false,
-               duration: o.duration,
-               easing: o.easing,
-               complete: done
-       });
-};
-
-})( jQuery );
-(function( $, undefined ) {
-
-$.effects.effect.fold = function( o, done ) {
-
-       // Create element
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "height", "width" ],
-               mode = $.effects.setMode( el, o.mode || "hide" ),
-               show = mode === "show",
-               hide = mode === "hide",
-               size = o.size || 15,
-               percent = /([0-9]+)%/.exec( size ),
-               horizFirst = !!o.horizFirst,
-               widthFirst = show !== horizFirst,
-               ref = widthFirst ? [ "width", "height" ] : [ "height", "width" ],
-               duration = o.duration / 2,
-               wrapper, distance,
-               animation1 = {},
-               animation2 = {};
-
-       $.effects.save( el, props );
-       el.show();
-
-       // Create Wrapper
-       wrapper = $.effects.createWrapper( el ).css({
-               overflow: "hidden"
-       });
-       distance = widthFirst ?
-               [ wrapper.width(), wrapper.height() ] :
-               [ wrapper.height(), wrapper.width() ];
-
-       if ( percent ) {
-               size = parseInt( percent[ 1 ], 10 ) / 100 * distance[ hide ? 0 : 1 ];
-       }
-       if ( show ) {
-               wrapper.css( horizFirst ? {
-                       height: 0,
-                       width: size
-               } : {
-                       height: size,
-                       width: 0
-               });
-       }
-
-       // Animation
-       animation1[ ref[ 0 ] ] = show ? distance[ 0 ] : size;
-       animation2[ ref[ 1 ] ] = show ? distance[ 1 ] : 0;
-
-       // Animate
-       wrapper
-               .animate( animation1, duration, o.easing )
-               .animate( animation2, duration, o.easing, function() {
-                       if ( hide ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               });
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.highlight = function( o, done ) {
-       var elem = $( this ),
-               props = [ "backgroundImage", "backgroundColor", "opacity" ],
-               mode = $.effects.setMode( elem, o.mode || "show" ),
-               animation = {
-                       backgroundColor: elem.css( "backgroundColor" )
-               };
-
-       if (mode === "hide") {
-               animation.opacity = 0;
-       }
-
-       $.effects.save( elem, props );
-
-       elem
-               .show()
-               .css({
-                       backgroundImage: "none",
-                       backgroundColor: o.color || "#ffff99"
-               })
-               .animate( animation, {
-                       queue: false,
-                       duration: o.duration,
-                       easing: o.easing,
-                       complete: function() {
-                               if ( mode === "hide" ) {
-                                       elem.hide();
-                               }
-                               $.effects.restore( elem, props );
-                               done();
-                       }
-               });
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.pulsate = function( o, done ) {
-       var elem = $( this ),
-               mode = $.effects.setMode( elem, o.mode || "show" ),
-               show = mode === "show",
-               hide = mode === "hide",
-               showhide = ( show || mode === "hide" ),
-
-               // showing or hiding leaves of the "last" animation
-               anims = ( ( o.times || 5 ) * 2 ) + ( showhide ? 1 : 0 ),
-               duration = o.duration / anims,
-               animateTo = 0,
-               queue = elem.queue(),
-               queuelen = queue.length,
-               i;
-
-       if ( show || !elem.is(":visible")) {
-               elem.css( "opacity", 0 ).show();
-               animateTo = 1;
-       }
-
-       // anims - 1 opacity "toggles"
-       for ( i = 1; i < anims; i++ ) {
-               elem.animate({
-                       opacity: animateTo
-               }, duration, o.easing );
-               animateTo = 1 - animateTo;
-       }
-
-       elem.animate({
-               opacity: animateTo
-       }, duration, o.easing);
-
-       elem.queue(function() {
-               if ( hide ) {
-                       elem.hide();
-               }
-               done();
-       });
-
-       // We just queued up "anims" animations, we need to put them next in the queue
-       if ( queuelen > 1 ) {
-               queue.splice.apply( queue,
-                       [ 1, 0 ].concat( queue.splice( queuelen, anims + 1 ) ) );
-       }
-       elem.dequeue();
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.puff = function( o, done ) {
-       var elem = $( this ),
-               mode = $.effects.setMode( elem, o.mode || "hide" ),
-               hide = mode === "hide",
-               percent = parseInt( o.percent, 10 ) || 150,
-               factor = percent / 100,
-               original = {
-                       height: elem.height(),
-                       width: elem.width(),
-                       outerHeight: elem.outerHeight(),
-                       outerWidth: elem.outerWidth()
-               };
-
-       $.extend( o, {
-               effect: "scale",
-               queue: false,
-               fade: true,
-               mode: mode,
-               complete: done,
-               percent: hide ? percent : 100,
-               from: hide ?
-                       original :
-                       {
-                               height: original.height * factor,
-                               width: original.width * factor,
-                               outerHeight: original.outerHeight * factor,
-                               outerWidth: original.outerWidth * factor
-                       }
-       });
-
-       elem.effect( o );
-};
-
-$.effects.effect.scale = function( o, done ) {
-
-       // Create element
-       var el = $( this ),
-               options = $.extend( true, {}, o ),
-               mode = $.effects.setMode( el, o.mode || "effect" ),
-               percent = parseInt( o.percent, 10 ) ||
-                       ( parseInt( o.percent, 10 ) === 0 ? 0 : ( mode === "hide" ? 0 : 100 ) ),
-               direction = o.direction || "both",
-               origin = o.origin,
-               original = {
-                       height: el.height(),
-                       width: el.width(),
-                       outerHeight: el.outerHeight(),
-                       outerWidth: el.outerWidth()
-               },
-               factor = {
-                       y: direction !== "horizontal" ? (percent / 100) : 1,
-                       x: direction !== "vertical" ? (percent / 100) : 1
-               };
-
-       // We are going to pass this effect to the size effect:
-       options.effect = "size";
-       options.queue = false;
-       options.complete = done;
-
-       // Set default origin and restore for show/hide
-       if ( mode !== "effect" ) {
-               options.origin = origin || ["middle","center"];
-               options.restore = true;
-       }
-
-       options.from = o.from || ( mode === "show" ? {
-               height: 0,
-               width: 0,
-               outerHeight: 0,
-               outerWidth: 0
-       } : original );
-       options.to = {
-               height: original.height * factor.y,
-               width: original.width * factor.x,
-               outerHeight: original.outerHeight * factor.y,
-               outerWidth: original.outerWidth * factor.x
-       };
-
-       // Fade option to support puff
-       if ( options.fade ) {
-               if ( mode === "show" ) {
-                       options.from.opacity = 0;
-                       options.to.opacity = 1;
-               }
-               if ( mode === "hide" ) {
-                       options.from.opacity = 1;
-                       options.to.opacity = 0;
-               }
-       }
-
-       // Animate
-       el.effect( options );
-
-};
-
-$.effects.effect.size = function( o, done ) {
-
-       // Create element
-       var original, baseline, factor,
-               el = $( this ),
-               props0 = [ "position", "top", "bottom", "left", "right", "width", "height", "overflow", "opacity" ],
-
-               // Always restore
-               props1 = [ "position", "top", "bottom", "left", "right", "overflow", "opacity" ],
-
-               // Copy for children
-               props2 = [ "width", "height", "overflow" ],
-               cProps = [ "fontSize" ],
-               vProps = [ "borderTopWidth", "borderBottomWidth", "paddingTop", "paddingBottom" ],
-               hProps = [ "borderLeftWidth", "borderRightWidth", "paddingLeft", "paddingRight" ],
-
-               // Set options
-               mode = $.effects.setMode( el, o.mode || "effect" ),
-               restore = o.restore || mode !== "effect",
-               scale = o.scale || "both",
-               origin = o.origin || [ "middle", "center" ],
-               position = el.css( "position" ),
-               props = restore ? props0 : props1,
-               zero = {
-                       height: 0,
-                       width: 0,
-                       outerHeight: 0,
-                       outerWidth: 0
-               };
-
-       if ( mode === "show" ) {
-               el.show();
-       }
-       original = {
-               height: el.height(),
-               width: el.width(),
-               outerHeight: el.outerHeight(),
-               outerWidth: el.outerWidth()
-       };
-
-       if ( o.mode === "toggle" && mode === "show" ) {
-               el.from = o.to || zero;
-               el.to = o.from || original;
-       } else {
-               el.from = o.from || ( mode === "show" ? zero : original );
-               el.to = o.to || ( mode === "hide" ? zero : original );
-       }
-
-       // Set scaling factor
-       factor = {
-               from: {
-                       y: el.from.height / original.height,
-                       x: el.from.width / original.width
-               },
-               to: {
-                       y: el.to.height / original.height,
-                       x: el.to.width / original.width
-               }
-       };
-
-       // Scale the css box
-       if ( scale === "box" || scale === "both" ) {
-
-               // Vertical props scaling
-               if ( factor.from.y !== factor.to.y ) {
-                       props = props.concat( vProps );
-                       el.from = $.effects.setTransition( el, vProps, factor.from.y, el.from );
-                       el.to = $.effects.setTransition( el, vProps, factor.to.y, el.to );
-               }
-
-               // Horizontal props scaling
-               if ( factor.from.x !== factor.to.x ) {
-                       props = props.concat( hProps );
-                       el.from = $.effects.setTransition( el, hProps, factor.from.x, el.from );
-                       el.to = $.effects.setTransition( el, hProps, factor.to.x, el.to );
-               }
-       }
-
-       // Scale the content
-       if ( scale === "content" || scale === "both" ) {
-
-               // Vertical props scaling
-               if ( factor.from.y !== factor.to.y ) {
-                       props = props.concat( cProps ).concat( props2 );
-                       el.from = $.effects.setTransition( el, cProps, factor.from.y, el.from );
-                       el.to = $.effects.setTransition( el, cProps, factor.to.y, el.to );
-               }
-       }
-
-       $.effects.save( el, props );
-       el.show();
-       $.effects.createWrapper( el );
-       el.css( "overflow", "hidden" ).css( el.from );
-
-       // Adjust
-       if (origin) { // Calculate baseline shifts
-               baseline = $.effects.getBaseline( origin, original );
-               el.from.top = ( original.outerHeight - el.outerHeight() ) * baseline.y;
-               el.from.left = ( original.outerWidth - el.outerWidth() ) * baseline.x;
-               el.to.top = ( original.outerHeight - el.to.outerHeight ) * baseline.y;
-               el.to.left = ( original.outerWidth - el.to.outerWidth ) * baseline.x;
-       }
-       el.css( el.from ); // set top & left
-
-       // Animate
-       if ( scale === "content" || scale === "both" ) { // Scale the children
-
-               // Add margins/font-size
-               vProps = vProps.concat([ "marginTop", "marginBottom" ]).concat(cProps);
-               hProps = hProps.concat([ "marginLeft", "marginRight" ]);
-               props2 = props0.concat(vProps).concat(hProps);
-
-               el.find( "*[width]" ).each( function(){
-                       var child = $( this ),
-                               c_original = {
-                                       height: child.height(),
-                                       width: child.width(),
-                                       outerHeight: child.outerHeight(),
-                                       outerWidth: child.outerWidth()
-                               };
-                       if (restore) {
-                               $.effects.save(child, props2);
-                       }
-
-                       child.from = {
-                               height: c_original.height * factor.from.y,
-                               width: c_original.width * factor.from.x,
-                               outerHeight: c_original.outerHeight * factor.from.y,
-                               outerWidth: c_original.outerWidth * factor.from.x
-                       };
-                       child.to = {
-                               height: c_original.height * factor.to.y,
-                               width: c_original.width * factor.to.x,
-                               outerHeight: c_original.height * factor.to.y,
-                               outerWidth: c_original.width * factor.to.x
-                       };
-
-                       // Vertical props scaling
-                       if ( factor.from.y !== factor.to.y ) {
-                               child.from = $.effects.setTransition( child, vProps, factor.from.y, child.from );
-                               child.to = $.effects.setTransition( child, vProps, factor.to.y, child.to );
-                       }
-
-                       // Horizontal props scaling
-                       if ( factor.from.x !== factor.to.x ) {
-                               child.from = $.effects.setTransition( child, hProps, factor.from.x, child.from );
-                               child.to = $.effects.setTransition( child, hProps, factor.to.x, child.to );
-                       }
-
-                       // Animate children
-                       child.css( child.from );
-                       child.animate( child.to, o.duration, o.easing, function() {
-
-                               // Restore children
-                               if ( restore ) {
-                                       $.effects.restore( child, props2 );
-                               }
-                       });
-               });
-       }
-
-       // Animate
-       el.animate( el.to, {
-               queue: false,
-               duration: o.duration,
-               easing: o.easing,
-               complete: function() {
-                       if ( el.to.opacity === 0 ) {
-                               el.css( "opacity", el.from.opacity );
-                       }
-                       if( mode === "hide" ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       if ( !restore ) {
-
-                               // we need to calculate our new positioning based on the scaling
-                               if ( position === "static" ) {
-                                       el.css({
-                                               position: "relative",
-                                               top: el.to.top,
-                                               left: el.to.left
-                                       });
-                               } else {
-                                       $.each([ "top", "left" ], function( idx, pos ) {
-                                               el.css( pos, function( _, str ) {
-                                                       var val = parseInt( str, 10 ),
-                                                               toRef = idx ? el.to.left : el.to.top;
-
-                                                       // if original was "auto", recalculate the new value from wrapper
-                                                       if ( str === "auto" ) {
-                                                               return toRef + "px";
-                                                       }
-
-                                                       return val + toRef + "px";
-                                               });
-                                       });
-                               }
-                       }
-
-                       $.effects.removeWrapper( el );
-                       done();
-               }
-       });
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.shake = function( o, done ) {
-
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "height", "width" ],
-               mode = $.effects.setMode( el, o.mode || "effect" ),
-               direction = o.direction || "left",
-               distance = o.distance || 20,
-               times = o.times || 3,
-               anims = times * 2 + 1,
-               speed = Math.round(o.duration/anims),
-               ref = (direction === "up" || direction === "down") ? "top" : "left",
-               positiveMotion = (direction === "up" || direction === "left"),
-               animation = {},
-               animation1 = {},
-               animation2 = {},
-               i,
-
-               // we will need to re-assemble the queue to stack our animations in place
-               queue = el.queue(),
-               queuelen = queue.length;
-
-       $.effects.save( el, props );
-       el.show();
-       $.effects.createWrapper( el );
-
-       // Animation
-       animation[ ref ] = ( positiveMotion ? "-=" : "+=" ) + distance;
-       animation1[ ref ] = ( positiveMotion ? "+=" : "-=" ) + distance * 2;
-       animation2[ ref ] = ( positiveMotion ? "-=" : "+=" ) + distance * 2;
-
-       // Animate
-       el.animate( animation, speed, o.easing );
-
-       // Shakes
-       for ( i = 1; i < times; i++ ) {
-               el.animate( animation1, speed, o.easing ).animate( animation2, speed, o.easing );
-       }
-       el
-               .animate( animation1, speed, o.easing )
-               .animate( animation, speed / 2, o.easing )
-               .queue(function() {
-                       if ( mode === "hide" ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               });
-
-       // inject all the animations we just queued to be first in line (after "inprogress")
-       if ( queuelen > 1) {
-               queue.splice.apply( queue,
-                       [ 1, 0 ].concat( queue.splice( queuelen, anims + 1 ) ) );
-       }
-       el.dequeue();
-
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.slide = function( o, done ) {
-
-       // Create element
-       var el = $( this ),
-               props = [ "position", "top", "bottom", "left", "right", "width", "height" ],
-               mode = $.effects.setMode( el, o.mode || "show" ),
-               show = mode === "show",
-               direction = o.direction || "left",
-               ref = (direction === "up" || direction === "down") ? "top" : "left",
-               positiveMotion = (direction === "up" || direction === "left"),
-               distance,
-               animation = {};
-
-       // Adjust
-       $.effects.save( el, props );
-       el.show();
-       distance = o.distance || el[ ref === "top" ? "outerHeight" : "outerWidth" ]( true );
-
-       $.effects.createWrapper( el ).css({
-               overflow: "hidden"
-       });
-
-       if ( show ) {
-               el.css( ref, positiveMotion ? (isNaN(distance) ? "-" + distance : -distance) : distance );
-       }
-
-       // Animation
-       animation[ ref ] = ( show ?
-               ( positiveMotion ? "+=" : "-=") :
-               ( positiveMotion ? "-=" : "+=")) +
-               distance;
-
-       // Animate
-       el.animate( animation, {
-               queue: false,
-               duration: o.duration,
-               easing: o.easing,
-               complete: function() {
-                       if ( mode === "hide" ) {
-                               el.hide();
-                       }
-                       $.effects.restore( el, props );
-                       $.effects.removeWrapper( el );
-                       done();
-               }
-       });
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.effects.effect.transfer = function( o, done ) {
-       var elem = $( this ),
-               target = $( o.to ),
-               targetFixed = target.css( "position" ) === "fixed",
-               body = $("body"),
-               fixTop = targetFixed ? body.scrollTop() : 0,
-               fixLeft = targetFixed ? body.scrollLeft() : 0,
-               endPosition = target.offset(),
-               animation = {
-                       top: endPosition.top - fixTop ,
-                       left: endPosition.left - fixLeft ,
-                       height: target.innerHeight(),
-                       width: target.innerWidth()
-               },
-               startPosition = elem.offset(),
-               transfer = $( "<div class='ui-effects-transfer'></div>" )
-                       .appendTo( document.body )
-                       .addClass( o.className )
-                       .css({
-                               top: startPosition.top - fixTop ,
-                               left: startPosition.left - fixLeft ,
-                               height: elem.innerHeight(),
-                               width: elem.innerWidth(),
-                               position: targetFixed ? "fixed" : "absolute"
-                       })
-                       .animate( animation, o.duration, o.easing, function() {
-                               transfer.remove();
-                               done();
-                       });
-};
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.widget( "ui.menu", {
-       version: "1.10.4",
-       defaultElement: "<ul>",
-       delay: 300,
-       options: {
-               icons: {
-                       submenu: "ui-icon-carat-1-e"
-               },
-               menus: "ul",
-               position: {
-                       my: "left top",
-                       at: "right top"
-               },
-               role: "menu",
-
-               // callbacks
-               blur: null,
-               focus: null,
-               select: null
-       },
-
-       _create: function() {
-               this.activeMenu = this.element;
-               // flag used to prevent firing of the click handler
-               // as the event bubbles up through nested menus
-               this.mouseHandled = false;
-               this.element
-                       .uniqueId()
-                       .addClass( "ui-menu ui-widget ui-widget-content ui-corner-all" )
-                       .toggleClass( "ui-menu-icons", !!this.element.find( ".ui-icon" ).length )
-                       .attr({
-                               role: this.options.role,
-                               tabIndex: 0
-                       })
-                       // need to catch all clicks on disabled menu
-                       // not possible through _on
-                       .bind( "click" + this.eventNamespace, $.proxy(function( event ) {
-                               if ( this.options.disabled ) {
-                                       event.preventDefault();
-                               }
-                       }, this ));
-
-               if ( this.options.disabled ) {
-                       this.element
-                               .addClass( "ui-state-disabled" )
-                               .attr( "aria-disabled", "true" );
-               }
-
-               this._on({
-                       // Prevent focus from sticking to links inside menu after clicking
-                       // them (focus should always stay on UL during navigation).
-                       "mousedown .ui-menu-item > a": function( event ) {
-                               event.preventDefault();
-                       },
-                       "click .ui-state-disabled > a": function( event ) {
-                               event.preventDefault();
-                       },
-                       "click .ui-menu-item:has(a)": function( event ) {
-                               var target = $( event.target ).closest( ".ui-menu-item" );
-                               if ( !this.mouseHandled && target.not( ".ui-state-disabled" ).length ) {
-                                       this.select( event );
-
-                                       // Only set the mouseHandled flag if the event will bubble, see #9469.
-                                       if ( !event.isPropagationStopped() ) {
-                                               this.mouseHandled = true;
-                                       }
-
-                                       // Open submenu on click
-                                       if ( target.has( ".ui-menu" ).length ) {
-                                               this.expand( event );
-                                       } else if ( !this.element.is( ":focus" ) && $( this.document[ 0 ].activeElement ).closest( ".ui-menu" ).length ) {
-
-                                               // Redirect focus to the menu
-                                               this.element.trigger( "focus", [ true ] );
-
-                                               // If the active item is on the top level, let it stay active.
-                                               // Otherwise, blur the active item since it is no longer visible.
-                                               if ( this.active && this.active.parents( ".ui-menu" ).length === 1 ) {
-                                                       clearTimeout( this.timer );
-                                               }
-                                       }
-                               }
-                       },
-                       "mouseenter .ui-menu-item": function( event ) {
-                               var target = $( event.currentTarget );
-                               // Remove ui-state-active class from siblings of the newly focused menu item
-                               // to avoid a jump caused by adjacent elements both having a class with a border
-                               target.siblings().children( ".ui-state-active" ).removeClass( "ui-state-active" );
-                               this.focus( event, target );
-                       },
-                       mouseleave: "collapseAll",
-                       "mouseleave .ui-menu": "collapseAll",
-                       focus: function( event, keepActiveItem ) {
-                               // If there's already an active item, keep it active
-                               // If not, activate the first item
-                               var item = this.active || this.element.children( ".ui-menu-item" ).eq( 0 );
-
-                               if ( !keepActiveItem ) {
-                                       this.focus( event, item );
-                               }
-                       },
-                       blur: function( event ) {
-                               this._delay(function() {
-                                       if ( !$.contains( this.element[0], this.document[0].activeElement ) ) {
-                                               this.collapseAll( event );
-                                       }
-                               });
-                       },
-                       keydown: "_keydown"
-               });
-
-               this.refresh();
-
-               // Clicks outside of a menu collapse any open menus
-               this._on( this.document, {
-                       click: function( event ) {
-                               if ( !$( event.target ).closest( ".ui-menu" ).length ) {
-                                       this.collapseAll( event );
-                               }
-
-                               // Reset the mouseHandled flag
-                               this.mouseHandled = false;
-                       }
-               });
-       },
-
-       _destroy: function() {
-               // Destroy (sub)menus
-               this.element
-                       .removeAttr( "aria-activedescendant" )
-                       .find( ".ui-menu" ).addBack()
-                               .removeClass( "ui-menu ui-widget ui-widget-content ui-corner-all ui-menu-icons" )
-                               .removeAttr( "role" )
-                               .removeAttr( "tabIndex" )
-                               .removeAttr( "aria-labelledby" )
-                               .removeAttr( "aria-expanded" )
-                               .removeAttr( "aria-hidden" )
-                               .removeAttr( "aria-disabled" )
-                               .removeUniqueId()
-                               .show();
-
-               // Destroy menu items
-               this.element.find( ".ui-menu-item" )
-                       .removeClass( "ui-menu-item" )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-disabled" )
-                       .children( "a" )
-                               .removeUniqueId()
-                               .removeClass( "ui-corner-all ui-state-hover" )
-                               .removeAttr( "tabIndex" )
-                               .removeAttr( "role" )
-                               .removeAttr( "aria-haspopup" )
-                               .children().each( function() {
-                                       var elem = $( this );
-                                       if ( elem.data( "ui-menu-submenu-carat" ) ) {
-                                               elem.remove();
-                                       }
-                               });
-
-               // Destroy menu dividers
-               this.element.find( ".ui-menu-divider" ).removeClass( "ui-menu-divider ui-widget-content" );
-       },
-
-       _keydown: function( event ) {
-               var match, prev, character, skip, regex,
-                       preventDefault = true;
-
-               function escape( value ) {
-                       return value.replace( /[\-\[\]{}()*+?.,\\\^$|#\s]/g, "\\$&" );
-               }
-
-               switch ( event.keyCode ) {
-               case $.ui.keyCode.PAGE_UP:
-                       this.previousPage( event );
-                       break;
-               case $.ui.keyCode.PAGE_DOWN:
-                       this.nextPage( event );
-                       break;
-               case $.ui.keyCode.HOME:
-                       this._move( "first", "first", event );
-                       break;
-               case $.ui.keyCode.END:
-                       this._move( "last", "last", event );
-                       break;
-               case $.ui.keyCode.UP:
-                       this.previous( event );
-                       break;
-               case $.ui.keyCode.DOWN:
-                       this.next( event );
-                       break;
-               case $.ui.keyCode.LEFT:
-                       this.collapse( event );
-                       break;
-               case $.ui.keyCode.RIGHT:
-                       if ( this.active && !this.active.is( ".ui-state-disabled" ) ) {
-                               this.expand( event );
-                       }
-                       break;
-               case $.ui.keyCode.ENTER:
-               case $.ui.keyCode.SPACE:
-                       this._activate( event );
-                       break;
-               case $.ui.keyCode.ESCAPE:
-                       this.collapse( event );
-                       break;
-               default:
-                       preventDefault = false;
-                       prev = this.previousFilter || "";
-                       character = String.fromCharCode( event.keyCode );
-                       skip = false;
-
-                       clearTimeout( this.filterTimer );
-
-                       if ( character === prev ) {
-                               skip = true;
-                       } else {
-                               character = prev + character;
-                       }
-
-                       regex = new RegExp( "^" + escape( character ), "i" );
-                       match = this.activeMenu.children( ".ui-menu-item" ).filter(function() {
-                               return regex.test( $( this ).children( "a" ).text() );
-                       });
-                       match = skip && match.index( this.active.next() ) !== -1 ?
-                               this.active.nextAll( ".ui-menu-item" ) :
-                               match;
-
-                       // If no matches on the current filter, reset to the last character pressed
-                       // to move down the menu to the first item that starts with that character
-                       if ( !match.length ) {
-                               character = String.fromCharCode( event.keyCode );
-                               regex = new RegExp( "^" + escape( character ), "i" );
-                               match = this.activeMenu.children( ".ui-menu-item" ).filter(function() {
-                                       return regex.test( $( this ).children( "a" ).text() );
-                               });
-                       }
-
-                       if ( match.length ) {
-                               this.focus( event, match );
-                               if ( match.length > 1 ) {
-                                       this.previousFilter = character;
-                                       this.filterTimer = this._delay(function() {
-                                               delete this.previousFilter;
-                                       }, 1000 );
-                               } else {
-                                       delete this.previousFilter;
-                               }
-                       } else {
-                               delete this.previousFilter;
-                       }
-               }
-
-               if ( preventDefault ) {
-                       event.preventDefault();
-               }
-       },
-
-       _activate: function( event ) {
-               if ( !this.active.is( ".ui-state-disabled" ) ) {
-                       if ( this.active.children( "a[aria-haspopup='true']" ).length ) {
-                               this.expand( event );
-                       } else {
-                               this.select( event );
-                       }
-               }
-       },
-
-       refresh: function() {
-               var menus,
-                       icon = this.options.icons.submenu,
-                       submenus = this.element.find( this.options.menus );
-
-               this.element.toggleClass( "ui-menu-icons", !!this.element.find( ".ui-icon" ).length );
-
-               // Initialize nested menus
-               submenus.filter( ":not(.ui-menu)" )
-                       .addClass( "ui-menu ui-widget ui-widget-content ui-corner-all" )
-                       .hide()
-                       .attr({
-                               role: this.options.role,
-                               "aria-hidden": "true",
-                               "aria-expanded": "false"
-                       })
-                       .each(function() {
-                               var menu = $( this ),
-                                       item = menu.prev( "a" ),
-                                       submenuCarat = $( "<span>" )
-                                               .addClass( "ui-menu-icon ui-icon " + icon )
-                                               .data( "ui-menu-submenu-carat", true );
-
-                               item
-                                       .attr( "aria-haspopup", "true" )
-                                       .prepend( submenuCarat );
-                               menu.attr( "aria-labelledby", item.attr( "id" ) );
-                       });
-
-               menus = submenus.add( this.element );
-
-               // Don't refresh list items that are already adapted
-               menus.children( ":not(.ui-menu-item):has(a)" )
-                       .addClass( "ui-menu-item" )
-                       .attr( "role", "presentation" )
-                       .children( "a" )
-                               .uniqueId()
-                               .addClass( "ui-corner-all" )
-                               .attr({
-                                       tabIndex: -1,
-                                       role: this._itemRole()
-                               });
-
-               // Initialize unlinked menu-items containing spaces and/or dashes only as dividers
-               menus.children( ":not(.ui-menu-item)" ).each(function() {
-                       var item = $( this );
-                       // hyphen, em dash, en dash
-                       if ( !/[^\-\u2014\u2013\s]/.test( item.text() ) ) {
-                               item.addClass( "ui-widget-content ui-menu-divider" );
-                       }
-               });
-
-               // Add aria-disabled attribute to any disabled menu item
-               menus.children( ".ui-state-disabled" ).attr( "aria-disabled", "true" );
-
-               // If the active item has been removed, blur the menu
-               if ( this.active && !$.contains( this.element[ 0 ], this.active[ 0 ] ) ) {
-                       this.blur();
-               }
-       },
-
-       _itemRole: function() {
-               return {
-                       menu: "menuitem",
-                       listbox: "option"
-               }[ this.options.role ];
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "icons" ) {
-                       this.element.find( ".ui-menu-icon" )
-                               .removeClass( this.options.icons.submenu )
-                               .addClass( value.submenu );
-               }
-               this._super( key, value );
-       },
-
-       focus: function( event, item ) {
-               var nested, focused;
-               this.blur( event, event && event.type === "focus" );
-
-               this._scrollIntoView( item );
-
-               this.active = item.first();
-               focused = this.active.children( "a" ).addClass( "ui-state-focus" );
-               // Only update aria-activedescendant if there's a role
-               // otherwise we assume focus is managed elsewhere
-               if ( this.options.role ) {
-                       this.element.attr( "aria-activedescendant", focused.attr( "id" ) );
-               }
-
-               // Highlight active parent menu item, if any
-               this.active
-                       .parent()
-                       .closest( ".ui-menu-item" )
-                       .children( "a:first" )
-                       .addClass( "ui-state-active" );
-
-               if ( event && event.type === "keydown" ) {
-                       this._close();
-               } else {
-                       this.timer = this._delay(function() {
-                               this._close();
-                       }, this.delay );
-               }
-
-               nested = item.children( ".ui-menu" );
-               if ( nested.length && event && ( /^mouse/.test( event.type ) ) ) {
-                       this._startOpening(nested);
-               }
-               this.activeMenu = item.parent();
-
-               this._trigger( "focus", event, { item: item } );
-       },
-
-       _scrollIntoView: function( item ) {
-               var borderTop, paddingTop, offset, scroll, elementHeight, itemHeight;
-               if ( this._hasScroll() ) {
-                       borderTop = parseFloat( $.css( this.activeMenu[0], "borderTopWidth" ) ) || 0;
-                       paddingTop = parseFloat( $.css( this.activeMenu[0], "paddingTop" ) ) || 0;
-                       offset = item.offset().top - this.activeMenu.offset().top - borderTop - paddingTop;
-                       scroll = this.activeMenu.scrollTop();
-                       elementHeight = this.activeMenu.height();
-                       itemHeight = item.height();
-
-                       if ( offset < 0 ) {
-                               this.activeMenu.scrollTop( scroll + offset );
-                       } else if ( offset + itemHeight > elementHeight ) {
-                               this.activeMenu.scrollTop( scroll + offset - elementHeight + itemHeight );
-                       }
-               }
-       },
-
-       blur: function( event, fromFocus ) {
-               if ( !fromFocus ) {
-                       clearTimeout( this.timer );
-               }
-
-               if ( !this.active ) {
-                       return;
-               }
-
-               this.active.children( "a" ).removeClass( "ui-state-focus" );
-               this.active = null;
-
-               this._trigger( "blur", event, { item: this.active } );
-       },
-
-       _startOpening: function( submenu ) {
-               clearTimeout( this.timer );
-
-               // Don't open if already open fixes a Firefox bug that caused a .5 pixel
-               // shift in the submenu position when mousing over the carat icon
-               if ( submenu.attr( "aria-hidden" ) !== "true" ) {
-                       return;
-               }
-
-               this.timer = this._delay(function() {
-                       this._close();
-                       this._open( submenu );
-               }, this.delay );
-       },
-
-       _open: function( submenu ) {
-               var position = $.extend({
-                       of: this.active
-               }, this.options.position );
-
-               clearTimeout( this.timer );
-               this.element.find( ".ui-menu" ).not( submenu.parents( ".ui-menu" ) )
-                       .hide()
-                       .attr( "aria-hidden", "true" );
-
-               submenu
-                       .show()
-                       .removeAttr( "aria-hidden" )
-                       .attr( "aria-expanded", "true" )
-                       .position( position );
-       },
-
-       collapseAll: function( event, all ) {
-               clearTimeout( this.timer );
-               this.timer = this._delay(function() {
-                       // If we were passed an event, look for the submenu that contains the event
-                       var currentMenu = all ? this.element :
-                               $( event && event.target ).closest( this.element.find( ".ui-menu" ) );
-
-                       // If we found no valid submenu ancestor, use the main menu to close all sub menus anyway
-                       if ( !currentMenu.length ) {
-                               currentMenu = this.element;
-                       }
-
-                       this._close( currentMenu );
-
-                       this.blur( event );
-                       this.activeMenu = currentMenu;
-               }, this.delay );
-       },
-
-       // With no arguments, closes the currently active menu - if nothing is active
-       // it closes all menus.  If passed an argument, it will search for menus BELOW
-       _close: function( startMenu ) {
-               if ( !startMenu ) {
-                       startMenu = this.active ? this.active.parent() : this.element;
-               }
-
-               startMenu
-                       .find( ".ui-menu" )
-                               .hide()
-                               .attr( "aria-hidden", "true" )
-                               .attr( "aria-expanded", "false" )
-                       .end()
-                       .find( "a.ui-state-active" )
-                               .removeClass( "ui-state-active" );
-       },
-
-       collapse: function( event ) {
-               var newItem = this.active &&
-                       this.active.parent().closest( ".ui-menu-item", this.element );
-               if ( newItem && newItem.length ) {
-                       this._close();
-                       this.focus( event, newItem );
-               }
-       },
-
-       expand: function( event ) {
-               var newItem = this.active &&
-                       this.active
-                               .children( ".ui-menu " )
-                               .children( ".ui-menu-item" )
-                               .first();
-
-               if ( newItem && newItem.length ) {
-                       this._open( newItem.parent() );
-
-                       // Delay so Firefox will not hide activedescendant change in expanding submenu from AT
-                       this._delay(function() {
-                               this.focus( event, newItem );
-                       });
-               }
-       },
-
-       next: function( event ) {
-               this._move( "next", "first", event );
-       },
-
-       previous: function( event ) {
-               this._move( "prev", "last", event );
-       },
-
-       isFirstItem: function() {
-               return this.active && !this.active.prevAll( ".ui-menu-item" ).length;
-       },
-
-       isLastItem: function() {
-               return this.active && !this.active.nextAll( ".ui-menu-item" ).length;
-       },
-
-       _move: function( direction, filter, event ) {
-               var next;
-               if ( this.active ) {
-                       if ( direction === "first" || direction === "last" ) {
-                               next = this.active
-                                       [ direction === "first" ? "prevAll" : "nextAll" ]( ".ui-menu-item" )
-                                       .eq( -1 );
-                       } else {
-                               next = this.active
-                                       [ direction + "All" ]( ".ui-menu-item" )
-                                       .eq( 0 );
-                       }
-               }
-               if ( !next || !next.length || !this.active ) {
-                       next = this.activeMenu.children( ".ui-menu-item" )[ filter ]();
-               }
-
-               this.focus( event, next );
-       },
-
-       nextPage: function( event ) {
-               var item, base, height;
-
-               if ( !this.active ) {
-                       this.next( event );
-                       return;
-               }
-               if ( this.isLastItem() ) {
-                       return;
-               }
-               if ( this._hasScroll() ) {
-                       base = this.active.offset().top;
-                       height = this.element.height();
-                       this.active.nextAll( ".ui-menu-item" ).each(function() {
-                               item = $( this );
-                               return item.offset().top - base - height < 0;
-                       });
-
-                       this.focus( event, item );
-               } else {
-                       this.focus( event, this.activeMenu.children( ".ui-menu-item" )
-                               [ !this.active ? "first" : "last" ]() );
-               }
-       },
-
-       previousPage: function( event ) {
-               var item, base, height;
-               if ( !this.active ) {
-                       this.next( event );
-                       return;
-               }
-               if ( this.isFirstItem() ) {
-                       return;
-               }
-               if ( this._hasScroll() ) {
-                       base = this.active.offset().top;
-                       height = this.element.height();
-                       this.active.prevAll( ".ui-menu-item" ).each(function() {
-                               item = $( this );
-                               return item.offset().top - base + height > 0;
-                       });
-
-                       this.focus( event, item );
-               } else {
-                       this.focus( event, this.activeMenu.children( ".ui-menu-item" ).first() );
-               }
-       },
-
-       _hasScroll: function() {
-               return this.element.outerHeight() < this.element.prop( "scrollHeight" );
-       },
-
-       select: function( event ) {
-               // TODO: It should never be possible to not have an active item at this
-               // point, but the tests don't trigger mouseenter before click.
-               this.active = this.active || $( event.target ).closest( ".ui-menu-item" );
-               var ui = { item: this.active };
-               if ( !this.active.has( ".ui-menu" ).length ) {
-                       this.collapseAll( event, true );
-               }
-               this._trigger( "select", event, ui );
-       }
-});
-
-}( jQuery ));
-(function( $, undefined ) {
-
-$.widget( "ui.progressbar", {
-       version: "1.10.4",
-       options: {
-               max: 100,
-               value: 0,
-
-               change: null,
-               complete: null
-       },
-
-       min: 0,
-
-       _create: function() {
-               // Constrain initial value
-               this.oldValue = this.options.value = this._constrainedValue();
-
-               this.element
-                       .addClass( "ui-progressbar ui-widget ui-widget-content ui-corner-all" )
-                       .attr({
-                               // Only set static values, aria-valuenow and aria-valuemax are
-                               // set inside _refreshValue()
-                               role: "progressbar",
-                               "aria-valuemin": this.min
-                       });
-
-               this.valueDiv = $( "<div class='ui-progressbar-value ui-widget-header ui-corner-left'></div>" )
-                       .appendTo( this.element );
-
-               this._refreshValue();
-       },
-
-       _destroy: function() {
-               this.element
-                       .removeClass( "ui-progressbar ui-widget ui-widget-content ui-corner-all" )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-valuemin" )
-                       .removeAttr( "aria-valuemax" )
-                       .removeAttr( "aria-valuenow" );
-
-               this.valueDiv.remove();
-       },
-
-       value: function( newValue ) {
-               if ( newValue === undefined ) {
-                       return this.options.value;
-               }
-
-               this.options.value = this._constrainedValue( newValue );
-               this._refreshValue();
-       },
-
-       _constrainedValue: function( newValue ) {
-               if ( newValue === undefined ) {
-                       newValue = this.options.value;
-               }
-
-               this.indeterminate = newValue === false;
-
-               // sanitize value
-               if ( typeof newValue !== "number" ) {
-                       newValue = 0;
-               }
-
-               return this.indeterminate ? false :
-                       Math.min( this.options.max, Math.max( this.min, newValue ) );
-       },
-
-       _setOptions: function( options ) {
-               // Ensure "value" option is set after other values (like max)
-               var value = options.value;
-               delete options.value;
-
-               this._super( options );
-
-               this.options.value = this._constrainedValue( value );
-               this._refreshValue();
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "max" ) {
-                       // Don't allow a max less than min
-                       value = Math.max( this.min, value );
-               }
-
-               this._super( key, value );
-       },
-
-       _percentage: function() {
-               return this.indeterminate ? 100 : 100 * ( this.options.value - this.min ) / ( this.options.max - this.min );
-       },
-
-       _refreshValue: function() {
-               var value = this.options.value,
-                       percentage = this._percentage();
-
-               this.valueDiv
-                       .toggle( this.indeterminate || value > this.min )
-                       .toggleClass( "ui-corner-right", value === this.options.max )
-                       .width( percentage.toFixed(0) + "%" );
-
-               this.element.toggleClass( "ui-progressbar-indeterminate", this.indeterminate );
-
-               if ( this.indeterminate ) {
-                       this.element.removeAttr( "aria-valuenow" );
-                       if ( !this.overlayDiv ) {
-                               this.overlayDiv = $( "<div class='ui-progressbar-overlay'></div>" ).appendTo( this.valueDiv );
-                       }
-               } else {
-                       this.element.attr({
-                               "aria-valuemax": this.options.max,
-                               "aria-valuenow": value
-                       });
-                       if ( this.overlayDiv ) {
-                               this.overlayDiv.remove();
-                               this.overlayDiv = null;
-                       }
-               }
-
-               if ( this.oldValue !== value ) {
-                       this.oldValue = value;
-                       this._trigger( "change" );
-               }
-               if ( value === this.options.max ) {
-                       this._trigger( "complete" );
-               }
-       }
-});
-
-})( jQuery );
-(function( $, undefined ) {
-
-function num(v) {
-       return parseInt(v, 10) || 0;
-}
-
-function isNumber(value) {
-       return !isNaN(parseInt(value, 10));
-}
-
-$.widget("ui.resizable", $.ui.mouse, {
-       version: "1.10.4",
-       widgetEventPrefix: "resize",
-       options: {
-               alsoResize: false,
-               animate: false,
-               animateDuration: "slow",
-               animateEasing: "swing",
-               aspectRatio: false,
-               autoHide: false,
-               containment: false,
-               ghost: false,
-               grid: false,
-               handles: "e,s,se",
-               helper: false,
-               maxHeight: null,
-               maxWidth: null,
-               minHeight: 10,
-               minWidth: 10,
-               // See #7960
-               zIndex: 90,
-
-               // callbacks
-               resize: null,
-               start: null,
-               stop: null
-       },
-       _create: function() {
-
-               var n, i, handle, axis, hname,
-                       that = this,
-                       o = this.options;
-               this.element.addClass("ui-resizable");
-
-               $.extend(this, {
-                       _aspectRatio: !!(o.aspectRatio),
-                       aspectRatio: o.aspectRatio,
-                       originalElement: this.element,
-                       _proportionallyResizeElements: [],
-                       _helper: o.helper || o.ghost || o.animate ? o.helper || "ui-resizable-helper" : null
-               });
-
-               //Wrap the element if it cannot hold child nodes
-               if(this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)) {
-
-                       //Create a wrapper element and set the wrapper to the new current internal element
-                       this.element.wrap(
-                               $("<div class='ui-wrapper' style='overflow: hidden;'></div>").css({
-                                       position: this.element.css("position"),
-                                       width: this.element.outerWidth(),
-                                       height: this.element.outerHeight(),
-                                       top: this.element.css("top"),
-                                       left: this.element.css("left")
-                               })
-                       );
-
-                       //Overwrite the original this.element
-                       this.element = this.element.parent().data(
-                               "ui-resizable", this.element.data("ui-resizable")
-                       );
-
-                       this.elementIsWrapper = true;
-
-                       //Move margins to the wrapper
-                       this.element.css({ marginLeft: this.originalElement.css("marginLeft"), marginTop: this.originalElement.css("marginTop"), marginRight: this.originalElement.css("marginRight"), marginBottom: this.originalElement.css("marginBottom") });
-                       this.originalElement.css({ marginLeft: 0, marginTop: 0, marginRight: 0, marginBottom: 0});
-
-                       //Prevent Safari textarea resize
-                       this.originalResizeStyle = this.originalElement.css("resize");
-                       this.originalElement.css("resize", "none");
-
-                       //Push the actual element to our proportionallyResize internal array
-                       this._proportionallyResizeElements.push(this.originalElement.css({ position: "static", zoom: 1, display: "block" }));
-
-                       // avoid IE jump (hard set the margin)
-                       this.originalElement.css({ margin: this.originalElement.css("margin") });
-
-                       // fix handlers offset
-                       this._proportionallyResize();
-
-               }
-
-               this.handles = o.handles || (!$(".ui-resizable-handle", this.element).length ? "e,s,se" : { n: ".ui-resizable-n", e: ".ui-resizable-e", s: ".ui-resizable-s", w: ".ui-resizable-w", se: ".ui-resizable-se", sw: ".ui-resizable-sw", ne: ".ui-resizable-ne", nw: ".ui-resizable-nw" });
-               if(this.handles.constructor === String) {
-
-                       if ( this.handles === "all") {
-                               this.handles = "n,e,s,w,se,sw,ne,nw";
-                       }
-
-                       n = this.handles.split(",");
-                       this.handles = {};
-
-                       for(i = 0; i < n.length; i++) {
-
-                               handle = $.trim(n[i]);
-                               hname = "ui-resizable-"+handle;
-                               axis = $("<div class='ui-resizable-handle " + hname + "'></div>");
-
-                               // Apply zIndex to all handles - see #7960
-                               axis.css({ zIndex: o.zIndex });
-
-                               //TODO : What's going on here?
-                               if ("se" === handle) {
-                                       axis.addClass("ui-icon ui-icon-gripsmall-diagonal-se");
-                               }
-
-                               //Insert into internal handles object and append to element
-                               this.handles[handle] = ".ui-resizable-"+handle;
-                               this.element.append(axis);
-                       }
-
-               }
-
-               this._renderAxis = function(target) {
-
-                       var i, axis, padPos, padWrapper;
-
-                       target = target || this.element;
-
-                       for(i in this.handles) {
-
-                               if(this.handles[i].constructor === String) {
-                                       this.handles[i] = $(this.handles[i], this.element).show();
-                               }
-
-                               //Apply pad to wrapper element, needed to fix axis position (textarea, inputs, scrolls)
-                               if (this.elementIsWrapper && this.originalElement[0].nodeName.match(/textarea|input|select|button/i)) {
-
-                                       axis = $(this.handles[i], this.element);
-
-                                       //Checking the correct pad and border
-                                       padWrapper = /sw|ne|nw|se|n|s/.test(i) ? axis.outerHeight() : axis.outerWidth();
-
-                                       //The padding type i have to apply...
-                                       padPos = [ "padding",
-                                               /ne|nw|n/.test(i) ? "Top" :
-                                               /se|sw|s/.test(i) ? "Bottom" :
-                                               /^e$/.test(i) ? "Right" : "Left" ].join("");
-
-                                       target.css(padPos, padWrapper);
-
-                                       this._proportionallyResize();
-
-                               }
-
-                               //TODO: What's that good for? There's not anything to be executed left
-                               if(!$(this.handles[i]).length) {
-                                       continue;
-                               }
-                       }
-               };
-
-               //TODO: make renderAxis a prototype function
-               this._renderAxis(this.element);
-
-               this._handles = $(".ui-resizable-handle", this.element)
-                       .disableSelection();
-
-               //Matching axis name
-               this._handles.mouseover(function() {
-                       if (!that.resizing) {
-                               if (this.className) {
-                                       axis = this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);
-                               }
-                               //Axis, default = se
-                               that.axis = axis && axis[1] ? axis[1] : "se";
-                       }
-               });
-
-               //If we want to auto hide the elements
-               if (o.autoHide) {
-                       this._handles.hide();
-                       $(this.element)
-                               .addClass("ui-resizable-autohide")
-                               .mouseenter(function() {
-                                       if (o.disabled) {
-                                               return;
-                                       }
-                                       $(this).removeClass("ui-resizable-autohide");
-                                       that._handles.show();
-                               })
-                               .mouseleave(function(){
-                                       if (o.disabled) {
-                                               return;
-                                       }
-                                       if (!that.resizing) {
-                                               $(this).addClass("ui-resizable-autohide");
-                                               that._handles.hide();
-                                       }
-                               });
-               }
-
-               //Initialize the mouse interaction
-               this._mouseInit();
-
-       },
-
-       _destroy: function() {
-
-               this._mouseDestroy();
-
-               var wrapper,
-                       _destroy = function(exp) {
-                               $(exp).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing")
-                                       .removeData("resizable").removeData("ui-resizable").unbind(".resizable").find(".ui-resizable-handle").remove();
-                       };
-
-               //TODO: Unwrap at same DOM position
-               if (this.elementIsWrapper) {
-                       _destroy(this.element);
-                       wrapper = this.element;
-                       this.originalElement.css({
-                               position: wrapper.css("position"),
-                               width: wrapper.outerWidth(),
-                               height: wrapper.outerHeight(),
-                               top: wrapper.css("top"),
-                               left: wrapper.css("left")
-                       }).insertAfter( wrapper );
-                       wrapper.remove();
-               }
-
-               this.originalElement.css("resize", this.originalResizeStyle);
-               _destroy(this.originalElement);
-
-               return this;
-       },
-
-       _mouseCapture: function(event) {
-               var i, handle,
-                       capture = false;
-
-               for (i in this.handles) {
-                       handle = $(this.handles[i])[0];
-                       if (handle === event.target || $.contains(handle, event.target)) {
-                               capture = true;
-                       }
-               }
-
-               return !this.options.disabled && capture;
-       },
-
-       _mouseStart: function(event) {
-
-               var curleft, curtop, cursor,
-                       o = this.options,
-                       iniPos = this.element.position(),
-                       el = this.element;
-
-               this.resizing = true;
-
-               // bugfix for http://dev.jquery.com/ticket/1749
-               if ( (/absolute/).test( el.css("position") ) ) {
-                       el.css({ position: "absolute", top: el.css("top"), left: el.css("left") });
-               } else if (el.is(".ui-draggable")) {
-                       el.css({ position: "absolute", top: iniPos.top, left: iniPos.left });
-               }
-
-               this._renderProxy();
-
-               curleft = num(this.helper.css("left"));
-               curtop = num(this.helper.css("top"));
-
-               if (o.containment) {
-                       curleft += $(o.containment).scrollLeft() || 0;
-                       curtop += $(o.containment).scrollTop() || 0;
-               }
-
-               //Store needed variables
-               this.offset = this.helper.offset();
-               this.position = { left: curleft, top: curtop };
-               this.size = this._helper ? { width: this.helper.width(), height: this.helper.height() } : { width: el.width(), height: el.height() };
-               this.originalSize = this._helper ? { width: el.outerWidth(), height: el.outerHeight() } : { width: el.width(), height: el.height() };
-               this.originalPosition = { left: curleft, top: curtop };
-               this.sizeDiff = { width: el.outerWidth() - el.width(), height: el.outerHeight() - el.height() };
-               this.originalMousePosition = { left: event.pageX, top: event.pageY };
-
-               //Aspect Ratio
-               this.aspectRatio = (typeof o.aspectRatio === "number") ? o.aspectRatio : ((this.originalSize.width / this.originalSize.height) || 1);
-
-               cursor = $(".ui-resizable-" + this.axis).css("cursor");
-               $("body").css("cursor", cursor === "auto" ? this.axis + "-resize" : cursor);
-
-               el.addClass("ui-resizable-resizing");
-               this._propagate("start", event);
-               return true;
-       },
-
-       _mouseDrag: function(event) {
-
-               //Increase performance, avoid regex
-               var data,
-                       el = this.helper, props = {},
-                       smp = this.originalMousePosition,
-                       a = this.axis,
-                       prevTop = this.position.top,
-                       prevLeft = this.position.left,
-                       prevWidth = this.size.width,
-                       prevHeight = this.size.height,
-                       dx = (event.pageX-smp.left)||0,
-                       dy = (event.pageY-smp.top)||0,
-                       trigger = this._change[a];
-
-               if (!trigger) {
-                       return false;
-               }
-
-               // Calculate the attrs that will be change
-               data = trigger.apply(this, [event, dx, dy]);
-
-               // Put this in the mouseDrag handler since the user can start pressing shift while resizing
-               this._updateVirtualBoundaries(event.shiftKey);
-               if (this._aspectRatio || event.shiftKey) {
-                       data = this._updateRatio(data, event);
-               }
-
-               data = this._respectSize(data, event);
-
-               this._updateCache(data);
-
-               // plugins callbacks need to be called first
-               this._propagate("resize", event);
-
-               if (this.position.top !== prevTop) {
-                       props.top = this.position.top + "px";
-               }
-               if (this.position.left !== prevLeft) {
-                       props.left = this.position.left + "px";
-               }
-               if (this.size.width !== prevWidth) {
-                       props.width = this.size.width + "px";
-               }
-               if (this.size.height !== prevHeight) {
-                       props.height = this.size.height + "px";
-               }
-               el.css(props);
-
-               if (!this._helper && this._proportionallyResizeElements.length) {
-                       this._proportionallyResize();
-               }
-
-               // Call the user callback if the element was resized
-               if ( ! $.isEmptyObject(props) ) {
-                       this._trigger("resize", event, this.ui());
-               }
-
-               return false;
-       },
-
-       _mouseStop: function(event) {
-
-               this.resizing = false;
-               var pr, ista, soffseth, soffsetw, s, left, top,
-                       o = this.options, that = this;
-
-               if(this._helper) {
-
-                       pr = this._proportionallyResizeElements;
-                       ista = pr.length && (/textarea/i).test(pr[0].nodeName);
-                       soffseth = ista && $.ui.hasScroll(pr[0], "left") /* TODO - jump height */ ? 0 : that.sizeDiff.height;
-                       soffsetw = ista ? 0 : that.sizeDiff.width;
-
-                       s = { width: (that.helper.width()  - soffsetw), height: (that.helper.height() - soffseth) };
-                       left = (parseInt(that.element.css("left"), 10) + (that.position.left - that.originalPosition.left)) || null;
-                       top = (parseInt(that.element.css("top"), 10) + (that.position.top - that.originalPosition.top)) || null;
-
-                       if (!o.animate) {
-                               this.element.css($.extend(s, { top: top, left: left }));
-                       }
-
-                       that.helper.height(that.size.height);
-                       that.helper.width(that.size.width);
-
-                       if (this._helper && !o.animate) {
-                               this._proportionallyResize();
-                       }
-               }
-
-               $("body").css("cursor", "auto");
-
-               this.element.removeClass("ui-resizable-resizing");
-
-               this._propagate("stop", event);
-
-               if (this._helper) {
-                       this.helper.remove();
-               }
-
-               return false;
-
-       },
-
-       _updateVirtualBoundaries: function(forceAspectRatio) {
-               var pMinWidth, pMaxWidth, pMinHeight, pMaxHeight, b,
-                       o = this.options;
-
-               b = {
-                       minWidth: isNumber(o.minWidth) ? o.minWidth : 0,
-                       maxWidth: isNumber(o.maxWidth) ? o.maxWidth : Infinity,
-                       minHeight: isNumber(o.minHeight) ? o.minHeight : 0,
-                       maxHeight: isNumber(o.maxHeight) ? o.maxHeight : Infinity
-               };
-
-               if(this._aspectRatio || forceAspectRatio) {
-                       // We want to create an enclosing box whose aspect ration is the requested one
-                       // First, compute the "projected" size for each dimension based on the aspect ratio and other dimension
-                       pMinWidth = b.minHeight * this.aspectRatio;
-                       pMinHeight = b.minWidth / this.aspectRatio;
-                       pMaxWidth = b.maxHeight * this.aspectRatio;
-                       pMaxHeight = b.maxWidth / this.aspectRatio;
-
-                       if(pMinWidth > b.minWidth) {
-                               b.minWidth = pMinWidth;
-                       }
-                       if(pMinHeight > b.minHeight) {
-                               b.minHeight = pMinHeight;
-                       }
-                       if(pMaxWidth < b.maxWidth) {
-                               b.maxWidth = pMaxWidth;
-                       }
-                       if(pMaxHeight < b.maxHeight) {
-                               b.maxHeight = pMaxHeight;
-                       }
-               }
-               this._vBoundaries = b;
-       },
-
-       _updateCache: function(data) {
-               this.offset = this.helper.offset();
-               if (isNumber(data.left)) {
-                       this.position.left = data.left;
-               }
-               if (isNumber(data.top)) {
-                       this.position.top = data.top;
-               }
-               if (isNumber(data.height)) {
-                       this.size.height = data.height;
-               }
-               if (isNumber(data.width)) {
-                       this.size.width = data.width;
-               }
-       },
-
-       _updateRatio: function( data ) {
-
-               var cpos = this.position,
-                       csize = this.size,
-                       a = this.axis;
-
-               if (isNumber(data.height)) {
-                       data.width = (data.height * this.aspectRatio);
-               } else if (isNumber(data.width)) {
-                       data.height = (data.width / this.aspectRatio);
-               }
-
-               if (a === "sw") {
-                       data.left = cpos.left + (csize.width - data.width);
-                       data.top = null;
-               }
-               if (a === "nw") {
-                       data.top = cpos.top + (csize.height - data.height);
-                       data.left = cpos.left + (csize.width - data.width);
-               }
-
-               return data;
-       },
-
-       _respectSize: function( data ) {
-
-               var o = this._vBoundaries,
-                       a = this.axis,
-                       ismaxw = isNumber(data.width) && o.maxWidth && (o.maxWidth < data.width), ismaxh = isNumber(data.height) && o.maxHeight && (o.maxHeight < data.height),
-                       isminw = isNumber(data.width) && o.minWidth && (o.minWidth > data.width), isminh = isNumber(data.height) && o.minHeight && (o.minHeight > data.height),
-                       dw = this.originalPosition.left + this.originalSize.width,
-                       dh = this.position.top + this.size.height,
-                       cw = /sw|nw|w/.test(a), ch = /nw|ne|n/.test(a);
-               if (isminw) {
-                       data.width = o.minWidth;
-               }
-               if (isminh) {
-                       data.height = o.minHeight;
-               }
-               if (ismaxw) {
-                       data.width = o.maxWidth;
-               }
-               if (ismaxh) {
-                       data.height = o.maxHeight;
-               }
-
-               if (isminw && cw) {
-                       data.left = dw - o.minWidth;
-               }
-               if (ismaxw && cw) {
-                       data.left = dw - o.maxWidth;
-               }
-               if (isminh && ch) {
-                       data.top = dh - o.minHeight;
-               }
-               if (ismaxh && ch) {
-                       data.top = dh - o.maxHeight;
-               }
-
-               // fixing jump error on top/left - bug #2330
-               if (!data.width && !data.height && !data.left && data.top) {
-                       data.top = null;
-               } else if (!data.width && !data.height && !data.top && data.left) {
-                       data.left = null;
-               }
-
-               return data;
-       },
-
-       _proportionallyResize: function() {
-
-               if (!this._proportionallyResizeElements.length) {
-                       return;
-               }
-
-               var i, j, borders, paddings, prel,
-                       element = this.helper || this.element;
-
-               for ( i=0; i < this._proportionallyResizeElements.length; i++) {
-
-                       prel = this._proportionallyResizeElements[i];
-
-                       if (!this.borderDif) {
-                               this.borderDif = [];
-                               borders = [prel.css("borderTopWidth"), prel.css("borderRightWidth"), prel.css("borderBottomWidth"), prel.css("borderLeftWidth")];
-                               paddings = [prel.css("paddingTop"), prel.css("paddingRight"), prel.css("paddingBottom"), prel.css("paddingLeft")];
-
-                               for ( j = 0; j < borders.length; j++ ) {
-                                       this.borderDif[ j ] = ( parseInt( borders[ j ], 10 ) || 0 ) + ( parseInt( paddings[ j ], 10 ) || 0 );
-                               }
-                       }
-
-                       prel.css({
-                               height: (element.height() - this.borderDif[0] - this.borderDif[2]) || 0,
-                               width: (element.width() - this.borderDif[1] - this.borderDif[3]) || 0
-                       });
-
-               }
-
-       },
-
-       _renderProxy: function() {
-
-               var el = this.element, o = this.options;
-               this.elementOffset = el.offset();
-
-               if(this._helper) {
-
-                       this.helper = this.helper || $("<div style='overflow:hidden;'></div>");
-
-                       this.helper.addClass(this._helper).css({
-                               width: this.element.outerWidth() - 1,
-                               height: this.element.outerHeight() - 1,
-                               position: "absolute",
-                               left: this.elementOffset.left +"px",
-                               top: this.elementOffset.top +"px",
-                               zIndex: ++o.zIndex //TODO: Don't modify option
-                       });
-
-                       this.helper
-                               .appendTo("body")
-                               .disableSelection();
-
-               } else {
-                       this.helper = this.element;
-               }
-
-       },
-
-       _change: {
-               e: function(event, dx) {
-                       return { width: this.originalSize.width + dx };
-               },
-               w: function(event, dx) {
-                       var cs = this.originalSize, sp = this.originalPosition;
-                       return { left: sp.left + dx, width: cs.width - dx };
-               },
-               n: function(event, dx, dy) {
-                       var cs = this.originalSize, sp = this.originalPosition;
-                       return { top: sp.top + dy, height: cs.height - dy };
-               },
-               s: function(event, dx, dy) {
-                       return { height: this.originalSize.height + dy };
-               },
-               se: function(event, dx, dy) {
-                       return $.extend(this._change.s.apply(this, arguments), this._change.e.apply(this, [event, dx, dy]));
-               },
-               sw: function(event, dx, dy) {
-                       return $.extend(this._change.s.apply(this, arguments), this._change.w.apply(this, [event, dx, dy]));
-               },
-               ne: function(event, dx, dy) {
-                       return $.extend(this._change.n.apply(this, arguments), this._change.e.apply(this, [event, dx, dy]));
-               },
-               nw: function(event, dx, dy) {
-                       return $.extend(this._change.n.apply(this, arguments), this._change.w.apply(this, [event, dx, dy]));
-               }
-       },
-
-       _propagate: function(n, event) {
-               $.ui.plugin.call(this, n, [event, this.ui()]);
-               (n !== "resize" && this._trigger(n, event, this.ui()));
-       },
-
-       plugins: {},
-
-       ui: function() {
-               return {
-                       originalElement: this.originalElement,
-                       element: this.element,
-                       helper: this.helper,
-                       position: this.position,
-                       size: this.size,
-                       originalSize: this.originalSize,
-                       originalPosition: this.originalPosition
-               };
-       }
-
-});
-
-/*
- * Resizable Extensions
- */
-
-$.ui.plugin.add("resizable", "animate", {
-
-       stop: function( event ) {
-               var that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       pr = that._proportionallyResizeElements,
-                       ista = pr.length && (/textarea/i).test(pr[0].nodeName),
-                       soffseth = ista && $.ui.hasScroll(pr[0], "left") /* TODO - jump height */ ? 0 : that.sizeDiff.height,
-                       soffsetw = ista ? 0 : that.sizeDiff.width,
-                       style = { width: (that.size.width - soffsetw), height: (that.size.height - soffseth) },
-                       left = (parseInt(that.element.css("left"), 10) + (that.position.left - that.originalPosition.left)) || null,
-                       top = (parseInt(that.element.css("top"), 10) + (that.position.top - that.originalPosition.top)) || null;
-
-               that.element.animate(
-                       $.extend(style, top && left ? { top: top, left: left } : {}), {
-                               duration: o.animateDuration,
-                               easing: o.animateEasing,
-                               step: function() {
-
-                                       var data = {
-                                               width: parseInt(that.element.css("width"), 10),
-                                               height: parseInt(that.element.css("height"), 10),
-                                               top: parseInt(that.element.css("top"), 10),
-                                               left: parseInt(that.element.css("left"), 10)
-                                       };
-
-                                       if (pr && pr.length) {
-                                               $(pr[0]).css({ width: data.width, height: data.height });
-                                       }
-
-                                       // propagating resize, and updating values for each animation step
-                                       that._updateCache(data);
-                                       that._propagate("resize", event);
-
-                               }
-                       }
-               );
-       }
-
-});
-
-$.ui.plugin.add("resizable", "containment", {
-
-       start: function() {
-               var element, p, co, ch, cw, width, height,
-                       that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       el = that.element,
-                       oc = o.containment,
-                       ce = (oc instanceof $) ? oc.get(0) : (/parent/.test(oc)) ? el.parent().get(0) : oc;
-
-               if (!ce) {
-                       return;
-               }
-
-               that.containerElement = $(ce);
-
-               if (/document/.test(oc) || oc === document) {
-                       that.containerOffset = { left: 0, top: 0 };
-                       that.containerPosition = { left: 0, top: 0 };
-
-                       that.parentData = {
-                               element: $(document), left: 0, top: 0,
-                               width: $(document).width(), height: $(document).height() || document.body.parentNode.scrollHeight
-                       };
-               }
-
-               // i'm a node, so compute top, left, right, bottom
-               else {
-                       element = $(ce);
-                       p = [];
-                       $([ "Top", "Right", "Left", "Bottom" ]).each(function(i, name) { p[i] = num(element.css("padding" + name)); });
-
-                       that.containerOffset = element.offset();
-                       that.containerPosition = element.position();
-                       that.containerSize = { height: (element.innerHeight() - p[3]), width: (element.innerWidth() - p[1]) };
-
-                       co = that.containerOffset;
-                       ch = that.containerSize.height;
-                       cw = that.containerSize.width;
-                       width = ($.ui.hasScroll(ce, "left") ? ce.scrollWidth : cw );
-                       height = ($.ui.hasScroll(ce) ? ce.scrollHeight : ch);
-
-                       that.parentData = {
-                               element: ce, left: co.left, top: co.top, width: width, height: height
-                       };
-               }
-       },
-
-       resize: function( event ) {
-               var woset, hoset, isParent, isOffsetRelative,
-                       that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       co = that.containerOffset, cp = that.position,
-                       pRatio = that._aspectRatio || event.shiftKey,
-                       cop = { top:0, left:0 }, ce = that.containerElement;
-
-               if (ce[0] !== document && (/static/).test(ce.css("position"))) {
-                       cop = co;
-               }
-
-               if (cp.left < (that._helper ? co.left : 0)) {
-                       that.size.width = that.size.width + (that._helper ? (that.position.left - co.left) : (that.position.left - cop.left));
-                       if (pRatio) {
-                               that.size.height = that.size.width / that.aspectRatio;
-                       }
-                       that.position.left = o.helper ? co.left : 0;
-               }
-
-               if (cp.top < (that._helper ? co.top : 0)) {
-                       that.size.height = that.size.height + (that._helper ? (that.position.top - co.top) : that.position.top);
-                       if (pRatio) {
-                               that.size.width = that.size.height * that.aspectRatio;
-                       }
-                       that.position.top = that._helper ? co.top : 0;
-               }
-
-               that.offset.left = that.parentData.left+that.position.left;
-               that.offset.top = that.parentData.top+that.position.top;
-
-               woset = Math.abs( (that._helper ? that.offset.left - cop.left : (that.offset.left - cop.left)) + that.sizeDiff.width );
-               hoset = Math.abs( (that._helper ? that.offset.top - cop.top : (that.offset.top - co.top)) + that.sizeDiff.height );
-
-               isParent = that.containerElement.get(0) === that.element.parent().get(0);
-               isOffsetRelative = /relative|absolute/.test(that.containerElement.css("position"));
-
-               if ( isParent && isOffsetRelative ) {
-                       woset -= Math.abs( that.parentData.left );
-               }
-
-               if (woset + that.size.width >= that.parentData.width) {
-                       that.size.width = that.parentData.width - woset;
-                       if (pRatio) {
-                               that.size.height = that.size.width / that.aspectRatio;
-                       }
-               }
-
-               if (hoset + that.size.height >= that.parentData.height) {
-                       that.size.height = that.parentData.height - hoset;
-                       if (pRatio) {
-                               that.size.width = that.size.height * that.aspectRatio;
-                       }
-               }
-       },
-
-       stop: function(){
-               var that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       co = that.containerOffset,
-                       cop = that.containerPosition,
-                       ce = that.containerElement,
-                       helper = $(that.helper),
-                       ho = helper.offset(),
-                       w = helper.outerWidth() - that.sizeDiff.width,
-                       h = helper.outerHeight() - that.sizeDiff.height;
-
-               if (that._helper && !o.animate && (/relative/).test(ce.css("position"))) {
-                       $(this).css({ left: ho.left - cop.left - co.left, width: w, height: h });
-               }
-
-               if (that._helper && !o.animate && (/static/).test(ce.css("position"))) {
-                       $(this).css({ left: ho.left - cop.left - co.left, width: w, height: h });
-               }
-
-       }
-});
-
-$.ui.plugin.add("resizable", "alsoResize", {
-
-       start: function () {
-               var that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       _store = function (exp) {
-                               $(exp).each(function() {
-                                       var el = $(this);
-                                       el.data("ui-resizable-alsoresize", {
-                                               width: parseInt(el.width(), 10), height: parseInt(el.height(), 10),
-                                               left: parseInt(el.css("left"), 10), top: parseInt(el.css("top"), 10)
-                                       });
-                               });
-                       };
-
-               if (typeof(o.alsoResize) === "object" && !o.alsoResize.parentNode) {
-                       if (o.alsoResize.length) { o.alsoResize = o.alsoResize[0]; _store(o.alsoResize); }
-                       else { $.each(o.alsoResize, function (exp) { _store(exp); }); }
-               }else{
-                       _store(o.alsoResize);
-               }
-       },
-
-       resize: function (event, ui) {
-               var that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       os = that.originalSize,
-                       op = that.originalPosition,
-                       delta = {
-                               height: (that.size.height - os.height) || 0, width: (that.size.width - os.width) || 0,
-                               top: (that.position.top - op.top) || 0, left: (that.position.left - op.left) || 0
-                       },
-
-                       _alsoResize = function (exp, c) {
-                               $(exp).each(function() {
-                                       var el = $(this), start = $(this).data("ui-resizable-alsoresize"), style = {},
-                                               css = c && c.length ? c : el.parents(ui.originalElement[0]).length ? ["width", "height"] : ["width", "height", "top", "left"];
-
-                                       $.each(css, function (i, prop) {
-                                               var sum = (start[prop]||0) + (delta[prop]||0);
-                                               if (sum && sum >= 0) {
-                                                       style[prop] = sum || null;
-                                               }
-                                       });
-
-                                       el.css(style);
-                               });
-                       };
-
-               if (typeof(o.alsoResize) === "object" && !o.alsoResize.nodeType) {
-                       $.each(o.alsoResize, function (exp, c) { _alsoResize(exp, c); });
-               }else{
-                       _alsoResize(o.alsoResize);
-               }
-       },
-
-       stop: function () {
-               $(this).removeData("resizable-alsoresize");
-       }
-});
-
-$.ui.plugin.add("resizable", "ghost", {
-
-       start: function() {
-
-               var that = $(this).data("ui-resizable"), o = that.options, cs = that.size;
-
-               that.ghost = that.originalElement.clone();
-               that.ghost
-                       .css({ opacity: 0.25, display: "block", position: "relative", height: cs.height, width: cs.width, margin: 0, left: 0, top: 0 })
-                       .addClass("ui-resizable-ghost")
-                       .addClass(typeof o.ghost === "string" ? o.ghost : "");
-
-               that.ghost.appendTo(that.helper);
-
-       },
-
-       resize: function(){
-               var that = $(this).data("ui-resizable");
-               if (that.ghost) {
-                       that.ghost.css({ position: "relative", height: that.size.height, width: that.size.width });
-               }
-       },
-
-       stop: function() {
-               var that = $(this).data("ui-resizable");
-               if (that.ghost && that.helper) {
-                       that.helper.get(0).removeChild(that.ghost.get(0));
-               }
-       }
-
-});
-
-$.ui.plugin.add("resizable", "grid", {
-
-       resize: function() {
-               var that = $(this).data("ui-resizable"),
-                       o = that.options,
-                       cs = that.size,
-                       os = that.originalSize,
-                       op = that.originalPosition,
-                       a = that.axis,
-                       grid = typeof o.grid === "number" ? [o.grid, o.grid] : o.grid,
-                       gridX = (grid[0]||1),
-                       gridY = (grid[1]||1),
-                       ox = Math.round((cs.width - os.width) / gridX) * gridX,
-                       oy = Math.round((cs.height - os.height) / gridY) * gridY,
-                       newWidth = os.width + ox,
-                       newHeight = os.height + oy,
-                       isMaxWidth = o.maxWidth && (o.maxWidth < newWidth),
-                       isMaxHeight = o.maxHeight && (o.maxHeight < newHeight),
-                       isMinWidth = o.minWidth && (o.minWidth > newWidth),
-                       isMinHeight = o.minHeight && (o.minHeight > newHeight);
-
-               o.grid = grid;
-
-               if (isMinWidth) {
-                       newWidth = newWidth + gridX;
-               }
-               if (isMinHeight) {
-                       newHeight = newHeight + gridY;
-               }
-               if (isMaxWidth) {
-                       newWidth = newWidth - gridX;
-               }
-               if (isMaxHeight) {
-                       newHeight = newHeight - gridY;
-               }
-
-               if (/^(se|s|e)$/.test(a)) {
-                       that.size.width = newWidth;
-                       that.size.height = newHeight;
-               } else if (/^(ne)$/.test(a)) {
-                       that.size.width = newWidth;
-                       that.size.height = newHeight;
-                       that.position.top = op.top - oy;
-               } else if (/^(sw)$/.test(a)) {
-                       that.size.width = newWidth;
-                       that.size.height = newHeight;
-                       that.position.left = op.left - ox;
-               } else {
-                       if ( newHeight - gridY > 0 ) {
-                               that.size.height = newHeight;
-                               that.position.top = op.top - oy;
-                       } else {
-                               that.size.height = gridY;
-                               that.position.top = op.top + os.height - gridY;
-                       }
-                       if ( newWidth - gridX > 0 ) {
-                               that.size.width = newWidth;
-                               that.position.left = op.left - ox;
-                       } else {
-                               that.size.width = gridX;
-                               that.position.left = op.left + os.width - gridX;
-                       }
-               }
-       }
-
-});
-
-})(jQuery);
-(function( $, undefined ) {
-
-$.widget("ui.selectable", $.ui.mouse, {
-       version: "1.10.4",
-       options: {
-               appendTo: "body",
-               autoRefresh: true,
-               distance: 0,
-               filter: "*",
-               tolerance: "touch",
-
-               // callbacks
-               selected: null,
-               selecting: null,
-               start: null,
-               stop: null,
-               unselected: null,
-               unselecting: null
-       },
-       _create: function() {
-               var selectees,
-                       that = this;
-
-               this.element.addClass("ui-selectable");
-
-               this.dragged = false;
-
-               // cache selectee children based on filter
-               this.refresh = function() {
-                       selectees = $(that.options.filter, that.element[0]);
-                       selectees.addClass("ui-selectee");
-                       selectees.each(function() {
-                               var $this = $(this),
-                                       pos = $this.offset();
-                               $.data(this, "selectable-item", {
-                                       element: this,
-                                       $element: $this,
-                                       left: pos.left,
-                                       top: pos.top,
-                                       right: pos.left + $this.outerWidth(),
-                                       bottom: pos.top + $this.outerHeight(),
-                                       startselected: false,
-                                       selected: $this.hasClass("ui-selected"),
-                                       selecting: $this.hasClass("ui-selecting"),
-                                       unselecting: $this.hasClass("ui-unselecting")
-                               });
-                       });
-               };
-               this.refresh();
-
-               this.selectees = selectees.addClass("ui-selectee");
-
-               this._mouseInit();
-
-               this.helper = $("<div class='ui-selectable-helper'></div>");
-       },
-
-       _destroy: function() {
-               this.selectees
-                       .removeClass("ui-selectee")
-                       .removeData("selectable-item");
-               this.element
-                       .removeClass("ui-selectable ui-selectable-disabled");
-               this._mouseDestroy();
-       },
-
-       _mouseStart: function(event) {
-               var that = this,
-                       options = this.options;
-
-               this.opos = [event.pageX, event.pageY];
-
-               if (this.options.disabled) {
-                       return;
-               }
-
-               this.selectees = $(options.filter, this.element[0]);
-
-               this._trigger("start", event);
-
-               $(options.appendTo).append(this.helper);
-               // position helper (lasso)
-               this.helper.css({
-                       "left": event.pageX,
-                       "top": event.pageY,
-                       "width": 0,
-                       "height": 0
-               });
-
-               if (options.autoRefresh) {
-                       this.refresh();
-               }
-
-               this.selectees.filter(".ui-selected").each(function() {
-                       var selectee = $.data(this, "selectable-item");
-                       selectee.startselected = true;
-                       if (!event.metaKey && !event.ctrlKey) {
-                               selectee.$element.removeClass("ui-selected");
-                               selectee.selected = false;
-                               selectee.$element.addClass("ui-unselecting");
-                               selectee.unselecting = true;
-                               // selectable UNSELECTING callback
-                               that._trigger("unselecting", event, {
-                                       unselecting: selectee.element
-                               });
-                       }
-               });
-
-               $(event.target).parents().addBack().each(function() {
-                       var doSelect,
-                               selectee = $.data(this, "selectable-item");
-                       if (selectee) {
-                               doSelect = (!event.metaKey && !event.ctrlKey) || !selectee.$element.hasClass("ui-selected");
-                               selectee.$element
-                                       .removeClass(doSelect ? "ui-unselecting" : "ui-selected")
-                                       .addClass(doSelect ? "ui-selecting" : "ui-unselecting");
-                               selectee.unselecting = !doSelect;
-                               selectee.selecting = doSelect;
-                               selectee.selected = doSelect;
-                               // selectable (UN)SELECTING callback
-                               if (doSelect) {
-                                       that._trigger("selecting", event, {
-                                               selecting: selectee.element
-                                       });
-                               } else {
-                                       that._trigger("unselecting", event, {
-                                               unselecting: selectee.element
-                                       });
-                               }
-                               return false;
-                       }
-               });
-
-       },
-
-       _mouseDrag: function(event) {
-
-               this.dragged = true;
-
-               if (this.options.disabled) {
-                       return;
-               }
-
-               var tmp,
-                       that = this,
-                       options = this.options,
-                       x1 = this.opos[0],
-                       y1 = this.opos[1],
-                       x2 = event.pageX,
-                       y2 = event.pageY;
-
-               if (x1 > x2) { tmp = x2; x2 = x1; x1 = tmp; }
-               if (y1 > y2) { tmp = y2; y2 = y1; y1 = tmp; }
-               this.helper.css({left: x1, top: y1, width: x2-x1, height: y2-y1});
-
-               this.selectees.each(function() {
-                       var selectee = $.data(this, "selectable-item"),
-                               hit = false;
-
-                       //prevent helper from being selected if appendTo: selectable
-                       if (!selectee || selectee.element === that.element[0]) {
-                               return;
-                       }
-
-                       if (options.tolerance === "touch") {
-                               hit = ( !(selectee.left > x2 || selectee.right < x1 || selectee.top > y2 || selectee.bottom < y1) );
-                       } else if (options.tolerance === "fit") {
-                               hit = (selectee.left > x1 && selectee.right < x2 && selectee.top > y1 && selectee.bottom < y2);
-                       }
-
-                       if (hit) {
-                               // SELECT
-                               if (selectee.selected) {
-                                       selectee.$element.removeClass("ui-selected");
-                                       selectee.selected = false;
-                               }
-                               if (selectee.unselecting) {
-                                       selectee.$element.removeClass("ui-unselecting");
-                                       selectee.unselecting = false;
-                               }
-                               if (!selectee.selecting) {
-                                       selectee.$element.addClass("ui-selecting");
-                                       selectee.selecting = true;
-                                       // selectable SELECTING callback
-                                       that._trigger("selecting", event, {
-                                               selecting: selectee.element
-                                       });
-                               }
-                       } else {
-                               // UNSELECT
-                               if (selectee.selecting) {
-                                       if ((event.metaKey || event.ctrlKey) && selectee.startselected) {
-                                               selectee.$element.removeClass("ui-selecting");
-                                               selectee.selecting = false;
-                                               selectee.$element.addClass("ui-selected");
-                                               selectee.selected = true;
-                                       } else {
-                                               selectee.$element.removeClass("ui-selecting");
-                                               selectee.selecting = false;
-                                               if (selectee.startselected) {
-                                                       selectee.$element.addClass("ui-unselecting");
-                                                       selectee.unselecting = true;
-                                               }
-                                               // selectable UNSELECTING callback
-                                               that._trigger("unselecting", event, {
-                                                       unselecting: selectee.element
-                                               });
-                                       }
-                               }
-                               if (selectee.selected) {
-                                       if (!event.metaKey && !event.ctrlKey && !selectee.startselected) {
-                                               selectee.$element.removeClass("ui-selected");
-                                               selectee.selected = false;
-
-                                               selectee.$element.addClass("ui-unselecting");
-                                               selectee.unselecting = true;
-                                               // selectable UNSELECTING callback
-                                               that._trigger("unselecting", event, {
-                                                       unselecting: selectee.element
-                                               });
-                                       }
-                               }
-                       }
-               });
-
-               return false;
-       },
-
-       _mouseStop: function(event) {
-               var that = this;
-
-               this.dragged = false;
-
-               $(".ui-unselecting", this.element[0]).each(function() {
-                       var selectee = $.data(this, "selectable-item");
-                       selectee.$element.removeClass("ui-unselecting");
-                       selectee.unselecting = false;
-                       selectee.startselected = false;
-                       that._trigger("unselected", event, {
-                               unselected: selectee.element
-                       });
-               });
-               $(".ui-selecting", this.element[0]).each(function() {
-                       var selectee = $.data(this, "selectable-item");
-                       selectee.$element.removeClass("ui-selecting").addClass("ui-selected");
-                       selectee.selecting = false;
-                       selectee.selected = true;
-                       selectee.startselected = true;
-                       that._trigger("selected", event, {
-                               selected: selectee.element
-                       });
-               });
-               this._trigger("stop", event);
-
-               this.helper.remove();
-
-               return false;
-       }
-
-});
-
-})(jQuery);
-(function( $, undefined ) {
-
-// number of pages in a slider
-// (how many times can you page up/down to go through the whole range)
-var numPages = 5;
-
-$.widget( "ui.slider", $.ui.mouse, {
-       version: "1.10.4",
-       widgetEventPrefix: "slide",
-
-       options: {
-               animate: false,
-               distance: 0,
-               max: 100,
-               min: 0,
-               orientation: "horizontal",
-               range: false,
-               step: 1,
-               value: 0,
-               values: null,
-
-               // callbacks
-               change: null,
-               slide: null,
-               start: null,
-               stop: null
-       },
-
-       _create: function() {
-               this._keySliding = false;
-               this._mouseSliding = false;
-               this._animateOff = true;
-               this._handleIndex = null;
-               this._detectOrientation();
-               this._mouseInit();
-
-               this.element
-                       .addClass( "ui-slider" +
-                               " ui-slider-" + this.orientation +
-                               " ui-widget" +
-                               " ui-widget-content" +
-                               " ui-corner-all");
-
-               this._refresh();
-               this._setOption( "disabled", this.options.disabled );
-
-               this._animateOff = false;
-       },
-
-       _refresh: function() {
-               this._createRange();
-               this._createHandles();
-               this._setupEvents();
-               this._refreshValue();
-       },
-
-       _createHandles: function() {
-               var i, handleCount,
-                       options = this.options,
-                       existingHandles = this.element.find( ".ui-slider-handle" ).addClass( "ui-state-default ui-corner-all" ),
-                       handle = "<a class='ui-slider-handle ui-state-default ui-corner-all' href='#'></a>",
-                       handles = [];
-
-               handleCount = ( options.values && options.values.length ) || 1;
-
-               if ( existingHandles.length > handleCount ) {
-                       existingHandles.slice( handleCount ).remove();
-                       existingHandles = existingHandles.slice( 0, handleCount );
-               }
-
-               for ( i = existingHandles.length; i < handleCount; i++ ) {
-                       handles.push( handle );
-               }
-
-               this.handles = existingHandles.add( $( handles.join( "" ) ).appendTo( this.element ) );
-
-               this.handle = this.handles.eq( 0 );
-
-               this.handles.each(function( i ) {
-                       $( this ).data( "ui-slider-handle-index", i );
-               });
-       },
-
-       _createRange: function() {
-               var options = this.options,
-                       classes = "";
-
-               if ( options.range ) {
-                       if ( options.range === true ) {
-                               if ( !options.values ) {
-                                       options.values = [ this._valueMin(), this._valueMin() ];
-                               } else if ( options.values.length && options.values.length !== 2 ) {
-                                       options.values = [ options.values[0], options.values[0] ];
-                               } else if ( $.isArray( options.values ) ) {
-                                       options.values = options.values.slice(0);
-                               }
-                       }
-
-                       if ( !this.range || !this.range.length ) {
-                               this.range = $( "<div></div>" )
-                                       .appendTo( this.element );
-
-                               classes = "ui-slider-range" +
-                               // note: this isn't the most fittingly semantic framework class for this element,
-                               // but worked best visually with a variety of themes
-                               " ui-widget-header ui-corner-all";
-                       } else {
-                               this.range.removeClass( "ui-slider-range-min ui-slider-range-max" )
-                                       // Handle range switching from true to min/max
-                                       .css({
-                                               "left": "",
-                                               "bottom": ""
-                                       });
-                       }
-
-                       this.range.addClass( classes +
-                               ( ( options.range === "min" || options.range === "max" ) ? " ui-slider-range-" + options.range : "" ) );
-               } else {
-                       if ( this.range ) {
-                               this.range.remove();
-                       }
-                       this.range = null;
-               }
-       },
-
-       _setupEvents: function() {
-               var elements = this.handles.add( this.range ).filter( "a" );
-               this._off( elements );
-               this._on( elements, this._handleEvents );
-               this._hoverable( elements );
-               this._focusable( elements );
-       },
-
-       _destroy: function() {
-               this.handles.remove();
-               if ( this.range ) {
-                       this.range.remove();
-               }
-
-               this.element
-                       .removeClass( "ui-slider" +
-                               " ui-slider-horizontal" +
-                               " ui-slider-vertical" +
-                               " ui-widget" +
-                               " ui-widget-content" +
-                               " ui-corner-all" );
-
-               this._mouseDestroy();
-       },
-
-       _mouseCapture: function( event ) {
-               var position, normValue, distance, closestHandle, index, allowed, offset, mouseOverHandle,
-                       that = this,
-                       o = this.options;
-
-               if ( o.disabled ) {
-                       return false;
-               }
-
-               this.elementSize = {
-                       width: this.element.outerWidth(),
-                       height: this.element.outerHeight()
-               };
-               this.elementOffset = this.element.offset();
-
-               position = { x: event.pageX, y: event.pageY };
-               normValue = this._normValueFromMouse( position );
-               distance = this._valueMax() - this._valueMin() + 1;
-               this.handles.each(function( i ) {
-                       var thisDistance = Math.abs( normValue - that.values(i) );
-                       if (( distance > thisDistance ) ||
-                               ( distance === thisDistance &&
-                                       (i === that._lastChangedValue || that.values(i) === o.min ))) {
-                               distance = thisDistance;
-                               closestHandle = $( this );
-                               index = i;
-                       }
-               });
-
-               allowed = this._start( event, index );
-               if ( allowed === false ) {
-                       return false;
-               }
-               this._mouseSliding = true;
-
-               this._handleIndex = index;
-
-               closestHandle
-                       .addClass( "ui-state-active" )
-                       .focus();
-
-               offset = closestHandle.offset();
-               mouseOverHandle = !$( event.target ).parents().addBack().is( ".ui-slider-handle" );
-               this._clickOffset = mouseOverHandle ? { left: 0, top: 0 } : {
-                       left: event.pageX - offset.left - ( closestHandle.width() / 2 ),
-                       top: event.pageY - offset.top -
-                               ( closestHandle.height() / 2 ) -
-                               ( parseInt( closestHandle.css("borderTopWidth"), 10 ) || 0 ) -
-                               ( parseInt( closestHandle.css("borderBottomWidth"), 10 ) || 0) +
-                               ( parseInt( closestHandle.css("marginTop"), 10 ) || 0)
-               };
-
-               if ( !this.handles.hasClass( "ui-state-hover" ) ) {
-                       this._slide( event, index, normValue );
-               }
-               this._animateOff = true;
-               return true;
-       },
-
-       _mouseStart: function() {
-               return true;
-       },
-
-       _mouseDrag: function( event ) {
-               var position = { x: event.pageX, y: event.pageY },
-                       normValue = this._normValueFromMouse( position );
-
-               this._slide( event, this._handleIndex, normValue );
-
-               return false;
-       },
-
-       _mouseStop: function( event ) {
-               this.handles.removeClass( "ui-state-active" );
-               this._mouseSliding = false;
-
-               this._stop( event, this._handleIndex );
-               this._change( event, this._handleIndex );
-
-               this._handleIndex = null;
-               this._clickOffset = null;
-               this._animateOff = false;
-
-               return false;
-       },
-
-       _detectOrientation: function() {
-               this.orientation = ( this.options.orientation === "vertical" ) ? "vertical" : "horizontal";
-       },
-
-       _normValueFromMouse: function( position ) {
-               var pixelTotal,
-                       pixelMouse,
-                       percentMouse,
-                       valueTotal,
-                       valueMouse;
-
-               if ( this.orientation === "horizontal" ) {
-                       pixelTotal = this.elementSize.width;
-                       pixelMouse = position.x - this.elementOffset.left - ( this._clickOffset ? this._clickOffset.left : 0 );
-               } else {
-                       pixelTotal = this.elementSize.height;
-                       pixelMouse = position.y - this.elementOffset.top - ( this._clickOffset ? this._clickOffset.top : 0 );
-               }
-
-               percentMouse = ( pixelMouse / pixelTotal );
-               if ( percentMouse > 1 ) {
-                       percentMouse = 1;
-               }
-               if ( percentMouse < 0 ) {
-                       percentMouse = 0;
-               }
-               if ( this.orientation === "vertical" ) {
-                       percentMouse = 1 - percentMouse;
-               }
-
-               valueTotal = this._valueMax() - this._valueMin();
-               valueMouse = this._valueMin() + percentMouse * valueTotal;
-
-               return this._trimAlignValue( valueMouse );
-       },
-
-       _start: function( event, index ) {
-               var uiHash = {
-                       handle: this.handles[ index ],
-                       value: this.value()
-               };
-               if ( this.options.values && this.options.values.length ) {
-                       uiHash.value = this.values( index );
-                       uiHash.values = this.values();
-               }
-               return this._trigger( "start", event, uiHash );
-       },
-
-       _slide: function( event, index, newVal ) {
-               var otherVal,
-                       newValues,
-                       allowed;
-
-               if ( this.options.values && this.options.values.length ) {
-                       otherVal = this.values( index ? 0 : 1 );
-
-                       if ( ( this.options.values.length === 2 && this.options.range === true ) &&
-                                       ( ( index === 0 && newVal > otherVal) || ( index === 1 && newVal < otherVal ) )
-                               ) {
-                               newVal = otherVal;
-                       }
-
-                       if ( newVal !== this.values( index ) ) {
-                               newValues = this.values();
-                               newValues[ index ] = newVal;
-                               // A slide can be canceled by returning false from the slide callback
-                               allowed = this._trigger( "slide", event, {
-                                       handle: this.handles[ index ],
-                                       value: newVal,
-                                       values: newValues
-                               } );
-                               otherVal = this.values( index ? 0 : 1 );
-                               if ( allowed !== false ) {
-                                       this.values( index, newVal );
-                               }
-                       }
-               } else {
-                       if ( newVal !== this.value() ) {
-                               // A slide can be canceled by returning false from the slide callback
-                               allowed = this._trigger( "slide", event, {
-                                       handle: this.handles[ index ],
-                                       value: newVal
-                               } );
-                               if ( allowed !== false ) {
-                                       this.value( newVal );
-                               }
-                       }
-               }
-       },
-
-       _stop: function( event, index ) {
-               var uiHash = {
-                       handle: this.handles[ index ],
-                       value: this.value()
-               };
-               if ( this.options.values && this.options.values.length ) {
-                       uiHash.value = this.values( index );
-                       uiHash.values = this.values();
-               }
-
-               this._trigger( "stop", event, uiHash );
-       },
-
-       _change: function( event, index ) {
-               if ( !this._keySliding && !this._mouseSliding ) {
-                       var uiHash = {
-                               handle: this.handles[ index ],
-                               value: this.value()
-                       };
-                       if ( this.options.values && this.options.values.length ) {
-                               uiHash.value = this.values( index );
-                               uiHash.values = this.values();
-                       }
-
-                       //store the last changed value index for reference when handles overlap
-                       this._lastChangedValue = index;
-
-                       this._trigger( "change", event, uiHash );
-               }
-       },
-
-       value: function( newValue ) {
-               if ( arguments.length ) {
-                       this.options.value = this._trimAlignValue( newValue );
-                       this._refreshValue();
-                       this._change( null, 0 );
-                       return;
-               }
-
-               return this._value();
-       },
-
-       values: function( index, newValue ) {
-               var vals,
-                       newValues,
-                       i;
-
-               if ( arguments.length > 1 ) {
-                       this.options.values[ index ] = this._trimAlignValue( newValue );
-                       this._refreshValue();
-                       this._change( null, index );
-                       return;
-               }
-
-               if ( arguments.length ) {
-                       if ( $.isArray( arguments[ 0 ] ) ) {
-                               vals = this.options.values;
-                               newValues = arguments[ 0 ];
-                               for ( i = 0; i < vals.length; i += 1 ) {
-                                       vals[ i ] = this._trimAlignValue( newValues[ i ] );
-                                       this._change( null, i );
-                               }
-                               this._refreshValue();
-                       } else {
-                               if ( this.options.values && this.options.values.length ) {
-                                       return this._values( index );
-                               } else {
-                                       return this.value();
-                               }
-                       }
-               } else {
-                       return this._values();
-               }
-       },
-
-       _setOption: function( key, value ) {
-               var i,
-                       valsLength = 0;
-
-               if ( key === "range" && this.options.range === true ) {
-                       if ( value === "min" ) {
-                               this.options.value = this._values( 0 );
-                               this.options.values = null;
-                       } else if ( value === "max" ) {
-                               this.options.value = this._values( this.options.values.length-1 );
-                               this.options.values = null;
-                       }
-               }
-
-               if ( $.isArray( this.options.values ) ) {
-                       valsLength = this.options.values.length;
-               }
-
-               $.Widget.prototype._setOption.apply( this, arguments );
-
-               switch ( key ) {
-                       case "orientation":
-                               this._detectOrientation();
-                               this.element
-                                       .removeClass( "ui-slider-horizontal ui-slider-vertical" )
-                                       .addClass( "ui-slider-" + this.orientation );
-                               this._refreshValue();
-                               break;
-                       case "value":
-                               this._animateOff = true;
-                               this._refreshValue();
-                               this._change( null, 0 );
-                               this._animateOff = false;
-                               break;
-                       case "values":
-                               this._animateOff = true;
-                               this._refreshValue();
-                               for ( i = 0; i < valsLength; i += 1 ) {
-                                       this._change( null, i );
-                               }
-                               this._animateOff = false;
-                               break;
-                       case "min":
-                       case "max":
-                               this._animateOff = true;
-                               this._refreshValue();
-                               this._animateOff = false;
-                               break;
-                       case "range":
-                               this._animateOff = true;
-                               this._refresh();
-                               this._animateOff = false;
-                               break;
-               }
-       },
-
-       //internal value getter
-       // _value() returns value trimmed by min and max, aligned by step
-       _value: function() {
-               var val = this.options.value;
-               val = this._trimAlignValue( val );
-
-               return val;
-       },
-
-       //internal values getter
-       // _values() returns array of values trimmed by min and max, aligned by step
-       // _values( index ) returns single value trimmed by min and max, aligned by step
-       _values: function( index ) {
-               var val,
-                       vals,
-                       i;
-
-               if ( arguments.length ) {
-                       val = this.options.values[ index ];
-                       val = this._trimAlignValue( val );
-
-                       return val;
-               } else if ( this.options.values && this.options.values.length ) {
-                       // .slice() creates a copy of the array
-                       // this copy gets trimmed by min and max and then returned
-                       vals = this.options.values.slice();
-                       for ( i = 0; i < vals.length; i+= 1) {
-                               vals[ i ] = this._trimAlignValue( vals[ i ] );
-                       }
-
-                       return vals;
-               } else {
-                       return [];
-               }
-       },
-
-       // returns the step-aligned value that val is closest to, between (inclusive) min and max
-       _trimAlignValue: function( val ) {
-               if ( val <= this._valueMin() ) {
-                       return this._valueMin();
-               }
-               if ( val >= this._valueMax() ) {
-                       return this._valueMax();
-               }
-               var step = ( this.options.step > 0 ) ? this.options.step : 1,
-                       valModStep = (val - this._valueMin()) % step,
-                       alignValue = val - valModStep;
-
-               if ( Math.abs(valModStep) * 2 >= step ) {
-                       alignValue += ( valModStep > 0 ) ? step : ( -step );
-               }
-
-               // Since JavaScript has problems with large floats, round
-               // the final value to 5 digits after the decimal point (see #4124)
-               return parseFloat( alignValue.toFixed(5) );
-       },
-
-       _valueMin: function() {
-               return this.options.min;
-       },
-
-       _valueMax: function() {
-               return this.options.max;
-       },
-
-       _refreshValue: function() {
-               var lastValPercent, valPercent, value, valueMin, valueMax,
-                       oRange = this.options.range,
-                       o = this.options,
-                       that = this,
-                       animate = ( !this._animateOff ) ? o.animate : false,
-                       _set = {};
-
-               if ( this.options.values && this.options.values.length ) {
-                       this.handles.each(function( i ) {
-                               valPercent = ( that.values(i) - that._valueMin() ) / ( that._valueMax() - that._valueMin() ) * 100;
-                               _set[ that.orientation === "horizontal" ? "left" : "bottom" ] = valPercent + "%";
-                               $( this ).stop( 1, 1 )[ animate ? "animate" : "css" ]( _set, o.animate );
-                               if ( that.options.range === true ) {
-                                       if ( that.orientation === "horizontal" ) {
-                                               if ( i === 0 ) {
-                                                       that.range.stop( 1, 1 )[ animate ? "animate" : "css" ]( { left: valPercent + "%" }, o.animate );
-                                               }
-                                               if ( i === 1 ) {
-                                                       that.range[ animate ? "animate" : "css" ]( { width: ( valPercent - lastValPercent ) + "%" }, { queue: false, duration: o.animate } );
-                                               }
-                                       } else {
-                                               if ( i === 0 ) {
-                                                       that.range.stop( 1, 1 )[ animate ? "animate" : "css" ]( { bottom: ( valPercent ) + "%" }, o.animate );
-                                               }
-                                               if ( i === 1 ) {
-                                                       that.range[ animate ? "animate" : "css" ]( { height: ( valPercent - lastValPercent ) + "%" }, { queue: false, duration: o.animate } );
-                                               }
-                                       }
-                               }
-                               lastValPercent = valPercent;
-                       });
-               } else {
-                       value = this.value();
-                       valueMin = this._valueMin();
-                       valueMax = this._valueMax();
-                       valPercent = ( valueMax !== valueMin ) ?
-                                       ( value - valueMin ) / ( valueMax - valueMin ) * 100 :
-                                       0;
-                       _set[ this.orientation === "horizontal" ? "left" : "bottom" ] = valPercent + "%";
-                       this.handle.stop( 1, 1 )[ animate ? "animate" : "css" ]( _set, o.animate );
-
-                       if ( oRange === "min" && this.orientation === "horizontal" ) {
-                               this.range.stop( 1, 1 )[ animate ? "animate" : "css" ]( { width: valPercent + "%" }, o.animate );
-                       }
-                       if ( oRange === "max" && this.orientation === "horizontal" ) {
-                               this.range[ animate ? "animate" : "css" ]( { width: ( 100 - valPercent ) + "%" }, { queue: false, duration: o.animate } );
-                       }
-                       if ( oRange === "min" && this.orientation === "vertical" ) {
-                               this.range.stop( 1, 1 )[ animate ? "animate" : "css" ]( { height: valPercent + "%" }, o.animate );
-                       }
-                       if ( oRange === "max" && this.orientation === "vertical" ) {
-                               this.range[ animate ? "animate" : "css" ]( { height: ( 100 - valPercent ) + "%" }, { queue: false, duration: o.animate } );
-                       }
-               }
-       },
-
-       _handleEvents: {
-               keydown: function( event ) {
-                       var allowed, curVal, newVal, step,
-                               index = $( event.target ).data( "ui-slider-handle-index" );
-
-                       switch ( event.keyCode ) {
-                               case $.ui.keyCode.HOME:
-                               case $.ui.keyCode.END:
-                               case $.ui.keyCode.PAGE_UP:
-                               case $.ui.keyCode.PAGE_DOWN:
-                               case $.ui.keyCode.UP:
-                               case $.ui.keyCode.RIGHT:
-                               case $.ui.keyCode.DOWN:
-                               case $.ui.keyCode.LEFT:
-                                       event.preventDefault();
-                                       if ( !this._keySliding ) {
-                                               this._keySliding = true;
-                                               $( event.target ).addClass( "ui-state-active" );
-                                               allowed = this._start( event, index );
-                                               if ( allowed === false ) {
-                                                       return;
-                                               }
-                                       }
-                                       break;
-                       }
-
-                       step = this.options.step;
-                       if ( this.options.values && this.options.values.length ) {
-                               curVal = newVal = this.values( index );
-                       } else {
-                               curVal = newVal = this.value();
-                       }
-
-                       switch ( event.keyCode ) {
-                               case $.ui.keyCode.HOME:
-                                       newVal = this._valueMin();
-                                       break;
-                               case $.ui.keyCode.END:
-                                       newVal = this._valueMax();
-                                       break;
-                               case $.ui.keyCode.PAGE_UP:
-                                       newVal = this._trimAlignValue( curVal + ( (this._valueMax() - this._valueMin()) / numPages ) );
-                                       break;
-                               case $.ui.keyCode.PAGE_DOWN:
-                                       newVal = this._trimAlignValue( curVal - ( (this._valueMax() - this._valueMin()) / numPages ) );
-                                       break;
-                               case $.ui.keyCode.UP:
-                               case $.ui.keyCode.RIGHT:
-                                       if ( curVal === this._valueMax() ) {
-                                               return;
-                                       }
-                                       newVal = this._trimAlignValue( curVal + step );
-                                       break;
-                               case $.ui.keyCode.DOWN:
-                               case $.ui.keyCode.LEFT:
-                                       if ( curVal === this._valueMin() ) {
-                                               return;
-                                       }
-                                       newVal = this._trimAlignValue( curVal - step );
-                                       break;
-                       }
-
-                       this._slide( event, index, newVal );
-               },
-               click: function( event ) {
-                       event.preventDefault();
-               },
-               keyup: function( event ) {
-                       var index = $( event.target ).data( "ui-slider-handle-index" );
-
-                       if ( this._keySliding ) {
-                               this._keySliding = false;
-                               this._stop( event, index );
-                               this._change( event, index );
-                               $( event.target ).removeClass( "ui-state-active" );
-                       }
-               }
-       }
-
-});
-
-}(jQuery));
-(function( $, undefined ) {
-
-function isOverAxis( x, reference, size ) {
-       return ( x > reference ) && ( x < ( reference + size ) );
-}
-
-function isFloating(item) {
-       return (/left|right/).test(item.css("float")) || (/inline|table-cell/).test(item.css("display"));
-}
-
-$.widget("ui.sortable", $.ui.mouse, {
-       version: "1.10.4",
-       widgetEventPrefix: "sort",
-       ready: false,
-       options: {
-               appendTo: "parent",
-               axis: false,
-               connectWith: false,
-               containment: false,
-               cursor: "auto",
-               cursorAt: false,
-               dropOnEmpty: true,
-               forcePlaceholderSize: false,
-               forceHelperSize: false,
-               grid: false,
-               handle: false,
-               helper: "original",
-               items: "> *",
-               opacity: false,
-               placeholder: false,
-               revert: false,
-               scroll: true,
-               scrollSensitivity: 20,
-               scrollSpeed: 20,
-               scope: "default",
-               tolerance: "intersect",
-               zIndex: 1000,
-
-               // callbacks
-               activate: null,
-               beforeStop: null,
-               change: null,
-               deactivate: null,
-               out: null,
-               over: null,
-               receive: null,
-               remove: null,
-               sort: null,
-               start: null,
-               stop: null,
-               update: null
-       },
-       _create: function() {
-
-               var o = this.options;
-               this.containerCache = {};
-               this.element.addClass("ui-sortable");
-
-               //Get the items
-               this.refresh();
-
-               //Let's determine if the items are being displayed horizontally
-               this.floating = this.items.length ? o.axis === "x" || isFloating(this.items[0].item) : false;
-
-               //Let's determine the parent's offset
-               this.offset = this.element.offset();
-
-               //Initialize mouse events for interaction
-               this._mouseInit();
-
-               //We're ready to go
-               this.ready = true;
-
-       },
-
-       _destroy: function() {
-               this.element
-                       .removeClass("ui-sortable ui-sortable-disabled");
-               this._mouseDestroy();
-
-               for ( var i = this.items.length - 1; i >= 0; i-- ) {
-                       this.items[i].item.removeData(this.widgetName + "-item");
-               }
-
-               return this;
-       },
-
-       _setOption: function(key, value){
-               if ( key === "disabled" ) {
-                       this.options[ key ] = value;
-
-                       this.widget().toggleClass( "ui-sortable-disabled", !!value );
-               } else {
-                       // Don't call widget base _setOption for disable as it adds ui-state-disabled class
-                       $.Widget.prototype._setOption.apply(this, arguments);
-               }
-       },
-
-       _mouseCapture: function(event, overrideHandle) {
-               var currentItem = null,
-                       validHandle = false,
-                       that = this;
-
-               if (this.reverting) {
-                       return false;
-               }
-
-               if(this.options.disabled || this.options.type === "static") {
-                       return false;
-               }
-
-               //We have to refresh the items data once first
-               this._refreshItems(event);
-
-               //Find out if the clicked node (or one of its parents) is a actual item in this.items
-               $(event.target).parents().each(function() {
-                       if($.data(this, that.widgetName + "-item") === that) {
-                               currentItem = $(this);
-                               return false;
-                       }
-               });
-               if($.data(event.target, that.widgetName + "-item") === that) {
-                       currentItem = $(event.target);
-               }
-
-               if(!currentItem) {
-                       return false;
-               }
-               if(this.options.handle && !overrideHandle) {
-                       $(this.options.handle, currentItem).find("*").addBack().each(function() {
-                               if(this === event.target) {
-                                       validHandle = true;
-                               }
-                       });
-                       if(!validHandle) {
-                               return false;
-                       }
-               }
-
-               this.currentItem = currentItem;
-               this._removeCurrentsFromItems();
-               return true;
-
-       },
-
-       _mouseStart: function(event, overrideHandle, noActivation) {
-
-               var i, body,
-                       o = this.options;
-
-               this.currentContainer = this;
-
-               //We only need to call refreshPositions, because the refreshItems call has been moved to mouseCapture
-               this.refreshPositions();
-
-               //Create and append the visible helper
-               this.helper = this._createHelper(event);
-
-               //Cache the helper size
-               this._cacheHelperProportions();
-
-               /*
-                * - Position generation -
-                * This block generates everything position related - it's the core of draggables.
-                */
-
-               //Cache the margins of the original element
-               this._cacheMargins();
-
-               //Get the next scrolling parent
-               this.scrollParent = this.helper.scrollParent();
-
-               //The element's absolute position on the page minus margins
-               this.offset = this.currentItem.offset();
-               this.offset = {
-                       top: this.offset.top - this.margins.top,
-                       left: this.offset.left - this.margins.left
-               };
-
-               $.extend(this.offset, {
-                       click: { //Where the click happened, relative to the element
-                               left: event.pageX - this.offset.left,
-                               top: event.pageY - this.offset.top
-                       },
-                       parent: this._getParentOffset(),
-                       relative: this._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper
-               });
-
-               // Only after we got the offset, we can change the helper's position to absolute
-               // TODO: Still need to figure out a way to make relative sorting possible
-               this.helper.css("position", "absolute");
-               this.cssPosition = this.helper.css("position");
-
-               //Generate the original position
-               this.originalPosition = this._generatePosition(event);
-               this.originalPageX = event.pageX;
-               this.originalPageY = event.pageY;
-
-               //Adjust the mouse offset relative to the helper if "cursorAt" is supplied
-               (o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));
-
-               //Cache the former DOM position
-               this.domPosition = { prev: this.currentItem.prev()[0], parent: this.currentItem.parent()[0] };
-
-               //If the helper is not the original, hide the original so it's not playing any role during the drag, won't cause anything bad this way
-               if(this.helper[0] !== this.currentItem[0]) {
-                       this.currentItem.hide();
-               }
-
-               //Create the placeholder
-               this._createPlaceholder();
-
-               //Set a containment if given in the options
-               if(o.containment) {
-                       this._setContainment();
-               }
-
-               if( o.cursor && o.cursor !== "auto" ) { // cursor option
-                       body = this.document.find( "body" );
-
-                       // support: IE
-                       this.storedCursor = body.css( "cursor" );
-                       body.css( "cursor", o.cursor );
-
-                       this.storedStylesheet = $( "<style>*{ cursor: "+o.cursor+" !important; }</style>" ).appendTo( body );
-               }
-
-               if(o.opacity) { // opacity option
-                       if (this.helper.css("opacity")) {
-                               this._storedOpacity = this.helper.css("opacity");
-                       }
-                       this.helper.css("opacity", o.opacity);
-               }
-
-               if(o.zIndex) { // zIndex option
-                       if (this.helper.css("zIndex")) {
-                               this._storedZIndex = this.helper.css("zIndex");
-                       }
-                       this.helper.css("zIndex", o.zIndex);
-               }
-
-               //Prepare scrolling
-               if(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== "HTML") {
-                       this.overflowOffset = this.scrollParent.offset();
-               }
-
-               //Call callbacks
-               this._trigger("start", event, this._uiHash());
-
-               //Recache the helper size
-               if(!this._preserveHelperProportions) {
-                       this._cacheHelperProportions();
-               }
-
-
-               //Post "activate" events to possible containers
-               if( !noActivation ) {
-                       for ( i = this.containers.length - 1; i >= 0; i-- ) {
-                               this.containers[ i ]._trigger( "activate", event, this._uiHash( this ) );
-                       }
-               }
-
-               //Prepare possible droppables
-               if($.ui.ddmanager) {
-                       $.ui.ddmanager.current = this;
-               }
-
-               if ($.ui.ddmanager && !o.dropBehaviour) {
-                       $.ui.ddmanager.prepareOffsets(this, event);
-               }
-
-               this.dragging = true;
-
-               this.helper.addClass("ui-sortable-helper");
-               this._mouseDrag(event); //Execute the drag once - this causes the helper not to be visible before getting its correct position
-               return true;
-
-       },
-
-       _mouseDrag: function(event) {
-               var i, item, itemElement, intersection,
-                       o = this.options,
-                       scrolled = false;
-
-               //Compute the helpers position
-               this.position = this._generatePosition(event);
-               this.positionAbs = this._convertPositionTo("absolute");
-
-               if (!this.lastPositionAbs) {
-                       this.lastPositionAbs = this.positionAbs;
-               }
-
-               //Do scrolling
-               if(this.options.scroll) {
-                       if(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== "HTML") {
-
-                               if((this.overflowOffset.top + this.scrollParent[0].offsetHeight) - event.pageY < o.scrollSensitivity) {
-                                       this.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop + o.scrollSpeed;
-                               } else if(event.pageY - this.overflowOffset.top < o.scrollSensitivity) {
-                                       this.scrollParent[0].scrollTop = scrolled = this.scrollParent[0].scrollTop - o.scrollSpeed;
-                               }
-
-                               if((this.overflowOffset.left + this.scrollParent[0].offsetWidth) - event.pageX < o.scrollSensitivity) {
-                                       this.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft + o.scrollSpeed;
-                               } else if(event.pageX - this.overflowOffset.left < o.scrollSensitivity) {
-                                       this.scrollParent[0].scrollLeft = scrolled = this.scrollParent[0].scrollLeft - o.scrollSpeed;
-                               }
-
-                       } else {
-
-                               if(event.pageY - $(document).scrollTop() < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);
-                               } else if($(window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);
-                               }
-
-                               if(event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);
-                               } else if($(window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {
-                                       scrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);
-                               }
-
-                       }
-
-                       if(scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {
-                               $.ui.ddmanager.prepareOffsets(this, event);
-                       }
-               }
-
-               //Regenerate the absolute position used for position checks
-               this.positionAbs = this._convertPositionTo("absolute");
-
-               //Set the helper position
-               if(!this.options.axis || this.options.axis !== "y") {
-                       this.helper[0].style.left = this.position.left+"px";
-               }
-               if(!this.options.axis || this.options.axis !== "x") {
-                       this.helper[0].style.top = this.position.top+"px";
-               }
-
-               //Rearrange
-               for (i = this.items.length - 1; i >= 0; i--) {
-
-                       //Cache variables and intersection, continue if no intersection
-                       item = this.items[i];
-                       itemElement = item.item[0];
-                       intersection = this._intersectsWithPointer(item);
-                       if (!intersection) {
-                               continue;
-                       }
-
-                       // Only put the placeholder inside the current Container, skip all
-                       // items from other containers. This works because when moving
-                       // an item from one container to another the
-                       // currentContainer is switched before the placeholder is moved.
-                       //
-                       // Without this, moving items in "sub-sortables" can cause
-                       // the placeholder to jitter beetween the outer and inner container.
-                       if (item.instance !== this.currentContainer) {
-                               continue;
-                       }
-
-                       // cannot intersect with itself
-                       // no useless actions that have been done before
-                       // no action if the item moved is the parent of the item checked
-                       if (itemElement !== this.currentItem[0] &&
-                               this.placeholder[intersection === 1 ? "next" : "prev"]()[0] !== itemElement &&
-                               !$.contains(this.placeholder[0], itemElement) &&
-                               (this.options.type === "semi-dynamic" ? !$.contains(this.element[0], itemElement) : true)
-                       ) {
-
-                               this.direction = intersection === 1 ? "down" : "up";
-
-                               if (this.options.tolerance === "pointer" || this._intersectsWithSides(item)) {
-                                       this._rearrange(event, item);
-                               } else {
-                                       break;
-                               }
-
-                               this._trigger("change", event, this._uiHash());
-                               break;
-                       }
-               }
-
-               //Post events to containers
-               this._contactContainers(event);
-
-               //Interconnect with droppables
-               if($.ui.ddmanager) {
-                       $.ui.ddmanager.drag(this, event);
-               }
-
-               //Call callbacks
-               this._trigger("sort", event, this._uiHash());
-
-               this.lastPositionAbs = this.positionAbs;
-               return false;
-
-       },
-
-       _mouseStop: function(event, noPropagation) {
-
-               if(!event) {
-                       return;
-               }
-
-               //If we are using droppables, inform the manager about the drop
-               if ($.ui.ddmanager && !this.options.dropBehaviour) {
-                       $.ui.ddmanager.drop(this, event);
-               }
-
-               if(this.options.revert) {
-                       var that = this,
-                               cur = this.placeholder.offset(),
-                               axis = this.options.axis,
-                               animation = {};
-
-                       if ( !axis || axis === "x" ) {
-                               animation.left = cur.left - this.offset.parent.left - this.margins.left + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollLeft);
-                       }
-                       if ( !axis || axis === "y" ) {
-                               animation.top = cur.top - this.offset.parent.top - this.margins.top + (this.offsetParent[0] === document.body ? 0 : this.offsetParent[0].scrollTop);
-                       }
-                       this.reverting = true;
-                       $(this.helper).animate( animation, parseInt(this.options.revert, 10) || 500, function() {
-                               that._clear(event);
-                       });
-               } else {
-                       this._clear(event, noPropagation);
-               }
-
-               return false;
-
-       },
-
-       cancel: function() {
-
-               if(this.dragging) {
-
-                       this._mouseUp({ target: null });
-
-                       if(this.options.helper === "original") {
-                               this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper");
-                       } else {
-                               this.currentItem.show();
-                       }
-
-                       //Post deactivating events to containers
-                       for (var i = this.containers.length - 1; i >= 0; i--){
-                               this.containers[i]._trigger("deactivate", null, this._uiHash(this));
-                               if(this.containers[i].containerCache.over) {
-                                       this.containers[i]._trigger("out", null, this._uiHash(this));
-                                       this.containers[i].containerCache.over = 0;
-                               }
-                       }
-
-               }
-
-               if (this.placeholder) {
-                       //$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
-                       if(this.placeholder[0].parentNode) {
-                               this.placeholder[0].parentNode.removeChild(this.placeholder[0]);
-                       }
-                       if(this.options.helper !== "original" && this.helper && this.helper[0].parentNode) {
-                               this.helper.remove();
-                       }
-
-                       $.extend(this, {
-                               helper: null,
-                               dragging: false,
-                               reverting: false,
-                               _noFinalSort: null
-                       });
-
-                       if(this.domPosition.prev) {
-                               $(this.domPosition.prev).after(this.currentItem);
-                       } else {
-                               $(this.domPosition.parent).prepend(this.currentItem);
-                       }
-               }
-
-               return this;
-
-       },
-
-       serialize: function(o) {
-
-               var items = this._getItemsAsjQuery(o && o.connected),
-                       str = [];
-               o = o || {};
-
-               $(items).each(function() {
-                       var res = ($(o.item || this).attr(o.attribute || "id") || "").match(o.expression || (/(.+)[\-=_](.+)/));
-                       if (res) {
-                               str.push((o.key || res[1]+"[]")+"="+(o.key && o.expression ? res[1] : res[2]));
-                       }
-               });
-
-               if(!str.length && o.key) {
-                       str.push(o.key + "=");
-               }
-
-               return str.join("&");
-
-       },
-
-       toArray: function(o) {
-
-               var items = this._getItemsAsjQuery(o && o.connected),
-                       ret = [];
-
-               o = o || {};
-
-               items.each(function() { ret.push($(o.item || this).attr(o.attribute || "id") || ""); });
-               return ret;
-
-       },
-
-       /* Be careful with the following core functions */
-       _intersectsWith: function(item) {
-
-               var x1 = this.positionAbs.left,
-                       x2 = x1 + this.helperProportions.width,
-                       y1 = this.positionAbs.top,
-                       y2 = y1 + this.helperProportions.height,
-                       l = item.left,
-                       r = l + item.width,
-                       t = item.top,
-                       b = t + item.height,
-                       dyClick = this.offset.click.top,
-                       dxClick = this.offset.click.left,
-                       isOverElementHeight = ( this.options.axis === "x" ) || ( ( y1 + dyClick ) > t && ( y1 + dyClick ) < b ),
-                       isOverElementWidth = ( this.options.axis === "y" ) || ( ( x1 + dxClick ) > l && ( x1 + dxClick ) < r ),
-                       isOverElement = isOverElementHeight && isOverElementWidth;
-
-               if ( this.options.tolerance === "pointer" ||
-                       this.options.forcePointerForContainers ||
-                       (this.options.tolerance !== "pointer" && this.helperProportions[this.floating ? "width" : "height"] > item[this.floating ? "width" : "height"])
-               ) {
-                       return isOverElement;
-               } else {
-
-                       return (l < x1 + (this.helperProportions.width / 2) && // Right Half
-                               x2 - (this.helperProportions.width / 2) < r && // Left Half
-                               t < y1 + (this.helperProportions.height / 2) && // Bottom Half
-                               y2 - (this.helperProportions.height / 2) < b ); // Top Half
-
-               }
-       },
-
-       _intersectsWithPointer: function(item) {
-
-               var isOverElementHeight = (this.options.axis === "x") || isOverAxis(this.positionAbs.top + this.offset.click.top, item.top, item.height),
-                       isOverElementWidth = (this.options.axis === "y") || isOverAxis(this.positionAbs.left + this.offset.click.left, item.left, item.width),
-                       isOverElement = isOverElementHeight && isOverElementWidth,
-                       verticalDirection = this._getDragVerticalDirection(),
-                       horizontalDirection = this._getDragHorizontalDirection();
-
-               if (!isOverElement) {
-                       return false;
-               }
-
-               return this.floating ?
-                       ( ((horizontalDirection && horizontalDirection === "right") || verticalDirection === "down") ? 2 : 1 )
-                       : ( verticalDirection && (verticalDirection === "down" ? 2 : 1) );
-
-       },
-
-       _intersectsWithSides: function(item) {
-
-               var isOverBottomHalf = isOverAxis(this.positionAbs.top + this.offset.click.top, item.top + (item.height/2), item.height),
-                       isOverRightHalf = isOverAxis(this.positionAbs.left + this.offset.click.left, item.left + (item.width/2), item.width),
-                       verticalDirection = this._getDragVerticalDirection(),
-                       horizontalDirection = this._getDragHorizontalDirection();
-
-               if (this.floating && horizontalDirection) {
-                       return ((horizontalDirection === "right" && isOverRightHalf) || (horizontalDirection === "left" && !isOverRightHalf));
-               } else {
-                       return verticalDirection && ((verticalDirection === "down" && isOverBottomHalf) || (verticalDirection === "up" && !isOverBottomHalf));
-               }
-
-       },
-
-       _getDragVerticalDirection: function() {
-               var delta = this.positionAbs.top - this.lastPositionAbs.top;
-               return delta !== 0 && (delta > 0 ? "down" : "up");
-       },
-
-       _getDragHorizontalDirection: function() {
-               var delta = this.positionAbs.left - this.lastPositionAbs.left;
-               return delta !== 0 && (delta > 0 ? "right" : "left");
-       },
-
-       refresh: function(event) {
-               this._refreshItems(event);
-               this.refreshPositions();
-               return this;
-       },
-
-       _connectWith: function() {
-               var options = this.options;
-               return options.connectWith.constructor === String ? [options.connectWith] : options.connectWith;
-       },
-
-       _getItemsAsjQuery: function(connected) {
-
-               var i, j, cur, inst,
-                       items = [],
-                       queries = [],
-                       connectWith = this._connectWith();
-
-               if(connectWith && connected) {
-                       for (i = connectWith.length - 1; i >= 0; i--){
-                               cur = $(connectWith[i]);
-                               for ( j = cur.length - 1; j >= 0; j--){
-                                       inst = $.data(cur[j], this.widgetFullName);
-                                       if(inst && inst !== this && !inst.options.disabled) {
-                                               queries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element) : $(inst.options.items, inst.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), inst]);
-                                       }
-                               }
-                       }
-               }
-
-               queries.push([$.isFunction(this.options.items) ? this.options.items.call(this.element, null, { options: this.options, item: this.currentItem }) : $(this.options.items, this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), this]);
-
-               function addItems() {
-                       items.push( this );
-               }
-               for (i = queries.length - 1; i >= 0; i--){
-                       queries[i][0].each( addItems );
-               }
-
-               return $(items);
-
-       },
-
-       _removeCurrentsFromItems: function() {
-
-               var list = this.currentItem.find(":data(" + this.widgetName + "-item)");
-
-               this.items = $.grep(this.items, function (item) {
-                       for (var j=0; j < list.length; j++) {
-                               if(list[j] === item.item[0]) {
-                                       return false;
-                               }
-                       }
-                       return true;
-               });
-
-       },
-
-       _refreshItems: function(event) {
-
-               this.items = [];
-               this.containers = [this];
-
-               var i, j, cur, inst, targetData, _queries, item, queriesLength,
-                       items = this.items,
-                       queries = [[$.isFunction(this.options.items) ? this.options.items.call(this.element[0], event, { item: this.currentItem }) : $(this.options.items, this.element), this]],
-                       connectWith = this._connectWith();
-
-               if(connectWith && this.ready) { //Shouldn't be run the first time through due to massive slow-down
-                       for (i = connectWith.length - 1; i >= 0; i--){
-                               cur = $(connectWith[i]);
-                               for (j = cur.length - 1; j >= 0; j--){
-                                       inst = $.data(cur[j], this.widgetFullName);
-                                       if(inst && inst !== this && !inst.options.disabled) {
-                                               queries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element[0], event, { item: this.currentItem }) : $(inst.options.items, inst.element), inst]);
-                                               this.containers.push(inst);
-                                       }
-                               }
-                       }
-               }
-
-               for (i = queries.length - 1; i >= 0; i--) {
-                       targetData = queries[i][1];
-                       _queries = queries[i][0];
-
-                       for (j=0, queriesLength = _queries.length; j < queriesLength; j++) {
-                               item = $(_queries[j]);
-
-                               item.data(this.widgetName + "-item", targetData); // Data for target checking (mouse manager)
-
-                               items.push({
-                                       item: item,
-                                       instance: targetData,
-                                       width: 0, height: 0,
-                                       left: 0, top: 0
-                               });
-                       }
-               }
-
-       },
-
-       refreshPositions: function(fast) {
-
-               //This has to be redone because due to the item being moved out/into the offsetParent, the offsetParent's position will change
-               if(this.offsetParent && this.helper) {
-                       this.offset.parent = this._getParentOffset();
-               }
-
-               var i, item, t, p;
-
-               for (i = this.items.length - 1; i >= 0; i--){
-                       item = this.items[i];
-
-                       //We ignore calculating positions of all connected containers when we're not over them
-                       if(item.instance !== this.currentContainer && this.currentContainer && item.item[0] !== this.currentItem[0]) {
-                               continue;
-                       }
-
-                       t = this.options.toleranceElement ? $(this.options.toleranceElement, item.item) : item.item;
-
-                       if (!fast) {
-                               item.width = t.outerWidth();
-                               item.height = t.outerHeight();
-                       }
-
-                       p = t.offset();
-                       item.left = p.left;
-                       item.top = p.top;
-               }
-
-               if(this.options.custom && this.options.custom.refreshContainers) {
-                       this.options.custom.refreshContainers.call(this);
-               } else {
-                       for (i = this.containers.length - 1; i >= 0; i--){
-                               p = this.containers[i].element.offset();
-                               this.containers[i].containerCache.left = p.left;
-                               this.containers[i].containerCache.top = p.top;
-                               this.containers[i].containerCache.width = this.containers[i].element.outerWidth();
-                               this.containers[i].containerCache.height = this.containers[i].element.outerHeight();
-                       }
-               }
-
-               return this;
-       },
-
-       _createPlaceholder: function(that) {
-               that = that || this;
-               var className,
-                       o = that.options;
-
-               if(!o.placeholder || o.placeholder.constructor === String) {
-                       className = o.placeholder;
-                       o.placeholder = {
-                               element: function() {
-
-                                       var nodeName = that.currentItem[0].nodeName.toLowerCase(),
-                                               element = $( "<" + nodeName + ">", that.document[0] )
-                                                       .addClass(className || that.currentItem[0].className+" ui-sortable-placeholder")
-                                                       .removeClass("ui-sortable-helper");
-
-                                       if ( nodeName === "tr" ) {
-                                               that.currentItem.children().each(function() {
-                                                       $( "<td>&#160;</td>", that.document[0] )
-                                                               .attr( "colspan", $( this ).attr( "colspan" ) || 1 )
-                                                               .appendTo( element );
-                                               });
-                                       } else if ( nodeName === "img" ) {
-                                               element.attr( "src", that.currentItem.attr( "src" ) );
-                                       }
-
-                                       if ( !className ) {
-                                               element.css( "visibility", "hidden" );
-                                       }
-
-                                       return element;
-                               },
-                               update: function(container, p) {
-
-                                       // 1. If a className is set as 'placeholder option, we don't force sizes - the class is responsible for that
-                                       // 2. The option 'forcePlaceholderSize can be enabled to force it even if a class name is specified
-                                       if(className && !o.forcePlaceholderSize) {
-                                               return;
-                                       }
-
-                                       //If the element doesn't have a actual height by itself (without styles coming from a stylesheet), it receives the inline height from the dragged item
-                                       if(!p.height()) { p.height(that.currentItem.innerHeight() - parseInt(that.currentItem.css("paddingTop")||0, 10) - parseInt(that.currentItem.css("paddingBottom")||0, 10)); }
-                                       if(!p.width()) { p.width(that.currentItem.innerWidth() - parseInt(that.currentItem.css("paddingLeft")||0, 10) - parseInt(that.currentItem.css("paddingRight")||0, 10)); }
-                               }
-                       };
-               }
-
-               //Create the placeholder
-               that.placeholder = $(o.placeholder.element.call(that.element, that.currentItem));
-
-               //Append it after the actual current item
-               that.currentItem.after(that.placeholder);
-
-               //Update the size of the placeholder (TODO: Logic to fuzzy, see line 316/317)
-               o.placeholder.update(that, that.placeholder);
-
-       },
-
-       _contactContainers: function(event) {
-               var i, j, dist, itemWithLeastDistance, posProperty, sizeProperty, base, cur, nearBottom, floating,
-                       innermostContainer = null,
-                       innermostIndex = null;
-
-               // get innermost container that intersects with item
-               for (i = this.containers.length - 1; i >= 0; i--) {
-
-                       // never consider a container that's located within the item itself
-                       if($.contains(this.currentItem[0], this.containers[i].element[0])) {
-                               continue;
-                       }
-
-                       if(this._intersectsWith(this.containers[i].containerCache)) {
-
-                               // if we've already found a container and it's more "inner" than this, then continue
-                               if(innermostContainer && $.contains(this.containers[i].element[0], innermostContainer.element[0])) {
-                                       continue;
-                               }
-
-                               innermostContainer = this.containers[i];
-                               innermostIndex = i;
-
-                       } else {
-                               // container doesn't intersect. trigger "out" event if necessary
-                               if(this.containers[i].containerCache.over) {
-                                       this.containers[i]._trigger("out", event, this._uiHash(this));
-                                       this.containers[i].containerCache.over = 0;
-                               }
-                       }
-
-               }
-
-               // if no intersecting containers found, return
-               if(!innermostContainer) {
-                       return;
-               }
-
-               // move the item into the container if it's not there already
-               if(this.containers.length === 1) {
-                       if (!this.containers[innermostIndex].containerCache.over) {
-                               this.containers[innermostIndex]._trigger("over", event, this._uiHash(this));
-                               this.containers[innermostIndex].containerCache.over = 1;
-                       }
-               } else {
-
-                       //When entering a new container, we will find the item with the least distance and append our item near it
-                       dist = 10000;
-                       itemWithLeastDistance = null;
-                       floating = innermostContainer.floating || isFloating(this.currentItem);
-                       posProperty = floating ? "left" : "top";
-                       sizeProperty = floating ? "width" : "height";
-                       base = this.positionAbs[posProperty] + this.offset.click[posProperty];
-                       for (j = this.items.length - 1; j >= 0; j--) {
-                               if(!$.contains(this.containers[innermostIndex].element[0], this.items[j].item[0])) {
-                                       continue;
-                               }
-                               if(this.items[j].item[0] === this.currentItem[0]) {
-                                       continue;
-                               }
-                               if (floating && !isOverAxis(this.positionAbs.top + this.offset.click.top, this.items[j].top, this.items[j].height)) {
-                                       continue;
-                               }
-                               cur = this.items[j].item.offset()[posProperty];
-                               nearBottom = false;
-                               if(Math.abs(cur - base) > Math.abs(cur + this.items[j][sizeProperty] - base)){
-                                       nearBottom = true;
-                                       cur += this.items[j][sizeProperty];
-                               }
-
-                               if(Math.abs(cur - base) < dist) {
-                                       dist = Math.abs(cur - base); itemWithLeastDistance = this.items[j];
-                                       this.direction = nearBottom ? "up": "down";
-                               }
-                       }
-
-                       //Check if dropOnEmpty is enabled
-                       if(!itemWithLeastDistance && !this.options.dropOnEmpty) {
-                               return;
-                       }
-
-                       if(this.currentContainer === this.containers[innermostIndex]) {
-                               return;
-                       }
-
-                       itemWithLeastDistance ? this._rearrange(event, itemWithLeastDistance, null, true) : this._rearrange(event, null, this.containers[innermostIndex].element, true);
-                       this._trigger("change", event, this._uiHash());
-                       this.containers[innermostIndex]._trigger("change", event, this._uiHash(this));
-                       this.currentContainer = this.containers[innermostIndex];
-
-                       //Update the placeholder
-                       this.options.placeholder.update(this.currentContainer, this.placeholder);
-
-                       this.containers[innermostIndex]._trigger("over", event, this._uiHash(this));
-                       this.containers[innermostIndex].containerCache.over = 1;
-               }
-
-
-       },
-
-       _createHelper: function(event) {
-
-               var o = this.options,
-                       helper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [event, this.currentItem])) : (o.helper === "clone" ? this.currentItem.clone() : this.currentItem);
-
-               //Add the helper to the DOM if that didn't happen already
-               if(!helper.parents("body").length) {
-                       $(o.appendTo !== "parent" ? o.appendTo : this.currentItem[0].parentNode)[0].appendChild(helper[0]);
-               }
-
-               if(helper[0] === this.currentItem[0]) {
-                       this._storedCSS = { width: this.currentItem[0].style.width, height: this.currentItem[0].style.height, position: this.currentItem.css("position"), top: this.currentItem.css("top"), left: this.currentItem.css("left") };
-               }
-
-               if(!helper[0].style.width || o.forceHelperSize) {
-                       helper.width(this.currentItem.width());
-               }
-               if(!helper[0].style.height || o.forceHelperSize) {
-                       helper.height(this.currentItem.height());
-               }
-
-               return helper;
-
-       },
-
-       _adjustOffsetFromHelper: function(obj) {
-               if (typeof obj === "string") {
-                       obj = obj.split(" ");
-               }
-               if ($.isArray(obj)) {
-                       obj = {left: +obj[0], top: +obj[1] || 0};
-               }
-               if ("left" in obj) {
-                       this.offset.click.left = obj.left + this.margins.left;
-               }
-               if ("right" in obj) {
-                       this.offset.click.left = this.helperProportions.width - obj.right + this.margins.left;
-               }
-               if ("top" in obj) {
-                       this.offset.click.top = obj.top + this.margins.top;
-               }
-               if ("bottom" in obj) {
-                       this.offset.click.top = this.helperProportions.height - obj.bottom + this.margins.top;
-               }
-       },
-
-       _getParentOffset: function() {
-
-
-               //Get the offsetParent and cache its position
-               this.offsetParent = this.helper.offsetParent();
-               var po = this.offsetParent.offset();
-
-               // This is a special case where we need to modify a offset calculated on start, since the following happened:
-               // 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent
-               // 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that
-               //    the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag
-               if(this.cssPosition === "absolute" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {
-                       po.left += this.scrollParent.scrollLeft();
-                       po.top += this.scrollParent.scrollTop();
-               }
-
-               // This needs to be actually done for all browsers, since pageX/pageY includes this information
-               // with an ugly IE fix
-               if( this.offsetParent[0] === document.body || (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === "html" && $.ui.ie)) {
-                       po = { top: 0, left: 0 };
-               }
-
-               return {
-                       top: po.top + (parseInt(this.offsetParent.css("borderTopWidth"),10) || 0),
-                       left: po.left + (parseInt(this.offsetParent.css("borderLeftWidth"),10) || 0)
-               };
-
-       },
-
-       _getRelativeOffset: function() {
-
-               if(this.cssPosition === "relative") {
-                       var p = this.currentItem.position();
-                       return {
-                               top: p.top - (parseInt(this.helper.css("top"),10) || 0) + this.scrollParent.scrollTop(),
-                               left: p.left - (parseInt(this.helper.css("left"),10) || 0) + this.scrollParent.scrollLeft()
-                       };
-               } else {
-                       return { top: 0, left: 0 };
-               }
-
-       },
-
-       _cacheMargins: function() {
-               this.margins = {
-                       left: (parseInt(this.currentItem.css("marginLeft"),10) || 0),
-                       top: (parseInt(this.currentItem.css("marginTop"),10) || 0)
-               };
-       },
-
-       _cacheHelperProportions: function() {
-               this.helperProportions = {
-                       width: this.helper.outerWidth(),
-                       height: this.helper.outerHeight()
-               };
-       },
-
-       _setContainment: function() {
-
-               var ce, co, over,
-                       o = this.options;
-               if(o.containment === "parent") {
-                       o.containment = this.helper[0].parentNode;
-               }
-               if(o.containment === "document" || o.containment === "window") {
-                       this.containment = [
-                               0 - this.offset.relative.left - this.offset.parent.left,
-                               0 - this.offset.relative.top - this.offset.parent.top,
-                               $(o.containment === "document" ? document : window).width() - this.helperProportions.width - this.margins.left,
-                               ($(o.containment === "document" ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top
-                       ];
-               }
-
-               if(!(/^(document|window|parent)$/).test(o.containment)) {
-                       ce = $(o.containment)[0];
-                       co = $(o.containment).offset();
-                       over = ($(ce).css("overflow") !== "hidden");
-
-                       this.containment = [
-                               co.left + (parseInt($(ce).css("borderLeftWidth"),10) || 0) + (parseInt($(ce).css("paddingLeft"),10) || 0) - this.margins.left,
-                               co.top + (parseInt($(ce).css("borderTopWidth"),10) || 0) + (parseInt($(ce).css("paddingTop"),10) || 0) - this.margins.top,
-                               co.left+(over ? Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css("borderLeftWidth"),10) || 0) - (parseInt($(ce).css("paddingRight"),10) || 0) - this.helperProportions.width - this.margins.left,
-                               co.top+(over ? Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css("borderTopWidth"),10) || 0) - (parseInt($(ce).css("paddingBottom"),10) || 0) - this.helperProportions.height - this.margins.top
-                       ];
-               }
-
-       },
-
-       _convertPositionTo: function(d, pos) {
-
-               if(!pos) {
-                       pos = this.position;
-               }
-               var mod = d === "absolute" ? 1 : -1,
-                       scroll = this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent,
-                       scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);
-
-               return {
-                       top: (
-                               pos.top +                                                                                                                               // The absolute mouse position
-                               this.offset.relative.top * mod +                                                                                // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.top * mod -                                                                                  // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ) * mod)
-                       ),
-                       left: (
-                               pos.left +                                                                                                                              // The absolute mouse position
-                               this.offset.relative.left * mod +                                                                               // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.left * mod   -                                                                               // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ) * mod)
-                       )
-               };
-
-       },
-
-       _generatePosition: function(event) {
-
-               var top, left,
-                       o = this.options,
-                       pageX = event.pageX,
-                       pageY = event.pageY,
-                       scroll = this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent : this.scrollParent, scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);
-
-               // This is another very weird special case that only happens for relative elements:
-               // 1. If the css position is relative
-               // 2. and the scroll parent is the document or similar to the offset parent
-               // we have to refresh the relative offset during the scroll so there are no jumps
-               if(this.cssPosition === "relative" && !(this.scrollParent[0] !== document && this.scrollParent[0] !== this.offsetParent[0])) {
-                       this.offset.relative = this._getRelativeOffset();
-               }
-
-               /*
-                * - Position constraining -
-                * Constrain the position to a mix of grid, containment.
-                */
-
-               if(this.originalPosition) { //If we are not dragging yet, we won't check for options
-
-                       if(this.containment) {
-                               if(event.pageX - this.offset.click.left < this.containment[0]) {
-                                       pageX = this.containment[0] + this.offset.click.left;
-                               }
-                               if(event.pageY - this.offset.click.top < this.containment[1]) {
-                                       pageY = this.containment[1] + this.offset.click.top;
-                               }
-                               if(event.pageX - this.offset.click.left > this.containment[2]) {
-                                       pageX = this.containment[2] + this.offset.click.left;
-                               }
-                               if(event.pageY - this.offset.click.top > this.containment[3]) {
-                                       pageY = this.containment[3] + this.offset.click.top;
-                               }
-                       }
-
-                       if(o.grid) {
-                               top = this.originalPageY + Math.round((pageY - this.originalPageY) / o.grid[1]) * o.grid[1];
-                               pageY = this.containment ? ( (top - this.offset.click.top >= this.containment[1] && top - this.offset.click.top <= this.containment[3]) ? top : ((top - this.offset.click.top >= this.containment[1]) ? top - o.grid[1] : top + o.grid[1])) : top;
-
-                               left = this.originalPageX + Math.round((pageX - this.originalPageX) / o.grid[0]) * o.grid[0];
-                               pageX = this.containment ? ( (left - this.offset.click.left >= this.containment[0] && left - this.offset.click.left <= this.containment[2]) ? left : ((left - this.offset.click.left >= this.containment[0]) ? left - o.grid[0] : left + o.grid[0])) : left;
-                       }
-
-               }
-
-               return {
-                       top: (
-                               pageY -                                                                                                                         // The absolute mouse position
-                               this.offset.click.top -                                                                                                 // Click offset (relative to the element)
-                               this.offset.relative.top        -                                                                                       // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.top +                                                                                                // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode ? 0 : scroll.scrollTop() ) ))
-                       ),
-                       left: (
-                               pageX -                                                                                                                         // The absolute mouse position
-                               this.offset.click.left -                                                                                                // Click offset (relative to the element)
-                               this.offset.relative.left       -                                                                                       // Only for relative positioned nodes: Relative offset from element to offset parent
-                               this.offset.parent.left +                                                                                               // The offsetParent's offset without borders (offset + border)
-                               ( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode ? 0 : scroll.scrollLeft() ))
-                       )
-               };
-
-       },
-
-       _rearrange: function(event, i, a, hardRefresh) {
-
-               a ? a[0].appendChild(this.placeholder[0]) : i.item[0].parentNode.insertBefore(this.placeholder[0], (this.direction === "down" ? i.item[0] : i.item[0].nextSibling));
-
-               //Various things done here to improve the performance:
-               // 1. we create a setTimeout, that calls refreshPositions
-               // 2. on the instance, we have a counter variable, that get's higher after every append
-               // 3. on the local scope, we copy the counter variable, and check in the timeout, if it's still the same
-               // 4. this lets only the last addition to the timeout stack through
-               this.counter = this.counter ? ++this.counter : 1;
-               var counter = this.counter;
-
-               this._delay(function() {
-                       if(counter === this.counter) {
-                               this.refreshPositions(!hardRefresh); //Precompute after each DOM insertion, NOT on mousemove
-                       }
-               });
-
-       },
-
-       _clear: function(event, noPropagation) {
-
-               this.reverting = false;
-               // We delay all events that have to be triggered to after the point where the placeholder has been removed and
-               // everything else normalized again
-               var i,
-                       delayedTriggers = [];
-
-               // We first have to update the dom position of the actual currentItem
-               // Note: don't do it if the current item is already removed (by a user), or it gets reappended (see #4088)
-               if(!this._noFinalSort && this.currentItem.parent().length) {
-                       this.placeholder.before(this.currentItem);
-               }
-               this._noFinalSort = null;
-
-               if(this.helper[0] === this.currentItem[0]) {
-                       for(i in this._storedCSS) {
-                               if(this._storedCSS[i] === "auto" || this._storedCSS[i] === "static") {
-                                       this._storedCSS[i] = "";
-                               }
-                       }
-                       this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper");
-               } else {
-                       this.currentItem.show();
-               }
-
-               if(this.fromOutside && !noPropagation) {
-                       delayedTriggers.push(function(event) { this._trigger("receive", event, this._uiHash(this.fromOutside)); });
-               }
-               if((this.fromOutside || this.domPosition.prev !== this.currentItem.prev().not(".ui-sortable-helper")[0] || this.domPosition.parent !== this.currentItem.parent()[0]) && !noPropagation) {
-                       delayedTriggers.push(function(event) { this._trigger("update", event, this._uiHash()); }); //Trigger update callback if the DOM position has changed
-               }
-
-               // Check if the items Container has Changed and trigger appropriate
-               // events.
-               if (this !== this.currentContainer) {
-                       if(!noPropagation) {
-                               delayedTriggers.push(function(event) { this._trigger("remove", event, this._uiHash()); });
-                               delayedTriggers.push((function(c) { return function(event) { c._trigger("receive", event, this._uiHash(this)); };  }).call(this, this.currentContainer));
-                               delayedTriggers.push((function(c) { return function(event) { c._trigger("update", event, this._uiHash(this));  }; }).call(this, this.currentContainer));
-                       }
-               }
-
-
-               //Post events to containers
-               function delayEvent( type, instance, container ) {
-                       return function( event ) {
-                               container._trigger( type, event, instance._uiHash( instance ) );
-                       };
-               }
-               for (i = this.containers.length - 1; i >= 0; i--){
-                       if (!noPropagation) {
-                               delayedTriggers.push( delayEvent( "deactivate", this, this.containers[ i ] ) );
-                       }
-                       if(this.containers[i].containerCache.over) {
-                               delayedTriggers.push( delayEvent( "out", this, this.containers[ i ] ) );
-                               this.containers[i].containerCache.over = 0;
-                       }
-               }
-
-               //Do what was originally in plugins
-               if ( this.storedCursor ) {
-                       this.document.find( "body" ).css( "cursor", this.storedCursor );
-                       this.storedStylesheet.remove();
-               }
-               if(this._storedOpacity) {
-                       this.helper.css("opacity", this._storedOpacity);
-               }
-               if(this._storedZIndex) {
-                       this.helper.css("zIndex", this._storedZIndex === "auto" ? "" : this._storedZIndex);
-               }
-
-               this.dragging = false;
-               if(this.cancelHelperRemoval) {
-                       if(!noPropagation) {
-                               this._trigger("beforeStop", event, this._uiHash());
-                               for (i=0; i < delayedTriggers.length; i++) {
-                                       delayedTriggers[i].call(this, event);
-                               } //Trigger all delayed events
-                               this._trigger("stop", event, this._uiHash());
-                       }
-
-                       this.fromOutside = false;
-                       return false;
-               }
-
-               if(!noPropagation) {
-                       this._trigger("beforeStop", event, this._uiHash());
-               }
-
-               //$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
-               this.placeholder[0].parentNode.removeChild(this.placeholder[0]);
-
-               if(this.helper[0] !== this.currentItem[0]) {
-                       this.helper.remove();
-               }
-               this.helper = null;
-
-               if(!noPropagation) {
-                       for (i=0; i < delayedTriggers.length; i++) {
-                               delayedTriggers[i].call(this, event);
-                       } //Trigger all delayed events
-                       this._trigger("stop", event, this._uiHash());
-               }
-
-               this.fromOutside = false;
-               return true;
-
-       },
-
-       _trigger: function() {
-               if ($.Widget.prototype._trigger.apply(this, arguments) === false) {
-                       this.cancel();
-               }
-       },
-
-       _uiHash: function(_inst) {
-               var inst = _inst || this;
-               return {
-                       helper: inst.helper,
-                       placeholder: inst.placeholder || $([]),
-                       position: inst.position,
-                       originalPosition: inst.originalPosition,
-                       offset: inst.positionAbs,
-                       item: inst.currentItem,
-                       sender: _inst ? _inst.element : null
-               };
-       }
-
-});
-
-})(jQuery);
-(function( $ ) {
-
-function modifier( fn ) {
-       return function() {
-               var previous = this.element.val();
-               fn.apply( this, arguments );
-               this._refresh();
-               if ( previous !== this.element.val() ) {
-                       this._trigger( "change" );
-               }
-       };
-}
-
-$.widget( "ui.spinner", {
-       version: "1.10.4",
-       defaultElement: "<input>",
-       widgetEventPrefix: "spin",
-       options: {
-               culture: null,
-               icons: {
-                       down: "ui-icon-triangle-1-s",
-                       up: "ui-icon-triangle-1-n"
-               },
-               incremental: true,
-               max: null,
-               min: null,
-               numberFormat: null,
-               page: 10,
-               step: 1,
-
-               change: null,
-               spin: null,
-               start: null,
-               stop: null
-       },
-
-       _create: function() {
-               // handle string values that need to be parsed
-               this._setOption( "max", this.options.max );
-               this._setOption( "min", this.options.min );
-               this._setOption( "step", this.options.step );
-
-               // Only format if there is a value, prevents the field from being marked
-               // as invalid in Firefox, see #9573.
-               if ( this.value() !== "" ) {
-                       // Format the value, but don't constrain.
-                       this._value( this.element.val(), true );
-               }
-
-               this._draw();
-               this._on( this._events );
-               this._refresh();
-
-               // turning off autocomplete prevents the browser from remembering the
-               // value when navigating through history, so we re-enable autocomplete
-               // if the page is unloaded before the widget is destroyed. #7790
-               this._on( this.window, {
-                       beforeunload: function() {
-                               this.element.removeAttr( "autocomplete" );
-                       }
-               });
-       },
-
-       _getCreateOptions: function() {
-               var options = {},
-                       element = this.element;
-
-               $.each( [ "min", "max", "step" ], function( i, option ) {
-                       var value = element.attr( option );
-                       if ( value !== undefined && value.length ) {
-                               options[ option ] = value;
-                       }
-               });
-
-               return options;
-       },
-
-       _events: {
-               keydown: function( event ) {
-                       if ( this._start( event ) && this._keydown( event ) ) {
-                               event.preventDefault();
-                       }
-               },
-               keyup: "_stop",
-               focus: function() {
-                       this.previous = this.element.val();
-               },
-               blur: function( event ) {
-                       if ( this.cancelBlur ) {
-                               delete this.cancelBlur;
-                               return;
-                       }
-
-                       this._stop();
-                       this._refresh();
-                       if ( this.previous !== this.element.val() ) {
-                               this._trigger( "change", event );
-                       }
-               },
-               mousewheel: function( event, delta ) {
-                       if ( !delta ) {
-                               return;
-                       }
-                       if ( !this.spinning && !this._start( event ) ) {
-                               return false;
-                       }
-
-                       this._spin( (delta > 0 ? 1 : -1) * this.options.step, event );
-                       clearTimeout( this.mousewheelTimer );
-                       this.mousewheelTimer = this._delay(function() {
-                               if ( this.spinning ) {
-                                       this._stop( event );
-                               }
-                       }, 100 );
-                       event.preventDefault();
-               },
-               "mousedown .ui-spinner-button": function( event ) {
-                       var previous;
-
-                       // We never want the buttons to have focus; whenever the user is
-                       // interacting with the spinner, the focus should be on the input.
-                       // If the input is focused then this.previous is properly set from
-                       // when the input first received focus. If the input is not focused
-                       // then we need to set this.previous based on the value before spinning.
-                       previous = this.element[0] === this.document[0].activeElement ?
-                               this.previous : this.element.val();
-                       function checkFocus() {
-                               var isActive = this.element[0] === this.document[0].activeElement;
-                               if ( !isActive ) {
-                                       this.element.focus();
-                                       this.previous = previous;
-                                       // support: IE
-                                       // IE sets focus asynchronously, so we need to check if focus
-                                       // moved off of the input because the user clicked on the button.
-                                       this._delay(function() {
-                                               this.previous = previous;
-                                       });
-                               }
-                       }
-
-                       // ensure focus is on (or stays on) the text field
-                       event.preventDefault();
-                       checkFocus.call( this );
-
-                       // support: IE
-                       // IE doesn't prevent moving focus even with event.preventDefault()
-                       // so we set a flag to know when we should ignore the blur event
-                       // and check (again) if focus moved off of the input.
-                       this.cancelBlur = true;
-                       this._delay(function() {
-                               delete this.cancelBlur;
-                               checkFocus.call( this );
-                       });
-
-                       if ( this._start( event ) === false ) {
-                               return;
-                       }
-
-                       this._repeat( null, $( event.currentTarget ).hasClass( "ui-spinner-up" ) ? 1 : -1, event );
-               },
-               "mouseup .ui-spinner-button": "_stop",
-               "mouseenter .ui-spinner-button": function( event ) {
-                       // button will add ui-state-active if mouse was down while mouseleave and kept down
-                       if ( !$( event.currentTarget ).hasClass( "ui-state-active" ) ) {
-                               return;
-                       }
-
-                       if ( this._start( event ) === false ) {
-                               return false;
-                       }
-                       this._repeat( null, $( event.currentTarget ).hasClass( "ui-spinner-up" ) ? 1 : -1, event );
-               },
-               // TODO: do we really want to consider this a stop?
-               // shouldn't we just stop the repeater and wait until mouseup before
-               // we trigger the stop event?
-               "mouseleave .ui-spinner-button": "_stop"
-       },
-
-       _draw: function() {
-               var uiSpinner = this.uiSpinner = this.element
-                       .addClass( "ui-spinner-input" )
-                       .attr( "autocomplete", "off" )
-                       .wrap( this._uiSpinnerHtml() )
-                       .parent()
-                               // add buttons
-                               .append( this._buttonHtml() );
-
-               this.element.attr( "role", "spinbutton" );
-
-               // button bindings
-               this.buttons = uiSpinner.find( ".ui-spinner-button" )
-                       .attr( "tabIndex", -1 )
-                       .button()
-                       .removeClass( "ui-corner-all" );
-
-               // IE 6 doesn't understand height: 50% for the buttons
-               // unless the wrapper has an explicit height
-               if ( this.buttons.height() > Math.ceil( uiSpinner.height() * 0.5 ) &&
-                               uiSpinner.height() > 0 ) {
-                       uiSpinner.height( uiSpinner.height() );
-               }
-
-               // disable spinner if element was already disabled
-               if ( this.options.disabled ) {
-                       this.disable();
-               }
-       },
-
-       _keydown: function( event ) {
-               var options = this.options,
-                       keyCode = $.ui.keyCode;
-
-               switch ( event.keyCode ) {
-               case keyCode.UP:
-                       this._repeat( null, 1, event );
-                       return true;
-               case keyCode.DOWN:
-                       this._repeat( null, -1, event );
-                       return true;
-               case keyCode.PAGE_UP:
-                       this._repeat( null, options.page, event );
-                       return true;
-               case keyCode.PAGE_DOWN:
-                       this._repeat( null, -options.page, event );
-                       return true;
-               }
-
-               return false;
-       },
-
-       _uiSpinnerHtml: function() {
-               return "<span class='ui-spinner ui-widget ui-widget-content ui-corner-all'></span>";
-       },
-
-       _buttonHtml: function() {
-               return "" +
-                       "<a class='ui-spinner-button ui-spinner-up ui-corner-tr'>" +
-                               "<span class='ui-icon " + this.options.icons.up + "'>&#9650;</span>" +
-                       "</a>" +
-                       "<a class='ui-spinner-button ui-spinner-down ui-corner-br'>" +
-                               "<span class='ui-icon " + this.options.icons.down + "'>&#9660;</span>" +
-                       "</a>";
-       },
-
-       _start: function( event ) {
-               if ( !this.spinning && this._trigger( "start", event ) === false ) {
-                       return false;
-               }
-
-               if ( !this.counter ) {
-                       this.counter = 1;
-               }
-               this.spinning = true;
-               return true;
-       },
-
-       _repeat: function( i, steps, event ) {
-               i = i || 500;
-
-               clearTimeout( this.timer );
-               this.timer = this._delay(function() {
-                       this._repeat( 40, steps, event );
-               }, i );
-
-               this._spin( steps * this.options.step, event );
-       },
-
-       _spin: function( step, event ) {
-               var value = this.value() || 0;
-
-               if ( !this.counter ) {
-                       this.counter = 1;
-               }
-
-               value = this._adjustValue( value + step * this._increment( this.counter ) );
-
-               if ( !this.spinning || this._trigger( "spin", event, { value: value } ) !== false) {
-                       this._value( value );
-                       this.counter++;
-               }
-       },
-
-       _increment: function( i ) {
-               var incremental = this.options.incremental;
-
-               if ( incremental ) {
-                       return $.isFunction( incremental ) ?
-                               incremental( i ) :
-                               Math.floor( i*i*i/50000 - i*i/500 + 17*i/200 + 1 );
-               }
-
-               return 1;
-       },
-
-       _precision: function() {
-               var precision = this._precisionOf( this.options.step );
-               if ( this.options.min !== null ) {
-                       precision = Math.max( precision, this._precisionOf( this.options.min ) );
-               }
-               return precision;
-       },
-
-       _precisionOf: function( num ) {
-               var str = num.toString(),
-                       decimal = str.indexOf( "." );
-               return decimal === -1 ? 0 : str.length - decimal - 1;
-       },
-
-       _adjustValue: function( value ) {
-               var base, aboveMin,
-                       options = this.options;
-
-               // make sure we're at a valid step
-               // - find out where we are relative to the base (min or 0)
-               base = options.min !== null ? options.min : 0;
-               aboveMin = value - base;
-               // - round to the nearest step
-               aboveMin = Math.round(aboveMin / options.step) * options.step;
-               // - rounding is based on 0, so adjust back to our base
-               value = base + aboveMin;
-
-               // fix precision from bad JS floating point math
-               value = parseFloat( value.toFixed( this._precision() ) );
-
-               // clamp the value
-               if ( options.max !== null && value > options.max) {
-                       return options.max;
-               }
-               if ( options.min !== null && value < options.min ) {
-                       return options.min;
-               }
-
-               return value;
-       },
-
-       _stop: function( event ) {
-               if ( !this.spinning ) {
-                       return;
-               }
-
-               clearTimeout( this.timer );
-               clearTimeout( this.mousewheelTimer );
-               this.counter = 0;
-               this.spinning = false;
-               this._trigger( "stop", event );
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "culture" || key === "numberFormat" ) {
-                       var prevValue = this._parse( this.element.val() );
-                       this.options[ key ] = value;
-                       this.element.val( this._format( prevValue ) );
-                       return;
-               }
-
-               if ( key === "max" || key === "min" || key === "step" ) {
-                       if ( typeof value === "string" ) {
-                               value = this._parse( value );
-                       }
-               }
-               if ( key === "icons" ) {
-                       this.buttons.first().find( ".ui-icon" )
-                               .removeClass( this.options.icons.up )
-                               .addClass( value.up );
-                       this.buttons.last().find( ".ui-icon" )
-                               .removeClass( this.options.icons.down )
-                               .addClass( value.down );
-               }
-
-               this._super( key, value );
-
-               if ( key === "disabled" ) {
-                       if ( value ) {
-                               this.element.prop( "disabled", true );
-                               this.buttons.button( "disable" );
-                       } else {
-                               this.element.prop( "disabled", false );
-                               this.buttons.button( "enable" );
-                       }
-               }
-       },
-
-       _setOptions: modifier(function( options ) {
-               this._super( options );
-               this._value( this.element.val() );
-       }),
-
-       _parse: function( val ) {
-               if ( typeof val === "string" && val !== "" ) {
-                       val = window.Globalize && this.options.numberFormat ?
-                               Globalize.parseFloat( val, 10, this.options.culture ) : +val;
-               }
-               return val === "" || isNaN( val ) ? null : val;
-       },
-
-       _format: function( value ) {
-               if ( value === "" ) {
-                       return "";
-               }
-               return window.Globalize && this.options.numberFormat ?
-                       Globalize.format( value, this.options.numberFormat, this.options.culture ) :
-                       value;
-       },
-
-       _refresh: function() {
-               this.element.attr({
-                       "aria-valuemin": this.options.min,
-                       "aria-valuemax": this.options.max,
-                       // TODO: what should we do with values that can't be parsed?
-                       "aria-valuenow": this._parse( this.element.val() )
-               });
-       },
-
-       // update the value without triggering change
-       _value: function( value, allowAny ) {
-               var parsed;
-               if ( value !== "" ) {
-                       parsed = this._parse( value );
-                       if ( parsed !== null ) {
-                               if ( !allowAny ) {
-                                       parsed = this._adjustValue( parsed );
-                               }
-                               value = this._format( parsed );
-                       }
-               }
-               this.element.val( value );
-               this._refresh();
-       },
-
-       _destroy: function() {
-               this.element
-                       .removeClass( "ui-spinner-input" )
-                       .prop( "disabled", false )
-                       .removeAttr( "autocomplete" )
-                       .removeAttr( "role" )
-                       .removeAttr( "aria-valuemin" )
-                       .removeAttr( "aria-valuemax" )
-                       .removeAttr( "aria-valuenow" );
-               this.uiSpinner.replaceWith( this.element );
-       },
-
-       stepUp: modifier(function( steps ) {
-               this._stepUp( steps );
-       }),
-       _stepUp: function( steps ) {
-               if ( this._start() ) {
-                       this._spin( (steps || 1) * this.options.step );
-                       this._stop();
-               }
-       },
-
-       stepDown: modifier(function( steps ) {
-               this._stepDown( steps );
-       }),
-       _stepDown: function( steps ) {
-               if ( this._start() ) {
-                       this._spin( (steps || 1) * -this.options.step );
-                       this._stop();
-               }
-       },
-
-       pageUp: modifier(function( pages ) {
-               this._stepUp( (pages || 1) * this.options.page );
-       }),
-
-       pageDown: modifier(function( pages ) {
-               this._stepDown( (pages || 1) * this.options.page );
-       }),
-
-       value: function( newVal ) {
-               if ( !arguments.length ) {
-                       return this._parse( this.element.val() );
-               }
-               modifier( this._value ).call( this, newVal );
-       },
-
-       widget: function() {
-               return this.uiSpinner;
-       }
-});
-
-}( jQuery ) );
-(function( $, undefined ) {
-
-var tabId = 0,
-       rhash = /#.*$/;
-
-function getNextTabId() {
-       return ++tabId;
-}
-
-function isLocal( anchor ) {
-       // support: IE7
-       // IE7 doesn't normalize the href property when set via script (#9317)
-       anchor = anchor.cloneNode( false );
-
-       return anchor.hash.length > 1 &&
-               decodeURIComponent( anchor.href.replace( rhash, "" ) ) ===
-                       decodeURIComponent( location.href.replace( rhash, "" ) );
-}
-
-$.widget( "ui.tabs", {
-       version: "1.10.4",
-       delay: 300,
-       options: {
-               active: null,
-               collapsible: false,
-               event: "click",
-               heightStyle: "content",
-               hide: null,
-               show: null,
-
-               // callbacks
-               activate: null,
-               beforeActivate: null,
-               beforeLoad: null,
-               load: null
-       },
-
-       _create: function() {
-               var that = this,
-                       options = this.options;
-
-               this.running = false;
-
-               this.element
-                       .addClass( "ui-tabs ui-widget ui-widget-content ui-corner-all" )
-                       .toggleClass( "ui-tabs-collapsible", options.collapsible )
-                       // Prevent users from focusing disabled tabs via click
-                       .delegate( ".ui-tabs-nav > li", "mousedown" + this.eventNamespace, function( event ) {
-                               if ( $( this ).is( ".ui-state-disabled" ) ) {
-                                       event.preventDefault();
-                               }
-                       })
-                       // support: IE <9
-                       // Preventing the default action in mousedown doesn't prevent IE
-                       // from focusing the element, so if the anchor gets focused, blur.
-                       // We don't have to worry about focusing the previously focused
-                       // element since clicking on a non-focusable element should focus
-                       // the body anyway.
-                       .delegate( ".ui-tabs-anchor", "focus" + this.eventNamespace, function() {
-                               if ( $( this ).closest( "li" ).is( ".ui-state-disabled" ) ) {
-                                       this.blur();
-                               }
-                       });
-
-               this._processTabs();
-               options.active = this._initialActive();
-
-               // Take disabling tabs via class attribute from HTML
-               // into account and update option properly.
-               if ( $.isArray( options.disabled ) ) {
-                       options.disabled = $.unique( options.disabled.concat(
-                               $.map( this.tabs.filter( ".ui-state-disabled" ), function( li ) {
-                                       return that.tabs.index( li );
-                               })
-                       ) ).sort();
-               }
-
-               // check for length avoids error when initializing empty list
-               if ( this.options.active !== false && this.anchors.length ) {
-                       this.active = this._findActive( options.active );
-               } else {
-                       this.active = $();
-               }
-
-               this._refresh();
-
-               if ( this.active.length ) {
-                       this.load( options.active );
-               }
-       },
-
-       _initialActive: function() {
-               var active = this.options.active,
-                       collapsible = this.options.collapsible,
-                       locationHash = location.hash.substring( 1 );
-
-               if ( active === null ) {
-                       // check the fragment identifier in the URL
-                       if ( locationHash ) {
-                               this.tabs.each(function( i, tab ) {
-                                       if ( $( tab ).attr( "aria-controls" ) === locationHash ) {
-                                               active = i;
-                                               return false;
-                                       }
-                               });
-                       }
-
-                       // check for a tab marked active via a class
-                       if ( active === null ) {
-                               active = this.tabs.index( this.tabs.filter( ".ui-tabs-active" ) );
-                       }
-
-                       // no active tab, set to false
-                       if ( active === null || active === -1 ) {
-                               active = this.tabs.length ? 0 : false;
-                       }
-               }
-
-               // handle numbers: negative, out of range
-               if ( active !== false ) {
-                       active = this.tabs.index( this.tabs.eq( active ) );
-                       if ( active === -1 ) {
-                               active = collapsible ? false : 0;
-                       }
-               }
-
-               // don't allow collapsible: false and active: false
-               if ( !collapsible && active === false && this.anchors.length ) {
-                       active = 0;
-               }
-
-               return active;
-       },
-
-       _getCreateEventData: function() {
-               return {
-                       tab: this.active,
-                       panel: !this.active.length ? $() : this._getPanelForTab( this.active )
-               };
-       },
-
-       _tabKeydown: function( event ) {
-               var focusedTab = $( this.document[0].activeElement ).closest( "li" ),
-                       selectedIndex = this.tabs.index( focusedTab ),
-                       goingForward = true;
-
-               if ( this._handlePageNav( event ) ) {
-                       return;
+               function escape( value ) {
+                       return value.replace( /[\-\[\]{}()*+?.,\\\^$|#\s]/g, "\\$&" );
                }
 
                switch ( event.keyCode ) {
-                       case $.ui.keyCode.RIGHT:
-                       case $.ui.keyCode.DOWN:
-                               selectedIndex++;
-                               break;
-                       case $.ui.keyCode.UP:
-                       case $.ui.keyCode.LEFT:
-                               goingForward = false;
-                               selectedIndex--;
-                               break;
-                       case $.ui.keyCode.END:
-                               selectedIndex = this.anchors.length - 1;
-                               break;
-                       case $.ui.keyCode.HOME:
-                               selectedIndex = 0;
-                               break;
-                       case $.ui.keyCode.SPACE:
-                               // Activate only, no collapsing
-                               event.preventDefault();
-                               clearTimeout( this.activating );
-                               this._activate( selectedIndex );
-                               return;
-                       case $.ui.keyCode.ENTER:
-                               // Toggle (cancel delayed activation, allow collapsing)
-                               event.preventDefault();
-                               clearTimeout( this.activating );
-                               // Determine if we should collapse or activate
-                               this._activate( selectedIndex === this.options.active ? false : selectedIndex );
-                               return;
-                       default:
-                               return;
-               }
-
-               // Focus the appropriate tab, based on which key was pressed
-               event.preventDefault();
-               clearTimeout( this.activating );
-               selectedIndex = this._focusNextTab( selectedIndex, goingForward );
-
-               // Navigating with control key will prevent automatic activation
-               if ( !event.ctrlKey ) {
-                       // Update aria-selected immediately so that AT think the tab is already selected.
-                       // Otherwise AT may confuse the user by stating that they need to activate the tab,
-                       // but the tab will already be activated by the time the announcement finishes.
-                       focusedTab.attr( "aria-selected", "false" );
-                       this.tabs.eq( selectedIndex ).attr( "aria-selected", "true" );
-
-                       this.activating = this._delay(function() {
-                               this.option( "active", selectedIndex );
-                       }, this.delay );
-               }
-       },
-
-       _panelKeydown: function( event ) {
-               if ( this._handlePageNav( event ) ) {
-                       return;
-               }
-
-               // Ctrl+up moves focus to the current tab
-               if ( event.ctrlKey && event.keyCode === $.ui.keyCode.UP ) {
-                       event.preventDefault();
-                       this.active.focus();
-               }
-       },
-
-       // Alt+page up/down moves focus to the previous/next tab (and activates)
-       _handlePageNav: function( event ) {
-               if ( event.altKey && event.keyCode === $.ui.keyCode.PAGE_UP ) {
-                       this._activate( this._focusNextTab( this.options.active - 1, false ) );
-                       return true;
-               }
-               if ( event.altKey && event.keyCode === $.ui.keyCode.PAGE_DOWN ) {
-                       this._activate( this._focusNextTab( this.options.active + 1, true ) );
-                       return true;
-               }
-       },
-
-       _findNextTab: function( index, goingForward ) {
-               var lastTabIndex = this.tabs.length - 1;
-
-               function constrain() {
-                       if ( index > lastTabIndex ) {
-                               index = 0;
-                       }
-                       if ( index < 0 ) {
-                               index = lastTabIndex;
-                       }
-                       return index;
-               }
-
-               while ( $.inArray( constrain(), this.options.disabled ) !== -1 ) {
-                       index = goingForward ? index + 1 : index - 1;
-               }
-
-               return index;
-       },
-
-       _focusNextTab: function( index, goingForward ) {
-               index = this._findNextTab( index, goingForward );
-               this.tabs.eq( index ).focus();
-               return index;
-       },
-
-       _setOption: function( key, value ) {
-               if ( key === "active" ) {
-                       // _activate() will handle invalid values and update this.options
-                       this._activate( value );
-                       return;
-               }
-
-               if ( key === "disabled" ) {
-                       // don't use the widget factory's disabled handling
-                       this._setupDisabled( value );
-                       return;
-               }
-
-               this._super( key, value);
-
-               if ( key === "collapsible" ) {
-                       this.element.toggleClass( "ui-tabs-collapsible", value );
-                       // Setting collapsible: false while collapsed; open first panel
-                       if ( !value && this.options.active === false ) {
-                               this._activate( 0 );
-                       }
-               }
-
-               if ( key === "event" ) {
-                       this._setupEvents( value );
-               }
-
-               if ( key === "heightStyle" ) {
-                       this._setupHeightStyle( value );
-               }
-       },
-
-       _tabId: function( tab ) {
-               return tab.attr( "aria-controls" ) || "ui-tabs-" + getNextTabId();
-       },
-
-       _sanitizeSelector: function( hash ) {
-               return hash ? hash.replace( /[!"$%&'()*+,.\/:;<=>?@\[\]\^`{|}~]/g, "\\$&" ) : "";
-       },
-
-       refresh: function() {
-               var options = this.options,
-                       lis = this.tablist.children( ":has(a[href])" );
-
-               // get disabled tabs from class attribute from HTML
-               // this will get converted to a boolean if needed in _refresh()
-               options.disabled = $.map( lis.filter( ".ui-state-disabled" ), function( tab ) {
-                       return lis.index( tab );
-               });
-
-               this._processTabs();
-
-               // was collapsed or no tabs
-               if ( options.active === false || !this.anchors.length ) {
-                       options.active = false;
-                       this.active = $();
-               // was active, but active tab is gone
-               } else if ( this.active.length && !$.contains( this.tablist[ 0 ], this.active[ 0 ] ) ) {
-                       // all remaining tabs are disabled
-                       if ( this.tabs.length === options.disabled.length ) {
-                               options.active = false;
-                               this.active = $();
-                       // activate previous tab
-                       } else {
-                               this._activate( this._findNextTab( Math.max( 0, options.active - 1 ), false ) );
-                       }
-               // was active, active tab still exists
-               } else {
-                       // make sure active index is correct
-                       options.active = this.tabs.index( this.active );
-               }
-
-               this._refresh();
-       },
-
-       _refresh: function() {
-               this._setupDisabled( this.options.disabled );
-               this._setupEvents( this.options.event );
-               this._setupHeightStyle( this.options.heightStyle );
-
-               this.tabs.not( this.active ).attr({
-                       "aria-selected": "false",
-                       tabIndex: -1
-               });
-               this.panels.not( this._getPanelForTab( this.active ) )
-                       .hide()
-                       .attr({
-                               "aria-expanded": "false",
-                               "aria-hidden": "true"
-                       });
-
-               // Make sure one tab is in the tab order
-               if ( !this.active.length ) {
-                       this.tabs.eq( 0 ).attr( "tabIndex", 0 );
-               } else {
-                       this.active
-                               .addClass( "ui-tabs-active ui-state-active" )
-                               .attr({
-                                       "aria-selected": "true",
-                                       tabIndex: 0
-                               });
-                       this._getPanelForTab( this.active )
-                               .show()
-                               .attr({
-                                       "aria-expanded": "true",
-                                       "aria-hidden": "false"
-                               });
-               }
-       },
-
-       _processTabs: function() {
-               var that = this;
-
-               this.tablist = this._getList()
-                       .addClass( "ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all" )
-                       .attr( "role", "tablist" );
-
-               this.tabs = this.tablist.find( "> li:has(a[href])" )
-                       .addClass( "ui-state-default ui-corner-top" )
-                       .attr({
-                               role: "tab",
-                               tabIndex: -1
-                       });
-
-               this.anchors = this.tabs.map(function() {
-                               return $( "a", this )[ 0 ];
-                       })
-                       .addClass( "ui-tabs-anchor" )
-                       .attr({
-                               role: "presentation",
-                               tabIndex: -1
-                       });
-
-               this.panels = $();
+               case $.ui.keyCode.PAGE_UP:
+                       this.previousPage( event );
+                       break;
+               case $.ui.keyCode.PAGE_DOWN:
+                       this.nextPage( event );
+                       break;
+               case $.ui.keyCode.HOME:
+                       this._move( "first", "first", event );
+                       break;
+               case $.ui.keyCode.END:
+                       this._move( "last", "last", event );
+                       break;
+               case $.ui.keyCode.UP:
+                       this.previous( event );
+                       break;
+               case $.ui.keyCode.DOWN:
+                       this.next( event );
+                       break;
+               case $.ui.keyCode.LEFT:
+                       this.collapse( event );
+                       break;
+               case $.ui.keyCode.RIGHT:
+                       if ( this.active && !this.active.is( ".ui-state-disabled" ) ) {
+                               this.expand( event );
+                       }
+                       break;
+               case $.ui.keyCode.ENTER:
+               case $.ui.keyCode.SPACE:
+                       this._activate( event );
+                       break;
+               case $.ui.keyCode.ESCAPE:
+                       this.collapse( event );
+                       break;
+               default:
+                       preventDefault = false;
+                       prev = this.previousFilter || "";
+                       character = String.fromCharCode( event.keyCode );
+                       skip = false;
 
-               this.anchors.each(function( i, anchor ) {
-                       var selector, panel, panelId,
-                               anchorId = $( anchor ).uniqueId().attr( "id" ),
-                               tab = $( anchor ).closest( "li" ),
-                               originalAriaControls = tab.attr( "aria-controls" );
+                       clearTimeout( this.filterTimer );
 
-                       // inline tab
-                       if ( isLocal( anchor ) ) {
-                               selector = anchor.hash;
-                               panel = that.element.find( that._sanitizeSelector( selector ) );
-                       // remote tab
+                       if ( character === prev ) {
+                               skip = true;
                        } else {
-                               panelId = that._tabId( tab );
-                               selector = "#" + panelId;
-                               panel = that.element.find( selector );
-                               if ( !panel.length ) {
-                                       panel = that._createPanel( panelId );
-                                       panel.insertAfter( that.panels[ i - 1 ] || that.tablist );
-                               }
-                               panel.attr( "aria-live", "polite" );
+                               character = prev + character;
                        }
 
-                       if ( panel.length) {
-                               that.panels = that.panels.add( panel );
-                       }
-                       if ( originalAriaControls ) {
-                               tab.data( "ui-tabs-aria-controls", originalAriaControls );
-                       }
-                       tab.attr({
-                               "aria-controls": selector.substring( 1 ),
-                               "aria-labelledby": anchorId
+                       regex = new RegExp( "^" + escape( character ), "i" );
+                       match = this.activeMenu.children( ".ui-menu-item" ).filter(function() {
+                               return regex.test( $( this ).children( "a" ).text() );
                        });
-                       panel.attr( "aria-labelledby", anchorId );
-               });
-
-               this.panels
-                       .addClass( "ui-tabs-panel ui-widget-content ui-corner-bottom" )
-                       .attr( "role", "tabpanel" );
-       },
-
-       // allow overriding how to find the list for rare usage scenarios (#7715)
-       _getList: function() {
-               return this.tablist || this.element.find( "ol,ul" ).eq( 0 );
-       },
-
-       _createPanel: function( id ) {
-               return $( "<div>" )
-                       .attr( "id", id )
-                       .addClass( "ui-tabs-panel ui-widget-content ui-corner-bottom" )
-                       .data( "ui-tabs-destroy", true );
-       },
+                       match = skip && match.index( this.active.next() ) !== -1 ?
+                               this.active.nextAll( ".ui-menu-item" ) :
+                               match;
 
-       _setupDisabled: function( disabled ) {
-               if ( $.isArray( disabled ) ) {
-                       if ( !disabled.length ) {
-                               disabled = false;
-                       } else if ( disabled.length === this.anchors.length ) {
-                               disabled = true;
+                       // If no matches on the current filter, reset to the last character pressed
+                       // to move down the menu to the first item that starts with that character
+                       if ( !match.length ) {
+                               character = String.fromCharCode( event.keyCode );
+                               regex = new RegExp( "^" + escape( character ), "i" );
+                               match = this.activeMenu.children( ".ui-menu-item" ).filter(function() {
+                                       return regex.test( $( this ).children( "a" ).text() );
+                               });
                        }
-               }
 
-               // disable tabs
-               for ( var i = 0, li; ( li = this.tabs[ i ] ); i++ ) {
-                       if ( disabled === true || $.inArray( i, disabled ) !== -1 ) {
-                               $( li )
-                                       .addClass( "ui-state-disabled" )
-                                       .attr( "aria-disabled", "true" );
+                       if ( match.length ) {
+                               this.focus( event, match );
+                               if ( match.length > 1 ) {
+                                       this.previousFilter = character;
+                                       this.filterTimer = this._delay(function() {
+                                               delete this.previousFilter;
+                                       }, 1000 );
+                               } else {
+                                       delete this.previousFilter;
+                               }
                        } else {
-                               $( li )
-                                       .removeClass( "ui-state-disabled" )
-                                       .removeAttr( "aria-disabled" );
+                               delete this.previousFilter;
                        }
                }
 
-               this.options.disabled = disabled;
+               if ( preventDefault ) {
+                       event.preventDefault();
+               }
        },
 
-       _setupEvents: function( event ) {
-               var events = {
-                       click: function( event ) {
-                               event.preventDefault();
+       _activate: function( event ) {
+               if ( !this.active.is( ".ui-state-disabled" ) ) {
+                       if ( this.active.children( "a[aria-haspopup='true']" ).length ) {
+                               this.expand( event );
+                       } else {
+                               this.select( event );
                        }
-               };
-               if ( event ) {
-                       $.each( event.split(" "), function( index, eventName ) {
-                               events[ eventName ] = "_eventHandler";
-                       });
                }
-
-               this._off( this.anchors.add( this.tabs ).add( this.panels ) );
-               this._on( this.anchors, events );
-               this._on( this.tabs, { keydown: "_tabKeydown" } );
-               this._on( this.panels, { keydown: "_panelKeydown" } );
-
-               this._focusable( this.tabs );
-               this._hoverable( this.tabs );
        },
 
-       _setupHeightStyle: function( heightStyle ) {
-               var maxHeight,
-                       parent = this.element.parent();
-
-               if ( heightStyle === "fill" ) {
-                       maxHeight = parent.height();
-                       maxHeight -= this.element.outerHeight() - this.element.height();
-
-                       this.element.siblings( ":visible" ).each(function() {
-                               var elem = $( this ),
-                                       position = elem.css( "position" );
-
-                               if ( position === "absolute" || position === "fixed" ) {
-                                       return;
-                               }
-                               maxHeight -= elem.outerHeight( true );
-                       });
+       refresh: function() {
+               var menus,
+                       icon = this.options.icons.submenu,
+                       submenus = this.element.find( this.options.menus );
 
-                       this.element.children().not( this.panels ).each(function() {
-                               maxHeight -= $( this ).outerHeight( true );
-                       });
+               this.element.toggleClass( "ui-menu-icons", !!this.element.find( ".ui-icon" ).length );
 
-                       this.panels.each(function() {
-                               $( this ).height( Math.max( 0, maxHeight -
-                                       $( this ).innerHeight() + $( this ).height() ) );
+               // Initialize nested menus
+               submenus.filter( ":not(.ui-menu)" )
+                       .addClass( "ui-menu ui-widget ui-widget-content ui-corner-all" )
+                       .hide()
+                       .attr({
+                               role: this.options.role,
+                               "aria-hidden": "true",
+                               "aria-expanded": "false"
                        })
-                       .css( "overflow", "auto" );
-               } else if ( heightStyle === "auto" ) {
-                       maxHeight = 0;
-                       this.panels.each(function() {
-                               maxHeight = Math.max( maxHeight, $( this ).height( "" ).height() );
-                       }).height( maxHeight );
-               }
-       },
-
-       _eventHandler: function( event ) {
-               var options = this.options,
-                       active = this.active,
-                       anchor = $( event.currentTarget ),
-                       tab = anchor.closest( "li" ),
-                       clickedIsActive = tab[ 0 ] === active[ 0 ],
-                       collapsing = clickedIsActive && options.collapsible,
-                       toShow = collapsing ? $() : this._getPanelForTab( tab ),
-                       toHide = !active.length ? $() : this._getPanelForTab( active ),
-                       eventData = {
-                               oldTab: active,
-                               oldPanel: toHide,
-                               newTab: collapsing ? $() : tab,
-                               newPanel: toShow
-                       };
-
-               event.preventDefault();
-
-               if ( tab.hasClass( "ui-state-disabled" ) ||
-                               // tab is already loading
-                               tab.hasClass( "ui-tabs-loading" ) ||
-                               // can't switch durning an animation
-                               this.running ||
-                               // click on active header, but not collapsible
-                               ( clickedIsActive && !options.collapsible ) ||
-                               // allow canceling activation
-                               ( this._trigger( "beforeActivate", event, eventData ) === false ) ) {
-                       return;
-               }
-
-               options.active = collapsing ? false : this.tabs.index( tab );
-
-               this.active = clickedIsActive ? $() : tab;
-               if ( this.xhr ) {
-                       this.xhr.abort();
-               }
-
-               if ( !toHide.length && !toShow.length ) {
-                       $.error( "jQuery UI Tabs: Mismatching fragment identifier." );
-               }
-
-               if ( toShow.length ) {
-                       this.load( this.tabs.index( tab ), event );
-               }
-               this._toggle( event, eventData );
-       },
-
-       // handles show/hide for selecting tabs
-       _toggle: function( event, eventData ) {
-               var that = this,
-                       toShow = eventData.newPanel,
-                       toHide = eventData.oldPanel;
+                       .each(function() {
+                               var menu = $( this ),
+                                       item = menu.prev( "a" ),
+                                       submenuCarat = $( "<span>" )
+                                               .addClass( "ui-menu-icon ui-icon " + icon )
+                                               .data( "ui-menu-submenu-carat", true );
 
-               this.running = true;
+                               item
+                                       .attr( "aria-haspopup", "true" )
+                                       .prepend( submenuCarat );
+                               menu.attr( "aria-labelledby", item.attr( "id" ) );
+                       });
 
-               function complete() {
-                       that.running = false;
-                       that._trigger( "activate", event, eventData );
-               }
+               menus = submenus.add( this.element );
 
-               function show() {
-                       eventData.newTab.closest( "li" ).addClass( "ui-tabs-active ui-state-active" );
+               // Don't refresh list items that are already adapted
+               menus.children( ":not(.ui-menu-item):has(a)" )
+                       .addClass( "ui-menu-item" )
+                       .attr( "role", "presentation" )
+                       .children( "a" )
+                               .uniqueId()
+                               .addClass( "ui-corner-all" )
+                               .attr({
+                                       tabIndex: -1,
+                                       role: this._itemRole()
+                               });
 
-                       if ( toShow.length && that.options.show ) {
-                               that._show( toShow, that.options.show, complete );
-                       } else {
-                               toShow.show();
-                               complete();
+               // Initialize unlinked menu-items containing spaces and/or dashes only as dividers
+               menus.children( ":not(.ui-menu-item)" ).each(function() {
+                       var item = $( this );
+                       // hyphen, em dash, en dash
+                       if ( !/[^\-\u2014\u2013\s]/.test( item.text() ) ) {
+                               item.addClass( "ui-widget-content ui-menu-divider" );
                        }
-               }
-
-               // start out by hiding, then showing, then completing
-               if ( toHide.length && this.options.hide ) {
-                       this._hide( toHide, this.options.hide, function() {
-                               eventData.oldTab.closest( "li" ).removeClass( "ui-tabs-active ui-state-active" );
-                               show();
-                       });
-               } else {
-                       eventData.oldTab.closest( "li" ).removeClass( "ui-tabs-active ui-state-active" );
-                       toHide.hide();
-                       show();
-               }
-
-               toHide.attr({
-                       "aria-expanded": "false",
-                       "aria-hidden": "true"
-               });
-               eventData.oldTab.attr( "aria-selected", "false" );
-               // If we're switching tabs, remove the old tab from the tab order.
-               // If we're opening from collapsed state, remove the previous tab from the tab order.
-               // If we're collapsing, then keep the collapsing tab in the tab order.
-               if ( toShow.length && toHide.length ) {
-                       eventData.oldTab.attr( "tabIndex", -1 );
-               } else if ( toShow.length ) {
-                       this.tabs.filter(function() {
-                               return $( this ).attr( "tabIndex" ) === 0;
-                       })
-                       .attr( "tabIndex", -1 );
-               }
-
-               toShow.attr({
-                       "aria-expanded": "true",
-                       "aria-hidden": "false"
                });
-               eventData.newTab.attr({
-                       "aria-selected": "true",
-                       tabIndex: 0
-               });
-       },
 
-       _activate: function( index ) {
-               var anchor,
-                       active = this._findActive( index );
-
-               // trying to activate the already active panel
-               if ( active[ 0 ] === this.active[ 0 ] ) {
-                       return;
-               }
+               // Add aria-disabled attribute to any disabled menu item
+               menus.children( ".ui-state-disabled" ).attr( "aria-disabled", "true" );
 
-               // trying to collapse, simulate a click on the current active header
-               if ( !active.length ) {
-                       active = this.active;
+               // If the active item has been removed, blur the menu
+               if ( this.active && !$.contains( this.element[ 0 ], this.active[ 0 ] ) ) {
+                       this.blur();
                }
-
-               anchor = active.find( ".ui-tabs-anchor" )[ 0 ];
-               this._eventHandler({
-                       target: anchor,
-                       currentTarget: anchor,
-                       preventDefault: $.noop
-               });
        },
 
-       _findActive: function( index ) {
-               return index === false ? $() : this.tabs.eq( index );
+       _itemRole: function() {
+               return {
+                       menu: "menuitem",
+                       listbox: "option"
+               }[ this.options.role ];
        },
 
-       _getIndex: function( index ) {
-               // meta-function to give users option to provide a href string instead of a numerical index.
-               if ( typeof index === "string" ) {
-                       index = this.anchors.index( this.anchors.filter( "[href$='" + index + "']" ) );
+       _setOption: function( key, value ) {
+               if ( key === "icons" ) {
+                       this.element.find( ".ui-menu-icon" )
+                               .removeClass( this.options.icons.submenu )
+                               .addClass( value.submenu );
                }
-
-               return index;
+               this._super( key, value );
        },
 
-       _destroy: function() {
-               if ( this.xhr ) {
-                       this.xhr.abort();
-               }
-
-               this.element.removeClass( "ui-tabs ui-widget ui-widget-content ui-corner-all ui-tabs-collapsible" );
-
-               this.tablist
-                       .removeClass( "ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all" )
-                       .removeAttr( "role" );
-
-               this.anchors
-                       .removeClass( "ui-tabs-anchor" )
-                       .removeAttr( "role" )
-                       .removeAttr( "tabIndex" )
-                       .removeUniqueId();
+       focus: function( event, item ) {
+               var nested, focused;
+               this.blur( event, event && event.type === "focus" );
 
-               this.tabs.add( this.panels ).each(function() {
-                       if ( $.data( this, "ui-tabs-destroy" ) ) {
-                               $( this ).remove();
-                       } else {
-                               $( this )
-                                       .removeClass( "ui-state-default ui-state-active ui-state-disabled " +
-                                               "ui-corner-top ui-corner-bottom ui-widget-content ui-tabs-active ui-tabs-panel" )
-                                       .removeAttr( "tabIndex" )
-                                       .removeAttr( "aria-live" )
-                                       .removeAttr( "aria-busy" )
-                                       .removeAttr( "aria-selected" )
-                                       .removeAttr( "aria-labelledby" )
-                                       .removeAttr( "aria-hidden" )
-                                       .removeAttr( "aria-expanded" )
-                                       .removeAttr( "role" );
-                       }
-               });
+               this._scrollIntoView( item );
 
-               this.tabs.each(function() {
-                       var li = $( this ),
-                               prev = li.data( "ui-tabs-aria-controls" );
-                       if ( prev ) {
-                               li
-                                       .attr( "aria-controls", prev )
-                                       .removeData( "ui-tabs-aria-controls" );
-                       } else {
-                               li.removeAttr( "aria-controls" );
-                       }
-               });
+               this.active = item.first();
+               focused = this.active.children( "a" ).addClass( "ui-state-focus" );
+               // Only update aria-activedescendant if there's a role
+               // otherwise we assume focus is managed elsewhere
+               if ( this.options.role ) {
+                       this.element.attr( "aria-activedescendant", focused.attr( "id" ) );
+               }
 
-               this.panels.show();
+               // Highlight active parent menu item, if any
+               this.active
+                       .parent()
+                       .closest( ".ui-menu-item" )
+                       .children( "a:first" )
+                       .addClass( "ui-state-active" );
 
-               if ( this.options.heightStyle !== "content" ) {
-                       this.panels.css( "height", "" );
+               if ( event && event.type === "keydown" ) {
+                       this._close();
+               } else {
+                       this.timer = this._delay(function() {
+                               this._close();
+                       }, this.delay );
                }
-       },
 
-       enable: function( index ) {
-               var disabled = this.options.disabled;
-               if ( disabled === false ) {
-                       return;
+               nested = item.children( ".ui-menu" );
+               if ( nested.length && event && ( /^mouse/.test( event.type ) ) ) {
+                       this._startOpening(nested);
                }
+               this.activeMenu = item.parent();
 
-               if ( index === undefined ) {
-                       disabled = false;
-               } else {
-                       index = this._getIndex( index );
-                       if ( $.isArray( disabled ) ) {
-                               disabled = $.map( disabled, function( num ) {
-                                       return num !== index ? num : null;
-                               });
-                       } else {
-                               disabled = $.map( this.tabs, function( li, num ) {
-                                       return num !== index ? num : null;
-                               });
-                       }
-               }
-               this._setupDisabled( disabled );
+               this._trigger( "focus", event, { item: item } );
        },
 
-       disable: function( index ) {
-               var disabled = this.options.disabled;
-               if ( disabled === true ) {
-                       return;
-               }
+       _scrollIntoView: function( item ) {
+               var borderTop, paddingTop, offset, scroll, elementHeight, itemHeight;
+               if ( this._hasScroll() ) {
+                       borderTop = parseFloat( $.css( this.activeMenu[0], "borderTopWidth" ) ) || 0;
+                       paddingTop = parseFloat( $.css( this.activeMenu[0], "paddingTop" ) ) || 0;
+                       offset = item.offset().top - this.activeMenu.offset().top - borderTop - paddingTop;
+                       scroll = this.activeMenu.scrollTop();
+                       elementHeight = this.activeMenu.height();
+                       itemHeight = item.height();
 
-               if ( index === undefined ) {
-                       disabled = true;
-               } else {
-                       index = this._getIndex( index );
-                       if ( $.inArray( index, disabled ) !== -1 ) {
-                               return;
-                       }
-                       if ( $.isArray( disabled ) ) {
-                               disabled = $.merge( [ index ], disabled ).sort();
-                       } else {
-                               disabled = [ index ];
+                       if ( offset < 0 ) {
+                               this.activeMenu.scrollTop( scroll + offset );
+                       } else if ( offset + itemHeight > elementHeight ) {
+                               this.activeMenu.scrollTop( scroll + offset - elementHeight + itemHeight );
                        }
                }
-               this._setupDisabled( disabled );
        },
 
-       load: function( index, event ) {
-               index = this._getIndex( index );
-               var that = this,
-                       tab = this.tabs.eq( index ),
-                       anchor = tab.find( ".ui-tabs-anchor" ),
-                       panel = this._getPanelForTab( tab ),
-                       eventData = {
-                               tab: tab,
-                               panel: panel
-                       };
+       blur: function( event, fromFocus ) {
+               if ( !fromFocus ) {
+                       clearTimeout( this.timer );
+               }
 
-               // not remote
-               if ( isLocal( anchor[ 0 ] ) ) {
+               if ( !this.active ) {
                        return;
                }
 
-               this.xhr = $.ajax( this._ajaxSettings( anchor, event, eventData ) );
+               this.active.children( "a" ).removeClass( "ui-state-focus" );
+               this.active = null;
 
-               // support: jQuery <1.8
-               // jQuery <1.8 returns false if the request is canceled in beforeSend,
-               // but as of 1.8, $.ajax() always returns a jqXHR object.
-               if ( this.xhr && this.xhr.statusText !== "canceled" ) {
-                       tab.addClass( "ui-tabs-loading" );
-                       panel.attr( "aria-busy", "true" );
-
-                       this.xhr
-                               .success(function( response ) {
-                                       // support: jQuery <1.8
-                                       // http://bugs.jquery.com/ticket/11778
-                                       setTimeout(function() {
-                                               panel.html( response );
-                                               that._trigger( "load", event, eventData );
-                                       }, 1 );
-                               })
-                               .complete(function( jqXHR, status ) {
-                                       // support: jQuery <1.8
-                                       // http://bugs.jquery.com/ticket/11778
-                                       setTimeout(function() {
-                                               if ( status === "abort" ) {
-                                                       that.panels.stop( false, true );
-                                               }
+               this._trigger( "blur", event, { item: this.active } );
+       },
 
-                                               tab.removeClass( "ui-tabs-loading" );
-                                               panel.removeAttr( "aria-busy" );
+       _startOpening: function( submenu ) {
+               clearTimeout( this.timer );
 
-                                               if ( jqXHR === that.xhr ) {
-                                                       delete that.xhr;
-                                               }
-                                       }, 1 );
-                               });
+               // Don't open if already open fixes a Firefox bug that caused a .5 pixel
+               // shift in the submenu position when mousing over the carat icon
+               if ( submenu.attr( "aria-hidden" ) !== "true" ) {
+                       return;
                }
-       },
 
-       _ajaxSettings: function( anchor, event, eventData ) {
-               var that = this;
-               return {
-                       url: anchor.attr( "href" ),
-                       beforeSend: function( jqXHR, settings ) {
-                               return that._trigger( "beforeLoad", event,
-                                       $.extend( { jqXHR : jqXHR, ajaxSettings: settings }, eventData ) );
-                       }
-               };
+               this.timer = this._delay(function() {
+                       this._close();
+                       this._open( submenu );
+               }, this.delay );
        },
 
-       _getPanelForTab: function( tab ) {
-               var id = $( tab ).attr( "aria-controls" );
-               return this.element.find( this._sanitizeSelector( "#" + id ) );
-       }
-});
-
-})( jQuery );
-(function( $ ) {
+       _open: function( submenu ) {
+               var position = $.extend({
+                       of: this.active
+               }, this.options.position );
 
-var increments = 0;
+               clearTimeout( this.timer );
+               this.element.find( ".ui-menu" ).not( submenu.parents( ".ui-menu" ) )
+                       .hide()
+                       .attr( "aria-hidden", "true" );
 
-function addDescribedBy( elem, id ) {
-       var describedby = (elem.attr( "aria-describedby" ) || "").split( /\s+/ );
-       describedby.push( id );
-       elem
-               .data( "ui-tooltip-id", id )
-               .attr( "aria-describedby", $.trim( describedby.join( " " ) ) );
-}
+               submenu
+                       .show()
+                       .removeAttr( "aria-hidden" )
+                       .attr( "aria-expanded", "true" )
+                       .position( position );
+       },
 
-function removeDescribedBy( elem ) {
-       var id = elem.data( "ui-tooltip-id" ),
-               describedby = (elem.attr( "aria-describedby" ) || "").split( /\s+/ ),
-               index = $.inArray( id, describedby );
-       if ( index !== -1 ) {
-               describedby.splice( index, 1 );
-       }
+       collapseAll: function( event, all ) {
+               clearTimeout( this.timer );
+               this.timer = this._delay(function() {
+                       // If we were passed an event, look for the submenu that contains the event
+                       var currentMenu = all ? this.element :
+                               $( event && event.target ).closest( this.element.find( ".ui-menu" ) );
 
-       elem.removeData( "ui-tooltip-id" );
-       describedby = $.trim( describedby.join( " " ) );
-       if ( describedby ) {
-               elem.attr( "aria-describedby", describedby );
-       } else {
-               elem.removeAttr( "aria-describedby" );
-       }
-}
+                       // If we found no valid submenu ancestor, use the main menu to close all sub menus anyway
+                       if ( !currentMenu.length ) {
+                               currentMenu = this.element;
+                       }
 
-$.widget( "ui.tooltip", {
-       version: "1.10.4",
-       options: {
-               content: function() {
-                       // support: IE<9, Opera in jQuery <1.7
-                       // .text() can't accept undefined, so coerce to a string
-                       var title = $( this ).attr( "title" ) || "";
-                       // Escape title, since we're going from an attribute to raw HTML
-                       return $( "<a>" ).text( title ).html();
-               },
-               hide: true,
-               // Disabled elements have inconsistent behavior across browsers (#8661)
-               items: "[title]:not([disabled])",
-               position: {
-                       my: "left top+15",
-                       at: "left bottom",
-                       collision: "flipfit flip"
-               },
-               show: true,
-               tooltipClass: null,
-               track: false,
+                       this._close( currentMenu );
 
-               // callbacks
-               close: null,
-               open: null
+                       this.blur( event );
+                       this.activeMenu = currentMenu;
+               }, this.delay );
        },
 
-       _create: function() {
-               this._on({
-                       mouseover: "open",
-                       focusin: "open"
-               });
+       // With no arguments, closes the currently active menu - if nothing is active
+       // it closes all menus.  If passed an argument, it will search for menus BELOW
+       _close: function( startMenu ) {
+               if ( !startMenu ) {
+                       startMenu = this.active ? this.active.parent() : this.element;
+               }
 
-               // IDs of generated tooltips, needed for destroy
-               this.tooltips = {};
-               // IDs of parent tooltips where we removed the title attribute
-               this.parents = {};
+               startMenu
+                       .find( ".ui-menu" )
+                               .hide()
+                               .attr( "aria-hidden", "true" )
+                               .attr( "aria-expanded", "false" )
+                       .end()
+                       .find( "a.ui-state-active" )
+                               .removeClass( "ui-state-active" );
+       },
 
-               if ( this.options.disabled ) {
-                       this._disable();
+       collapse: function( event ) {
+               var newItem = this.active &&
+                       this.active.parent().closest( ".ui-menu-item", this.element );
+               if ( newItem && newItem.length ) {
+                       this._close();
+                       this.focus( event, newItem );
                }
        },
 
-       _setOption: function( key, value ) {
-               var that = this;
-
-               if ( key === "disabled" ) {
-                       this[ value ? "_disable" : "_enable" ]();
-                       this.options[ key ] = value;
-                       // disable element style changes
-                       return;
-               }
+       expand: function( event ) {
+               var newItem = this.active &&
+                       this.active
+                               .children( ".ui-menu " )
+                               .children( ".ui-menu-item" )
+                               .first();
 
-               this._super( key, value );
+               if ( newItem && newItem.length ) {
+                       this._open( newItem.parent() );
 
-               if ( key === "content" ) {
-                       $.each( this.tooltips, function( id, element ) {
-                               that._updateContent( element );
+                       // Delay so Firefox will not hide activedescendant change in expanding submenu from AT
+                       this._delay(function() {
+                               this.focus( event, newItem );
                        });
                }
        },
 
-       _disable: function() {
-               var that = this;
-
-               // close open tooltips
-               $.each( this.tooltips, function( id, element ) {
-                       var event = $.Event( "blur" );
-                       event.target = event.currentTarget = element[0];
-                       that.close( event, true );
-               });
-
-               // remove title attributes to prevent native tooltips
-               this.element.find( this.options.items ).addBack().each(function() {
-                       var element = $( this );
-                       if ( element.is( "[title]" ) ) {
-                               element
-                                       .data( "ui-tooltip-title", element.attr( "title" ) )
-                                       .attr( "title", "" );
-                       }
-               });
+       next: function( event ) {
+               this._move( "next", "first", event );
        },
 
-       _enable: function() {
-               // restore title attributes
-               this.element.find( this.options.items ).addBack().each(function() {
-                       var element = $( this );
-                       if ( element.data( "ui-tooltip-title" ) ) {
-                               element.attr( "title", element.data( "ui-tooltip-title" ) );
-                       }
-               });
+       previous: function( event ) {
+               this._move( "prev", "last", event );
        },
 
-       open: function( event ) {
-               var that = this,
-                       target = $( event ? event.target : this.element )
-                               // we need closest here due to mouseover bubbling,
-                               // but always pointing at the same event target
-                               .closest( this.options.items );
-
-               // No element to show a tooltip for or the tooltip is already open
-               if ( !target.length || target.data( "ui-tooltip-id" ) ) {
-                       return;
-               }
-
-               if ( target.attr( "title" ) ) {
-                       target.data( "ui-tooltip-title", target.attr( "title" ) );
-               }
-
-               target.data( "ui-tooltip-open", true );
-
-               // kill parent tooltips, custom or native, for hover
-               if ( event && event.type === "mouseover" ) {
-                       target.parents().each(function() {
-                               var parent = $( this ),
-                                       blurEvent;
-                               if ( parent.data( "ui-tooltip-open" ) ) {
-                                       blurEvent = $.Event( "blur" );
-                                       blurEvent.target = blurEvent.currentTarget = this;
-                                       that.close( blurEvent, true );
-                               }
-                               if ( parent.attr( "title" ) ) {
-                                       parent.uniqueId();
-                                       that.parents[ this.id ] = {
-                                               element: this,
-                                               title: parent.attr( "title" )
-                                       };
-                                       parent.attr( "title", "" );
-                               }
-                       });
-               }
-
-               this._updateContent( target, event );
+       isFirstItem: function() {
+               return this.active && !this.active.prevAll( ".ui-menu-item" ).length;
        },
 
-       _updateContent: function( target, event ) {
-               var content,
-                       contentOption = this.options.content,
-                       that = this,
-                       eventType = event ? event.type : null;
-
-               if ( typeof contentOption === "string" ) {
-                       return this._open( event, target, contentOption );
-               }
+       isLastItem: function() {
+               return this.active && !this.active.nextAll( ".ui-menu-item" ).length;
+       },
 
-               content = contentOption.call( target[0], function( response ) {
-                       // ignore async response if tooltip was closed already
-                       if ( !target.data( "ui-tooltip-open" ) ) {
-                               return;
+       _move: function( direction, filter, event ) {
+               var next;
+               if ( this.active ) {
+                       if ( direction === "first" || direction === "last" ) {
+                               next = this.active
+                                       [ direction === "first" ? "prevAll" : "nextAll" ]( ".ui-menu-item" )
+                                       .eq( -1 );
+                       } else {
+                               next = this.active
+                                       [ direction + "All" ]( ".ui-menu-item" )
+                                       .eq( 0 );
                        }
-                       // IE may instantly serve a cached response for ajax requests
-                       // delay this call to _open so the other call to _open runs first
-                       that._delay(function() {
-                               // jQuery creates a special event for focusin when it doesn't
-                               // exist natively. To improve performance, the native event
-                               // object is reused and the type is changed. Therefore, we can't
-                               // rely on the type being correct after the event finished
-                               // bubbling, so we set it back to the previous value. (#8740)
-                               if ( event ) {
-                                       event.type = eventType;
-                               }
-                               this._open( event, target, response );
-                       });
-               });
-               if ( content ) {
-                       this._open( event, target, content );
                }
+               if ( !next || !next.length || !this.active ) {
+                       next = this.activeMenu.children( ".ui-menu-item" )[ filter ]();
+               }
+
+               this.focus( event, next );
        },
 
-       _open: function( event, target, content ) {
-               var tooltip, events, delayedShow,
-                       positionOption = $.extend( {}, this.options.position );
+       nextPage: function( event ) {
+               var item, base, height;
 
-               if ( !content ) {
+               if ( !this.active ) {
+                       this.next( event );
                        return;
                }
-
-               // Content can be updated multiple times. If the tooltip already
-               // exists, then just update the content and bail.
-               tooltip = this._find( target );
-               if ( tooltip.length ) {
-                       tooltip.find( ".ui-tooltip-content" ).html( content );
+               if ( this.isLastItem() ) {
                        return;
                }
-
-               // if we have a title, clear it to prevent the native tooltip
-               // we have to check first to avoid defining a title if none exists
-               // (we don't want to cause an element to start matching [title])
-               //
-               // We use removeAttr only for key events, to allow IE to export the correct
-               // accessible attributes. For mouse events, set to empty string to avoid
-               // native tooltip showing up (happens only when removing inside mouseover).
-               if ( target.is( "[title]" ) ) {
-                       if ( event && event.type === "mouseover" ) {
-                               target.attr( "title", "" );
-                       } else {
-                               target.removeAttr( "title" );
-                       }
-               }
-
-               tooltip = this._tooltip( target );
-               addDescribedBy( target, tooltip.attr( "id" ) );
-               tooltip.find( ".ui-tooltip-content" ).html( content );
-
-               function position( event ) {
-                       positionOption.of = event;
-                       if ( tooltip.is( ":hidden" ) ) {
-                               return;
-                       }
-                       tooltip.position( positionOption );
-               }
-               if ( this.options.track && event && /^mouse/.test( event.type ) ) {
-                       this._on( this.document, {
-                               mousemove: position
+               if ( this._hasScroll() ) {
+                       base = this.active.offset().top;
+                       height = this.element.height();
+                       this.active.nextAll( ".ui-menu-item" ).each(function() {
+                               item = $( this );
+                               return item.offset().top - base - height < 0;
                        });
-                       // trigger once to override element-relative positioning
-                       position( event );
-               } else {
-                       tooltip.position( $.extend({
-                               of: target
-                       }, this.options.position ) );
-               }
 
-               tooltip.hide();
-
-               this._show( tooltip, this.options.show );
-               // Handle tracking tooltips that are shown with a delay (#8644). As soon
-               // as the tooltip is visible, position the tooltip using the most recent
-               // event.
-               if ( this.options.show && this.options.show.delay ) {
-                       delayedShow = this.delayedShow = setInterval(function() {
-                               if ( tooltip.is( ":visible" ) ) {
-                                       position( positionOption.of );
-                                       clearInterval( delayedShow );
-                               }
-                       }, $.fx.interval );
-               }
-
-               this._trigger( "open", event, { tooltip: tooltip } );
-
-               events = {
-                       keyup: function( event ) {
-                               if ( event.keyCode === $.ui.keyCode.ESCAPE ) {
-                                       var fakeEvent = $.Event(event);
-                                       fakeEvent.currentTarget = target[0];
-                                       this.close( fakeEvent, true );
-                               }
-                       },
-                       remove: function() {
-                               this._removeTooltip( tooltip );
-                       }
-               };
-               if ( !event || event.type === "mouseover" ) {
-                       events.mouseleave = "close";
-               }
-               if ( !event || event.type === "focusin" ) {
-                       events.focusout = "close";
+                       this.focus( event, item );
+               } else {
+                       this.focus( event, this.activeMenu.children( ".ui-menu-item" )
+                               [ !this.active ? "first" : "last" ]() );
                }
-               this._on( true, target, events );
        },
 
-       close: function( event ) {
-               var that = this,
-                       target = $( event ? event.currentTarget : this.element ),
-                       tooltip = this._find( target );
-
-               // disabling closes the tooltip, so we need to track when we're closing
-               // to avoid an infinite loop in case the tooltip becomes disabled on close
-               if ( this.closing ) {
+       previousPage: function( event ) {
+               var item, base, height;
+               if ( !this.active ) {
+                       this.next( event );
                        return;
                }
-
-               // Clear the interval for delayed tracking tooltips
-               clearInterval( this.delayedShow );
-
-               // only set title if we had one before (see comment in _open())
-               if ( target.data( "ui-tooltip-title" ) ) {
-                       target.attr( "title", target.data( "ui-tooltip-title" ) );
-               }
-
-               removeDescribedBy( target );
-
-               tooltip.stop( true );
-               this._hide( tooltip, this.options.hide, function() {
-                       that._removeTooltip( $( this ) );
-               });
-
-               target.removeData( "ui-tooltip-open" );
-               this._off( target, "mouseleave focusout keyup" );
-               // Remove 'remove' binding only on delegated targets
-               if ( target[0] !== this.element[0] ) {
-                       this._off( target, "remove" );
+               if ( this.isFirstItem() ) {
+                       return;
                }
-               this._off( this.document, "mousemove" );
-
-               if ( event && event.type === "mouseleave" ) {
-                       $.each( this.parents, function( id, parent ) {
-                               $( parent.element ).attr( "title", parent.title );
-                               delete that.parents[ id ];
+               if ( this._hasScroll() ) {
+                       base = this.active.offset().top;
+                       height = this.element.height();
+                       this.active.prevAll( ".ui-menu-item" ).each(function() {
+                               item = $( this );
+                               return item.offset().top - base + height > 0;
                        });
-               }
-
-               this.closing = true;
-               this._trigger( "close", event, { tooltip: tooltip } );
-               this.closing = false;
-       },
-
-       _tooltip: function( element ) {
-               var id = "ui-tooltip-" + increments++,
-                       tooltip = $( "<div>" )
-                               .attr({
-                                       id: id,
-                                       role: "tooltip"
-                               })
-                               .addClass( "ui-tooltip ui-widget ui-corner-all ui-widget-content " +
-                                       ( this.options.tooltipClass || "" ) );
-               $( "<div>" )
-                       .addClass( "ui-tooltip-content" )
-                       .appendTo( tooltip );
-               tooltip.appendTo( this.document[0].body );
-               this.tooltips[ id ] = element;
-               return tooltip;
-       },
 
-       _find: function( target ) {
-               var id = target.data( "ui-tooltip-id" );
-               return id ? $( "#" + id ) : $();
+                       this.focus( event, item );
+               } else {
+                       this.focus( event, this.activeMenu.children( ".ui-menu-item" ).first() );
+               }
        },
 
-       _removeTooltip: function( tooltip ) {
-               tooltip.remove();
-               delete this.tooltips[ tooltip.attr( "id" ) ];
+       _hasScroll: function() {
+               return this.element.outerHeight() < this.element.prop( "scrollHeight" );
        },
 
-       _destroy: function() {
-               var that = this;
-
-               // close open tooltips
-               $.each( this.tooltips, function( id, element ) {
-                       // Delegate to close method to handle common cleanup
-                       var event = $.Event( "blur" );
-                       event.target = event.currentTarget = element[0];
-                       that.close( event, true );
-
-                       // Remove immediately; destroying an open tooltip doesn't use the
-                       // hide animation
-                       $( "#" + id ).remove();
-
-                       // Restore the title
-                       if ( element.data( "ui-tooltip-title" ) ) {
-                               element.attr( "title", element.data( "ui-tooltip-title" ) );
-                               element.removeData( "ui-tooltip-title" );
-                       }
-               });
+       select: function( event ) {
+               // TODO: It should never be possible to not have an active item at this
+               // point, but the tests don't trigger mouseenter before click.
+               this.active = this.active || $( event.target ).closest( ".ui-menu-item" );
+               var ui = { item: this.active };
+               if ( !this.active.has( ".ui-menu" ).length ) {
+                       this.collapseAll( event, true );
+               }
+               this._trigger( "select", event, ui );
        }
 });
 
-}( jQuery ) );
+}( jQuery ));
diff --git a/karmaworld/assets/js/jquery.dataTables.js b/karmaworld/assets/js/jquery.dataTables.js
new file mode 100644 (file)
index 0000000..1d8a220
--- /dev/null
@@ -0,0 +1,12099 @@
+/**
+ * @summary     DataTables
+ * @description Paginate, search and sort HTML tables
+ * @version     1.9.4
+ * @file        jquery.dataTables.js
+ * @author      Allan Jardine (www.sprymedia.co.uk)
+ * @contact     www.sprymedia.co.uk/contact
+ *
+ * @copyright Copyright 2008-2012 Allan Jardine, all rights reserved.
+ *
+ * This source file is free software, under either the GPL v2 license or a
+ * BSD style license, available at:
+ *   http://datatables.net/license_gpl2
+ *   http://datatables.net/license_bsd
+ * 
+ * This source file is distributed in the hope that it will be useful, but 
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the license files for details.
+ * 
+ * For details please refer to: http://www.datatables.net
+ */
+
+/*jslint evil: true, undef: true, browser: true */
+/*globals $, jQuery,define,_fnExternApiFunc,_fnInitialise,_fnInitComplete,_fnLanguageCompat,_fnAddColumn,_fnColumnOptions,_fnAddData,_fnCreateTr,_fnGatherData,_fnBuildHead,_fnDrawHead,_fnDraw,_fnReDraw,_fnAjaxUpdate,_fnAjaxParameters,_fnAjaxUpdateDraw,_fnServerParams,_fnAddOptionsHtml,_fnFeatureHtmlTable,_fnScrollDraw,_fnAdjustColumnSizing,_fnFeatureHtmlFilter,_fnFilterComplete,_fnFilterCustom,_fnFilterColumn,_fnFilter,_fnBuildSearchArray,_fnBuildSearchRow,_fnFilterCreateSearch,_fnDataToSearch,_fnSort,_fnSortAttachListener,_fnSortingClasses,_fnFeatureHtmlPaginate,_fnPageChange,_fnFeatureHtmlInfo,_fnUpdateInfo,_fnFeatureHtmlLength,_fnFeatureHtmlProcessing,_fnProcessingDisplay,_fnVisibleToColumnIndex,_fnColumnIndexToVisible,_fnNodeToDataIndex,_fnVisbleColumns,_fnCalculateEnd,_fnConvertToWidth,_fnCalculateColumnWidths,_fnScrollingWidthAdjust,_fnGetWidestNode,_fnGetMaxLenString,_fnStringToCss,_fnDetectType,_fnSettingsFromNode,_fnGetDataMaster,_fnGetTrNodes,_fnGetTdNodes,_fnEscapeRegex,_fnDeleteIndex,_fnReOrderIndex,_fnColumnOrdering,_fnLog,_fnClearTable,_fnSaveState,_fnLoadState,_fnCreateCookie,_fnReadCookie,_fnDetectHeader,_fnGetUniqueThs,_fnScrollBarWidth,_fnApplyToChildren,_fnMap,_fnGetRowData,_fnGetCellData,_fnSetCellData,_fnGetObjectDataFn,_fnSetObjectDataFn,_fnApplyColumnDefs,_fnBindAction,_fnCallbackReg,_fnCallbackFire,_fnJsonString,_fnRender,_fnNodeToColumnIndex,_fnInfoMacros,_fnBrowserDetect,_fnGetColumns*/
+
+(/** @lends <global> */function( window, document, undefined ) {
+
+(function( factory ) {
+       "use strict";
+
+       // Define as an AMD module if possible
+       if ( typeof define === 'function' && define.amd )
+       {
+               define( ['jquery'], factory );
+       }
+       /* Define using browser globals otherwise
+        * Prevent multiple instantiations if the script is loaded twice
+        */
+       else if ( jQuery && !jQuery.fn.dataTable )
+       {
+               factory( jQuery );
+       }
+}
+(/** @lends <global> */function( $ ) {
+       "use strict";
+       /** 
+        * DataTables is a plug-in for the jQuery Javascript library. It is a 
+        * highly flexible tool, based upon the foundations of progressive 
+        * enhancement, which will add advanced interaction controls to any 
+        * HTML table. For a full list of features please refer to
+        * <a href="http://datatables.net">DataTables.net</a>.
+        *
+        * Note that the <i>DataTable</i> object is not a global variable but is
+        * aliased to <i>jQuery.fn.DataTable</i> and <i>jQuery.fn.dataTable</i> through which 
+        * it may be  accessed.
+        *
+        *  @class
+        *  @param {object} [oInit={}] Configuration object for DataTables. Options
+        *    are defined by {@link DataTable.defaults}
+        *  @requires jQuery 1.3+
+        * 
+        *  @example
+        *    // Basic initialisation
+        *    $(document).ready( function {
+        *      $('#example').dataTable();
+        *    } );
+        *  
+        *  @example
+        *    // Initialisation with configuration options - in this case, disable
+        *    // pagination and sorting.
+        *    $(document).ready( function {
+        *      $('#example').dataTable( {
+        *        "bPaginate": false,
+        *        "bSort": false 
+        *      } );
+        *    } );
+        */
+       var DataTable = function( oInit )
+       {
+               
+               
+               /**
+                * Add a column to the list used for the table with default values
+                *  @param {object} oSettings dataTables settings object
+                *  @param {node} nTh The th element for this column
+                *  @memberof DataTable#oApi
+                */
+               function _fnAddColumn( oSettings, nTh )
+               {
+                       var oDefaults = DataTable.defaults.columns;
+                       var iCol = oSettings.aoColumns.length;
+                       var oCol = $.extend( {}, DataTable.models.oColumn, oDefaults, {
+                               "sSortingClass": oSettings.oClasses.sSortable,
+                               "sSortingClassJUI": oSettings.oClasses.sSortJUI,
+                               "nTh": nTh ? nTh : document.createElement('th'),
+                               "sTitle":    oDefaults.sTitle    ? oDefaults.sTitle    : nTh ? nTh.innerHTML : '',
+                               "aDataSort": oDefaults.aDataSort ? oDefaults.aDataSort : [iCol],
+                               "mData": oDefaults.mData ? oDefaults.oDefaults : iCol
+                       } );
+                       oSettings.aoColumns.push( oCol );
+                       
+                       /* Add a column specific filter */
+                       if ( oSettings.aoPreSearchCols[ iCol ] === undefined || oSettings.aoPreSearchCols[ iCol ] === null )
+                       {
+                               oSettings.aoPreSearchCols[ iCol ] = $.extend( {}, DataTable.models.oSearch );
+                       }
+                       else
+                       {
+                               var oPre = oSettings.aoPreSearchCols[ iCol ];
+                               
+                               /* Don't require that the user must specify bRegex, bSmart or bCaseInsensitive */
+                               if ( oPre.bRegex === undefined )
+                               {
+                                       oPre.bRegex = true;
+                               }
+                               
+                               if ( oPre.bSmart === undefined )
+                               {
+                                       oPre.bSmart = true;
+                               }
+                               
+                               if ( oPre.bCaseInsensitive === undefined )
+                               {
+                                       oPre.bCaseInsensitive = true;
+                               }
+                       }
+                       
+                       /* Use the column options function to initialise classes etc */
+                       _fnColumnOptions( oSettings, iCol, null );
+               }
+               
+               
+               /**
+                * Apply options for a column
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iCol column index to consider
+                *  @param {object} oOptions object with sType, bVisible and bSearchable etc
+                *  @memberof DataTable#oApi
+                */
+               function _fnColumnOptions( oSettings, iCol, oOptions )
+               {
+                       var oCol = oSettings.aoColumns[ iCol ];
+                       
+                       /* User specified column options */
+                       if ( oOptions !== undefined && oOptions !== null )
+                       {
+                               /* Backwards compatibility for mDataProp */
+                               if ( oOptions.mDataProp && !oOptions.mData )
+                               {
+                                       oOptions.mData = oOptions.mDataProp;
+                               }
+               
+                               if ( oOptions.sType !== undefined )
+                               {
+                                       oCol.sType = oOptions.sType;
+                                       oCol._bAutoType = false;
+                               }
+                               
+                               $.extend( oCol, oOptions );
+                               _fnMap( oCol, oOptions, "sWidth", "sWidthOrig" );
+               
+                               /* iDataSort to be applied (backwards compatibility), but aDataSort will take
+                                * priority if defined
+                                */
+                               if ( oOptions.iDataSort !== undefined )
+                               {
+                                       oCol.aDataSort = [ oOptions.iDataSort ];
+                               }
+                               _fnMap( oCol, oOptions, "aDataSort" );
+                       }
+               
+                       /* Cache the data get and set functions for speed */
+                       var mRender = oCol.mRender ? _fnGetObjectDataFn( oCol.mRender ) : null;
+                       var mData = _fnGetObjectDataFn( oCol.mData );
+               
+                       oCol.fnGetData = function (oData, sSpecific) {
+                               var innerData = mData( oData, sSpecific );
+               
+                               if ( oCol.mRender && (sSpecific && sSpecific !== '') )
+                               {
+                                       return mRender( innerData, sSpecific, oData );
+                               }
+                               return innerData;
+                       };
+                       oCol.fnSetData = _fnSetObjectDataFn( oCol.mData );
+                       
+                       /* Feature sorting overrides column specific when off */
+                       if ( !oSettings.oFeatures.bSort )
+                       {
+                               oCol.bSortable = false;
+                       }
+                       
+                       /* Check that the class assignment is correct for sorting */
+                       if ( !oCol.bSortable ||
+                                ($.inArray('asc', oCol.asSorting) == -1 && $.inArray('desc', oCol.asSorting) == -1) )
+                       {
+                               oCol.sSortingClass = oSettings.oClasses.sSortableNone;
+                               oCol.sSortingClassJUI = "";
+                       }
+                       else if ( $.inArray('asc', oCol.asSorting) == -1 && $.inArray('desc', oCol.asSorting) == -1 )
+                       {
+                               oCol.sSortingClass = oSettings.oClasses.sSortable;
+                               oCol.sSortingClassJUI = oSettings.oClasses.sSortJUI;
+                       }
+                       else if ( $.inArray('asc', oCol.asSorting) != -1 && $.inArray('desc', oCol.asSorting) == -1 )
+                       {
+                               oCol.sSortingClass = oSettings.oClasses.sSortableAsc;
+                               oCol.sSortingClassJUI = oSettings.oClasses.sSortJUIAscAllowed;
+                       }
+                       else if ( $.inArray('asc', oCol.asSorting) == -1 && $.inArray('desc', oCol.asSorting) != -1 )
+                       {
+                               oCol.sSortingClass = oSettings.oClasses.sSortableDesc;
+                               oCol.sSortingClassJUI = oSettings.oClasses.sSortJUIDescAllowed;
+                       }
+               }
+               
+               
+               /**
+                * Adjust the table column widths for new data. Note: you would probably want to 
+                * do a redraw after calling this function!
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnAdjustColumnSizing ( oSettings )
+               {
+                       /* Not interested in doing column width calculation if auto-width is disabled */
+                       if ( oSettings.oFeatures.bAutoWidth === false )
+                       {
+                               return false;
+                       }
+                       
+                       _fnCalculateColumnWidths( oSettings );
+                       for ( var i=0 , iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               oSettings.aoColumns[i].nTh.style.width = oSettings.aoColumns[i].sWidth;
+                       }
+               }
+               
+               
+               /**
+                * Covert the index of a visible column to the index in the data array (take account
+                * of hidden columns)
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iMatch Visible column index to lookup
+                *  @returns {int} i the data index
+                *  @memberof DataTable#oApi
+                */
+               function _fnVisibleToColumnIndex( oSettings, iMatch )
+               {
+                       var aiVis = _fnGetColumns( oSettings, 'bVisible' );
+               
+                       return typeof aiVis[iMatch] === 'number' ?
+                               aiVis[iMatch] :
+                               null;
+               }
+               
+               
+               /**
+                * Covert the index of an index in the data array and convert it to the visible
+                *   column index (take account of hidden columns)
+                *  @param {int} iMatch Column index to lookup
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {int} i the data index
+                *  @memberof DataTable#oApi
+                */
+               function _fnColumnIndexToVisible( oSettings, iMatch )
+               {
+                       var aiVis = _fnGetColumns( oSettings, 'bVisible' );
+                       var iPos = $.inArray( iMatch, aiVis );
+               
+                       return iPos !== -1 ? iPos : null;
+               }
+               
+               
+               /**
+                * Get the number of visible columns
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {int} i the number of visible columns
+                *  @memberof DataTable#oApi
+                */
+               function _fnVisbleColumns( oSettings )
+               {
+                       return _fnGetColumns( oSettings, 'bVisible' ).length;
+               }
+               
+               
+               /**
+                * Get an array of column indexes that match a given property
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string} sParam Parameter in aoColumns to look for - typically 
+                *    bVisible or bSearchable
+                *  @returns {array} Array of indexes with matched properties
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetColumns( oSettings, sParam )
+               {
+                       var a = [];
+               
+                       $.map( oSettings.aoColumns, function(val, i) {
+                               if ( val[sParam] ) {
+                                       a.push( i );
+                               }
+                       } );
+               
+                       return a;
+               }
+               
+               
+               /**
+                * Get the sort type based on an input string
+                *  @param {string} sData data we wish to know the type of
+                *  @returns {string} type (defaults to 'string' if no type can be detected)
+                *  @memberof DataTable#oApi
+                */
+               function _fnDetectType( sData )
+               {
+                       var aTypes = DataTable.ext.aTypes;
+                       var iLen = aTypes.length;
+                       
+                       for ( var i=0 ; i<iLen ; i++ )
+                       {
+                               var sType = aTypes[i]( sData );
+                               if ( sType !== null )
+                               {
+                                       return sType;
+                               }
+                       }
+                       
+                       return 'string';
+               }
+               
+               
+               /**
+                * Figure out how to reorder a display list
+                *  @param {object} oSettings dataTables settings object
+                *  @returns array {int} aiReturn index list for reordering
+                *  @memberof DataTable#oApi
+                */
+               function _fnReOrderIndex ( oSettings, sColumns )
+               {
+                       var aColumns = sColumns.split(',');
+                       var aiReturn = [];
+                       
+                       for ( var i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               for ( var j=0 ; j<iLen ; j++ )
+                               {
+                                       if ( oSettings.aoColumns[i].sName == aColumns[j] )
+                                       {
+                                               aiReturn.push( j );
+                                               break;
+                                       }
+                               }
+                       }
+                       
+                       return aiReturn;
+               }
+               
+               
+               /**
+                * Get the column ordering that DataTables expects
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {string} comma separated list of names
+                *  @memberof DataTable#oApi
+                */
+               function _fnColumnOrdering ( oSettings )
+               {
+                       var sNames = '';
+                       for ( var i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               sNames += oSettings.aoColumns[i].sName+',';
+                       }
+                       if ( sNames.length == iLen )
+                       {
+                               return "";
+                       }
+                       return sNames.slice(0, -1);
+               }
+               
+               
+               /**
+                * Take the column definitions and static columns arrays and calculate how
+                * they relate to column indexes. The callback function will then apply the
+                * definition found for a column to a suitable configuration object.
+                *  @param {object} oSettings dataTables settings object
+                *  @param {array} aoColDefs The aoColumnDefs array that is to be applied
+                *  @param {array} aoCols The aoColumns array that defines columns individually
+                *  @param {function} fn Callback function - takes two parameters, the calculated
+                *    column index and the definition for that column.
+                *  @memberof DataTable#oApi
+                */
+               function _fnApplyColumnDefs( oSettings, aoColDefs, aoCols, fn )
+               {
+                       var i, iLen, j, jLen, k, kLen;
+               
+                       // Column definitions with aTargets
+                       if ( aoColDefs )
+                       {
+                               /* Loop over the definitions array - loop in reverse so first instance has priority */
+                               for ( i=aoColDefs.length-1 ; i>=0 ; i-- )
+                               {
+                                       /* Each definition can target multiple columns, as it is an array */
+                                       var aTargets = aoColDefs[i].aTargets;
+                                       if ( !$.isArray( aTargets ) )
+                                       {
+                                               _fnLog( oSettings, 1, 'aTargets must be an array of targets, not a '+(typeof aTargets) );
+                                       }
+               
+                                       for ( j=0, jLen=aTargets.length ; j<jLen ; j++ )
+                                       {
+                                               if ( typeof aTargets[j] === 'number' && aTargets[j] >= 0 )
+                                               {
+                                                       /* Add columns that we don't yet know about */
+                                                       while( oSettings.aoColumns.length <= aTargets[j] )
+                                                       {
+                                                               _fnAddColumn( oSettings );
+                                                       }
+               
+                                                       /* Integer, basic index */
+                                                       fn( aTargets[j], aoColDefs[i] );
+                                               }
+                                               else if ( typeof aTargets[j] === 'number' && aTargets[j] < 0 )
+                                               {
+                                                       /* Negative integer, right to left column counting */
+                                                       fn( oSettings.aoColumns.length+aTargets[j], aoColDefs[i] );
+                                               }
+                                               else if ( typeof aTargets[j] === 'string' )
+                                               {
+                                                       /* Class name matching on TH element */
+                                                       for ( k=0, kLen=oSettings.aoColumns.length ; k<kLen ; k++ )
+                                                       {
+                                                               if ( aTargets[j] == "_all" ||
+                                                                    $(oSettings.aoColumns[k].nTh).hasClass( aTargets[j] ) )
+                                                               {
+                                                                       fn( k, aoColDefs[i] );
+                                                               }
+                                                       }
+                                               }
+                                       }
+                               }
+                       }
+               
+                       // Statically defined columns array
+                       if ( aoCols )
+                       {
+                               for ( i=0, iLen=aoCols.length ; i<iLen ; i++ )
+                               {
+                                       fn( i, aoCols[i] );
+                               }
+                       }
+               }
+               
+               /**
+                * Add a data array to the table, creating DOM node etc. This is the parallel to 
+                * _fnGatherData, but for adding rows from a Javascript source, rather than a
+                * DOM source.
+                *  @param {object} oSettings dataTables settings object
+                *  @param {array} aData data array to be added
+                *  @returns {int} >=0 if successful (index of new aoData entry), -1 if failed
+                *  @memberof DataTable#oApi
+                */
+               function _fnAddData ( oSettings, aDataSupplied )
+               {
+                       var oCol;
+                       
+                       /* Take an independent copy of the data source so we can bash it about as we wish */
+                       var aDataIn = ($.isArray(aDataSupplied)) ?
+                               aDataSupplied.slice() :
+                               $.extend( true, {}, aDataSupplied );
+                       
+                       /* Create the object for storing information about this new row */
+                       var iRow = oSettings.aoData.length;
+                       var oData = $.extend( true, {}, DataTable.models.oRow );
+                       oData._aData = aDataIn;
+                       oSettings.aoData.push( oData );
+               
+                       /* Create the cells */
+                       var nTd, sThisType;
+                       for ( var i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               oCol = oSettings.aoColumns[i];
+               
+                               /* Use rendered data for filtering / sorting */
+                               if ( typeof oCol.fnRender === 'function' && oCol.bUseRendered && oCol.mData !== null )
+                               {
+                                       _fnSetCellData( oSettings, iRow, i, _fnRender(oSettings, iRow, i) );
+                               }
+                               else
+                               {
+                                       _fnSetCellData( oSettings, iRow, i, _fnGetCellData( oSettings, iRow, i ) );
+                               }
+                               
+                               /* See if we should auto-detect the column type */
+                               if ( oCol._bAutoType && oCol.sType != 'string' )
+                               {
+                                       /* Attempt to auto detect the type - same as _fnGatherData() */
+                                       var sVarType = _fnGetCellData( oSettings, iRow, i, 'type' );
+                                       if ( sVarType !== null && sVarType !== '' )
+                                       {
+                                               sThisType = _fnDetectType( sVarType );
+                                               if ( oCol.sType === null )
+                                               {
+                                                       oCol.sType = sThisType;
+                                               }
+                                               else if ( oCol.sType != sThisType && oCol.sType != "html" )
+                                               {
+                                                       /* String is always the 'fallback' option */
+                                                       oCol.sType = 'string';
+                                               }
+                                       }
+                               }
+                       }
+                       
+                       /* Add to the display array */
+                       oSettings.aiDisplayMaster.push( iRow );
+               
+                       /* Create the DOM information */
+                       if ( !oSettings.oFeatures.bDeferRender )
+                       {
+                               _fnCreateTr( oSettings, iRow );
+                       }
+               
+                       return iRow;
+               }
+               
+               
+               /**
+                * Read in the data from the target table from the DOM
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnGatherData( oSettings )
+               {
+                       var iLoop, i, iLen, j, jLen, jInner,
+                               nTds, nTrs, nTd, nTr, aLocalData, iThisIndex,
+                               iRow, iRows, iColumn, iColumns, sNodeName,
+                               oCol, oData;
+                       
+                       /*
+                        * Process by row first
+                        * Add the data object for the whole table - storing the tr node. Note - no point in getting
+                        * DOM based data if we are going to go and replace it with Ajax source data.
+                        */
+                       if ( oSettings.bDeferLoading || oSettings.sAjaxSource === null )
+                       {
+                               nTr = oSettings.nTBody.firstChild;
+                               while ( nTr )
+                               {
+                                       if ( nTr.nodeName.toUpperCase() == "TR" )
+                                       {
+                                               iThisIndex = oSettings.aoData.length;
+                                               nTr._DT_RowIndex = iThisIndex;
+                                               oSettings.aoData.push( $.extend( true, {}, DataTable.models.oRow, {
+                                                       "nTr": nTr
+                                               } ) );
+               
+                                               oSettings.aiDisplayMaster.push( iThisIndex );
+                                               nTd = nTr.firstChild;
+                                               jInner = 0;
+                                               while ( nTd )
+                                               {
+                                                       sNodeName = nTd.nodeName.toUpperCase();
+                                                       if ( sNodeName == "TD" || sNodeName == "TH" )
+                                                       {
+                                                               _fnSetCellData( oSettings, iThisIndex, jInner, $.trim(nTd.innerHTML) );
+                                                               jInner++;
+                                                       }
+                                                       nTd = nTd.nextSibling;
+                                               }
+                                       }
+                                       nTr = nTr.nextSibling;
+                               }
+                       }
+                       
+                       /* Gather in the TD elements of the Table - note that this is basically the same as
+                        * fnGetTdNodes, but that function takes account of hidden columns, which we haven't yet
+                        * setup!
+                        */
+                       nTrs = _fnGetTrNodes( oSettings );
+                       nTds = [];
+                       for ( i=0, iLen=nTrs.length ; i<iLen ; i++ )
+                       {
+                               nTd = nTrs[i].firstChild;
+                               while ( nTd )
+                               {
+                                       sNodeName = nTd.nodeName.toUpperCase();
+                                       if ( sNodeName == "TD" || sNodeName == "TH" )
+                                       {
+                                               nTds.push( nTd );
+                                       }
+                                       nTd = nTd.nextSibling;
+                               }
+                       }
+                       
+                       /* Now process by column */
+                       for ( iColumn=0, iColumns=oSettings.aoColumns.length ; iColumn<iColumns ; iColumn++ )
+                       {
+                               oCol = oSettings.aoColumns[iColumn];
+               
+                               /* Get the title of the column - unless there is a user set one */
+                               if ( oCol.sTitle === null )
+                               {
+                                       oCol.sTitle = oCol.nTh.innerHTML;
+                               }
+                               
+                               var
+                                       bAutoType = oCol._bAutoType,
+                                       bRender = typeof oCol.fnRender === 'function',
+                                       bClass = oCol.sClass !== null,
+                                       bVisible = oCol.bVisible,
+                                       nCell, sThisType, sRendered, sValType;
+                               
+                               /* A single loop to rule them all (and be more efficient) */
+                               if ( bAutoType || bRender || bClass || !bVisible )
+                               {
+                                       for ( iRow=0, iRows=oSettings.aoData.length ; iRow<iRows ; iRow++ )
+                                       {
+                                               oData = oSettings.aoData[iRow];
+                                               nCell = nTds[ (iRow*iColumns) + iColumn ];
+                                               
+                                               /* Type detection */
+                                               if ( bAutoType && oCol.sType != 'string' )
+                                               {
+                                                       sValType = _fnGetCellData( oSettings, iRow, iColumn, 'type' );
+                                                       if ( sValType !== '' )
+                                                       {
+                                                               sThisType = _fnDetectType( sValType );
+                                                               if ( oCol.sType === null )
+                                                               {
+                                                                       oCol.sType = sThisType;
+                                                               }
+                                                               else if ( oCol.sType != sThisType && 
+                                                                         oCol.sType != "html" )
+                                                               {
+                                                                       /* String is always the 'fallback' option */
+                                                                       oCol.sType = 'string';
+                                                               }
+                                                       }
+                                               }
+               
+                                               if ( oCol.mRender )
+                                               {
+                                                       // mRender has been defined, so we need to get the value and set it
+                                                       nCell.innerHTML = _fnGetCellData( oSettings, iRow, iColumn, 'display' );
+                                               }
+                                               else if ( oCol.mData !== iColumn )
+                                               {
+                                                       // If mData is not the same as the column number, then we need to
+                                                       // get the dev set value. If it is the column, no point in wasting
+                                                       // time setting the value that is already there!
+                                                       nCell.innerHTML = _fnGetCellData( oSettings, iRow, iColumn, 'display' );
+                                               }
+                                               
+                                               /* Rendering */
+                                               if ( bRender )
+                                               {
+                                                       sRendered = _fnRender( oSettings, iRow, iColumn );
+                                                       nCell.innerHTML = sRendered;
+                                                       if ( oCol.bUseRendered )
+                                                       {
+                                                               /* Use the rendered data for filtering / sorting */
+                                                               _fnSetCellData( oSettings, iRow, iColumn, sRendered );
+                                                       }
+                                               }
+                                               
+                                               /* Classes */
+                                               if ( bClass )
+                                               {
+                                                       nCell.className += ' '+oCol.sClass;
+                                               }
+                                               
+                                               /* Column visibility */
+                                               if ( !bVisible )
+                                               {
+                                                       oData._anHidden[iColumn] = nCell;
+                                                       nCell.parentNode.removeChild( nCell );
+                                               }
+                                               else
+                                               {
+                                                       oData._anHidden[iColumn] = null;
+                                               }
+               
+                                               if ( oCol.fnCreatedCell )
+                                               {
+                                                       oCol.fnCreatedCell.call( oSettings.oInstance,
+                                                               nCell, _fnGetCellData( oSettings, iRow, iColumn, 'display' ), oData._aData, iRow, iColumn
+                                                       );
+                                               }
+                                       }
+                               }
+                       }
+               
+                       /* Row created callbacks */
+                       if ( oSettings.aoRowCreatedCallback.length !== 0 )
+                       {
+                               for ( i=0, iLen=oSettings.aoData.length ; i<iLen ; i++ )
+                               {
+                                       oData = oSettings.aoData[i];
+                                       _fnCallbackFire( oSettings, 'aoRowCreatedCallback', null, [oData.nTr, oData._aData, i] );
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Take a TR element and convert it to an index in aoData
+                *  @param {object} oSettings dataTables settings object
+                *  @param {node} n the TR element to find
+                *  @returns {int} index if the node is found, null if not
+                *  @memberof DataTable#oApi
+                */
+               function _fnNodeToDataIndex( oSettings, n )
+               {
+                       return (n._DT_RowIndex!==undefined) ? n._DT_RowIndex : null;
+               }
+               
+               
+               /**
+                * Take a TD element and convert it into a column data index (not the visible index)
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow The row number the TD/TH can be found in
+                *  @param {node} n The TD/TH element to find
+                *  @returns {int} index if the node is found, -1 if not
+                *  @memberof DataTable#oApi
+                */
+               function _fnNodeToColumnIndex( oSettings, iRow, n )
+               {
+                       var anCells = _fnGetTdNodes( oSettings, iRow );
+               
+                       for ( var i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               if ( anCells[i] === n )
+                               {
+                                       return i;
+                               }
+                       }
+                       return -1;
+               }
+               
+               
+               /**
+                * Get an array of data for a given row from the internal data cache
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow aoData row id
+                *  @param {string} sSpecific data get type ('type' 'filter' 'sort')
+                *  @param {array} aiColumns Array of column indexes to get data from
+                *  @returns {array} Data array
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetRowData( oSettings, iRow, sSpecific, aiColumns )
+               {
+                       var out = [];
+                       for ( var i=0, iLen=aiColumns.length ; i<iLen ; i++ )
+                       {
+                               out.push( _fnGetCellData( oSettings, iRow, aiColumns[i], sSpecific ) );
+                       }
+                       return out;
+               }
+               
+               
+               /**
+                * Get the data for a given cell from the internal cache, taking into account data mapping
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow aoData row id
+                *  @param {int} iCol Column index
+                *  @param {string} sSpecific data get type ('display', 'type' 'filter' 'sort')
+                *  @returns {*} Cell data
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetCellData( oSettings, iRow, iCol, sSpecific )
+               {
+                       var sData;
+                       var oCol = oSettings.aoColumns[iCol];
+                       var oData = oSettings.aoData[iRow]._aData;
+               
+                       if ( (sData=oCol.fnGetData( oData, sSpecific )) === undefined )
+                       {
+                               if ( oSettings.iDrawError != oSettings.iDraw && oCol.sDefaultContent === null )
+                               {
+                                       _fnLog( oSettings, 0, "Requested unknown parameter "+
+                                               (typeof oCol.mData=='function' ? '{mData function}' : "'"+oCol.mData+"'")+
+                                               " from the data source for row "+iRow );
+                                       oSettings.iDrawError = oSettings.iDraw;
+                               }
+                               return oCol.sDefaultContent;
+                       }
+               
+                       /* When the data source is null, we can use default column data */
+                       if ( sData === null && oCol.sDefaultContent !== null )
+                       {
+                               sData = oCol.sDefaultContent;
+                       }
+                       else if ( typeof sData === 'function' )
+                       {
+                               /* If the data source is a function, then we run it and use the return */
+                               return sData();
+                       }
+               
+                       if ( sSpecific == 'display' && sData === null )
+                       {
+                               return '';
+                       }
+                       return sData;
+               }
+               
+               
+               /**
+                * Set the value for a specific cell, into the internal data cache
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow aoData row id
+                *  @param {int} iCol Column index
+                *  @param {*} val Value to set
+                *  @memberof DataTable#oApi
+                */
+               function _fnSetCellData( oSettings, iRow, iCol, val )
+               {
+                       var oCol = oSettings.aoColumns[iCol];
+                       var oData = oSettings.aoData[iRow]._aData;
+               
+                       oCol.fnSetData( oData, val );
+               }
+               
+               
+               // Private variable that is used to match array syntax in the data property object
+               var __reArray = /\[.*?\]$/;
+               
+               /**
+                * Return a function that can be used to get data from a source object, taking
+                * into account the ability to use nested objects as a source
+                *  @param {string|int|function} mSource The data source for the object
+                *  @returns {function} Data get function
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetObjectDataFn( mSource )
+               {
+                       if ( mSource === null )
+                       {
+                               /* Give an empty string for rendering / sorting etc */
+                               return function (data, type) {
+                                       return null;
+                               };
+                       }
+                       else if ( typeof mSource === 'function' )
+                       {
+                               return function (data, type, extra) {
+                                       return mSource( data, type, extra );
+                               };
+                       }
+                       else if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 || mSource.indexOf('[') !== -1) )
+                       {
+                               /* If there is a . in the source string then the data source is in a 
+                                * nested object so we loop over the data for each level to get the next
+                                * level down. On each loop we test for undefined, and if found immediately
+                                * return. This allows entire objects to be missing and sDefaultContent to
+                                * be used if defined, rather than throwing an error
+                                */
+                               var fetchData = function (data, type, src) {
+                                       var a = src.split('.');
+                                       var arrayNotation, out, innerSrc;
+               
+                                       if ( src !== "" )
+                                       {
+                                               for ( var i=0, iLen=a.length ; i<iLen ; i++ )
+                                               {
+                                                       // Check if we are dealing with an array notation request
+                                                       arrayNotation = a[i].match(__reArray);
+               
+                                                       if ( arrayNotation ) {
+                                                               a[i] = a[i].replace(__reArray, '');
+               
+                                                               // Condition allows simply [] to be passed in
+                                                               if ( a[i] !== "" ) {
+                                                                       data = data[ a[i] ];
+                                                               }
+                                                               out = [];
+                                                               
+                                                               // Get the remainder of the nested object to get
+                                                               a.splice( 0, i+1 );
+                                                               innerSrc = a.join('.');
+               
+                                                               // Traverse each entry in the array getting the properties requested
+                                                               for ( var j=0, jLen=data.length ; j<jLen ; j++ ) {
+                                                                       out.push( fetchData( data[j], type, innerSrc ) );
+                                                               }
+               
+                                                               // If a string is given in between the array notation indicators, that
+                                                               // is used to join the strings together, otherwise an array is returned
+                                                               var join = arrayNotation[0].substring(1, arrayNotation[0].length-1);
+                                                               data = (join==="") ? out : out.join(join);
+               
+                                                               // The inner call to fetchData has already traversed through the remainder
+                                                               // of the source requested, so we exit from the loop
+                                                               break;
+                                                       }
+               
+                                                       if ( data === null || data[ a[i] ] === undefined )
+                                                       {
+                                                               return undefined;
+                                                       }
+                                                       data = data[ a[i] ];
+                                               }
+                                       }
+               
+                                       return data;
+                               };
+               
+                               return function (data, type) {
+                                       return fetchData( data, type, mSource );
+                               };
+                       }
+                       else
+                       {
+                               /* Array or flat object mapping */
+                               return function (data, type) {
+                                       return data[mSource];   
+                               };
+                       }
+               }
+               
+               
+               /**
+                * Return a function that can be used to set data from a source object, taking
+                * into account the ability to use nested objects as a source
+                *  @param {string|int|function} mSource The data source for the object
+                *  @returns {function} Data set function
+                *  @memberof DataTable#oApi
+                */
+               function _fnSetObjectDataFn( mSource )
+               {
+                       if ( mSource === null )
+                       {
+                               /* Nothing to do when the data source is null */
+                               return function (data, val) {};
+                       }
+                       else if ( typeof mSource === 'function' )
+                       {
+                               return function (data, val) {
+                                       mSource( data, 'set', val );
+                               };
+                       }
+                       else if ( typeof mSource === 'string' && (mSource.indexOf('.') !== -1 || mSource.indexOf('[') !== -1) )
+                       {
+                               /* Like the get, we need to get data from a nested object */
+                               var setData = function (data, val, src) {
+                                       var a = src.split('.'), b;
+                                       var arrayNotation, o, innerSrc;
+               
+                                       for ( var i=0, iLen=a.length-1 ; i<iLen ; i++ )
+                                       {
+                                               // Check if we are dealing with an array notation request
+                                               arrayNotation = a[i].match(__reArray);
+               
+                                               if ( arrayNotation )
+                                               {
+                                                       a[i] = a[i].replace(__reArray, '');
+                                                       data[ a[i] ] = [];
+                                                       
+                                                       // Get the remainder of the nested object to set so we can recurse
+                                                       b = a.slice();
+                                                       b.splice( 0, i+1 );
+                                                       innerSrc = b.join('.');
+               
+                                                       // Traverse each entry in the array setting the properties requested
+                                                       for ( var j=0, jLen=val.length ; j<jLen ; j++ )
+                                                       {
+                                                               o = {};
+                                                               setData( o, val[j], innerSrc );
+                                                               data[ a[i] ].push( o );
+                                                       }
+               
+                                                       // The inner call to setData has already traversed through the remainder
+                                                       // of the source and has set the data, thus we can exit here
+                                                       return;
+                                               }
+               
+                                               // If the nested object doesn't currently exist - since we are
+                                               // trying to set the value - create it
+                                               if ( data[ a[i] ] === null || data[ a[i] ] === undefined )
+                                               {
+                                                       data[ a[i] ] = {};
+                                               }
+                                               data = data[ a[i] ];
+                                       }
+               
+                                       // If array notation is used, we just want to strip it and use the property name
+                                       // and assign the value. If it isn't used, then we get the result we want anyway
+                                       data[ a[a.length-1].replace(__reArray, '') ] = val;
+                               };
+               
+                               return function (data, val) {
+                                       return setData( data, val, mSource );
+                               };
+                       }
+                       else
+                       {
+                               /* Array or flat object mapping */
+                               return function (data, val) {
+                                       data[mSource] = val;    
+                               };
+                       }
+               }
+               
+               
+               /**
+                * Return an array with the full table data
+                *  @param {object} oSettings dataTables settings object
+                *  @returns array {array} aData Master data array
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetDataMaster ( oSettings )
+               {
+                       var aData = [];
+                       var iLen = oSettings.aoData.length;
+                       for ( var i=0 ; i<iLen; i++ )
+                       {
+                               aData.push( oSettings.aoData[i]._aData );
+                       }
+                       return aData;
+               }
+               
+               
+               /**
+                * Nuke the table
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnClearTable( oSettings )
+               {
+                       oSettings.aoData.splice( 0, oSettings.aoData.length );
+                       oSettings.aiDisplayMaster.splice( 0, oSettings.aiDisplayMaster.length );
+                       oSettings.aiDisplay.splice( 0, oSettings.aiDisplay.length );
+                       _fnCalculateEnd( oSettings );
+               }
+               
+               
+                /**
+                * Take an array of integers (index array) and remove a target integer (value - not 
+                * the key!)
+                *  @param {array} a Index array to target
+                *  @param {int} iTarget value to find
+                *  @memberof DataTable#oApi
+                */
+               function _fnDeleteIndex( a, iTarget )
+               {
+                       var iTargetIndex = -1;
+                       
+                       for ( var i=0, iLen=a.length ; i<iLen ; i++ )
+                       {
+                               if ( a[i] == iTarget )
+                               {
+                                       iTargetIndex = i;
+                               }
+                               else if ( a[i] > iTarget )
+                               {
+                                       a[i]--;
+                               }
+                       }
+                       
+                       if ( iTargetIndex != -1 )
+                       {
+                               a.splice( iTargetIndex, 1 );
+                       }
+               }
+               
+               
+                /**
+                * Call the developer defined fnRender function for a given cell (row/column) with
+                * the required parameters and return the result.
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow aoData index for the row
+                *  @param {int} iCol aoColumns index for the column
+                *  @returns {*} Return of the developer's fnRender function
+                *  @memberof DataTable#oApi
+                */
+               function _fnRender( oSettings, iRow, iCol )
+               {
+                       var oCol = oSettings.aoColumns[iCol];
+               
+                       return oCol.fnRender( {
+                               "iDataRow":    iRow,
+                               "iDataColumn": iCol,
+                               "oSettings":   oSettings,
+                               "aData":       oSettings.aoData[iRow]._aData,
+                               "mDataProp":   oCol.mData
+                       }, _fnGetCellData(oSettings, iRow, iCol, 'display') );
+               }
+               /**
+                * Create a new TR element (and it's TD children) for a row
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iRow Row to consider
+                *  @memberof DataTable#oApi
+                */
+               function _fnCreateTr ( oSettings, iRow )
+               {
+                       var oData = oSettings.aoData[iRow];
+                       var nTd;
+               
+                       if ( oData.nTr === null )
+                       {
+                               oData.nTr = document.createElement('tr');
+               
+                               /* Use a private property on the node to allow reserve mapping from the node
+                                * to the aoData array for fast look up
+                                */
+                               oData.nTr._DT_RowIndex = iRow;
+               
+                               /* Special parameters can be given by the data source to be used on the row */
+                               if ( oData._aData.DT_RowId )
+                               {
+                                       oData.nTr.id = oData._aData.DT_RowId;
+                               }
+               
+                               if ( oData._aData.DT_RowClass )
+                               {
+                                       oData.nTr.className = oData._aData.DT_RowClass;
+                               }
+               
+                               /* Process each column */
+                               for ( var i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       var oCol = oSettings.aoColumns[i];
+                                       nTd = document.createElement( oCol.sCellType );
+               
+                                       /* Render if needed - if bUseRendered is true then we already have the rendered
+                                        * value in the data source - so can just use that
+                                        */
+                                       nTd.innerHTML = (typeof oCol.fnRender === 'function' && (!oCol.bUseRendered || oCol.mData === null)) ?
+                                               _fnRender( oSettings, iRow, i ) :
+                                               _fnGetCellData( oSettings, iRow, i, 'display' );
+                               
+                                       /* Add user defined class */
+                                       if ( oCol.sClass !== null )
+                                       {
+                                               nTd.className = oCol.sClass;
+                                       }
+                                       
+                                       if ( oCol.bVisible )
+                                       {
+                                               oData.nTr.appendChild( nTd );
+                                               oData._anHidden[i] = null;
+                                       }
+                                       else
+                                       {
+                                               oData._anHidden[i] = nTd;
+                                       }
+               
+                                       if ( oCol.fnCreatedCell )
+                                       {
+                                               oCol.fnCreatedCell.call( oSettings.oInstance,
+                                                       nTd, _fnGetCellData( oSettings, iRow, i, 'display' ), oData._aData, iRow, i
+                                               );
+                                       }
+                               }
+               
+                               _fnCallbackFire( oSettings, 'aoRowCreatedCallback', null, [oData.nTr, oData._aData, iRow] );
+                       }
+               }
+               
+               
+               /**
+                * Create the HTML header for the table
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnBuildHead( oSettings )
+               {
+                       var i, nTh, iLen, j, jLen;
+                       var iThs = $('th, td', oSettings.nTHead).length;
+                       var iCorrector = 0;
+                       var jqChildren;
+                       
+                       /* If there is a header in place - then use it - otherwise it's going to get nuked... */
+                       if ( iThs !== 0 )
+                       {
+                               /* We've got a thead from the DOM, so remove hidden columns and apply width to vis cols */
+                               for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       nTh = oSettings.aoColumns[i].nTh;
+                                       nTh.setAttribute('role', 'columnheader');
+                                       if ( oSettings.aoColumns[i].bSortable )
+                                       {
+                                               nTh.setAttribute('tabindex', oSettings.iTabIndex);
+                                               nTh.setAttribute('aria-controls', oSettings.sTableId);
+                                       }
+               
+                                       if ( oSettings.aoColumns[i].sClass !== null )
+                                       {
+                                               $(nTh).addClass( oSettings.aoColumns[i].sClass );
+                                       }
+                                       
+                                       /* Set the title of the column if it is user defined (not what was auto detected) */
+                                       if ( oSettings.aoColumns[i].sTitle != nTh.innerHTML )
+                                       {
+                                               nTh.innerHTML = oSettings.aoColumns[i].sTitle;
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               /* We don't have a header in the DOM - so we are going to have to create one */
+                               var nTr = document.createElement( "tr" );
+                               
+                               for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       nTh = oSettings.aoColumns[i].nTh;
+                                       nTh.innerHTML = oSettings.aoColumns[i].sTitle;
+                                       nTh.setAttribute('tabindex', '0');
+                                       
+                                       if ( oSettings.aoColumns[i].sClass !== null )
+                                       {
+                                               $(nTh).addClass( oSettings.aoColumns[i].sClass );
+                                       }
+                                       
+                                       nTr.appendChild( nTh );
+                               }
+                               $(oSettings.nTHead).html( '' )[0].appendChild( nTr );
+                               _fnDetectHeader( oSettings.aoHeader, oSettings.nTHead );
+                       }
+                       
+                       /* ARIA role for the rows */    
+                       $(oSettings.nTHead).children('tr').attr('role', 'row');
+                       
+                       /* Add the extra markup needed by jQuery UI's themes */
+                       if ( oSettings.bJUI )
+                       {
+                               for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       nTh = oSettings.aoColumns[i].nTh;
+                                       
+                                       var nDiv = document.createElement('div');
+                                       nDiv.className = oSettings.oClasses.sSortJUIWrapper;
+                                       $(nTh).contents().appendTo(nDiv);
+                                       
+                                       var nSpan = document.createElement('span');
+                                       nSpan.className = oSettings.oClasses.sSortIcon;
+                                       nDiv.appendChild( nSpan );
+                                       nTh.appendChild( nDiv );
+                               }
+                       }
+                       
+                       if ( oSettings.oFeatures.bSort )
+                       {
+                               for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                               {
+                                       if ( oSettings.aoColumns[i].bSortable !== false )
+                                       {
+                                               _fnSortAttachListener( oSettings, oSettings.aoColumns[i].nTh, i );
+                                       }
+                                       else
+                                       {
+                                               $(oSettings.aoColumns[i].nTh).addClass( oSettings.oClasses.sSortableNone );
+                                       }
+                               }
+                       }
+                       
+                       /* Deal with the footer - add classes if required */
+                       if ( oSettings.oClasses.sFooterTH !== "" )
+                       {
+                               $(oSettings.nTFoot).children('tr').children('th').addClass( oSettings.oClasses.sFooterTH );
+                       }
+                       
+                       /* Cache the footer elements */
+                       if ( oSettings.nTFoot !== null )
+                       {
+                               var anCells = _fnGetUniqueThs( oSettings, null, oSettings.aoFooter );
+                               for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       if ( anCells[i] )
+                                       {
+                                               oSettings.aoColumns[i].nTf = anCells[i];
+                                               if ( oSettings.aoColumns[i].sClass )
+                                               {
+                                                       $(anCells[i]).addClass( oSettings.aoColumns[i].sClass );
+                                               }
+                                       }
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Draw the header (or footer) element based on the column visibility states. The
+                * methodology here is to use the layout array from _fnDetectHeader, modified for
+                * the instantaneous column visibility, to construct the new layout. The grid is
+                * traversed over cell at a time in a rows x columns grid fashion, although each 
+                * cell insert can cover multiple elements in the grid - which is tracks using the
+                * aApplied array. Cell inserts in the grid will only occur where there isn't
+                * already a cell in that position.
+                *  @param {object} oSettings dataTables settings object
+                *  @param array {objects} aoSource Layout array from _fnDetectHeader
+                *  @param {boolean} [bIncludeHidden=false] If true then include the hidden columns in the calc, 
+                *  @memberof DataTable#oApi
+                */
+               function _fnDrawHead( oSettings, aoSource, bIncludeHidden )
+               {
+                       var i, iLen, j, jLen, k, kLen, n, nLocalTr;
+                       var aoLocal = [];
+                       var aApplied = [];
+                       var iColumns = oSettings.aoColumns.length;
+                       var iRowspan, iColspan;
+               
+                       if (  bIncludeHidden === undefined )
+                       {
+                               bIncludeHidden = false;
+                       }
+               
+                       /* Make a copy of the master layout array, but without the visible columns in it */
+                       for ( i=0, iLen=aoSource.length ; i<iLen ; i++ )
+                       {
+                               aoLocal[i] = aoSource[i].slice();
+                               aoLocal[i].nTr = aoSource[i].nTr;
+               
+                               /* Remove any columns which are currently hidden */
+                               for ( j=iColumns-1 ; j>=0 ; j-- )
+                               {
+                                       if ( !oSettings.aoColumns[j].bVisible && !bIncludeHidden )
+                                       {
+                                               aoLocal[i].splice( j, 1 );
+                                       }
+                               }
+               
+                               /* Prep the applied array - it needs an element for each row */
+                               aApplied.push( [] );
+                       }
+               
+                       for ( i=0, iLen=aoLocal.length ; i<iLen ; i++ )
+                       {
+                               nLocalTr = aoLocal[i].nTr;
+                               
+                               /* All cells are going to be replaced, so empty out the row */
+                               if ( nLocalTr )
+                               {
+                                       while( (n = nLocalTr.firstChild) )
+                                       {
+                                               nLocalTr.removeChild( n );
+                                       }
+                               }
+               
+                               for ( j=0, jLen=aoLocal[i].length ; j<jLen ; j++ )
+                               {
+                                       iRowspan = 1;
+                                       iColspan = 1;
+               
+                                       /* Check to see if there is already a cell (row/colspan) covering our target
+                                        * insert point. If there is, then there is nothing to do.
+                                        */
+                                       if ( aApplied[i][j] === undefined )
+                                       {
+                                               nLocalTr.appendChild( aoLocal[i][j].cell );
+                                               aApplied[i][j] = 1;
+               
+                                               /* Expand the cell to cover as many rows as needed */
+                                               while ( aoLocal[i+iRowspan] !== undefined &&
+                                                       aoLocal[i][j].cell == aoLocal[i+iRowspan][j].cell )
+                                               {
+                                                       aApplied[i+iRowspan][j] = 1;
+                                                       iRowspan++;
+                                               }
+               
+                                               /* Expand the cell to cover as many columns as needed */
+                                               while ( aoLocal[i][j+iColspan] !== undefined &&
+                                                       aoLocal[i][j].cell == aoLocal[i][j+iColspan].cell )
+                                               {
+                                                       /* Must update the applied array over the rows for the columns */
+                                                       for ( k=0 ; k<iRowspan ; k++ )
+                                                       {
+                                                               aApplied[i+k][j+iColspan] = 1;
+                                                       }
+                                                       iColspan++;
+                                               }
+               
+                                               /* Do the actual expansion in the DOM */
+                                               aoLocal[i][j].cell.rowSpan = iRowspan;
+                                               aoLocal[i][j].cell.colSpan = iColspan;
+                                       }
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Insert the required TR nodes into the table for display
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnDraw( oSettings )
+               {
+                       /* Provide a pre-callback function which can be used to cancel the draw is false is returned */
+                       var aPreDraw = _fnCallbackFire( oSettings, 'aoPreDrawCallback', 'preDraw', [oSettings] );
+                       if ( $.inArray( false, aPreDraw ) !== -1 )
+                       {
+                               _fnProcessingDisplay( oSettings, false );
+                               return;
+                       }
+                       
+                       var i, iLen, n;
+                       var anRows = [];
+                       var iRowCount = 0;
+                       var iStripes = oSettings.asStripeClasses.length;
+                       var iOpenRows = oSettings.aoOpenRows.length;
+                       
+                       oSettings.bDrawing = true;
+                       
+                       /* Check and see if we have an initial draw position from state saving */
+                       if ( oSettings.iInitDisplayStart !== undefined && oSettings.iInitDisplayStart != -1 )
+                       {
+                               if ( oSettings.oFeatures.bServerSide )
+                               {
+                                       oSettings._iDisplayStart = oSettings.iInitDisplayStart;
+                               }
+                               else
+                               {
+                                       oSettings._iDisplayStart = (oSettings.iInitDisplayStart >= oSettings.fnRecordsDisplay()) ?
+                                               0 : oSettings.iInitDisplayStart;
+                               }
+                               oSettings.iInitDisplayStart = -1;
+                               _fnCalculateEnd( oSettings );
+                       }
+                       
+                       /* Server-side processing draw intercept */
+                       if ( oSettings.bDeferLoading )
+                       {
+                               oSettings.bDeferLoading = false;
+                               oSettings.iDraw++;
+                       }
+                       else if ( !oSettings.oFeatures.bServerSide )
+                       {
+                               oSettings.iDraw++;
+                       }
+                       else if ( !oSettings.bDestroying && !_fnAjaxUpdate( oSettings ) )
+                       {
+                               return;
+                       }
+                       
+                       if ( oSettings.aiDisplay.length !== 0 )
+                       {
+                               var iStart = oSettings._iDisplayStart;
+                               var iEnd = oSettings._iDisplayEnd;
+                               
+                               if ( oSettings.oFeatures.bServerSide )
+                               {
+                                       iStart = 0;
+                                       iEnd = oSettings.aoData.length;
+                               }
+                               
+                               for ( var j=iStart ; j<iEnd ; j++ )
+                               {
+                                       var aoData = oSettings.aoData[ oSettings.aiDisplay[j] ];
+                                       if ( aoData.nTr === null )
+                                       {
+                                               _fnCreateTr( oSettings, oSettings.aiDisplay[j] );
+                                       }
+               
+                                       var nRow = aoData.nTr;
+                                       
+                                       /* Remove the old striping classes and then add the new one */
+                                       if ( iStripes !== 0 )
+                                       {
+                                               var sStripe = oSettings.asStripeClasses[ iRowCount % iStripes ];
+                                               if ( aoData._sRowStripe != sStripe )
+                                               {
+                                                       $(nRow).removeClass( aoData._sRowStripe ).addClass( sStripe );
+                                                       aoData._sRowStripe = sStripe;
+                                               }
+                                       }
+                                       
+                                       /* Row callback functions - might want to manipulate the row */
+                                       _fnCallbackFire( oSettings, 'aoRowCallback', null, 
+                                               [nRow, oSettings.aoData[ oSettings.aiDisplay[j] ]._aData, iRowCount, j] );
+                                       
+                                       anRows.push( nRow );
+                                       iRowCount++;
+                                       
+                                       /* If there is an open row - and it is attached to this parent - attach it on redraw */
+                                       if ( iOpenRows !== 0 )
+                                       {
+                                               for ( var k=0 ; k<iOpenRows ; k++ )
+                                               {
+                                                       if ( nRow == oSettings.aoOpenRows[k].nParent )
+                                                       {
+                                                               anRows.push( oSettings.aoOpenRows[k].nTr );
+                                                               break;
+                                                       }
+                                               }
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               /* Table is empty - create a row with an empty message in it */
+                               anRows[ 0 ] = document.createElement( 'tr' );
+                               
+                               if ( oSettings.asStripeClasses[0] )
+                               {
+                                       anRows[ 0 ].className = oSettings.asStripeClasses[0];
+                               }
+               
+                               var oLang = oSettings.oLanguage;
+                               var sZero = oLang.sZeroRecords;
+                               if ( oSettings.iDraw == 1 && oSettings.sAjaxSource !== null && !oSettings.oFeatures.bServerSide )
+                               {
+                                       sZero = oLang.sLoadingRecords;
+                               }
+                               else if ( oLang.sEmptyTable && oSettings.fnRecordsTotal() === 0 )
+                               {
+                                       sZero = oLang.sEmptyTable;
+                               }
+               
+                               var nTd = document.createElement( 'td' );
+                               nTd.setAttribute( 'valign', "top" );
+                               nTd.colSpan = _fnVisbleColumns( oSettings );
+                               nTd.className = oSettings.oClasses.sRowEmpty;
+                               nTd.innerHTML = _fnInfoMacros( oSettings, sZero );
+                               
+                               anRows[ iRowCount ].appendChild( nTd );
+                       }
+                       
+                       /* Header and footer callbacks */
+                       _fnCallbackFire( oSettings, 'aoHeaderCallback', 'header', [ $(oSettings.nTHead).children('tr')[0], 
+                               _fnGetDataMaster( oSettings ), oSettings._iDisplayStart, oSettings.fnDisplayEnd(), oSettings.aiDisplay ] );
+                       
+                       _fnCallbackFire( oSettings, 'aoFooterCallback', 'footer', [ $(oSettings.nTFoot).children('tr')[0], 
+                               _fnGetDataMaster( oSettings ), oSettings._iDisplayStart, oSettings.fnDisplayEnd(), oSettings.aiDisplay ] );
+                       
+                       /* 
+                        * Need to remove any old row from the display - note we can't just empty the tbody using
+                        * $().html('') since this will unbind the jQuery event handlers (even although the node 
+                        * still exists!) - equally we can't use innerHTML, since IE throws an exception.
+                        */
+                       var
+                               nAddFrag = document.createDocumentFragment(),
+                               nRemoveFrag = document.createDocumentFragment(),
+                               nBodyPar, nTrs;
+                       
+                       if ( oSettings.nTBody )
+                       {
+                               nBodyPar = oSettings.nTBody.parentNode;
+                               nRemoveFrag.appendChild( oSettings.nTBody );
+                               
+                               /* When doing infinite scrolling, only remove child rows when sorting, filtering or start
+                                * up. When not infinite scroll, always do it.
+                                */
+                               if ( !oSettings.oScroll.bInfinite || !oSettings._bInitComplete ||
+                                       oSettings.bSorted || oSettings.bFiltered )
+                               {
+                                       while( (n = oSettings.nTBody.firstChild) )
+                                       {
+                                               oSettings.nTBody.removeChild( n );
+                                       }
+                               }
+                               
+                               /* Put the draw table into the dom */
+                               for ( i=0, iLen=anRows.length ; i<iLen ; i++ )
+                               {
+                                       nAddFrag.appendChild( anRows[i] );
+                               }
+                               
+                               oSettings.nTBody.appendChild( nAddFrag );
+                               if ( nBodyPar !== null )
+                               {
+                                       nBodyPar.appendChild( oSettings.nTBody );
+                               }
+                       }
+                       
+                       /* Call all required callback functions for the end of a draw */
+                       _fnCallbackFire( oSettings, 'aoDrawCallback', 'draw', [oSettings] );
+                       
+                       /* Draw is complete, sorting and filtering must be as well */
+                       oSettings.bSorted = false;
+                       oSettings.bFiltered = false;
+                       oSettings.bDrawing = false;
+                       
+                       if ( oSettings.oFeatures.bServerSide )
+                       {
+                               _fnProcessingDisplay( oSettings, false );
+                               if ( !oSettings._bInitComplete )
+                               {
+                                       _fnInitComplete( oSettings );
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Redraw the table - taking account of the various features which are enabled
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnReDraw( oSettings )
+               {
+                       if ( oSettings.oFeatures.bSort )
+                       {
+                               /* Sorting will refilter and draw for us */
+                               _fnSort( oSettings, oSettings.oPreviousSearch );
+                       }
+                       else if ( oSettings.oFeatures.bFilter )
+                       {
+                               /* Filtering will redraw for us */
+                               _fnFilterComplete( oSettings, oSettings.oPreviousSearch );
+                       }
+                       else
+                       {
+                               _fnCalculateEnd( oSettings );
+                               _fnDraw( oSettings );
+                       }
+               }
+               
+               
+               /**
+                * Add the options to the page HTML for the table
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnAddOptionsHtml ( oSettings )
+               {
+                       /*
+                        * Create a temporary, empty, div which we can later on replace with what we have generated
+                        * we do it this way to rendering the 'options' html offline - speed :-)
+                        */
+                       var nHolding = $('<div></div>')[0];
+                       oSettings.nTable.parentNode.insertBefore( nHolding, oSettings.nTable );
+                       
+                       /* 
+                        * All DataTables are wrapped in a div
+                        */
+                       oSettings.nTableWrapper = $('<div id="'+oSettings.sTableId+'_wrapper" class="'+oSettings.oClasses.sWrapper+'" role="grid"></div>')[0];
+                       oSettings.nTableReinsertBefore = oSettings.nTable.nextSibling;
+               
+                       /* Track where we want to insert the option */
+                       var nInsertNode = oSettings.nTableWrapper;
+                       
+                       /* Loop over the user set positioning and place the elements as needed */
+                       var aDom = oSettings.sDom.split('');
+                       var nTmp, iPushFeature, cOption, nNewNode, cNext, sAttr, j;
+                       for ( var i=0 ; i<aDom.length ; i++ )
+                       {
+                               iPushFeature = 0;
+                               cOption = aDom[i];
+                               
+                               if ( cOption == '<' )
+                               {
+                                       /* New container div */
+                                       nNewNode = $('<div></div>')[0];
+                                       
+                                       /* Check to see if we should append an id and/or a class name to the container */
+                                       cNext = aDom[i+1];
+                                       if ( cNext == "'" || cNext == '"' )
+                                       {
+                                               sAttr = "";
+                                               j = 2;
+                                               while ( aDom[i+j] != cNext )
+                                               {
+                                                       sAttr += aDom[i+j];
+                                                       j++;
+                                               }
+                                               
+                                               /* Replace jQuery UI constants */
+                                               if ( sAttr == "H" )
+                                               {
+                                                       sAttr = oSettings.oClasses.sJUIHeader;
+                                               }
+                                               else if ( sAttr == "F" )
+                                               {
+                                                       sAttr = oSettings.oClasses.sJUIFooter;
+                                               }
+                                               
+                                               /* The attribute can be in the format of "#id.class", "#id" or "class" This logic
+                                                * breaks the string into parts and applies them as needed
+                                                */
+                                               if ( sAttr.indexOf('.') != -1 )
+                                               {
+                                                       var aSplit = sAttr.split('.');
+                                                       nNewNode.id = aSplit[0].substr(1, aSplit[0].length-1);
+                                                       nNewNode.className = aSplit[1];
+                                               }
+                                               else if ( sAttr.charAt(0) == "#" )
+                                               {
+                                                       nNewNode.id = sAttr.substr(1, sAttr.length-1);
+                                               }
+                                               else
+                                               {
+                                                       nNewNode.className = sAttr;
+                                               }
+                                               
+                                               i += j; /* Move along the position array */
+                                       }
+                                       
+                                       nInsertNode.appendChild( nNewNode );
+                                       nInsertNode = nNewNode;
+                               }
+                               else if ( cOption == '>' )
+                               {
+                                       /* End container div */
+                                       nInsertNode = nInsertNode.parentNode;
+                               }
+                               else if ( cOption == 'l' && oSettings.oFeatures.bPaginate && oSettings.oFeatures.bLengthChange )
+                               {
+                                       /* Length */
+                                       nTmp = _fnFeatureHtmlLength( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( cOption == 'f' && oSettings.oFeatures.bFilter )
+                               {
+                                       /* Filter */
+                                       nTmp = _fnFeatureHtmlFilter( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( cOption == 'r' && oSettings.oFeatures.bProcessing )
+                               {
+                                       /* pRocessing */
+                                       nTmp = _fnFeatureHtmlProcessing( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( cOption == 't' )
+                               {
+                                       /* Table */
+                                       nTmp = _fnFeatureHtmlTable( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( cOption ==  'i' && oSettings.oFeatures.bInfo )
+                               {
+                                       /* Info */
+                                       nTmp = _fnFeatureHtmlInfo( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( cOption == 'p' && oSettings.oFeatures.bPaginate )
+                               {
+                                       /* Pagination */
+                                       nTmp = _fnFeatureHtmlPaginate( oSettings );
+                                       iPushFeature = 1;
+                               }
+                               else if ( DataTable.ext.aoFeatures.length !== 0 )
+                               {
+                                       /* Plug-in features */
+                                       var aoFeatures = DataTable.ext.aoFeatures;
+                                       for ( var k=0, kLen=aoFeatures.length ; k<kLen ; k++ )
+                                       {
+                                               if ( cOption == aoFeatures[k].cFeature )
+                                               {
+                                                       nTmp = aoFeatures[k].fnInit( oSettings );
+                                                       if ( nTmp )
+                                                       {
+                                                               iPushFeature = 1;
+                                                       }
+                                                       break;
+                                               }
+                                       }
+                               }
+                               
+                               /* Add to the 2D features array */
+                               if ( iPushFeature == 1 && nTmp !== null )
+                               {
+                                       if ( typeof oSettings.aanFeatures[cOption] !== 'object' )
+                                       {
+                                               oSettings.aanFeatures[cOption] = [];
+                                       }
+                                       oSettings.aanFeatures[cOption].push( nTmp );
+                                       nInsertNode.appendChild( nTmp );
+                               }
+                       }
+                       
+                       /* Built our DOM structure - replace the holding div with what we want */
+                       nHolding.parentNode.replaceChild( oSettings.nTableWrapper, nHolding );
+               }
+               
+               
+               /**
+                * Use the DOM source to create up an array of header cells. The idea here is to
+                * create a layout grid (array) of rows x columns, which contains a reference
+                * to the cell that that point in the grid (regardless of col/rowspan), such that
+                * any column / row could be removed and the new grid constructed
+                *  @param array {object} aLayout Array to store the calculated layout in
+                *  @param {node} nThead The header/footer element for the table
+                *  @memberof DataTable#oApi
+                */
+               function _fnDetectHeader ( aLayout, nThead )
+               {
+                       var nTrs = $(nThead).children('tr');
+                       var nTr, nCell;
+                       var i, k, l, iLen, jLen, iColShifted, iColumn, iColspan, iRowspan;
+                       var bUnique;
+                       var fnShiftCol = function ( a, i, j ) {
+                               var k = a[i];
+                               while ( k[j] ) {
+                                       j++;
+                               }
+                               return j;
+                       };
+               
+                       aLayout.splice( 0, aLayout.length );
+                       
+                       /* We know how many rows there are in the layout - so prep it */
+                       for ( i=0, iLen=nTrs.length ; i<iLen ; i++ )
+                       {
+                               aLayout.push( [] );
+                       }
+                       
+                       /* Calculate a layout array */
+                       for ( i=0, iLen=nTrs.length ; i<iLen ; i++ )
+                       {
+                               nTr = nTrs[i];
+                               iColumn = 0;
+                               
+                               /* For every cell in the row... */
+                               nCell = nTr.firstChild;
+                               while ( nCell ) {
+                                       if ( nCell.nodeName.toUpperCase() == "TD" ||
+                                            nCell.nodeName.toUpperCase() == "TH" )
+                                       {
+                                               /* Get the col and rowspan attributes from the DOM and sanitise them */
+                                               iColspan = nCell.getAttribute('colspan') * 1;
+                                               iRowspan = nCell.getAttribute('rowspan') * 1;
+                                               iColspan = (!iColspan || iColspan===0 || iColspan===1) ? 1 : iColspan;
+                                               iRowspan = (!iRowspan || iRowspan===0 || iRowspan===1) ? 1 : iRowspan;
+               
+                                               /* There might be colspan cells already in this row, so shift our target 
+                                                * accordingly
+                                                */
+                                               iColShifted = fnShiftCol( aLayout, i, iColumn );
+                                               
+                                               /* Cache calculation for unique columns */
+                                               bUnique = iColspan === 1 ? true : false;
+                                               
+                                               /* If there is col / rowspan, copy the information into the layout grid */
+                                               for ( l=0 ; l<iColspan ; l++ )
+                                               {
+                                                       for ( k=0 ; k<iRowspan ; k++ )
+                                                       {
+                                                               aLayout[i+k][iColShifted+l] = {
+                                                                       "cell": nCell,
+                                                                       "unique": bUnique
+                                                               };
+                                                               aLayout[i+k].nTr = nTr;
+                                                       }
+                                               }
+                                       }
+                                       nCell = nCell.nextSibling;
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Get an array of unique th elements, one for each column
+                *  @param {object} oSettings dataTables settings object
+                *  @param {node} nHeader automatically detect the layout from this node - optional
+                *  @param {array} aLayout thead/tfoot layout from _fnDetectHeader - optional
+                *  @returns array {node} aReturn list of unique th's
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetUniqueThs ( oSettings, nHeader, aLayout )
+               {
+                       var aReturn = [];
+                       if ( !aLayout )
+                       {
+                               aLayout = oSettings.aoHeader;
+                               if ( nHeader )
+                               {
+                                       aLayout = [];
+                                       _fnDetectHeader( aLayout, nHeader );
+                               }
+                       }
+               
+                       for ( var i=0, iLen=aLayout.length ; i<iLen ; i++ )
+                       {
+                               for ( var j=0, jLen=aLayout[i].length ; j<jLen ; j++ )
+                               {
+                                       if ( aLayout[i][j].unique && 
+                                                (!aReturn[j] || !oSettings.bSortCellsTop) )
+                                       {
+                                               aReturn[j] = aLayout[i][j].cell;
+                                       }
+                               }
+                       }
+                       
+                       return aReturn;
+               }
+               
+               
+               
+               /**
+                * Update the table using an Ajax call
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {boolean} Block the table drawing or not
+                *  @memberof DataTable#oApi
+                */
+               function _fnAjaxUpdate( oSettings )
+               {
+                       if ( oSettings.bAjaxDataGet )
+                       {
+                               oSettings.iDraw++;
+                               _fnProcessingDisplay( oSettings, true );
+                               var iColumns = oSettings.aoColumns.length;
+                               var aoData = _fnAjaxParameters( oSettings );
+                               _fnServerParams( oSettings, aoData );
+                               
+                               oSettings.fnServerData.call( oSettings.oInstance, oSettings.sAjaxSource, aoData,
+                                       function(json) {
+                                               _fnAjaxUpdateDraw( oSettings, json );
+                                       }, oSettings );
+                               return false;
+                       }
+                       else
+                       {
+                               return true;
+                       }
+               }
+               
+               
+               /**
+                * Build up the parameters in an object needed for a server-side processing request
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {bool} block the table drawing or not
+                *  @memberof DataTable#oApi
+                */
+               function _fnAjaxParameters( oSettings )
+               {
+                       var iColumns = oSettings.aoColumns.length;
+                       var aoData = [], mDataProp, aaSort, aDataSort;
+                       var i, j;
+                       
+                       aoData.push( { "name": "sEcho",          "value": oSettings.iDraw } );
+                       aoData.push( { "name": "iColumns",       "value": iColumns } );
+                       aoData.push( { "name": "sColumns",       "value": _fnColumnOrdering(oSettings) } );
+                       aoData.push( { "name": "iDisplayStart",  "value": oSettings._iDisplayStart } );
+                       aoData.push( { "name": "iDisplayLength", "value": oSettings.oFeatures.bPaginate !== false ?
+                               oSettings._iDisplayLength : -1 } );
+                               
+                       for ( i=0 ; i<iColumns ; i++ )
+                       {
+                         mDataProp = oSettings.aoColumns[i].mData;
+                               aoData.push( { "name": "mDataProp_"+i, "value": typeof(mDataProp)==="function" ? 'function' : mDataProp } );
+                       }
+                       
+                       /* Filtering */
+                       if ( oSettings.oFeatures.bFilter !== false )
+                       {
+                               aoData.push( { "name": "sSearch", "value": oSettings.oPreviousSearch.sSearch } );
+                               aoData.push( { "name": "bRegex",  "value": oSettings.oPreviousSearch.bRegex } );
+                               for ( i=0 ; i<iColumns ; i++ )
+                               {
+                                       aoData.push( { "name": "sSearch_"+i,     "value": oSettings.aoPreSearchCols[i].sSearch } );
+                                       aoData.push( { "name": "bRegex_"+i,      "value": oSettings.aoPreSearchCols[i].bRegex } );
+                                       aoData.push( { "name": "bSearchable_"+i, "value": oSettings.aoColumns[i].bSearchable } );
+                               }
+                       }
+                       
+                       /* Sorting */
+                       if ( oSettings.oFeatures.bSort !== false )
+                       {
+                               var iCounter = 0;
+               
+                               aaSort = ( oSettings.aaSortingFixed !== null ) ?
+                                       oSettings.aaSortingFixed.concat( oSettings.aaSorting ) :
+                                       oSettings.aaSorting.slice();
+                               
+                               for ( i=0 ; i<aaSort.length ; i++ )
+                               {
+                                       aDataSort = oSettings.aoColumns[ aaSort[i][0] ].aDataSort;
+                                       
+                                       for ( j=0 ; j<aDataSort.length ; j++ )
+                                       {
+                                               aoData.push( { "name": "iSortCol_"+iCounter,  "value": aDataSort[j] } );
+                                               aoData.push( { "name": "sSortDir_"+iCounter,  "value": aaSort[i][1] } );
+                                               iCounter++;
+                                       }
+                               }
+                               aoData.push( { "name": "iSortingCols",   "value": iCounter } );
+                               
+                               for ( i=0 ; i<iColumns ; i++ )
+                               {
+                                       aoData.push( { "name": "bSortable_"+i,  "value": oSettings.aoColumns[i].bSortable } );
+                               }
+                       }
+                       
+                       return aoData;
+               }
+               
+               
+               /**
+                * Add Ajax parameters from plug-ins
+                *  @param {object} oSettings dataTables settings object
+                *  @param array {objects} aoData name/value pairs to send to the server
+                *  @memberof DataTable#oApi
+                */
+               function _fnServerParams( oSettings, aoData )
+               {
+                       _fnCallbackFire( oSettings, 'aoServerParams', 'serverParams', [aoData] );
+               }
+               
+               
+               /**
+                * Data the data from the server (nuking the old) and redraw the table
+                *  @param {object} oSettings dataTables settings object
+                *  @param {object} json json data return from the server.
+                *  @param {string} json.sEcho Tracking flag for DataTables to match requests
+                *  @param {int} json.iTotalRecords Number of records in the data set, not accounting for filtering
+                *  @param {int} json.iTotalDisplayRecords Number of records in the data set, accounting for filtering
+                *  @param {array} json.aaData The data to display on this page
+                *  @param {string} [json.sColumns] Column ordering (sName, comma separated)
+                *  @memberof DataTable#oApi
+                */
+               function _fnAjaxUpdateDraw ( oSettings, json )
+               {
+                       if ( json.sEcho !== undefined )
+                       {
+                               /* Protect against old returns over-writing a new one. Possible when you get
+                                * very fast interaction, and later queries are completed much faster
+                                */
+                               if ( json.sEcho*1 < oSettings.iDraw )
+                               {
+                                       return;
+                               }
+                               else
+                               {
+                                       oSettings.iDraw = json.sEcho * 1;
+                               }
+                       }
+                       
+                       if ( !oSettings.oScroll.bInfinite ||
+                                  (oSettings.oScroll.bInfinite && (oSettings.bSorted || oSettings.bFiltered)) )
+                       {
+                               _fnClearTable( oSettings );
+                       }
+                       oSettings._iRecordsTotal = parseInt(json.iTotalRecords, 10);
+                       oSettings._iRecordsDisplay = parseInt(json.iTotalDisplayRecords, 10);
+                       
+                       /* Determine if reordering is required */
+                       var sOrdering = _fnColumnOrdering(oSettings);
+                       var bReOrder = (json.sColumns !== undefined && sOrdering !== "" && json.sColumns != sOrdering );
+                       var aiIndex;
+                       if ( bReOrder )
+                       {
+                               aiIndex = _fnReOrderIndex( oSettings, json.sColumns );
+                       }
+                       
+                       var aData = _fnGetObjectDataFn( oSettings.sAjaxDataProp )( json );
+                       for ( var i=0, iLen=aData.length ; i<iLen ; i++ )
+                       {
+                               if ( bReOrder )
+                               {
+                                       /* If we need to re-order, then create a new array with the correct order and add it */
+                                       var aDataSorted = [];
+                                       for ( var j=0, jLen=oSettings.aoColumns.length ; j<jLen ; j++ )
+                                       {
+                                               aDataSorted.push( aData[i][ aiIndex[j] ] );
+                                       }
+                                       _fnAddData( oSettings, aDataSorted );
+                               }
+                               else
+                               {
+                                       /* No re-order required, sever got it "right" - just straight add */
+                                       _fnAddData( oSettings, aData[i] );
+                               }
+                       }
+                       oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                       
+                       oSettings.bAjaxDataGet = false;
+                       _fnDraw( oSettings );
+                       oSettings.bAjaxDataGet = true;
+                       _fnProcessingDisplay( oSettings, false );
+               }
+               
+               
+               
+               /**
+                * Generate the node required for filtering text
+                *  @returns {node} Filter control element
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlFilter ( oSettings )
+               {
+                       var oPreviousSearch = oSettings.oPreviousSearch;
+                       
+                       var sSearchStr = oSettings.oLanguage.sSearch;
+                       sSearchStr = (sSearchStr.indexOf('_INPUT_') !== -1) ?
+                         sSearchStr.replace('_INPUT_', '<input type="text" />') :
+                         sSearchStr==="" ? '<input type="text" />' : sSearchStr+' <input type="text" />';
+                       
+                       var nFilter = document.createElement( 'div' );
+                       nFilter.className = oSettings.oClasses.sFilter;
+                       nFilter.innerHTML = '<label>'+sSearchStr+'</label>';
+                       if ( !oSettings.aanFeatures.f )
+                       {
+                               nFilter.id = oSettings.sTableId+'_filter';
+                       }
+                       
+                       var jqFilter = $('input[type="text"]', nFilter);
+               
+                       // Store a reference to the input element, so other input elements could be
+                       // added to the filter wrapper if needed (submit button for example)
+                       nFilter._DT_Input = jqFilter[0];
+               
+                       jqFilter.val( oPreviousSearch.sSearch.replace('"','&quot;') );
+                       jqFilter.bind( 'keyup.DT', function(e) {
+                               /* Update all other filter input elements for the new display */
+                               var n = oSettings.aanFeatures.f;
+                               var val = this.value==="" ? "" : this.value; // mental IE8 fix :-(
+               
+                               for ( var i=0, iLen=n.length ; i<iLen ; i++ )
+                               {
+                                       if ( n[i] != $(this).parents('div.dataTables_filter')[0] )
+                                       {
+                                               $(n[i]._DT_Input).val( val );
+                                       }
+                               }
+                               
+                               /* Now do the filter */
+                               if ( val != oPreviousSearch.sSearch )
+                               {
+                                       _fnFilterComplete( oSettings, { 
+                                               "sSearch": val, 
+                                               "bRegex": oPreviousSearch.bRegex,
+                                               "bSmart": oPreviousSearch.bSmart ,
+                                               "bCaseInsensitive": oPreviousSearch.bCaseInsensitive 
+                                       } );
+                               }
+                       } );
+               
+                       jqFilter
+                               .attr('aria-controls', oSettings.sTableId)
+                               .bind( 'keypress.DT', function(e) {
+                                       /* Prevent form submission */
+                                       if ( e.keyCode == 13 )
+                                       {
+                                               return false;
+                                       }
+                               }
+                       );
+                       
+                       return nFilter;
+               }
+               
+               
+               /**
+                * Filter the table using both the global filter and column based filtering
+                *  @param {object} oSettings dataTables settings object
+                *  @param {object} oSearch search information
+                *  @param {int} [iForce] force a research of the master array (1) or not (undefined or 0)
+                *  @memberof DataTable#oApi
+                */
+               function _fnFilterComplete ( oSettings, oInput, iForce )
+               {
+                       var oPrevSearch = oSettings.oPreviousSearch;
+                       var aoPrevSearch = oSettings.aoPreSearchCols;
+                       var fnSaveFilter = function ( oFilter ) {
+                               /* Save the filtering values */
+                               oPrevSearch.sSearch = oFilter.sSearch;
+                               oPrevSearch.bRegex = oFilter.bRegex;
+                               oPrevSearch.bSmart = oFilter.bSmart;
+                               oPrevSearch.bCaseInsensitive = oFilter.bCaseInsensitive;
+                       };
+               
+                       /* In server-side processing all filtering is done by the server, so no point hanging around here */
+                       if ( !oSettings.oFeatures.bServerSide )
+                       {
+                               /* Global filter */
+                               _fnFilter( oSettings, oInput.sSearch, iForce, oInput.bRegex, oInput.bSmart, oInput.bCaseInsensitive );
+                               fnSaveFilter( oInput );
+               
+                               /* Now do the individual column filter */
+                               for ( var i=0 ; i<oSettings.aoPreSearchCols.length ; i++ )
+                               {
+                                       _fnFilterColumn( oSettings, aoPrevSearch[i].sSearch, i, aoPrevSearch[i].bRegex, 
+                                               aoPrevSearch[i].bSmart, aoPrevSearch[i].bCaseInsensitive );
+                               }
+                               
+                               /* Custom filtering */
+                               _fnFilterCustom( oSettings );
+                       }
+                       else
+                       {
+                               fnSaveFilter( oInput );
+                       }
+                       
+                       /* Tell the draw function we have been filtering */
+                       oSettings.bFiltered = true;
+                       $(oSettings.oInstance).trigger('filter', oSettings);
+                       
+                       /* Redraw the table */
+                       oSettings._iDisplayStart = 0;
+                       _fnCalculateEnd( oSettings );
+                       _fnDraw( oSettings );
+                       
+                       /* Rebuild search array 'offline' */
+                       _fnBuildSearchArray( oSettings, 0 );
+               }
+               
+               
+               /**
+                * Apply custom filtering functions
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnFilterCustom( oSettings )
+               {
+                       var afnFilters = DataTable.ext.afnFiltering;
+                       var aiFilterColumns = _fnGetColumns( oSettings, 'bSearchable' );
+               
+                       for ( var i=0, iLen=afnFilters.length ; i<iLen ; i++ )
+                       {
+                               var iCorrector = 0;
+                               for ( var j=0, jLen=oSettings.aiDisplay.length ; j<jLen ; j++ )
+                               {
+                                       var iDisIndex = oSettings.aiDisplay[j-iCorrector];
+                                       var bTest = afnFilters[i](
+                                               oSettings,
+                                               _fnGetRowData( oSettings, iDisIndex, 'filter', aiFilterColumns ),
+                                               iDisIndex
+                                       );
+                                       
+                                       /* Check if we should use this row based on the filtering function */
+                                       if ( !bTest )
+                                       {
+                                               oSettings.aiDisplay.splice( j-iCorrector, 1 );
+                                               iCorrector++;
+                                       }
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Filter the table on a per-column basis
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string} sInput string to filter on
+                *  @param {int} iColumn column to filter
+                *  @param {bool} bRegex treat search string as a regular expression or not
+                *  @param {bool} bSmart use smart filtering or not
+                *  @param {bool} bCaseInsensitive Do case insenstive matching or not
+                *  @memberof DataTable#oApi
+                */
+               function _fnFilterColumn ( oSettings, sInput, iColumn, bRegex, bSmart, bCaseInsensitive )
+               {
+                       if ( sInput === "" )
+                       {
+                               return;
+                       }
+                       
+                       var iIndexCorrector = 0;
+                       var rpSearch = _fnFilterCreateSearch( sInput, bRegex, bSmart, bCaseInsensitive );
+                       
+                       for ( var i=oSettings.aiDisplay.length-1 ; i>=0 ; i-- )
+                       {
+                               var sData = _fnDataToSearch( _fnGetCellData( oSettings, oSettings.aiDisplay[i], iColumn, 'filter' ),
+                                       oSettings.aoColumns[iColumn].sType );
+                               if ( ! rpSearch.test( sData ) )
+                               {
+                                       oSettings.aiDisplay.splice( i, 1 );
+                                       iIndexCorrector++;
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Filter the data table based on user input and draw the table
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string} sInput string to filter on
+                *  @param {int} iForce optional - force a research of the master array (1) or not (undefined or 0)
+                *  @param {bool} bRegex treat as a regular expression or not
+                *  @param {bool} bSmart perform smart filtering or not
+                *  @param {bool} bCaseInsensitive Do case insenstive matching or not
+                *  @memberof DataTable#oApi
+                */
+               function _fnFilter( oSettings, sInput, iForce, bRegex, bSmart, bCaseInsensitive )
+               {
+                       var i;
+                       var rpSearch = _fnFilterCreateSearch( sInput, bRegex, bSmart, bCaseInsensitive );
+                       var oPrevSearch = oSettings.oPreviousSearch;
+                       
+                       /* Check if we are forcing or not - optional parameter */
+                       if ( !iForce )
+                       {
+                               iForce = 0;
+                       }
+                       
+                       /* Need to take account of custom filtering functions - always filter */
+                       if ( DataTable.ext.afnFiltering.length !== 0 )
+                       {
+                               iForce = 1;
+                       }
+                       
+                       /*
+                        * If the input is blank - we want the full data set
+                        */
+                       if ( sInput.length <= 0 )
+                       {
+                               oSettings.aiDisplay.splice( 0, oSettings.aiDisplay.length);
+                               oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                       }
+                       else
+                       {
+                               /*
+                                * We are starting a new search or the new search string is smaller 
+                                * then the old one (i.e. delete). Search from the master array
+                                */
+                               if ( oSettings.aiDisplay.length == oSettings.aiDisplayMaster.length ||
+                                          oPrevSearch.sSearch.length > sInput.length || iForce == 1 ||
+                                          sInput.indexOf(oPrevSearch.sSearch) !== 0 )
+                               {
+                                       /* Nuke the old display array - we are going to rebuild it */
+                                       oSettings.aiDisplay.splice( 0, oSettings.aiDisplay.length);
+                                       
+                                       /* Force a rebuild of the search array */
+                                       _fnBuildSearchArray( oSettings, 1 );
+                                       
+                                       /* Search through all records to populate the search array
+                                        * The the oSettings.aiDisplayMaster and asDataSearch arrays have 1 to 1 
+                                        * mapping
+                                        */
+                                       for ( i=0 ; i<oSettings.aiDisplayMaster.length ; i++ )
+                                       {
+                                               if ( rpSearch.test(oSettings.asDataSearch[i]) )
+                                               {
+                                                       oSettings.aiDisplay.push( oSettings.aiDisplayMaster[i] );
+                                               }
+                                       }
+                         }
+                         else
+                               {
+                               /* Using old search array - refine it - do it this way for speed
+                                * Don't have to search the whole master array again
+                                        */
+                               var iIndexCorrector = 0;
+                               
+                               /* Search the current results */
+                               for ( i=0 ; i<oSettings.asDataSearch.length ; i++ )
+                                       {
+                                       if ( ! rpSearch.test(oSettings.asDataSearch[i]) )
+                                               {
+                                               oSettings.aiDisplay.splice( i-iIndexCorrector, 1 );
+                                               iIndexCorrector++;
+                                       }
+                               }
+                         }
+                       }
+               }
+               
+               
+               /**
+                * Create an array which can be quickly search through
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iMaster use the master data array - optional
+                *  @memberof DataTable#oApi
+                */
+               function _fnBuildSearchArray ( oSettings, iMaster )
+               {
+                       if ( !oSettings.oFeatures.bServerSide )
+                       {
+                               /* Clear out the old data */
+                               oSettings.asDataSearch = [];
+               
+                               var aiFilterColumns = _fnGetColumns( oSettings, 'bSearchable' );
+                               var aiIndex = (iMaster===1) ?
+                                       oSettings.aiDisplayMaster :
+                                       oSettings.aiDisplay;
+                               
+                               for ( var i=0, iLen=aiIndex.length ; i<iLen ; i++ )
+                               {
+                                       oSettings.asDataSearch[i] = _fnBuildSearchRow(
+                                               oSettings,
+                                               _fnGetRowData( oSettings, aiIndex[i], 'filter', aiFilterColumns )
+                                       );
+                               }
+                       }
+               }
+               
+               
+               /**
+                * Create a searchable string from a single data row
+                *  @param {object} oSettings dataTables settings object
+                *  @param {array} aData Row data array to use for the data to search
+                *  @memberof DataTable#oApi
+                */
+               function _fnBuildSearchRow( oSettings, aData )
+               {
+                       var sSearch = aData.join('  ');
+                       
+                       /* If it looks like there is an HTML entity in the string, attempt to decode it */
+                       if ( sSearch.indexOf('&') !== -1 )
+                       {
+                               sSearch = $('<div>').html(sSearch).text();
+                       }
+                       
+                       // Strip newline characters
+                       return sSearch.replace( /[\n\r]/g, " " );
+               }
+               
+               /**
+                * Build a regular expression object suitable for searching a table
+                *  @param {string} sSearch string to search for
+                *  @param {bool} bRegex treat as a regular expression or not
+                *  @param {bool} bSmart perform smart filtering or not
+                *  @param {bool} bCaseInsensitive Do case insensitive matching or not
+                *  @returns {RegExp} constructed object
+                *  @memberof DataTable#oApi
+                */
+               function _fnFilterCreateSearch( sSearch, bRegex, bSmart, bCaseInsensitive )
+               {
+                       var asSearch, sRegExpString;
+                       
+                       if ( bSmart )
+                       {
+                               /* Generate the regular expression to use. Something along the lines of:
+                                * ^(?=.*?\bone\b)(?=.*?\btwo\b)(?=.*?\bthree\b).*$
+                                */
+                               asSearch = bRegex ? sSearch.split( ' ' ) : _fnEscapeRegex( sSearch ).split( ' ' );
+                               sRegExpString = '^(?=.*?'+asSearch.join( ')(?=.*?' )+').*$';
+                               return new RegExp( sRegExpString, bCaseInsensitive ? "i" : "" );
+                       }
+                       else
+                       {
+                               sSearch = bRegex ? sSearch : _fnEscapeRegex( sSearch );
+                               return new RegExp( sSearch, bCaseInsensitive ? "i" : "" );
+                       }
+               }
+               
+               
+               /**
+                * Convert raw data into something that the user can search on
+                *  @param {string} sData data to be modified
+                *  @param {string} sType data type
+                *  @returns {string} search string
+                *  @memberof DataTable#oApi
+                */
+               function _fnDataToSearch ( sData, sType )
+               {
+                       if ( typeof DataTable.ext.ofnSearch[sType] === "function" )
+                       {
+                               return DataTable.ext.ofnSearch[sType]( sData );
+                       }
+                       else if ( sData === null )
+                       {
+                               return '';
+                       }
+                       else if ( sType == "html" )
+                       {
+                               return sData.replace(/[\r\n]/g," ").replace( /<.*?>/g, "" );
+                       }
+                       else if ( typeof sData === "string" )
+                       {
+                               return sData.replace(/[\r\n]/g," ");
+                       }
+                       return sData;
+               }
+               
+               
+               /**
+                * scape a string such that it can be used in a regular expression
+                *  @param {string} sVal string to escape
+                *  @returns {string} escaped string
+                *  @memberof DataTable#oApi
+                */
+               function _fnEscapeRegex ( sVal )
+               {
+                       var acEscape = [ '/', '.', '*', '+', '?', '|', '(', ')', '[', ']', '{', '}', '\\', '$', '^', '-' ];
+                       var reReplace = new RegExp( '(\\' + acEscape.join('|\\') + ')', 'g' );
+                       return sVal.replace(reReplace, '\\$1');
+               }
+               
+               
+               /**
+                * Generate the node required for the info display
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {node} Information element
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlInfo ( oSettings )
+               {
+                       var nInfo = document.createElement( 'div' );
+                       nInfo.className = oSettings.oClasses.sInfo;
+                       
+                       /* Actions that are to be taken once only for this feature */
+                       if ( !oSettings.aanFeatures.i )
+                       {
+                               /* Add draw callback */
+                               oSettings.aoDrawCallback.push( {
+                                       "fn": _fnUpdateInfo,
+                                       "sName": "information"
+                               } );
+                               
+                               /* Add id */
+                               nInfo.id = oSettings.sTableId+'_info';
+                       }
+                       oSettings.nTable.setAttribute( 'aria-describedby', oSettings.sTableId+'_info' );
+                       
+                       return nInfo;
+               }
+               
+               
+               /**
+                * Update the information elements in the display
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnUpdateInfo ( oSettings )
+               {
+                       /* Show information about the table */
+                       if ( !oSettings.oFeatures.bInfo || oSettings.aanFeatures.i.length === 0 )
+                       {
+                               return;
+                       }
+                       
+                       var
+                               oLang = oSettings.oLanguage,
+                               iStart = oSettings._iDisplayStart+1,
+                               iEnd = oSettings.fnDisplayEnd(),
+                               iMax = oSettings.fnRecordsTotal(),
+                               iTotal = oSettings.fnRecordsDisplay(),
+                               sOut;
+                       
+                       if ( iTotal === 0 )
+                       {
+                               /* Empty record set */
+                               sOut = oLang.sInfoEmpty;
+                       }
+                       else {
+                               /* Normal record set */
+                               sOut = oLang.sInfo;
+                       }
+               
+                       if ( iTotal != iMax )
+                       {
+                               /* Record set after filtering */
+                               sOut += ' ' + oLang.sInfoFiltered;
+                       }
+               
+                       // Convert the macros
+                       sOut += oLang.sInfoPostFix;
+                       sOut = _fnInfoMacros( oSettings, sOut );
+                       
+                       if ( oLang.fnInfoCallback !== null )
+                       {
+                               sOut = oLang.fnInfoCallback.call( oSettings.oInstance, 
+                                       oSettings, iStart, iEnd, iMax, iTotal, sOut );
+                       }
+                       
+                       var n = oSettings.aanFeatures.i;
+                       for ( var i=0, iLen=n.length ; i<iLen ; i++ )
+                       {
+                               $(n[i]).html( sOut );
+                       }
+               }
+               
+               
+               function _fnInfoMacros ( oSettings, str )
+               {
+                       var
+                               iStart = oSettings._iDisplayStart+1,
+                               sStart = oSettings.fnFormatNumber( iStart ),
+                               iEnd = oSettings.fnDisplayEnd(),
+                               sEnd = oSettings.fnFormatNumber( iEnd ),
+                               iTotal = oSettings.fnRecordsDisplay(),
+                               sTotal = oSettings.fnFormatNumber( iTotal ),
+                               iMax = oSettings.fnRecordsTotal(),
+                               sMax = oSettings.fnFormatNumber( iMax );
+               
+                       // When infinite scrolling, we are always starting at 1. _iDisplayStart is used only
+                       // internally
+                       if ( oSettings.oScroll.bInfinite )
+                       {
+                               sStart = oSettings.fnFormatNumber( 1 );
+                       }
+               
+                       return str.
+                               replace(/_START_/g, sStart).
+                               replace(/_END_/g,   sEnd).
+                               replace(/_TOTAL_/g, sTotal).
+                               replace(/_MAX_/g,   sMax);
+               }
+               
+               
+               
+               /**
+                * Draw the table for the first time, adding all required features
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnInitialise ( oSettings )
+               {
+                       var i, iLen, iAjaxStart=oSettings.iInitDisplayStart;
+                       
+                       /* Ensure that the table data is fully initialised */
+                       if ( oSettings.bInitialised === false )
+                       {
+                               setTimeout( function(){ _fnInitialise( oSettings ); }, 200 );
+                               return;
+                       }
+                       
+                       /* Show the display HTML options */
+                       _fnAddOptionsHtml( oSettings );
+                       
+                       /* Build and draw the header / footer for the table */
+                       _fnBuildHead( oSettings );
+                       _fnDrawHead( oSettings, oSettings.aoHeader );
+                       if ( oSettings.nTFoot )
+                       {
+                               _fnDrawHead( oSettings, oSettings.aoFooter );
+                       }
+               
+                       /* Okay to show that something is going on now */
+                       _fnProcessingDisplay( oSettings, true );
+                       
+                       /* Calculate sizes for columns */
+                       if ( oSettings.oFeatures.bAutoWidth )
+                       {
+                               _fnCalculateColumnWidths( oSettings );
+                       }
+                       
+                       for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               if ( oSettings.aoColumns[i].sWidth !== null )
+                               {
+                                       oSettings.aoColumns[i].nTh.style.width = _fnStringToCss( oSettings.aoColumns[i].sWidth );
+                               }
+                       }
+                       
+                       /* If there is default sorting required - let's do it. The sort function will do the
+                        * drawing for us. Otherwise we draw the table regardless of the Ajax source - this allows
+                        * the table to look initialised for Ajax sourcing data (show 'loading' message possibly)
+                        */
+                       if ( oSettings.oFeatures.bSort )
+                       {
+                               _fnSort( oSettings );
+                       }
+                       else if ( oSettings.oFeatures.bFilter )
+                       {
+                               _fnFilterComplete( oSettings, oSettings.oPreviousSearch );
+                       }
+                       else
+                       {
+                               oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                               _fnCalculateEnd( oSettings );
+                               _fnDraw( oSettings );
+                       }
+                       
+                       /* if there is an ajax source load the data */
+                       if ( oSettings.sAjaxSource !== null && !oSettings.oFeatures.bServerSide )
+                       {
+                               var aoData = [];
+                               _fnServerParams( oSettings, aoData );
+                               oSettings.fnServerData.call( oSettings.oInstance, oSettings.sAjaxSource, aoData, function(json) {
+                                       var aData = (oSettings.sAjaxDataProp !== "") ?
+                                               _fnGetObjectDataFn( oSettings.sAjaxDataProp )(json) : json;
+               
+                                       /* Got the data - add it to the table */
+                                       for ( i=0 ; i<aData.length ; i++ )
+                                       {
+                                               _fnAddData( oSettings, aData[i] );
+                                       }
+                                       
+                                       /* Reset the init display for cookie saving. We've already done a filter, and
+                                        * therefore cleared it before. So we need to make it appear 'fresh'
+                                        */
+                                       oSettings.iInitDisplayStart = iAjaxStart;
+                                       
+                                       if ( oSettings.oFeatures.bSort )
+                                       {
+                                               _fnSort( oSettings );
+                                       }
+                                       else
+                                       {
+                                               oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                                               _fnCalculateEnd( oSettings );
+                                               _fnDraw( oSettings );
+                                       }
+                                       
+                                       _fnProcessingDisplay( oSettings, false );
+                                       _fnInitComplete( oSettings, json );
+                               }, oSettings );
+                               return;
+                       }
+                       
+                       /* Server-side processing initialisation complete is done at the end of _fnDraw */
+                       if ( !oSettings.oFeatures.bServerSide )
+                       {
+                               _fnProcessingDisplay( oSettings, false );
+                               _fnInitComplete( oSettings );
+                       }
+               }
+               
+               
+               /**
+                * Draw the table for the first time, adding all required features
+                *  @param {object} oSettings dataTables settings object
+                *  @param {object} [json] JSON from the server that completed the table, if using Ajax source
+                *    with client-side processing (optional)
+                *  @memberof DataTable#oApi
+                */
+               function _fnInitComplete ( oSettings, json )
+               {
+                       oSettings._bInitComplete = true;
+                       _fnCallbackFire( oSettings, 'aoInitComplete', 'init', [oSettings, json] );
+               }
+               
+               
+               /**
+                * Language compatibility - when certain options are given, and others aren't, we
+                * need to duplicate the values over, in order to provide backwards compatibility
+                * with older language files.
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnLanguageCompat( oLanguage )
+               {
+                       var oDefaults = DataTable.defaults.oLanguage;
+               
+                       /* Backwards compatibility - if there is no sEmptyTable given, then use the same as
+                        * sZeroRecords - assuming that is given.
+                        */
+                       if ( !oLanguage.sEmptyTable && oLanguage.sZeroRecords &&
+                               oDefaults.sEmptyTable === "No data available in table" )
+                       {
+                               _fnMap( oLanguage, oLanguage, 'sZeroRecords', 'sEmptyTable' );
+                       }
+               
+                       /* Likewise with loading records */
+                       if ( !oLanguage.sLoadingRecords && oLanguage.sZeroRecords &&
+                               oDefaults.sLoadingRecords === "Loading..." )
+                       {
+                               _fnMap( oLanguage, oLanguage, 'sZeroRecords', 'sLoadingRecords' );
+                       }
+               }
+               
+               
+               
+               /**
+                * Generate the node required for user display length changing
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {node} Display length feature node
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlLength ( oSettings )
+               {
+                       if ( oSettings.oScroll.bInfinite )
+                       {
+                               return null;
+                       }
+                       
+                       /* This can be overruled by not using the _MENU_ var/macro in the language variable */
+                       var sName = 'name="'+oSettings.sTableId+'_length"';
+                       var sStdMenu = '<select size="1" '+sName+'>';
+                       var i, iLen;
+                       var aLengthMenu = oSettings.aLengthMenu;
+                       
+                       if ( aLengthMenu.length == 2 && typeof aLengthMenu[0] === 'object' && 
+                                       typeof aLengthMenu[1] === 'object' )
+                       {
+                               for ( i=0, iLen=aLengthMenu[0].length ; i<iLen ; i++ )
+                               {
+                                       sStdMenu += '<option value="'+aLengthMenu[0][i]+'">'+aLengthMenu[1][i]+'</option>';
+                               }
+                       }
+                       else
+                       {
+                               for ( i=0, iLen=aLengthMenu.length ; i<iLen ; i++ )
+                               {
+                                       sStdMenu += '<option value="'+aLengthMenu[i]+'">'+aLengthMenu[i]+'</option>';
+                               }
+                       }
+                       sStdMenu += '</select>';
+                       
+                       var nLength = document.createElement( 'div' );
+                       if ( !oSettings.aanFeatures.l )
+                       {
+                               nLength.id = oSettings.sTableId+'_length';
+                       }
+                       nLength.className = oSettings.oClasses.sLength;
+                       nLength.innerHTML = '<label>'+oSettings.oLanguage.sLengthMenu.replace( '_MENU_', sStdMenu )+'</label>';
+                       
+                       /*
+                        * Set the length to the current display length - thanks to Andrea Pavlovic for this fix,
+                        * and Stefan Skopnik for fixing the fix!
+                        */
+                       $('select option[value="'+oSettings._iDisplayLength+'"]', nLength).attr("selected", true);
+                       
+                       $('select', nLength).bind( 'change.DT', function(e) {
+                               var iVal = $(this).val();
+                               
+                               /* Update all other length options for the new display */
+                               var n = oSettings.aanFeatures.l;
+                               for ( i=0, iLen=n.length ; i<iLen ; i++ )
+                               {
+                                       if ( n[i] != this.parentNode )
+                                       {
+                                               $('select', n[i]).val( iVal );
+                                       }
+                               }
+                               
+                               /* Redraw the table */
+                               oSettings._iDisplayLength = parseInt(iVal, 10);
+                               _fnCalculateEnd( oSettings );
+                               
+                               /* If we have space to show extra rows (backing up from the end point - then do so */
+                               if ( oSettings.fnDisplayEnd() == oSettings.fnRecordsDisplay() )
+                               {
+                                       oSettings._iDisplayStart = oSettings.fnDisplayEnd() - oSettings._iDisplayLength;
+                                       if ( oSettings._iDisplayStart < 0 )
+                                       {
+                                               oSettings._iDisplayStart = 0;
+                                       }
+                               }
+                               
+                               if ( oSettings._iDisplayLength == -1 )
+                               {
+                                       oSettings._iDisplayStart = 0;
+                               }
+                               
+                               _fnDraw( oSettings );
+                       } );
+               
+               
+                       $('select', nLength).attr('aria-controls', oSettings.sTableId);
+                       
+                       return nLength;
+               }
+               
+               
+               /**
+                * Recalculate the end point based on the start point
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnCalculateEnd( oSettings )
+               {
+                       if ( oSettings.oFeatures.bPaginate === false )
+                       {
+                               oSettings._iDisplayEnd = oSettings.aiDisplay.length;
+                       }
+                       else
+                       {
+                               /* Set the end point of the display - based on how many elements there are
+                                * still to display
+                                */
+                               if ( oSettings._iDisplayStart + oSettings._iDisplayLength > oSettings.aiDisplay.length ||
+                                          oSettings._iDisplayLength == -1 )
+                               {
+                                       oSettings._iDisplayEnd = oSettings.aiDisplay.length;
+                               }
+                               else
+                               {
+                                       oSettings._iDisplayEnd = oSettings._iDisplayStart + oSettings._iDisplayLength;
+                               }
+                       }
+               }
+               
+               
+               
+               /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
+                * Note that most of the paging logic is done in 
+                * DataTable.ext.oPagination
+                */
+               
+               /**
+                * Generate the node required for default pagination
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {node} Pagination feature node
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlPaginate ( oSettings )
+               {
+                       if ( oSettings.oScroll.bInfinite )
+                       {
+                               return null;
+                       }
+                       
+                       var nPaginate = document.createElement( 'div' );
+                       nPaginate.className = oSettings.oClasses.sPaging+oSettings.sPaginationType;
+                       
+                       DataTable.ext.oPagination[ oSettings.sPaginationType ].fnInit( oSettings, nPaginate, 
+                               function( oSettings ) {
+                                       _fnCalculateEnd( oSettings );
+                                       _fnDraw( oSettings );
+                               }
+                       );
+                       
+                       /* Add a draw callback for the pagination on first instance, to update the paging display */
+                       if ( !oSettings.aanFeatures.p )
+                       {
+                               oSettings.aoDrawCallback.push( {
+                                       "fn": function( oSettings ) {
+                                               DataTable.ext.oPagination[ oSettings.sPaginationType ].fnUpdate( oSettings, function( oSettings ) {
+                                                       _fnCalculateEnd( oSettings );
+                                                       _fnDraw( oSettings );
+                                               } );
+                                       },
+                                       "sName": "pagination"
+                               } );
+                       }
+                       return nPaginate;
+               }
+               
+               
+               /**
+                * Alter the display settings to change the page
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string|int} mAction Paging action to take: "first", "previous", "next" or "last"
+                *    or page number to jump to (integer)
+                *  @returns {bool} true page has changed, false - no change (no effect) eg 'first' on page 1
+                *  @memberof DataTable#oApi
+                */
+               function _fnPageChange ( oSettings, mAction )
+               {
+                       var iOldStart = oSettings._iDisplayStart;
+                       
+                       if ( typeof mAction === "number" )
+                       {
+                               oSettings._iDisplayStart = mAction * oSettings._iDisplayLength;
+                               if ( oSettings._iDisplayStart > oSettings.fnRecordsDisplay() )
+                               {
+                                       oSettings._iDisplayStart = 0;
+                               }
+                       }
+                       else if ( mAction == "first" )
+                       {
+                               oSettings._iDisplayStart = 0;
+                       }
+                       else if ( mAction == "previous" )
+                       {
+                               oSettings._iDisplayStart = oSettings._iDisplayLength>=0 ?
+                                       oSettings._iDisplayStart - oSettings._iDisplayLength :
+                                       0;
+                               
+                               /* Correct for under-run */
+                               if ( oSettings._iDisplayStart < 0 )
+                               {
+                                 oSettings._iDisplayStart = 0;
+                               }
+                       }
+                       else if ( mAction == "next" )
+                       {
+                               if ( oSettings._iDisplayLength >= 0 )
+                               {
+                                       /* Make sure we are not over running the display array */
+                                       if ( oSettings._iDisplayStart + oSettings._iDisplayLength < oSettings.fnRecordsDisplay() )
+                                       {
+                                               oSettings._iDisplayStart += oSettings._iDisplayLength;
+                                       }
+                               }
+                               else
+                               {
+                                       oSettings._iDisplayStart = 0;
+                               }
+                       }
+                       else if ( mAction == "last" )
+                       {
+                               if ( oSettings._iDisplayLength >= 0 )
+                               {
+                                       var iPages = parseInt( (oSettings.fnRecordsDisplay()-1) / oSettings._iDisplayLength, 10 ) + 1;
+                                       oSettings._iDisplayStart = (iPages-1) * oSettings._iDisplayLength;
+                               }
+                               else
+                               {
+                                       oSettings._iDisplayStart = 0;
+                               }
+                       }
+                       else
+                       {
+                               _fnLog( oSettings, 0, "Unknown paging action: "+mAction );
+                       }
+                       $(oSettings.oInstance).trigger('page', oSettings);
+                       
+                       return iOldStart != oSettings._iDisplayStart;
+               }
+               
+               
+               
+               /**
+                * Generate the node required for the processing node
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {node} Processing element
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlProcessing ( oSettings )
+               {
+                       var nProcessing = document.createElement( 'div' );
+                       
+                       if ( !oSettings.aanFeatures.r )
+                       {
+                               nProcessing.id = oSettings.sTableId+'_processing';
+                       }
+                       nProcessing.innerHTML = oSettings.oLanguage.sProcessing;
+                       nProcessing.className = oSettings.oClasses.sProcessing;
+                       oSettings.nTable.parentNode.insertBefore( nProcessing, oSettings.nTable );
+                       
+                       return nProcessing;
+               }
+               
+               
+               /**
+                * Display or hide the processing indicator
+                *  @param {object} oSettings dataTables settings object
+                *  @param {bool} bShow Show the processing indicator (true) or not (false)
+                *  @memberof DataTable#oApi
+                */
+               function _fnProcessingDisplay ( oSettings, bShow )
+               {
+                       if ( oSettings.oFeatures.bProcessing )
+                       {
+                               var an = oSettings.aanFeatures.r;
+                               for ( var i=0, iLen=an.length ; i<iLen ; i++ )
+                               {
+                                       an[i].style.visibility = bShow ? "visible" : "hidden";
+                               }
+                       }
+               
+                       $(oSettings.oInstance).trigger('processing', [oSettings, bShow]);
+               }
+               
+               /**
+                * Add any control elements for the table - specifically scrolling
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {node} Node to add to the DOM
+                *  @memberof DataTable#oApi
+                */
+               function _fnFeatureHtmlTable ( oSettings )
+               {
+                       /* Check if scrolling is enabled or not - if not then leave the DOM unaltered */
+                       if ( oSettings.oScroll.sX === "" && oSettings.oScroll.sY === "" )
+                       {
+                               return oSettings.nTable;
+                       }
+                       
+                       /*
+                        * The HTML structure that we want to generate in this function is:
+                        *  div - nScroller
+                        *    div - nScrollHead
+                        *      div - nScrollHeadInner
+                        *        table - nScrollHeadTable
+                        *          thead - nThead
+                        *    div - nScrollBody
+                        *      table - oSettings.nTable
+                        *        thead - nTheadSize
+                        *        tbody - nTbody
+                        *    div - nScrollFoot
+                        *      div - nScrollFootInner
+                        *        table - nScrollFootTable
+                        *          tfoot - nTfoot
+                        */
+                       var
+                               nScroller = document.createElement('div'),
+                               nScrollHead = document.createElement('div'),
+                               nScrollHeadInner = document.createElement('div'),
+                               nScrollBody = document.createElement('div'),
+                               nScrollFoot = document.createElement('div'),
+                               nScrollFootInner = document.createElement('div'),
+                               nScrollHeadTable = oSettings.nTable.cloneNode(false),
+                               nScrollFootTable = oSettings.nTable.cloneNode(false),
+                               nThead = oSettings.nTable.getElementsByTagName('thead')[0],
+                               nTfoot = oSettings.nTable.getElementsByTagName('tfoot').length === 0 ? null : 
+                                       oSettings.nTable.getElementsByTagName('tfoot')[0],
+                               oClasses = oSettings.oClasses;
+                       
+                       nScrollHead.appendChild( nScrollHeadInner );
+                       nScrollFoot.appendChild( nScrollFootInner );
+                       nScrollBody.appendChild( oSettings.nTable );
+                       nScroller.appendChild( nScrollHead );
+                       nScroller.appendChild( nScrollBody );
+                       nScrollHeadInner.appendChild( nScrollHeadTable );
+                       nScrollHeadTable.appendChild( nThead );
+                       if ( nTfoot !== null )
+                       {
+                               nScroller.appendChild( nScrollFoot );
+                               nScrollFootInner.appendChild( nScrollFootTable );
+                               nScrollFootTable.appendChild( nTfoot );
+                       }
+                       
+                       nScroller.className = oClasses.sScrollWrapper;
+                       nScrollHead.className = oClasses.sScrollHead;
+                       nScrollHeadInner.className = oClasses.sScrollHeadInner;
+                       nScrollBody.className = oClasses.sScrollBody;
+                       nScrollFoot.className = oClasses.sScrollFoot;
+                       nScrollFootInner.className = oClasses.sScrollFootInner;
+                       
+                       if ( oSettings.oScroll.bAutoCss )
+                       {
+                               nScrollHead.style.overflow = "hidden";
+                               nScrollHead.style.position = "relative";
+                               nScrollFoot.style.overflow = "hidden";
+                               nScrollBody.style.overflow = "auto";
+                       }
+                       
+                       nScrollHead.style.border = "0";
+                       nScrollHead.style.width = "100%";
+                       nScrollFoot.style.border = "0";
+                       nScrollHeadInner.style.width = oSettings.oScroll.sXInner !== "" ?
+                               oSettings.oScroll.sXInner : "100%"; /* will be overwritten */
+                       
+                       /* Modify attributes to respect the clones */
+                       nScrollHeadTable.removeAttribute('id');
+                       nScrollHeadTable.style.marginLeft = "0";
+                       oSettings.nTable.style.marginLeft = "0";
+                       if ( nTfoot !== null )
+                       {
+                               nScrollFootTable.removeAttribute('id');
+                               nScrollFootTable.style.marginLeft = "0";
+                       }
+                       
+                       /* Move caption elements from the body to the header, footer or leave where it is
+                        * depending on the configuration. Note that the DTD says there can be only one caption */
+                       var nCaption = $(oSettings.nTable).children('caption');
+                       if ( nCaption.length > 0 )
+                       {
+                               nCaption = nCaption[0];
+                               if ( nCaption._captionSide === "top" )
+                               {
+                                       nScrollHeadTable.appendChild( nCaption );
+                               }
+                               else if ( nCaption._captionSide === "bottom" && nTfoot )
+                               {
+                                       nScrollFootTable.appendChild( nCaption );
+                               }
+                       }
+                       
+                       /*
+                        * Sizing
+                        */
+                       /* When x-scrolling add the width and a scroller to move the header with the body */
+                       if ( oSettings.oScroll.sX !== "" )
+                       {
+                               nScrollHead.style.width = _fnStringToCss( oSettings.oScroll.sX );
+                               nScrollBody.style.width = _fnStringToCss( oSettings.oScroll.sX );
+                               
+                               if ( nTfoot !== null )
+                               {
+                                       nScrollFoot.style.width = _fnStringToCss( oSettings.oScroll.sX );       
+                               }
+                               
+                               /* When the body is scrolled, then we also want to scroll the headers */
+                               $(nScrollBody).scroll( function (e) {
+                                       nScrollHead.scrollLeft = this.scrollLeft;
+                                       
+                                       if ( nTfoot !== null )
+                                       {
+                                               nScrollFoot.scrollLeft = this.scrollLeft;
+                                       }
+                               } );
+                       }
+                       
+                       /* When yscrolling, add the height */
+                       if ( oSettings.oScroll.sY !== "" )
+                       {
+                               nScrollBody.style.height = _fnStringToCss( oSettings.oScroll.sY );
+                       }
+                       
+                       /* Redraw - align columns across the tables */
+                       oSettings.aoDrawCallback.push( {
+                               "fn": _fnScrollDraw,
+                               "sName": "scrolling"
+                       } );
+                       
+                       /* Infinite scrolling event handlers */
+                       if ( oSettings.oScroll.bInfinite )
+                       {
+                               $(nScrollBody).scroll( function() {
+                                       /* Use a blocker to stop scrolling from loading more data while other data is still loading */
+                                       if ( !oSettings.bDrawing && $(this).scrollTop() !== 0 )
+                                       {
+                                               /* Check if we should load the next data set */
+                                               if ( $(this).scrollTop() + $(this).height() > 
+                                                       $(oSettings.nTable).height() - oSettings.oScroll.iLoadGap )
+                                               {
+                                                       /* Only do the redraw if we have to - we might be at the end of the data */
+                                                       if ( oSettings.fnDisplayEnd() < oSettings.fnRecordsDisplay() )
+                                                       {
+                                                               _fnPageChange( oSettings, 'next' );
+                                                               _fnCalculateEnd( oSettings );
+                                                               _fnDraw( oSettings );
+                                                       }
+                                               }
+                                       }
+                               } );
+                       }
+                       
+                       oSettings.nScrollHead = nScrollHead;
+                       oSettings.nScrollFoot = nScrollFoot;
+                       
+                       return nScroller;
+               }
+               
+               
+               /**
+                * Update the various tables for resizing. It's a bit of a pig this function, but
+                * basically the idea to:
+                *   1. Re-create the table inside the scrolling div
+                *   2. Take live measurements from the DOM
+                *   3. Apply the measurements
+                *   4. Clean up
+                *  @param {object} o dataTables settings object
+                *  @returns {node} Node to add to the DOM
+                *  @memberof DataTable#oApi
+                */
+               function _fnScrollDraw ( o )
+               {
+                       var
+                               nScrollHeadInner = o.nScrollHead.getElementsByTagName('div')[0],
+                               nScrollHeadTable = nScrollHeadInner.getElementsByTagName('table')[0],
+                               nScrollBody = o.nTable.parentNode,
+                               i, iLen, j, jLen, anHeadToSize, anHeadSizers, anFootSizers, anFootToSize, oStyle, iVis,
+                               nTheadSize, nTfootSize,
+                               iWidth, aApplied=[], aAppliedFooter=[], iSanityWidth,
+                               nScrollFootInner = (o.nTFoot !== null) ? o.nScrollFoot.getElementsByTagName('div')[0] : null,
+                               nScrollFootTable = (o.nTFoot !== null) ? nScrollFootInner.getElementsByTagName('table')[0] : null,
+                               ie67 = o.oBrowser.bScrollOversize,
+                               zeroOut = function(nSizer) {
+                                       oStyle = nSizer.style;
+                                       oStyle.paddingTop = "0";
+                                       oStyle.paddingBottom = "0";
+                                       oStyle.borderTopWidth = "0";
+                                       oStyle.borderBottomWidth = "0";
+                                       oStyle.height = 0;
+                               };
+                       
+                       /*
+                        * 1. Re-create the table inside the scrolling div
+                        */
+                       
+                       /* Remove the old minimised thead and tfoot elements in the inner table */
+                       $(o.nTable).children('thead, tfoot').remove();
+               
+                       /* Clone the current header and footer elements and then place it into the inner table */
+                       nTheadSize = $(o.nTHead).clone()[0];
+                       o.nTable.insertBefore( nTheadSize, o.nTable.childNodes[0] );
+                       anHeadToSize = o.nTHead.getElementsByTagName('tr');
+                       anHeadSizers = nTheadSize.getElementsByTagName('tr');
+                       
+                       if ( o.nTFoot !== null )
+                       {
+                               nTfootSize = $(o.nTFoot).clone()[0];
+                               o.nTable.insertBefore( nTfootSize, o.nTable.childNodes[1] );
+                               anFootToSize = o.nTFoot.getElementsByTagName('tr');
+                               anFootSizers = nTfootSize.getElementsByTagName('tr');
+                       }
+                       
+                       /*
+                        * 2. Take live measurements from the DOM - do not alter the DOM itself!
+                        */
+                       
+                       /* Remove old sizing and apply the calculated column widths
+                        * Get the unique column headers in the newly created (cloned) header. We want to apply the
+                        * calculated sizes to this header
+                        */
+                       if ( o.oScroll.sX === "" )
+                       {
+                               nScrollBody.style.width = '100%';
+                               nScrollHeadInner.parentNode.style.width = '100%';
+                       }
+                       
+                       var nThs = _fnGetUniqueThs( o, nTheadSize );
+                       for ( i=0, iLen=nThs.length ; i<iLen ; i++ )
+                       {
+                               iVis = _fnVisibleToColumnIndex( o, i );
+                               nThs[i].style.width = o.aoColumns[iVis].sWidth;
+                       }
+                       
+                       if ( o.nTFoot !== null )
+                       {
+                               _fnApplyToChildren( function(n) {
+                                       n.style.width = "";
+                               }, anFootSizers );
+                       }
+               
+                       // If scroll collapse is enabled, when we put the headers back into the body for sizing, we
+                       // will end up forcing the scrollbar to appear, making our measurements wrong for when we
+                       // then hide it (end of this function), so add the header height to the body scroller.
+                       if ( o.oScroll.bCollapse && o.oScroll.sY !== "" )
+                       {
+                               nScrollBody.style.height = (nScrollBody.offsetHeight + o.nTHead.offsetHeight)+"px";
+                       }
+                       
+                       /* Size the table as a whole */
+                       iSanityWidth = $(o.nTable).outerWidth();
+                       if ( o.oScroll.sX === "" )
+                       {
+                               /* No x scrolling */
+                               o.nTable.style.width = "100%";
+                               
+                               /* I know this is rubbish - but IE7 will make the width of the table when 100% include
+                                * the scrollbar - which is shouldn't. When there is a scrollbar we need to take this
+                                * into account.
+                                */
+                               if ( ie67 && ($('tbody', nScrollBody).height() > nScrollBody.offsetHeight || 
+                                       $(nScrollBody).css('overflow-y') == "scroll")  )
+                               {
+                                       o.nTable.style.width = _fnStringToCss( $(o.nTable).outerWidth() - o.oScroll.iBarWidth);
+                               }
+                       }
+                       else
+                       {
+                               if ( o.oScroll.sXInner !== "" )
+                               {
+                                       /* x scroll inner has been given - use it */
+                                       o.nTable.style.width = _fnStringToCss(o.oScroll.sXInner);
+                               }
+                               else if ( iSanityWidth == $(nScrollBody).width() &&
+                                  $(nScrollBody).height() < $(o.nTable).height() )
+                               {
+                                       /* There is y-scrolling - try to take account of the y scroll bar */
+                                       o.nTable.style.width = _fnStringToCss( iSanityWidth-o.oScroll.iBarWidth );
+                                       if ( $(o.nTable).outerWidth() > iSanityWidth-o.oScroll.iBarWidth )
+                                       {
+                                               /* Not possible to take account of it */
+                                               o.nTable.style.width = _fnStringToCss( iSanityWidth );
+                                       }
+                               }
+                               else
+                               {
+                                       /* All else fails */
+                                       o.nTable.style.width = _fnStringToCss( iSanityWidth );
+                               }
+                       }
+                       
+                       /* Recalculate the sanity width - now that we've applied the required width, before it was
+                        * a temporary variable. This is required because the column width calculation is done
+                        * before this table DOM is created.
+                        */
+                       iSanityWidth = $(o.nTable).outerWidth();
+                       
+                       /* We want the hidden header to have zero height, so remove padding and borders. Then
+                        * set the width based on the real headers
+                        */
+                       
+                       // Apply all styles in one pass. Invalidates layout only once because we don't read any 
+                       // DOM properties.
+                       _fnApplyToChildren( zeroOut, anHeadSizers );
+                        
+                       // Read all widths in next pass. Forces layout only once because we do not change 
+                       // any DOM properties.
+                       _fnApplyToChildren( function(nSizer) {
+                               aApplied.push( _fnStringToCss( $(nSizer).width() ) );
+                       }, anHeadSizers );
+                        
+                       // Apply all widths in final pass. Invalidates layout only once because we do not
+                       // read any DOM properties.
+                       _fnApplyToChildren( function(nToSize, i) {
+                               nToSize.style.width = aApplied[i];
+                       }, anHeadToSize );
+               
+                       $(anHeadSizers).height(0);
+                       
+                       /* Same again with the footer if we have one */
+                       if ( o.nTFoot !== null )
+                       {
+                               _fnApplyToChildren( zeroOut, anFootSizers );
+                                
+                               _fnApplyToChildren( function(nSizer) {
+                                       aAppliedFooter.push( _fnStringToCss( $(nSizer).width() ) );
+                               }, anFootSizers );
+                                
+                               _fnApplyToChildren( function(nToSize, i) {
+                                       nToSize.style.width = aAppliedFooter[i];
+                               }, anFootToSize );
+               
+                               $(anFootSizers).height(0);
+                       }
+                       
+                       /*
+                        * 3. Apply the measurements
+                        */
+                       
+                       /* "Hide" the header and footer that we used for the sizing. We want to also fix their width
+                        * to what they currently are
+                        */
+                       _fnApplyToChildren( function(nSizer, i) {
+                               nSizer.innerHTML = "";
+                               nSizer.style.width = aApplied[i];
+                       }, anHeadSizers );
+                       
+                       if ( o.nTFoot !== null )
+                       {
+                               _fnApplyToChildren( function(nSizer, i) {
+                                       nSizer.innerHTML = "";
+                                       nSizer.style.width = aAppliedFooter[i];
+                               }, anFootSizers );
+                       }
+                       
+                       /* Sanity check that the table is of a sensible width. If not then we are going to get
+                        * misalignment - try to prevent this by not allowing the table to shrink below its min width
+                        */
+                       if ( $(o.nTable).outerWidth() < iSanityWidth )
+                       {
+                               /* The min width depends upon if we have a vertical scrollbar visible or not */
+                               var iCorrection = ((nScrollBody.scrollHeight > nScrollBody.offsetHeight || 
+                                       $(nScrollBody).css('overflow-y') == "scroll")) ?
+                                               iSanityWidth+o.oScroll.iBarWidth : iSanityWidth;
+                               
+                               /* IE6/7 are a law unto themselves... */
+                               if ( ie67 && (nScrollBody.scrollHeight > 
+                                       nScrollBody.offsetHeight || $(nScrollBody).css('overflow-y') == "scroll")  )
+                               {
+                                       o.nTable.style.width = _fnStringToCss( iCorrection-o.oScroll.iBarWidth );
+                               }
+                               
+                               /* Apply the calculated minimum width to the table wrappers */
+                               nScrollBody.style.width = _fnStringToCss( iCorrection );
+                               o.nScrollHead.style.width = _fnStringToCss( iCorrection );
+                               
+                               if ( o.nTFoot !== null )
+                               {
+                                       o.nScrollFoot.style.width = _fnStringToCss( iCorrection );
+                               }
+                               
+                               /* And give the user a warning that we've stopped the table getting too small */
+                               if ( o.oScroll.sX === "" )
+                               {
+                                       _fnLog( o, 1, "The table cannot fit into the current element which will cause column"+
+                                               " misalignment. The table has been drawn at its minimum possible width." );
+                               }
+                               else if ( o.oScroll.sXInner !== "" )
+                               {
+                                       _fnLog( o, 1, "The table cannot fit into the current element which will cause column"+
+                                               " misalignment. Increase the sScrollXInner value or remove it to allow automatic"+
+                                               " calculation" );
+                               }
+                       }
+                       else
+                       {
+                               nScrollBody.style.width = _fnStringToCss( '100%' );
+                               o.nScrollHead.style.width = _fnStringToCss( '100%' );
+                               
+                               if ( o.nTFoot !== null )
+                               {
+                                       o.nScrollFoot.style.width = _fnStringToCss( '100%' );
+                               }
+                       }
+                       
+                       
+                       /*
+                        * 4. Clean up
+                        */
+                       if ( o.oScroll.sY === "" )
+                       {
+                               /* IE7< puts a vertical scrollbar in place (when it shouldn't be) due to subtracting
+                                * the scrollbar height from the visible display, rather than adding it on. We need to
+                                * set the height in order to sort this. Don't want to do it in any other browsers.
+                                */
+                               if ( ie67 )
+                               {
+                                       nScrollBody.style.height = _fnStringToCss( o.nTable.offsetHeight+o.oScroll.iBarWidth );
+                               }
+                       }
+                       
+                       if ( o.oScroll.sY !== "" && o.oScroll.bCollapse )
+                       {
+                               nScrollBody.style.height = _fnStringToCss( o.oScroll.sY );
+                               
+                               var iExtra = (o.oScroll.sX !== "" && o.nTable.offsetWidth > nScrollBody.offsetWidth) ?
+                                       o.oScroll.iBarWidth : 0;
+                               if ( o.nTable.offsetHeight < nScrollBody.offsetHeight )
+                               {
+                                       nScrollBody.style.height = _fnStringToCss( o.nTable.offsetHeight+iExtra );
+                               }
+                       }
+                       
+                       /* Finally set the width's of the header and footer tables */
+                       var iOuterWidth = $(o.nTable).outerWidth();
+                       nScrollHeadTable.style.width = _fnStringToCss( iOuterWidth );
+                       nScrollHeadInner.style.width = _fnStringToCss( iOuterWidth );
+               
+                       // Figure out if there are scrollbar present - if so then we need a the header and footer to
+                       // provide a bit more space to allow "overflow" scrolling (i.e. past the scrollbar)
+                       var bScrolling = $(o.nTable).height() > nScrollBody.clientHeight || $(nScrollBody).css('overflow-y') == "scroll";
+                       nScrollHeadInner.style.paddingRight = bScrolling ? o.oScroll.iBarWidth+"px" : "0px";
+                       
+                       if ( o.nTFoot !== null )
+                       {
+                               nScrollFootTable.style.width = _fnStringToCss( iOuterWidth );
+                               nScrollFootInner.style.width = _fnStringToCss( iOuterWidth );
+                               nScrollFootInner.style.paddingRight = bScrolling ? o.oScroll.iBarWidth+"px" : "0px";
+                       }
+               
+                       /* Adjust the position of the header in case we loose the y-scrollbar */
+                       $(nScrollBody).scroll();
+                       
+                       /* If sorting or filtering has occurred, jump the scrolling back to the top */
+                       if ( o.bSorted || o.bFiltered )
+                       {
+                               nScrollBody.scrollTop = 0;
+                       }
+               }
+               
+               
+               /**
+                * Apply a given function to the display child nodes of an element array (typically
+                * TD children of TR rows
+                *  @param {function} fn Method to apply to the objects
+                *  @param array {nodes} an1 List of elements to look through for display children
+                *  @param array {nodes} an2 Another list (identical structure to the first) - optional
+                *  @memberof DataTable#oApi
+                */
+               function _fnApplyToChildren( fn, an1, an2 )
+               {
+                       var index=0, i=0, iLen=an1.length;
+                       var nNode1, nNode2;
+               
+                       while ( i < iLen )
+                       {
+                               nNode1 = an1[i].firstChild;
+                               nNode2 = an2 ? an2[i].firstChild : null;
+                               while ( nNode1 )
+                               {
+                                       if ( nNode1.nodeType === 1 )
+                                       {
+                                               if ( an2 )
+                                               {
+                                                       fn( nNode1, nNode2, index );
+                                               }
+                                               else
+                                               {
+                                                       fn( nNode1, index );
+                                               }
+                                               index++;
+                                       }
+                                       nNode1 = nNode1.nextSibling;
+                                       nNode2 = an2 ? nNode2.nextSibling : null;
+                               }
+                               i++;
+                       }
+               }
+               
+               /**
+                * Convert a CSS unit width to pixels (e.g. 2em)
+                *  @param {string} sWidth width to be converted
+                *  @param {node} nParent parent to get the with for (required for relative widths) - optional
+                *  @returns {int} iWidth width in pixels
+                *  @memberof DataTable#oApi
+                */
+               function _fnConvertToWidth ( sWidth, nParent )
+               {
+                       if ( !sWidth || sWidth === null || sWidth === '' )
+                       {
+                               return 0;
+                       }
+                       
+                       if ( !nParent )
+                       {
+                               nParent = document.body;
+                       }
+                       
+                       var iWidth;
+                       var nTmp = document.createElement( "div" );
+                       nTmp.style.width = _fnStringToCss( sWidth );
+                       
+                       nParent.appendChild( nTmp );
+                       iWidth = nTmp.offsetWidth;
+                       nParent.removeChild( nTmp );
+                       
+                       return ( iWidth );
+               }
+               
+               
+               /**
+                * Calculate the width of columns for the table
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnCalculateColumnWidths ( oSettings )
+               {
+                       var iTableWidth = oSettings.nTable.offsetWidth;
+                       var iUserInputs = 0;
+                       var iTmpWidth;
+                       var iVisibleColumns = 0;
+                       var iColums = oSettings.aoColumns.length;
+                       var i, iIndex, iCorrector, iWidth;
+                       var oHeaders = $('th', oSettings.nTHead);
+                       var widthAttr = oSettings.nTable.getAttribute('width');
+                       var nWrapper = oSettings.nTable.parentNode;
+                       
+                       /* Convert any user input sizes into pixel sizes */
+                       for ( i=0 ; i<iColums ; i++ )
+                       {
+                               if ( oSettings.aoColumns[i].bVisible )
+                               {
+                                       iVisibleColumns++;
+                                       
+                                       if ( oSettings.aoColumns[i].sWidth !== null )
+                                       {
+                                               iTmpWidth = _fnConvertToWidth( oSettings.aoColumns[i].sWidthOrig, 
+                                                       nWrapper );
+                                               if ( iTmpWidth !== null )
+                                               {
+                                                       oSettings.aoColumns[i].sWidth = _fnStringToCss( iTmpWidth );
+                                               }
+                                                       
+                                               iUserInputs++;
+                                       }
+                               }
+                       }
+                       
+                       /* If the number of columns in the DOM equals the number that we have to process in 
+                        * DataTables, then we can use the offsets that are created by the web-browser. No custom 
+                        * sizes can be set in order for this to happen, nor scrolling used
+                        */
+                       if ( iColums == oHeaders.length && iUserInputs === 0 && iVisibleColumns == iColums &&
+                               oSettings.oScroll.sX === "" && oSettings.oScroll.sY === "" )
+                       {
+                               for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                               {
+                                       iTmpWidth = $(oHeaders[i]).width();
+                                       if ( iTmpWidth !== null )
+                                       {
+                                               oSettings.aoColumns[i].sWidth = _fnStringToCss( iTmpWidth );
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               /* Otherwise we are going to have to do some calculations to get the width of each column.
+                                * Construct a 1 row table with the widest node in the data, and any user defined widths,
+                                * then insert it into the DOM and allow the browser to do all the hard work of
+                                * calculating table widths.
+                                */
+                               var
+                                       nCalcTmp = oSettings.nTable.cloneNode( false ),
+                                       nTheadClone = oSettings.nTHead.cloneNode(true),
+                                       nBody = document.createElement( 'tbody' ),
+                                       nTr = document.createElement( 'tr' ),
+                                       nDivSizing;
+                               
+                               nCalcTmp.removeAttribute( "id" );
+                               nCalcTmp.appendChild( nTheadClone );
+                               if ( oSettings.nTFoot !== null )
+                               {
+                                       nCalcTmp.appendChild( oSettings.nTFoot.cloneNode(true) );
+                                       _fnApplyToChildren( function(n) {
+                                               n.style.width = "";
+                                       }, nCalcTmp.getElementsByTagName('tr') );
+                               }
+                               
+                               nCalcTmp.appendChild( nBody );
+                               nBody.appendChild( nTr );
+                               
+                               /* Remove any sizing that was previously applied by the styles */
+                               var jqColSizing = $('thead th', nCalcTmp);
+                               if ( jqColSizing.length === 0 )
+                               {
+                                       jqColSizing = $('tbody tr:eq(0)>td', nCalcTmp);
+                               }
+               
+                               /* Apply custom sizing to the cloned header */
+                               var nThs = _fnGetUniqueThs( oSettings, nTheadClone );
+                               iCorrector = 0;
+                               for ( i=0 ; i<iColums ; i++ )
+                               {
+                                       var oColumn = oSettings.aoColumns[i];
+                                       if ( oColumn.bVisible && oColumn.sWidthOrig !== null && oColumn.sWidthOrig !== "" )
+                                       {
+                                               nThs[i-iCorrector].style.width = _fnStringToCss( oColumn.sWidthOrig );
+                                       }
+                                       else if ( oColumn.bVisible )
+                                       {
+                                               nThs[i-iCorrector].style.width = "";
+                                       }
+                                       else
+                                       {
+                                               iCorrector++;
+                                       }
+                               }
+               
+                               /* Find the biggest td for each column and put it into the table */
+                               for ( i=0 ; i<iColums ; i++ )
+                               {
+                                       if ( oSettings.aoColumns[i].bVisible )
+                                       {
+                                               var nTd = _fnGetWidestNode( oSettings, i );
+                                               if ( nTd !== null )
+                                               {
+                                                       nTd = nTd.cloneNode(true);
+                                                       if ( oSettings.aoColumns[i].sContentPadding !== "" )
+                                                       {
+                                                               nTd.innerHTML += oSettings.aoColumns[i].sContentPadding;
+                                                       }
+                                                       nTr.appendChild( nTd );
+                                               }
+                                       }
+                               }
+                               
+                               /* Build the table and 'display' it */
+                               nWrapper.appendChild( nCalcTmp );
+                               
+                               /* When scrolling (X or Y) we want to set the width of the table as appropriate. However,
+                                * when not scrolling leave the table width as it is. This results in slightly different,
+                                * but I think correct behaviour
+                                */
+                               if ( oSettings.oScroll.sX !== "" && oSettings.oScroll.sXInner !== "" )
+                               {
+                                       nCalcTmp.style.width = _fnStringToCss(oSettings.oScroll.sXInner);
+                               }
+                               else if ( oSettings.oScroll.sX !== "" )
+                               {
+                                       nCalcTmp.style.width = "";
+                                       if ( $(nCalcTmp).width() < nWrapper.offsetWidth )
+                                       {
+                                               nCalcTmp.style.width = _fnStringToCss( nWrapper.offsetWidth );
+                                       }
+                               }
+                               else if ( oSettings.oScroll.sY !== "" )
+                               {
+                                       nCalcTmp.style.width = _fnStringToCss( nWrapper.offsetWidth );
+                               }
+                               else if ( widthAttr )
+                               {
+                                       nCalcTmp.style.width = _fnStringToCss( widthAttr );
+                               }
+                               nCalcTmp.style.visibility = "hidden";
+                               
+                               /* Scrolling considerations */
+                               _fnScrollingWidthAdjust( oSettings, nCalcTmp );
+                               
+                               /* Read the width's calculated by the browser and store them for use by the caller. We
+                                * first of all try to use the elements in the body, but it is possible that there are
+                                * no elements there, under which circumstances we use the header elements
+                                */
+                               var oNodes = $("tbody tr:eq(0)", nCalcTmp).children();
+                               if ( oNodes.length === 0 )
+                               {
+                                       oNodes = _fnGetUniqueThs( oSettings, $('thead', nCalcTmp)[0] );
+                               }
+               
+                               /* Browsers need a bit of a hand when a width is assigned to any columns when 
+                                * x-scrolling as they tend to collapse the table to the min-width, even if
+                                * we sent the column widths. So we need to keep track of what the table width
+                                * should be by summing the user given values, and the automatic values
+                                */
+                               if ( oSettings.oScroll.sX !== "" )
+                               {
+                                       var iTotal = 0;
+                                       iCorrector = 0;
+                                       for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                                       {
+                                               if ( oSettings.aoColumns[i].bVisible )
+                                               {
+                                                       if ( oSettings.aoColumns[i].sWidthOrig === null )
+                                                       {
+                                                               iTotal += $(oNodes[iCorrector]).outerWidth();
+                                                       }
+                                                       else
+                                                       {
+                                                               iTotal += parseInt(oSettings.aoColumns[i].sWidth.replace('px',''), 10) +
+                                                                       ($(oNodes[iCorrector]).outerWidth() - $(oNodes[iCorrector]).width());
+                                                       }
+                                                       iCorrector++;
+                                               }
+                                       }
+                                       
+                                       nCalcTmp.style.width = _fnStringToCss( iTotal );
+                                       oSettings.nTable.style.width = _fnStringToCss( iTotal );
+                               }
+               
+                               iCorrector = 0;
+                               for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                               {
+                                       if ( oSettings.aoColumns[i].bVisible )
+                                       {
+                                               iWidth = $(oNodes[iCorrector]).width();
+                                               if ( iWidth !== null && iWidth > 0 )
+                                               {
+                                                       oSettings.aoColumns[i].sWidth = _fnStringToCss( iWidth );
+                                               }
+                                               iCorrector++;
+                                       }
+                               }
+               
+                               var cssWidth = $(nCalcTmp).css('width');
+                               oSettings.nTable.style.width = (cssWidth.indexOf('%') !== -1) ?
+                                   cssWidth : _fnStringToCss( $(nCalcTmp).outerWidth() );
+                               nCalcTmp.parentNode.removeChild( nCalcTmp );
+                       }
+               
+                       if ( widthAttr )
+                       {
+                               oSettings.nTable.style.width = _fnStringToCss( widthAttr );
+                       }
+               }
+               
+               
+               /**
+                * Adjust a table's width to take account of scrolling
+                *  @param {object} oSettings dataTables settings object
+                *  @param {node} n table node
+                *  @memberof DataTable#oApi
+                */
+               function _fnScrollingWidthAdjust ( oSettings, n )
+               {
+                       if ( oSettings.oScroll.sX === "" && oSettings.oScroll.sY !== "" )
+                       {
+                               /* When y-scrolling only, we want to remove the width of the scroll bar so the table
+                                * + scroll bar will fit into the area avaialble.
+                                */
+                               var iOrigWidth = $(n).width();
+                               n.style.width = _fnStringToCss( $(n).outerWidth()-oSettings.oScroll.iBarWidth );
+                       }
+                       else if ( oSettings.oScroll.sX !== "" )
+                       {
+                               /* When x-scrolling both ways, fix the table at it's current size, without adjusting */
+                               n.style.width = _fnStringToCss( $(n).outerWidth() );
+                       }
+               }
+               
+               
+               /**
+                * Get the widest node
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iCol column of interest
+                *  @returns {node} widest table node
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetWidestNode( oSettings, iCol )
+               {
+                       var iMaxIndex = _fnGetMaxLenString( oSettings, iCol );
+                       if ( iMaxIndex < 0 )
+                       {
+                               return null;
+                       }
+               
+                       if ( oSettings.aoData[iMaxIndex].nTr === null )
+                       {
+                               var n = document.createElement('td');
+                               n.innerHTML = _fnGetCellData( oSettings, iMaxIndex, iCol, '' );
+                               return n;
+                       }
+                       return _fnGetTdNodes(oSettings, iMaxIndex)[iCol];
+               }
+               
+               
+               /**
+                * Get the maximum strlen for each data column
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iCol column of interest
+                *  @returns {string} max string length for each column
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetMaxLenString( oSettings, iCol )
+               {
+                       var iMax = -1;
+                       var iMaxIndex = -1;
+                       
+                       for ( var i=0 ; i<oSettings.aoData.length ; i++ )
+                       {
+                               var s = _fnGetCellData( oSettings, i, iCol, 'display' )+"";
+                               s = s.replace( /<.*?>/g, "" );
+                               if ( s.length > iMax )
+                               {
+                                       iMax = s.length;
+                                       iMaxIndex = i;
+                               }
+                       }
+                       
+                       return iMaxIndex;
+               }
+               
+               
+               /**
+                * Append a CSS unit (only if required) to a string
+                *  @param {array} aArray1 first array
+                *  @param {array} aArray2 second array
+                *  @returns {int} 0 if match, 1 if length is different, 2 if no match
+                *  @memberof DataTable#oApi
+                */
+               function _fnStringToCss( s )
+               {
+                       if ( s === null )
+                       {
+                               return "0px";
+                       }
+                       
+                       if ( typeof s == 'number' )
+                       {
+                               if ( s < 0 )
+                               {
+                                       return "0px";
+                               }
+                               return s+"px";
+                       }
+                       
+                       /* Check if the last character is not 0-9 */
+                       var c = s.charCodeAt( s.length-1 );
+                       if (c < 0x30 || c > 0x39)
+                       {
+                               return s;
+                       }
+                       return s+"px";
+               }
+               
+               
+               /**
+                * Get the width of a scroll bar in this browser being used
+                *  @returns {int} width in pixels
+                *  @memberof DataTable#oApi
+                */
+               function _fnScrollBarWidth ()
+               {  
+                       var inner = document.createElement('p');
+                       var style = inner.style;
+                       style.width = "100%";
+                       style.height = "200px";
+                       style.padding = "0px";
+                       
+                       var outer = document.createElement('div');
+                       style = outer.style;
+                       style.position = "absolute";
+                       style.top = "0px";
+                       style.left = "0px";
+                       style.visibility = "hidden";
+                       style.width = "200px";
+                       style.height = "150px";
+                       style.padding = "0px";
+                       style.overflow = "hidden";
+                       outer.appendChild(inner);
+                       
+                       document.body.appendChild(outer);
+                       var w1 = inner.offsetWidth;
+                       outer.style.overflow = 'scroll';
+                       var w2 = inner.offsetWidth;
+                       if ( w1 == w2 )
+                       {
+                               w2 = outer.clientWidth;
+                       }
+                       
+                       document.body.removeChild(outer);
+                       return (w1 - w2);  
+               }
+               
+               /**
+                * Change the order of the table
+                *  @param {object} oSettings dataTables settings object
+                *  @param {bool} bApplyClasses optional - should we apply classes or not
+                *  @memberof DataTable#oApi
+                */
+               function _fnSort ( oSettings, bApplyClasses )
+               {
+                       var
+                               i, iLen, j, jLen, k, kLen,
+                               sDataType, nTh,
+                               aaSort = [],
+                               aiOrig = [],
+                               oSort = DataTable.ext.oSort,
+                               aoData = oSettings.aoData,
+                               aoColumns = oSettings.aoColumns,
+                               oAria = oSettings.oLanguage.oAria;
+                       
+                       /* No sorting required if server-side or no sorting array */
+                       if ( !oSettings.oFeatures.bServerSide && 
+                               (oSettings.aaSorting.length !== 0 || oSettings.aaSortingFixed !== null) )
+                       {
+                               aaSort = ( oSettings.aaSortingFixed !== null ) ?
+                                       oSettings.aaSortingFixed.concat( oSettings.aaSorting ) :
+                                       oSettings.aaSorting.slice();
+                               
+                               /* If there is a sorting data type, and a function belonging to it, then we need to
+                                * get the data from the developer's function and apply it for this column
+                                */
+                               for ( i=0 ; i<aaSort.length ; i++ )
+                               {
+                                       var iColumn = aaSort[i][0];
+                                       var iVisColumn = _fnColumnIndexToVisible( oSettings, iColumn );
+                                       sDataType = oSettings.aoColumns[ iColumn ].sSortDataType;
+                                       if ( DataTable.ext.afnSortData[sDataType] )
+                                       {
+                                               var aData = DataTable.ext.afnSortData[sDataType].call( 
+                                                       oSettings.oInstance, oSettings, iColumn, iVisColumn
+                                               );
+                                               if ( aData.length === aoData.length )
+                                               {
+                                                       for ( j=0, jLen=aoData.length ; j<jLen ; j++ )
+                                                       {
+                                                               _fnSetCellData( oSettings, j, iColumn, aData[j] );
+                                                       }
+                                               }
+                                               else
+                                               {
+                                                       _fnLog( oSettings, 0, "Returned data sort array (col "+iColumn+") is the wrong length" );
+                                               }
+                                       }
+                               }
+                               
+                               /* Create a value - key array of the current row positions such that we can use their
+                                * current position during the sort, if values match, in order to perform stable sorting
+                                */
+                               for ( i=0, iLen=oSettings.aiDisplayMaster.length ; i<iLen ; i++ )
+                               {
+                                       aiOrig[ oSettings.aiDisplayMaster[i] ] = i;
+                               }
+               
+                               /* Build an internal data array which is specific to the sort, so we can get and prep
+                                * the data to be sorted only once, rather than needing to do it every time the sorting
+                                * function runs. This make the sorting function a very simple comparison
+                                */
+                               var iSortLen = aaSort.length;
+                               var fnSortFormat, aDataSort;
+                               for ( i=0, iLen=aoData.length ; i<iLen ; i++ )
+                               {
+                                       for ( j=0 ; j<iSortLen ; j++ )
+                                       {
+                                               aDataSort = aoColumns[ aaSort[j][0] ].aDataSort;
+               
+                                               for ( k=0, kLen=aDataSort.length ; k<kLen ; k++ )
+                                               {
+                                                       sDataType = aoColumns[ aDataSort[k] ].sType;
+                                                       fnSortFormat = oSort[ (sDataType ? sDataType : 'string')+"-pre" ];
+                                                       
+                                                       aoData[i]._aSortData[ aDataSort[k] ] = fnSortFormat ?
+                                                               fnSortFormat( _fnGetCellData( oSettings, i, aDataSort[k], 'sort' ) ) :
+                                                               _fnGetCellData( oSettings, i, aDataSort[k], 'sort' );
+                                               }
+                                       }
+                               }
+                               
+                               /* Do the sort - here we want multi-column sorting based on a given data source (column)
+                                * and sorting function (from oSort) in a certain direction. It's reasonably complex to
+                                * follow on it's own, but this is what we want (example two column sorting):
+                                *  fnLocalSorting = function(a,b){
+                                *      var iTest;
+                                *      iTest = oSort['string-asc']('data11', 'data12');
+                                *      if (iTest !== 0)
+                                *              return iTest;
+                                *    iTest = oSort['numeric-desc']('data21', 'data22');
+                                *    if (iTest !== 0)
+                                *              return iTest;
+                                *      return oSort['numeric-asc']( aiOrig[a], aiOrig[b] );
+                                *  }
+                                * Basically we have a test for each sorting column, if the data in that column is equal,
+                                * test the next column. If all columns match, then we use a numeric sort on the row 
+                                * positions in the original data array to provide a stable sort.
+                                */
+                               oSettings.aiDisplayMaster.sort( function ( a, b ) {
+                                       var k, l, lLen, iTest, aDataSort, sDataType;
+                                       for ( k=0 ; k<iSortLen ; k++ )
+                                       {
+                                               aDataSort = aoColumns[ aaSort[k][0] ].aDataSort;
+               
+                                               for ( l=0, lLen=aDataSort.length ; l<lLen ; l++ )
+                                               {
+                                                       sDataType = aoColumns[ aDataSort[l] ].sType;
+                                                       
+                                                       iTest = oSort[ (sDataType ? sDataType : 'string')+"-"+aaSort[k][1] ](
+                                                               aoData[a]._aSortData[ aDataSort[l] ],
+                                                               aoData[b]._aSortData[ aDataSort[l] ]
+                                                       );
+                                               
+                                                       if ( iTest !== 0 )
+                                                       {
+                                                               return iTest;
+                                                       }
+                                               }
+                                       }
+                                       
+                                       return oSort['numeric-asc']( aiOrig[a], aiOrig[b] );
+                               } );
+                       }
+                       
+                       /* Alter the sorting classes to take account of the changes */
+                       if ( (bApplyClasses === undefined || bApplyClasses) && !oSettings.oFeatures.bDeferRender )
+                       {
+                               _fnSortingClasses( oSettings );
+                       }
+               
+                       for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               var sTitle = aoColumns[i].sTitle.replace( /<.*?>/g, "" );
+                               nTh = aoColumns[i].nTh;
+                               nTh.removeAttribute('aria-sort');
+                               nTh.removeAttribute('aria-label');
+                               
+                               /* In ARIA only the first sorting column can be marked as sorting - no multi-sort option */
+                               if ( aoColumns[i].bSortable )
+                               {
+                                       if ( aaSort.length > 0 && aaSort[0][0] == i )
+                                       {
+                                               nTh.setAttribute('aria-sort', aaSort[0][1]=="asc" ? "ascending" : "descending" );
+                                               
+                                               var nextSort = (aoColumns[i].asSorting[ aaSort[0][2]+1 ]) ? 
+                                                       aoColumns[i].asSorting[ aaSort[0][2]+1 ] : aoColumns[i].asSorting[0];
+                                               nTh.setAttribute('aria-label', sTitle+
+                                                       (nextSort=="asc" ? oAria.sSortAscending : oAria.sSortDescending) );
+                                       }
+                                       else
+                                       {
+                                               nTh.setAttribute('aria-label', sTitle+
+                                                       (aoColumns[i].asSorting[0]=="asc" ? oAria.sSortAscending : oAria.sSortDescending) );
+                                       }
+                               }
+                               else
+                               {
+                                       nTh.setAttribute('aria-label', sTitle);
+                               }
+                       }
+                       
+                       /* Tell the draw function that we have sorted the data */
+                       oSettings.bSorted = true;
+                       $(oSettings.oInstance).trigger('sort', oSettings);
+                       
+                       /* Copy the master data into the draw array and re-draw */
+                       if ( oSettings.oFeatures.bFilter )
+                       {
+                               /* _fnFilter() will redraw the table for us */
+                               _fnFilterComplete( oSettings, oSettings.oPreviousSearch, 1 );
+                       }
+                       else
+                       {
+                               oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                               oSettings._iDisplayStart = 0; /* reset display back to page 0 */
+                               _fnCalculateEnd( oSettings );
+                               _fnDraw( oSettings );
+                       }
+               }
+               
+               
+               /**
+                * Attach a sort handler (click) to a node
+                *  @param {object} oSettings dataTables settings object
+                *  @param {node} nNode node to attach the handler to
+                *  @param {int} iDataIndex column sorting index
+                *  @param {function} [fnCallback] callback function
+                *  @memberof DataTable#oApi
+                */
+               function _fnSortAttachListener ( oSettings, nNode, iDataIndex, fnCallback )
+               {
+                       _fnBindAction( nNode, {}, function (e) {
+                               /* If the column is not sortable - don't to anything */
+                               if ( oSettings.aoColumns[iDataIndex].bSortable === false )
+                               {
+                                       return;
+                               }
+                               
+                               /*
+                                * This is a little bit odd I admit... I declare a temporary function inside the scope of
+                                * _fnBuildHead and the click handler in order that the code presented here can be used 
+                                * twice - once for when bProcessing is enabled, and another time for when it is 
+                                * disabled, as we need to perform slightly different actions.
+                                *   Basically the issue here is that the Javascript engine in modern browsers don't 
+                                * appear to allow the rendering engine to update the display while it is still executing
+                                * it's thread (well - it does but only after long intervals). This means that the 
+                                * 'processing' display doesn't appear for a table sort. To break the js thread up a bit
+                                * I force an execution break by using setTimeout - but this breaks the expected 
+                                * thread continuation for the end-developer's point of view (their code would execute
+                                * too early), so we only do it when we absolutely have to.
+                                */
+                               var fnInnerSorting = function () {
+                                       var iColumn, iNextSort;
+                                       
+                                       /* If the shift key is pressed then we are multiple column sorting */
+                                       if ( e.shiftKey )
+                                       {
+                                               /* Are we already doing some kind of sort on this column? */
+                                               var bFound = false;
+                                               for ( var i=0 ; i<oSettings.aaSorting.length ; i++ )
+                                               {
+                                                       if ( oSettings.aaSorting[i][0] == iDataIndex )
+                                                       {
+                                                               bFound = true;
+                                                               iColumn = oSettings.aaSorting[i][0];
+                                                               iNextSort = oSettings.aaSorting[i][2]+1;
+                                                               
+                                                               if ( !oSettings.aoColumns[iColumn].asSorting[iNextSort] )
+                                                               {
+                                                                       /* Reached the end of the sorting options, remove from multi-col sort */
+                                                                       oSettings.aaSorting.splice( i, 1 );
+                                                               }
+                                                               else
+                                                               {
+                                                                       /* Move onto next sorting direction */
+                                                                       oSettings.aaSorting[i][1] = oSettings.aoColumns[iColumn].asSorting[iNextSort];
+                                                                       oSettings.aaSorting[i][2] = iNextSort;
+                                                               }
+                                                               break;
+                                                       }
+                                               }
+                                               
+                                               /* No sort yet - add it in */
+                                               if ( bFound === false )
+                                               {
+                                                       oSettings.aaSorting.push( [ iDataIndex, 
+                                                               oSettings.aoColumns[iDataIndex].asSorting[0], 0 ] );
+                                               }
+                                       }
+                                       else
+                                       {
+                                               /* If no shift key then single column sort */
+                                               if ( oSettings.aaSorting.length == 1 && oSettings.aaSorting[0][0] == iDataIndex )
+                                               {
+                                                       iColumn = oSettings.aaSorting[0][0];
+                                                       iNextSort = oSettings.aaSorting[0][2]+1;
+                                                       if ( !oSettings.aoColumns[iColumn].asSorting[iNextSort] )
+                                                       {
+                                                               iNextSort = 0;
+                                                       }
+                                                       oSettings.aaSorting[0][1] = oSettings.aoColumns[iColumn].asSorting[iNextSort];
+                                                       oSettings.aaSorting[0][2] = iNextSort;
+                                               }
+                                               else
+                                               {
+                                                       oSettings.aaSorting.splice( 0, oSettings.aaSorting.length );
+                                                       oSettings.aaSorting.push( [ iDataIndex, 
+                                                               oSettings.aoColumns[iDataIndex].asSorting[0], 0 ] );
+                                               }
+                                       }
+                                       
+                                       /* Run the sort */
+                                       _fnSort( oSettings );
+                               }; /* /fnInnerSorting */
+                               
+                               if ( !oSettings.oFeatures.bProcessing )
+                               {
+                                       fnInnerSorting();
+                               }
+                               else
+                               {
+                                       _fnProcessingDisplay( oSettings, true );
+                                       setTimeout( function() {
+                                               fnInnerSorting();
+                                               if ( !oSettings.oFeatures.bServerSide )
+                                               {
+                                                       _fnProcessingDisplay( oSettings, false );
+                                               }
+                                       }, 0 );
+                               }
+                               
+                               /* Call the user specified callback function - used for async user interaction */
+                               if ( typeof fnCallback == 'function' )
+                               {
+                                       fnCallback( oSettings );
+                               }
+                       } );
+               }
+               
+               
+               /**
+                * Set the sorting classes on the header, Note: it is safe to call this function 
+                * when bSort and bSortClasses are false
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnSortingClasses( oSettings )
+               {
+                       var i, iLen, j, jLen, iFound;
+                       var aaSort, sClass;
+                       var iColumns = oSettings.aoColumns.length;
+                       var oClasses = oSettings.oClasses;
+                       
+                       for ( i=0 ; i<iColumns ; i++ )
+                       {
+                               if ( oSettings.aoColumns[i].bSortable )
+                               {
+                                       $(oSettings.aoColumns[i].nTh).removeClass( oClasses.sSortAsc +" "+ oClasses.sSortDesc +
+                                               " "+ oSettings.aoColumns[i].sSortingClass );
+                               }
+                       }
+                       
+                       if ( oSettings.aaSortingFixed !== null )
+                       {
+                               aaSort = oSettings.aaSortingFixed.concat( oSettings.aaSorting );
+                       }
+                       else
+                       {
+                               aaSort = oSettings.aaSorting.slice();
+                       }
+                       
+                       /* Apply the required classes to the header */
+                       for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                       {
+                               if ( oSettings.aoColumns[i].bSortable )
+                               {
+                                       sClass = oSettings.aoColumns[i].sSortingClass;
+                                       iFound = -1;
+                                       for ( j=0 ; j<aaSort.length ; j++ )
+                                       {
+                                               if ( aaSort[j][0] == i )
+                                               {
+                                                       sClass = ( aaSort[j][1] == "asc" ) ?
+                                                               oClasses.sSortAsc : oClasses.sSortDesc;
+                                                       iFound = j;
+                                                       break;
+                                               }
+                                       }
+                                       $(oSettings.aoColumns[i].nTh).addClass( sClass );
+                                       
+                                       if ( oSettings.bJUI )
+                                       {
+                                               /* jQuery UI uses extra markup */
+                                               var jqSpan = $("span."+oClasses.sSortIcon,  oSettings.aoColumns[i].nTh);
+                                               jqSpan.removeClass(oClasses.sSortJUIAsc +" "+ oClasses.sSortJUIDesc +" "+ 
+                                                       oClasses.sSortJUI +" "+ oClasses.sSortJUIAscAllowed +" "+ oClasses.sSortJUIDescAllowed );
+                                               
+                                               var sSpanClass;
+                                               if ( iFound == -1 )
+                                               {
+                                                       sSpanClass = oSettings.aoColumns[i].sSortingClassJUI;
+                                               }
+                                               else if ( aaSort[iFound][1] == "asc" )
+                                               {
+                                                       sSpanClass = oClasses.sSortJUIAsc;
+                                               }
+                                               else
+                                               {
+                                                       sSpanClass = oClasses.sSortJUIDesc;
+                                               }
+                                               
+                                               jqSpan.addClass( sSpanClass );
+                                       }
+                               }
+                               else
+                               {
+                                       /* No sorting on this column, so add the base class. This will have been assigned by
+                                        * _fnAddColumn
+                                        */
+                                       $(oSettings.aoColumns[i].nTh).addClass( oSettings.aoColumns[i].sSortingClass );
+                               }
+                       }
+                       
+                       /* 
+                        * Apply the required classes to the table body
+                        * Note that this is given as a feature switch since it can significantly slow down a sort
+                        * on large data sets (adding and removing of classes is always slow at the best of times..)
+                        * Further to this, note that this code is admittedly fairly ugly. It could be made a lot 
+                        * simpler using jQuery selectors and add/removeClass, but that is significantly slower
+                        * (on the order of 5 times slower) - hence the direct DOM manipulation here.
+                        * Note that for deferred drawing we do use jQuery - the reason being that taking the first
+                        * row found to see if the whole column needs processed can miss classes since the first
+                        * column might be new.
+                        */
+                       sClass = oClasses.sSortColumn;
+                       
+                       if ( oSettings.oFeatures.bSort && oSettings.oFeatures.bSortClasses )
+                       {
+                               var nTds = _fnGetTdNodes( oSettings );
+                               
+                               /* Determine what the sorting class for each column should be */
+                               var iClass, iTargetCol;
+                               var asClasses = [];
+                               for (i = 0; i < iColumns; i++)
+                               {
+                                       asClasses.push("");
+                               }
+                               for (i = 0, iClass = 1; i < aaSort.length; i++)
+                               {
+                                       iTargetCol = parseInt( aaSort[i][0], 10 );
+                                       asClasses[iTargetCol] = sClass + iClass;
+                                       
+                                       if ( iClass < 3 )
+                                       {
+                                               iClass++;
+                                       }
+                               }
+                               
+                               /* Make changes to the classes for each cell as needed */
+                               var reClass = new RegExp(sClass + "[123]");
+                               var sTmpClass, sCurrentClass, sNewClass;
+                               for ( i=0, iLen=nTds.length; i<iLen; i++ )
+                               {
+                                       /* Determine which column we're looking at */
+                                       iTargetCol = i % iColumns;
+                                       
+                                       /* What is the full list of classes now */
+                                       sCurrentClass = nTds[i].className;
+                                       /* What sorting class should be applied? */
+                                       sNewClass = asClasses[iTargetCol];
+                                       /* What would the new full list be if we did a replacement? */
+                                       sTmpClass = sCurrentClass.replace(reClass, sNewClass);
+                                       
+                                       if ( sTmpClass != sCurrentClass )
+                                       {
+                                               /* We changed something */
+                                               nTds[i].className = $.trim( sTmpClass );
+                                       }
+                                       else if ( sNewClass.length > 0 && sCurrentClass.indexOf(sNewClass) == -1 )
+                                       {
+                                               /* We need to add a class */
+                                               nTds[i].className = sCurrentClass + " " + sNewClass;
+                                       }
+                               }
+                       }
+               }
+               
+               
+               
+               /**
+                * Save the state of a table in a cookie such that the page can be reloaded
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnSaveState ( oSettings )
+               {
+                       if ( !oSettings.oFeatures.bStateSave || oSettings.bDestroying )
+                       {
+                               return;
+                       }
+               
+                       /* Store the interesting variables */
+                       var i, iLen, bInfinite=oSettings.oScroll.bInfinite;
+                       var oState = {
+                               "iCreate":      new Date().getTime(),
+                               "iStart":       (bInfinite ? 0 : oSettings._iDisplayStart),
+                               "iEnd":         (bInfinite ? oSettings._iDisplayLength : oSettings._iDisplayEnd),
+                               "iLength":      oSettings._iDisplayLength,
+                               "aaSorting":    $.extend( true, [], oSettings.aaSorting ),
+                               "oSearch":      $.extend( true, {}, oSettings.oPreviousSearch ),
+                               "aoSearchCols": $.extend( true, [], oSettings.aoPreSearchCols ),
+                               "abVisCols":    []
+                       };
+               
+                       for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                       {
+                               oState.abVisCols.push( oSettings.aoColumns[i].bVisible );
+                       }
+               
+                       _fnCallbackFire( oSettings, "aoStateSaveParams", 'stateSaveParams', [oSettings, oState] );
+                       
+                       oSettings.fnStateSave.call( oSettings.oInstance, oSettings, oState );
+               }
+               
+               
+               /**
+                * Attempt to load a saved table state from a cookie
+                *  @param {object} oSettings dataTables settings object
+                *  @param {object} oInit DataTables init object so we can override settings
+                *  @memberof DataTable#oApi
+                */
+               function _fnLoadState ( oSettings, oInit )
+               {
+                       if ( !oSettings.oFeatures.bStateSave )
+                       {
+                               return;
+                       }
+               
+                       var oData = oSettings.fnStateLoad.call( oSettings.oInstance, oSettings );
+                       if ( !oData )
+                       {
+                               return;
+                       }
+                       
+                       /* Allow custom and plug-in manipulation functions to alter the saved data set and
+                        * cancelling of loading by returning false
+                        */
+                       var abStateLoad = _fnCallbackFire( oSettings, 'aoStateLoadParams', 'stateLoadParams', [oSettings, oData] );
+                       if ( $.inArray( false, abStateLoad ) !== -1 )
+                       {
+                               return;
+                       }
+                       
+                       /* Store the saved state so it might be accessed at any time */
+                       oSettings.oLoadedState = $.extend( true, {}, oData );
+                       
+                       /* Restore key features */
+                       oSettings._iDisplayStart    = oData.iStart;
+                       oSettings.iInitDisplayStart = oData.iStart;
+                       oSettings._iDisplayEnd      = oData.iEnd;
+                       oSettings._iDisplayLength   = oData.iLength;
+                       oSettings.aaSorting         = oData.aaSorting.slice();
+                       oSettings.saved_aaSorting   = oData.aaSorting.slice();
+                       
+                       /* Search filtering  */
+                       $.extend( oSettings.oPreviousSearch, oData.oSearch );
+                       $.extend( true, oSettings.aoPreSearchCols, oData.aoSearchCols );
+                       
+                       /* Column visibility state
+                        * Pass back visibility settings to the init handler, but to do not here override
+                        * the init object that the user might have passed in
+                        */
+                       oInit.saved_aoColumns = [];
+                       for ( var i=0 ; i<oData.abVisCols.length ; i++ )
+                       {
+                               oInit.saved_aoColumns[i] = {};
+                               oInit.saved_aoColumns[i].bVisible = oData.abVisCols[i];
+                       }
+               
+                       _fnCallbackFire( oSettings, 'aoStateLoaded', 'stateLoaded', [oSettings, oData] );
+               }
+               
+               
+               /**
+                * Create a new cookie with a value to store the state of a table
+                *  @param {string} sName name of the cookie to create
+                *  @param {string} sValue the value the cookie should take
+                *  @param {int} iSecs duration of the cookie
+                *  @param {string} sBaseName sName is made up of the base + file name - this is the base
+                *  @param {function} fnCallback User definable function to modify the cookie
+                *  @memberof DataTable#oApi
+                */
+               function _fnCreateCookie ( sName, sValue, iSecs, sBaseName, fnCallback )
+               {
+                       var date = new Date();
+                       date.setTime( date.getTime()+(iSecs*1000) );
+                       
+                       /* 
+                        * Shocking but true - it would appear IE has major issues with having the path not having
+                        * a trailing slash on it. We need the cookie to be available based on the path, so we
+                        * have to append the file name to the cookie name. Appalling. Thanks to vex for adding the
+                        * patch to use at least some of the path
+                        */
+                       var aParts = window.location.pathname.split('/');
+                       var sNameFile = sName + '_' + aParts.pop().replace(/[\/:]/g,"").toLowerCase();
+                       var sFullCookie, oData;
+                       
+                       if ( fnCallback !== null )
+                       {
+                               oData = (typeof $.parseJSON === 'function') ? 
+                                       $.parseJSON( sValue ) : eval( '('+sValue+')' );
+                               sFullCookie = fnCallback( sNameFile, oData, date.toGMTString(),
+                                       aParts.join('/')+"/" );
+                       }
+                       else
+                       {
+                               sFullCookie = sNameFile + "=" + encodeURIComponent(sValue) +
+                                       "; expires=" + date.toGMTString() +"; path=" + aParts.join('/')+"/";
+                       }
+                       
+                       /* Are we going to go over the cookie limit of 4KiB? If so, try to delete a cookies
+                        * belonging to DataTables.
+                        */
+                       var
+                               aCookies =document.cookie.split(';'),
+                               iNewCookieLen = sFullCookie.split(';')[0].length,
+                               aOldCookies = [];
+                       
+                       if ( iNewCookieLen+document.cookie.length+10 > 4096 ) /* Magic 10 for padding */
+                       {
+                               for ( var i=0, iLen=aCookies.length ; i<iLen ; i++ )
+                               {
+                                       if ( aCookies[i].indexOf( sBaseName ) != -1 )
+                                       {
+                                               /* It's a DataTables cookie, so eval it and check the time stamp */
+                                               var aSplitCookie = aCookies[i].split('=');
+                                               try {
+                                                       oData = eval( '('+decodeURIComponent(aSplitCookie[1])+')' );
+               
+                                                       if ( oData && oData.iCreate )
+                                                       {
+                                                               aOldCookies.push( {
+                                                                       "name": aSplitCookie[0],
+                                                                       "time": oData.iCreate
+                                                               } );
+                                                       }
+                                               }
+                                               catch( e ) {}
+                                       }
+                               }
+               
+                               // Make sure we delete the oldest ones first
+                               aOldCookies.sort( function (a, b) {
+                                       return b.time - a.time;
+                               } );
+               
+                               // Eliminate as many old DataTables cookies as we need to
+                               while ( iNewCookieLen + document.cookie.length + 10 > 4096 ) {
+                                       if ( aOldCookies.length === 0 ) {
+                                               // Deleted all DT cookies and still not enough space. Can't state save
+                                               return;
+                                       }
+                                       
+                                       var old = aOldCookies.pop();
+                                       document.cookie = old.name+"=; expires=Thu, 01-Jan-1970 00:00:01 GMT; path="+
+                                               aParts.join('/') + "/";
+                               }
+                       }
+                       
+                       document.cookie = sFullCookie;
+               }
+               
+               
+               /**
+                * Read an old cookie to get a cookie with an old table state
+                *  @param {string} sName name of the cookie to read
+                *  @returns {string} contents of the cookie - or null if no cookie with that name found
+                *  @memberof DataTable#oApi
+                */
+               function _fnReadCookie ( sName )
+               {
+                       var
+                               aParts = window.location.pathname.split('/'),
+                               sNameEQ = sName + '_' + aParts[aParts.length-1].replace(/[\/:]/g,"").toLowerCase() + '=',
+                               sCookieContents = document.cookie.split(';');
+                       
+                       for( var i=0 ; i<sCookieContents.length ; i++ )
+                       {
+                               var c = sCookieContents[i];
+                               
+                               while (c.charAt(0)==' ')
+                               {
+                                       c = c.substring(1,c.length);
+                               }
+                               
+                               if (c.indexOf(sNameEQ) === 0)
+                               {
+                                       return decodeURIComponent( c.substring(sNameEQ.length,c.length) );
+                               }
+                       }
+                       return null;
+               }
+               
+               
+               /**
+                * Return the settings object for a particular table
+                *  @param {node} nTable table we are using as a dataTable
+                *  @returns {object} Settings object - or null if not found
+                *  @memberof DataTable#oApi
+                */
+               function _fnSettingsFromNode ( nTable )
+               {
+                       for ( var i=0 ; i<DataTable.settings.length ; i++ )
+                       {
+                               if ( DataTable.settings[i].nTable === nTable )
+                               {
+                                       return DataTable.settings[i];
+                               }
+                       }
+                       
+                       return null;
+               }
+               
+               
+               /**
+                * Return an array with the TR nodes for the table
+                *  @param {object} oSettings dataTables settings object
+                *  @returns {array} TR array
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetTrNodes ( oSettings )
+               {
+                       var aNodes = [];
+                       var aoData = oSettings.aoData;
+                       for ( var i=0, iLen=aoData.length ; i<iLen ; i++ )
+                       {
+                               if ( aoData[i].nTr !== null )
+                               {
+                                       aNodes.push( aoData[i].nTr );
+                               }
+                       }
+                       return aNodes;
+               }
+               
+               
+               /**
+                * Return an flat array with all TD nodes for the table, or row
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} [iIndividualRow] aoData index to get the nodes for - optional 
+                *    if not given then the return array will contain all nodes for the table
+                *  @returns {array} TD array
+                *  @memberof DataTable#oApi
+                */
+               function _fnGetTdNodes ( oSettings, iIndividualRow )
+               {
+                       var anReturn = [];
+                       var iCorrector;
+                       var anTds, nTd;
+                       var iRow, iRows=oSettings.aoData.length,
+                               iColumn, iColumns, oData, sNodeName, iStart=0, iEnd=iRows;
+                       
+                       /* Allow the collection to be limited to just one row */
+                       if ( iIndividualRow !== undefined )
+                       {
+                               iStart = iIndividualRow;
+                               iEnd = iIndividualRow+1;
+                       }
+               
+                       for ( iRow=iStart ; iRow<iEnd ; iRow++ )
+                       {
+                               oData = oSettings.aoData[iRow];
+                               if ( oData.nTr !== null )
+                               {
+                                       /* get the TD child nodes - taking into account text etc nodes */
+                                       anTds = [];
+                                       nTd = oData.nTr.firstChild;
+                                       while ( nTd )
+                                       {
+                                               sNodeName = nTd.nodeName.toLowerCase();
+                                               if ( sNodeName == 'td' || sNodeName == 'th' )
+                                               {
+                                                       anTds.push( nTd );
+                                               }
+                                               nTd = nTd.nextSibling;
+                                       }
+               
+                                       iCorrector = 0;
+                                       for ( iColumn=0, iColumns=oSettings.aoColumns.length ; iColumn<iColumns ; iColumn++ )
+                                       {
+                                               if ( oSettings.aoColumns[iColumn].bVisible )
+                                               {
+                                                       anReturn.push( anTds[iColumn-iCorrector] );
+                                               }
+                                               else
+                                               {
+                                                       anReturn.push( oData._anHidden[iColumn] );
+                                                       iCorrector++;
+                                               }
+                                       }
+                               }
+                       }
+               
+                       return anReturn;
+               }
+               
+               
+               /**
+                * Log an error message
+                *  @param {object} oSettings dataTables settings object
+                *  @param {int} iLevel log error messages, or display them to the user
+                *  @param {string} sMesg error message
+                *  @memberof DataTable#oApi
+                */
+               function _fnLog( oSettings, iLevel, sMesg )
+               {
+                       var sAlert = (oSettings===null) ?
+                               "DataTables warning: "+sMesg :
+                               "DataTables warning (table id = '"+oSettings.sTableId+"'): "+sMesg;
+                       
+                       if ( iLevel === 0 )
+                       {
+                               if ( DataTable.ext.sErrMode == 'alert' )
+                               {
+                                       alert( sAlert );
+                               }
+                               else
+                               {
+                                       throw new Error(sAlert);
+                               }
+                               return;
+                       }
+                       else if ( window.console && console.log )
+                       {
+                               console.log( sAlert );
+                       }
+               }
+               
+               
+               /**
+                * See if a property is defined on one object, if so assign it to the other object
+                *  @param {object} oRet target object
+                *  @param {object} oSrc source object
+                *  @param {string} sName property
+                *  @param {string} [sMappedName] name to map too - optional, sName used if not given
+                *  @memberof DataTable#oApi
+                */
+               function _fnMap( oRet, oSrc, sName, sMappedName )
+               {
+                       if ( sMappedName === undefined )
+                       {
+                               sMappedName = sName;
+                       }
+                       if ( oSrc[sName] !== undefined )
+                       {
+                               oRet[sMappedName] = oSrc[sName];
+                       }
+               }
+               
+               
+               /**
+                * Extend objects - very similar to jQuery.extend, but deep copy objects, and shallow
+                * copy arrays. The reason we need to do this, is that we don't want to deep copy array
+                * init values (such as aaSorting) since the dev wouldn't be able to override them, but
+                * we do want to deep copy arrays.
+                *  @param {object} oOut Object to extend
+                *  @param {object} oExtender Object from which the properties will be applied to oOut
+                *  @returns {object} oOut Reference, just for convenience - oOut === the return.
+                *  @memberof DataTable#oApi
+                *  @todo This doesn't take account of arrays inside the deep copied objects.
+                */
+               function _fnExtend( oOut, oExtender )
+               {
+                       var val;
+                       
+                       for ( var prop in oExtender )
+                       {
+                               if ( oExtender.hasOwnProperty(prop) )
+                               {
+                                       val = oExtender[prop];
+               
+                                       if ( typeof oInit[prop] === 'object' && val !== null && $.isArray(val) === false )
+                                       {
+                                               $.extend( true, oOut[prop], val );
+                                       }
+                                       else
+                                       {
+                                               oOut[prop] = val;
+                                       }
+                               }
+                       }
+               
+                       return oOut;
+               }
+               
+               
+               /**
+                * Bind an event handers to allow a click or return key to activate the callback.
+                * This is good for accessibility since a return on the keyboard will have the
+                * same effect as a click, if the element has focus.
+                *  @param {element} n Element to bind the action to
+                *  @param {object} oData Data object to pass to the triggered function
+                *  @param {function} fn Callback function for when the event is triggered
+                *  @memberof DataTable#oApi
+                */
+               function _fnBindAction( n, oData, fn )
+               {
+                       $(n)
+                               .bind( 'click.DT', oData, function (e) {
+                                               n.blur(); // Remove focus outline for mouse users
+                                               fn(e);
+                                       } )
+                               .bind( 'keypress.DT', oData, function (e){
+                                       if ( e.which === 13 ) {
+                                               fn(e);
+                                       } } )
+                               .bind( 'selectstart.DT', function () {
+                                       /* Take the brutal approach to cancelling text selection */
+                                       return false;
+                                       } );
+               }
+               
+               
+               /**
+                * Register a callback function. Easily allows a callback function to be added to
+                * an array store of callback functions that can then all be called together.
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string} sStore Name of the array storage for the callbacks in oSettings
+                *  @param {function} fn Function to be called back
+                *  @param {string} sName Identifying name for the callback (i.e. a label)
+                *  @memberof DataTable#oApi
+                */
+               function _fnCallbackReg( oSettings, sStore, fn, sName )
+               {
+                       if ( fn )
+                       {
+                               oSettings[sStore].push( {
+                                       "fn": fn,
+                                       "sName": sName
+                               } );
+                       }
+               }
+               
+               
+               /**
+                * Fire callback functions and trigger events. Note that the loop over the callback
+                * array store is done backwards! Further note that you do not want to fire off triggers
+                * in time sensitive applications (for example cell creation) as its slow.
+                *  @param {object} oSettings dataTables settings object
+                *  @param {string} sStore Name of the array storage for the callbacks in oSettings
+                *  @param {string} sTrigger Name of the jQuery custom event to trigger. If null no trigger
+                *    is fired
+                *  @param {array} aArgs Array of arguments to pass to the callback function / trigger
+                *  @memberof DataTable#oApi
+                */
+               function _fnCallbackFire( oSettings, sStore, sTrigger, aArgs )
+               {
+                       var aoStore = oSettings[sStore];
+                       var aRet =[];
+               
+                       for ( var i=aoStore.length-1 ; i>=0 ; i-- )
+                       {
+                               aRet.push( aoStore[i].fn.apply( oSettings.oInstance, aArgs ) );
+                       }
+               
+                       if ( sTrigger !== null )
+                       {
+                               $(oSettings.oInstance).trigger(sTrigger, aArgs);
+                       }
+               
+                       return aRet;
+               }
+               
+               
+               /**
+                * JSON stringify. If JSON.stringify it provided by the browser, json2.js or any other
+                * library, then we use that as it is fast, safe and accurate. If the function isn't 
+                * available then we need to built it ourselves - the inspiration for this function comes
+                * from Craig Buckler ( http://www.sitepoint.com/javascript-json-serialization/ ). It is
+                * not perfect and absolutely should not be used as a replacement to json2.js - but it does
+                * do what we need, without requiring a dependency for DataTables.
+                *  @param {object} o JSON object to be converted
+                *  @returns {string} JSON string
+                *  @memberof DataTable#oApi
+                */
+               var _fnJsonString = (window.JSON) ? JSON.stringify : function( o )
+               {
+                       /* Not an object or array */
+                       var sType = typeof o;
+                       if (sType !== "object" || o === null)
+                       {
+                               // simple data type
+                               if (sType === "string")
+                               {
+                                       o = '"'+o+'"';
+                               }
+                               return o+"";
+                       }
+               
+                       /* If object or array, need to recurse over it */
+                       var
+                               sProp, mValue,
+                               json = [],
+                               bArr = $.isArray(o);
+                       
+                       for (sProp in o)
+                       {
+                               mValue = o[sProp];
+                               sType = typeof mValue;
+               
+                               if (sType === "string")
+                               {
+                                       mValue = '"'+mValue+'"';
+                               }
+                               else if (sType === "object" && mValue !== null)
+                               {
+                                       mValue = _fnJsonString(mValue);
+                               }
+               
+                               json.push((bArr ? "" : '"'+sProp+'":') + mValue);
+                       }
+               
+                       return (bArr ? "[" : "{") + json + (bArr ? "]" : "}");
+               };
+               
+               
+               /**
+                * From some browsers (specifically IE6/7) we need special handling to work around browser
+                * bugs - this function is used to detect when these workarounds are needed.
+                *  @param {object} oSettings dataTables settings object
+                *  @memberof DataTable#oApi
+                */
+               function _fnBrowserDetect( oSettings )
+               {
+                       /* IE6/7 will oversize a width 100% element inside a scrolling element, to include the
+                        * width of the scrollbar, while other browsers ensure the inner element is contained
+                        * without forcing scrolling
+                        */
+                       var n = $(
+                               '<div style="position:absolute; top:0; left:0; height:1px; width:1px; overflow:hidden">'+
+                                       '<div style="position:absolute; top:1px; left:1px; width:100px; overflow:scroll;">'+
+                                               '<div id="DT_BrowserTest" style="width:100%; height:10px;"></div>'+
+                                       '</div>'+
+                               '</div>')[0];
+               
+                       document.body.appendChild( n );
+                       oSettings.oBrowser.bScrollOversize = $('#DT_BrowserTest', n)[0].offsetWidth === 100 ? true : false;
+                       document.body.removeChild( n );
+               }
+               
+
+               /**
+                * Perform a jQuery selector action on the table's TR elements (from the tbody) and
+                * return the resulting jQuery object.
+                *  @param {string|node|jQuery} sSelector jQuery selector or node collection to act on
+                *  @param {object} [oOpts] Optional parameters for modifying the rows to be included
+                *  @param {string} [oOpts.filter=none] Select TR elements that meet the current filter
+                *    criterion ("applied") or all TR elements (i.e. no filter).
+                *  @param {string} [oOpts.order=current] Order of the TR elements in the processed array.
+                *    Can be either 'current', whereby the current sorting of the table is used, or
+                *    'original' whereby the original order the data was read into the table is used.
+                *  @param {string} [oOpts.page=all] Limit the selection to the currently displayed page
+                *    ("current") or not ("all"). If 'current' is given, then order is assumed to be 
+                *    'current' and filter is 'applied', regardless of what they might be given as.
+                *  @returns {object} jQuery object, filtered by the given selector.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *
+                *      // Highlight every second row
+                *      oTable.$('tr:odd').css('backgroundColor', 'blue');
+                *    } );
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *
+                *      // Filter to rows with 'Webkit' in them, add a background colour and then
+                *      // remove the filter, thus highlighting the 'Webkit' rows only.
+                *      oTable.fnFilter('Webkit');
+                *      oTable.$('tr', {"filter": "applied"}).css('backgroundColor', 'blue');
+                *      oTable.fnFilter('');
+                *    } );
+                */
+               this.$ = function ( sSelector, oOpts )
+               {
+                       var i, iLen, a = [], tr;
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var aoData = oSettings.aoData;
+                       var aiDisplay = oSettings.aiDisplay;
+                       var aiDisplayMaster = oSettings.aiDisplayMaster;
+               
+                       if ( !oOpts )
+                       {
+                               oOpts = {};
+                       }
+               
+                       oOpts = $.extend( {}, {
+                               "filter": "none", // applied
+                               "order": "current", // "original"
+                               "page": "all" // current
+                       }, oOpts );
+               
+                       // Current page implies that order=current and fitler=applied, since it is fairly
+                       // senseless otherwise
+                       if ( oOpts.page == 'current' )
+                       {
+                               for ( i=oSettings._iDisplayStart, iLen=oSettings.fnDisplayEnd() ; i<iLen ; i++ )
+                               {
+                                       tr = aoData[ aiDisplay[i] ].nTr;
+                                       if ( tr )
+                                       {
+                                               a.push( tr );
+                                       }
+                               }
+                       }
+                       else if ( oOpts.order == "current" && oOpts.filter == "none" )
+                       {
+                               for ( i=0, iLen=aiDisplayMaster.length ; i<iLen ; i++ )
+                               {
+                                       tr = aoData[ aiDisplayMaster[i] ].nTr;
+                                       if ( tr )
+                                       {
+                                               a.push( tr );
+                                       }
+                               }
+                       }
+                       else if ( oOpts.order == "current" && oOpts.filter == "applied" )
+                       {
+                               for ( i=0, iLen=aiDisplay.length ; i<iLen ; i++ )
+                               {
+                                       tr = aoData[ aiDisplay[i] ].nTr;
+                                       if ( tr )
+                                       {
+                                               a.push( tr );
+                                       }
+                               }
+                       }
+                       else if ( oOpts.order == "original" && oOpts.filter == "none" )
+                       {
+                               for ( i=0, iLen=aoData.length ; i<iLen ; i++ )
+                               {
+                                       tr = aoData[ i ].nTr ;
+                                       if ( tr )
+                                       {
+                                               a.push( tr );
+                                       }
+                               }
+                       }
+                       else if ( oOpts.order == "original" && oOpts.filter == "applied" )
+                       {
+                               for ( i=0, iLen=aoData.length ; i<iLen ; i++ )
+                               {
+                                       tr = aoData[ i ].nTr;
+                                       if ( $.inArray( i, aiDisplay ) !== -1 && tr )
+                                       {
+                                               a.push( tr );
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               _fnLog( oSettings, 1, "Unknown selection options" );
+                       }
+               
+                       /* We need to filter on the TR elements and also 'find' in their descendants
+                        * to make the selector act like it would in a full table - so we need
+                        * to build both results and then combine them together
+                        */
+                       var jqA = $(a);
+                       var jqTRs = jqA.filter( sSelector );
+                       var jqDescendants = jqA.find( sSelector );
+               
+                       return $( [].concat($.makeArray(jqTRs), $.makeArray(jqDescendants)) );
+               };
+               
+               
+               /**
+                * Almost identical to $ in operation, but in this case returns the data for the matched
+                * rows - as such, the jQuery selector used should match TR row nodes or TD/TH cell nodes
+                * rather than any descendants, so the data can be obtained for the row/cell. If matching
+                * rows are found, the data returned is the original data array/object that was used to  
+                * create the row (or a generated array if from a DOM source).
+                *
+                * This method is often useful in-combination with $ where both functions are given the
+                * same parameters and the array indexes will match identically.
+                *  @param {string|node|jQuery} sSelector jQuery selector or node collection to act on
+                *  @param {object} [oOpts] Optional parameters for modifying the rows to be included
+                *  @param {string} [oOpts.filter=none] Select elements that meet the current filter
+                *    criterion ("applied") or all elements (i.e. no filter).
+                *  @param {string} [oOpts.order=current] Order of the data in the processed array.
+                *    Can be either 'current', whereby the current sorting of the table is used, or
+                *    'original' whereby the original order the data was read into the table is used.
+                *  @param {string} [oOpts.page=all] Limit the selection to the currently displayed page
+                *    ("current") or not ("all"). If 'current' is given, then order is assumed to be 
+                *    'current' and filter is 'applied', regardless of what they might be given as.
+                *  @returns {array} Data for the matched elements. If any elements, as a result of the
+                *    selector, were not TR, TD or TH elements in the DataTable, they will have a null 
+                *    entry in the array.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *
+                *      // Get the data from the first row in the table
+                *      var data = oTable._('tr:first');
+                *
+                *      // Do something useful with the data
+                *      alert( "First cell is: "+data[0] );
+                *    } );
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *
+                *      // Filter to 'Webkit' and get all data for 
+                *      oTable.fnFilter('Webkit');
+                *      var data = oTable._('tr', {"filter": "applied"});
+                *      
+                *      // Do something with the data
+                *      alert( data.length+" rows matched the filter" );
+                *    } );
+                */
+               this._ = function ( sSelector, oOpts )
+               {
+                       var aOut = [];
+                       var i, iLen, iIndex;
+                       var aTrs = this.$( sSelector, oOpts );
+               
+                       for ( i=0, iLen=aTrs.length ; i<iLen ; i++ )
+                       {
+                               aOut.push( this.fnGetData(aTrs[i]) );
+                       }
+               
+                       return aOut;
+               };
+               
+               
+               /**
+                * Add a single new row or multiple rows of data to the table. Please note
+                * that this is suitable for client-side processing only - if you are using 
+                * server-side processing (i.e. "bServerSide": true), then to add data, you
+                * must add it to the data source, i.e. the server-side, through an Ajax call.
+                *  @param {array|object} mData The data to be added to the table. This can be:
+                *    <ul>
+                *      <li>1D array of data - add a single row with the data provided</li>
+                *      <li>2D array of arrays - add multiple rows in a single call</li>
+                *      <li>object - data object when using <i>mData</i></li>
+                *      <li>array of objects - multiple data objects when using <i>mData</i></li>
+                *    </ul>
+                *  @param {bool} [bRedraw=true] redraw the table or not
+                *  @returns {array} An array of integers, representing the list of indexes in 
+                *    <i>aoData</i> ({@link DataTable.models.oSettings}) that have been added to 
+                *    the table.
+                *  @dtopt API
+                *
+                *  @example
+                *    // Global var for counter
+                *    var giCount = 2;
+                *    
+                *    $(document).ready(function() {
+                *      $('#example').dataTable();
+                *    } );
+                *    
+                *    function fnClickAddRow() {
+                *      $('#example').dataTable().fnAddData( [
+                *        giCount+".1",
+                *        giCount+".2",
+                *        giCount+".3",
+                *        giCount+".4" ]
+                *      );
+                *        
+                *      giCount++;
+                *    }
+                */
+               this.fnAddData = function( mData, bRedraw )
+               {
+                       if ( mData.length === 0 )
+                       {
+                               return [];
+                       }
+                       
+                       var aiReturn = [];
+                       var iTest;
+                       
+                       /* Find settings from table node */
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       
+                       /* Check if we want to add multiple rows or not */
+                       if ( typeof mData[0] === "object" && mData[0] !== null )
+                       {
+                               for ( var i=0 ; i<mData.length ; i++ )
+                               {
+                                       iTest = _fnAddData( oSettings, mData[i] );
+                                       if ( iTest == -1 )
+                                       {
+                                               return aiReturn;
+                                       }
+                                       aiReturn.push( iTest );
+                               }
+                       }
+                       else
+                       {
+                               iTest = _fnAddData( oSettings, mData );
+                               if ( iTest == -1 )
+                               {
+                                       return aiReturn;
+                               }
+                               aiReturn.push( iTest );
+                       }
+                       
+                       oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                       
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnReDraw( oSettings );
+                       }
+                       return aiReturn;
+               };
+               
+               
+               /**
+                * This function will make DataTables recalculate the column sizes, based on the data 
+                * contained in the table and the sizes applied to the columns (in the DOM, CSS or 
+                * through the sWidth parameter). This can be useful when the width of the table's 
+                * parent element changes (for example a window resize).
+                *  @param {boolean} [bRedraw=true] Redraw the table or not, you will typically want to
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sScrollY": "200px",
+                *        "bPaginate": false
+                *      } );
+                *      
+                *      $(window).bind('resize', function () {
+                *        oTable.fnAdjustColumnSizing();
+                *      } );
+                *    } );
+                */
+               this.fnAdjustColumnSizing = function ( bRedraw )
+               {
+                       var oSettings = _fnSettingsFromNode(this[DataTable.ext.iApiIndex]);
+                       _fnAdjustColumnSizing( oSettings );
+                       
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               this.fnDraw( false );
+                       }
+                       else if ( oSettings.oScroll.sX !== "" || oSettings.oScroll.sY !== "" )
+                       {
+                               /* If not redrawing, but scrolling, we want to apply the new column sizes anyway */
+                               this.oApi._fnScrollDraw(oSettings);
+                       }
+               };
+               
+               
+               /**
+                * Quickly and simply clear a table
+                *  @param {bool} [bRedraw=true] redraw the table or not
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Immediately 'nuke' the current rows (perhaps waiting for an Ajax callback...)
+                *      oTable.fnClearTable();
+                *    } );
+                */
+               this.fnClearTable = function( bRedraw )
+               {
+                       /* Find settings from table node */
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       _fnClearTable( oSettings );
+                       
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnDraw( oSettings );
+                       }
+               };
+               
+               
+               /**
+                * The exact opposite of 'opening' a row, this function will close any rows which 
+                * are currently 'open'.
+                *  @param {node} nTr the table row to 'close'
+                *  @returns {int} 0 on success, or 1 if failed (can't find the row)
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable;
+                *      
+                *      // 'open' an information row when a row is clicked on
+                *      $('#example tbody tr').click( function () {
+                *        if ( oTable.fnIsOpen(this) ) {
+                *          oTable.fnClose( this );
+                *        } else {
+                *          oTable.fnOpen( this, "Temporary row opened", "info_row" );
+                *        }
+                *      } );
+                *      
+                *      oTable = $('#example').dataTable();
+                *    } );
+                */
+               this.fnClose = function( nTr )
+               {
+                       /* Find settings from table node */
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       
+                       for ( var i=0 ; i<oSettings.aoOpenRows.length ; i++ )
+                       {
+                               if ( oSettings.aoOpenRows[i].nParent == nTr )
+                               {
+                                       var nTrParent = oSettings.aoOpenRows[i].nTr.parentNode;
+                                       if ( nTrParent )
+                                       {
+                                               /* Remove it if it is currently on display */
+                                               nTrParent.removeChild( oSettings.aoOpenRows[i].nTr );
+                                       }
+                                       oSettings.aoOpenRows.splice( i, 1 );
+                                       return 0;
+                               }
+                       }
+                       return 1;
+               };
+               
+               
+               /**
+                * Remove a row for the table
+                *  @param {mixed} mTarget The index of the row from aoData to be deleted, or
+                *    the TR element you want to delete
+                *  @param {function|null} [fnCallBack] Callback function
+                *  @param {bool} [bRedraw=true] Redraw the table or not
+                *  @returns {array} The row that was deleted
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Immediately remove the first row
+                *      oTable.fnDeleteRow( 0 );
+                *    } );
+                */
+               this.fnDeleteRow = function( mTarget, fnCallBack, bRedraw )
+               {
+                       /* Find settings from table node */
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var i, iLen, iAODataIndex;
+                       
+                       iAODataIndex = (typeof mTarget === 'object') ? 
+                               _fnNodeToDataIndex(oSettings, mTarget) : mTarget;
+                       
+                       /* Return the data array from this row */
+                       var oData = oSettings.aoData.splice( iAODataIndex, 1 );
+               
+                       /* Update the _DT_RowIndex parameter */
+                       for ( i=0, iLen=oSettings.aoData.length ; i<iLen ; i++ )
+                       {
+                               if ( oSettings.aoData[i].nTr !== null )
+                               {
+                                       oSettings.aoData[i].nTr._DT_RowIndex = i;
+                               }
+                       }
+                       
+                       /* Remove the target row from the search array */
+                       var iDisplayIndex = $.inArray( iAODataIndex, oSettings.aiDisplay );
+                       oSettings.asDataSearch.splice( iDisplayIndex, 1 );
+                       
+                       /* Delete from the display arrays */
+                       _fnDeleteIndex( oSettings.aiDisplayMaster, iAODataIndex );
+                       _fnDeleteIndex( oSettings.aiDisplay, iAODataIndex );
+                       
+                       /* If there is a user callback function - call it */
+                       if ( typeof fnCallBack === "function" )
+                       {
+                               fnCallBack.call( this, oSettings, oData );
+                       }
+                       
+                       /* Check for an 'overflow' they case for displaying the table */
+                       if ( oSettings._iDisplayStart >= oSettings.fnRecordsDisplay() )
+                       {
+                               oSettings._iDisplayStart -= oSettings._iDisplayLength;
+                               if ( oSettings._iDisplayStart < 0 )
+                               {
+                                       oSettings._iDisplayStart = 0;
+                               }
+                       }
+                       
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnCalculateEnd( oSettings );
+                               _fnDraw( oSettings );
+                       }
+                       
+                       return oData;
+               };
+               
+               
+               /**
+                * Restore the table to it's original state in the DOM by removing all of DataTables 
+                * enhancements, alterations to the DOM structure of the table and event listeners.
+                *  @param {boolean} [bRemove=false] Completely remove the table from the DOM
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      // This example is fairly pointless in reality, but shows how fnDestroy can be used
+                *      var oTable = $('#example').dataTable();
+                *      oTable.fnDestroy();
+                *    } );
+                */
+               this.fnDestroy = function ( bRemove )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var nOrig = oSettings.nTableWrapper.parentNode;
+                       var nBody = oSettings.nTBody;
+                       var i, iLen;
+               
+                       bRemove = (bRemove===undefined) ? false : bRemove;
+                       
+                       /* Flag to note that the table is currently being destroyed - no action should be taken */
+                       oSettings.bDestroying = true;
+                       
+                       /* Fire off the destroy callbacks for plug-ins etc */
+                       _fnCallbackFire( oSettings, "aoDestroyCallback", "destroy", [oSettings] );
+               
+                       /* If the table is not being removed, restore the hidden columns */
+                       if ( !bRemove )
+                       {
+                               for ( i=0, iLen=oSettings.aoColumns.length ; i<iLen ; i++ )
+                               {
+                                       if ( oSettings.aoColumns[i].bVisible === false )
+                                       {
+                                               this.fnSetColumnVis( i, true );
+                                       }
+                               }
+                       }
+                       
+                       /* Blitz all DT events */
+                       $(oSettings.nTableWrapper).find('*').andSelf().unbind('.DT');
+                       
+                       /* If there is an 'empty' indicator row, remove it */
+                       $('tbody>tr>td.'+oSettings.oClasses.sRowEmpty, oSettings.nTable).parent().remove();
+                       
+                       /* When scrolling we had to break the table up - restore it */
+                       if ( oSettings.nTable != oSettings.nTHead.parentNode )
+                       {
+                               $(oSettings.nTable).children('thead').remove();
+                               oSettings.nTable.appendChild( oSettings.nTHead );
+                       }
+                       
+                       if ( oSettings.nTFoot && oSettings.nTable != oSettings.nTFoot.parentNode )
+                       {
+                               $(oSettings.nTable).children('tfoot').remove();
+                               oSettings.nTable.appendChild( oSettings.nTFoot );
+                       }
+                       
+                       /* Remove the DataTables generated nodes, events and classes */
+                       oSettings.nTable.parentNode.removeChild( oSettings.nTable );
+                       $(oSettings.nTableWrapper).remove();
+                       
+                       oSettings.aaSorting = [];
+                       oSettings.aaSortingFixed = [];
+                       _fnSortingClasses( oSettings );
+                       
+                       $(_fnGetTrNodes( oSettings )).removeClass( oSettings.asStripeClasses.join(' ') );
+                       
+                       $('th, td', oSettings.nTHead).removeClass( [
+                               oSettings.oClasses.sSortable,
+                               oSettings.oClasses.sSortableAsc,
+                               oSettings.oClasses.sSortableDesc,
+                               oSettings.oClasses.sSortableNone ].join(' ')
+                       );
+                       if ( oSettings.bJUI )
+                       {
+                               $('th span.'+oSettings.oClasses.sSortIcon
+                                       + ', td span.'+oSettings.oClasses.sSortIcon, oSettings.nTHead).remove();
+               
+                               $('th, td', oSettings.nTHead).each( function () {
+                                       var jqWrapper = $('div.'+oSettings.oClasses.sSortJUIWrapper, this);
+                                       var kids = jqWrapper.contents();
+                                       $(this).append( kids );
+                                       jqWrapper.remove();
+                               } );
+                       }
+                       
+                       /* Add the TR elements back into the table in their original order */
+                       if ( !bRemove && oSettings.nTableReinsertBefore )
+                       {
+                               nOrig.insertBefore( oSettings.nTable, oSettings.nTableReinsertBefore );
+                       }
+                       else if ( !bRemove )
+                       {
+                               nOrig.appendChild( oSettings.nTable );
+                       }
+               
+                       for ( i=0, iLen=oSettings.aoData.length ; i<iLen ; i++ )
+                       {
+                               if ( oSettings.aoData[i].nTr !== null )
+                               {
+                                       nBody.appendChild( oSettings.aoData[i].nTr );
+                               }
+                       }
+                       
+                       /* Restore the width of the original table */
+                       if ( oSettings.oFeatures.bAutoWidth === true )
+                       {
+                         oSettings.nTable.style.width = _fnStringToCss(oSettings.sDestroyWidth);
+                       }
+                       
+                       /* If the were originally stripe classes - then we add them back here. Note
+                        * this is not fool proof (for example if not all rows had stripe classes - but
+                        * it's a good effort without getting carried away
+                        */
+                       iLen = oSettings.asDestroyStripes.length;
+                       if (iLen)
+                       {
+                               var anRows = $(nBody).children('tr');
+                               for ( i=0 ; i<iLen ; i++ )
+                               {
+                                       anRows.filter(':nth-child(' + iLen + 'n + ' + i + ')').addClass( oSettings.asDestroyStripes[i] );
+                               }
+                       }
+                       
+                       /* Remove the settings object from the settings array */
+                       for ( i=0, iLen=DataTable.settings.length ; i<iLen ; i++ )
+                       {
+                               if ( DataTable.settings[i] == oSettings )
+                               {
+                                       DataTable.settings.splice( i, 1 );
+                               }
+                       }
+                       
+                       /* End it all */
+                       oSettings = null;
+                       oInit = null;
+               };
+               
+               
+               /**
+                * Redraw the table
+                *  @param {bool} [bComplete=true] Re-filter and resort (if enabled) the table before the draw.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Re-draw the table - you wouldn't want to do it here, but it's an example :-)
+                *      oTable.fnDraw();
+                *    } );
+                */
+               this.fnDraw = function( bComplete )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       if ( bComplete === false )
+                       {
+                               _fnCalculateEnd( oSettings );
+                               _fnDraw( oSettings );
+                       }
+                       else
+                       {
+                               _fnReDraw( oSettings );
+                       }
+               };
+               
+               
+               /**
+                * Filter the input based on data
+                *  @param {string} sInput String to filter the table on
+                *  @param {int|null} [iColumn] Column to limit filtering to
+                *  @param {bool} [bRegex=false] Treat as regular expression or not
+                *  @param {bool} [bSmart=true] Perform smart filtering or not
+                *  @param {bool} [bShowGlobal=true] Show the input global filter in it's input box(es)
+                *  @param {bool} [bCaseInsensitive=true] Do case-insensitive matching (true) or not (false)
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Sometime later - filter...
+                *      oTable.fnFilter( 'test string' );
+                *    } );
+                */
+               this.fnFilter = function( sInput, iColumn, bRegex, bSmart, bShowGlobal, bCaseInsensitive )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       
+                       if ( !oSettings.oFeatures.bFilter )
+                       {
+                               return;
+                       }
+                       
+                       if ( bRegex === undefined || bRegex === null )
+                       {
+                               bRegex = false;
+                       }
+                       
+                       if ( bSmart === undefined || bSmart === null )
+                       {
+                               bSmart = true;
+                       }
+                       
+                       if ( bShowGlobal === undefined || bShowGlobal === null )
+                       {
+                               bShowGlobal = true;
+                       }
+                       
+                       if ( bCaseInsensitive === undefined || bCaseInsensitive === null )
+                       {
+                               bCaseInsensitive = true;
+                       }
+                       
+                       if ( iColumn === undefined || iColumn === null )
+                       {
+                               /* Global filter */
+                               _fnFilterComplete( oSettings, {
+                                       "sSearch":sInput+"",
+                                       "bRegex": bRegex,
+                                       "bSmart": bSmart,
+                                       "bCaseInsensitive": bCaseInsensitive
+                               }, 1 );
+                               
+                               if ( bShowGlobal && oSettings.aanFeatures.f )
+                               {
+                                       var n = oSettings.aanFeatures.f;
+                                       for ( var i=0, iLen=n.length ; i<iLen ; i++ )
+                                       {
+                                               // IE9 throws an 'unknown error' if document.activeElement is used
+                                               // inside an iframe or frame...
+                                               try {
+                                                       if ( n[i]._DT_Input != document.activeElement )
+                                                       {
+                                                               $(n[i]._DT_Input).val( sInput );
+                                                       }
+                                               }
+                                               catch ( e ) {
+                                                       $(n[i]._DT_Input).val( sInput );
+                                               }
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               /* Single column filter */
+                               $.extend( oSettings.aoPreSearchCols[ iColumn ], {
+                                       "sSearch": sInput+"",
+                                       "bRegex": bRegex,
+                                       "bSmart": bSmart,
+                                       "bCaseInsensitive": bCaseInsensitive
+                               } );
+                               _fnFilterComplete( oSettings, oSettings.oPreviousSearch, 1 );
+                       }
+               };
+               
+               
+               /**
+                * Get the data for the whole table, an individual row or an individual cell based on the 
+                * provided parameters.
+                *  @param {int|node} [mRow] A TR row node, TD/TH cell node or an integer. If given as
+                *    a TR node then the data source for the whole row will be returned. If given as a
+                *    TD/TH cell node then iCol will be automatically calculated and the data for the
+                *    cell returned. If given as an integer, then this is treated as the aoData internal
+                *    data index for the row (see fnGetPosition) and the data for that row used.
+                *  @param {int} [iCol] Optional column index that you want the data of.
+                *  @returns {array|object|string} If mRow is undefined, then the data for all rows is
+                *    returned. If mRow is defined, just data for that row, and is iCol is
+                *    defined, only data for the designated cell is returned.
+                *  @dtopt API
+                *
+                *  @example
+                *    // Row data
+                *    $(document).ready(function() {
+                *      oTable = $('#example').dataTable();
+                *
+                *      oTable.$('tr').click( function () {
+                *        var data = oTable.fnGetData( this );
+                *        // ... do something with the array / object of data for the row
+                *      } );
+                *    } );
+                *
+                *  @example
+                *    // Individual cell data
+                *    $(document).ready(function() {
+                *      oTable = $('#example').dataTable();
+                *
+                *      oTable.$('td').click( function () {
+                *        var sData = oTable.fnGetData( this );
+                *        alert( 'The cell clicked on had the value of '+sData );
+                *      } );
+                *    } );
+                */
+               this.fnGetData = function( mRow, iCol )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       
+                       if ( mRow !== undefined )
+                       {
+                               var iRow = mRow;
+                               if ( typeof mRow === 'object' )
+                               {
+                                       var sNode = mRow.nodeName.toLowerCase();
+                                       if (sNode === "tr" )
+                                       {
+                                               iRow = _fnNodeToDataIndex(oSettings, mRow);
+                                       }
+                                       else if ( sNode === "td" )
+                                       {
+                                               iRow = _fnNodeToDataIndex(oSettings, mRow.parentNode);
+                                               iCol = _fnNodeToColumnIndex( oSettings, iRow, mRow );
+                                       }
+                               }
+               
+                               if ( iCol !== undefined )
+                               {
+                                       return _fnGetCellData( oSettings, iRow, iCol, '' );
+                               }
+                               return (oSettings.aoData[iRow]!==undefined) ?
+                                       oSettings.aoData[iRow]._aData : null;
+                       }
+                       return _fnGetDataMaster( oSettings );
+               };
+               
+               
+               /**
+                * Get an array of the TR nodes that are used in the table's body. Note that you will 
+                * typically want to use the '$' API method in preference to this as it is more 
+                * flexible.
+                *  @param {int} [iRow] Optional row index for the TR element you want
+                *  @returns {array|node} If iRow is undefined, returns an array of all TR elements
+                *    in the table's body, or iRow is defined, just the TR element requested.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Get the nodes from the table
+                *      var nNodes = oTable.fnGetNodes( );
+                *    } );
+                */
+               this.fnGetNodes = function( iRow )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       
+                       if ( iRow !== undefined ) {
+                               return (oSettings.aoData[iRow]!==undefined) ?
+                                       oSettings.aoData[iRow].nTr : null;
+                       }
+                       return _fnGetTrNodes( oSettings );
+               };
+               
+               
+               /**
+                * Get the array indexes of a particular cell from it's DOM element
+                * and column index including hidden columns
+                *  @param {node} nNode this can either be a TR, TD or TH in the table's body
+                *  @returns {int} If nNode is given as a TR, then a single index is returned, or
+                *    if given as a cell, an array of [row index, column index (visible), 
+                *    column index (all)] is given.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      $('#example tbody td').click( function () {
+                *        // Get the position of the current data from the node
+                *        var aPos = oTable.fnGetPosition( this );
+                *        
+                *        // Get the data array for this row
+                *        var aData = oTable.fnGetData( aPos[0] );
+                *        
+                *        // Update the data array and return the value
+                *        aData[ aPos[1] ] = 'clicked';
+                *        this.innerHTML = 'clicked';
+                *      } );
+                *      
+                *      // Init DataTables
+                *      oTable = $('#example').dataTable();
+                *    } );
+                */
+               this.fnGetPosition = function( nNode )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var sNodeName = nNode.nodeName.toUpperCase();
+                       
+                       if ( sNodeName == "TR" )
+                       {
+                               return _fnNodeToDataIndex(oSettings, nNode);
+                       }
+                       else if ( sNodeName == "TD" || sNodeName == "TH" )
+                       {
+                               var iDataIndex = _fnNodeToDataIndex( oSettings, nNode.parentNode );
+                               var iColumnIndex = _fnNodeToColumnIndex( oSettings, iDataIndex, nNode );
+                               return [ iDataIndex, _fnColumnIndexToVisible(oSettings, iColumnIndex ), iColumnIndex ];
+                       }
+                       return null;
+               };
+               
+               
+               /**
+                * Check to see if a row is 'open' or not.
+                *  @param {node} nTr the table row to check
+                *  @returns {boolean} true if the row is currently open, false otherwise
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable;
+                *      
+                *      // 'open' an information row when a row is clicked on
+                *      $('#example tbody tr').click( function () {
+                *        if ( oTable.fnIsOpen(this) ) {
+                *          oTable.fnClose( this );
+                *        } else {
+                *          oTable.fnOpen( this, "Temporary row opened", "info_row" );
+                *        }
+                *      } );
+                *      
+                *      oTable = $('#example').dataTable();
+                *    } );
+                */
+               this.fnIsOpen = function( nTr )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var aoOpenRows = oSettings.aoOpenRows;
+                       
+                       for ( var i=0 ; i<oSettings.aoOpenRows.length ; i++ )
+                       {
+                               if ( oSettings.aoOpenRows[i].nParent == nTr )
+                               {
+                                       return true;
+                               }
+                       }
+                       return false;
+               };
+               
+               
+               /**
+                * This function will place a new row directly after a row which is currently 
+                * on display on the page, with the HTML contents that is passed into the 
+                * function. This can be used, for example, to ask for confirmation that a 
+                * particular record should be deleted.
+                *  @param {node} nTr The table row to 'open'
+                *  @param {string|node|jQuery} mHtml The HTML to put into the row
+                *  @param {string} sClass Class to give the new TD cell
+                *  @returns {node} The row opened. Note that if the table row passed in as the
+                *    first parameter, is not found in the table, this method will silently
+                *    return.
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable;
+                *      
+                *      // 'open' an information row when a row is clicked on
+                *      $('#example tbody tr').click( function () {
+                *        if ( oTable.fnIsOpen(this) ) {
+                *          oTable.fnClose( this );
+                *        } else {
+                *          oTable.fnOpen( this, "Temporary row opened", "info_row" );
+                *        }
+                *      } );
+                *      
+                *      oTable = $('#example').dataTable();
+                *    } );
+                */
+               this.fnOpen = function( nTr, mHtml, sClass )
+               {
+                       /* Find settings from table node */
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+               
+                       /* Check that the row given is in the table */
+                       var nTableRows = _fnGetTrNodes( oSettings );
+                       if ( $.inArray(nTr, nTableRows) === -1 )
+                       {
+                               return;
+                       }
+                       
+                       /* the old open one if there is one */
+                       this.fnClose( nTr );
+                       
+                       var nNewRow = document.createElement("tr");
+                       var nNewCell = document.createElement("td");
+                       nNewRow.appendChild( nNewCell );
+                       nNewCell.className = sClass;
+                       nNewCell.colSpan = _fnVisbleColumns( oSettings );
+               
+                       if (typeof mHtml === "string")
+                       {
+                               nNewCell.innerHTML = mHtml;
+                       }
+                       else
+                       {
+                               $(nNewCell).html( mHtml );
+                       }
+               
+                       /* If the nTr isn't on the page at the moment - then we don't insert at the moment */
+                       var nTrs = $('tr', oSettings.nTBody);
+                       if ( $.inArray(nTr, nTrs) != -1  )
+                       {
+                               $(nNewRow).insertAfter(nTr);
+                       }
+                       
+                       oSettings.aoOpenRows.push( {
+                               "nTr": nNewRow,
+                               "nParent": nTr
+                       } );
+                       
+                       return nNewRow;
+               };
+               
+               
+               /**
+                * Change the pagination - provides the internal logic for pagination in a simple API 
+                * function. With this function you can have a DataTables table go to the next, 
+                * previous, first or last pages.
+                *  @param {string|int} mAction Paging action to take: "first", "previous", "next" or "last"
+                *    or page number to jump to (integer), note that page 0 is the first page.
+                *  @param {bool} [bRedraw=true] Redraw the table or not
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      oTable.fnPageChange( 'next' );
+                *    } );
+                */
+               this.fnPageChange = function ( mAction, bRedraw )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       _fnPageChange( oSettings, mAction );
+                       _fnCalculateEnd( oSettings );
+                       
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnDraw( oSettings );
+                       }
+               };
+               
+               
+               /**
+                * Show a particular column
+                *  @param {int} iCol The column whose display should be changed
+                *  @param {bool} bShow Show (true) or hide (false) the column
+                *  @param {bool} [bRedraw=true] Redraw the table or not
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Hide the second column after initialisation
+                *      oTable.fnSetColumnVis( 1, false );
+                *    } );
+                */
+               this.fnSetColumnVis = function ( iCol, bShow, bRedraw )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var i, iLen;
+                       var aoColumns = oSettings.aoColumns;
+                       var aoData = oSettings.aoData;
+                       var nTd, bAppend, iBefore;
+                       
+                       /* No point in doing anything if we are requesting what is already true */
+                       if ( aoColumns[iCol].bVisible == bShow )
+                       {
+                               return;
+                       }
+                       
+                       /* Show the column */
+                       if ( bShow )
+                       {
+                               var iInsert = 0;
+                               for ( i=0 ; i<iCol ; i++ )
+                               {
+                                       if ( aoColumns[i].bVisible )
+                                       {
+                                               iInsert++;
+                                       }
+                               }
+                               
+                               /* Need to decide if we should use appendChild or insertBefore */
+                               bAppend = (iInsert >= _fnVisbleColumns( oSettings ));
+               
+                               /* Which coloumn should we be inserting before? */
+                               if ( !bAppend )
+                               {
+                                       for ( i=iCol ; i<aoColumns.length ; i++ )
+                                       {
+                                               if ( aoColumns[i].bVisible )
+                                               {
+                                                       iBefore = i;
+                                                       break;
+                                               }
+                                       }
+                               }
+               
+                               for ( i=0, iLen=aoData.length ; i<iLen ; i++ )
+                               {
+                                       if ( aoData[i].nTr !== null )
+                                       {
+                                               if ( bAppend )
+                                               {
+                                                       aoData[i].nTr.appendChild( 
+                                                               aoData[i]._anHidden[iCol]
+                                                       );
+                                               }
+                                               else
+                                               {
+                                                       aoData[i].nTr.insertBefore(
+                                                               aoData[i]._anHidden[iCol], 
+                                                               _fnGetTdNodes( oSettings, i )[iBefore] );
+                                               }
+                                       }
+                               }
+                       }
+                       else
+                       {
+                               /* Remove a column from display */
+                               for ( i=0, iLen=aoData.length ; i<iLen ; i++ )
+                               {
+                                       if ( aoData[i].nTr !== null )
+                                       {
+                                               nTd = _fnGetTdNodes( oSettings, i )[iCol];
+                                               aoData[i]._anHidden[iCol] = nTd;
+                                               nTd.parentNode.removeChild( nTd );
+                                       }
+                               }
+                       }
+               
+                       /* Clear to set the visible flag */
+                       aoColumns[iCol].bVisible = bShow;
+               
+                       /* Redraw the header and footer based on the new column visibility */
+                       _fnDrawHead( oSettings, oSettings.aoHeader );
+                       if ( oSettings.nTFoot )
+                       {
+                               _fnDrawHead( oSettings, oSettings.aoFooter );
+                       }
+                       
+                       /* If there are any 'open' rows, then we need to alter the colspan for this col change */
+                       for ( i=0, iLen=oSettings.aoOpenRows.length ; i<iLen ; i++ )
+                       {
+                               oSettings.aoOpenRows[i].nTr.colSpan = _fnVisbleColumns( oSettings );
+                       }
+                       
+                       /* Do a redraw incase anything depending on the table columns needs it 
+                        * (built-in: scrolling) 
+                        */
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnAdjustColumnSizing( oSettings );
+                               _fnDraw( oSettings );
+                       }
+                       
+                       _fnSaveState( oSettings );
+               };
+               
+               
+               /**
+                * Get the settings for a particular table for external manipulation
+                *  @returns {object} DataTables settings object. See 
+                *    {@link DataTable.models.oSettings}
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      var oSettings = oTable.fnSettings();
+                *      
+                *      // Show an example parameter from the settings
+                *      alert( oSettings._iDisplayStart );
+                *    } );
+                */
+               this.fnSettings = function()
+               {
+                       return _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+               };
+               
+               
+               /**
+                * Sort the table by a particular column
+                *  @param {int} iCol the data index to sort on. Note that this will not match the 
+                *    'display index' if you have hidden data entries
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Sort immediately with columns 0 and 1
+                *      oTable.fnSort( [ [0,'asc'], [1,'asc'] ] );
+                *    } );
+                */
+               this.fnSort = function( aaSort )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       oSettings.aaSorting = aaSort;
+                       _fnSort( oSettings );
+               };
+               
+               
+               /**
+                * Attach a sort listener to an element for a given column
+                *  @param {node} nNode the element to attach the sort listener to
+                *  @param {int} iColumn the column that a click on this node will sort on
+                *  @param {function} [fnCallback] callback function when sort is run
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      
+                *      // Sort on column 1, when 'sorter' is clicked on
+                *      oTable.fnSortListener( document.getElementById('sorter'), 1 );
+                *    } );
+                */
+               this.fnSortListener = function( nNode, iColumn, fnCallback )
+               {
+                       _fnSortAttachListener( _fnSettingsFromNode( this[DataTable.ext.iApiIndex] ), nNode, iColumn,
+                               fnCallback );
+               };
+               
+               
+               /**
+                * Update a table cell or row - this method will accept either a single value to
+                * update the cell with, an array of values with one element for each column or
+                * an object in the same format as the original data source. The function is
+                * self-referencing in order to make the multi column updates easier.
+                *  @param {object|array|string} mData Data to update the cell/row with
+                *  @param {node|int} mRow TR element you want to update or the aoData index
+                *  @param {int} [iColumn] The column to update (not used of mData is an array or object)
+                *  @param {bool} [bRedraw=true] Redraw the table or not
+                *  @param {bool} [bAction=true] Perform pre-draw actions or not
+                *  @returns {int} 0 on success, 1 on error
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      oTable.fnUpdate( 'Example update', 0, 0 ); // Single cell
+                *      oTable.fnUpdate( ['a', 'b', 'c', 'd', 'e'], 1, 0 ); // Row
+                *    } );
+                */
+               this.fnUpdate = function( mData, mRow, iColumn, bRedraw, bAction )
+               {
+                       var oSettings = _fnSettingsFromNode( this[DataTable.ext.iApiIndex] );
+                       var i, iLen, sDisplay;
+                       var iRow = (typeof mRow === 'object') ? 
+                               _fnNodeToDataIndex(oSettings, mRow) : mRow;
+                       
+                       if ( $.isArray(mData) && iColumn === undefined )
+                       {
+                               /* Array update - update the whole row */
+                               oSettings.aoData[iRow]._aData = mData.slice();
+                               
+                               /* Flag to the function that we are recursing */
+                               for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                               {
+                                       this.fnUpdate( _fnGetCellData( oSettings, iRow, i ), iRow, i, false, false );
+                               }
+                       }
+                       else if ( $.isPlainObject(mData) && iColumn === undefined )
+                       {
+                               /* Object update - update the whole row - assume the developer gets the object right */
+                               oSettings.aoData[iRow]._aData = $.extend( true, {}, mData );
+               
+                               for ( i=0 ; i<oSettings.aoColumns.length ; i++ )
+                               {
+                                       this.fnUpdate( _fnGetCellData( oSettings, iRow, i ), iRow, i, false, false );
+                               }
+                       }
+                       else
+                       {
+                               /* Individual cell update */
+                               _fnSetCellData( oSettings, iRow, iColumn, mData );
+                               sDisplay = _fnGetCellData( oSettings, iRow, iColumn, 'display' );
+                               
+                               var oCol = oSettings.aoColumns[iColumn];
+                               if ( oCol.fnRender !== null )
+                               {
+                                       sDisplay = _fnRender( oSettings, iRow, iColumn );
+                                       if ( oCol.bUseRendered )
+                                       {
+                                               _fnSetCellData( oSettings, iRow, iColumn, sDisplay );
+                                       }
+                               }
+                               
+                               if ( oSettings.aoData[iRow].nTr !== null )
+                               {
+                                       /* Do the actual HTML update */
+                                       _fnGetTdNodes( oSettings, iRow )[iColumn].innerHTML = sDisplay;
+                               }
+                       }
+                       
+                       /* Modify the search index for this row (strictly this is likely not needed, since fnReDraw
+                        * will rebuild the search array - however, the redraw might be disabled by the user)
+                        */
+                       var iDisplayIndex = $.inArray( iRow, oSettings.aiDisplay );
+                       oSettings.asDataSearch[iDisplayIndex] = _fnBuildSearchRow(
+                               oSettings, 
+                               _fnGetRowData( oSettings, iRow, 'filter', _fnGetColumns( oSettings, 'bSearchable' ) )
+                       );
+                       
+                       /* Perform pre-draw actions */
+                       if ( bAction === undefined || bAction )
+                       {
+                               _fnAdjustColumnSizing( oSettings );
+                       }
+                       
+                       /* Redraw the table */
+                       if ( bRedraw === undefined || bRedraw )
+                       {
+                               _fnReDraw( oSettings );
+                       }
+                       return 0;
+               };
+               
+               
+               /**
+                * Provide a common method for plug-ins to check the version of DataTables being used, in order
+                * to ensure compatibility.
+                *  @param {string} sVersion Version string to check for, in the format "X.Y.Z". Note that the
+                *    formats "X" and "X.Y" are also acceptable.
+                *  @returns {boolean} true if this version of DataTables is greater or equal to the required
+                *    version, or false if this version of DataTales is not suitable
+                *  @method
+                *  @dtopt API
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      alert( oTable.fnVersionCheck( '1.9.0' ) );
+                *    } );
+                */
+               this.fnVersionCheck = DataTable.ext.fnVersionCheck;
+               
+               
+               /*
+                * This is really a good bit rubbish this method of exposing the internal methods
+                * publicly... - To be fixed in 2.0 using methods on the prototype
+                */
+               
+               
+               /**
+                * Create a wrapper function for exporting an internal functions to an external API.
+                *  @param {string} sFunc API function name
+                *  @returns {function} wrapped function
+                *  @memberof DataTable#oApi
+                */
+               function _fnExternApiFunc (sFunc)
+               {
+                       return function() {
+                               var aArgs = [_fnSettingsFromNode(this[DataTable.ext.iApiIndex])].concat( 
+                                       Array.prototype.slice.call(arguments) );
+                               return DataTable.ext.oApi[sFunc].apply( this, aArgs );
+                       };
+               }
+               
+               
+               /**
+                * Reference to internal functions for use by plug-in developers. Note that these
+                * methods are references to internal functions and are considered to be private.
+                * If you use these methods, be aware that they are liable to change between versions
+                * (check the upgrade notes).
+                *  @namespace
+                */
+               this.oApi = {
+                       "_fnExternApiFunc": _fnExternApiFunc,
+                       "_fnInitialise": _fnInitialise,
+                       "_fnInitComplete": _fnInitComplete,
+                       "_fnLanguageCompat": _fnLanguageCompat,
+                       "_fnAddColumn": _fnAddColumn,
+                       "_fnColumnOptions": _fnColumnOptions,
+                       "_fnAddData": _fnAddData,
+                       "_fnCreateTr": _fnCreateTr,
+                       "_fnGatherData": _fnGatherData,
+                       "_fnBuildHead": _fnBuildHead,
+                       "_fnDrawHead": _fnDrawHead,
+                       "_fnDraw": _fnDraw,
+                       "_fnReDraw": _fnReDraw,
+                       "_fnAjaxUpdate": _fnAjaxUpdate,
+                       "_fnAjaxParameters": _fnAjaxParameters,
+                       "_fnAjaxUpdateDraw": _fnAjaxUpdateDraw,
+                       "_fnServerParams": _fnServerParams,
+                       "_fnAddOptionsHtml": _fnAddOptionsHtml,
+                       "_fnFeatureHtmlTable": _fnFeatureHtmlTable,
+                       "_fnScrollDraw": _fnScrollDraw,
+                       "_fnAdjustColumnSizing": _fnAdjustColumnSizing,
+                       "_fnFeatureHtmlFilter": _fnFeatureHtmlFilter,
+                       "_fnFilterComplete": _fnFilterComplete,
+                       "_fnFilterCustom": _fnFilterCustom,
+                       "_fnFilterColumn": _fnFilterColumn,
+                       "_fnFilter": _fnFilter,
+                       "_fnBuildSearchArray": _fnBuildSearchArray,
+                       "_fnBuildSearchRow": _fnBuildSearchRow,
+                       "_fnFilterCreateSearch": _fnFilterCreateSearch,
+                       "_fnDataToSearch": _fnDataToSearch,
+                       "_fnSort": _fnSort,
+                       "_fnSortAttachListener": _fnSortAttachListener,
+                       "_fnSortingClasses": _fnSortingClasses,
+                       "_fnFeatureHtmlPaginate": _fnFeatureHtmlPaginate,
+                       "_fnPageChange": _fnPageChange,
+                       "_fnFeatureHtmlInfo": _fnFeatureHtmlInfo,
+                       "_fnUpdateInfo": _fnUpdateInfo,
+                       "_fnFeatureHtmlLength": _fnFeatureHtmlLength,
+                       "_fnFeatureHtmlProcessing": _fnFeatureHtmlProcessing,
+                       "_fnProcessingDisplay": _fnProcessingDisplay,
+                       "_fnVisibleToColumnIndex": _fnVisibleToColumnIndex,
+                       "_fnColumnIndexToVisible": _fnColumnIndexToVisible,
+                       "_fnNodeToDataIndex": _fnNodeToDataIndex,
+                       "_fnVisbleColumns": _fnVisbleColumns,
+                       "_fnCalculateEnd": _fnCalculateEnd,
+                       "_fnConvertToWidth": _fnConvertToWidth,
+                       "_fnCalculateColumnWidths": _fnCalculateColumnWidths,
+                       "_fnScrollingWidthAdjust": _fnScrollingWidthAdjust,
+                       "_fnGetWidestNode": _fnGetWidestNode,
+                       "_fnGetMaxLenString": _fnGetMaxLenString,
+                       "_fnStringToCss": _fnStringToCss,
+                       "_fnDetectType": _fnDetectType,
+                       "_fnSettingsFromNode": _fnSettingsFromNode,
+                       "_fnGetDataMaster": _fnGetDataMaster,
+                       "_fnGetTrNodes": _fnGetTrNodes,
+                       "_fnGetTdNodes": _fnGetTdNodes,
+                       "_fnEscapeRegex": _fnEscapeRegex,
+                       "_fnDeleteIndex": _fnDeleteIndex,
+                       "_fnReOrderIndex": _fnReOrderIndex,
+                       "_fnColumnOrdering": _fnColumnOrdering,
+                       "_fnLog": _fnLog,
+                       "_fnClearTable": _fnClearTable,
+                       "_fnSaveState": _fnSaveState,
+                       "_fnLoadState": _fnLoadState,
+                       "_fnCreateCookie": _fnCreateCookie,
+                       "_fnReadCookie": _fnReadCookie,
+                       "_fnDetectHeader": _fnDetectHeader,
+                       "_fnGetUniqueThs": _fnGetUniqueThs,
+                       "_fnScrollBarWidth": _fnScrollBarWidth,
+                       "_fnApplyToChildren": _fnApplyToChildren,
+                       "_fnMap": _fnMap,
+                       "_fnGetRowData": _fnGetRowData,
+                       "_fnGetCellData": _fnGetCellData,
+                       "_fnSetCellData": _fnSetCellData,
+                       "_fnGetObjectDataFn": _fnGetObjectDataFn,
+                       "_fnSetObjectDataFn": _fnSetObjectDataFn,
+                       "_fnApplyColumnDefs": _fnApplyColumnDefs,
+                       "_fnBindAction": _fnBindAction,
+                       "_fnExtend": _fnExtend,
+                       "_fnCallbackReg": _fnCallbackReg,
+                       "_fnCallbackFire": _fnCallbackFire,
+                       "_fnJsonString": _fnJsonString,
+                       "_fnRender": _fnRender,
+                       "_fnNodeToColumnIndex": _fnNodeToColumnIndex,
+                       "_fnInfoMacros": _fnInfoMacros,
+                       "_fnBrowserDetect": _fnBrowserDetect,
+                       "_fnGetColumns": _fnGetColumns
+               };
+               
+               $.extend( DataTable.ext.oApi, this.oApi );
+               
+               for ( var sFunc in DataTable.ext.oApi )
+               {
+                       if ( sFunc )
+                       {
+                               this[sFunc] = _fnExternApiFunc(sFunc);
+                       }
+               }
+               
+               
+               var _that = this;
+               this.each(function() {
+                       var i=0, iLen, j, jLen, k, kLen;
+                       var sId = this.getAttribute( 'id' );
+                       var bInitHandedOff = false;
+                       var bUsePassedData = false;
+                       
+                       
+                       /* Sanity check */
+                       if ( this.nodeName.toLowerCase() != 'table' )
+                       {
+                               _fnLog( null, 0, "Attempted to initialise DataTables on a node which is not a "+
+                                       "table: "+this.nodeName );
+                               return;
+                       }
+                       
+                       /* Check to see if we are re-initialising a table */
+                       for ( i=0, iLen=DataTable.settings.length ; i<iLen ; i++ )
+                       {
+                               /* Base check on table node */
+                               if ( DataTable.settings[i].nTable == this )
+                               {
+                                       if ( oInit === undefined || oInit.bRetrieve )
+                                       {
+                                               return DataTable.settings[i].oInstance;
+                                       }
+                                       else if ( oInit.bDestroy )
+                                       {
+                                               DataTable.settings[i].oInstance.fnDestroy();
+                                               break;
+                                       }
+                                       else
+                                       {
+                                               _fnLog( DataTable.settings[i], 0, "Cannot reinitialise DataTable.\n\n"+
+                                                       "To retrieve the DataTables object for this table, pass no arguments or see "+
+                                                       "the docs for bRetrieve and bDestroy" );
+                                               return;
+                                       }
+                               }
+                               
+                               /* If the element we are initialising has the same ID as a table which was previously
+                                * initialised, but the table nodes don't match (from before) then we destroy the old
+                                * instance by simply deleting it. This is under the assumption that the table has been
+                                * destroyed by other methods. Anyone using non-id selectors will need to do this manually
+                                */
+                               if ( DataTable.settings[i].sTableId == this.id )
+                               {
+                                       DataTable.settings.splice( i, 1 );
+                                       break;
+                               }
+                       }
+                       
+                       /* Ensure the table has an ID - required for accessibility */
+                       if ( sId === null || sId === "" )
+                       {
+                               sId = "DataTables_Table_"+(DataTable.ext._oExternConfig.iNextUnique++);
+                               this.id = sId;
+                       }
+                       
+                       /* Create the settings object for this table and set some of the default parameters */
+                       var oSettings = $.extend( true, {}, DataTable.models.oSettings, {
+                               "nTable":        this,
+                               "oApi":          _that.oApi,
+                               "oInit":         oInit,
+                               "sDestroyWidth": $(this).width(),
+                               "sInstance":     sId,
+                               "sTableId":      sId
+                       } );
+                       DataTable.settings.push( oSettings );
+                       
+                       // Need to add the instance after the instance after the settings object has been added
+                       // to the settings array, so we can self reference the table instance if more than one
+                       oSettings.oInstance = (_that.length===1) ? _that : $(this).dataTable();
+                       
+                       /* Setting up the initialisation object */
+                       if ( !oInit )
+                       {
+                               oInit = {};
+                       }
+                       
+                       // Backwards compatibility, before we apply all the defaults
+                       if ( oInit.oLanguage )
+                       {
+                               _fnLanguageCompat( oInit.oLanguage );
+                       }
+                       
+                       oInit = _fnExtend( $.extend(true, {}, DataTable.defaults), oInit );
+                       
+                       // Map the initialisation options onto the settings object
+                       _fnMap( oSettings.oFeatures, oInit, "bPaginate" );
+                       _fnMap( oSettings.oFeatures, oInit, "bLengthChange" );
+                       _fnMap( oSettings.oFeatures, oInit, "bFilter" );
+                       _fnMap( oSettings.oFeatures, oInit, "bSort" );
+                       _fnMap( oSettings.oFeatures, oInit, "bInfo" );
+                       _fnMap( oSettings.oFeatures, oInit, "bProcessing" );
+                       _fnMap( oSettings.oFeatures, oInit, "bAutoWidth" );
+                       _fnMap( oSettings.oFeatures, oInit, "bSortClasses" );
+                       _fnMap( oSettings.oFeatures, oInit, "bServerSide" );
+                       _fnMap( oSettings.oFeatures, oInit, "bDeferRender" );
+                       _fnMap( oSettings.oScroll, oInit, "sScrollX", "sX" );
+                       _fnMap( oSettings.oScroll, oInit, "sScrollXInner", "sXInner" );
+                       _fnMap( oSettings.oScroll, oInit, "sScrollY", "sY" );
+                       _fnMap( oSettings.oScroll, oInit, "bScrollCollapse", "bCollapse" );
+                       _fnMap( oSettings.oScroll, oInit, "bScrollInfinite", "bInfinite" );
+                       _fnMap( oSettings.oScroll, oInit, "iScrollLoadGap", "iLoadGap" );
+                       _fnMap( oSettings.oScroll, oInit, "bScrollAutoCss", "bAutoCss" );
+                       _fnMap( oSettings, oInit, "asStripeClasses" );
+                       _fnMap( oSettings, oInit, "asStripClasses", "asStripeClasses" ); // legacy
+                       _fnMap( oSettings, oInit, "fnServerData" );
+                       _fnMap( oSettings, oInit, "fnFormatNumber" );
+                       _fnMap( oSettings, oInit, "sServerMethod" );
+                       _fnMap( oSettings, oInit, "aaSorting" );
+                       _fnMap( oSettings, oInit, "aaSortingFixed" );
+                       _fnMap( oSettings, oInit, "aLengthMenu" );
+                       _fnMap( oSettings, oInit, "sPaginationType" );
+                       _fnMap( oSettings, oInit, "sAjaxSource" );
+                       _fnMap( oSettings, oInit, "sAjaxDataProp" );
+                       _fnMap( oSettings, oInit, "iCookieDuration" );
+                       _fnMap( oSettings, oInit, "sCookiePrefix" );
+                       _fnMap( oSettings, oInit, "sDom" );
+                       _fnMap( oSettings, oInit, "bSortCellsTop" );
+                       _fnMap( oSettings, oInit, "iTabIndex" );
+                       _fnMap( oSettings, oInit, "oSearch", "oPreviousSearch" );
+                       _fnMap( oSettings, oInit, "aoSearchCols", "aoPreSearchCols" );
+                       _fnMap( oSettings, oInit, "iDisplayLength", "_iDisplayLength" );
+                       _fnMap( oSettings, oInit, "bJQueryUI", "bJUI" );
+                       _fnMap( oSettings, oInit, "fnCookieCallback" );
+                       _fnMap( oSettings, oInit, "fnStateLoad" );
+                       _fnMap( oSettings, oInit, "fnStateSave" );
+                       _fnMap( oSettings.oLanguage, oInit, "fnInfoCallback" );
+                       
+                       /* Callback functions which are array driven */
+                       _fnCallbackReg( oSettings, 'aoDrawCallback',       oInit.fnDrawCallback,      'user' );
+                       _fnCallbackReg( oSettings, 'aoServerParams',       oInit.fnServerParams,      'user' );
+                       _fnCallbackReg( oSettings, 'aoStateSaveParams',    oInit.fnStateSaveParams,   'user' );
+                       _fnCallbackReg( oSettings, 'aoStateLoadParams',    oInit.fnStateLoadParams,   'user' );
+                       _fnCallbackReg( oSettings, 'aoStateLoaded',        oInit.fnStateLoaded,       'user' );
+                       _fnCallbackReg( oSettings, 'aoRowCallback',        oInit.fnRowCallback,       'user' );
+                       _fnCallbackReg( oSettings, 'aoRowCreatedCallback', oInit.fnCreatedRow,        'user' );
+                       _fnCallbackReg( oSettings, 'aoHeaderCallback',     oInit.fnHeaderCallback,    'user' );
+                       _fnCallbackReg( oSettings, 'aoFooterCallback',     oInit.fnFooterCallback,    'user' );
+                       _fnCallbackReg( oSettings, 'aoInitComplete',       oInit.fnInitComplete,      'user' );
+                       _fnCallbackReg( oSettings, 'aoPreDrawCallback',    oInit.fnPreDrawCallback,   'user' );
+                       
+                       if ( oSettings.oFeatures.bServerSide && oSettings.oFeatures.bSort &&
+                                  oSettings.oFeatures.bSortClasses )
+                       {
+                               /* Enable sort classes for server-side processing. Safe to do it here, since server-side
+                                * processing must be enabled by the developer
+                                */
+                               _fnCallbackReg( oSettings, 'aoDrawCallback', _fnSortingClasses, 'server_side_sort_classes' );
+                       }
+                       else if ( oSettings.oFeatures.bDeferRender )
+                       {
+                               _fnCallbackReg( oSettings, 'aoDrawCallback', _fnSortingClasses, 'defer_sort_classes' );
+                       }
+                       
+                       if ( oInit.bJQueryUI )
+                       {
+                               /* Use the JUI classes object for display. You could clone the oStdClasses object if 
+                                * you want to have multiple tables with multiple independent classes 
+                                */
+                               $.extend( oSettings.oClasses, DataTable.ext.oJUIClasses );
+                               
+                               if ( oInit.sDom === DataTable.defaults.sDom && DataTable.defaults.sDom === "lfrtip" )
+                               {
+                                       /* Set the DOM to use a layout suitable for jQuery UI's theming */
+                                       oSettings.sDom = '<"H"lfr>t<"F"ip>';
+                               }
+                       }
+                       else
+                       {
+                               $.extend( oSettings.oClasses, DataTable.ext.oStdClasses );
+                       }
+                       $(this).addClass( oSettings.oClasses.sTable );
+                       
+                       /* Calculate the scroll bar width and cache it for use later on */
+                       if ( oSettings.oScroll.sX !== "" || oSettings.oScroll.sY !== "" )
+                       {
+                               oSettings.oScroll.iBarWidth = _fnScrollBarWidth();
+                       }
+                       
+                       if ( oSettings.iInitDisplayStart === undefined )
+                       {
+                               /* Display start point, taking into account the save saving */
+                               oSettings.iInitDisplayStart = oInit.iDisplayStart;
+                               oSettings._iDisplayStart = oInit.iDisplayStart;
+                       }
+                       
+                       /* Must be done after everything which can be overridden by a cookie! */
+                       if ( oInit.bStateSave )
+                       {
+                               oSettings.oFeatures.bStateSave = true;
+                               _fnLoadState( oSettings, oInit );
+                               _fnCallbackReg( oSettings, 'aoDrawCallback', _fnSaveState, 'state_save' );
+                       }
+                       
+                       if ( oInit.iDeferLoading !== null )
+                       {
+                               oSettings.bDeferLoading = true;
+                               var tmp = $.isArray( oInit.iDeferLoading );
+                               oSettings._iRecordsDisplay = tmp ? oInit.iDeferLoading[0] : oInit.iDeferLoading;
+                               oSettings._iRecordsTotal = tmp ? oInit.iDeferLoading[1] : oInit.iDeferLoading;
+                       }
+                       
+                       if ( oInit.aaData !== null )
+                       {
+                               bUsePassedData = true;
+                       }
+                       
+                       /* Language definitions */
+                       if ( oInit.oLanguage.sUrl !== "" )
+                       {
+                               /* Get the language definitions from a file - because this Ajax call makes the language
+                                * get async to the remainder of this function we use bInitHandedOff to indicate that 
+                                * _fnInitialise will be fired by the returned Ajax handler, rather than the constructor
+                                */
+                               oSettings.oLanguage.sUrl = oInit.oLanguage.sUrl;
+                               $.getJSON( oSettings.oLanguage.sUrl, null, function( json ) {
+                                       _fnLanguageCompat( json );
+                                       $.extend( true, oSettings.oLanguage, oInit.oLanguage, json );
+                                       _fnInitialise( oSettings );
+                               } );
+                               bInitHandedOff = true;
+                       }
+                       else
+                       {
+                               $.extend( true, oSettings.oLanguage, oInit.oLanguage );
+                       }
+                       
+                       
+                       /*
+                        * Stripes
+                        */
+                       if ( oInit.asStripeClasses === null )
+                       {
+                               oSettings.asStripeClasses =[
+                                       oSettings.oClasses.sStripeOdd,
+                                       oSettings.oClasses.sStripeEven
+                               ];
+                       }
+                       
+                       /* Remove row stripe classes if they are already on the table row */
+                       iLen=oSettings.asStripeClasses.length;
+                       oSettings.asDestroyStripes = [];
+                       if (iLen)
+                       {
+                               var bStripeRemove = false;
+                               var anRows = $(this).children('tbody').children('tr:lt(' + iLen + ')');
+                               for ( i=0 ; i<iLen ; i++ )
+                               {
+                                       if ( anRows.hasClass( oSettings.asStripeClasses[i] ) )
+                                       {
+                                               bStripeRemove = true;
+                                               
+                                               /* Store the classes which we are about to remove so they can be re-added on destroy */
+                                               oSettings.asDestroyStripes.push( oSettings.asStripeClasses[i] );
+                                       }
+                               }
+                               
+                               if ( bStripeRemove )
+                               {
+                                       anRows.removeClass( oSettings.asStripeClasses.join(' ') );
+                               }
+                       }
+                       
+                       /*
+                        * Columns
+                        * See if we should load columns automatically or use defined ones
+                        */
+                       var anThs = [];
+                       var aoColumnsInit;
+                       var nThead = this.getElementsByTagName('thead');
+                       if ( nThead.length !== 0 )
+                       {
+                               _fnDetectHeader( oSettings.aoHeader, nThead[0] );
+                               anThs = _fnGetUniqueThs( oSettings );
+                       }
+                       
+                       /* If not given a column array, generate one with nulls */
+                       if ( oInit.aoColumns === null )
+                       {
+                               aoColumnsInit = [];
+                               for ( i=0, iLen=anThs.length ; i<iLen ; i++ )
+                               {
+                                       aoColumnsInit.push( null );
+                               }
+                       }
+                       else
+                       {
+                               aoColumnsInit = oInit.aoColumns;
+                       }
+                       
+                       /* Add the columns */
+                       for ( i=0, iLen=aoColumnsInit.length ; i<iLen ; i++ )
+                       {
+                               /* Short cut - use the loop to check if we have column visibility state to restore */
+                               if ( oInit.saved_aoColumns !== undefined && oInit.saved_aoColumns.length == iLen )
+                               {
+                                       if ( aoColumnsInit[i] === null )
+                                       {
+                                               aoColumnsInit[i] = {};
+                                       }
+                                       aoColumnsInit[i].bVisible = oInit.saved_aoColumns[i].bVisible;
+                               }
+                               
+                               _fnAddColumn( oSettings, anThs ? anThs[i] : null );
+                       }
+                       
+                       /* Apply the column definitions */
+                       _fnApplyColumnDefs( oSettings, oInit.aoColumnDefs, aoColumnsInit, function (iCol, oDef) {
+                               _fnColumnOptions( oSettings, iCol, oDef );
+                       } );
+                       
+                       
+                       /*
+                        * Sorting
+                        * Check the aaSorting array
+                        */
+                       for ( i=0, iLen=oSettings.aaSorting.length ; i<iLen ; i++ )
+                       {
+                               if ( oSettings.aaSorting[i][0] >= oSettings.aoColumns.length )
+                               {
+                                       oSettings.aaSorting[i][0] = 0;
+                               }
+                               var oColumn = oSettings.aoColumns[ oSettings.aaSorting[i][0] ];
+                               
+                               /* Add a default sorting index */
+                               if ( oSettings.aaSorting[i][2] === undefined )
+                               {
+                                       oSettings.aaSorting[i][2] = 0;
+                               }
+                               
+                               /* If aaSorting is not defined, then we use the first indicator in asSorting */
+                               if ( oInit.aaSorting === undefined && oSettings.saved_aaSorting === undefined )
+                               {
+                                       oSettings.aaSorting[i][1] = oColumn.asSorting[0];
+                               }
+                               
+                               /* Set the current sorting index based on aoColumns.asSorting */
+                               for ( j=0, jLen=oColumn.asSorting.length ; j<jLen ; j++ )
+                               {
+                                       if ( oSettings.aaSorting[i][1] == oColumn.asSorting[j] )
+                                       {
+                                               oSettings.aaSorting[i][2] = j;
+                                               break;
+                                       }
+                               }
+                       }
+                               
+                       /* Do a first pass on the sorting classes (allows any size changes to be taken into
+                        * account, and also will apply sorting disabled classes if disabled
+                        */
+                       _fnSortingClasses( oSettings );
+                       
+                       
+                       /*
+                        * Final init
+                        * Cache the header, body and footer as required, creating them if needed
+                        */
+                       
+                       /* Browser support detection */
+                       _fnBrowserDetect( oSettings );
+                       
+                       // Work around for Webkit bug 83867 - store the caption-side before removing from doc
+                       var captions = $(this).children('caption').each( function () {
+                               this._captionSide = $(this).css('caption-side');
+                       } );
+                       
+                       var thead = $(this).children('thead');
+                       if ( thead.length === 0 )
+                       {
+                               thead = [ document.createElement( 'thead' ) ];
+                               this.appendChild( thead[0] );
+                       }
+                       oSettings.nTHead = thead[0];
+                       
+                       var tbody = $(this).children('tbody');
+                       if ( tbody.length === 0 )
+                       {
+                               tbody = [ document.createElement( 'tbody' ) ];
+                               this.appendChild( tbody[0] );
+                       }
+                       oSettings.nTBody = tbody[0];
+                       oSettings.nTBody.setAttribute( "role", "alert" );
+                       oSettings.nTBody.setAttribute( "aria-live", "polite" );
+                       oSettings.nTBody.setAttribute( "aria-relevant", "all" );
+                       
+                       var tfoot = $(this).children('tfoot');
+                       if ( tfoot.length === 0 && captions.length > 0 && (oSettings.oScroll.sX !== "" || oSettings.oScroll.sY !== "") )
+                       {
+                               // If we are a scrolling table, and no footer has been given, then we need to create
+                               // a tfoot element for the caption element to be appended to
+                               tfoot = [ document.createElement( 'tfoot' ) ];
+                               this.appendChild( tfoot[0] );
+                       }
+                       
+                       if ( tfoot.length > 0 )
+                       {
+                               oSettings.nTFoot = tfoot[0];
+                               _fnDetectHeader( oSettings.aoFooter, oSettings.nTFoot );
+                       }
+                       
+                       /* Check if there is data passing into the constructor */
+                       if ( bUsePassedData )
+                       {
+                               for ( i=0 ; i<oInit.aaData.length ; i++ )
+                               {
+                                       _fnAddData( oSettings, oInit.aaData[ i ] );
+                               }
+                       }
+                       else
+                       {
+                               /* Grab the data from the page */
+                               _fnGatherData( oSettings );
+                       }
+                       
+                       /* Copy the data index array */
+                       oSettings.aiDisplay = oSettings.aiDisplayMaster.slice();
+                       
+                       /* Initialisation complete - table can be drawn */
+                       oSettings.bInitialised = true;
+                       
+                       /* Check if we need to initialise the table (it might not have been handed off to the
+                        * language processor)
+                        */
+                       if ( bInitHandedOff === false )
+                       {
+                               _fnInitialise( oSettings );
+                       }
+               } );
+               _that = null;
+               return this;
+       };
+
+       
+       
+       /**
+        * Provide a common method for plug-ins to check the version of DataTables being used, in order
+        * to ensure compatibility.
+        *  @param {string} sVersion Version string to check for, in the format "X.Y.Z". Note that the
+        *    formats "X" and "X.Y" are also acceptable.
+        *  @returns {boolean} true if this version of DataTables is greater or equal to the required
+        *    version, or false if this version of DataTales is not suitable
+        *  @static
+        *  @dtopt API-Static
+        *
+        *  @example
+        *    alert( $.fn.dataTable.fnVersionCheck( '1.9.0' ) );
+        */
+       DataTable.fnVersionCheck = function( sVersion )
+       {
+               /* This is cheap, but effective */
+               var fnZPad = function (Zpad, count)
+               {
+                       while(Zpad.length < count) {
+                               Zpad += '0';
+                       }
+                       return Zpad;
+               };
+               var aThis = DataTable.ext.sVersion.split('.');
+               var aThat = sVersion.split('.');
+               var sThis = '', sThat = '';
+               
+               for ( var i=0, iLen=aThat.length ; i<iLen ; i++ )
+               {
+                       sThis += fnZPad( aThis[i], 3 );
+                       sThat += fnZPad( aThat[i], 3 );
+               }
+               
+               return parseInt(sThis, 10) >= parseInt(sThat, 10);
+       };
+       
+       
+       /**
+        * Check if a TABLE node is a DataTable table already or not.
+        *  @param {node} nTable The TABLE node to check if it is a DataTable or not (note that other
+        *    node types can be passed in, but will always return false).
+        *  @returns {boolean} true the table given is a DataTable, or false otherwise
+        *  @static
+        *  @dtopt API-Static
+        *
+        *  @example
+        *    var ex = document.getElementById('example');
+        *    if ( ! $.fn.DataTable.fnIsDataTable( ex ) ) {
+        *      $(ex).dataTable();
+        *    }
+        */
+       DataTable.fnIsDataTable = function ( nTable )
+       {
+               var o = DataTable.settings;
+       
+               for ( var i=0 ; i<o.length ; i++ )
+               {
+                       if ( o[i].nTable === nTable || o[i].nScrollHead === nTable || o[i].nScrollFoot === nTable )
+                       {
+                               return true;
+                       }
+               }
+       
+               return false;
+       };
+       
+       
+       /**
+        * Get all DataTable tables that have been initialised - optionally you can select to
+        * get only currently visible tables.
+        *  @param {boolean} [bVisible=false] Flag to indicate if you want all (default) or 
+        *    visible tables only.
+        *  @returns {array} Array of TABLE nodes (not DataTable instances) which are DataTables
+        *  @static
+        *  @dtopt API-Static
+        *
+        *  @example
+        *    var table = $.fn.dataTable.fnTables(true);
+        *    if ( table.length > 0 ) {
+        *      $(table).dataTable().fnAdjustColumnSizing();
+        *    }
+        */
+       DataTable.fnTables = function ( bVisible )
+       {
+               var out = [];
+       
+               jQuery.each( DataTable.settings, function (i, o) {
+                       if ( !bVisible || (bVisible === true && $(o.nTable).is(':visible')) )
+                       {
+                               out.push( o.nTable );
+                       }
+               } );
+       
+               return out;
+       };
+       
+
+       /**
+        * Version string for plug-ins to check compatibility. Allowed format is
+        * a.b.c.d.e where: a:int, b:int, c:int, d:string(dev|beta), e:int. d and
+        * e are optional
+        *  @member
+        *  @type string
+        *  @default Version number
+        */
+       DataTable.version = "1.9.4";
+
+       /**
+        * Private data store, containing all of the settings objects that are created for the
+        * tables on a given page.
+        * 
+        * Note that the <i>DataTable.settings</i> object is aliased to <i>jQuery.fn.dataTableExt</i> 
+        * through which it may be accessed and manipulated, or <i>jQuery.fn.dataTable.settings</i>.
+        *  @member
+        *  @type array
+        *  @default []
+        *  @private
+        */
+       DataTable.settings = [];
+
+       /**
+        * Object models container, for the various models that DataTables has available
+        * to it. These models define the objects that are used to hold the active state 
+        * and configuration of the table.
+        *  @namespace
+        */
+       DataTable.models = {};
+       
+       
+       /**
+        * DataTables extension options and plug-ins. This namespace acts as a collection "area"
+        * for plug-ins that can be used to extend the default DataTables behaviour - indeed many
+        * of the build in methods use this method to provide their own capabilities (sorting methods
+        * for example).
+        * 
+        * Note that this namespace is aliased to jQuery.fn.dataTableExt so it can be readily accessed
+        * and modified by plug-ins.
+        *  @namespace
+        */
+       DataTable.models.ext = {
+               /**
+                * Plug-in filtering functions - this method of filtering is complimentary to the default
+                * type based filtering, and a lot more comprehensive as it allows you complete control
+                * over the filtering logic. Each element in this array is a function (parameters
+                * described below) that is called for every row in the table, and your logic decides if
+                * it should be included in the filtered data set or not.
+                *   <ul>
+                *     <li>
+                *       Function input parameters:
+                *       <ul>
+                *         <li>{object} DataTables settings object: see {@link DataTable.models.oSettings}.</li>
+                *         <li>{array|object} Data for the row to be processed (same as the original format
+                *           that was passed in as the data source, or an array from a DOM data source</li>
+                *         <li>{int} Row index in aoData ({@link DataTable.models.oSettings.aoData}), which can
+                *           be useful to retrieve the TR element if you need DOM interaction.</li>
+                *       </ul>
+                *     </li>
+                *     <li>
+                *       Function return:
+                *       <ul>
+                *         <li>{boolean} Include the row in the filtered result set (true) or not (false)</li>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                *  @type array
+                *  @default []
+                *
+                *  @example
+                *    // The following example shows custom filtering being applied to the fourth column (i.e.
+                *    // the aData[3] index) based on two input values from the end-user, matching the data in 
+                *    // a certain range.
+                *    $.fn.dataTableExt.afnFiltering.push(
+                *      function( oSettings, aData, iDataIndex ) {
+                *        var iMin = document.getElementById('min').value * 1;
+                *        var iMax = document.getElementById('max').value * 1;
+                *        var iVersion = aData[3] == "-" ? 0 : aData[3]*1;
+                *        if ( iMin == "" && iMax == "" ) {
+                *          return true;
+                *        }
+                *        else if ( iMin == "" && iVersion < iMax ) {
+                *          return true;
+                *        }
+                *        else if ( iMin < iVersion && "" == iMax ) {
+                *          return true;
+                *        }
+                *        else if ( iMin < iVersion && iVersion < iMax ) {
+                *          return true;
+                *        }
+                *        return false;
+                *      }
+                *    );
+                */
+               "afnFiltering": [],
+       
+       
+               /**
+                * Plug-in sorting functions - this method of sorting is complimentary to the default type
+                * based sorting that DataTables does automatically, allowing much greater control over the
+                * the data that is being used to sort a column. This is useful if you want to do sorting
+                * based on live data (for example the contents of an 'input' element) rather than just the
+                * static string that DataTables knows of. The way these plug-ins work is that you create
+                * an array of the values you wish to be sorted for the column in question and then return
+                * that array. Which pre-sorting function is run here depends on the sSortDataType parameter
+                * that is used for the column (if any). This is the corollary of <i>ofnSearch</i> for sort 
+                * data.
+                *   <ul>
+            *     <li>
+            *       Function input parameters:
+            *       <ul>
+                *         <li>{object} DataTables settings object: see {@link DataTable.models.oSettings}.</li>
+            *         <li>{int} Target column index</li>
+            *       </ul>
+            *     </li>
+                *     <li>
+                *       Function return:
+                *       <ul>
+                *         <li>{array} Data for the column to be sorted upon</li>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                *  
+                * Note that as of v1.9, it is typically preferable to use <i>mData</i> to prepare data for
+                * the different uses that DataTables can put the data to. Specifically <i>mData</i> when
+                * used as a function will give you a 'type' (sorting, filtering etc) that you can use to 
+                * prepare the data as required for the different types. As such, this method is deprecated.
+                *  @type array
+                *  @default []
+                *  @deprecated
+                *
+                *  @example
+                *    // Updating the cached sorting information with user entered values in HTML input elements
+                *    jQuery.fn.dataTableExt.afnSortData['dom-text'] = function ( oSettings, iColumn )
+                *    {
+                *      var aData = [];
+                *      $( 'td:eq('+iColumn+') input', oSettings.oApi._fnGetTrNodes(oSettings) ).each( function () {
+                *        aData.push( this.value );
+                *      } );
+                *      return aData;
+                *    }
+                */
+               "afnSortData": [],
+       
+       
+               /**
+                * Feature plug-ins - This is an array of objects which describe the feature plug-ins that are
+                * available to DataTables. These feature plug-ins are accessible through the sDom initialisation
+                * option. As such, each feature plug-in must describe a function that is used to initialise
+                * itself (fnInit), a character so the feature can be enabled by sDom (cFeature) and the name
+                * of the feature (sFeature). Thus the objects attached to this method must provide:
+                *   <ul>
+                *     <li>{function} fnInit Initialisation of the plug-in
+                *       <ul>
+            *         <li>
+            *           Function input parameters:
+            *           <ul>
+                *             <li>{object} DataTables settings object: see {@link DataTable.models.oSettings}.</li>
+            *           </ul>
+            *         </li>
+                *         <li>
+                *           Function return:
+                *           <ul>
+                *             <li>{node|null} The element which contains your feature. Note that the return
+                *                may also be void if your plug-in does not require to inject any DOM elements 
+                *                into DataTables control (sDom) - for example this might be useful when 
+                *                developing a plug-in which allows table control via keyboard entry.</li>
+                *           </ul>
+                *         </il>
+                *       </ul>
+                *     </li>
+                *     <li>{character} cFeature Character that will be matched in sDom - case sensitive</li>
+                *     <li>{string} sFeature Feature name</li>
+                *   </ul>
+                *  @type array
+                *  @default []
+                * 
+                *  @example
+                *    // How TableTools initialises itself.
+                *    $.fn.dataTableExt.aoFeatures.push( {
+                *      "fnInit": function( oSettings ) {
+                *        return new TableTools( { "oDTSettings": oSettings } );
+                *      },
+                *      "cFeature": "T",
+                *      "sFeature": "TableTools"
+                *    } );
+                */
+               "aoFeatures": [],
+       
+       
+               /**
+                * Type detection plug-in functions - DataTables utilises types to define how sorting and
+                * filtering behave, and types can be either  be defined by the developer (sType for the
+                * column) or they can be automatically detected by the methods in this array. The functions
+                * defined in the array are quite simple, taking a single parameter (the data to analyse) 
+                * and returning the type if it is a known type, or null otherwise.
+                *   <ul>
+            *     <li>
+            *       Function input parameters:
+            *       <ul>
+                *         <li>{*} Data from the column cell to be analysed</li>
+            *       </ul>
+            *     </li>
+                *     <li>
+                *       Function return:
+                *       <ul>
+                *         <li>{string|null} Data type detected, or null if unknown (and thus pass it
+                *           on to the other type detection functions.</li>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                *  @type array
+                *  @default []
+                *  
+                *  @example
+                *    // Currency type detection plug-in:
+                *    jQuery.fn.dataTableExt.aTypes.push(
+                *      function ( sData ) {
+                *        var sValidChars = "0123456789.-";
+                *        var Char;
+                *        
+                *        // Check the numeric part
+                *        for ( i=1 ; i<sData.length ; i++ ) {
+                *          Char = sData.charAt(i); 
+                *          if (sValidChars.indexOf(Char) == -1) {
+                *            return null;
+                *          }
+                *        }
+                *        
+                *        // Check prefixed by currency
+                *        if ( sData.charAt(0) == '$' || sData.charAt(0) == '&pound;' ) {
+                *          return 'currency';
+                *        }
+                *        return null;
+                *      }
+                *    );
+                */
+               "aTypes": [],
+       
+       
+               /**
+                * Provide a common method for plug-ins to check the version of DataTables being used, 
+                * in order to ensure compatibility.
+                *  @type function
+                *  @param {string} sVersion Version string to check for, in the format "X.Y.Z". Note 
+                *    that the formats "X" and "X.Y" are also acceptable.
+                *  @returns {boolean} true if this version of DataTables is greater or equal to the 
+                *    required version, or false if this version of DataTales is not suitable
+                *
+                *  @example
+                *    $(document).ready(function() {
+                *      var oTable = $('#example').dataTable();
+                *      alert( oTable.fnVersionCheck( '1.9.0' ) );
+                *    } );
+                */
+               "fnVersionCheck": DataTable.fnVersionCheck,
+       
+       
+               /**
+                * Index for what 'this' index API functions should use
+                *  @type int
+                *  @default 0
+                */
+               "iApiIndex": 0,
+       
+       
+               /**
+                * Pre-processing of filtering data plug-ins - When you assign the sType for a column
+                * (or have it automatically detected for you by DataTables or a type detection plug-in), 
+                * you will typically be using this for custom sorting, but it can also be used to provide 
+                * custom filtering by allowing you to pre-processing the data and returning the data in
+                * the format that should be filtered upon. This is done by adding functions this object 
+                * with a parameter name which matches the sType for that target column. This is the
+                * corollary of <i>afnSortData</i> for filtering data.
+                *   <ul>
+            *     <li>
+            *       Function input parameters:
+            *       <ul>
+                *         <li>{*} Data from the column cell to be prepared for filtering</li>
+            *       </ul>
+            *     </li>
+                *     <li>
+                *       Function return:
+                *       <ul>
+                *         <li>{string|null} Formatted string that will be used for the filtering.</li>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                * 
+                * Note that as of v1.9, it is typically preferable to use <i>mData</i> to prepare data for
+                * the different uses that DataTables can put the data to. Specifically <i>mData</i> when
+                * used as a function will give you a 'type' (sorting, filtering etc) that you can use to 
+                * prepare the data as required for the different types. As such, this method is deprecated.
+                *  @type object
+                *  @default {}
+                *  @deprecated
+                *
+                *  @example
+                *    $.fn.dataTableExt.ofnSearch['title-numeric'] = function ( sData ) {
+                *      return sData.replace(/\n/g," ").replace( /<.*?>/g, "" );
+                *    }
+                */
+               "ofnSearch": {},
+       
+       
+               /**
+                * Container for all private functions in DataTables so they can be exposed externally
+                *  @type object
+                *  @default {}
+                */
+               "oApi": {},
+       
+       
+               /**
+                * Storage for the various classes that DataTables uses
+                *  @type object
+                *  @default {}
+                */
+               "oStdClasses": {},
+               
+       
+               /**
+                * Storage for the various classes that DataTables uses - jQuery UI suitable
+                *  @type object
+                *  @default {}
+                */
+               "oJUIClasses": {},
+       
+       
+               /**
+                * Pagination plug-in methods - The style and controls of the pagination can significantly 
+                * impact on how the end user interacts with the data in your table, and DataTables allows 
+                * the addition of pagination controls by extending this object, which can then be enabled
+                * through the <i>sPaginationType</i> initialisation parameter. Each pagination type that
+                * is added is an object (the property name of which is what <i>sPaginationType</i> refers
+                * to) that has two properties, both methods that are used by DataTables to update the
+                * control's state.
+                *   <ul>
+                *     <li>
+                *       fnInit -  Initialisation of the paging controls. Called only during initialisation 
+                *         of the table. It is expected that this function will add the required DOM elements 
+                *         to the page for the paging controls to work. The element pointer 
+                *         'oSettings.aanFeatures.p' array is provided by DataTables to contain the paging 
+                *         controls (note that this is a 2D array to allow for multiple instances of each 
+                *         DataTables DOM element). It is suggested that you add the controls to this element 
+                *         as children
+                *       <ul>
+            *         <li>
+            *           Function input parameters:
+            *           <ul>
+                *             <li>{object} DataTables settings object: see {@link DataTable.models.oSettings}.</li>
+                *             <li>{node} Container into which the pagination controls must be inserted</li>
+                *             <li>{function} Draw callback function - whenever the controls cause a page
+                *               change, this method must be called to redraw the table.</li>
+            *           </ul>
+            *         </li>
+                *         <li>
+                *           Function return:
+                *           <ul>
+                *             <li>No return required</li>
+                *           </ul>
+                *         </il>
+                *       </ul>
+                *     </il>
+                *     <li>
+                *       fnInit -  This function is called whenever the paging status of the table changes and is
+                *         typically used to update classes and/or text of the paging controls to reflex the new 
+                *         status.
+                *       <ul>
+            *         <li>
+            *           Function input parameters:
+            *           <ul>
+                *             <li>{object} DataTables settings object: see {@link DataTable.models.oSettings}.</li>
+                *             <li>{function} Draw callback function - in case you need to redraw the table again
+                *               or attach new event listeners</li>
+            *           </ul>
+            *         </li>
+                *         <li>
+                *           Function return:
+                *           <ul>
+                *             <li>No return required</li>
+                *           </ul>
+                *         </il>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                *  @type object
+                *  @default {}
+                *
+                *  @example
+                *    $.fn.dataTableExt.oPagination.four_button = {
+                *      "fnInit": function ( oSettings, nPaging, fnCallbackDraw ) {
+                *        nFirst = document.createElement( 'span' );
+                *        nPrevious = document.createElement( 'span' );
+                *        nNext = document.createElement( 'span' );
+                *        nLast = document.createElement( 'span' );
+                *        
+                *        nFirst.appendChild( document.createTextNode( oSettings.oLanguage.oPaginate.sFirst ) );
+                *        nPrevious.appendChild( document.createTextNode( oSettings.oLanguage.oPaginate.sPrevious ) );
+                *        nNext.appendChild( document.createTextNode( oSettings.oLanguage.oPaginate.sNext ) );
+                *        nLast.appendChild( document.createTextNode( oSettings.oLanguage.oPaginate.sLast ) );
+                *        
+                *        nFirst.className = "paginate_button first";
+                *        nPrevious.className = "paginate_button previous";
+                *        nNext.className="paginate_button next";
+                *        nLast.className = "paginate_button last";
+                *        
+                *        nPaging.appendChild( nFirst );
+                *        nPaging.appendChild( nPrevious );
+                *        nPaging.appendChild( nNext );
+                *        nPaging.appendChild( nLast );
+                *        
+                *        $(nFirst).click( function () {
+                *          oSettings.oApi._fnPageChange( oSettings, "first" );
+                *          fnCallbackDraw( oSettings );
+                *        } );
+                *        
+                *        $(nPrevious).click( function() {
+                *          oSettings.oApi._fnPageChange( oSettings, "previous" );
+                *          fnCallbackDraw( oSettings );
+                *        } );
+                *        
+                *        $(nNext).click( function() {
+                *          oSettings.oApi._fnPageChange( oSettings, "next" );
+                *          fnCallbackDraw( oSettings );
+                *        } );
+                *        
+                *        $(nLast).click( function() {
+                *          oSettings.oApi._fnPageChange( oSettings, "last" );
+                *          fnCallbackDraw( oSettings );
+                *        } );
+                *        
+                *        $(nFirst).bind( 'selectstart', function () { return false; } );
+                *        $(nPrevious).bind( 'selectstart', function () { return false; } );
+                *        $(nNext).bind( 'selectstart', function () { return false; } );
+                *        $(nLast).bind( 'selectstart', function () { return false; } );
+                *      },
+                *      
+                *      "fnUpdate": function ( oSettings, fnCallbackDraw ) {
+                *        if ( !oSettings.aanFeatures.p ) {
+                *          return;
+                *        }
+                *        
+                *        // Loop over each instance of the pager
+                *        var an = oSettings.aanFeatures.p;
+                *        for ( var i=0, iLen=an.length ; i<iLen ; i++ ) {
+                *          var buttons = an[i].getElementsByTagName('span');
+                *          if ( oSettings._iDisplayStart === 0 ) {
+                *            buttons[0].className = "paginate_disabled_previous";
+                *            buttons[1].className = "paginate_disabled_previous";
+                *          }
+                *          else {
+                *            buttons[0].className = "paginate_enabled_previous";
+                *            buttons[1].className = "paginate_enabled_previous";
+                *          }
+                *          
+                *          if ( oSettings.fnDisplayEnd() == oSettings.fnRecordsDisplay() ) {
+                *            buttons[2].className = "paginate_disabled_next";
+                *            buttons[3].className = "paginate_disabled_next";
+                *          }
+                *          else {
+                *            buttons[2].className = "paginate_enabled_next";
+                *            buttons[3].className = "paginate_enabled_next";
+                *          }
+                *        }
+                *      }
+                *    };
+                */
+               "oPagination": {},
+       
+       
+               /**
+                * Sorting plug-in methods - Sorting in DataTables is based on the detected type of the
+                * data column (you can add your own type detection functions, or override automatic 
+                * detection using sType). With this specific type given to the column, DataTables will 
+                * apply the required sort from the functions in the object. Each sort type must provide
+                * two mandatory methods, one each for ascending and descending sorting, and can optionally
+                * provide a pre-formatting method that will help speed up sorting by allowing DataTables
+                * to pre-format the sort data only once (rather than every time the actual sort functions
+                * are run). The two sorting functions are typical Javascript sort methods:
+                *   <ul>
+            *     <li>
+            *       Function input parameters:
+            *       <ul>
+                *         <li>{*} Data to compare to the second parameter</li>
+                *         <li>{*} Data to compare to the first parameter</li>
+            *       </ul>
+            *     </li>
+                *     <li>
+                *       Function return:
+                *       <ul>
+                *         <li>{int} Sorting match: <0 if first parameter should be sorted lower than
+                *           the second parameter, ===0 if the two parameters are equal and >0 if
+                *           the first parameter should be sorted height than the second parameter.</li>
+                *       </ul>
+                *     </il>
+                *   </ul>
+                *  @type object
+                *  @default {}
+                *
+                *  @example
+                *    // Case-sensitive string sorting, with no pre-formatting method
+                *    $.extend( $.fn.dataTableExt.oSort, {
+                *      "string-case-asc": function(x,y) {
+                *        return ((x < y) ? -1 : ((x > y) ? 1 : 0));
+                *      },
+                *      "string-case-desc": function(x,y) {
+                *        return ((x < y) ? 1 : ((x > y) ? -1 : 0));
+                *      }
+                *    } );
+                *
+                *  @example
+                *    // Case-insensitive string sorting, with pre-formatting
+                *    $.extend( $.fn.dataTableExt.oSort, {
+                *      "string-pre": function(x) {
+                *        return x.toLowerCase();
+                *      },
+                *      "string-asc": function(x,y) {
+                *        return ((x < y) ? -1 : ((x > y) ? 1 : 0));
+                *      },
+                *      "string-desc": function(x,y) {
+                *        return ((x < y) ? 1 : ((x > y) ? -1 : 0));
+                *      }
+                *    } );
+                */
+               "oSort": {},
+       
+       
+               /**
+                * Version string for plug-ins to check compatibility. Allowed format is
+                * a.b.c.d.e where: a:int, b:int, c:int, d:string(dev|beta), e:int. d and
+                * e are optional
+                *  @type string
+                *  @default Version number
+                */
+               "sVersion": DataTable.version,
+       
+       
+               /**
+                * How should DataTables report an error. Can take the value 'alert' or 'throw'
+                *  @type string
+                *  @default alert
+                */
+               "sErrMode": "alert",
+       
+       
+               /**
+                * Store information for DataTables to access globally about other instances
+                *  @namespace
+                *  @private
+                */
+               "_oExternConfig": {
+                       /* int:iNextUnique - next unique number for an instance */
+                       "iNextUnique": 0
+               }
+       };
+       
+       
+       
+       
+       /**
+        * Template object for the way in which DataTables holds information about
+        * search information for the global filter and individual column filters.
+        *  @namespace
+        */
+       DataTable.models.oSearch = {
+               /**
+                * Flag to indicate if the filtering should be case insensitive or not
+                *  @type boolean
+                *  @default true
+                */
+               "bCaseInsensitive": true,
+       
+               /**
+                * Applied search term
+                *  @type string
+                *  @default <i>Empty string</i>
+                */
+               "sSearch": "",
+       
+               /**
+                * Flag to indicate if the search term should be interpreted as a
+                * regular expression (true) or not (false) and therefore and special
+                * regex characters escaped.
+                *  @type boolean
+                *  @default false
+                */
+               "bRegex": false,
+       
+               /**
+                * Flag to indicate if DataTables is to use its smart filtering or not.
+                *  @type boolean
+                *  @default true
+                */
+               "bSmart": true
+       };
+       
+       
+       
+       
+       /**
+        * Template object for the way in which DataTables holds information about
+        * each individual row. This is the object format used for the settings 
+        * aoData array.
+        *  @namespace
+        */
+       DataTable.models.oRow = {
+               /**
+                * TR element for the row
+                *  @type node
+                *  @default null
+                */
+               "nTr": null,
+       
+               /**
+                * Data object from the original data source for the row. This is either
+                * an array if using the traditional form of DataTables, or an object if
+                * using mData options. The exact type will depend on the passed in
+                * data from the data source, or will be an array if using DOM a data 
+                * source.
+                *  @type array|object
+                *  @default []
+                */
+               "_aData": [],
+       
+               /**
+                * Sorting data cache - this array is ostensibly the same length as the
+                * number of columns (although each index is generated only as it is 
+                * needed), and holds the data that is used for sorting each column in the
+                * row. We do this cache generation at the start of the sort in order that
+                * the formatting of the sort data need be done only once for each cell
+                * per sort. This array should not be read from or written to by anything
+                * other than the master sorting methods.
+                *  @type array
+                *  @default []
+                *  @private
+                */
+               "_aSortData": [],
+       
+               /**
+                * Array of TD elements that are cached for hidden rows, so they can be
+                * reinserted into the table if a column is made visible again (or to act
+                * as a store if a column is made hidden). Only hidden columns have a 
+                * reference in the array. For non-hidden columns the value is either
+                * undefined or null.
+                *  @type array nodes
+                *  @default []
+                *  @private
+                */
+               "_anHidden": [],
+       
+               /**
+                * Cache of the class name that DataTables has applied to the row, so we
+                * can quickly look at this variable rather than needing to do a DOM check
+                * on className for the nTr property.
+                *  @type string
+                *  @default <i>Empty string</i>
+                *  @private
+                */
+               "_sRowStripe": ""
+       };
+       
+       
+       
+       /**
+        * Template object for the column information object in DataTables. This object
+        * is held in the settings aoColumns array and contains all the information that
+        * DataTables needs about each individual column.
+        * 
+        * Note that this object is related to {@link DataTable.defaults.columns} 
+        * but this one is the internal data store for DataTables's cache of columns.
+        * It should NOT be manipulated outside of DataTables. Any configuration should
+        * be done through the initialisation options.
+        *  @namespace
+        */
+       DataTable.models.oColumn = {
+               /**
+                * A list of the columns that sorting should occur on when this column
+                * is sorted. That this property is an array allows multi-column sorting
+                * to be defined for a column (for example first name / last name columns
+                * would benefit from this). The values are integers pointing to the
+                * columns to be sorted on (typically it will be a single integer pointing
+                * at itself, but that doesn't need to be the case).
+                *  @type array
+                */
+               "aDataSort": null,
+       
+               /**
+                * Define the sorting directions that are applied to the column, in sequence
+                * as the column is repeatedly sorted upon - i.e. the first value is used
+                * as the sorting direction when the column if first sorted (clicked on).
+                * Sort it again (click again) and it will move on to the next index.
+                * Repeat until loop.
+                *  @type array
+                */
+               "asSorting": null,
+               
+               /**
+                * Flag to indicate if the column is searchable, and thus should be included
+                * in the filtering or not.
+                *  @type boolean
+                */
+               "bSearchable": null,
+               
+               /**
+                * Flag to indicate if the column is sortable or not.
+                *  @type boolean
+                */
+               "bSortable": null,
+               
+               /**
+                * <code>Deprecated</code> When using fnRender, you have two options for what 
+                * to do with the data, and this property serves as the switch. Firstly, you 
+                * can have the sorting and filtering use the rendered value (true - default), 
+                * or you can have the sorting and filtering us the original value (false).
+                *
+                * Please note that this option has now been deprecated and will be removed
+                * in the next version of DataTables. Please use mRender / mData rather than
+                * fnRender.
+                *  @type boolean
+                *  @deprecated
+                */
+               "bUseRendered": null,
+               
+               /**
+                * Flag to indicate if the column is currently visible in the table or not
+                *  @type boolean
+                */
+               "bVisible": null,
+               
+               /**
+                * Flag to indicate to the type detection method if the automatic type
+                * detection should be used, or if a column type (sType) has been specified
+                *  @type boolean
+                *  @default true
+                *  @private
+                */
+               "_bAutoType": true,
+               
+               /**
+                * Developer definable function that is called whenever a cell is created (Ajax source,
+                * etc) or processed for input (DOM source). This can be used as a compliment to mRender
+                * allowing you to modify the DOM element (add background colour for example) when the
+                * element is available.
+                *  @type function
+                *  @param {element} nTd The TD node that has been created
+                *  @param {*} sData The Data for the cell
+                *  @param {array|object} oData The data for the whole row
+                *  @param {int} iRow The row index for the aoData data store
+                *  @default null
+                */
+               "fnCreatedCell": null,
+               
+               /**
+                * Function to get data from a cell in a column. You should <b>never</b>
+                * access data directly through _aData internally in DataTables - always use
+                * the method attached to this property. It allows mData to function as
+                * required. This function is automatically assigned by the column 
+                * initialisation method
+                *  @type function
+                *  @param {array|object} oData The data array/object for the array 
+                *    (i.e. aoData[]._aData)
+                *  @param {string} sSpecific The specific data type you want to get - 
+                *    'display', 'type' 'filter' 'sort'
+                *  @returns {*} The data for the cell from the given row's data
+                *  @default null
+                */
+               "fnGetData": null,
+               
+               /**
+                * <code>Deprecated</code> Custom display function that will be called for the 
+                * display of each cell in this column.
+                *
+                * Please note that this option has now been deprecated and will be removed
+                * in the next version of DataTables. Please use mRender / mData rather than
+                * fnRender.
+                *  @type function
+                *  @param {object} o Object with the following parameters:
+                *  @param {int}    o.iDataRow The row in aoData
+                *  @param {int}    o.iDataColumn The column in question
+                *  @param {array}  o.aData The data for the row in question
+                *  @param {object} o.oSettings The settings object for this DataTables instance
+                *  @returns {string} The string you which to use in the display
+                *  @default null
+                *  @deprecated
+                */
+               "fnRender": null,
+               
+               /**
+                * Function to set data for a cell in the column. You should <b>never</b> 
+                * set the data directly to _aData internally in DataTables - always use
+                * this method. It allows mData to function as required. This function
+                * is automatically assigned by the column initialisation method
+                *  @type function
+                *  @param {array|object} oData The data array/object for the array 
+                *    (i.e. aoData[]._aData)
+                *  @param {*} sValue Value to set
+                *  @default null
+                */
+               "fnSetData": null,
+               
+               /**
+                * Property to read the value for the cells in the column from the data 
+                * source array / object. If null, then the default content is used, if a
+                * function is given then the return from the function is used.
+                *  @type function|int|string|null
+                *  @default null
+                */
+               "mData": null,
+               
+               /**
+                * Partner property to mData which is used (only when defined) to get
+                * the data - i.e. it is basically the same as mData, but without the
+                * 'set' option, and also the data fed to it is the result from mData.
+                * This is the rendering method to match the data method of mData.
+                *  @type function|int|string|null
+                *  @default null
+                */
+               "mRender": null,
+               
+               /**
+                * Unique header TH/TD element for this column - this is what the sorting
+                * listener is attached to (if sorting is enabled.)
+                *  @type node
+                *  @default null
+                */
+               "nTh": null,
+               
+               /**
+                * Unique footer TH/TD element for this column (if there is one). Not used 
+                * in DataTables as such, but can be used for plug-ins to reference the 
+                * footer for each column.
+                *  @type node
+                *  @default null
+                */
+               "nTf": null,
+               
+               /**
+                * The class to apply to all TD elements in the table's TBODY for the column
+                *  @type string
+                *  @default null
+                */
+               "sClass": null,
+               
+               /**
+                * When DataTables calculates the column widths to assign to each column,
+                * it finds the longest string in each column and then constructs a
+                * temporary table and reads the widths from that. The problem with this
+                * is that "mmm" is much wider then "iiii", but the latter is a longer 
+                * string - thus the calculation can go wrong (doing it properly and putting
+                * it into an DOM object and measuring that is horribly(!) slow). Thus as
+                * a "work around" we provide this option. It will append its value to the
+                * text that is found to be the longest string for the column - i.e. padding.
+                *  @type string
+                */
+               "sContentPadding": null,
+               
+               /**
+                * Allows a default value to be given for a column's data, and will be used
+                * whenever a null data source is encountered (this can be because mData
+                * is set to null, or because the data source itself is null).
+                *  @type string
+                *  @default null
+                */
+               "sDefaultContent": null,
+               
+               /**
+                * Name for the column, allowing reference to the column by name as well as
+                * by index (needs a lookup to work by name).
+                *  @type string
+                */
+               "sName": null,
+               
+               /**
+                * Custom sorting data type - defines which of the available plug-ins in
+                * afnSortData the custom sorting will use - if any is defined.
+                *  @type string
+                *  @default std
+                */
+               "sSortDataType": 'std',
+               
+               /**
+                * Class to be applied to the header element when sorting on this column
+                *  @type string
+                *  @default null
+                */
+               "sSortingClass": null,
+               
+               /**
+                * Class to be applied to the header element when sorting on this column -
+                * when jQuery UI theming is used.
+                *  @type string
+                *  @default null
+                */
+               "sSortingClassJUI": null,
+               
+               /**
+                * Title of the column - what is seen in the TH element (nTh).
+                *  @type string
+                */
+               "sTitle": null,
+               
+               /**
+                * Column sorting and filtering type
+                *  @type string
+                *  @default null
+                */
+               "sType": null,
+               
+               /**
+                * Width of the column
+                *  @type string
+                *  @default null
+                */
+               "sWidth": null,
+               
+               /**
+                * Width of the column when it was first "encountered"
+                *  @type string
+                *  @default null
+                */
+               "sWidthOrig": null
+       };
+       
+       
+       
+       /**
+        * Initialisation options that can be given to DataTables at initialisation 
+        * time.
+        *  @namespace
+        */
+       DataTable.defaults = {
+               /**
+                * An array of data to use for the table, passed in at initialisation which 
+                * will be used in preference to any data which is already in the DOM. This is
+                * particularly useful for constructing tables purely in Javascript, for
+                * example with a custom Ajax call.
+                *  @type array
+                *  @default null
+                *  @dtopt Option
+                * 
+                *  @example
+                *    // Using a 2D array data source
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "aaData": [
+                *          ['Trident', 'Internet Explorer 4.0', 'Win 95+', 4, 'X'],
+                *          ['Trident', 'Internet Explorer 5.0', 'Win 95+', 5, 'C'],
+                *        ],
+                *        "aoColumns": [
+                *          { "sTitle": "Engine" },
+                *          { "sTitle": "Browser" },
+                *          { "sTitle": "Platform" },
+                *          { "sTitle": "Version" },
+                *          { "sTitle": "Grade" }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using an array of objects as a data source (mData)
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "aaData": [
+                *          {
+                *            "engine":   "Trident",
+                *            "browser":  "Internet Explorer 4.0",
+                *            "platform": "Win 95+",
+                *            "version":  4,
+                *            "grade":    "X"
+                *          },
+                *          {
+                *            "engine":   "Trident",
+                *            "browser":  "Internet Explorer 5.0",
+                *            "platform": "Win 95+",
+                *            "version":  5,
+                *            "grade":    "C"
+                *          }
+                *        ],
+                *        "aoColumns": [
+                *          { "sTitle": "Engine",   "mData": "engine" },
+                *          { "sTitle": "Browser",  "mData": "browser" },
+                *          { "sTitle": "Platform", "mData": "platform" },
+                *          { "sTitle": "Version",  "mData": "version" },
+                *          { "sTitle": "Grade",    "mData": "grade" }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "aaData": null,
+       
+       
+               /**
+                * If sorting is enabled, then DataTables will perform a first pass sort on 
+                * initialisation. You can define which column(s) the sort is performed upon, 
+                * and the sorting direction, with this variable. The aaSorting array should 
+                * contain an array for each column to be sorted initially containing the 
+                * column's index and a direction string ('asc' or 'desc').
+                *  @type array
+                *  @default [[0,'asc']]
+                *  @dtopt Option
+                * 
+                *  @example
+                *    // Sort by 3rd column first, and then 4th column
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aaSorting": [[2,'asc'], [3,'desc']]
+                *      } );
+                *    } );
+                *    
+                *    // No initial sorting
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aaSorting": []
+                *      } );
+                *    } );
+                */
+               "aaSorting": [[0,'asc']],
+       
+       
+               /**
+                * This parameter is basically identical to the aaSorting parameter, but 
+                * cannot be overridden by user interaction with the table. What this means 
+                * is that you could have a column (visible or hidden) which the sorting will 
+                * always be forced on first - any sorting after that (from the user) will 
+                * then be performed as required. This can be useful for grouping rows 
+                * together.
+                *  @type array
+                *  @default null
+                *  @dtopt Option
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aaSortingFixed": [[0,'asc']]
+                *      } );
+                *    } )
+                */
+               "aaSortingFixed": null,
+       
+       
+               /**
+                * This parameter allows you to readily specify the entries in the length drop
+                * down menu that DataTables shows when pagination is enabled. It can be 
+                * either a 1D array of options which will be used for both the displayed 
+                * option and the value, or a 2D array which will use the array in the first 
+                * position as the value, and the array in the second position as the 
+                * displayed options (useful for language strings such as 'All').
+                *  @type array
+                *  @default [ 10, 25, 50, 100 ]
+                *  @dtopt Option
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aLengthMenu": [[10, 25, 50, -1], [10, 25, 50, "All"]]
+                *      } );
+                *    } );
+                *  
+                *  @example
+                *    // Setting the default display length as well as length menu
+                *    // This is likely to be wanted if you remove the '10' option which
+                *    // is the iDisplayLength default.
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "iDisplayLength": 25,
+                *        "aLengthMenu": [[25, 50, 100, -1], [25, 50, 100, "All"]]
+                *      } );
+                *    } );
+                */
+               "aLengthMenu": [ 10, 25, 50, 100 ],
+       
+       
+               /**
+                * The aoColumns option in the initialisation parameter allows you to define
+                * details about the way individual columns behave. For a full list of
+                * column options that can be set, please see 
+                * {@link DataTable.defaults.columns}. Note that if you use aoColumns to
+                * define your columns, you must have an entry in the array for every single
+                * column that you have in your table (these can be null if you don't which
+                * to specify any options).
+                *  @member
+                */
+               "aoColumns": null,
+       
+               /**
+                * Very similar to aoColumns, aoColumnDefs allows you to target a specific 
+                * column, multiple columns, or all columns, using the aTargets property of 
+                * each object in the array. This allows great flexibility when creating 
+                * tables, as the aoColumnDefs arrays can be of any length, targeting the 
+                * columns you specifically want. aoColumnDefs may use any of the column 
+                * options available: {@link DataTable.defaults.columns}, but it _must_
+                * have aTargets defined in each object in the array. Values in the aTargets
+                * array may be:
+                *   <ul>
+                *     <li>a string - class name will be matched on the TH for the column</li>
+                *     <li>0 or a positive integer - column index counting from the left</li>
+                *     <li>a negative integer - column index counting from the right</li>
+                *     <li>the string "_all" - all columns (i.e. assign a default)</li>
+                *   </ul>
+                *  @member
+                */
+               "aoColumnDefs": null,
+       
+       
+               /**
+                * Basically the same as oSearch, this parameter defines the individual column
+                * filtering state at initialisation time. The array must be of the same size 
+                * as the number of columns, and each element be an object with the parameters
+                * "sSearch" and "bEscapeRegex" (the latter is optional). 'null' is also
+                * accepted and the default will be used.
+                *  @type array
+                *  @default []
+                *  @dtopt Option
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoSearchCols": [
+                *          null,
+                *          { "sSearch": "My filter" },
+                *          null,
+                *          { "sSearch": "^[0-9]", "bEscapeRegex": false }
+                *        ]
+                *      } );
+                *    } )
+                */
+               "aoSearchCols": [],
+       
+       
+               /**
+                * An array of CSS classes that should be applied to displayed rows. This 
+                * array may be of any length, and DataTables will apply each class 
+                * sequentially, looping when required.
+                *  @type array
+                *  @default null <i>Will take the values determined by the oClasses.sStripe*
+                *    options</i>
+                *  @dtopt Option
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "asStripeClasses": [ 'strip1', 'strip2', 'strip3' ]
+                *      } );
+                *    } )
+                */
+               "asStripeClasses": null,
+       
+       
+               /**
+                * Enable or disable automatic column width calculation. This can be disabled
+                * as an optimisation (it takes some time to calculate the widths) if the
+                * tables widths are passed in using aoColumns.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bAutoWidth": false
+                *      } );
+                *    } );
+                */
+               "bAutoWidth": true,
+       
+       
+               /**
+                * Deferred rendering can provide DataTables with a huge speed boost when you
+                * are using an Ajax or JS data source for the table. This option, when set to
+                * true, will cause DataTables to defer the creation of the table elements for
+                * each row until they are needed for a draw - saving a significant amount of
+                * time.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sAjaxSource": "sources/arrays.txt",
+                *        "bDeferRender": true
+                *      } );
+                *    } );
+                */
+               "bDeferRender": false,
+       
+       
+               /**
+                * Replace a DataTable which matches the given selector and replace it with 
+                * one which has the properties of the new initialisation object passed. If no
+                * table matches the selector, then the new DataTable will be constructed as
+                * per normal.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sScrollY": "200px",
+                *        "bPaginate": false
+                *      } );
+                *      
+                *      // Some time later....
+                *      $('#example').dataTable( {
+                *        "bFilter": false,
+                *        "bDestroy": true
+                *      } );
+                *    } );
+                */
+               "bDestroy": false,
+       
+       
+               /**
+                * Enable or disable filtering of data. Filtering in DataTables is "smart" in
+                * that it allows the end user to input multiple words (space separated) and
+                * will match a row containing those words, even if not in the order that was
+                * specified (this allow matching across multiple columns). Note that if you
+                * wish to use filtering in DataTables this must remain 'true' - to remove the
+                * default filtering input box and retain filtering abilities, please use
+                * {@link DataTable.defaults.sDom}.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bFilter": false
+                *      } );
+                *    } );
+                */
+               "bFilter": true,
+       
+       
+               /**
+                * Enable or disable the table information display. This shows information 
+                * about the data that is currently visible on the page, including information
+                * about filtered data if that action is being performed.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bInfo": false
+                *      } );
+                *    } );
+                */
+               "bInfo": true,
+       
+       
+               /**
+                * Enable jQuery UI ThemeRoller support (required as ThemeRoller requires some
+                * slightly different and additional mark-up from what DataTables has
+                * traditionally used).
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bJQueryUI": true
+                *      } );
+                *    } );
+                */
+               "bJQueryUI": false,
+       
+       
+               /**
+                * Allows the end user to select the size of a formatted page from a select
+                * menu (sizes are 10, 25, 50 and 100). Requires pagination (bPaginate).
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bLengthChange": false
+                *      } );
+                *    } );
+                */
+               "bLengthChange": true,
+       
+       
+               /**
+                * Enable or disable pagination.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bPaginate": false
+                *      } );
+                *    } );
+                */
+               "bPaginate": true,
+       
+       
+               /**
+                * Enable or disable the display of a 'processing' indicator when the table is
+                * being processed (e.g. a sort). This is particularly useful for tables with
+                * large amounts of data where it can take a noticeable amount of time to sort
+                * the entries.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bProcessing": true
+                *      } );
+                *    } );
+                */
+               "bProcessing": false,
+       
+       
+               /**
+                * Retrieve the DataTables object for the given selector. Note that if the
+                * table has already been initialised, this parameter will cause DataTables
+                * to simply return the object that has already been set up - it will not take
+                * account of any changes you might have made to the initialisation object
+                * passed to DataTables (setting this parameter to true is an acknowledgement
+                * that you understand this). bDestroy can be used to reinitialise a table if
+                * you need.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      initTable();
+                *      tableActions();
+                *    } );
+                *    
+                *    function initTable ()
+                *    {
+                *      return $('#example').dataTable( {
+                *        "sScrollY": "200px",
+                *        "bPaginate": false,
+                *        "bRetrieve": true
+                *      } );
+                *    }
+                *    
+                *    function tableActions ()
+                *    {
+                *      var oTable = initTable();
+                *      // perform API operations with oTable 
+                *    }
+                */
+               "bRetrieve": false,
+       
+       
+               /**
+                * Indicate if DataTables should be allowed to set the padding / margin
+                * etc for the scrolling header elements or not. Typically you will want
+                * this.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bScrollAutoCss": false,
+                *        "sScrollY": "200px"
+                *      } );
+                *    } );
+                */
+               "bScrollAutoCss": true,
+       
+       
+               /**
+                * When vertical (y) scrolling is enabled, DataTables will force the height of
+                * the table's viewport to the given height at all times (useful for layout).
+                * However, this can look odd when filtering data down to a small data set,
+                * and the footer is left "floating" further down. This parameter (when
+                * enabled) will cause DataTables to collapse the table's viewport down when
+                * the result set will fit within the given Y height.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sScrollY": "200",
+                *        "bScrollCollapse": true
+                *      } );
+                *    } );
+                */
+               "bScrollCollapse": false,
+       
+       
+               /**
+                * Enable infinite scrolling for DataTables (to be used in combination with
+                * sScrollY). Infinite scrolling means that DataTables will continually load
+                * data as a user scrolls through a table, which is very useful for large
+                * dataset. This cannot be used with pagination, which is automatically
+                * disabled. Note - the Scroller extra for DataTables is recommended in
+                * in preference to this option.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bScrollInfinite": true,
+                *        "bScrollCollapse": true,
+                *        "sScrollY": "200px"
+                *      } );
+                *    } );
+                */
+               "bScrollInfinite": false,
+       
+       
+               /**
+                * Configure DataTables to use server-side processing. Note that the
+                * sAjaxSource parameter must also be given in order to give DataTables a
+                * source to obtain the required data for each draw.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bServerSide": true,
+                *        "sAjaxSource": "xhr.php"
+                *      } );
+                *    } );
+                */
+               "bServerSide": false,
+       
+       
+               /**
+                * Enable or disable sorting of columns. Sorting of individual columns can be
+                * disabled by the "bSortable" option for each column.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bSort": false
+                *      } );
+                *    } );
+                */
+               "bSort": true,
+       
+       
+               /**
+                * Allows control over whether DataTables should use the top (true) unique
+                * cell that is found for a single column, or the bottom (false - default).
+                * This is useful when using complex headers.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bSortCellsTop": true
+                *      } );
+                *    } );
+                */
+               "bSortCellsTop": false,
+       
+       
+               /**
+                * Enable or disable the addition of the classes 'sorting_1', 'sorting_2' and
+                * 'sorting_3' to the columns which are currently being sorted on. This is
+                * presented as a feature switch as it can increase processing time (while
+                * classes are removed and added) so for large data sets you might want to
+                * turn this off.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bSortClasses": false
+                *      } );
+                *    } );
+                */
+               "bSortClasses": true,
+       
+       
+               /**
+                * Enable or disable state saving. When enabled a cookie will be used to save
+                * table display information such as pagination information, display length,
+                * filtering and sorting. As such when the end user reloads the page the
+                * display display will match what thy had previously set up.
+                *  @type boolean
+                *  @default false
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true
+                *      } );
+                *    } );
+                */
+               "bStateSave": false,
+       
+       
+               /**
+                * Customise the cookie and / or the parameters being stored when using
+                * DataTables with state saving enabled. This function is called whenever
+                * the cookie is modified, and it expects a fully formed cookie string to be
+                * returned. Note that the data object passed in is a Javascript object which
+                * must be converted to a string (JSON.stringify for example).
+                *  @type function
+                *  @param {string} sName Name of the cookie defined by DataTables
+                *  @param {object} oData Data to be stored in the cookie
+                *  @param {string} sExpires Cookie expires string
+                *  @param {string} sPath Path of the cookie to set
+                *  @returns {string} Cookie formatted string (which should be encoded by
+                *    using encodeURIComponent())
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function () {
+                *      $('#example').dataTable( {
+                *        "fnCookieCallback": function (sName, oData, sExpires, sPath) {
+                *          // Customise oData or sName or whatever else here
+                *          return sName + "="+JSON.stringify(oData)+"; expires=" + sExpires +"; path=" + sPath;
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnCookieCallback": null,
+       
+       
+               /**
+                * This function is called when a TR element is created (and all TD child
+                * elements have been inserted), or registered if using a DOM source, allowing
+                * manipulation of the TR element (adding classes etc).
+                *  @type function
+                *  @param {node} nRow "TR" element for the current row
+                *  @param {array} aData Raw data array for this row
+                *  @param {int} iDataIndex The index of this row in aoData
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnCreatedRow": function( nRow, aData, iDataIndex ) {
+                *          // Bold the grade for all 'A' grade browsers
+                *          if ( aData[4] == "A" )
+                *          {
+                *            $('td:eq(4)', nRow).html( '<b>A</b>' );
+                *          }
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnCreatedRow": null,
+       
+       
+               /**
+                * This function is called on every 'draw' event, and allows you to
+                * dynamically modify any aspect you want about the created DOM.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnDrawCallback": function( oSettings ) {
+                *          alert( 'DataTables has redrawn the table' );
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnDrawCallback": null,
+       
+       
+               /**
+                * Identical to fnHeaderCallback() but for the table footer this function
+                * allows you to modify the table footer on every 'draw' even.
+                *  @type function
+                *  @param {node} nFoot "TR" element for the footer
+                *  @param {array} aData Full table data (as derived from the original HTML)
+                *  @param {int} iStart Index for the current display starting point in the 
+                *    display array
+                *  @param {int} iEnd Index for the current display ending point in the 
+                *    display array
+                *  @param {array int} aiDisplay Index array to translate the visual position
+                *    to the full data array
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnFooterCallback": function( nFoot, aData, iStart, iEnd, aiDisplay ) {
+                *          nFoot.getElementsByTagName('th')[0].innerHTML = "Starting index is "+iStart;
+                *        }
+                *      } );
+                *    } )
+                */
+               "fnFooterCallback": null,
+       
+       
+               /**
+                * When rendering large numbers in the information element for the table
+                * (i.e. "Showing 1 to 10 of 57 entries") DataTables will render large numbers
+                * to have a comma separator for the 'thousands' units (e.g. 1 million is
+                * rendered as "1,000,000") to help readability for the end user. This
+                * function will override the default method DataTables uses.
+                *  @type function
+                *  @member
+                *  @param {int} iIn number to be formatted
+                *  @returns {string} formatted string for DataTables to show the number
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnFormatNumber": function ( iIn ) {
+                *          if ( iIn &lt; 1000 ) {
+                *            return iIn;
+                *          } else {
+                *            var 
+                *              s=(iIn+""), 
+                *              a=s.split(""), out="", 
+                *              iLen=s.length;
+                *            
+                *            for ( var i=0 ; i&lt;iLen ; i++ ) {
+                *              if ( i%3 === 0 &amp;&amp; i !== 0 ) {
+                *                out = "'"+out;
+                *              }
+                *              out = a[iLen-i-1]+out;
+                *            }
+                *          }
+                *          return out;
+                *        };
+                *      } );
+                *    } );
+                */
+               "fnFormatNumber": function ( iIn ) {
+                       if ( iIn < 1000 )
+                       {
+                               // A small optimisation for what is likely to be the majority of use cases
+                               return iIn;
+                       }
+       
+                       var s=(iIn+""), a=s.split(""), out="", iLen=s.length;
+                       
+                       for ( var i=0 ; i<iLen ; i++ )
+                       {
+                               if ( i%3 === 0 && i !== 0 )
+                               {
+                                       out = this.oLanguage.sInfoThousands+out;
+                               }
+                               out = a[iLen-i-1]+out;
+                       }
+                       return out;
+               },
+       
+       
+               /**
+                * This function is called on every 'draw' event, and allows you to
+                * dynamically modify the header row. This can be used to calculate and
+                * display useful information about the table.
+                *  @type function
+                *  @param {node} nHead "TR" element for the header
+                *  @param {array} aData Full table data (as derived from the original HTML)
+                *  @param {int} iStart Index for the current display starting point in the
+                *    display array
+                *  @param {int} iEnd Index for the current display ending point in the
+                *    display array
+                *  @param {array int} aiDisplay Index array to translate the visual position
+                *    to the full data array
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnHeaderCallback": function( nHead, aData, iStart, iEnd, aiDisplay ) {
+                *          nHead.getElementsByTagName('th')[0].innerHTML = "Displaying "+(iEnd-iStart)+" records";
+                *        }
+                *      } );
+                *    } )
+                */
+               "fnHeaderCallback": null,
+       
+       
+               /**
+                * The information element can be used to convey information about the current
+                * state of the table. Although the internationalisation options presented by
+                * DataTables are quite capable of dealing with most customisations, there may
+                * be times where you wish to customise the string further. This callback
+                * allows you to do exactly that.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @param {int} iStart Starting position in data for the draw
+                *  @param {int} iEnd End position in data for the draw
+                *  @param {int} iMax Total number of rows in the table (regardless of
+                *    filtering)
+                *  @param {int} iTotal Total number of rows in the data set, after filtering
+                *  @param {string} sPre The string that DataTables has formatted using it's
+                *    own rules
+                *  @returns {string} The string to be displayed in the information element.
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $('#example').dataTable( {
+                *      "fnInfoCallback": function( oSettings, iStart, iEnd, iMax, iTotal, sPre ) {
+                *        return iStart +" to "+ iEnd;
+                *      }
+                *    } );
+                */
+               "fnInfoCallback": null,
+       
+       
+               /**
+                * Called when the table has been initialised. Normally DataTables will
+                * initialise sequentially and there will be no need for this function,
+                * however, this does not hold true when using external language information
+                * since that is obtained using an async XHR call.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @param {object} json The JSON object request from the server - only
+                *    present if client-side Ajax sourced data is used
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnInitComplete": function(oSettings, json) {
+                *          alert( 'DataTables has finished its initialisation.' );
+                *        }
+                *      } );
+                *    } )
+                */
+               "fnInitComplete": null,
+       
+       
+               /**
+                * Called at the very start of each table draw and can be used to cancel the
+                * draw by returning false, any other return (including undefined) results in
+                * the full draw occurring).
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @returns {boolean} False will cancel the draw, anything else (including no
+                *    return) will allow it to complete.
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnPreDrawCallback": function( oSettings ) {
+                *          if ( $('#test').val() == 1 ) {
+                *            return false;
+                *          }
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnPreDrawCallback": null,
+       
+       
+               /**
+                * This function allows you to 'post process' each row after it have been
+                * generated for each table draw, but before it is rendered on screen. This
+                * function might be used for setting the row class name etc.
+                *  @type function
+                *  @param {node} nRow "TR" element for the current row
+                *  @param {array} aData Raw data array for this row
+                *  @param {int} iDisplayIndex The display index for the current table draw
+                *  @param {int} iDisplayIndexFull The index of the data in the full list of
+                *    rows (after filtering)
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "fnRowCallback": function( nRow, aData, iDisplayIndex, iDisplayIndexFull ) {
+                *          // Bold the grade for all 'A' grade browsers
+                *          if ( aData[4] == "A" )
+                *          {
+                *            $('td:eq(4)', nRow).html( '<b>A</b>' );
+                *          }
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnRowCallback": null,
+       
+       
+               /**
+                * This parameter allows you to override the default function which obtains
+                * the data from the server ($.getJSON) so something more suitable for your
+                * application. For example you could use POST data, or pull information from
+                * a Gears or AIR database.
+                *  @type function
+                *  @member
+                *  @param {string} sSource HTTP source to obtain the data from (sAjaxSource)
+                *  @param {array} aoData A key/value pair object containing the data to send
+                *    to the server
+                *  @param {function} fnCallback to be called on completion of the data get
+                *    process that will draw the data on the page.
+                *  @param {object} oSettings DataTables settings object
+                *  @dtopt Callbacks
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    // POST data to server
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bProcessing": true,
+                *        "bServerSide": true,
+                *        "sAjaxSource": "xhr.php",
+                *        "fnServerData": function ( sSource, aoData, fnCallback, oSettings ) {
+                *          oSettings.jqXHR = $.ajax( {
+                *            "dataType": 'json', 
+                *            "type": "POST", 
+                *            "url": sSource, 
+                *            "data": aoData, 
+                *            "success": fnCallback
+                *          } );
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnServerData": function ( sUrl, aoData, fnCallback, oSettings ) {
+                       oSettings.jqXHR = $.ajax( {
+                               "url":  sUrl,
+                               "data": aoData,
+                               "success": function (json) {
+                                       if ( json.sError ) {
+                                               oSettings.oApi._fnLog( oSettings, 0, json.sError );
+                                       }
+                                       
+                                       $(oSettings.oInstance).trigger('xhr', [oSettings, json]);
+                                       fnCallback( json );
+                               },
+                               "dataType": "json",
+                               "cache": false,
+                               "type": oSettings.sServerMethod,
+                               "error": function (xhr, error, thrown) {
+                                       if ( error == "parsererror" ) {
+                                               oSettings.oApi._fnLog( oSettings, 0, "DataTables warning: JSON data from "+
+                                                       "server could not be parsed. This is caused by a JSON formatting error." );
+                                       }
+                               }
+                       } );
+               },
+       
+       
+               /**
+                * It is often useful to send extra data to the server when making an Ajax
+                * request - for example custom filtering information, and this callback
+                * function makes it trivial to send extra information to the server. The
+                * passed in parameter is the data set that has been constructed by
+                * DataTables, and you can add to this or modify it as you require.
+                *  @type function
+                *  @param {array} aoData Data array (array of objects which are name/value
+                *    pairs) that has been constructed by DataTables and will be sent to the
+                *    server. In the case of Ajax sourced data with server-side processing
+                *    this will be an empty array, for server-side processing there will be a
+                *    significant number of parameters!
+                *  @returns {undefined} Ensure that you modify the aoData array passed in,
+                *    as this is passed by reference.
+                *  @dtopt Callbacks
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bProcessing": true,
+                *        "bServerSide": true,
+                *        "sAjaxSource": "scripts/server_processing.php",
+                *        "fnServerParams": function ( aoData ) {
+                *          aoData.push( { "name": "more_data", "value": "my_value" } );
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnServerParams": null,
+       
+       
+               /**
+                * Load the table state. With this function you can define from where, and how, the
+                * state of a table is loaded. By default DataTables will load from its state saving
+                * cookie, but you might wish to use local storage (HTML5) or a server-side database.
+                *  @type function
+                *  @member
+                *  @param {object} oSettings DataTables settings object
+                *  @return {object} The DataTables state object to be loaded
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateLoad": function (oSettings) {
+                *          var o;
+                *          
+                *          // Send an Ajax request to the server to get the data. Note that
+                *          // this is a synchronous request.
+                *          $.ajax( {
+                *            "url": "/state_load",
+                *            "async": false,
+                *            "dataType": "json",
+                *            "success": function (json) {
+                *              o = json;
+                *            }
+                *          } );
+                *          
+                *          return o;
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnStateLoad": function ( oSettings ) {
+                       var sData = this.oApi._fnReadCookie( oSettings.sCookiePrefix+oSettings.sInstance );
+                       var oData;
+       
+                       try {
+                               oData = (typeof $.parseJSON === 'function') ? 
+                                       $.parseJSON(sData) : eval( '('+sData+')' );
+                       } catch (e) {
+                               oData = null;
+                       }
+       
+                       return oData;
+               },
+       
+       
+               /**
+                * Callback which allows modification of the saved state prior to loading that state.
+                * This callback is called when the table is loading state from the stored data, but
+                * prior to the settings object being modified by the saved state. Note that for 
+                * plug-in authors, you should use the 'stateLoadParams' event to load parameters for 
+                * a plug-in.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @param {object} oData The state object that is to be loaded
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    // Remove a saved filter, so filtering is never loaded
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateLoadParams": function (oSettings, oData) {
+                *          oData.oSearch.sSearch = "";
+                *        }
+                *      } );
+                *    } );
+                * 
+                *  @example
+                *    // Disallow state loading by returning false
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateLoadParams": function (oSettings, oData) {
+                *          return false;
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnStateLoadParams": null,
+       
+       
+               /**
+                * Callback that is called when the state has been loaded from the state saving method
+                * and the DataTables settings object has been modified as a result of the loaded state.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @param {object} oData The state object that was loaded
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    // Show an alert with the filtering value that was saved
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateLoaded": function (oSettings, oData) {
+                *          alert( 'Saved filter was: '+oData.oSearch.sSearch );
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnStateLoaded": null,
+       
+       
+               /**
+                * Save the table state. This function allows you to define where and how the state
+                * information for the table is stored - by default it will use a cookie, but you
+                * might want to use local storage (HTML5) or a server-side database.
+                *  @type function
+                *  @member
+                *  @param {object} oSettings DataTables settings object
+                *  @param {object} oData The state object to be saved
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateSave": function (oSettings, oData) {
+                *          // Send an Ajax request to the server with the state object
+                *          $.ajax( {
+                *            "url": "/state_save",
+                *            "data": oData,
+                *            "dataType": "json",
+                *            "method": "POST"
+                *            "success": function () {}
+                *          } );
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnStateSave": function ( oSettings, oData ) {
+                       this.oApi._fnCreateCookie( 
+                               oSettings.sCookiePrefix+oSettings.sInstance, 
+                               this.oApi._fnJsonString(oData), 
+                               oSettings.iCookieDuration, 
+                               oSettings.sCookiePrefix, 
+                               oSettings.fnCookieCallback
+                       );
+               },
+       
+       
+               /**
+                * Callback which allows modification of the state to be saved. Called when the table 
+                * has changed state a new state save is required. This method allows modification of
+                * the state saving object prior to actually doing the save, including addition or 
+                * other state properties or modification. Note that for plug-in authors, you should 
+                * use the 'stateSaveParams' event to save parameters for a plug-in.
+                *  @type function
+                *  @param {object} oSettings DataTables settings object
+                *  @param {object} oData The state object to be saved
+                *  @dtopt Callbacks
+                * 
+                *  @example
+                *    // Remove a saved filter, so filtering is never saved
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bStateSave": true,
+                *        "fnStateSaveParams": function (oSettings, oData) {
+                *          oData.oSearch.sSearch = "";
+                *        }
+                *      } );
+                *    } );
+                */
+               "fnStateSaveParams": null,
+       
+       
+               /**
+                * Duration of the cookie which is used for storing session information. This
+                * value is given in seconds.
+                *  @type int
+                *  @default 7200 <i>(2 hours)</i>
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "iCookieDuration": 60*60*24; // 1 day
+                *      } );
+                *    } )
+                */
+               "iCookieDuration": 7200,
+       
+       
+               /**
+                * When enabled DataTables will not make a request to the server for the first
+                * page draw - rather it will use the data already on the page (no sorting etc
+                * will be applied to it), thus saving on an XHR at load time. iDeferLoading
+                * is used to indicate that deferred loading is required, but it is also used
+                * to tell DataTables how many records there are in the full table (allowing
+                * the information element and pagination to be displayed correctly). In the case
+                * where a filtering is applied to the table on initial load, this can be
+                * indicated by giving the parameter as an array, where the first element is
+                * the number of records available after filtering and the second element is the
+                * number of records without filtering (allowing the table information element
+                * to be shown correctly).
+                *  @type int | array
+                *  @default null
+                *  @dtopt Options
+                * 
+                *  @example
+                *    // 57 records available in the table, no filtering applied
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bServerSide": true,
+                *        "sAjaxSource": "scripts/server_processing.php",
+                *        "iDeferLoading": 57
+                *      } );
+                *    } );
+                * 
+                *  @example
+                *    // 57 records after filtering, 100 without filtering (an initial filter applied)
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bServerSide": true,
+                *        "sAjaxSource": "scripts/server_processing.php",
+                *        "iDeferLoading": [ 57, 100 ],
+                *        "oSearch": {
+                *          "sSearch": "my_filter"
+                *        }
+                *      } );
+                *    } );
+                */
+               "iDeferLoading": null,
+       
+       
+               /**
+                * Number of rows to display on a single page when using pagination. If
+                * feature enabled (bLengthChange) then the end user will be able to override
+                * this to a custom setting using a pop-up menu.
+                *  @type int
+                *  @default 10
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "iDisplayLength": 50
+                *      } );
+                *    } )
+                */
+               "iDisplayLength": 10,
+       
+       
+               /**
+                * Define the starting point for data display when using DataTables with
+                * pagination. Note that this parameter is the number of records, rather than
+                * the page number, so if you have 10 records per page and want to start on
+                * the third page, it should be "20".
+                *  @type int
+                *  @default 0
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "iDisplayStart": 20
+                *      } );
+                *    } )
+                */
+               "iDisplayStart": 0,
+       
+       
+               /**
+                * The scroll gap is the amount of scrolling that is left to go before
+                * DataTables will load the next 'page' of data automatically. You typically
+                * want a gap which is big enough that the scrolling will be smooth for the
+                * user, while not so large that it will load more data than need.
+                *  @type int
+                *  @default 100
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bScrollInfinite": true,
+                *        "bScrollCollapse": true,
+                *        "sScrollY": "200px",
+                *        "iScrollLoadGap": 50
+                *      } );
+                *    } );
+                */
+               "iScrollLoadGap": 100,
+       
+       
+               /**
+                * By default DataTables allows keyboard navigation of the table (sorting, paging,
+                * and filtering) by adding a tabindex attribute to the required elements. This
+                * allows you to tab through the controls and press the enter key to activate them.
+                * The tabindex is default 0, meaning that the tab follows the flow of the document.
+                * You can overrule this using this parameter if you wish. Use a value of -1 to
+                * disable built-in keyboard navigation.
+                *  @type int
+                *  @default 0
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "iTabIndex": 1
+                *      } );
+                *    } );
+                */
+               "iTabIndex": 0,
+       
+       
+               /**
+                * All strings that DataTables uses in the user interface that it creates
+                * are defined in this object, allowing you to modified them individually or
+                * completely replace them all as required.
+                *  @namespace
+                */
+               "oLanguage": {
+                       /**
+                        * Strings that are used for WAI-ARIA labels and controls only (these are not
+                        * actually visible on the page, but will be read by screenreaders, and thus
+                        * must be internationalised as well).
+                        *  @namespace
+                        */
+                       "oAria": {
+                               /**
+                                * ARIA label that is added to the table headers when the column may be
+                                * sorted ascending by activing the column (click or return when focused).
+                                * Note that the column header is prefixed to this string.
+                                *  @type string
+                                *  @default : activate to sort column ascending
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oAria": {
+                                *            "sSortAscending": " - click/return to sort ascending"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sSortAscending": ": activate to sort column ascending",
+       
+                               /**
+                                * ARIA label that is added to the table headers when the column may be
+                                * sorted descending by activing the column (click or return when focused).
+                                * Note that the column header is prefixed to this string.
+                                *  @type string
+                                *  @default : activate to sort column ascending
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oAria": {
+                                *            "sSortDescending": " - click/return to sort descending"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sSortDescending": ": activate to sort column descending"
+                       },
+       
+                       /**
+                        * Pagination string used by DataTables for the two built-in pagination
+                        * control types ("two_button" and "full_numbers")
+                        *  @namespace
+                        */
+                       "oPaginate": {
+                               /**
+                                * Text to use when using the 'full_numbers' type of pagination for the
+                                * button to take the user to the first page.
+                                *  @type string
+                                *  @default First
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oPaginate": {
+                                *            "sFirst": "First page"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sFirst": "First",
+                       
+                       
+                               /**
+                                * Text to use when using the 'full_numbers' type of pagination for the
+                                * button to take the user to the last page.
+                                *  @type string
+                                *  @default Last
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oPaginate": {
+                                *            "sLast": "Last page"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sLast": "Last",
+                       
+                       
+                               /**
+                                * Text to use for the 'next' pagination button (to take the user to the 
+                                * next page).
+                                *  @type string
+                                *  @default Next
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oPaginate": {
+                                *            "sNext": "Next page"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sNext": "Next",
+                       
+                       
+                               /**
+                                * Text to use for the 'previous' pagination button (to take the user to  
+                                * the previous page).
+                                *  @type string
+                                *  @default Previous
+                                *  @dtopt Language
+                                * 
+                                *  @example
+                                *    $(document).ready( function() {
+                                *      $('#example').dataTable( {
+                                *        "oLanguage": {
+                                *          "oPaginate": {
+                                *            "sPrevious": "Previous page"
+                                *          }
+                                *        }
+                                *      } );
+                                *    } );
+                                */
+                               "sPrevious": "Previous"
+                       },
+               
+                       /**
+                        * This string is shown in preference to sZeroRecords when the table is
+                        * empty of data (regardless of filtering). Note that this is an optional
+                        * parameter - if it is not given, the value of sZeroRecords will be used
+                        * instead (either the default or given value).
+                        *  @type string
+                        *  @default No data available in table
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sEmptyTable": "No data available in table"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sEmptyTable": "No data available in table",
+               
+               
+                       /**
+                        * This string gives information to the end user about the information that 
+                        * is current on display on the page. The _START_, _END_ and _TOTAL_ 
+                        * variables are all dynamically replaced as the table display updates, and 
+                        * can be freely moved or removed as the language requirements change.
+                        *  @type string
+                        *  @default Showing _START_ to _END_ of _TOTAL_ entries
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sInfo": "Got a total of _TOTAL_ entries to show (_START_ to _END_)"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sInfo": "Showing _START_ to _END_ of _TOTAL_ entries",
+               
+               
+                       /**
+                        * Display information string for when the table is empty. Typically the 
+                        * format of this string should match sInfo.
+                        *  @type string
+                        *  @default Showing 0 to 0 of 0 entries
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sInfoEmpty": "No entries to show"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sInfoEmpty": "Showing 0 to 0 of 0 entries",
+               
+               
+                       /**
+                        * When a user filters the information in a table, this string is appended 
+                        * to the information (sInfo) to give an idea of how strong the filtering 
+                        * is. The variable _MAX_ is dynamically updated.
+                        *  @type string
+                        *  @default (filtered from _MAX_ total entries)
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sInfoFiltered": " - filtering from _MAX_ records"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sInfoFiltered": "(filtered from _MAX_ total entries)",
+               
+               
+                       /**
+                        * If can be useful to append extra information to the info string at times,
+                        * and this variable does exactly that. This information will be appended to
+                        * the sInfo (sInfoEmpty and sInfoFiltered in whatever combination they are
+                        * being used) at all times.
+                        *  @type string
+                        *  @default <i>Empty string</i>
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sInfoPostFix": "All records shown are derived from real information."
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sInfoPostFix": "",
+               
+               
+                       /**
+                        * DataTables has a build in number formatter (fnFormatNumber) which is used
+                        * to format large numbers that are used in the table information. By
+                        * default a comma is used, but this can be trivially changed to any
+                        * character you wish with this parameter.
+                        *  @type string
+                        *  @default ,
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sInfoThousands": "'"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sInfoThousands": ",",
+               
+               
+                       /**
+                        * Detail the action that will be taken when the drop down menu for the
+                        * pagination length option is changed. The '_MENU_' variable is replaced
+                        * with a default select list of 10, 25, 50 and 100, and can be replaced
+                        * with a custom select box if required.
+                        *  @type string
+                        *  @default Show _MENU_ entries
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    // Language change only
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sLengthMenu": "Display _MENU_ records"
+                        *        }
+                        *      } );
+                        *    } );
+                        *    
+                        *  @example
+                        *    // Language and options change
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sLengthMenu": 'Display <select>'+
+                        *            '<option value="10">10</option>'+
+                        *            '<option value="20">20</option>'+
+                        *            '<option value="30">30</option>'+
+                        *            '<option value="40">40</option>'+
+                        *            '<option value="50">50</option>'+
+                        *            '<option value="-1">All</option>'+
+                        *            '</select> records'
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sLengthMenu": "Show _MENU_ entries",
+               
+               
+                       /**
+                        * When using Ajax sourced data and during the first draw when DataTables is
+                        * gathering the data, this message is shown in an empty row in the table to
+                        * indicate to the end user the the data is being loaded. Note that this
+                        * parameter is not used when loading data by server-side processing, just
+                        * Ajax sourced data with client-side processing.
+                        *  @type string
+                        *  @default Loading...
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sLoadingRecords": "Please wait - loading..."
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sLoadingRecords": "Loading...",
+               
+               
+                       /**
+                        * Text which is displayed when the table is processing a user action
+                        * (usually a sort command or similar).
+                        *  @type string
+                        *  @default Processing...
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sProcessing": "DataTables is currently busy"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sProcessing": "Processing...",
+               
+               
+                       /**
+                        * Details the actions that will be taken when the user types into the
+                        * filtering input text box. The variable "_INPUT_", if used in the string,
+                        * is replaced with the HTML text box for the filtering input allowing
+                        * control over where it appears in the string. If "_INPUT_" is not given
+                        * then the input box is appended to the string automatically.
+                        *  @type string
+                        *  @default Search:
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    // Input text box will be appended at the end automatically
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sSearch": "Filter records:"
+                        *        }
+                        *      } );
+                        *    } );
+                        *    
+                        *  @example
+                        *    // Specify where the filter should appear
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sSearch": "Apply filter _INPUT_ to table"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sSearch": "Search:",
+               
+               
+                       /**
+                        * All of the language information can be stored in a file on the
+                        * server-side, which DataTables will look up if this parameter is passed.
+                        * It must store the URL of the language file, which is in a JSON format,
+                        * and the object has the same properties as the oLanguage object in the
+                        * initialiser object (i.e. the above parameters). Please refer to one of
+                        * the example language files to see how this works in action.
+                        *  @type string
+                        *  @default <i>Empty string - i.e. disabled</i>
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sUrl": "http://www.sprymedia.co.uk/dataTables/lang.txt"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sUrl": "",
+               
+               
+                       /**
+                        * Text shown inside the table records when the is no information to be
+                        * displayed after filtering. sEmptyTable is shown when there is simply no
+                        * information in the table at all (regardless of filtering).
+                        *  @type string
+                        *  @default No matching records found
+                        *  @dtopt Language
+                        * 
+                        *  @example
+                        *    $(document).ready( function() {
+                        *      $('#example').dataTable( {
+                        *        "oLanguage": {
+                        *          "sZeroRecords": "No records to display"
+                        *        }
+                        *      } );
+                        *    } );
+                        */
+                       "sZeroRecords": "No matching records found"
+               },
+       
+       
+               /**
+                * This parameter allows you to have define the global filtering state at
+                * initialisation time. As an object the "sSearch" parameter must be
+                * defined, but all other parameters are optional. When "bRegex" is true,
+                * the search string will be treated as a regular expression, when false
+                * (default) it will be treated as a straight string. When "bSmart"
+                * DataTables will use it's smart filtering methods (to word match at
+                * any point in the data), when false this will not be done.
+                *  @namespace
+                *  @extends DataTable.models.oSearch
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "oSearch": {"sSearch": "Initial search"}
+                *      } );
+                *    } )
+                */
+               "oSearch": $.extend( {}, DataTable.models.oSearch ),
+       
+       
+               /**
+                * By default DataTables will look for the property 'aaData' when obtaining
+                * data from an Ajax source or for server-side processing - this parameter
+                * allows that property to be changed. You can use Javascript dotted object
+                * notation to get a data source for multiple levels of nesting.
+                *  @type string
+                *  @default aaData
+                *  @dtopt Options
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    // Get data from { "data": [...] }
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sAjaxSource": "sources/data.txt",
+                *        "sAjaxDataProp": "data"
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Get data from { "data": { "inner": [...] } }
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sAjaxSource": "sources/data.txt",
+                *        "sAjaxDataProp": "data.inner"
+                *      } );
+                *    } );
+                */
+               "sAjaxDataProp": "aaData",
+       
+       
+               /**
+                * You can instruct DataTables to load data from an external source using this
+                * parameter (use aData if you want to pass data in you already have). Simply
+                * provide a url a JSON object can be obtained from. This object must include
+                * the parameter 'aaData' which is the data source for the table.
+                *  @type string
+                *  @default null
+                *  @dtopt Options
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sAjaxSource": "http://www.sprymedia.co.uk/dataTables/json.php"
+                *      } );
+                *    } )
+                */
+               "sAjaxSource": null,
+       
+       
+               /**
+                * This parameter can be used to override the default prefix that DataTables
+                * assigns to a cookie when state saving is enabled.
+                *  @type string
+                *  @default SpryMedia_DataTables_
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sCookiePrefix": "my_datatable_",
+                *      } );
+                *    } );
+                */
+               "sCookiePrefix": "SpryMedia_DataTables_",
+       
+       
+               /**
+                * This initialisation variable allows you to specify exactly where in the
+                * DOM you want DataTables to inject the various controls it adds to the page
+                * (for example you might want the pagination controls at the top of the
+                * table). DIV elements (with or without a custom class) can also be added to
+                * aid styling. The follow syntax is used:
+                *   <ul>
+                *     <li>The following options are allowed:   
+                *       <ul>
+                *         <li>'l' - Length changing</li
+                *         <li>'f' - Filtering input</li>
+                *         <li>'t' - The table!</li>
+                *         <li>'i' - Information</li>
+                *         <li>'p' - Pagination</li>
+                *         <li>'r' - pRocessing</li>
+                *       </ul>
+                *     </li>
+                *     <li>The following constants are allowed:
+                *       <ul>
+                *         <li>'H' - jQueryUI theme "header" classes ('fg-toolbar ui-widget-header ui-corner-tl ui-corner-tr ui-helper-clearfix')</li>
+                *         <li>'F' - jQueryUI theme "footer" classes ('fg-toolbar ui-widget-header ui-corner-bl ui-corner-br ui-helper-clearfix')</li>
+                *       </ul>
+                *     </li>
+                *     <li>The following syntax is expected:
+                *       <ul>
+                *         <li>'&lt;' and '&gt;' - div elements</li>
+                *         <li>'&lt;"class" and '&gt;' - div with a class</li>
+                *         <li>'&lt;"#id" and '&gt;' - div with an ID</li>
+                *       </ul>
+                *     </li>
+                *     <li>Examples:
+                *       <ul>
+                *         <li>'&lt;"wrapper"flipt&gt;'</li>
+                *         <li>'&lt;lf&lt;t&gt;ip&gt;'</li>
+                *       </ul>
+                *     </li>
+                *   </ul>
+                *  @type string
+                *  @default lfrtip <i>(when bJQueryUI is false)</i> <b>or</b> 
+                *    <"H"lfr>t<"F"ip> <i>(when bJQueryUI is true)</i>
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sDom": '&lt;"top"i&gt;rt&lt;"bottom"flp&gt;&lt;"clear"&gt;'
+                *      } );
+                *    } );
+                */
+               "sDom": "lfrtip",
+       
+       
+               /**
+                * DataTables features two different built-in pagination interaction methods
+                * ('two_button' or 'full_numbers') which present different page controls to
+                * the end user. Further methods can be added using the API (see below).
+                *  @type string
+                *  @default two_button
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sPaginationType": "full_numbers"
+                *      } );
+                *    } )
+                */
+               "sPaginationType": "two_button",
+       
+       
+               /**
+                * Enable horizontal scrolling. When a table is too wide to fit into a certain
+                * layout, or you have a large number of columns in the table, you can enable
+                * x-scrolling to show the table in a viewport, which can be scrolled. This
+                * property can be any CSS unit, or a number (in which case it will be treated
+                * as a pixel measurement).
+                *  @type string
+                *  @default <i>blank string - i.e. disabled</i>
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sScrollX": "100%",
+                *        "bScrollCollapse": true
+                *      } );
+                *    } );
+                */
+               "sScrollX": "",
+       
+       
+               /**
+                * This property can be used to force a DataTable to use more width than it
+                * might otherwise do when x-scrolling is enabled. For example if you have a
+                * table which requires to be well spaced, this parameter is useful for
+                * "over-sizing" the table, and thus forcing scrolling. This property can by
+                * any CSS unit, or a number (in which case it will be treated as a pixel
+                * measurement).
+                *  @type string
+                *  @default <i>blank string - i.e. disabled</i>
+                *  @dtopt Options
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sScrollX": "100%",
+                *        "sScrollXInner": "110%"
+                *      } );
+                *    } );
+                */
+               "sScrollXInner": "",
+       
+       
+               /**
+                * Enable vertical scrolling. Vertical scrolling will constrain the DataTable
+                * to the given height, and enable scrolling for any data which overflows the
+                * current viewport. This can be used as an alternative to paging to display
+                * a lot of data in a small area (although paging and scrolling can both be
+                * enabled at the same time). This property can be any CSS unit, or a number
+                * (in which case it will be treated as a pixel measurement).
+                *  @type string
+                *  @default <i>blank string - i.e. disabled</i>
+                *  @dtopt Features
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "sScrollY": "200px",
+                *        "bPaginate": false
+                *      } );
+                *    } );
+                */
+               "sScrollY": "",
+       
+       
+               /**
+                * Set the HTTP method that is used to make the Ajax call for server-side
+                * processing or Ajax sourced data.
+                *  @type string
+                *  @default GET
+                *  @dtopt Options
+                *  @dtopt Server-side
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "bServerSide": true,
+                *        "sAjaxSource": "scripts/post.php",
+                *        "sServerMethod": "POST"
+                *      } );
+                *    } );
+                */
+               "sServerMethod": "GET"
+       };
+       
+       
+       
+       /**
+        * Column options that can be given to DataTables at initialisation time.
+        *  @namespace
+        */
+       DataTable.defaults.columns = {
+               /**
+                * Allows a column's sorting to take multiple columns into account when 
+                * doing a sort. For example first name / last name columns make sense to 
+                * do a multi-column sort over the two columns.
+                *  @type array
+                *  @default null <i>Takes the value of the column index automatically</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [
+                *          { "aDataSort": [ 0, 1 ], "aTargets": [ 0 ] },
+                *          { "aDataSort": [ 1, 0 ], "aTargets": [ 1 ] },
+                *          { "aDataSort": [ 2, 3, 4 ], "aTargets": [ 2 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [
+                *          { "aDataSort": [ 0, 1 ] },
+                *          { "aDataSort": [ 1, 0 ] },
+                *          { "aDataSort": [ 2, 3, 4 ] },
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "aDataSort": null,
+       
+       
+               /**
+                * You can control the default sorting direction, and even alter the behaviour
+                * of the sort handler (i.e. only allow ascending sorting etc) using this
+                * parameter.
+                *  @type array
+                *  @default [ 'asc', 'desc' ]
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [
+                *          { "asSorting": [ "asc" ], "aTargets": [ 1 ] },
+                *          { "asSorting": [ "desc", "asc", "asc" ], "aTargets": [ 2 ] },
+                *          { "asSorting": [ "desc" ], "aTargets": [ 3 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [
+                *          null,
+                *          { "asSorting": [ "asc" ] },
+                *          { "asSorting": [ "desc", "asc", "asc" ] },
+                *          { "asSorting": [ "desc" ] },
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "asSorting": [ 'asc', 'desc' ],
+       
+       
+               /**
+                * Enable or disable filtering on the data in this column.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "bSearchable": false, "aTargets": [ 0 ] }
+                *        ] } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "bSearchable": false },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ] } );
+                *    } );
+                */
+               "bSearchable": true,
+       
+       
+               /**
+                * Enable or disable sorting on this column.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "bSortable": false, "aTargets": [ 0 ] }
+                *        ] } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "bSortable": false },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ] } );
+                *    } );
+                */
+               "bSortable": true,
+       
+       
+               /**
+                * <code>Deprecated</code> When using fnRender() for a column, you may wish 
+                * to use the original data (before rendering) for sorting and filtering 
+                * (the default is to used the rendered data that the user can see). This 
+                * may be useful for dates etc.
+                * 
+                * Please note that this option has now been deprecated and will be removed
+                * in the next version of DataTables. Please use mRender / mData rather than
+                * fnRender.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Columns
+                *  @deprecated
+                */
+               "bUseRendered": true,
+       
+       
+               /**
+                * Enable or disable the display of this column.
+                *  @type boolean
+                *  @default true
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "bVisible": false, "aTargets": [ 0 ] }
+                *        ] } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "bVisible": false },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ] } );
+                *    } );
+                */
+               "bVisible": true,
+               
+               
+               /**
+                * Developer definable function that is called whenever a cell is created (Ajax source,
+                * etc) or processed for input (DOM source). This can be used as a compliment to mRender
+                * allowing you to modify the DOM element (add background colour for example) when the
+                * element is available.
+                *  @type function
+                *  @param {element} nTd The TD node that has been created
+                *  @param {*} sData The Data for the cell
+                *  @param {array|object} oData The data for the whole row
+                *  @param {int} iRow The row index for the aoData data store
+                *  @param {int} iCol The column index for aoColumns
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ {
+                *          "aTargets": [3],
+                *          "fnCreatedCell": function (nTd, sData, oData, iRow, iCol) {
+                *            if ( sData == "1.7" ) {
+                *              $(nTd).css('color', 'blue')
+                *            }
+                *          }
+                *        } ]
+                *      });
+                *    } );
+                */
+               "fnCreatedCell": null,
+       
+       
+               /**
+                * <code>Deprecated</code> Custom display function that will be called for the 
+                * display of each cell in this column.
+                *
+                * Please note that this option has now been deprecated and will be removed
+                * in the next version of DataTables. Please use mRender / mData rather than
+                * fnRender.
+                *  @type function
+                *  @param {object} o Object with the following parameters:
+                *  @param {int}    o.iDataRow The row in aoData
+                *  @param {int}    o.iDataColumn The column in question
+                *  @param {array}  o.aData The data for the row in question
+                *  @param {object} o.oSettings The settings object for this DataTables instance
+                *  @param {object} o.mDataProp The data property used for this column
+                *  @param {*}      val The current cell value
+                *  @returns {string} The string you which to use in the display
+                *  @dtopt Columns
+                *  @deprecated
+                */
+               "fnRender": null,
+       
+       
+               /**
+                * The column index (starting from 0!) that you wish a sort to be performed
+                * upon when this column is selected for sorting. This can be used for sorting
+                * on hidden columns for example.
+                *  @type int
+                *  @default -1 <i>Use automatically calculated column index</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "iDataSort": 1, "aTargets": [ 0 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "iDataSort": 1 },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "iDataSort": -1,
+       
+       
+               /**
+                * This parameter has been replaced by mData in DataTables to ensure naming
+                * consistency. mDataProp can still be used, as there is backwards compatibility
+                * in DataTables for this option, but it is strongly recommended that you use
+                * mData in preference to mDataProp.
+                *  @name DataTable.defaults.columns.mDataProp
+                */
+       
+       
+               /**
+                * This property can be used to read data from any JSON data source property,
+                * including deeply nested objects / properties. mData can be given in a
+                * number of different ways which effect its behaviour:
+                *   <ul>
+                *     <li>integer - treated as an array index for the data source. This is the
+                *       default that DataTables uses (incrementally increased for each column).</li>
+                *     <li>string - read an object property from the data source. Note that you can
+                *       use Javascript dotted notation to read deep properties / arrays from the
+                *       data source.</li>
+                *     <li>null - the sDefaultContent option will be used for the cell (null
+                *       by default, so you will need to specify the default content you want -
+                *       typically an empty string). This can be useful on generated columns such 
+                *       as edit / delete action columns.</li>
+                *     <li>function - the function given will be executed whenever DataTables 
+                *       needs to set or get the data for a cell in the column. The function 
+                *       takes three parameters:
+                *       <ul>
+                *         <li>{array|object} The data source for the row</li>
+                *         <li>{string} The type call data requested - this will be 'set' when
+                *           setting data or 'filter', 'display', 'type', 'sort' or undefined when 
+                *           gathering data. Note that when <i>undefined</i> is given for the type
+                *           DataTables expects to get the raw data for the object back</li>
+                *         <li>{*} Data to set when the second parameter is 'set'.</li>
+                *       </ul>
+                *       The return value from the function is not required when 'set' is the type
+                *       of call, but otherwise the return is what will be used for the data
+                *       requested.</li>
+                *    </ul>
+                *
+                * Note that prior to DataTables 1.9.2 mData was called mDataProp. The name change
+                * reflects the flexibility of this property and is consistent with the naming of
+                * mRender. If 'mDataProp' is given, then it will still be used by DataTables, as
+                * it automatically maps the old name to the new if required.
+                *  @type string|int|function|null
+                *  @default null <i>Use automatically calculated column index</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Read table data from objects
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sAjaxSource": "sources/deep.txt",
+                *        "aoColumns": [
+                *          { "mData": "engine" },
+                *          { "mData": "browser" },
+                *          { "mData": "platform.inner" },
+                *          { "mData": "platform.details.0" },
+                *          { "mData": "platform.details.1" }
+                *        ]
+                *      } );
+                *    } );
+                * 
+                *  @example
+                *    // Using mData as a function to provide different information for
+                *    // sorting, filtering and display. In this case, currency (price)
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "aoColumnDefs": [ {
+                *          "aTargets": [ 0 ],
+                *          "mData": function ( source, type, val ) {
+                *            if (type === 'set') {
+                *              source.price = val;
+                *              // Store the computed dislay and filter values for efficiency
+                *              source.price_display = val=="" ? "" : "$"+numberFormat(val);
+                *              source.price_filter  = val=="" ? "" : "$"+numberFormat(val)+" "+val;
+                *              return;
+                *            }
+                *            else if (type === 'display') {
+                *              return source.price_display;
+                *            }
+                *            else if (type === 'filter') {
+                *              return source.price_filter;
+                *            }
+                *            // 'sort', 'type' and undefined all just use the integer
+                *            return source.price;
+                *          }
+                *        } ]
+                *      } );
+                *    } );
+                */
+               "mData": null,
+       
+       
+               /**
+                * This property is the rendering partner to mData and it is suggested that
+                * when you want to manipulate data for display (including filtering, sorting etc)
+                * but not altering the underlying data for the table, use this property. mData
+                * can actually do everything this property can and more, but this parameter is
+                * easier to use since there is no 'set' option. Like mData is can be given
+                * in a number of different ways to effect its behaviour, with the addition of 
+                * supporting array syntax for easy outputting of arrays (including arrays of
+                * objects):
+                *   <ul>
+                *     <li>integer - treated as an array index for the data source. This is the
+                *       default that DataTables uses (incrementally increased for each column).</li>
+                *     <li>string - read an object property from the data source. Note that you can
+                *       use Javascript dotted notation to read deep properties / arrays from the
+                *       data source and also array brackets to indicate that the data reader should
+                *       loop over the data source array. When characters are given between the array
+                *       brackets, these characters are used to join the data source array together.
+                *       For example: "accounts[, ].name" would result in a comma separated list with
+                *       the 'name' value from the 'accounts' array of objects.</li>
+                *     <li>function - the function given will be executed whenever DataTables 
+                *       needs to set or get the data for a cell in the column. The function 
+                *       takes three parameters:
+                *       <ul>
+                *         <li>{array|object} The data source for the row (based on mData)</li>
+                *         <li>{string} The type call data requested - this will be 'filter', 'display', 
+                *           'type' or 'sort'.</li>
+                *         <li>{array|object} The full data source for the row (not based on mData)</li>
+                *       </ul>
+                *       The return value from the function is what will be used for the data
+                *       requested.</li>
+                *    </ul>
+                *  @type string|int|function|null
+                *  @default null <i>Use mData</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Create a comma separated list from an array of objects
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "sAjaxSource": "sources/deep.txt",
+                *        "aoColumns": [
+                *          { "mData": "engine" },
+                *          { "mData": "browser" },
+                *          {
+                *            "mData": "platform",
+                *            "mRender": "[, ].name"
+                *          }
+                *        ]
+                *      } );
+                *    } );
+                * 
+                *  @example
+                *    // Use as a function to create a link from the data source
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "aoColumnDefs": [
+                *        {
+                *          "aTargets": [ 0 ],
+                *          "mData": "download_link",
+                *          "mRender": function ( data, type, full ) {
+                *            return '<a href="'+data+'">Download</a>';
+                *          }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "mRender": null,
+       
+       
+               /**
+                * Change the cell type created for the column - either TD cells or TH cells. This
+                * can be useful as TH cells have semantic meaning in the table body, allowing them
+                * to act as a header for a row (you may wish to add scope='row' to the TH elements).
+                *  @type string
+                *  @default td
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Make the first column use TH cells
+                *    $(document).ready( function() {
+                *      var oTable = $('#example').dataTable( {
+                *        "aoColumnDefs": [ {
+                *          "aTargets": [ 0 ],
+                *          "sCellType": "th"
+                *        } ]
+                *      } );
+                *    } );
+                */
+               "sCellType": "td",
+       
+       
+               /**
+                * Class to give to each cell in this column.
+                *  @type string
+                *  @default <i>Empty string</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "sClass": "my_class", "aTargets": [ 0 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "sClass": "my_class" },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sClass": "",
+               
+               /**
+                * When DataTables calculates the column widths to assign to each column,
+                * it finds the longest string in each column and then constructs a
+                * temporary table and reads the widths from that. The problem with this
+                * is that "mmm" is much wider then "iiii", but the latter is a longer 
+                * string - thus the calculation can go wrong (doing it properly and putting
+                * it into an DOM object and measuring that is horribly(!) slow). Thus as
+                * a "work around" we provide this option. It will append its value to the
+                * text that is found to be the longest string for the column - i.e. padding.
+                * Generally you shouldn't need this, and it is not documented on the 
+                * general DataTables.net documentation
+                *  @type string
+                *  @default <i>Empty string<i>
+                *  @dtopt Columns
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          null,
+                *          null,
+                *          null,
+                *          {
+                *            "sContentPadding": "mmm"
+                *          }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sContentPadding": "",
+       
+       
+               /**
+                * Allows a default value to be given for a column's data, and will be used
+                * whenever a null data source is encountered (this can be because mData
+                * is set to null, or because the data source itself is null).
+                *  @type string
+                *  @default null
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          {
+                *            "mData": null,
+                *            "sDefaultContent": "Edit",
+                *            "aTargets": [ -1 ]
+                *          }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          null,
+                *          null,
+                *          null,
+                *          {
+                *            "mData": null,
+                *            "sDefaultContent": "Edit"
+                *          }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sDefaultContent": null,
+       
+       
+               /**
+                * This parameter is only used in DataTables' server-side processing. It can
+                * be exceptionally useful to know what columns are being displayed on the
+                * client side, and to map these to database fields. When defined, the names
+                * also allow DataTables to reorder information from the server if it comes
+                * back in an unexpected order (i.e. if you switch your columns around on the
+                * client-side, your server-side code does not also need updating).
+                *  @type string
+                *  @default <i>Empty string</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "sName": "engine", "aTargets": [ 0 ] },
+                *          { "sName": "browser", "aTargets": [ 1 ] },
+                *          { "sName": "platform", "aTargets": [ 2 ] },
+                *          { "sName": "version", "aTargets": [ 3 ] },
+                *          { "sName": "grade", "aTargets": [ 4 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "sName": "engine" },
+                *          { "sName": "browser" },
+                *          { "sName": "platform" },
+                *          { "sName": "version" },
+                *          { "sName": "grade" }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sName": "",
+       
+       
+               /**
+                * Defines a data source type for the sorting which can be used to read
+                * real-time information from the table (updating the internally cached
+                * version) prior to sorting. This allows sorting to occur on user editable
+                * elements such as form inputs.
+                *  @type string
+                *  @default std
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [
+                *          { "sSortDataType": "dom-text", "aTargets": [ 2, 3 ] },
+                *          { "sType": "numeric", "aTargets": [ 3 ] },
+                *          { "sSortDataType": "dom-select", "aTargets": [ 4 ] },
+                *          { "sSortDataType": "dom-checkbox", "aTargets": [ 5 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [
+                *          null,
+                *          null,
+                *          { "sSortDataType": "dom-text" },
+                *          { "sSortDataType": "dom-text", "sType": "numeric" },
+                *          { "sSortDataType": "dom-select" },
+                *          { "sSortDataType": "dom-checkbox" }
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sSortDataType": "std",
+       
+       
+               /**
+                * The title of this column.
+                *  @type string
+                *  @default null <i>Derived from the 'TH' value for this column in the 
+                *    original HTML table.</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "sTitle": "My column title", "aTargets": [ 0 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "sTitle": "My column title" },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sTitle": null,
+       
+       
+               /**
+                * The type allows you to specify how the data for this column will be sorted.
+                * Four types (string, numeric, date and html (which will strip HTML tags
+                * before sorting)) are currently available. Note that only date formats
+                * understood by Javascript's Date() object will be accepted as type date. For
+                * example: "Mar 26, 2008 5:03 PM". May take the values: 'string', 'numeric',
+                * 'date' or 'html' (by default). Further types can be adding through
+                * plug-ins.
+                *  @type string
+                *  @default null <i>Auto-detected from raw data</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "sType": "html", "aTargets": [ 0 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "sType": "html" },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sType": null,
+       
+       
+               /**
+                * Defining the width of the column, this parameter may take any CSS value
+                * (3em, 20px etc). DataTables apples 'smart' widths to columns which have not
+                * been given a specific width through this interface ensuring that the table
+                * remains readable.
+                *  @type string
+                *  @default null <i>Automatic</i>
+                *  @dtopt Columns
+                * 
+                *  @example
+                *    // Using aoColumnDefs
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumnDefs": [ 
+                *          { "sWidth": "20%", "aTargets": [ 0 ] }
+                *        ]
+                *      } );
+                *    } );
+                *    
+                *  @example
+                *    // Using aoColumns
+                *    $(document).ready( function() {
+                *      $('#example').dataTable( {
+                *        "aoColumns": [ 
+                *          { "sWidth": "20%" },
+                *          null,
+                *          null,
+                *          null,
+                *          null
+                *        ]
+                *      } );
+                *    } );
+                */
+               "sWidth": null
+       };
+       
+       
+       
+       /**
+        * DataTables settings object - this holds all the information needed for a
+        * given table, including configuration, data and current application of the
+        * table options. DataTables does not have a single instance for each DataTable
+        * with the settings attached to that instance, but rather instances of the
+        * DataTable "class" are created on-the-fly as needed (typically by a 
+        * $().dataTable() call) and the settings object is then applied to that
+        * instance.
+        * 
+        * Note that this object is related to {@link DataTable.defaults} but this 
+        * one is the internal data store for DataTables's cache of columns. It should
+        * NOT be manipulated outside of DataTables. Any configuration should be done
+        * through the initialisation options.
+        *  @namespace
+        *  @todo Really should attach the settings object to individual instances so we
+        *    don't need to create new instances on each $().dataTable() call (if the
+        *    table already exists). It would also save passing oSettings around and
+        *    into every single function. However, this is a very significant 
+        *    architecture change for DataTables and will almost certainly break
+        *    backwards compatibility with older installations. This is something that
+        *    will be done in 2.0.
+        */
+       DataTable.models.oSettings = {
+               /**
+                * Primary features of DataTables and their enablement state.
+                *  @namespace
+                */
+               "oFeatures": {
+                       
+                       /**
+                        * Flag to say if DataTables should automatically try to calculate the
+                        * optimum table and columns widths (true) or not (false).
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bAutoWidth": null,
+       
+                       /**
+                        * Delay the creation of TR and TD elements until they are actually
+                        * needed by a driven page draw. This can give a significant speed
+                        * increase for Ajax source and Javascript source data, but makes no
+                        * difference at all fro DOM and server-side processing tables.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bDeferRender": null,
+                       
+                       /**
+                        * Enable filtering on the table or not. Note that if this is disabled
+                        * then there is no filtering at all on the table, including fnFilter.
+                        * To just remove the filtering input use sDom and remove the 'f' option.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bFilter": null,
+                       
+                       /**
+                        * Table information element (the 'Showing x of y records' div) enable
+                        * flag.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bInfo": null,
+                       
+                       /**
+                        * Present a user control allowing the end user to change the page size
+                        * when pagination is enabled.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bLengthChange": null,
+       
+                       /**
+                        * Pagination enabled or not. Note that if this is disabled then length
+                        * changing must also be disabled.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bPaginate": null,
+                       
+                       /**
+                        * Processing indicator enable flag whenever DataTables is enacting a
+                        * user request - typically an Ajax request for server-side processing.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bProcessing": null,
+                       
+                       /**
+                        * Server-side processing enabled flag - when enabled DataTables will
+                        * get all data from the server for every draw - there is no filtering,
+                        * sorting or paging done on the client-side.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bServerSide": null,
+                       
+                       /**
+                        * Sorting enablement flag.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bSort": null,
+                       
+                       /**
+                        * Apply a class to the columns which are being sorted to provide a
+                        * visual highlight or not. This can slow things down when enabled since
+                        * there is a lot of DOM interaction.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bSortClasses": null,
+                       
+                       /**
+                        * State saving enablement flag.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bStateSave": null
+               },
+               
+       
+               /**
+                * Scrolling settings for a table.
+                *  @namespace
+                */
+               "oScroll": {
+                       /**
+                        * Indicate if DataTables should be allowed to set the padding / margin
+                        * etc for the scrolling header elements or not. Typically you will want
+                        * this.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bAutoCss": null,
+                       
+                       /**
+                        * When the table is shorter in height than sScrollY, collapse the
+                        * table container down to the height of the table (when true).
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bCollapse": null,
+                       
+                       /**
+                        * Infinite scrolling enablement flag. Now deprecated in favour of
+                        * using the Scroller plug-in.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type boolean
+                        */
+                       "bInfinite": null,
+                       
+                       /**
+                        * Width of the scrollbar for the web-browser's platform. Calculated
+                        * during table initialisation.
+                        *  @type int
+                        *  @default 0
+                        */
+                       "iBarWidth": 0,
+                       
+                       /**
+                        * Space (in pixels) between the bottom of the scrolling container and 
+                        * the bottom of the scrolling viewport before the next page is loaded
+                        * when using infinite scrolling.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type int
+                        */
+                       "iLoadGap": null,
+                       
+                       /**
+                        * Viewport width for horizontal scrolling. Horizontal scrolling is 
+                        * disabled if an empty string.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type string
+                        */
+                       "sX": null,
+                       
+                       /**
+                        * Width to expand the table to when using x-scrolling. Typically you
+                        * should not need to use this.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type string
+                        *  @deprecated
+                        */
+                       "sXInner": null,
+                       
+                       /**
+                        * Viewport height for vertical scrolling. Vertical scrolling is disabled
+                        * if an empty string.
+                        * Note that this parameter will be set by the initialisation routine. To
+                        * set a default use {@link DataTable.defaults}.
+                        *  @type string
+                        */
+                       "sY": null
+               },
+               
+               /**
+                * Language information for the table.
+                *  @namespace
+                *  @extends DataTable.defaults.oLanguage
+                */
+               "oLanguage": {
+                       /**
+                        * Information callback function. See 
+                        * {@link DataTable.defaults.fnInfoCallback}
+                        *  @type function
+                        *  @default null
+                        */
+                       "fnInfoCallback": null
+               },
+               
+               /**
+                * Browser support parameters
+                *  @namespace
+                */
+               "oBrowser": {
+                       /**
+                        * Indicate if the browser incorrectly calculates width:100% inside a
+                        * scrolling element (IE6/7)
+                        *  @type boolean
+                        *  @default false
+                        */
+                       "bScrollOversize": false
+               },
+               
+               /**
+                * Array referencing the nodes which are used for the features. The 
+                * parameters of this object match what is allowed by sDom - i.e.
+                *   <ul>
+                *     <li>'l' - Length changing</li>
+                *     <li>'f' - Filtering input</li>
+                *     <li>'t' - The table!</li>
+                *     <li>'i' - Information</li>
+                *     <li>'p' - Pagination</li>
+                *     <li>'r' - pRocessing</li>
+                *   </ul>
+                *  @type array
+                *  @default []
+                */
+               "aanFeatures": [],
+               
+               /**
+                * Store data information - see {@link DataTable.models.oRow} for detailed
+                * information.
+                *  @type array
+                *  @default []
+                */
+               "aoData": [],
+               
+               /**
+                * Array of indexes which are in the current display (after filtering etc)
+                *  @type array
+                *  @default []
+                */
+               "aiDisplay": [],
+               
+               /**
+                * Array of indexes for display - no filtering
+                *  @type array
+                *  @default []
+                */
+               "aiDisplayMaster": [],
+               
+               /**
+                * Store information about each column that is in use
+                *  @type array
+                *  @default []
+                */
+               "aoColumns": [],
+               
+               /**
+                * Store information about the table's header
+                *  @type array
+                *  @default []
+                */
+               "aoHeader": [],
+               
+               /**
+                * Store information about the table's footer
+                *  @type array
+                *  @default []
+                */
+               "aoFooter": [],
+               
+               /**
+                * Search data array for regular expression searching
+                *  @type array
+                *  @default []
+                */
+               "asDataSearch": [],
+               
+               /**
+                * Store the applied global search information in case we want to force a 
+                * research or compare the old search to a new one.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @namespace
+                *  @extends DataTable.models.oSearch
+                */
+               "oPreviousSearch": {},
+               
+               /**
+                * Store the applied search for each column - see 
+                * {@link DataTable.models.oSearch} for the format that is used for the
+                * filtering information for each column.
+                *  @type array
+                *  @default []
+                */
+               "aoPreSearchCols": [],
+               
+               /**
+                * Sorting that is applied to the table. Note that the inner arrays are
+                * used in the following manner:
+                * <ul>
+                *   <li>Index 0 - column number</li>
+                *   <li>Index 1 - current sorting direction</li>
+                *   <li>Index 2 - index of asSorting for this column</li>
+                * </ul>
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type array
+                *  @todo These inner arrays should really be objects
+                */
+               "aaSorting": null,
+               
+               /**
+                * Sorting that is always applied to the table (i.e. prefixed in front of
+                * aaSorting).
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type array|null
+                *  @default null
+                */
+               "aaSortingFixed": null,
+               
+               /**
+                * Classes to use for the striping of a table.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type array
+                *  @default []
+                */
+               "asStripeClasses": null,
+               
+               /**
+                * If restoring a table - we should restore its striping classes as well
+                *  @type array
+                *  @default []
+                */
+               "asDestroyStripes": [],
+               
+               /**
+                * If restoring a table - we should restore its width 
+                *  @type int
+                *  @default 0
+                */
+               "sDestroyWidth": 0,
+               
+               /**
+                * Callback functions array for every time a row is inserted (i.e. on a draw).
+                *  @type array
+                *  @default []
+                */
+               "aoRowCallback": [],
+               
+               /**
+                * Callback functions for the header on each draw.
+                *  @type array
+                *  @default []
+                */
+               "aoHeaderCallback": [],
+               
+               /**
+                * Callback function for the footer on each draw.
+                *  @type array
+                *  @default []
+                */
+               "aoFooterCallback": [],
+               
+               /**
+                * Array of callback functions for draw callback functions
+                *  @type array
+                *  @default []
+                */
+               "aoDrawCallback": [],
+               
+               /**
+                * Array of callback functions for row created function
+                *  @type array
+                *  @default []
+                */
+               "aoRowCreatedCallback": [],
+               
+               /**
+                * Callback functions for just before the table is redrawn. A return of 
+                * false will be used to cancel the draw.
+                *  @type array
+                *  @default []
+                */
+               "aoPreDrawCallback": [],
+               
+               /**
+                * Callback functions for when the table has been initialised.
+                *  @type array
+                *  @default []
+                */
+               "aoInitComplete": [],
+       
+               
+               /**
+                * Callbacks for modifying the settings to be stored for state saving, prior to
+                * saving state.
+                *  @type array
+                *  @default []
+                */
+               "aoStateSaveParams": [],
+               
+               /**
+                * Callbacks for modifying the settings that have been stored for state saving
+                * prior to using the stored values to restore the state.
+                *  @type array
+                *  @default []
+                */
+               "aoStateLoadParams": [],
+               
+               /**
+                * Callbacks for operating on the settings object once the saved state has been
+                * loaded
+                *  @type array
+                *  @default []
+                */
+               "aoStateLoaded": [],
+               
+               /**
+                * Cache the table ID for quick access
+                *  @type string
+                *  @default <i>Empty string</i>
+                */
+               "sTableId": "",
+               
+               /**
+                * The TABLE node for the main table
+                *  @type node
+                *  @default null
+                */
+               "nTable": null,
+               
+               /**
+                * Permanent ref to the thead element
+                *  @type node
+                *  @default null
+                */
+               "nTHead": null,
+               
+               /**
+                * Permanent ref to the tfoot element - if it exists
+                *  @type node
+                *  @default null
+                */
+               "nTFoot": null,
+               
+               /**
+                * Permanent ref to the tbody element
+                *  @type node
+                *  @default null
+                */
+               "nTBody": null,
+               
+               /**
+                * Cache the wrapper node (contains all DataTables controlled elements)
+                *  @type node
+                *  @default null
+                */
+               "nTableWrapper": null,
+               
+               /**
+                * Indicate if when using server-side processing the loading of data 
+                * should be deferred until the second draw.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type boolean
+                *  @default false
+                */
+               "bDeferLoading": false,
+               
+               /**
+                * Indicate if all required information has been read in
+                *  @type boolean
+                *  @default false
+                */
+               "bInitialised": false,
+               
+               /**
+                * Information about open rows. Each object in the array has the parameters
+                * 'nTr' and 'nParent'
+                *  @type array
+                *  @default []
+                */
+               "aoOpenRows": [],
+               
+               /**
+                * Dictate the positioning of DataTables' control elements - see
+                * {@link DataTable.model.oInit.sDom}.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string
+                *  @default null
+                */
+               "sDom": null,
+               
+               /**
+                * Which type of pagination should be used.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string 
+                *  @default two_button
+                */
+               "sPaginationType": "two_button",
+               
+               /**
+                * The cookie duration (for bStateSave) in seconds.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type int
+                *  @default 0
+                */
+               "iCookieDuration": 0,
+               
+               /**
+                * The cookie name prefix.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string
+                *  @default <i>Empty string</i>
+                */
+               "sCookiePrefix": "",
+               
+               /**
+                * Callback function for cookie creation.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type function
+                *  @default null
+                */
+               "fnCookieCallback": null,
+               
+               /**
+                * Array of callback functions for state saving. Each array element is an 
+                * object with the following parameters:
+                *   <ul>
+                *     <li>function:fn - function to call. Takes two parameters, oSettings
+                *       and the JSON string to save that has been thus far created. Returns
+                *       a JSON string to be inserted into a json object 
+                *       (i.e. '"param": [ 0, 1, 2]')</li>
+                *     <li>string:sName - name of callback</li>
+                *   </ul>
+                *  @type array
+                *  @default []
+                */
+               "aoStateSave": [],
+               
+               /**
+                * Array of callback functions for state loading. Each array element is an 
+                * object with the following parameters:
+                *   <ul>
+                *     <li>function:fn - function to call. Takes two parameters, oSettings 
+                *       and the object stored. May return false to cancel state loading</li>
+                *     <li>string:sName - name of callback</li>
+                *   </ul>
+                *  @type array
+                *  @default []
+                */
+               "aoStateLoad": [],
+               
+               /**
+                * State that was loaded from the cookie. Useful for back reference
+                *  @type object
+                *  @default null
+                */
+               "oLoadedState": null,
+               
+               /**
+                * Source url for AJAX data for the table.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string
+                *  @default null
+                */
+               "sAjaxSource": null,
+               
+               /**
+                * Property from a given object from which to read the table data from. This
+                * can be an empty string (when not server-side processing), in which case 
+                * it is  assumed an an array is given directly.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string
+                */
+               "sAjaxDataProp": null,
+               
+               /**
+                * Note if draw should be blocked while getting data
+                *  @type boolean
+                *  @default true
+                */
+               "bAjaxDataGet": true,
+               
+               /**
+                * The last jQuery XHR object that was used for server-side data gathering. 
+                * This can be used for working with the XHR information in one of the 
+                * callbacks
+                *  @type object
+                *  @default null
+                */
+               "jqXHR": null,
+               
+               /**
+                * Function to get the server-side data.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type function
+                */
+               "fnServerData": null,
+               
+               /**
+                * Functions which are called prior to sending an Ajax request so extra 
+                * parameters can easily be sent to the server
+                *  @type array
+                *  @default []
+                */
+               "aoServerParams": [],
+               
+               /**
+                * Send the XHR HTTP method - GET or POST (could be PUT or DELETE if 
+                * required).
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type string
+                */
+               "sServerMethod": null,
+               
+               /**
+                * Format numbers for display.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type function
+                */
+               "fnFormatNumber": null,
+               
+               /**
+                * List of options that can be used for the user selectable length menu.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type array
+                *  @default []
+                */
+               "aLengthMenu": null,
+               
+               /**
+                * Counter for the draws that the table does. Also used as a tracker for
+                * server-side processing
+                *  @type int
+                *  @default 0
+                */
+               "iDraw": 0,
+               
+               /**
+                * Indicate if a redraw is being done - useful for Ajax
+                *  @type boolean
+                *  @default false
+                */
+               "bDrawing": false,
+               
+               /**
+                * Draw index (iDraw) of the last error when parsing the returned data
+                *  @type int
+                *  @default -1
+                */
+               "iDrawError": -1,
+               
+               /**
+                * Paging display length
+                *  @type int
+                *  @default 10
+                */
+               "_iDisplayLength": 10,
+       
+               /**
+                * Paging start point - aiDisplay index
+                *  @type int
+                *  @default 0
+                */
+               "_iDisplayStart": 0,
+       
+               /**
+                * Paging end point - aiDisplay index. Use fnDisplayEnd rather than
+                * this property to get the end point
+                *  @type int
+                *  @default 10
+                *  @private
+                */
+               "_iDisplayEnd": 10,
+               
+               /**
+                * Server-side processing - number of records in the result set
+                * (i.e. before filtering), Use fnRecordsTotal rather than
+                * this property to get the value of the number of records, regardless of
+                * the server-side processing setting.
+                *  @type int
+                *  @default 0
+                *  @private
+                */
+               "_iRecordsTotal": 0,
+       
+               /**
+                * Server-side processing - number of records in the current display set
+                * (i.e. after filtering). Use fnRecordsDisplay rather than
+                * this property to get the value of the number of records, regardless of
+                * the server-side processing setting.
+                *  @type boolean
+                *  @default 0
+                *  @private
+                */
+               "_iRecordsDisplay": 0,
+               
+               /**
+                * Flag to indicate if jQuery UI marking and classes should be used.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type boolean
+                */
+               "bJUI": null,
+               
+               /**
+                * The classes to use for the table
+                *  @type object
+                *  @default {}
+                */
+               "oClasses": {},
+               
+               /**
+                * Flag attached to the settings object so you can check in the draw 
+                * callback if filtering has been done in the draw. Deprecated in favour of
+                * events.
+                *  @type boolean
+                *  @default false
+                *  @deprecated
+                */
+               "bFiltered": false,
+               
+               /**
+                * Flag attached to the settings object so you can check in the draw 
+                * callback if sorting has been done in the draw. Deprecated in favour of
+                * events.
+                *  @type boolean
+                *  @default false
+                *  @deprecated
+                */
+               "bSorted": false,
+               
+               /**
+                * Indicate that if multiple rows are in the header and there is more than 
+                * one unique cell per column, if the top one (true) or bottom one (false) 
+                * should be used for sorting / title by DataTables.
+                * Note that this parameter will be set by the initialisation routine. To
+                * set a default use {@link DataTable.defaults}.
+                *  @type boolean
+                */
+               "bSortCellsTop": null,
+               
+               /**
+                * Initialisation object that is used for the table
+                *  @type object
+                *  @default null
+                */
+               "oInit": null,
+               
+               /**
+                * Destroy callback functions - for plug-ins to attach themselves to the
+                * destroy so they can clean up markup and events.
+                *  @type array
+                *  @default []
+                */
+               "aoDestroyCallback": [],
+       
+               
+               /**
+                * Get the number of records in the current record set, before filtering
+                *  @type function
+                */
+               "fnRecordsTotal": function ()
+               {
+                       if ( this.oFeatures.bServerSide ) {
+                               return parseInt(this._iRecordsTotal, 10);
+                       } else {
+                               return this.aiDisplayMaster.length;
+                       }
+               },
+               
+               /**
+                * Get the number of records in the current record set, after filtering
+                *  @type function
+                */
+               "fnRecordsDisplay": function ()
+               {
+                       if ( this.oFeatures.bServerSide ) {
+                               return parseInt(this._iRecordsDisplay, 10);
+                       } else {
+                               return this.aiDisplay.length;
+                       }
+               },
+               
+               /**
+                * Set the display end point - aiDisplay index
+                *  @type function
+                *  @todo Should do away with _iDisplayEnd and calculate it on-the-fly here
+                */
+               "fnDisplayEnd": function ()
+               {
+                       if ( this.oFeatures.bServerSide ) {
+                               if ( this.oFeatures.bPaginate === false || this._iDisplayLength == -1 ) {
+                                       return this._iDisplayStart+this.aiDisplay.length;
+                               } else {
+                                       return Math.min( this._iDisplayStart+this._iDisplayLength, 
+                                               this._iRecordsDisplay );
+                               }
+                       } else {
+                               return this._iDisplayEnd;
+                       }
+               },
+               
+               /**
+                * The DataTables object for this table
+                *  @type object
+                *  @default null
+                */
+               "oInstance": null,
+               
+               /**
+                * Unique identifier for each instance of the DataTables object. If there
+                * is an ID on the table node, then it takes that value, otherwise an
+                * incrementing internal counter is used.
+                *  @type string
+                *  @default null
+                */
+               "sInstance": null,
+       
+               /**
+                * tabindex attribute value that is added to DataTables control elements, allowing
+                * keyboard navigation of the table and its controls.
+                */
+               "iTabIndex": 0,
+       
+               /**
+                * DIV container for the footer scrolling table if scrolling
+                */
+               "nScrollHead": null,
+       
+               /**
+                * DIV container for the footer scrolling table if scrolling
+                */
+               "nScrollFoot": null
+       };
+
+       /**
+        * Extension object for DataTables that is used to provide all extension options.
+        * 
+        * Note that the <i>DataTable.ext</i> object is available through
+        * <i>jQuery.fn.dataTable.ext</i> where it may be accessed and manipulated. It is
+        * also aliased to <i>jQuery.fn.dataTableExt</i> for historic reasons.
+        *  @namespace
+        *  @extends DataTable.models.ext
+        */
+       DataTable.ext = $.extend( true, {}, DataTable.models.ext );
+       
+       $.extend( DataTable.ext.oStdClasses, {
+               "sTable": "dataTable",
+       
+               /* Two buttons buttons */
+               "sPagePrevEnabled": "paginate_enabled_previous",
+               "sPagePrevDisabled": "paginate_disabled_previous",
+               "sPageNextEnabled": "paginate_enabled_next",
+               "sPageNextDisabled": "paginate_disabled_next",
+               "sPageJUINext": "",
+               "sPageJUIPrev": "",
+               
+               /* Full numbers paging buttons */
+               "sPageButton": "paginate_button",
+               "sPageButtonActive": "paginate_active",
+               "sPageButtonStaticDisabled": "paginate_button paginate_button_disabled",
+               "sPageFirst": "first",
+               "sPagePrevious": "previous",
+               "sPageNext": "next",
+               "sPageLast": "last",
+               
+               /* Striping classes */
+               "sStripeOdd": "odd",
+               "sStripeEven": "even",
+               
+               /* Empty row */
+               "sRowEmpty": "dataTables_empty",
+               
+               /* Features */
+               "sWrapper": "dataTables_wrapper",
+               "sFilter": "dataTables_filter",
+               "sInfo": "dataTables_info",
+               "sPaging": "dataTables_paginate paging_", /* Note that the type is postfixed */
+               "sLength": "dataTables_length",
+               "sProcessing": "dataTables_processing",
+               
+               /* Sorting */
+               "sSortAsc": "sorting_asc",
+               "sSortDesc": "sorting_desc",
+               "sSortable": "sorting", /* Sortable in both directions */
+               "sSortableAsc": "sorting_asc_disabled",
+               "sSortableDesc": "sorting_desc_disabled",
+               "sSortableNone": "sorting_disabled",
+               "sSortColumn": "sorting_", /* Note that an int is postfixed for the sorting order */
+               "sSortJUIAsc": "",
+               "sSortJUIDesc": "",
+               "sSortJUI": "",
+               "sSortJUIAscAllowed": "",
+               "sSortJUIDescAllowed": "",
+               "sSortJUIWrapper": "",
+               "sSortIcon": "",
+               
+               /* Scrolling */
+               "sScrollWrapper": "dataTables_scroll",
+               "sScrollHead": "dataTables_scrollHead",
+               "sScrollHeadInner": "dataTables_scrollHeadInner",
+               "sScrollBody": "dataTables_scrollBody",
+               "sScrollFoot": "dataTables_scrollFoot",
+               "sScrollFootInner": "dataTables_scrollFootInner",
+               
+               /* Misc */
+               "sFooterTH": "",
+               "sJUIHeader": "",
+               "sJUIFooter": ""
+       } );
+       
+       
+       $.extend( DataTable.ext.oJUIClasses, DataTable.ext.oStdClasses, {
+               /* Two buttons buttons */
+               "sPagePrevEnabled": "fg-button ui-button ui-state-default ui-corner-left",
+               "sPagePrevDisabled": "fg-button ui-button ui-state-default ui-corner-left ui-state-disabled",
+               "sPageNextEnabled": "fg-button ui-button ui-state-default ui-corner-right",
+               "sPageNextDisabled": "fg-button ui-button ui-state-default ui-corner-right ui-state-disabled",
+               "sPageJUINext": "ui-icon ui-icon-circle-arrow-e",
+               "sPageJUIPrev": "ui-icon ui-icon-circle-arrow-w",
+               
+               /* Full numbers paging buttons */
+               "sPageButton": "fg-button ui-button ui-state-default",
+               "sPageButtonActive": "fg-button ui-button ui-state-default ui-state-disabled",
+               "sPageButtonStaticDisabled": "fg-button ui-button ui-state-default ui-state-disabled",
+               "sPageFirst": "first ui-corner-tl ui-corner-bl",
+               "sPageLast": "last ui-corner-tr ui-corner-br",
+               
+               /* Features */
+               "sPaging": "dataTables_paginate fg-buttonset ui-buttonset fg-buttonset-multi "+
+                       "ui-buttonset-multi paging_", /* Note that the type is postfixed */
+               
+               /* Sorting */
+               "sSortAsc": "ui-state-default",
+               "sSortDesc": "ui-state-default",
+               "sSortable": "ui-state-default",
+               "sSortableAsc": "ui-state-default",
+               "sSortableDesc": "ui-state-default",
+               "sSortableNone": "ui-state-default",
+               "sSortJUIAsc": "css_right ui-icon ui-icon-triangle-1-n",
+               "sSortJUIDesc": "css_right ui-icon ui-icon-triangle-1-s",
+               "sSortJUI": "css_right ui-icon ui-icon-carat-2-n-s",
+               "sSortJUIAscAllowed": "css_right ui-icon ui-icon-carat-1-n",
+               "sSortJUIDescAllowed": "css_right ui-icon ui-icon-carat-1-s",
+               "sSortJUIWrapper": "DataTables_sort_wrapper",
+               "sSortIcon": "DataTables_sort_icon",
+               
+               /* Scrolling */
+               "sScrollHead": "dataTables_scrollHead ui-state-default",
+               "sScrollFoot": "dataTables_scrollFoot ui-state-default",
+               
+               /* Misc */
+               "sFooterTH": "ui-state-default",
+               "sJUIHeader": "fg-toolbar ui-toolbar ui-widget-header ui-corner-tl ui-corner-tr ui-helper-clearfix",
+               "sJUIFooter": "fg-toolbar ui-toolbar ui-widget-header ui-corner-bl ui-corner-br ui-helper-clearfix"
+       } );
+       
+       /*
+        * Variable: oPagination
+        * Purpose:  
+        * Scope:    jQuery.fn.dataTableExt
+        */
+       $.extend( DataTable.ext.oPagination, {
+               /*
+                * Variable: two_button
+                * Purpose:  Standard two button (forward/back) pagination
+                * Scope:    jQuery.fn.dataTableExt.oPagination
+                */
+               "two_button": {
+                       /*
+                        * Function: oPagination.two_button.fnInit
+                        * Purpose:  Initialise dom elements required for pagination with forward/back buttons only
+                        * Returns:  -
+                        * Inputs:   object:oSettings - dataTables settings object
+                        *           node:nPaging - the DIV which contains this pagination control
+                        *           function:fnCallbackDraw - draw function which must be called on update
+                        */
+                       "fnInit": function ( oSettings, nPaging, fnCallbackDraw )
+                       {
+                               var oLang = oSettings.oLanguage.oPaginate;
+                               var oClasses = oSettings.oClasses;
+                               var fnClickHandler = function ( e ) {
+                                       if ( oSettings.oApi._fnPageChange( oSettings, e.data.action ) )
+                                       {
+                                               fnCallbackDraw( oSettings );
+                                       }
+                               };
+       
+                               var sAppend = (!oSettings.bJUI) ?
+                                       '<a class="'+oSettings.oClasses.sPagePrevDisabled+'" tabindex="'+oSettings.iTabIndex+'" role="button">'+oLang.sPrevious+'</a>'+
+                                       '<a class="'+oSettings.oClasses.sPageNextDisabled+'" tabindex="'+oSettings.iTabIndex+'" role="button">'+oLang.sNext+'</a>'
+                                       :
+                                       '<a class="'+oSettings.oClasses.sPagePrevDisabled+'" tabindex="'+oSettings.iTabIndex+'" role="button"><span class="'+oSettings.oClasses.sPageJUIPrev+'"></span></a>'+
+                                       '<a class="'+oSettings.oClasses.sPageNextDisabled+'" tabindex="'+oSettings.iTabIndex+'" role="button"><span class="'+oSettings.oClasses.sPageJUINext+'"></span></a>';
+                               $(nPaging).append( sAppend );
+                               
+                               var els = $('a', nPaging);
+                               var nPrevious = els[0],
+                                       nNext = els[1];
+                               
+                               oSettings.oApi._fnBindAction( nPrevious, {action: "previous"}, fnClickHandler );
+                               oSettings.oApi._fnBindAction( nNext,     {action: "next"},     fnClickHandler );
+                               
+                               /* ID the first elements only */
+                               if ( !oSettings.aanFeatures.p )
+                               {
+                                       nPaging.id = oSettings.sTableId+'_paginate';
+                                       nPrevious.id = oSettings.sTableId+'_previous';
+                                       nNext.id = oSettings.sTableId+'_next';
+       
+                                       nPrevious.setAttribute('aria-controls', oSettings.sTableId);
+                                       nNext.setAttribute('aria-controls', oSettings.sTableId);
+                               }
+                       },
+                       
+                       /*
+                        * Function: oPagination.two_button.fnUpdate
+                        * Purpose:  Update the two button pagination at the end of the draw
+                        * Returns:  -
+                        * Inputs:   object:oSettings - dataTables settings object
+                        *           function:fnCallbackDraw - draw function to call on page change
+                        */
+                       "fnUpdate": function ( oSettings, fnCallbackDraw )
+                       {
+                               if ( !oSettings.aanFeatures.p )
+                               {
+                                       return;
+                               }
+                               
+                               var oClasses = oSettings.oClasses;
+                               var an = oSettings.aanFeatures.p;
+                               var nNode;
+       
+                               /* Loop over each instance of the pager */
+                               for ( var i=0, iLen=an.length ; i<iLen ; i++ )
+                               {
+                                       nNode = an[i].firstChild;
+                                       if ( nNode )
+                                       {
+                                               /* Previous page */
+                                               nNode.className = ( oSettings._iDisplayStart === 0 ) ?
+                                                   oClasses.sPagePrevDisabled : oClasses.sPagePrevEnabled;
+                                                   
+                                               /* Next page */
+                                               nNode = nNode.nextSibling;
+                                               nNode.className = ( oSettings.fnDisplayEnd() == oSettings.fnRecordsDisplay() ) ?
+                                                   oClasses.sPageNextDisabled : oClasses.sPageNextEnabled;
+                                       }
+                               }
+                       }
+               },
+               
+               
+               /*
+                * Variable: iFullNumbersShowPages
+                * Purpose:  Change the number of pages which can be seen
+                * Scope:    jQuery.fn.dataTableExt.oPagination
+                */
+               "iFullNumbersShowPages": 5,
+               
+               /*
+                * Variable: full_numbers
+                * Purpose:  Full numbers pagination
+                * Scope:    jQuery.fn.dataTableExt.oPagination
+                */
+               "full_numbers": {
+                       /*
+                        * Function: oPagination.full_numbers.fnInit
+                        * Purpose:  Initialise dom elements required for pagination with a list of the pages
+                        * Returns:  -
+                        * Inputs:   object:oSettings - dataTables settings object
+                        *           node:nPaging - the DIV which contains this pagination control
+                        *           function:fnCallbackDraw - draw function which must be called on update
+                        */
+                       "fnInit": function ( oSettings, nPaging, fnCallbackDraw )
+                       {
+                               var oLang = oSettings.oLanguage.oPaginate;
+                               var oClasses = oSettings.oClasses;
+                               var fnClickHandler = function ( e ) {
+                                       if ( oSettings.oApi._fnPageChange( oSettings, e.data.action ) )
+                                       {
+                                               fnCallbackDraw( oSettings );
+                                       }
+                               };
+       
+                               $(nPaging).append(
+                                       '<a  tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButton+" "+oClasses.sPageFirst+'">'+oLang.sFirst+'</a>'+
+                                       '<a  tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButton+" "+oClasses.sPagePrevious+'">'+oLang.sPrevious+'</a>'+
+                                       '<span></span>'+
+                                       '<a tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButton+" "+oClasses.sPageNext+'">'+oLang.sNext+'</a>'+
+                                       '<a tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButton+" "+oClasses.sPageLast+'">'+oLang.sLast+'</a>'
+                               );
+                               var els = $('a', nPaging);
+                               var nFirst = els[0],
+                                       nPrev = els[1],
+                                       nNext = els[2],
+                                       nLast = els[3];
+                               
+                               oSettings.oApi._fnBindAction( nFirst, {action: "first"},    fnClickHandler );
+                               oSettings.oApi._fnBindAction( nPrev,  {action: "previous"}, fnClickHandler );
+                               oSettings.oApi._fnBindAction( nNext,  {action: "next"},     fnClickHandler );
+                               oSettings.oApi._fnBindAction( nLast,  {action: "last"},     fnClickHandler );
+                               
+                               /* ID the first elements only */
+                               if ( !oSettings.aanFeatures.p )
+                               {
+                                       nPaging.id = oSettings.sTableId+'_paginate';
+                                       nFirst.id =oSettings.sTableId+'_first';
+                                       nPrev.id =oSettings.sTableId+'_previous';
+                                       nNext.id =oSettings.sTableId+'_next';
+                                       nLast.id =oSettings.sTableId+'_last';
+                               }
+                       },
+                       
+                       /*
+                        * Function: oPagination.full_numbers.fnUpdate
+                        * Purpose:  Update the list of page buttons shows
+                        * Returns:  -
+                        * Inputs:   object:oSettings - dataTables settings object
+                        *           function:fnCallbackDraw - draw function to call on page change
+                        */
+                       "fnUpdate": function ( oSettings, fnCallbackDraw )
+                       {
+                               if ( !oSettings.aanFeatures.p )
+                               {
+                                       return;
+                               }
+                               
+                               var iPageCount = DataTable.ext.oPagination.iFullNumbersShowPages;
+                               var iPageCountHalf = Math.floor(iPageCount / 2);
+                               var iPages = Math.ceil((oSettings.fnRecordsDisplay()) / oSettings._iDisplayLength);
+                               var iCurrentPage = Math.ceil(oSettings._iDisplayStart / oSettings._iDisplayLength) + 1;
+                               var sList = "";
+                               var iStartButton, iEndButton, i, iLen;
+                               var oClasses = oSettings.oClasses;
+                               var anButtons, anStatic, nPaginateList, nNode;
+                               var an = oSettings.aanFeatures.p;
+                               var fnBind = function (j) {
+                                       oSettings.oApi._fnBindAction( this, {"page": j+iStartButton-1}, function(e) {
+                                               /* Use the information in the element to jump to the required page */
+                                               oSettings.oApi._fnPageChange( oSettings, e.data.page );
+                                               fnCallbackDraw( oSettings );
+                                               e.preventDefault();
+                                       } );
+                               };
+                               
+                               /* Pages calculation */
+                               if ( oSettings._iDisplayLength === -1 )
+                               {
+                                       iStartButton = 1;
+                                       iEndButton = 1;
+                                       iCurrentPage = 1;
+                               }
+                               else if (iPages < iPageCount)
+                               {
+                                       iStartButton = 1;
+                                       iEndButton = iPages;
+                               }
+                               else if (iCurrentPage <= iPageCountHalf)
+                               {
+                                       iStartButton = 1;
+                                       iEndButton = iPageCount;
+                               }
+                               else if (iCurrentPage >= (iPages - iPageCountHalf))
+                               {
+                                       iStartButton = iPages - iPageCount + 1;
+                                       iEndButton = iPages;
+                               }
+                               else
+                               {
+                                       iStartButton = iCurrentPage - Math.ceil(iPageCount / 2) + 1;
+                                       iEndButton = iStartButton + iPageCount - 1;
+                               }
+       
+                               
+                               /* Build the dynamic list */
+                               for ( i=iStartButton ; i<=iEndButton ; i++ )
+                               {
+                                       sList += (iCurrentPage !== i) ?
+                                               '<a tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButton+'">'+oSettings.fnFormatNumber(i)+'</a>' :
+                                               '<a tabindex="'+oSettings.iTabIndex+'" class="'+oClasses.sPageButtonActive+'">'+oSettings.fnFormatNumber(i)+'</a>';
+                               }
+                               
+                               /* Loop over each instance of the pager */
+                               for ( i=0, iLen=an.length ; i<iLen ; i++ )
+                               {
+                                       nNode = an[i];
+                                       if ( !nNode.hasChildNodes() )
+                                       {
+                                               continue;
+                                       }
+                                       
+                                       /* Build up the dynamic list first - html and listeners */
+                                       $('span:eq(0)', nNode)
+                                               .html( sList )
+                                               .children('a').each( fnBind );
+                                       
+                                       /* Update the permanent button's classes */
+                                       anButtons = nNode.getElementsByTagName('a');
+                                       anStatic = [
+                                               anButtons[0], anButtons[1], 
+                                               anButtons[anButtons.length-2], anButtons[anButtons.length-1]
+                                       ];
+       
+                                       $(anStatic).removeClass( oClasses.sPageButton+" "+oClasses.sPageButtonActive+" "+oClasses.sPageButtonStaticDisabled );
+                                       $([anStatic[0], anStatic[1]]).addClass( 
+                                               (iCurrentPage==1) ?
+                                                       oClasses.sPageButtonStaticDisabled :
+                                                       oClasses.sPageButton
+                                       );
+                                       $([anStatic[2], anStatic[3]]).addClass(
+                                               (iPages===0 || iCurrentPage===iPages || oSettings._iDisplayLength===-1) ?
+                                                       oClasses.sPageButtonStaticDisabled :
+                                                       oClasses.sPageButton
+                                       );
+                               }
+                       }
+               }
+       } );
+       
+       $.extend( DataTable.ext.oSort, {
+               /*
+                * text sorting
+                */
+               "string-pre": function ( a )
+               {
+                       if ( typeof a != 'string' ) {
+                               a = (a !== null && a.toString) ? a.toString() : '';
+                       }
+                       return a.toLowerCase();
+               },
+       
+               "string-asc": function ( x, y )
+               {
+                       return ((x < y) ? -1 : ((x > y) ? 1 : 0));
+               },
+               
+               "string-desc": function ( x, y )
+               {
+                       return ((x < y) ? 1 : ((x > y) ? -1 : 0));
+               },
+               
+               
+               /*
+                * html sorting (ignore html tags)
+                */
+               "html-pre": function ( a )
+               {
+                       return a.replace( /<.*?>/g, "" ).toLowerCase();
+               },
+               
+               "html-asc": function ( x, y )
+               {
+                       return ((x < y) ? -1 : ((x > y) ? 1 : 0));
+               },
+               
+               "html-desc": function ( x, y )
+               {
+                       return ((x < y) ? 1 : ((x > y) ? -1 : 0));
+               },
+               
+               
+               /*
+                * date sorting
+                */
+               "date-pre": function ( a )
+               {
+                       var x = Date.parse( a );
+                       
+                       if ( isNaN(x) || x==="" )
+                       {
+                               x = Date.parse( "01/01/1970 00:00:00" );
+                       }
+                       return x;
+               },
+       
+               "date-asc": function ( x, y )
+               {
+                       return x - y;
+               },
+               
+               "date-desc": function ( x, y )
+               {
+                       return y - x;
+               },
+               
+               
+               /*
+                * numerical sorting
+                */
+               "numeric-pre": function ( a )
+               {
+                       return (a=="-" || a==="") ? 0 : a*1;
+               },
+       
+               "numeric-asc": function ( x, y )
+               {
+                       return x - y;
+               },
+               
+               "numeric-desc": function ( x, y )
+               {
+                       return y - x;
+               }
+       } );
+       
+       
+       $.extend( DataTable.ext.aTypes, [
+               /*
+                * Function: -
+                * Purpose:  Check to see if a string is numeric
+                * Returns:  string:'numeric' or null
+                * Inputs:   mixed:sText - string to check
+                */
+               function ( sData )
+               {
+                       /* Allow zero length strings as a number */
+                       if ( typeof sData === 'number' )
+                       {
+                               return 'numeric';
+                       }
+                       else if ( typeof sData !== 'string' )
+                       {
+                               return null;
+                       }
+                       
+                       var sValidFirstChars = "0123456789-";
+                       var sValidChars = "0123456789.";
+                       var Char;
+                       var bDecimal = false;
+                       
+                       /* Check for a valid first char (no period and allow negatives) */
+                       Char = sData.charAt(0); 
+                       if (sValidFirstChars.indexOf(Char) == -1) 
+                       {
+                               return null;
+                       }
+                       
+                       /* Check all the other characters are valid */
+                       for ( var i=1 ; i<sData.length ; i++ ) 
+                       {
+                               Char = sData.charAt(i); 
+                               if (sValidChars.indexOf(Char) == -1) 
+                               {
+                                       return null;
+                               }
+                               
+                               /* Only allowed one decimal place... */
+                               if ( Char == "." )
+                               {
+                                       if ( bDecimal )
+                                       {
+                                               return null;
+                                       }
+                                       bDecimal = true;
+                               }
+                       }
+                       
+                       return 'numeric';
+               },
+               
+               /*
+                * Function: -
+                * Purpose:  Check to see if a string is actually a formatted date
+                * Returns:  string:'date' or null
+                * Inputs:   string:sText - string to check
+                */
+               function ( sData )
+               {
+                       var iParse = Date.parse(sData);
+                       if ( (iParse !== null && !isNaN(iParse)) || (typeof sData === 'string' && sData.length === 0) )
+                       {
+                               return 'date';
+                       }
+                       return null;
+               },
+               
+               /*
+                * Function: -
+                * Purpose:  Check to see if a string should be treated as an HTML string
+                * Returns:  string:'html' or null
+                * Inputs:   string:sText - string to check
+                */
+               function ( sData )
+               {
+                       if ( typeof sData === 'string' && sData.indexOf('<') != -1 && sData.indexOf('>') != -1 )
+                       {
+                               return 'html';
+                       }
+                       return null;
+               }
+       ] );
+       
+
+       // jQuery aliases
+       $.fn.DataTable = DataTable;
+       $.fn.dataTable = DataTable;
+       $.fn.dataTableSettings = DataTable.settings;
+       $.fn.dataTableExt = DataTable.ext;
+
+
+       // Information about events fired by DataTables - for documentation.
+       /**
+        * Draw event, fired whenever the table is redrawn on the page, at the same point as
+        * fnDrawCallback. This may be useful for binding events or performing calculations when
+        * the table is altered at all.
+        *  @name DataTable#draw
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        */
+
+       /**
+        * Filter event, fired when the filtering applied to the table (using the build in global
+        * global filter, or column filters) is altered.
+        *  @name DataTable#filter
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        */
+
+       /**
+        * Page change event, fired when the paging of the table is altered.
+        *  @name DataTable#page
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        */
+
+       /**
+        * Sort event, fired when the sorting applied to the table is altered.
+        *  @name DataTable#sort
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        */
+
+       /**
+        * DataTables initialisation complete event, fired when the table is fully drawn,
+        * including Ajax data loaded, if Ajax data is required.
+        *  @name DataTable#init
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} oSettings DataTables settings object
+        *  @param {object} json The JSON object request from the server - only
+        *    present if client-side Ajax sourced data is used</li></ol>
+        */
+
+       /**
+        * State save event, fired when the table has changed state a new state save is required.
+        * This method allows modification of the state saving object prior to actually doing the
+        * save, including addition or other state properties (for plug-ins) or modification
+        * of a DataTables core property.
+        *  @name DataTable#stateSaveParams
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} oSettings DataTables settings object
+        *  @param {object} json The state information to be saved
+        */
+
+       /**
+        * State load event, fired when the table is loading state from the stored data, but
+        * prior to the settings object being modified by the saved state - allowing modification
+        * of the saved state is required or loading of state for a plug-in.
+        *  @name DataTable#stateLoadParams
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} oSettings DataTables settings object
+        *  @param {object} json The saved state information
+        */
+
+       /**
+        * State loaded event, fired when state has been loaded from stored data and the settings
+        * object has been modified by the loaded data.
+        *  @name DataTable#stateLoaded
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} oSettings DataTables settings object
+        *  @param {object} json The saved state information
+        */
+
+       /**
+        * Processing event, fired when DataTables is doing some kind of processing (be it,
+        * sort, filter or anything else). Can be used to indicate to the end user that
+        * there is something happening, or that something has finished.
+        *  @name DataTable#processing
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} oSettings DataTables settings object
+        *  @param {boolean} bShow Flag for if DataTables is doing processing or not
+        */
+
+       /**
+        * Ajax (XHR) event, fired whenever an Ajax request is completed from a request to 
+        * made to the server for new data (note that this trigger is called in fnServerData,
+        * if you override fnServerData and which to use this event, you need to trigger it in
+        * you success function).
+        *  @name DataTable#xhr
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        *  @param {object} json JSON returned from the server
+        */
+
+       /**
+        * Destroy event, fired when the DataTable is destroyed by calling fnDestroy or passing
+        * the bDestroy:true parameter in the initialisation object. This can be used to remove
+        * bound events, added DOM nodes, etc.
+        *  @name DataTable#destroy
+        *  @event
+        *  @param {event} e jQuery event object
+        *  @param {object} o DataTables settings object {@link DataTable.models.oSettings}
+        */
+}));
+
+}(window, document));
+
index cc800b74ae1a56624aad17e6c22947afe3feab7f..26e251e6c8c0d8d1823645d513f3e865b5e67d25 100644 (file)
@@ -154,13 +154,15 @@ COMPRESS_STORAGE = DEFAULT_FILE_STORAGE
 
 # See: http://django_compressor.readthedocs.org/en/latest/settings/#django.conf.settings.COMPRESS_CSS_FILTERS
 COMPRESS_CSS_FILTERS += [
-    'compressor.filters.cssmin.CSSMinFilter',
+    'compressor.filters.css_default.CssAbsoluteFilter',
 ]
 
 # See: http://django_compressor.readthedocs.org/en/latest/settings/#django.conf.settings.COMPRESS_JS_FILTERS
 COMPRESS_JS_FILTERS += [
-    'compressor.filters.jsmin.JSMinFilter',
+    'compressor.filters.closure.ClosureCompilerFilter',
 ]
+COMPRESS_CLOSURE_COMPILER_BINARY = 'closure'
+
 ########## END COMPRESSION CONFIGURATION
 
 
index 4f1b3c4b8ca8f3e52b488a88cb29f5056b262de5..c8b19ca3430ac99d6a71b6d13a07bdf442ead495 100644 (file)
@@ -1,9 +1,12 @@
 {% extends "base.html" %}
 {% load url from future %}
 {% load humanize %}
+{% load compress %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/about.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/about.css">
+  {% endcompress %}
 {% endblock %}
 
 {% block title %}
index 9bf6450e9952cdb81db417e0e396ae536d816829..2a5a8a4db20c02e200b7d9fe5920c4d249203967 100644 (file)
@@ -9,11 +9,13 @@
        
   <link rel="shortcut icon" href="{{ STATIC_URL }}img/favicon.ico">
   {% compress css %}
-    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/fontface/fontface.css">
-    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/foundation.min.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/fontface.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/foundation.css">
     <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/jquery-ui.css">
-    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/font-awesome/css/font-awesome.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/font-awesome.css">
     <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/opentip.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}ajax_select/css/ajax_select.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/jquery.dataTables.css">
     <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/global.css">
   {% endcompress %}
   {% compress js %}
     <script type="text/javascript" src="{{ STATIC_URL }}js/jquery-ui-1.10.4.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/fastclick.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/opentip-jquery.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/jquery.cookie.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.joyride.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.tab.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.alert.js"></script>
     <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.topbar.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/foundation.reveal.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}ajax_select/js/ajax_select.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}ajax_select_cascade/js/ajax_select_cascade.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/jquery.dataTables.js"></script>
   {% endcompress %}
 
   <script type="text/javascript" src="//use.typekit.net/pnc8diw.js"></script>
index b7ad71244daa5d76f3504e67f5ca603139d9164a..131e3ecd79d16399bf5b3876e627a6651ab12526 100644 (file)
@@ -1,9 +1,8 @@
 {% extends "base.html" %}
 {% load url from future %}
-
+{% load compress %}
 
 {% block pagescripts %}
-  <script src="{{ STATIC_URL }}js/setup-ajax.js"></script>
   <script>
     var json_school_course_list = "{% url 'json_school_course_list' %}";
     var json_school_course_instructor_list = "{% url 'json_school_course_instructor_list' %}";
     var course_edit_url = "{% url 'edit_course' course.id %}";
     var dataTable_sDom = '<"top">rt<"bottom"p><"clear">';
   </script>
-  <script src="{{ STATIC_URL }}js/jquery.dataTables.min.js"></script>
-  <script src="{{ STATIC_URL }}js/course.js"></script>
-  <script src="{{ STATIC_URL }}js/course-detail.js" ></script>
-  <script src="{{ STATIC_URL }}js/note-list.js" ></script>
-  <script src="{{ STATIC_URL }}js/filepicker.js"></script>
+  {% compress js %}
+    <script src="{{ STATIC_URL }}js/setup-ajax.js"></script>
+    <script src="{{ STATIC_URL }}js/course.js"></script>
+    <script src="{{ STATIC_URL }}js/course-detail.js" ></script>
+    <script src="{{ STATIC_URL }}js/note-list.js" ></script>
+    <script src="{{ STATIC_URL }}js/filepicker.js"></script>
+  {% endcompress %}
 {% endblock %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/datatables-css/jquery.dataTables.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
+  {% endcompress %}
 {% endblock %}
 
 {% block title %}
index 9843904105e276080e2ffb56512aec5ad68459ae..9f157936aa60738ce92fb977ab528c7df08fe8d2 100644 (file)
@@ -1,13 +1,15 @@
 {% extends "base.html" %}
 {% load url from future %}
+{% load compress %}
 
 {% block title %}
   Share College Course Notes
 {% endblock %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="//cdnjs.cloudflare.com/ajax/libs/datatables/1.9.4/css/jquery.dataTables.min.css">
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/home.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/home.css">
+  {% endcompress %}
 {% endblock %}
 
 {% block pagescripts %}
     var csrf_token = "{{ csrf_token }}";
     var dataTable_sDom = '<"top">rt<"bottom"p><"clear">';
   </script>
-  <script src="//cdnjs.cloudflare.com/ajax/libs/datatables/1.9.4/jquery.dataTables.min.js"></script>
-  <script src="{{ STATIC_URL }}js/setup-ajax.js"></script>
-  <script src="{{ STATIC_URL }}js/course.js"></script>
-  <script src="{{ STATIC_URL }}js/add-course.js"></script>
-  <script src="{{ STATIC_URL }}js/course-list.js"></script>
+  {% compress js %}
+    <script type="text/javascript" src="{{ STATIC_URL }}js/setup-ajax.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/course.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/add-course.js"></script>
+    <script type="text/javascript" src="{{ STATIC_URL }}js/course-list.js"></script>
+  {% endcompress %}
 {% endblock %}
 
 {% block raw_content %}
-<section id="home_content">
-  <div id="page_header">
-    <div id="splash" class="museo700">
-      <div id="splash_copy" class="row">
-        <div class="small-12 large-8 columns large-offset-2">
-          Access a growing database of <span class="note_count">{{ note_count }}</span> college lecture notes.
+  <section id="home_content">
+    <div id="page_header">
+      <div id="splash" class="museo700">
+        <div id="splash_copy" class="row">
+          <div class="small-12 large-8 columns large-offset-2">
+            Access a growing database of <span class="note_count">{{ note_count }}</span> college lecture notes.
+          </div>
         </div>
-      </div>
-      <div class="row">
-        <div class="small-12 columns">
-          <a href="{% url 'about' %}">
-            <button id="intro-video-button">Watch the video&nbsp;&nbsp;<i class='fa fa-caret-right'></i></button>
-          </a>
+        <div class="row">
+          <div class="small-12 columns">
+            <a href="{% url 'about' %}">
+              <button id="intro-video-button">Watch the video&nbsp;&nbsp;<i class='fa fa-caret-right'></i></button>
+            </a>
+          </div>
         </div>
       </div>
     </div>
-  </div>
 
-  <div id="course-search-bar">
-    <div class="row">
-      <div class="small-12 large-2 columns">
-        <button id="add-course-btn" class="inline-button important" data-reveal-id="add-course-form">Add a Course</button>
-      </div>
-      <div class="small-12 large-6 columns">
-        <input class="search-courses" type="text" placeholder="Search Courses and Schools" />
-      </div>
-      <div class="large-4 columns show-for-large-up">
-        <div id="course-sort-wrapper">
-          Sort By
-          <select class="course-sort">
-            <option value="0">Date</option>
-            <option value="1">Number of Notes</option>
-            <option value="2" selected>Popularity</option>
-            <option value="3">School</option>
-          </select>
+    <div id="course-search-bar">
+      <div class="row">
+        <div class="small-12 large-2 columns">
+          <button id="add-course-btn" class="inline-button important" data-reveal-id="add-course-form">Add a Course</button>
+        </div>
+        <div class="small-12 large-6 columns">
+          <input class="search-courses" type="text" placeholder="Search Courses and Schools" />
+        </div>
+        <div class="large-4 columns show-for-large-up">
+          <div id="course-sort-wrapper">
+            Sort By
+            <select class="course-sort">
+              <option value="0">Date</option>
+              <option value="1">Number of Notes</option>
+              <option value="2" selected>Popularity</option>
+              <option value="3">School</option>
+            </select>
+          </div>
         </div>
       </div>
     </div>
-  </div>
 
-  <div class="row">
-    <div class="small-12 columns">
-      <!-- Main course table -->
-      <table id="data_table_list">
-        <thead class="hide">
-          <tr>
-            <th class="no-display" id="data-table-date">Date</th>
-            <th class="no-display" id="data-table-note-count"># Notes</th>
-            <th class="no-display" id="data-table-thanks">Popularity</th>
-            <th class="no-display" id="data-table-school">School</th>
-            <th class="no-display" id="data-table-course">Course</th>
-          </tr>
-        </thead>
-        <tbody>
-        {% for course in course_list %}
-          {% include 'courses/course_list_entry.html' %}
-        {% endfor %}
-        </tbody>
-      </table>
-    </div>
-  </div> <!-- .row -->
+    <div class="row">
+      <div class="small-12 columns">
+        <!-- Main course table -->
+        <table id="data_table_list">
+          <thead class="hide">
+            <tr>
+              <th class="no-display" id="data-table-date">Date</th>
+              <th class="no-display" id="data-table-note-count"># Notes</th>
+              <th class="no-display" id="data-table-thanks">Popularity</th>
+              <th class="no-display" id="data-table-school">School</th>
+              <th class="no-display" id="data-table-course">Course</th>
+            </tr>
+          </thead>
+          <tbody>
+          {% for course in course_list %}
+            {% include 'courses/course_list_entry.html' %}
+          {% endfor %}
+          </tbody>
+        </table>
+      </div>
+    </div> <!-- .row -->
 
-  {% include 'partial/add_course.html' %}
+    {% include 'partial/add_course.html' %}
 
-</section> <!-- #results_content -->
+  </section> <!-- #results_content -->
 
 {% endblock %}
 
index 0c077190c90dd921208beb91394d5ba2f4cadedf..5a951dac7fd5dd528570f6d18fd1fdd34e907c21 100644 (file)
@@ -1,14 +1,16 @@
 {% extends "base.html" %}
 {% load url from future %}
+{% load compress %}
 
 {% block title %}
   {{ note.name }}
 {% endblock %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
-  <link type="text/css" rel="stylesheet" href="{{ STATIC_URL }}css/annotator.min.css" />
-  <link rel="stylesheet" type="text/css" media="all" href="//cdnjs.cloudflare.com/ajax/libs/datatables/1.9.4/css/jquery.dataTables.min.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/annotator.min.css" />
+  {% endcompress %}
 {% endblock %}
 
 {% block pagescripts %}
     var setup_ajax_url = "{{ STATIC_URL }}js/setup-ajax.js";
     var empty_js = "{{ STATIC_URL }}js/empty.js";
   </script>
-  <script src="{{ STATIC_URL }}js/setup-ajax.js"></script>
-  <script src="{{ STATIC_URL }}js/note-detail.js" ></script>
-  <script src="{{ STATIC_URL }}js/pxem.jQuery.js"></script>
-  <script src="//cdnjs.cloudflare.com/ajax/libs/marked/0.3.1/marked.min.js" ></script>
-  <script src="{{ STATIC_URL }}js/annotator-full.min.js"></script>
-  <script src="//cdnjs.cloudflare.com/ajax/libs/jquery-cookie/1.4.0/jquery.cookie.min.js"></script>
-  <script src="//cdnjs.cloudflare.com/ajax/libs/datatables/1.9.4/jquery.dataTables.min.js"></script>
+  {% compress js %}
+    <script src="{{ STATIC_URL }}js/setup-ajax.js"></script>
+    <script src="{{ STATIC_URL }}js/note-detail.js" ></script>
+    <script src="{{ STATIC_URL }}js/pxem.jQuery.js"></script>
+    <script src="{{ STATIC_URL }}js/marked.js" ></script>
+    <script src="{{ STATIC_URL }}js/annotator-full.min.js"></script>
+  {% endcompress %}
   <script>
     $(function() {
       $(document).foundation('joyride', 'start');
index b82ec12f378d092d06281053cc613a5d6be999c8..dc82ec04f5dfb29026d818d44c6b3eed0e6346dc 100644 (file)
@@ -1,18 +1,21 @@
 {% extends "base.html" %}
 {% load url from future %}
+{% load compress %}
 
 {% block title %}
   Search Results
 {% endblock %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/datatables-css/jquery.dataTables.css">
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/note_course_pages.css">
+  {% endcompress %}
 {% endblock %}
 
 {% block pagescripts %}
-  <script src="{{ STATIC_URL }}js/jquery.dataTables.min.js"></script>
-  <script src="{{ STATIC_URL }}js/note-list.js"></script>
+  {% compress js %}
+    <script src="{{ STATIC_URL }}js/note-list.js"></script>
+  {% endcompress %}
   <script>
     var dataTable_sDom = '<"top">rt<"bottom"><"clear">';
   </script>
index c6ca20c16836a8a09c56a979d436a826db4f07ef..01e428314ade76ceb8ba5eb8e9e688ec4d661bab 100644 (file)
@@ -1,7 +1,5 @@
 {% load url from future %}
 
-{{ course_form.media }}
-
 <section id="add-course-form" class="reveal-modal" data-reveal>
   <a class="close-reveal-modal">&#215;</a>
 
index 540f53e8497458f17edd124e9a8881935cc65aa5..30cd60ce1456efa51ab33fe0505ad1a96cbf9db8 100644 (file)
@@ -1,9 +1,12 @@
 {% extends "base.html" %}
 {% load url from future %}
 {% load humanize %}
+{% load compress %}
 
 {% block pagestyle %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/about.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/about.css">
+  {% endcompress %}
 {% endblock %}
 
 
index a9376edc8b0cb3c60d7e7f83284d87238253f182..2c35480aa2862d282da58f8adb306232c609a0d4 100644 (file)
@@ -2,9 +2,12 @@
 {% load url from future %}
 {% load account %}
 {% load social_account_list %}
+{% load compress %}
 
 {% block pagescripts %}
-  <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/dashboard.css">
+  {% compress css %}
+    <link rel="stylesheet" type="text/css" media="all" href="{{ STATIC_URL }}css/dashboard.css">
+  {% endcompress %}
 {% endblock %}
 
 {% block title %}