diff --git a/README.md b/README.md
index 42dd90eb294aa6063108d6fbf78ef7ee9ac42ff4..f84140acca9062303128ac6cfbd9f292f6ed0e92 100644
--- a/README.md
+++ b/README.md
@@ -7,7 +7,7 @@ It offers both a simple HTTP API for search, and a normal website for the same p
 Setting up search backends
 --------------------------
 
-#### pgsql-smart
+####pgsql-smart
 
 First, add a new column to the backlog table:
 
diff --git a/api/backlog/index.php b/api/backlog/index.php
index 557b4cea5687f98359191440f0bd6ac158b8ecab..25cd8b1398af622ef3ef93ca235cd096b14a60a7 100644
--- a/api/backlog/index.php
+++ b/api/backlog/index.php
@@ -9,11 +9,11 @@ require_once '../../backend/helper/SessionHelper.php';
 
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 try {
     $backend->authenticateFromHeader($_SERVER['HTTP_AUTHORIZATION'] ?: "");
-    $renderer->renderJson($backend->context($_GET['anchor'] ?: 0, $_GET['buffer'] ?: 0, $_GET['before'], $_GET['after']));
+    $renderer->renderJson($backend->context($_REQUEST['anchor'] ?: 0, $_REQUEST['buffer'] ?: 0, $_REQUEST['before'], $_REQUEST['after']));
 } catch (\Exception $e) {
     $renderer->renderJson(["error" => $e->getMessage()]);
 }
\ No newline at end of file
diff --git a/api/search/index.php b/api/search/index.php
index bd996519f91de6c9a74579f79cd981693d995080..9d3fccc15c175f2c03904646a22bb8eedf674642 100644
--- a/api/search/index.php
+++ b/api/search/index.php
@@ -9,11 +9,11 @@ require_once '../../backend/helper/SessionHelper.php';
 
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 try {
     $backend->authenticateFromHeader($_SERVER['HTTP_AUTHORIZATION'] ?: "");
-    $renderer->renderJson($backend->findBuffers($_GET['q'] ?: "", $_GET['since'] ?: null, $_GET['before'] ?: null, $_GET['buffer'] ?: null, $_GET['network'] ?: null));
+    $renderer->renderJson($backend->findBuffers($_REQUEST['query'] ?: "", $_REQUEST['since'] ?: null, $_REQUEST['before'] ?: null, $_REQUEST['buffer'] ?: null, $_REQUEST['network'] ?: null));
 } catch (\Exception $e) {
     $renderer->renderJson(["error" => $e->getMessage()]);
 }
\ No newline at end of file
diff --git a/api/searchbuffer/index.php b/api/searchbuffer/index.php
index 6fefe5e5c483fbc322882f756d2005ccebd156e5..73b119ebfdd4bab112a1753720a67152acdd1f96 100644
--- a/api/searchbuffer/index.php
+++ b/api/searchbuffer/index.php
@@ -9,11 +9,11 @@ require_once '../../backend/helper/SessionHelper.php';
 
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 try {
     $backend->authenticateFromHeader($_SERVER['HTTP_AUTHORIZATION'] ?: "");
-    $renderer->renderJson($backend->findInBuffer($_GET['query'] ?: "", $_GET['since'] ?: null, $_GET['before'] ?: null, $_GET['buffer'] ?: 0, $_GET['offset'] ?: 0, $_GET['limit'] ?: 20));
+    $renderer->renderJson($backend->findInBuffer($_REQUEST['query'] ?: "", $_REQUEST['since'] ?: null, $_REQUEST['before'] ?: null, $_REQUEST['buffer'] ?: 0, $_REQUEST['offset'] ?: 0, $_REQUEST['limit'] ?: 20));
 } catch (\Exception $e) {
     $renderer->renderJson(["error" => $e->getMessage()]);
 }
\ No newline at end of file
diff --git a/api/searchbuffers/index.php b/api/searchbuffers/index.php
index ef0727a709c15fcf90fbec5158e427aeb14a95a8..11f14a2437d93310d350807e35d05feb95f8912d 100644
--- a/api/searchbuffers/index.php
+++ b/api/searchbuffers/index.php
@@ -9,11 +9,11 @@ require_once '../../backend/helper/SessionHelper.php';
 
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 try {
     $backend->authenticateFromHeader($_SERVER['HTTP_AUTHORIZATION'] ?: "");
-    $renderer->renderJson($backend->findInBufferMultiple($_GET['q'] ?: "", $_GET['since'] ?: null, $_GET['before'] ?: null, $_GET['limit'] ?: 4));
+    $renderer->renderJson($backend->findInBufferMultiple($_REQUEST['q'] ?: "", $_REQUEST['since'] ?: null, $_REQUEST['before'] ?: null, $_REQUEST['limit'] ?: 4));
 } catch (\Exception $e) {
     $renderer->renderJson(["error" => $e->getMessage()]);
 }
\ No newline at end of file
diff --git a/backend/Database.php b/backend/Database.php
index 34ca513a7a8339c559d998fabf380b7ab8e1d98b..18dfb5ff133bdfc64937636cdd03e2f96f10d93c 100644
--- a/backend/Database.php
+++ b/backend/Database.php
@@ -8,7 +8,7 @@ require_once 'User.php';
 require_once 'Config.php';
 require_once 'helper/AuthHelper.php';
 
-class Backend {
+class Database {
     private $storedFindBuffers;
     private $storedFindInBuffer;
     private $loadBefore;
@@ -28,7 +28,7 @@ class Backend {
             FROM backlog
             JOIN buffer ON backlog.bufferid = buffer.bufferid
             JOIN network ON buffer.networkid = network.networkid,
-                            plainto_tsquery('english'::REGCONFIG, :query) query
+                            phraseto_tsquery_multilang(:query) query
             WHERE (backlog.type & 23559) > 0
               AND buffer.userid = :userid
               AND (NOT(:_since) OR backlog.time > to_timestamp(:since))
@@ -60,7 +60,7 @@ class Backend {
                                   ) AS rank
                FROM backlog
                JOIN buffer ON backlog.bufferid = buffer.bufferid,
-                              plainto_tsquery('english'::REGCONFIG, :query) query
+                              phraseto_tsquery_multilang(:query) query
                WHERE (backlog.type & 23559) > 0
                  AND (NOT(:_since) OR backlog.time > to_timestamp(:since))
                  AND (NOT(:_before) OR backlog.time < to_timestamp(:before))
@@ -80,7 +80,7 @@ class Backend {
             FROM backlog
             JOIN sender ON backlog.senderid = sender.senderid
             JOIN buffer ON backlog.bufferid = buffer.bufferid,
-                            plainto_tsquery('english'::REGCONFIG, :query) query
+                            phraseto_tsquery_multilang(:query) query
             WHERE (backlog.type & 23559) > 0
               AND (NOT(:_since) OR backlog.time > to_timestamp(:since))
               AND (NOT(:_before) OR backlog.time < to_timestamp(:before))
@@ -133,12 +133,12 @@ class Backend {
         ");
     }
 
-    public static function createFromOptions(string $database_connector, string $username, string $password) : Backend {
-        return new Backend($database_connector, $username, $password);
+    public static function createFromOptions(string $database_connector, string $username, string $password) : Database {
+        return new Database($database_connector, $username, $password);
     }
 
-    public static function createFromConfig(Config $config) : Backend {
-        return new Backend($config->database_connector, $config->username, $config->password);
+    public static function createFromConfig(Config $config) : Database {
+        return new Database($config->database_connector, $config->username, $config->password);
     }
 
     public function authenticateFromHeader(string $header) : bool {
diff --git a/index.php b/index.php
index 8e667477528f21061cbdaea98ae4d758312804d6..e068fc0b4f92266d37e67f76e7f95e538798ed1a 100644
--- a/index.php
+++ b/index.php
@@ -10,7 +10,7 @@ require_once 'backend/helper/SessionHelper.php';
 $session = SessionHelper::getInstance();
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config, $session);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 if (!$backend->authenticate($session->username ?: '', $session->password ?: '')) {
     $session->destroy();
diff --git a/login.php b/login.php
index d1bd68f50674fd6e9a162a31df279820160e37d9..2968c6d078f907422bbb0d4120f6c8dcf6f2295a 100644
--- a/login.php
+++ b/login.php
@@ -10,7 +10,7 @@ require_once 'backend/helper/SessionHelper.php';
 $session = SessionHelper::getInstance();
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config, $session);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_GET['action']) && $_GET['action'] === 'login') {
     $username = $_POST['username'] ?: '';
diff --git a/res/MaterialIcons-Regular.ttf b/res/MaterialIcons-Regular.ttf
deleted file mode 100644
index 7015564ad166a3e9d88c82f17829f0cc01ebe29a..0000000000000000000000000000000000000000
Binary files a/res/MaterialIcons-Regular.ttf and /dev/null differ
diff --git a/res/css/content.sass b/res/css/content.sass
new file mode 100644
index 0000000000000000000000000000000000000000..ba39de6b48bb7c28aed6a943effb59d35f7522cb
--- /dev/null
+++ b/res/css/content.sass
@@ -0,0 +1,183 @@
+.results
+  max-width: 1328px
+  padding: 56px 6rem 8rem 6rem
+  margin: 0 auto
+
+  transition: opacity 400ms
+
+  .buffer
+    display: block
+    margin-top: 0
+    margin-bottom: 20px
+    border: rgba(0, 0, 0, 0)
+    transition: all 400ms
+
+    .title
+      border-bottom: 1px solid transparent
+      border-top: 1px solid transparent
+      color: #616161
+      margin-top: 20px
+      padding-bottom: 10px
+      padding-left: 22px
+      position: relative
+      will-change: transform, -webkit-transform
+
+    .inline-button
+      display: block
+      background: #f5f5f5
+      font-size: 16px
+      height: 48px
+      line-height: 48px
+      color: rgb(113, 113, 113)
+      text-align: center
+      font-style: italic
+      cursor: pointer
+      -webkit-user-select: none
+      -moz-user-select: none
+      position: relative
+
+      &:before
+        bottom: 0
+        box-shadow: 0 -1px 0 #e5e5e5, 0 0 2px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .24)
+        content: ''
+        display: block
+        left: 0
+        pointer-events: none
+        position: absolute
+        right: 0
+        top: 0
+
+    .container
+      font-size: 13px
+
+      .context
+        .container
+        .before
+        .after
+
+        &:not(.selected)
+          .before, .after
+            display: none
+
+          .inline-button
+            display: none
+
+        .message
+          display: flex
+          line-height: 24px
+          padding: 12px 24px
+          border-bottom: 1px solid #e5e5e5
+          color: #212121
+          background: #fff
+          position: relative
+
+          &:before
+            bottom: 0
+            box-shadow: 0 -1px 0 #e5e5e5, 0 0 2px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .24)
+            content: ''
+            display: block
+            left: 0
+            pointer-events: none
+            position: absolute
+            right: 0
+            top: 0
+
+          &:last-child
+            border-bottom: none
+
+          time
+            width: 132px
+            display: inline-block
+            text-align: right
+            flex-shrink: 0
+
+          .container
+            display: flex
+
+            .sender
+              width: 148px
+              display: inline-block
+              padding: 0 24px
+              font-weight: bold
+              flex-shrink: 0
+
+            .preview
+              .irc_highlight
+                background-color: rgba(251, 246, 167, 0.5)
+
+            .content
+              flex-shrink: 1
+              overflow: hidden
+
+              .irc_bold
+                font-weight: bold
+              .irc_italic
+                font-style: italic
+              .irc_underline
+                text-decoration: underline
+
+              [data-irc_foreground="0"]
+                color: #ffffff
+              [data-irc_foreground="1"]
+                color: #000000
+              [data-irc_foreground="2"]
+                color: #000080
+              [data-irc_foreground="3"]
+                color: #008000
+              [data-irc_foreground="4"]
+                color: #ff0000
+              [data-irc_foreground="5"]
+                color: #800000
+              [data-irc_foreground="6"]
+                color: #800080
+              [data-irc_foreground="7"]
+                color: #ffa500
+              [data-irc_foreground="8"]
+                color: #ffff00
+              [data-irc_foreground="9"]
+                color: #00ff00
+              [data-irc_foreground="10"]
+                color: #008080
+              [data-irc_foreground="11"]
+                color: #00ffff
+              [data-irc_foreground="12"]
+                color: #4169e1
+              [data-irc_foreground="13"]
+                color: #ff00ff
+              [data-irc_foreground="14"]
+                color: #808080
+              [data-irc_foreground="15"]
+                color: #c0c0c0
+
+              [data-irc_background="0"]
+                background-color: #ffffff
+              [data-irc_background="1"]
+                background-color: #000000
+              [data-irc_background="2"]
+                background-color: #000080
+              [data-irc_background="3"]
+                background-color: #008000
+              [data-irc_background="4"]
+                background-color: #ff0000
+              [data-irc_background="5"]
+                background-color: #800000
+              [data-irc_background="6"]
+                background-color: #800080
+              [data-irc_background="7"]
+                background-color: #ffa500
+              [data-irc_background="8"]
+                background-color: #ffff00
+              [data-irc_background="9"]
+                background-color: #00ff00
+              [data-irc_background="10"]
+                background-color: #008080
+              [data-irc_background="11"]
+                background-color: #00ffff
+              [data-irc_background="12"]
+                background-color: #4169e1
+              [data-irc_background="13"]
+                background-color: #ff00ff
+              [data-irc_background="14"]
+                background-color: #808080
+              [data-irc_background="15"]
+                background-color: #c0c0c0
diff --git a/res/css/font.sass b/res/css/font.sass
new file mode 100644
index 0000000000000000000000000000000000000000..2ad055f1824d2c994d0d6c909d1302cecb3566b2
--- /dev/null
+++ b/res/css/font.sass
@@ -0,0 +1,11 @@
+@font-face
+  font-family: 'Roboto'
+  font-style: normal
+  font-weight: 400
+  src: local('Roboto'), local('Roboto-Regular'), url('../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff2') format('woff2'), url('../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff') format('woff')
+
+@font-face
+  font-family: 'Roboto'
+  font-style: normal
+  font-weight: 700
+  src: local('Roboto Bold'), local('Roboto-Bold'), url('../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff2') format('woff2'), url('../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff') format('woff')
\ No newline at end of file
diff --git a/res/css/icons.sass b/res/css/icons.sass
new file mode 100644
index 0000000000000000000000000000000000000000..b35c5d91e39690dafbc5d654dfd4cf40d312243b
--- /dev/null
+++ b/res/css/icons.sass
@@ -0,0 +1,31 @@
+@font-face
+  font-family: 'Material Icons'
+  font-style: normal
+  font-weight: 400
+  src: local('Material Icons'), local('MaterialIcons-Regular'), url(../icons/MaterialIcons-Regular.woff2) format('woff2'), url(../icons/MaterialIcons-Regular.woff) format('woff')
+
+.icon
+  font-family: 'Material Icons', sans-serif
+  font-weight: normal
+  font-style: normal
+  font-size: 24px
+  display: inline-block
+  width: 1em
+  height: 1em
+  line-height: 1
+  text-transform: none
+  letter-spacing: normal
+  word-wrap: normal
+  white-space: nowrap
+  direction: ltr
+
+  /* Support for all WebKit browsers. */
+  -webkit-font-smoothing: antialiased
+  /* Support for Safari and Chrome. */
+  text-rendering: optimizeLegibility
+
+  /* Support for Firefox. */
+  -moz-osx-font-smoothing: grayscale
+
+  /* Support for IE. */
+  font-feature-settings: 'liga'
\ No newline at end of file
diff --git a/res/login.css b/res/css/login.css
similarity index 100%
rename from res/login.css
rename to res/css/login.css
diff --git a/res/css/nav.sass b/res/css/nav.sass
new file mode 100644
index 0000000000000000000000000000000000000000..40302644887b452592d88cb2bc7f7ebc6d0af469
--- /dev/null
+++ b/res/css/nav.sass
@@ -0,0 +1,174 @@
+@import "util"
+
+.nav
+  position: fixed
+  left: 0
+  right: 0
+  top: 0
+  height: 56px
+  z-index: 2
+
+  .container
+    background: #0271B3
+    padding: 0 6rem
+    z-index: 1
+    position: absolute
+    top: 0
+    left: 0
+    right: 0
+    box-shadow: 0 -1px 0 #e0e0e0, 0 0 2px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .24)
+    transition: background .15s
+
+    .searchBar
+      max-width: 1136px
+      margin: 10px auto
+      height: 36px
+      display: flex
+      position: relative
+      border: none
+      transition: background .15s
+      background: rgba(255, 255, 255, .15)
+      border-radius: 2px
+      padding: 0 0 0 72px
+      color: #ffffff
+      flex-direction: row
+
+      &:hover
+        background: rgba(255, 255, 255, .3)
+
+      .icon
+        display: inline-block
+        width: 72px
+        height: 36px
+        position: absolute
+        text-align: center
+        line-height: 36px
+        left: 0
+        top: 0
+
+      .search
+        display: inline-block
+        flex-grow: 1
+        flex-shrink: 1
+        background: none
+        border: none
+        line-height: 100%
+        color: #ffffff
+        font-size: 1rem
+
+        &::-moz-placeholder
+          color: #ffffff
+          opacity: 1
+          -moz-osx-font-smoothing: grayscale
+
+        &::-webkit-input-placeholder
+          color: #ffffff
+          opacity: 1
+          -webkit-font-smoothing: antialiased
+
+  .actions
+    position: absolute
+    height: 56px
+    z-index: 8
+    right: 0
+    display: flex
+    align-items: center
+    justify-content: flex-end
+    padding-left: 30px
+    padding-right: 30px
+
+    a
+      height: 30px
+      width: 30px
+      position: relative
+      padding: 3px
+      cursor: pointer
+      color: #fff
+      transition: all .15s
+      text-decoration: none
+      @include vendor-prefix('user-select', 'none')
+
+      &:hover:before
+        background-color: rgba(0, 0, 0, .12)
+        bottom: -4px
+        content: ' '
+        left: -4px
+        margin: auto
+        padding: 4px
+        position: absolute
+        right: -4px
+        top: -4px
+        z-index: -1
+        border-radius: 50%
+
+  .history
+    top: 100%
+    max-width: 1328px
+    margin: auto
+    padding: 0 6rem
+    transform: translateY(-200%)
+    transition: transform 400ms
+    position: relative
+
+    ul
+      list-style-type: none
+      margin: 0
+      padding: 6px 0
+      background: #fff
+      box-shadow: 0 -1px 0 #e0e0e0, 0 0 2px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .24)
+
+      li
+        cursor: pointer
+        line-height: 36px
+        overflow: hidden
+        padding: 0 24px
+        text-overflow: ellipsis
+        white-space: nowrap
+
+        &:hover, &:focus, &.selected
+          background: rgba(0, 0, 0, 0.03)
+
+        .icon
+          border-radius: 12px
+          height: 24px
+          margin-right: 24px
+          vertical-align: middle
+          width: 24px
+          display: inline-block
+          background-size: cover
+          opacity: 0.6
+
+      p
+        cursor: default
+        line-height: 36px
+        overflow: hidden
+        padding: 0 24px
+        text-overflow: ellipsis
+        white-space: nowrap
+        font-style: italic
+        color: #646464
+
+  &.focus
+    .container
+      background: #f2f2f2
+
+      .searchBar
+        background: #ffffff
+
+        .search
+          color: #333333
+
+          &::-moz-placeholder
+            color: #757575
+
+          &::-webkit-input-placeholder
+            color: #757575
+
+    .history
+      transform: translateY(0)
+
+    .icon
+      color: #333333
+
+    &+.results
+      opacity: 0
\ No newline at end of file
diff --git a/res/search.css b/res/css/oldsearch.css
similarity index 96%
rename from res/search.css
rename to res/css/oldsearch.css
index 154aa6baeddc4441eb66e1f81db3ac4bcb0d3595..2fecab762f4717cb3d5ac676c793d55b7a876628 100644
--- a/res/search.css
+++ b/res/css/oldsearch.css
@@ -12,6 +12,7 @@ body {
 }
 
 section {
+    transition: opacity 400ms;
     max-width: 1328px;
     padding: 56px 6rem 8rem 6rem;
     margin: 0 auto;
@@ -19,14 +20,17 @@ section {
 
 buffer {
     display: block;
-    margin-top: 20px;
+    margin-top: 0;
     margin-bottom: 20px;
+    border: rgba(0, 0, 0, 0);
+    transition: all 400ms;
 }
 
 buffer.selected {
     background-color: #ddd;
     border: rgba(0, 0, 0, .4);
     padding: 20px 16px;
+    margin-top: 20px;
     margin-left: -16px;
     margin-right: -16px;
 }
@@ -56,10 +60,22 @@ message {
     position: relative;
 }
 
-message.faded * {
+message:not(.original) * {
     opacity: .8
 }
 
+context:not(.selected) > .before, context:not(.selected) > .after {
+    display: none;
+}
+
+context:not(.selected) inline-button {
+    display: none;
+}
+
+buffer:not(.selected) context:nth-child(4)~context * {
+    display: none;
+}
+
 message sender {
     width: 148px;
     display: inline-block;
diff --git a/res/css/search.css b/res/css/search.css
new file mode 100644
index 0000000000000000000000000000000000000000..afc63e924f899ec3eedeff93e20bbdec774a3fe0
--- /dev/null
+++ b/res/css/search.css
@@ -0,0 +1,362 @@
+@font-face {
+  font-family: "Material Icons";
+  font-style: normal;
+  font-weight: 400;
+  src: local("Material Icons"), local("MaterialIcons-Regular"), url(../icons/MaterialIcons-Regular.woff2) format("woff2"), url(../icons/MaterialIcons-Regular.woff) format("woff"); }
+.icon {
+  font-family: "Material Icons", sans-serif;
+  font-weight: normal;
+  font-style: normal;
+  font-size: 24px;
+  display: inline-block;
+  width: 1em;
+  height: 1em;
+  line-height: 1;
+  text-transform: none;
+  letter-spacing: normal;
+  word-wrap: normal;
+  white-space: nowrap;
+  direction: ltr;
+  /* Support for all WebKit browsers. */
+  -webkit-font-smoothing: antialiased;
+  /* Support for Safari and Chrome. */
+  text-rendering: optimizeLegibility;
+  /* Support for Firefox. */
+  -moz-osx-font-smoothing: grayscale;
+  /* Support for IE. */
+  font-feature-settings: "liga"; }
+
+@font-face {
+  font-family: "Roboto";
+  font-style: normal;
+  font-weight: 400;
+  src: local("Roboto"), local("Roboto-Regular"), url("../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff2") format("woff2"), url("../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff") format("woff"); }
+@font-face {
+  font-family: "Roboto";
+  font-style: normal;
+  font-weight: 700;
+  src: local("Roboto Bold"), local("Roboto-Bold"), url("../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff2") format("woff2"), url("../fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff") format("woff"); }
+* {
+  padding: 0;
+  margin: 0;
+  box-sizing: border-box; }
+
+body {
+  background: #F2F2F2;
+  font-family: "Roboto", sans-serif;
+  font-size: 81.25%; }
+
+*:focus {
+  outline: none; }
+
+.nav {
+  position: fixed;
+  left: 0;
+  right: 0;
+  top: 0;
+  height: 56px;
+  z-index: 2; }
+  .nav .container {
+    background: #0271B3;
+    padding: 0 6rem;
+    z-index: 1;
+    position: absolute;
+    top: 0;
+    left: 0;
+    right: 0;
+    box-shadow: 0 -1px 0 #e0e0e0, 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);
+    transition: background 0.15s; }
+    .nav .container .searchBar {
+      max-width: 1136px;
+      margin: 10px auto;
+      height: 36px;
+      display: flex;
+      position: relative;
+      border: none;
+      transition: background 0.15s;
+      background: rgba(255, 255, 255, 0.15);
+      border-radius: 2px;
+      padding: 0 0 0 72px;
+      color: #ffffff;
+      flex-direction: row; }
+      .nav .container .searchBar:hover {
+        background: rgba(255, 255, 255, 0.3); }
+      .nav .container .searchBar .icon {
+        display: inline-block;
+        width: 72px;
+        height: 36px;
+        position: absolute;
+        text-align: center;
+        line-height: 36px;
+        left: 0;
+        top: 0; }
+      .nav .container .searchBar .search {
+        display: inline-block;
+        flex-grow: 1;
+        flex-shrink: 1;
+        background: none;
+        border: none;
+        line-height: 100%;
+        color: #ffffff;
+        font-size: 1rem; }
+        .nav .container .searchBar .search::-moz-placeholder {
+          color: #ffffff;
+          opacity: 1;
+          -moz-osx-font-smoothing: grayscale; }
+        .nav .container .searchBar .search::-webkit-input-placeholder {
+          color: #ffffff;
+          opacity: 1;
+          -webkit-font-smoothing: antialiased; }
+  .nav .actions {
+    position: absolute;
+    height: 56px;
+    z-index: 8;
+    right: 0;
+    display: flex;
+    align-items: center;
+    justify-content: flex-end;
+    padding-left: 30px;
+    padding-right: 30px; }
+    .nav .actions a {
+      height: 30px;
+      width: 30px;
+      position: relative;
+      padding: 3px;
+      cursor: pointer;
+      color: #fff;
+      transition: all 0.15s;
+      text-decoration: none;
+      -webkit-user-select: none;
+      -moz-user-select: none;
+      -ms-user-select: none;
+      -o-user-select: none;
+      user-select: none; }
+      .nav .actions a:hover:before {
+        background-color: rgba(0, 0, 0, 0.12);
+        bottom: -4px;
+        content: " ";
+        left: -4px;
+        margin: auto;
+        padding: 4px;
+        position: absolute;
+        right: -4px;
+        top: -4px;
+        z-index: -1;
+        border-radius: 50%; }
+  .nav .history {
+    top: 100%;
+    max-width: 1328px;
+    margin: auto;
+    padding: 0 6rem;
+    transform: translateY(-200%);
+    transition: transform 400ms;
+    position: relative; }
+    .nav .history ul {
+      list-style-type: none;
+      margin: 0;
+      padding: 6px 0;
+      background: #fff;
+      box-shadow: 0 -1px 0 #e0e0e0, 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24); }
+      .nav .history ul li {
+        cursor: pointer;
+        line-height: 36px;
+        overflow: hidden;
+        padding: 0 24px;
+        text-overflow: ellipsis;
+        white-space: nowrap; }
+        .nav .history ul li:hover, .nav .history ul li:focus, .nav .history ul li.selected {
+          background: rgba(0, 0, 0, 0.03); }
+        .nav .history ul li .icon {
+          border-radius: 12px;
+          height: 24px;
+          margin-right: 24px;
+          vertical-align: middle;
+          width: 24px;
+          display: inline-block;
+          background-size: cover;
+          opacity: 0.6; }
+      .nav .history ul p {
+        cursor: default;
+        line-height: 36px;
+        overflow: hidden;
+        padding: 0 24px;
+        text-overflow: ellipsis;
+        white-space: nowrap;
+        font-style: italic;
+        color: #646464; }
+  .nav.focus .container {
+    background: #f2f2f2; }
+    .nav.focus .container .searchBar {
+      background: #ffffff; }
+      .nav.focus .container .searchBar .search {
+        color: #333333; }
+        .nav.focus .container .searchBar .search::-moz-placeholder {
+          color: #757575; }
+        .nav.focus .container .searchBar .search::-webkit-input-placeholder {
+          color: #757575; }
+  .nav.focus .history {
+    transform: translateY(0); }
+  .nav.focus .icon {
+    color: #333333; }
+  .nav.focus + .results {
+    opacity: 0; }
+
+.results {
+  max-width: 1328px;
+  padding: 56px 6rem 8rem 6rem;
+  margin: 0 auto;
+  transition: opacity 400ms; }
+  .results .buffer {
+    display: block;
+    margin-top: 0;
+    margin-bottom: 20px;
+    border: transparent;
+    transition: all 400ms; }
+    .results .buffer .title {
+      border-bottom: 1px solid transparent;
+      border-top: 1px solid transparent;
+      color: #616161;
+      margin-top: 20px;
+      padding-bottom: 10px;
+      padding-left: 22px;
+      position: relative;
+      will-change: transform, -webkit-transform; }
+    .results .buffer .inline-button {
+      display: block;
+      background: #f5f5f5;
+      font-size: 16px;
+      height: 48px;
+      line-height: 48px;
+      color: #717171;
+      text-align: center;
+      font-style: italic;
+      cursor: pointer;
+      -webkit-user-select: none;
+      -moz-user-select: none;
+      position: relative; }
+      .results .buffer .inline-button:before {
+        bottom: 0;
+        box-shadow: 0 -1px 0 #e5e5e5, 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);
+        content: "";
+        display: block;
+        left: 0;
+        pointer-events: none;
+        position: absolute;
+        right: 0;
+        top: 0; }
+    .results .buffer .container {
+      font-size: 13px; }
+      .results .buffer .container .context:not(.selected) .before, .results .buffer .container .context:not(.selected) .after {
+        display: none; }
+      .results .buffer .container .context:not(.selected) .inline-button {
+        display: none; }
+      .results .buffer .container .context .message {
+        display: flex;
+        line-height: 24px;
+        padding: 12px 24px;
+        border-bottom: 1px solid #e5e5e5;
+        color: #212121;
+        background: #fff;
+        position: relative; }
+        .results .buffer .container .context .message:before {
+          bottom: 0;
+          box-shadow: 0 -1px 0 #e5e5e5, 0 0 2px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.24);
+          content: "";
+          display: block;
+          left: 0;
+          pointer-events: none;
+          position: absolute;
+          right: 0;
+          top: 0; }
+        .results .buffer .container .context .message:last-child {
+          border-bottom: none; }
+        .results .buffer .container .context .message time {
+          width: 132px;
+          display: inline-block;
+          text-align: right;
+          flex-shrink: 0; }
+        .results .buffer .container .context .message .container {
+          display: flex; }
+          .results .buffer .container .context .message .container .sender {
+            width: 148px;
+            display: inline-block;
+            padding: 0 24px;
+            font-weight: bold;
+            flex-shrink: 0; }
+          .results .buffer .container .context .message .container .preview .irc_highlight {
+            background-color: rgba(251, 246, 167, 0.5); }
+          .results .buffer .container .context .message .container .content {
+            flex-shrink: 1;
+            overflow: hidden; }
+            .results .buffer .container .context .message .container .content .irc_bold {
+              font-weight: bold; }
+            .results .buffer .container .context .message .container .content .irc_italic {
+              font-style: italic; }
+            .results .buffer .container .context .message .container .content .irc_underline {
+              text-decoration: underline; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="0"] {
+              color: #ffffff; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="1"] {
+              color: #000000; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="2"] {
+              color: #000080; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="3"] {
+              color: #008000; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="4"] {
+              color: #ff0000; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="5"] {
+              color: #800000; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="6"] {
+              color: #800080; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="7"] {
+              color: #ffa500; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="8"] {
+              color: #ffff00; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="9"] {
+              color: #00ff00; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="10"] {
+              color: #008080; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="11"] {
+              color: #00ffff; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="12"] {
+              color: #4169e1; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="13"] {
+              color: #ff00ff; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="14"] {
+              color: #808080; }
+            .results .buffer .container .context .message .container .content [data-irc_foreground="15"] {
+              color: #c0c0c0; }
+            .results .buffer .container .context .message .container .content [data-irc_background="0"] {
+              background-color: #ffffff; }
+            .results .buffer .container .context .message .container .content [data-irc_background="1"] {
+              background-color: #000000; }
+            .results .buffer .container .context .message .container .content [data-irc_background="2"] {
+              background-color: #000080; }
+            .results .buffer .container .context .message .container .content [data-irc_background="3"] {
+              background-color: #008000; }
+            .results .buffer .container .context .message .container .content [data-irc_background="4"] {
+              background-color: #ff0000; }
+            .results .buffer .container .context .message .container .content [data-irc_background="5"] {
+              background-color: #800000; }
+            .results .buffer .container .context .message .container .content [data-irc_background="6"] {
+              background-color: #800080; }
+            .results .buffer .container .context .message .container .content [data-irc_background="7"] {
+              background-color: #ffa500; }
+            .results .buffer .container .context .message .container .content [data-irc_background="8"] {
+              background-color: #ffff00; }
+            .results .buffer .container .context .message .container .content [data-irc_background="9"] {
+              background-color: #00ff00; }
+            .results .buffer .container .context .message .container .content [data-irc_background="10"] {
+              background-color: #008080; }
+            .results .buffer .container .context .message .container .content [data-irc_background="11"] {
+              background-color: #00ffff; }
+            .results .buffer .container .context .message .container .content [data-irc_background="12"] {
+              background-color: #4169e1; }
+            .results .buffer .container .context .message .container .content [data-irc_background="13"] {
+              background-color: #ff00ff; }
+            .results .buffer .container .context .message .container .content [data-irc_background="14"] {
+              background-color: #808080; }
+            .results .buffer .container .context .message .container .content [data-irc_background="15"] {
+              background-color: #c0c0c0; }
+
+/*# sourceMappingURL=search.css.map */
diff --git a/res/css/search.css.map b/res/css/search.css.map
new file mode 100644
index 0000000000000000000000000000000000000000..2b78bf293324f2e326ed2b23f9f7fe974d06e186
--- /dev/null
+++ b/res/css/search.css.map
@@ -0,0 +1,7 @@
+{
+"version": 3,
+"mappings": ";EACE,WAAW,EAAE,gBAAgB;EAC7B,UAAU,EAAE,MAAM;EAClB,WAAW,EAAE,GAAG;EAChB,GAAG,EAAE,2KAA2K;AAElL,KAAK;EACH,WAAW,EAAE,4BAA4B;EACzC,WAAW,EAAE,MAAM;EACnB,UAAU,EAAE,MAAM;EAClB,SAAS,EAAE,IAAI;EACf,OAAO,EAAE,YAAY;EACrB,KAAK,EAAE,GAAG;EACV,MAAM,EAAE,GAAG;EACX,WAAW,EAAE,CAAC;EACd,cAAc,EAAE,IAAI;EACpB,cAAc,EAAE,MAAM;EACtB,SAAS,EAAE,MAAM;EACjB,WAAW,EAAE,MAAM;EACnB,SAAS,EAAE,GAAG;;EAGd,sBAAsB,EAAE,WAAW;;EAEnC,cAAc,EAAE,kBAAkB;;EAGlC,uBAAuB,EAAE,SAAS;;EAGlC,qBAAqB,EAAE,MAAM;;;EC7B7B,WAAW,EAAE,QAAQ;EACrB,UAAU,EAAE,MAAM;EAClB,WAAW,EAAE,GAAG;EAChB,GAAG,EAAE,4RAA4R;;EAGjS,WAAW,EAAE,QAAQ;EACrB,UAAU,EAAE,MAAM;EAClB,WAAW,EAAE,GAAG;EAChB,GAAG,EAAE,sRAAsR;ACN7R,CAAC;EACC,OAAO,EAAE,CAAC;EACV,MAAM,EAAE,CAAC;EACT,UAAU,EAAE,UAAU;;AAExB,IAAI;EACF,UAAU,EAAE,OAAO;EACnB,WAAW,EAAE,oBAAoB;EACjC,SAAS,EAAE,MAAM;;AAEnB,OAAO;EACL,OAAO,EAAE,IAAI;;ACbf,IAAI;EACF,QAAQ,EAAE,KAAK;EACf,IAAI,EAAE,CAAC;EACP,KAAK,EAAE,CAAC;EACR,GAAG,EAAE,CAAC;EACN,MAAM,EAAE,IAAI;EACZ,OAAO,EAAE,CAAC;EAEV,eAAU;IACR,UAAU,EAAE,OAAO;IACnB,OAAO,EAAE,MAAM;IACf,OAAO,EAAE,CAAC;IACV,QAAQ,EAAE,QAAQ;IAClB,GAAG,EAAE,CAAC;IACN,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;IACR,UAAU,EAAE,4EAA0E;IACtF,UAAU,EAAE,gBAAe;IAE3B,0BAAU;MACR,SAAS,EAAE,MAAM;MACjB,MAAM,EAAE,SAAS;MACjB,MAAM,EAAE,IAAI;MACZ,OAAO,EAAE,IAAI;MACb,QAAQ,EAAE,QAAQ;MAClB,MAAM,EAAE,IAAI;MACZ,UAAU,EAAE,gBAAe;MAC3B,UAAU,EAAE,yBAAwB;MACpC,aAAa,EAAE,GAAG;MAClB,OAAO,EAAE,UAAU;MACnB,KAAK,EAAE,OAAO;MACd,cAAc,EAAE,GAAG;MAEnB,gCAAO;QACL,UAAU,EAAE,wBAAuB;MAErC,gCAAK;QACH,OAAO,EAAE,YAAY;QACrB,KAAK,EAAE,IAAI;QACX,MAAM,EAAE,IAAI;QACZ,QAAQ,EAAE,QAAQ;QAClB,UAAU,EAAE,MAAM;QAClB,WAAW,EAAE,IAAI;QACjB,IAAI,EAAE,CAAC;QACP,GAAG,EAAE,CAAC;MAER,kCAAO;QACL,OAAO,EAAE,YAAY;QACrB,SAAS,EAAE,CAAC;QACZ,WAAW,EAAE,CAAC;QACd,UAAU,EAAE,IAAI;QAChB,MAAM,EAAE,IAAI;QACZ,WAAW,EAAE,IAAI;QACjB,KAAK,EAAE,OAAO;QACd,SAAS,EAAE,IAAI;QAEf,oDAAmB;UACjB,KAAK,EAAE,OAAO;UACd,OAAO,EAAE,CAAC;UACV,uBAAuB,EAAE,SAAS;QAEpC,6DAA4B;UAC1B,KAAK,EAAE,OAAO;UACd,OAAO,EAAE,CAAC;UACV,sBAAsB,EAAE,WAAW;EAE3C,aAAQ;IACN,QAAQ,EAAE,QAAQ;IAClB,MAAM,EAAE,IAAI;IACZ,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,CAAC;IACR,OAAO,EAAE,IAAI;IACb,WAAW,EAAE,MAAM;IACnB,eAAe,EAAE,QAAQ;IACzB,YAAY,EAAE,IAAI;IAClB,aAAa,EAAE,IAAI;IAEnB,eAAC;MACC,MAAM,EAAE,IAAI;MACZ,KAAK,EAAE,IAAI;MACX,QAAQ,EAAE,QAAQ;MAClB,OAAO,EAAE,GAAG;MACZ,MAAM,EAAE,OAAO;MACf,KAAK,EAAE,IAAI;MACX,UAAU,EAAE,SAAQ;MACpB,eAAe,EAAE,IAAI;MCrFvB,mBAAkB,EAAE,IAAS;MAA7B,gBAAkB,EAAE,IAAS;MAA7B,eAAkB,EAAE,IAAS;MAA7B,cAAkB,EAAE,IAAS;MAA7B,WAAkB,EAAE,IAAS;MDwF3B,4BAAc;QACZ,gBAAgB,EAAE,mBAAkB;QACpC,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,GAAG;QACZ,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,GAAG;QACZ,QAAQ,EAAE,QAAQ;QAClB,KAAK,EAAE,IAAI;QACX,GAAG,EAAE,IAAI;QACT,OAAO,EAAE,EAAE;QACX,aAAa,EAAE,GAAG;EAExB,aAAQ;IACN,GAAG,EAAE,IAAI;IACT,SAAS,EAAE,MAAM;IACjB,MAAM,EAAE,IAAI;IACZ,OAAO,EAAE,MAAM;IACf,SAAS,EAAE,iBAAiB;IAC5B,UAAU,EAAE,eAAe;IAC3B,QAAQ,EAAE,QAAQ;IAElB,gBAAE;MACA,eAAe,EAAE,IAAI;MACrB,MAAM,EAAE,CAAC;MACT,OAAO,EAAE,KAAK;MACd,UAAU,EAAE,IAAI;MAChB,UAAU,EAAE,4EAA0E;MAEtF,mBAAE;QACA,MAAM,EAAE,OAAO;QACf,WAAW,EAAE,IAAI;QACjB,QAAQ,EAAE,MAAM;QAChB,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,WAAW,EAAE,MAAM;QAEnB,kFAA4B;UAC1B,UAAU,EAAE,mBAAmB;QAEjC,yBAAK;UACH,aAAa,EAAE,IAAI;UACnB,MAAM,EAAE,IAAI;UACZ,YAAY,EAAE,IAAI;UAClB,cAAc,EAAE,MAAM;UACtB,KAAK,EAAE,IAAI;UACX,OAAO,EAAE,YAAY;UACrB,eAAe,EAAE,KAAK;UACtB,OAAO,EAAE,GAAG;MAEhB,kBAAC;QACC,MAAM,EAAE,OAAO;QACf,WAAW,EAAE,IAAI;QACjB,QAAQ,EAAE,MAAM;QAChB,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,WAAW,EAAE,MAAM;QACnB,UAAU,EAAE,MAAM;QAClB,KAAK,EAAE,OAAO;EAGlB,qBAAU;IACR,UAAU,EAAE,OAAO;IAEnB,gCAAU;MACR,UAAU,EAAE,OAAO;MAEnB,wCAAO;QACL,KAAK,EAAE,OAAO;QAEd,0DAAmB;UACjB,KAAK,EAAE,OAAO;QAEhB,mEAA4B;UAC1B,KAAK,EAAE,OAAO;EAEtB,mBAAQ;IACN,SAAS,EAAE,aAAa;EAE1B,gBAAK;IACH,KAAK,EAAE,OAAO;EAEhB,qBAAU;IACR,OAAO,EAAE,CAAC;;AE7KhB,QAAQ;EACN,SAAS,EAAE,MAAM;EACjB,OAAO,EAAE,mBAAmB;EAC5B,MAAM,EAAE,MAAM;EAEd,UAAU,EAAE,aAAa;EAEzB,gBAAO;IACL,OAAO,EAAE,KAAK;IACd,UAAU,EAAE,CAAC;IACb,aAAa,EAAE,IAAI;IACnB,MAAM,EAAE,WAAgB;IACxB,UAAU,EAAE,SAAS;IAErB,uBAAM;MACJ,aAAa,EAAE,qBAAqB;MACpC,UAAU,EAAE,qBAAqB;MACjC,KAAK,EAAE,OAAO;MACd,UAAU,EAAE,IAAI;MAChB,cAAc,EAAE,IAAI;MACpB,YAAY,EAAE,IAAI;MAClB,QAAQ,EAAE,QAAQ;MAClB,WAAW,EAAE,4BAA4B;IAE3C,+BAAc;MACZ,OAAO,EAAE,KAAK;MACd,UAAU,EAAE,OAAO;MACnB,SAAS,EAAE,IAAI;MACf,MAAM,EAAE,IAAI;MACZ,WAAW,EAAE,IAAI;MACjB,KAAK,EAAE,OAAkB;MACzB,UAAU,EAAE,MAAM;MAClB,UAAU,EAAE,MAAM;MAClB,MAAM,EAAE,OAAO;MACf,mBAAmB,EAAE,IAAI;MACzB,gBAAgB,EAAE,IAAI;MACtB,QAAQ,EAAE,QAAQ;MAElB,sCAAQ;QACN,MAAM,EAAE,CAAC;QACT,UAAU,EAAE,4EAA0E;QACtF,OAAO,EAAE,EAAE;QACX,OAAO,EAAE,KAAK;QACd,IAAI,EAAE,CAAC;QACP,cAAc,EAAE,IAAI;QACpB,QAAQ,EAAE,QAAQ;QAClB,KAAK,EAAE,CAAC;QACR,GAAG,EAAE,CAAC;IAEV,2BAAU;MACR,SAAS,EAAE,IAAI;MAQX,uHAAe;QACb,OAAO,EAAE,IAAI;MAEf,kEAAc;QACZ,OAAO,EAAE,IAAI;MAEjB,6CAAQ;QACN,OAAO,EAAE,IAAI;QACb,WAAW,EAAE,IAAI;QACjB,OAAO,EAAE,SAAS;QAClB,aAAa,EAAE,iBAAiB;QAChC,KAAK,EAAE,OAAO;QACd,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,QAAQ;QAElB,oDAAQ;UACN,MAAM,EAAE,CAAC;UACT,UAAU,EAAE,4EAA0E;UACtF,OAAO,EAAE,EAAE;UACX,OAAO,EAAE,KAAK;UACd,IAAI,EAAE,CAAC;UACP,cAAc,EAAE,IAAI;UACpB,QAAQ,EAAE,QAAQ;UAClB,KAAK,EAAE,CAAC;UACR,GAAG,EAAE,CAAC;QAER,wDAAY;UACV,aAAa,EAAE,IAAI;QAErB,kDAAI;UACF,KAAK,EAAE,KAAK;UACZ,OAAO,EAAE,YAAY;UACrB,UAAU,EAAE,KAAK;UACjB,WAAW,EAAE,CAAC;QAEhB,wDAAU;UACR,OAAO,EAAE,IAAI;UAEb,gEAAO;YACL,KAAK,EAAE,KAAK;YACZ,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,CAAC;UAGd,gFAAc;YACZ,gBAAgB,EAAE,wBAAwB;UAE9C,iEAAQ;YACN,WAAW,EAAE,CAAC;YACd,QAAQ,EAAE,MAAM;YAEhB,2EAAS;cACP,WAAW,EAAE,IAAI;YACnB,6EAAW;cACT,UAAU,EAAE,MAAM;YACpB,gFAAc;cACZ,eAAe,EAAE,SAAS;YAE5B,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,2FAAyB;cACvB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAChB,4FAA0B;cACxB,KAAK,EAAE,OAAO;YAEhB,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,2FAAyB;cACvB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO;YAC3B,4FAA0B;cACxB,gBAAgB,EAAE,OAAO",
+"sources": ["icons.sass","font.sass","search.sass","nav.sass","util.sass","content.sass"],
+"names": [],
+"file": "search.css"
+}
\ No newline at end of file
diff --git a/res/css/search.sass b/res/css/search.sass
new file mode 100644
index 0000000000000000000000000000000000000000..90da18066bd32aef4272951b27e18ea3a3546191
--- /dev/null
+++ b/res/css/search.sass
@@ -0,0 +1,19 @@
+@import "util"
+@import "icons"
+@import "font"
+
+*
+  padding: 0
+  margin: 0
+  box-sizing: border-box
+
+body
+  background: #F2F2F2
+  font-family: 'Roboto', sans-serif
+  font-size: 81.25%
+
+*:focus
+  outline: none
+
+@import "nav"
+@import "content"
\ No newline at end of file
diff --git a/res/css/util.sass b/res/css/util.sass
new file mode 100644
index 0000000000000000000000000000000000000000..2ed7ccb1b0da31480d7d9a11dbff51d50fa70f32
--- /dev/null
+++ b/res/css/util.sass
@@ -0,0 +1,3 @@
+@mixin vendor-prefix($name, $value)
+  @each $vendor in ('-webkit-', '-moz-', '-ms-', '-o-', '')
+    #{$vendor}#{$name}: #{$value}
\ No newline at end of file
diff --git a/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff
new file mode 100644
index 0000000000000000000000000000000000000000..562fe18a08ff8a04d793c8a5863e80fb20bc978a
Binary files /dev/null and b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff differ
diff --git a/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff2 b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff2
new file mode 100644
index 0000000000000000000000000000000000000000..45901ee1a5c953acfd55d535ba50cf76acbae5c9
Binary files /dev/null and b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-700.woff2 differ
diff --git a/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff
new file mode 100644
index 0000000000000000000000000000000000000000..2e069a916b0daab939d520689774205ca8e39679
Binary files /dev/null and b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff differ
diff --git a/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff2 b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff2
new file mode 100644
index 0000000000000000000000000000000000000000..45e0bcd1ab18a298bc8baad1e9961ea27384255e
Binary files /dev/null and b/res/fonts/roboto-v15-latin-ext_cyrillic_greek-ext_cyrillic-ext_latin_greek_vietnamese-regular.woff2 differ
diff --git a/res/MaterialIcons-Regular.woff b/res/icons/MaterialIcons-Regular.woff
similarity index 100%
rename from res/MaterialIcons-Regular.woff
rename to res/icons/MaterialIcons-Regular.woff
diff --git a/res/MaterialIcons-Regular.woff2 b/res/icons/MaterialIcons-Regular.woff2
similarity index 100%
rename from res/MaterialIcons-Regular.woff2
rename to res/icons/MaterialIcons-Regular.woff2
diff --git a/res/error.png b/res/icons/error.png
similarity index 100%
rename from res/error.png
rename to res/icons/error.png
diff --git a/res/jquery.js b/res/jquery.js
deleted file mode 100644
index 2ec0d1da096531861df15ba66d60de68c0345939..0000000000000000000000000000000000000000
--- a/res/jquery.js
+++ /dev/null
@@ -1,4 +0,0 @@
-/*! jQuery v3.2.0 | (c) JS Foundation and other contributors | jquery.org/license */
-!function(a,b){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){"use strict";var c=[],d=a.document,e=Object.getPrototypeOf,f=c.slice,g=c.concat,h=c.push,i=c.indexOf,j={},k=j.toString,l=j.hasOwnProperty,m=l.toString,n=m.call(Object),o={};function p(a,b){b=b||d;var c=b.createElement("script");c.text=a,b.head.appendChild(c).parentNode.removeChild(c)}var q="3.2.0",r=function(a,b){return new r.fn.init(a,b)},s=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,t=/^-ms-/,u=/-([a-z])/g,v=function(a,b){return b.toUpperCase()};r.fn=r.prototype={jquery:q,constructor:r,length:0,toArray:function(){return f.call(this)},get:function(a){return null==a?f.call(this):a<0?this[a+this.length]:this[a]},pushStack:function(a){var b=r.merge(this.constructor(),a);return b.prevObject=this,b},each:function(a){return r.each(this,a)},map:function(a){return this.pushStack(r.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(f.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(a<0?b:0);return this.pushStack(c>=0&&c<b?[this[c]]:[])},end:function(){return this.prevObject||this.constructor()},push:h,sort:c.sort,splice:c.splice},r.extend=r.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||r.isFunction(g)||(g={}),h===i&&(g=this,h--);h<i;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(r.isPlainObject(d)||(e=Array.isArray(d)))?(e?(e=!1,f=c&&Array.isArray(c)?c:[]):f=c&&r.isPlainObject(c)?c:{},g[b]=r.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},r.extend({expando:"jQuery"+(q+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===r.type(a)},isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){var b=r.type(a);return("number"===b||"string"===b)&&!isNaN(a-parseFloat(a))},isPlainObject:function(a){var b,c;return!(!a||"[object Object]"!==k.call(a))&&(!(b=e(a))||(c=l.call(b,"constructor")&&b.constructor,"function"==typeof c&&m.call(c)===n))},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?j[k.call(a)]||"object":typeof a},globalEval:function(a){p(a)},camelCase:function(a){return a.replace(t,"ms-").replace(u,v)},each:function(a,b){var c,d=0;if(w(a)){for(c=a.length;d<c;d++)if(b.call(a[d],d,a[d])===!1)break}else for(d in a)if(b.call(a[d],d,a[d])===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(s,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(w(Object(a))?r.merge(c,"string"==typeof a?[a]:a):h.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:i.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;d<c;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;f<g;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,e,f=0,h=[];if(w(a))for(d=a.length;f<d;f++)e=b(a[f],f,c),null!=e&&h.push(e);else for(f in a)e=b(a[f],f,c),null!=e&&h.push(e);return g.apply([],h)},guid:1,proxy:function(a,b){var c,d,e;if("string"==typeof b&&(c=a[b],b=a,a=c),r.isFunction(a))return d=f.call(arguments,2),e=function(){return a.apply(b||this,d.concat(f.call(arguments)))},e.guid=a.guid=a.guid||r.guid++,e},now:Date.now,support:o}),"function"==typeof Symbol&&(r.fn[Symbol.iterator]=c[Symbol.iterator]),r.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(a,b){j["[object "+b+"]"]=b.toLowerCase()});function w(a){var b=!!a&&"length"in a&&a.length,c=r.type(a);return"function"!==c&&!r.isWindow(a)&&("array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a)}var x=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C={}.hasOwnProperty,D=[],E=D.pop,F=D.push,G=D.push,H=D.slice,I=function(a,b){for(var c=0,d=a.length;c<d;c++)if(a[c]===b)return c;return-1},J="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",K="[\\x20\\t\\r\\n\\f]",L="(?:\\\\.|[\\w-]|[^\0-\\xa0])+",M="\\["+K+"*("+L+")(?:"+K+"*([*^$|!~]?=)"+K+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+L+"))|)"+K+"*\\]",N=":("+L+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+M+")*)|.*)\\)|)",O=new RegExp(K+"+","g"),P=new RegExp("^"+K+"+|((?:^|[^\\\\])(?:\\\\.)*)"+K+"+$","g"),Q=new RegExp("^"+K+"*,"+K+"*"),R=new RegExp("^"+K+"*([>+~]|"+K+")"+K+"*"),S=new RegExp("="+K+"*([^\\]'\"]*?)"+K+"*\\]","g"),T=new RegExp(N),U=new RegExp("^"+L+"$"),V={ID:new RegExp("^#("+L+")"),CLASS:new RegExp("^\\.("+L+")"),TAG:new RegExp("^("+L+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+N),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+K+"*(even|odd|(([+-]|)(\\d*)n|)"+K+"*(?:([+-]|)"+K+"*(\\d+)|))"+K+"*\\)|)","i"),bool:new RegExp("^(?:"+J+")$","i"),needsContext:new RegExp("^"+K+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+K+"*((?:-\\d)?\\d*)"+K+"*\\)|)(?=[^-]|$)","i")},W=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Y=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,$=/[+~]/,_=new RegExp("\\\\([\\da-f]{1,6}"+K+"?|("+K+")|.)","ig"),aa=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:d<0?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ba=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ca=function(a,b){return b?"\0"===a?"\ufffd":a.slice(0,-1)+"\\"+a.charCodeAt(a.length-1).toString(16)+" ":"\\"+a},da=function(){m()},ea=ta(function(a){return a.disabled===!0&&("form"in a||"label"in a)},{dir:"parentNode",next:"legend"});try{G.apply(D=H.call(v.childNodes),v.childNodes),D[v.childNodes.length].nodeType}catch(fa){G={apply:D.length?function(a,b){F.apply(a,H.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s=b&&b.ownerDocument,w=b?b.nodeType:9;if(d=d||[],"string"!=typeof a||!a||1!==w&&9!==w&&11!==w)return d;if(!e&&((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,p)){if(11!==w&&(l=Z.exec(a)))if(f=l[1]){if(9===w){if(!(j=b.getElementById(f)))return d;if(j.id===f)return d.push(j),d}else if(s&&(j=s.getElementById(f))&&t(b,j)&&j.id===f)return d.push(j),d}else{if(l[2])return G.apply(d,b.getElementsByTagName(a)),d;if((f=l[3])&&c.getElementsByClassName&&b.getElementsByClassName)return G.apply(d,b.getElementsByClassName(f)),d}if(c.qsa&&!A[a+" "]&&(!q||!q.test(a))){if(1!==w)s=b,r=a;else if("object"!==b.nodeName.toLowerCase()){(k=b.getAttribute("id"))?k=k.replace(ba,ca):b.setAttribute("id",k=u),o=g(a),h=o.length;while(h--)o[h]="#"+k+" "+sa(o[h]);r=o.join(","),s=$.test(a)&&qa(b.parentNode)||b}if(r)try{return G.apply(d,s.querySelectorAll(r)),d}catch(x){}finally{k===u&&b.removeAttribute("id")}}}return i(a.replace(P,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("fieldset");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=c.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&a.sourceIndex-b.sourceIndex;if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return function(b){return"form"in b?b.parentNode&&b.disabled===!1?"label"in b?"label"in b.parentNode?b.parentNode.disabled===a:b.disabled===a:b.isDisabled===a||b.isDisabled!==!a&&ea(b)===a:b.disabled===a:"label"in b&&b.disabled===a}}function pa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function qa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=n.documentElement,p=!f(n),v!==n&&(e=n.defaultView)&&e.top!==e&&(e.addEventListener?e.addEventListener("unload",da,!1):e.attachEvent&&e.attachEvent("onunload",da)),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(n.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Y.test(n.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!n.getElementsByName||!n.getElementsByName(u).length}),c.getById?(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){return a.getAttribute("id")===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c?[c]:[]}}):(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c,d,e,f=b.getElementById(a);if(f){if(c=f.getAttributeNode("id"),c&&c.value===a)return[f];e=b.getElementsByName(a),d=0;while(f=e[d++])if(c=f.getAttributeNode("id"),c&&c.value===a)return[f]}return[]}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){if("undefined"!=typeof b.getElementsByClassName&&p)return b.getElementsByClassName(a)},r=[],q=[],(c.qsa=Y.test(n.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="<a id='"+u+"'></a><select id='"+u+"-\r\\' msallowcapture=''><option selected=''></option></select>",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+K+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+K+"*(?:value|"+J+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){a.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var b=n.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+K+"*[*^$|!~]?="),2!==a.querySelectorAll(":enabled").length&&q.push(":enabled",":disabled"),o.appendChild(a).disabled=!0,2!==a.querySelectorAll(":disabled").length&&q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=Y.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"*"),s.call(a,"[s!='']:x"),r.push("!=",N)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=Y.test(o.compareDocumentPosition),t=b||Y.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===n||a.ownerDocument===v&&t(v,a)?-1:b===n||b.ownerDocument===v&&t(v,b)?1:k?I(k,a)-I(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,g=[a],h=[b];if(!e||!f)return a===n?-1:b===n?1:e?-1:f?1:k?I(k,a)-I(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)g.unshift(c);c=b;while(c=c.parentNode)h.unshift(c);while(g[d]===h[d])d++;return d?la(g[d],h[d]):g[d]===v?-1:h[d]===v?1:0},n):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(S,"='$1']"),c.matchesSelector&&p&&!A[b+" "]&&(!r||!r.test(b))&&(!q||!q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&C.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.escape=function(a){return(a+"").replace(ba,ca)},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(_,aa),a[3]=(a[3]||a[4]||a[5]||"").replace(_,aa),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return V.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&T.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(_,aa).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+K+")"+a+"("+K+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(O," ")+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h,t=!1;if(q){if(f){while(p){m=b;while(m=m[p])if(h?m.nodeName.toLowerCase()===r:1===m.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){m=q,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n&&j[2],m=n&&q.childNodes[n];while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if(1===m.nodeType&&++t&&m===b){k[a]=[w,n,t];break}}else if(s&&(m=b,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n),t===!1)while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if((h?m.nodeName.toLowerCase()===r:1===m.nodeType)&&++t&&(s&&(l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),k[a]=[w,t]),m===b))break;return t-=e,t===d||t%d===0&&t/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=I(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(P,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(_,aa),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return U.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(_,aa).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:oa(!1),disabled:oa(!0),checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return X.test(a.nodeName)},input:function(a){return W.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:pa(function(){return[0]}),last:pa(function(a,b){return[b-1]}),eq:pa(function(a,b,c){return[c<0?c+b:c]}),even:pa(function(a,b){for(var c=0;c<b;c+=2)a.push(c);return a}),odd:pa(function(a,b){for(var c=1;c<b;c+=2)a.push(c);return a}),lt:pa(function(a,b,c){for(var d=c<0?c+b:c;--d>=0;)a.push(d);return a}),gt:pa(function(a,b,c){for(var d=c<0?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=ma(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=na(b);function ra(){}ra.prototype=d.filters=d.pseudos,d.setFilters=new ra,g=ga.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){c&&!(e=Q.exec(h))||(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=R.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(P," ")}),h=h.slice(c.length));for(g in d.filter)!(e=V[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?ga.error(a):z(a,i).slice(0)};function sa(a){for(var b=0,c=a.length,d="";b<c;b++)d+=a[b].value;return d}function ta(a,b,c){var d=b.dir,e=b.next,f=e||d,g=c&&"parentNode"===f,h=x++;return b.first?function(b,c,e){while(b=b[d])if(1===b.nodeType||g)return a(b,c,e);return!1}:function(b,c,i){var j,k,l,m=[w,h];if(i){while(b=b[d])if((1===b.nodeType||g)&&a(b,c,i))return!0}else while(b=b[d])if(1===b.nodeType||g)if(l=b[u]||(b[u]={}),k=l[b.uniqueID]||(l[b.uniqueID]={}),e&&e===b.nodeName.toLowerCase())b=b[d]||b;else{if((j=k[f])&&j[0]===w&&j[1]===h)return m[2]=j[2];if(k[f]=m,m[2]=a(b,c,i))return!0}return!1}}function ua(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function va(a,b,c){for(var d=0,e=b.length;d<e;d++)ga(a,b[d],c);return c}function wa(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;h<i;h++)(f=a[h])&&(c&&!c(f,d,e)||(g.push(f),j&&b.push(h)));return g}function xa(a,b,c,d,e,f){return d&&!d[u]&&(d=xa(d)),e&&!e[u]&&(e=xa(e,f)),ia(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||va(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:wa(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=wa(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?I(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=wa(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):G.apply(g,r)})}function ya(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=ta(function(a){return a===b},h,!0),l=ta(function(a){return I(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];i<f;i++)if(c=d.relative[a[i].type])m=[ta(ua(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;e<f;e++)if(d.relative[a[e].type])break;return xa(i>1&&ua(m),i>1&&sa(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(P,"$1"),c,i<e&&ya(a.slice(i,e)),e<f&&ya(a=a.slice(e)),e<f&&sa(a))}m.push(c)}return ua(m)}function za(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,o,q,r=0,s="0",t=f&&[],u=[],v=j,x=f||e&&d.find.TAG("*",k),y=w+=null==v?1:Math.random()||.1,z=x.length;for(k&&(j=g===n||g||k);s!==z&&null!=(l=x[s]);s++){if(e&&l){o=0,g||l.ownerDocument===n||(m(l),h=!p);while(q=a[o++])if(q(l,g||n,h)){i.push(l);break}k&&(w=y)}c&&((l=!q&&l)&&r--,f&&t.push(l))}if(r+=s,c&&s!==r){o=0;while(q=b[o++])q(t,u,g,h);if(f){if(r>0)while(s--)t[s]||u[s]||(u[s]=E.call(i));u=wa(u)}G.apply(i,u),k&&!f&&u.length>0&&r+b.length>1&&ga.uniqueSort(i)}return k&&(w=y,j=v),t};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=ya(b[c]),f[u]?d.push(f):e.push(f);f=A(a,za(e,d)),f.selector=a}return f},i=ga.select=function(a,b,c,e){var f,i,j,k,l,m="function"==typeof a&&a,n=!e&&g(a=m.selector||a);if(c=c||[],1===n.length){if(i=n[0]=n[0].slice(0),i.length>2&&"ID"===(j=i[0]).type&&9===b.nodeType&&p&&d.relative[i[1].type]){if(b=(d.find.ID(j.matches[0].replace(_,aa),b)||[])[0],!b)return c;m&&(b=b.parentNode),a=a.slice(i.shift().value.length)}f=V.needsContext.test(a)?0:i.length;while(f--){if(j=i[f],d.relative[k=j.type])break;if((l=d.find[k])&&(e=l(j.matches[0].replace(_,aa),$.test(i[0].type)&&qa(b.parentNode)||b))){if(i.splice(f,1),a=e.length&&sa(i),!a)return G.apply(c,e),c;break}}}return(m||h(a,n))(e,b,!p,c,!b||$.test(a)&&qa(b.parentNode)||b),c},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("fieldset"))}),ja(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){if(!c)return a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){if(!c&&"input"===a.nodeName.toLowerCase())return a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(J,function(a,b,c){var d;if(!c)return a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);r.find=x,r.expr=x.selectors,r.expr[":"]=r.expr.pseudos,r.uniqueSort=r.unique=x.uniqueSort,r.text=x.getText,r.isXMLDoc=x.isXML,r.contains=x.contains,r.escapeSelector=x.escape;var y=function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&r(a).is(c))break;d.push(a)}return d},z=function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c},A=r.expr.match.needsContext;function B(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()}var C=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i,D=/^.[^:#\[\.,]*$/;function E(a,b,c){return r.isFunction(b)?r.grep(a,function(a,d){return!!b.call(a,d,a)!==c}):b.nodeType?r.grep(a,function(a){return a===b!==c}):"string"!=typeof b?r.grep(a,function(a){return i.call(b,a)>-1!==c}):D.test(b)?r.filter(b,a,c):(b=r.filter(b,a),r.grep(a,function(a){return i.call(b,a)>-1!==c&&1===a.nodeType}))}r.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?r.find.matchesSelector(d,a)?[d]:[]:r.find.matches(a,r.grep(b,function(a){return 1===a.nodeType}))},r.fn.extend({find:function(a){var b,c,d=this.length,e=this;if("string"!=typeof a)return this.pushStack(r(a).filter(function(){for(b=0;b<d;b++)if(r.contains(e[b],this))return!0}));for(c=this.pushStack([]),b=0;b<d;b++)r.find(a,e[b],c);return d>1?r.uniqueSort(c):c},filter:function(a){return this.pushStack(E(this,a||[],!1))},not:function(a){return this.pushStack(E(this,a||[],!0))},is:function(a){return!!E(this,"string"==typeof a&&A.test(a)?r(a):a||[],!1).length}});var F,G=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,H=r.fn.init=function(a,b,c){var e,f;if(!a)return this;if(c=c||F,"string"==typeof a){if(e="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:G.exec(a),!e||!e[1]&&b)return!b||b.jquery?(b||c).find(a):this.constructor(b).find(a);if(e[1]){if(b=b instanceof r?b[0]:b,r.merge(this,r.parseHTML(e[1],b&&b.nodeType?b.ownerDocument||b:d,!0)),C.test(e[1])&&r.isPlainObject(b))for(e in b)r.isFunction(this[e])?this[e](b[e]):this.attr(e,b[e]);return this}return f=d.getElementById(e[2]),f&&(this[0]=f,this.length=1),this}return a.nodeType?(this[0]=a,this.length=1,this):r.isFunction(a)?void 0!==c.ready?c.ready(a):a(r):r.makeArray(a,this)};H.prototype=r.fn,F=r(d);var I=/^(?:parents|prev(?:Until|All))/,J={children:!0,contents:!0,next:!0,prev:!0};r.fn.extend({has:function(a){var b=r(a,this),c=b.length;return this.filter(function(){for(var a=0;a<c;a++)if(r.contains(this,b[a]))return!0})},closest:function(a,b){var c,d=0,e=this.length,f=[],g="string"!=typeof a&&r(a);if(!A.test(a))for(;d<e;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&r.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?r.uniqueSort(f):f)},index:function(a){return a?"string"==typeof a?i.call(r(a),this[0]):i.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(r.uniqueSort(r.merge(this.get(),r(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function K(a,b){while((a=a[b])&&1!==a.nodeType);return a}r.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return y(a,"parentNode")},parentsUntil:function(a,b,c){return y(a,"parentNode",c)},next:function(a){return K(a,"nextSibling")},prev:function(a){return K(a,"previousSibling")},nextAll:function(a){return y(a,"nextSibling")},prevAll:function(a){return y(a,"previousSibling")},nextUntil:function(a,b,c){return y(a,"nextSibling",c)},prevUntil:function(a,b,c){return y(a,"previousSibling",c)},siblings:function(a){return z((a.parentNode||{}).firstChild,a)},children:function(a){return z(a.firstChild)},contents:function(a){return B(a,"iframe")?a.contentDocument:(B(a,"template")&&(a=a.content||a),r.merge([],a.childNodes))}},function(a,b){r.fn[a]=function(c,d){var e=r.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=r.filter(d,e)),this.length>1&&(J[a]||r.uniqueSort(e),I.test(a)&&e.reverse()),this.pushStack(e)}});var L=/[^\x20\t\r\n\f]+/g;function M(a){var b={};return r.each(a.match(L)||[],function(a,c){b[c]=!0}),b}r.Callbacks=function(a){a="string"==typeof a?M(a):r.extend({},a);var b,c,d,e,f=[],g=[],h=-1,i=function(){for(e=e||a.once,d=b=!0;g.length;h=-1){c=g.shift();while(++h<f.length)f[h].apply(c[0],c[1])===!1&&a.stopOnFalse&&(h=f.length,c=!1)}a.memory||(c=!1),b=!1,e&&(f=c?[]:"")},j={add:function(){return f&&(c&&!b&&(h=f.length-1,g.push(c)),function d(b){r.each(b,function(b,c){r.isFunction(c)?a.unique&&j.has(c)||f.push(c):c&&c.length&&"string"!==r.type(c)&&d(c)})}(arguments),c&&!b&&i()),this},remove:function(){return r.each(arguments,function(a,b){var c;while((c=r.inArray(b,f,c))>-1)f.splice(c,1),c<=h&&h--}),this},has:function(a){return a?r.inArray(a,f)>-1:f.length>0},empty:function(){return f&&(f=[]),this},disable:function(){return e=g=[],f=c="",this},disabled:function(){return!f},lock:function(){return e=g=[],c||b||(f=c=""),this},locked:function(){return!!e},fireWith:function(a,c){return e||(c=c||[],c=[a,c.slice?c.slice():c],g.push(c),b||i()),this},fire:function(){return j.fireWith(this,arguments),this},fired:function(){return!!d}};return j};function N(a){return a}function O(a){throw a}function P(a,b,c,d){var e;try{a&&r.isFunction(e=a.promise)?e.call(a).done(b).fail(c):a&&r.isFunction(e=a.then)?e.call(a,b,c):b.apply(void 0,[a].slice(d))}catch(a){c.apply(void 0,[a])}}r.extend({Deferred:function(b){var c=[["notify","progress",r.Callbacks("memory"),r.Callbacks("memory"),2],["resolve","done",r.Callbacks("once memory"),r.Callbacks("once memory"),0,"resolved"],["reject","fail",r.Callbacks("once memory"),r.Callbacks("once memory"),1,"rejected"]],d="pending",e={state:function(){return d},always:function(){return f.done(arguments).fail(arguments),this},"catch":function(a){return e.then(null,a)},pipe:function(){var a=arguments;return r.Deferred(function(b){r.each(c,function(c,d){var e=r.isFunction(a[d[4]])&&a[d[4]];f[d[1]](function(){var a=e&&e.apply(this,arguments);a&&r.isFunction(a.promise)?a.promise().progress(b.notify).done(b.resolve).fail(b.reject):b[d[0]+"With"](this,e?[a]:arguments)})}),a=null}).promise()},then:function(b,d,e){var f=0;function g(b,c,d,e){return function(){var h=this,i=arguments,j=function(){var a,j;if(!(b<f)){if(a=d.apply(h,i),a===c.promise())throw new TypeError("Thenable self-resolution");j=a&&("object"==typeof a||"function"==typeof a)&&a.then,r.isFunction(j)?e?j.call(a,g(f,c,N,e),g(f,c,O,e)):(f++,j.call(a,g(f,c,N,e),g(f,c,O,e),g(f,c,N,c.notifyWith))):(d!==N&&(h=void 0,i=[a]),(e||c.resolveWith)(h,i))}},k=e?j:function(){try{j()}catch(a){r.Deferred.exceptionHook&&r.Deferred.exceptionHook(a,k.stackTrace),b+1>=f&&(d!==O&&(h=void 0,i=[a]),c.rejectWith(h,i))}};b?k():(r.Deferred.getStackHook&&(k.stackTrace=r.Deferred.getStackHook()),a.setTimeout(k))}}return r.Deferred(function(a){c[0][3].add(g(0,a,r.isFunction(e)?e:N,a.notifyWith)),c[1][3].add(g(0,a,r.isFunction(b)?b:N)),c[2][3].add(g(0,a,r.isFunction(d)?d:O))}).promise()},promise:function(a){return null!=a?r.extend(a,e):e}},f={};return r.each(c,function(a,b){var g=b[2],h=b[5];e[b[1]]=g.add,h&&g.add(function(){d=h},c[3-a][2].disable,c[0][2].lock),g.add(b[3].fire),f[b[0]]=function(){return f[b[0]+"With"](this===f?void 0:this,arguments),this},f[b[0]+"With"]=g.fireWith}),e.promise(f),b&&b.call(f,f),f},when:function(a){var b=arguments.length,c=b,d=Array(c),e=f.call(arguments),g=r.Deferred(),h=function(a){return function(c){d[a]=this,e[a]=arguments.length>1?f.call(arguments):c,--b||g.resolveWith(d,e)}};if(b<=1&&(P(a,g.done(h(c)).resolve,g.reject,!b),"pending"===g.state()||r.isFunction(e[c]&&e[c].then)))return g.then();while(c--)P(e[c],h(c),g.reject);return g.promise()}});var Q=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;r.Deferred.exceptionHook=function(b,c){a.console&&a.console.warn&&b&&Q.test(b.name)&&a.console.warn("jQuery.Deferred exception: "+b.message,b.stack,c)},r.readyException=function(b){a.setTimeout(function(){throw b})};var R=r.Deferred();r.fn.ready=function(a){return R.then(a)["catch"](function(a){r.readyException(a)}),this},r.extend({isReady:!1,readyWait:1,ready:function(a){(a===!0?--r.readyWait:r.isReady)||(r.isReady=!0,a!==!0&&--r.readyWait>0||R.resolveWith(d,[r]))}}),r.ready.then=R.then;function S(){d.removeEventListener("DOMContentLoaded",S),
-a.removeEventListener("load",S),r.ready()}"complete"===d.readyState||"loading"!==d.readyState&&!d.documentElement.doScroll?a.setTimeout(r.ready):(d.addEventListener("DOMContentLoaded",S),a.addEventListener("load",S));var T=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===r.type(c)){e=!0;for(h in c)T(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,r.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(r(a),c)})),b))for(;h<i;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},U=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function V(){this.expando=r.expando+V.uid++}V.uid=1,V.prototype={cache:function(a){var b=a[this.expando];return b||(b={},U(a)&&(a.nodeType?a[this.expando]=b:Object.defineProperty(a,this.expando,{value:b,configurable:!0}))),b},set:function(a,b,c){var d,e=this.cache(a);if("string"==typeof b)e[r.camelCase(b)]=c;else for(d in b)e[r.camelCase(d)]=b[d];return e},get:function(a,b){return void 0===b?this.cache(a):a[this.expando]&&a[this.expando][r.camelCase(b)]},access:function(a,b,c){return void 0===b||b&&"string"==typeof b&&void 0===c?this.get(a,b):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d=a[this.expando];if(void 0!==d){if(void 0!==b){Array.isArray(b)?b=b.map(r.camelCase):(b=r.camelCase(b),b=b in d?[b]:b.match(L)||[]),c=b.length;while(c--)delete d[b[c]]}(void 0===b||r.isEmptyObject(d))&&(a.nodeType?a[this.expando]=void 0:delete a[this.expando])}},hasData:function(a){var b=a[this.expando];return void 0!==b&&!r.isEmptyObject(b)}};var W=new V,X=new V,Y=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,Z=/[A-Z]/g;function $(a){return"true"===a||"false"!==a&&("null"===a?null:a===+a+""?+a:Y.test(a)?JSON.parse(a):a)}function _(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(Z,"-$&").toLowerCase(),c=a.getAttribute(d),"string"==typeof c){try{c=$(c)}catch(e){}X.set(a,b,c)}else c=void 0;return c}r.extend({hasData:function(a){return X.hasData(a)||W.hasData(a)},data:function(a,b,c){return X.access(a,b,c)},removeData:function(a,b){X.remove(a,b)},_data:function(a,b,c){return W.access(a,b,c)},_removeData:function(a,b){W.remove(a,b)}}),r.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=X.get(f),1===f.nodeType&&!W.get(f,"hasDataAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=r.camelCase(d.slice(5)),_(f,d,e[d])));W.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){X.set(this,a)}):T(this,function(b){var c;if(f&&void 0===b){if(c=X.get(f,a),void 0!==c)return c;if(c=_(f,a),void 0!==c)return c}else this.each(function(){X.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){X.remove(this,a)})}}),r.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=W.get(a,b),c&&(!d||Array.isArray(c)?d=W.access(a,b,r.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=r.queue(a,b),d=c.length,e=c.shift(),f=r._queueHooks(a,b),g=function(){r.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return W.get(a,c)||W.access(a,c,{empty:r.Callbacks("once memory").add(function(){W.remove(a,[b+"queue",c])})})}}),r.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?r.queue(this[0],a):void 0===b?this:this.each(function(){var c=r.queue(this,a,b);r._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&r.dequeue(this,a)})},dequeue:function(a){return this.each(function(){r.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=r.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=W.get(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var aa=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,ba=new RegExp("^(?:([+-])=|)("+aa+")([a-z%]*)$","i"),ca=["Top","Right","Bottom","Left"],da=function(a,b){return a=b||a,"none"===a.style.display||""===a.style.display&&r.contains(a.ownerDocument,a)&&"none"===r.css(a,"display")},ea=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};function fa(a,b,c,d){var e,f=1,g=20,h=d?function(){return d.cur()}:function(){return r.css(a,b,"")},i=h(),j=c&&c[3]||(r.cssNumber[b]?"":"px"),k=(r.cssNumber[b]||"px"!==j&&+i)&&ba.exec(r.css(a,b));if(k&&k[3]!==j){j=j||k[3],c=c||[],k=+i||1;do f=f||".5",k/=f,r.style(a,b,k+j);while(f!==(f=h()/i)&&1!==f&&--g)}return c&&(k=+k||+i||0,e=c[1]?k+(c[1]+1)*c[2]:+c[2],d&&(d.unit=j,d.start=k,d.end=e)),e}var ga={};function ha(a){var b,c=a.ownerDocument,d=a.nodeName,e=ga[d];return e?e:(b=c.body.appendChild(c.createElement(d)),e=r.css(b,"display"),b.parentNode.removeChild(b),"none"===e&&(e="block"),ga[d]=e,e)}function ia(a,b){for(var c,d,e=[],f=0,g=a.length;f<g;f++)d=a[f],d.style&&(c=d.style.display,b?("none"===c&&(e[f]=W.get(d,"display")||null,e[f]||(d.style.display="")),""===d.style.display&&da(d)&&(e[f]=ha(d))):"none"!==c&&(e[f]="none",W.set(d,"display",c)));for(f=0;f<g;f++)null!=e[f]&&(a[f].style.display=e[f]);return a}r.fn.extend({show:function(){return ia(this,!0)},hide:function(){return ia(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){da(this)?r(this).show():r(this).hide()})}});var ja=/^(?:checkbox|radio)$/i,ka=/<([a-z][^\/\0>\x20\t\r\n\f]+)/i,la=/^$|\/(?:java|ecma)script/i,ma={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};ma.optgroup=ma.option,ma.tbody=ma.tfoot=ma.colgroup=ma.caption=ma.thead,ma.th=ma.td;function na(a,b){var c;return c="undefined"!=typeof a.getElementsByTagName?a.getElementsByTagName(b||"*"):"undefined"!=typeof a.querySelectorAll?a.querySelectorAll(b||"*"):[],void 0===b||b&&B(a,b)?r.merge([a],c):c}function oa(a,b){for(var c=0,d=a.length;c<d;c++)W.set(a[c],"globalEval",!b||W.get(b[c],"globalEval"))}var pa=/<|&#?\w+;/;function qa(a,b,c,d,e){for(var f,g,h,i,j,k,l=b.createDocumentFragment(),m=[],n=0,o=a.length;n<o;n++)if(f=a[n],f||0===f)if("object"===r.type(f))r.merge(m,f.nodeType?[f]:f);else if(pa.test(f)){g=g||l.appendChild(b.createElement("div")),h=(ka.exec(f)||["",""])[1].toLowerCase(),i=ma[h]||ma._default,g.innerHTML=i[1]+r.htmlPrefilter(f)+i[2],k=i[0];while(k--)g=g.lastChild;r.merge(m,g.childNodes),g=l.firstChild,g.textContent=""}else m.push(b.createTextNode(f));l.textContent="",n=0;while(f=m[n++])if(d&&r.inArray(f,d)>-1)e&&e.push(f);else if(j=r.contains(f.ownerDocument,f),g=na(l.appendChild(f),"script"),j&&oa(g),c){k=0;while(f=g[k++])la.test(f.type||"")&&c.push(f)}return l}!function(){var a=d.createDocumentFragment(),b=a.appendChild(d.createElement("div")),c=d.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),o.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="<textarea>x</textarea>",o.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var ra=d.documentElement,sa=/^key/,ta=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,ua=/^([^.]*)(?:\.(.+)|)/;function va(){return!0}function wa(){return!1}function xa(){try{return d.activeElement}catch(a){}}function ya(a,b,c,d,e,f){var g,h;if("object"==typeof b){"string"!=typeof c&&(d=d||c,c=void 0);for(h in b)ya(a,h,c,d,b[h],f);return a}if(null==d&&null==e?(e=c,d=c=void 0):null==e&&("string"==typeof c?(e=d,d=void 0):(e=d,d=c,c=void 0)),e===!1)e=wa;else if(!e)return a;return 1===f&&(g=e,e=function(a){return r().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=r.guid++)),a.each(function(){r.event.add(this,b,e,d,c)})}r.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=W.get(a);if(q){c.handler&&(f=c,c=f.handler,e=f.selector),e&&r.find.matchesSelector(ra,e),c.guid||(c.guid=r.guid++),(i=q.events)||(i=q.events={}),(g=q.handle)||(g=q.handle=function(b){return"undefined"!=typeof r&&r.event.triggered!==b.type?r.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(L)||[""],j=b.length;while(j--)h=ua.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n&&(l=r.event.special[n]||{},n=(e?l.delegateType:l.bindType)||n,l=r.event.special[n]||{},k=r.extend({type:n,origType:p,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&r.expr.match.needsContext.test(e),namespace:o.join(".")},f),(m=i[n])||(m=i[n]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,o,g)!==!1||a.addEventListener&&a.addEventListener(n,g)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),r.event.global[n]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=W.hasData(a)&&W.get(a);if(q&&(i=q.events)){b=(b||"").match(L)||[""],j=b.length;while(j--)if(h=ua.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n){l=r.event.special[n]||{},n=(d?l.delegateType:l.bindType)||n,m=i[n]||[],h=h[2]&&new RegExp("(^|\\.)"+o.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&p!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,o,q.handle)!==!1||r.removeEvent(a,n,q.handle),delete i[n])}else for(n in i)r.event.remove(a,n+b[j],c,d,!0);r.isEmptyObject(i)&&W.remove(a,"handle events")}},dispatch:function(a){var b=r.event.fix(a),c,d,e,f,g,h,i=new Array(arguments.length),j=(W.get(this,"events")||{})[b.type]||[],k=r.event.special[b.type]||{};for(i[0]=b,c=1;c<arguments.length;c++)i[c]=arguments[c];if(b.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,b)!==!1){h=r.event.handlers.call(this,b,j),c=0;while((f=h[c++])&&!b.isPropagationStopped()){b.currentTarget=f.elem,d=0;while((g=f.handlers[d++])&&!b.isImmediatePropagationStopped())b.rnamespace&&!b.rnamespace.test(g.namespace)||(b.handleObj=g,b.data=g.data,e=((r.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==e&&(b.result=e)===!1&&(b.preventDefault(),b.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,b),b.result}},handlers:function(a,b){var c,d,e,f,g,h=[],i=b.delegateCount,j=a.target;if(i&&j.nodeType&&!("click"===a.type&&a.button>=1))for(;j!==this;j=j.parentNode||this)if(1===j.nodeType&&("click"!==a.type||j.disabled!==!0)){for(f=[],g={},c=0;c<i;c++)d=b[c],e=d.selector+" ",void 0===g[e]&&(g[e]=d.needsContext?r(e,this).index(j)>-1:r.find(e,this,null,[j]).length),g[e]&&f.push(d);f.length&&h.push({elem:j,handlers:f})}return j=this,i<b.length&&h.push({elem:j,handlers:b.slice(i)}),h},addProp:function(a,b){Object.defineProperty(r.Event.prototype,a,{enumerable:!0,configurable:!0,get:r.isFunction(b)?function(){if(this.originalEvent)return b(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[a]},set:function(b){Object.defineProperty(this,a,{enumerable:!0,configurable:!0,writable:!0,value:b})}})},fix:function(a){return a[r.expando]?a:new r.Event(a)},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==xa()&&this.focus)return this.focus(),!1},delegateType:"focusin"},blur:{trigger:function(){if(this===xa()&&this.blur)return this.blur(),!1},delegateType:"focusout"},click:{trigger:function(){if(ja.test(this.type)&&this.click&&B(this,"input"))return this.click(),!1},_default:function(a){return B(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}}},r.removeEvent=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c)},r.Event=function(a,b){return this instanceof r.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?va:wa,this.target=a.target&&3===a.target.nodeType?a.target.parentNode:a.target,this.currentTarget=a.currentTarget,this.relatedTarget=a.relatedTarget):this.type=a,b&&r.extend(this,b),this.timeStamp=a&&a.timeStamp||r.now(),void(this[r.expando]=!0)):new r.Event(a,b)},r.Event.prototype={constructor:r.Event,isDefaultPrevented:wa,isPropagationStopped:wa,isImmediatePropagationStopped:wa,isSimulated:!1,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=va,a&&!this.isSimulated&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=va,a&&!this.isSimulated&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=va,a&&!this.isSimulated&&a.stopImmediatePropagation(),this.stopPropagation()}},r.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(a){var b=a.button;return null==a.which&&sa.test(a.type)?null!=a.charCode?a.charCode:a.keyCode:!a.which&&void 0!==b&&ta.test(a.type)?1&b?1:2&b?3:4&b?2:0:a.which}},r.event.addProp),r.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){r.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return e&&(e===d||r.contains(d,e))||(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),r.fn.extend({on:function(a,b,c,d){return ya(this,a,b,c,d)},one:function(a,b,c,d){return ya(this,a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,r(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return b!==!1&&"function"!=typeof b||(c=b,b=void 0),c===!1&&(c=wa),this.each(function(){r.event.remove(this,a,c,b)})}});var za=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,Aa=/<script|<style|<link/i,Ba=/checked\s*(?:[^=]|=\s*.checked.)/i,Ca=/^true\/(.*)/,Da=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function Ea(a,b){return B(a,"table")&&B(11!==b.nodeType?b:b.firstChild,"tr")?r(">tbody",a)[0]||a:a}function Fa(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function Ga(a){var b=Ca.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function Ha(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(W.hasData(a)&&(f=W.access(a),g=W.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;c<d;c++)r.event.add(b,e,j[e][c])}X.hasData(a)&&(h=X.access(a),i=r.extend({},h),X.set(b,i))}}function Ia(a,b){var c=b.nodeName.toLowerCase();"input"===c&&ja.test(a.type)?b.checked=a.checked:"input"!==c&&"textarea"!==c||(b.defaultValue=a.defaultValue)}function Ja(a,b,c,d){b=g.apply([],b);var e,f,h,i,j,k,l=0,m=a.length,n=m-1,q=b[0],s=r.isFunction(q);if(s||m>1&&"string"==typeof q&&!o.checkClone&&Ba.test(q))return a.each(function(e){var f=a.eq(e);s&&(b[0]=q.call(this,e,f.html())),Ja(f,b,c,d)});if(m&&(e=qa(b,a[0].ownerDocument,!1,a,d),f=e.firstChild,1===e.childNodes.length&&(e=f),f||d)){for(h=r.map(na(e,"script"),Fa),i=h.length;l<m;l++)j=e,l!==n&&(j=r.clone(j,!0,!0),i&&r.merge(h,na(j,"script"))),c.call(a[l],j,l);if(i)for(k=h[h.length-1].ownerDocument,r.map(h,Ga),l=0;l<i;l++)j=h[l],la.test(j.type||"")&&!W.access(j,"globalEval")&&r.contains(k,j)&&(j.src?r._evalUrl&&r._evalUrl(j.src):p(j.textContent.replace(Da,""),k))}return a}function Ka(a,b,c){for(var d,e=b?r.filter(b,a):a,f=0;null!=(d=e[f]);f++)c||1!==d.nodeType||r.cleanData(na(d)),d.parentNode&&(c&&r.contains(d.ownerDocument,d)&&oa(na(d,"script")),d.parentNode.removeChild(d));return a}r.extend({htmlPrefilter:function(a){return a.replace(za,"<$1></$2>")},clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=r.contains(a.ownerDocument,a);if(!(o.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||r.isXMLDoc(a)))for(g=na(h),f=na(a),d=0,e=f.length;d<e;d++)Ia(f[d],g[d]);if(b)if(c)for(f=f||na(a),g=g||na(h),d=0,e=f.length;d<e;d++)Ha(f[d],g[d]);else Ha(a,h);return g=na(h,"script"),g.length>0&&oa(g,!i&&na(a,"script")),h},cleanData:function(a){for(var b,c,d,e=r.event.special,f=0;void 0!==(c=a[f]);f++)if(U(c)){if(b=c[W.expando]){if(b.events)for(d in b.events)e[d]?r.event.remove(c,d):r.removeEvent(c,d,b.handle);c[W.expando]=void 0}c[X.expando]&&(c[X.expando]=void 0)}}}),r.fn.extend({detach:function(a){return Ka(this,a,!0)},remove:function(a){return Ka(this,a)},text:function(a){return T(this,function(a){return void 0===a?r.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=a)})},null,a,arguments.length)},append:function(){return Ja(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Ea(this,a);b.appendChild(a)}})},prepend:function(){return Ja(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Ea(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return Ja(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return Ja(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(r.cleanData(na(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null!=a&&a,b=null==b?a:b,this.map(function(){return r.clone(this,a,b)})},html:function(a){return T(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!Aa.test(a)&&!ma[(ka.exec(a)||["",""])[1].toLowerCase()]){a=r.htmlPrefilter(a);try{for(;c<d;c++)b=this[c]||{},1===b.nodeType&&(r.cleanData(na(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=[];return Ja(this,arguments,function(b){var c=this.parentNode;r.inArray(this,a)<0&&(r.cleanData(na(this)),c&&c.replaceChild(b,this))},a)}}),r.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){r.fn[a]=function(a){for(var c,d=[],e=r(a),f=e.length-1,g=0;g<=f;g++)c=g===f?this:this.clone(!0),r(e[g])[b](c),h.apply(d,c.get());return this.pushStack(d)}});var La=/^margin/,Ma=new RegExp("^("+aa+")(?!px)[a-z%]+$","i"),Na=function(b){var c=b.ownerDocument.defaultView;return c&&c.opener||(c=a),c.getComputedStyle(b)};!function(){function b(){if(i){i.style.cssText="box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%",i.innerHTML="",ra.appendChild(h);var b=a.getComputedStyle(i);c="1%"!==b.top,g="2px"===b.marginLeft,e="4px"===b.width,i.style.marginRight="50%",f="4px"===b.marginRight,ra.removeChild(h),i=null}}var c,e,f,g,h=d.createElement("div"),i=d.createElement("div");i.style&&(i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",o.clearCloneStyle="content-box"===i.style.backgroundClip,h.style.cssText="border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute",h.appendChild(i),r.extend(o,{pixelPosition:function(){return b(),c},boxSizingReliable:function(){return b(),e},pixelMarginRight:function(){return b(),f},reliableMarginLeft:function(){return b(),g}}))}();function Oa(a,b,c){var d,e,f,g,h=a.style;return c=c||Na(a),c&&(g=c.getPropertyValue(b)||c[b],""!==g||r.contains(a.ownerDocument,a)||(g=r.style(a,b)),!o.pixelMarginRight()&&Ma.test(g)&&La.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0!==g?g+"":g}function Pa(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}var Qa=/^(none|table(?!-c[ea]).+)/,Ra=/^--/,Sa={position:"absolute",visibility:"hidden",display:"block"},Ta={letterSpacing:"0",fontWeight:"400"},Ua=["Webkit","Moz","ms"],Va=d.createElement("div").style;function Wa(a){if(a in Va)return a;var b=a[0].toUpperCase()+a.slice(1),c=Ua.length;while(c--)if(a=Ua[c]+b,a in Va)return a}function Xa(a){var b=r.cssProps[a];return b||(b=r.cssProps[a]=Wa(a)||a),b}function Ya(a,b,c){var d=ba.exec(b);return d?Math.max(0,d[2]-(c||0))+(d[3]||"px"):b}function Za(a,b,c,d,e){var f,g=0;for(f=c===(d?"border":"content")?4:"width"===b?1:0;f<4;f+=2)"margin"===c&&(g+=r.css(a,c+ca[f],!0,e)),d?("content"===c&&(g-=r.css(a,"padding"+ca[f],!0,e)),"margin"!==c&&(g-=r.css(a,"border"+ca[f]+"Width",!0,e))):(g+=r.css(a,"padding"+ca[f],!0,e),"padding"!==c&&(g+=r.css(a,"border"+ca[f]+"Width",!0,e)));return g}function $a(a,b,c){var d,e=Na(a),f=Oa(a,b,e),g="border-box"===r.css(a,"boxSizing",!1,e);return Ma.test(f)?f:(d=g&&(o.boxSizingReliable()||f===a.style[b]),f=parseFloat(f)||0,f+Za(a,b,c||(g?"border":"content"),d,e)+"px")}r.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Oa(a,"opacity");return""===c?"1":c}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=r.camelCase(b),i=Ra.test(b),j=a.style;return i||(b=Xa(h)),g=r.cssHooks[b]||r.cssHooks[h],void 0===c?g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:j[b]:(f=typeof c,"string"===f&&(e=ba.exec(c))&&e[1]&&(c=fa(a,b,e),f="number"),null!=c&&c===c&&("number"===f&&(c+=e&&e[3]||(r.cssNumber[h]?"":"px")),o.clearCloneStyle||""!==c||0!==b.indexOf("background")||(j[b]="inherit"),g&&"set"in g&&void 0===(c=g.set(a,c,d))||(i?j.setProperty(b,c):j[b]=c)),void 0)}},css:function(a,b,c,d){var e,f,g,h=r.camelCase(b),i=Ra.test(b);return i||(b=Xa(h)),g=r.cssHooks[b]||r.cssHooks[h],g&&"get"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=Oa(a,b,d)),"normal"===e&&b in Ta&&(e=Ta[b]),""===c||c?(f=parseFloat(e),c===!0||isFinite(f)?f||0:e):e}}),r.each(["height","width"],function(a,b){r.cssHooks[b]={get:function(a,c,d){if(c)return!Qa.test(r.css(a,"display"))||a.getClientRects().length&&a.getBoundingClientRect().width?$a(a,b,d):ea(a,Sa,function(){return $a(a,b,d)})},set:function(a,c,d){var e,f=d&&Na(a),g=d&&Za(a,b,d,"border-box"===r.css(a,"boxSizing",!1,f),f);return g&&(e=ba.exec(c))&&"px"!==(e[3]||"px")&&(a.style[b]=c,c=r.css(a,b)),Ya(a,c,g)}}}),r.cssHooks.marginLeft=Pa(o.reliableMarginLeft,function(a,b){if(b)return(parseFloat(Oa(a,"marginLeft"))||a.getBoundingClientRect().left-ea(a,{marginLeft:0},function(){return a.getBoundingClientRect().left}))+"px"}),r.each({margin:"",padding:"",border:"Width"},function(a,b){r.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];d<4;d++)e[a+ca[d]+b]=f[d]||f[d-2]||f[0];return e}},La.test(a)||(r.cssHooks[a+b].set=Ya)}),r.fn.extend({css:function(a,b){return T(this,function(a,b,c){var d,e,f={},g=0;if(Array.isArray(b)){for(d=Na(a),e=b.length;g<e;g++)f[b[g]]=r.css(a,b[g],!1,d);return f}return void 0!==c?r.style(a,b,c):r.css(a,b)},a,b,arguments.length>1)}});function _a(a,b,c,d,e){return new _a.prototype.init(a,b,c,d,e)}r.Tween=_a,_a.prototype={constructor:_a,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||r.easing._default,this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(r.cssNumber[c]?"":"px")},cur:function(){var a=_a.propHooks[this.prop];return a&&a.get?a.get(this):_a.propHooks._default.get(this)},run:function(a){var b,c=_a.propHooks[this.prop];return this.options.duration?this.pos=b=r.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):_a.propHooks._default.set(this),this}},_a.prototype.init.prototype=_a.prototype,_a.propHooks={_default:{get:function(a){var b;return 1!==a.elem.nodeType||null!=a.elem[a.prop]&&null==a.elem.style[a.prop]?a.elem[a.prop]:(b=r.css(a.elem,a.prop,""),b&&"auto"!==b?b:0)},set:function(a){r.fx.step[a.prop]?r.fx.step[a.prop](a):1!==a.elem.nodeType||null==a.elem.style[r.cssProps[a.prop]]&&!r.cssHooks[a.prop]?a.elem[a.prop]=a.now:r.style(a.elem,a.prop,a.now+a.unit)}}},_a.propHooks.scrollTop=_a.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},r.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2},_default:"swing"},r.fx=_a.prototype.init,r.fx.step={};var ab,bb,cb=/^(?:toggle|show|hide)$/,db=/queueHooks$/;function eb(){bb&&(d.hidden===!1&&a.requestAnimationFrame?a.requestAnimationFrame(eb):a.setTimeout(eb,r.fx.interval),r.fx.tick())}function fb(){return a.setTimeout(function(){ab=void 0}),ab=r.now()}function gb(a,b){var c,d=0,e={height:a};for(b=b?1:0;d<4;d+=2-b)c=ca[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function hb(a,b,c){for(var d,e=(kb.tweeners[b]||[]).concat(kb.tweeners["*"]),f=0,g=e.length;f<g;f++)if(d=e[f].call(c,b,a))return d}function ib(a,b,c){var d,e,f,g,h,i,j,k,l="width"in b||"height"in b,m=this,n={},o=a.style,p=a.nodeType&&da(a),q=W.get(a,"fxshow");c.queue||(g=r._queueHooks(a,"fx"),null==g.unqueued&&(g.unqueued=0,h=g.empty.fire,g.empty.fire=function(){g.unqueued||h()}),g.unqueued++,m.always(function(){m.always(function(){g.unqueued--,r.queue(a,"fx").length||g.empty.fire()})}));for(d in b)if(e=b[d],cb.test(e)){if(delete b[d],f=f||"toggle"===e,e===(p?"hide":"show")){if("show"!==e||!q||void 0===q[d])continue;p=!0}n[d]=q&&q[d]||r.style(a,d)}if(i=!r.isEmptyObject(b),i||!r.isEmptyObject(n)){l&&1===a.nodeType&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=q&&q.display,null==j&&(j=W.get(a,"display")),k=r.css(a,"display"),"none"===k&&(j?k=j:(ia([a],!0),j=a.style.display||j,k=r.css(a,"display"),ia([a]))),("inline"===k||"inline-block"===k&&null!=j)&&"none"===r.css(a,"float")&&(i||(m.done(function(){o.display=j}),null==j&&(k=o.display,j="none"===k?"":k)),o.display="inline-block")),c.overflow&&(o.overflow="hidden",m.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]})),i=!1;for(d in n)i||(q?"hidden"in q&&(p=q.hidden):q=W.access(a,"fxshow",{display:j}),f&&(q.hidden=!p),p&&ia([a],!0),m.done(function(){p||ia([a]),W.remove(a,"fxshow");for(d in n)r.style(a,d,n[d])})),i=hb(p?q[d]:0,d,m),d in q||(q[d]=i.start,p&&(i.end=i.start,i.start=0))}}function jb(a,b){var c,d,e,f,g;for(c in a)if(d=r.camelCase(c),e=b[d],f=a[c],Array.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=r.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function kb(a,b,c){var d,e,f=0,g=kb.prefilters.length,h=r.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=ab||fb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;g<i;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),f<1&&i?c:(i||h.notifyWith(a,[j,1,0]),h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:r.extend({},b),opts:r.extend(!0,{specialEasing:{},easing:r.easing._default},c),originalProperties:b,originalOptions:c,startTime:ab||fb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=r.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;c<d;c++)j.tweens[c].run(1);return b?(h.notifyWith(a,[j,1,0]),h.resolveWith(a,[j,b])):h.rejectWith(a,[j,b]),this}}),k=j.props;for(jb(k,j.opts.specialEasing);f<g;f++)if(d=kb.prefilters[f].call(j,a,k,j.opts))return r.isFunction(d.stop)&&(r._queueHooks(j.elem,j.opts.queue).stop=r.proxy(d.stop,d)),d;return r.map(k,hb,j),r.isFunction(j.opts.start)&&j.opts.start.call(a,j),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always),r.fx.timer(r.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j}r.Animation=r.extend(kb,{tweeners:{"*":[function(a,b){var c=this.createTween(a,b);return fa(c.elem,a,ba.exec(b),c),c}]},tweener:function(a,b){r.isFunction(a)?(b=a,a=["*"]):a=a.match(L);for(var c,d=0,e=a.length;d<e;d++)c=a[d],kb.tweeners[c]=kb.tweeners[c]||[],kb.tweeners[c].unshift(b)},prefilters:[ib],prefilter:function(a,b){b?kb.prefilters.unshift(a):kb.prefilters.push(a)}}),r.speed=function(a,b,c){var d=a&&"object"==typeof a?r.extend({},a):{complete:c||!c&&b||r.isFunction(a)&&a,duration:a,easing:c&&b||b&&!r.isFunction(b)&&b};return r.fx.off?d.duration=0:"number"!=typeof d.duration&&(d.duration in r.fx.speeds?d.duration=r.fx.speeds[d.duration]:d.duration=r.fx.speeds._default),null!=d.queue&&d.queue!==!0||(d.queue="fx"),d.old=d.complete,d.complete=function(){r.isFunction(d.old)&&d.old.call(this),d.queue&&r.dequeue(this,d.queue)},d},r.fn.extend({fadeTo:function(a,b,c,d){return this.filter(da).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=r.isEmptyObject(a),f=r.speed(b,c,d),g=function(){var b=kb(this,r.extend({},a),f);(e||W.get(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=r.timers,g=W.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&db.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));!b&&c||r.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=W.get(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=r.timers,g=d?d.length:0;for(c.finish=!0,r.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;b<g;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),r.each(["toggle","show","hide"],function(a,b){var c=r.fn[b];r.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(gb(b,!0),a,d,e)}}),r.each({slideDown:gb("show"),slideUp:gb("hide"),slideToggle:gb("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){r.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),r.timers=[],r.fx.tick=function(){var a,b=0,c=r.timers;for(ab=r.now();b<c.length;b++)a=c[b],a()||c[b]!==a||c.splice(b--,1);c.length||r.fx.stop(),ab=void 0},r.fx.timer=function(a){r.timers.push(a),r.fx.start()},r.fx.interval=13,r.fx.start=function(){bb||(bb=!0,eb())},r.fx.stop=function(){bb=null},r.fx.speeds={slow:600,fast:200,_default:400},r.fn.delay=function(b,c){return b=r.fx?r.fx.speeds[b]||b:b,c=c||"fx",this.queue(c,function(c,d){var e=a.setTimeout(c,b);d.stop=function(){a.clearTimeout(e)}})},function(){var a=d.createElement("input"),b=d.createElement("select"),c=b.appendChild(d.createElement("option"));a.type="checkbox",o.checkOn=""!==a.value,o.optSelected=c.selected,a=d.createElement("input"),a.value="t",a.type="radio",o.radioValue="t"===a.value}();var lb,mb=r.expr.attrHandle;r.fn.extend({attr:function(a,b){return T(this,r.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){r.removeAttr(this,a)})}}),r.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return"undefined"==typeof a.getAttribute?r.prop(a,b,c):(1===f&&r.isXMLDoc(a)||(e=r.attrHooks[b.toLowerCase()]||(r.expr.match.bool.test(b)?lb:void 0)),void 0!==c?null===c?void r.removeAttr(a,b):e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:(a.setAttribute(b,c+""),c):e&&"get"in e&&null!==(d=e.get(a,b))?d:(d=r.find.attr(a,b),null==d?void 0:d));
-},attrHooks:{type:{set:function(a,b){if(!o.radioValue&&"radio"===b&&B(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}},removeAttr:function(a,b){var c,d=0,e=b&&b.match(L);if(e&&1===a.nodeType)while(c=e[d++])a.removeAttribute(c)}}),lb={set:function(a,b,c){return b===!1?r.removeAttr(a,c):a.setAttribute(c,c),c}},r.each(r.expr.match.bool.source.match(/\w+/g),function(a,b){var c=mb[b]||r.find.attr;mb[b]=function(a,b,d){var e,f,g=b.toLowerCase();return d||(f=mb[g],mb[g]=e,e=null!=c(a,b,d)?g:null,mb[g]=f),e}});var nb=/^(?:input|select|textarea|button)$/i,ob=/^(?:a|area)$/i;r.fn.extend({prop:function(a,b){return T(this,r.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[r.propFix[a]||a]})}}),r.extend({prop:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return 1===f&&r.isXMLDoc(a)||(b=r.propFix[b]||b,e=r.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=r.find.attr(a,"tabindex");return b?parseInt(b,10):nb.test(a.nodeName)||ob.test(a.nodeName)&&a.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),o.optSelected||(r.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null},set:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}}),r.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){r.propFix[this.toLowerCase()]=this});function pb(a){var b=a.match(L)||[];return b.join(" ")}function qb(a){return a.getAttribute&&a.getAttribute("class")||""}r.fn.extend({addClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).addClass(a.call(this,b,qb(this)))});if("string"==typeof a&&a){b=a.match(L)||[];while(c=this[i++])if(e=qb(c),d=1===c.nodeType&&" "+pb(e)+" "){g=0;while(f=b[g++])d.indexOf(" "+f+" ")<0&&(d+=f+" ");h=pb(d),e!==h&&c.setAttribute("class",h)}}return this},removeClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).removeClass(a.call(this,b,qb(this)))});if(!arguments.length)return this.attr("class","");if("string"==typeof a&&a){b=a.match(L)||[];while(c=this[i++])if(e=qb(c),d=1===c.nodeType&&" "+pb(e)+" "){g=0;while(f=b[g++])while(d.indexOf(" "+f+" ")>-1)d=d.replace(" "+f+" "," ");h=pb(d),e!==h&&c.setAttribute("class",h)}}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):r.isFunction(a)?this.each(function(c){r(this).toggleClass(a.call(this,c,qb(this),b),b)}):this.each(function(){var b,d,e,f;if("string"===c){d=0,e=r(this),f=a.match(L)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else void 0!==a&&"boolean"!==c||(b=qb(this),b&&W.set(this,"__className__",b),this.setAttribute&&this.setAttribute("class",b||a===!1?"":W.get(this,"__className__")||""))})},hasClass:function(a){var b,c,d=0;b=" "+a+" ";while(c=this[d++])if(1===c.nodeType&&(" "+pb(qb(c))+" ").indexOf(b)>-1)return!0;return!1}});var rb=/\r/g;r.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=r.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,r(this).val()):a,null==e?e="":"number"==typeof e?e+="":Array.isArray(e)&&(e=r.map(e,function(a){return null==a?"":a+""})),b=r.valHooks[this.type]||r.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=r.valHooks[e.type]||r.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(rb,""):null==c?"":c)}}}),r.extend({valHooks:{option:{get:function(a){var b=r.find.attr(a,"value");return null!=b?b:pb(r.text(a))}},select:{get:function(a){var b,c,d,e=a.options,f=a.selectedIndex,g="select-one"===a.type,h=g?null:[],i=g?f+1:e.length;for(d=f<0?i:g?f:0;d<i;d++)if(c=e[d],(c.selected||d===f)&&!c.disabled&&(!c.parentNode.disabled||!B(c.parentNode,"optgroup"))){if(b=r(c).val(),g)return b;h.push(b)}return h},set:function(a,b){var c,d,e=a.options,f=r.makeArray(b),g=e.length;while(g--)d=e[g],(d.selected=r.inArray(r.valHooks.option.get(d),f)>-1)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),r.each(["radio","checkbox"],function(){r.valHooks[this]={set:function(a,b){if(Array.isArray(b))return a.checked=r.inArray(r(a).val(),b)>-1}},o.checkOn||(r.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var sb=/^(?:focusinfocus|focusoutblur)$/;r.extend(r.event,{trigger:function(b,c,e,f){var g,h,i,j,k,m,n,o=[e||d],p=l.call(b,"type")?b.type:b,q=l.call(b,"namespace")?b.namespace.split("."):[];if(h=i=e=e||d,3!==e.nodeType&&8!==e.nodeType&&!sb.test(p+r.event.triggered)&&(p.indexOf(".")>-1&&(q=p.split("."),p=q.shift(),q.sort()),k=p.indexOf(":")<0&&"on"+p,b=b[r.expando]?b:new r.Event(p,"object"==typeof b&&b),b.isTrigger=f?2:3,b.namespace=q.join("."),b.rnamespace=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=e),c=null==c?[b]:r.makeArray(c,[b]),n=r.event.special[p]||{},f||!n.trigger||n.trigger.apply(e,c)!==!1)){if(!f&&!n.noBubble&&!r.isWindow(e)){for(j=n.delegateType||p,sb.test(j+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),i=h;i===(e.ownerDocument||d)&&o.push(i.defaultView||i.parentWindow||a)}g=0;while((h=o[g++])&&!b.isPropagationStopped())b.type=g>1?j:n.bindType||p,m=(W.get(h,"events")||{})[b.type]&&W.get(h,"handle"),m&&m.apply(h,c),m=k&&h[k],m&&m.apply&&U(h)&&(b.result=m.apply(h,c),b.result===!1&&b.preventDefault());return b.type=p,f||b.isDefaultPrevented()||n._default&&n._default.apply(o.pop(),c)!==!1||!U(e)||k&&r.isFunction(e[p])&&!r.isWindow(e)&&(i=e[k],i&&(e[k]=null),r.event.triggered=p,e[p](),r.event.triggered=void 0,i&&(e[k]=i)),b.result}},simulate:function(a,b,c){var d=r.extend(new r.Event,c,{type:a,isSimulated:!0});r.event.trigger(d,null,b)}}),r.fn.extend({trigger:function(a,b){return this.each(function(){r.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];if(c)return r.event.trigger(a,b,c,!0)}}),r.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(a,b){r.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),r.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}}),o.focusin="onfocusin"in a,o.focusin||r.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){r.event.simulate(b,a.target,r.event.fix(a))};r.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=W.access(d,b);e||d.addEventListener(a,c,!0),W.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=W.access(d,b)-1;e?W.access(d,b,e):(d.removeEventListener(a,c,!0),W.remove(d,b))}}});var tb=a.location,ub=r.now(),vb=/\?/;r.parseXML=function(b){var c;if(!b||"string"!=typeof b)return null;try{c=(new a.DOMParser).parseFromString(b,"text/xml")}catch(d){c=void 0}return c&&!c.getElementsByTagName("parsererror").length||r.error("Invalid XML: "+b),c};var wb=/\[\]$/,xb=/\r?\n/g,yb=/^(?:submit|button|image|reset|file)$/i,zb=/^(?:input|select|textarea|keygen)/i;function Ab(a,b,c,d){var e;if(Array.isArray(b))r.each(b,function(b,e){c||wb.test(a)?d(a,e):Ab(a+"["+("object"==typeof e&&null!=e?b:"")+"]",e,c,d)});else if(c||"object"!==r.type(b))d(a,b);else for(e in b)Ab(a+"["+e+"]",b[e],c,d)}r.param=function(a,b){var c,d=[],e=function(a,b){var c=r.isFunction(b)?b():b;d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(null==c?"":c)};if(Array.isArray(a)||a.jquery&&!r.isPlainObject(a))r.each(a,function(){e(this.name,this.value)});else for(c in a)Ab(c,a[c],b,e);return d.join("&")},r.fn.extend({serialize:function(){return r.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=r.prop(this,"elements");return a?r.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!r(this).is(":disabled")&&zb.test(this.nodeName)&&!yb.test(a)&&(this.checked||!ja.test(a))}).map(function(a,b){var c=r(this).val();return null==c?null:Array.isArray(c)?r.map(c,function(a){return{name:b.name,value:a.replace(xb,"\r\n")}}):{name:b.name,value:c.replace(xb,"\r\n")}}).get()}});var Bb=/%20/g,Cb=/#.*$/,Db=/([?&])_=[^&]*/,Eb=/^(.*?):[ \t]*([^\r\n]*)$/gm,Fb=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Gb=/^(?:GET|HEAD)$/,Hb=/^\/\//,Ib={},Jb={},Kb="*/".concat("*"),Lb=d.createElement("a");Lb.href=tb.href;function Mb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(L)||[];if(r.isFunction(c))while(d=f[e++])"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Nb(a,b,c,d){var e={},f=a===Jb;function g(h){var i;return e[h]=!0,r.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Ob(a,b){var c,d,e=r.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&r.extend(!0,a,d),a}function Pb(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}if(f)return f!==i[0]&&i.unshift(f),c[f]}function Qb(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}r.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:tb.href,type:"GET",isLocal:Fb.test(tb.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Kb,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":r.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Ob(Ob(a,r.ajaxSettings),b):Ob(r.ajaxSettings,a)},ajaxPrefilter:Mb(Ib),ajaxTransport:Mb(Jb),ajax:function(b,c){"object"==typeof b&&(c=b,b=void 0),c=c||{};var e,f,g,h,i,j,k,l,m,n,o=r.ajaxSetup({},c),p=o.context||o,q=o.context&&(p.nodeType||p.jquery)?r(p):r.event,s=r.Deferred(),t=r.Callbacks("once memory"),u=o.statusCode||{},v={},w={},x="canceled",y={readyState:0,getResponseHeader:function(a){var b;if(k){if(!h){h={};while(b=Eb.exec(g))h[b[1].toLowerCase()]=b[2]}b=h[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return k?g:null},setRequestHeader:function(a,b){return null==k&&(a=w[a.toLowerCase()]=w[a.toLowerCase()]||a,v[a]=b),this},overrideMimeType:function(a){return null==k&&(o.mimeType=a),this},statusCode:function(a){var b;if(a)if(k)y.always(a[y.status]);else for(b in a)u[b]=[u[b],a[b]];return this},abort:function(a){var b=a||x;return e&&e.abort(b),A(0,b),this}};if(s.promise(y),o.url=((b||o.url||tb.href)+"").replace(Hb,tb.protocol+"//"),o.type=c.method||c.type||o.method||o.type,o.dataTypes=(o.dataType||"*").toLowerCase().match(L)||[""],null==o.crossDomain){j=d.createElement("a");try{j.href=o.url,j.href=j.href,o.crossDomain=Lb.protocol+"//"+Lb.host!=j.protocol+"//"+j.host}catch(z){o.crossDomain=!0}}if(o.data&&o.processData&&"string"!=typeof o.data&&(o.data=r.param(o.data,o.traditional)),Nb(Ib,o,c,y),k)return y;l=r.event&&o.global,l&&0===r.active++&&r.event.trigger("ajaxStart"),o.type=o.type.toUpperCase(),o.hasContent=!Gb.test(o.type),f=o.url.replace(Cb,""),o.hasContent?o.data&&o.processData&&0===(o.contentType||"").indexOf("application/x-www-form-urlencoded")&&(o.data=o.data.replace(Bb,"+")):(n=o.url.slice(f.length),o.data&&(f+=(vb.test(f)?"&":"?")+o.data,delete o.data),o.cache===!1&&(f=f.replace(Db,"$1"),n=(vb.test(f)?"&":"?")+"_="+ub++ +n),o.url=f+n),o.ifModified&&(r.lastModified[f]&&y.setRequestHeader("If-Modified-Since",r.lastModified[f]),r.etag[f]&&y.setRequestHeader("If-None-Match",r.etag[f])),(o.data&&o.hasContent&&o.contentType!==!1||c.contentType)&&y.setRequestHeader("Content-Type",o.contentType),y.setRequestHeader("Accept",o.dataTypes[0]&&o.accepts[o.dataTypes[0]]?o.accepts[o.dataTypes[0]]+("*"!==o.dataTypes[0]?", "+Kb+"; q=0.01":""):o.accepts["*"]);for(m in o.headers)y.setRequestHeader(m,o.headers[m]);if(o.beforeSend&&(o.beforeSend.call(p,y,o)===!1||k))return y.abort();if(x="abort",t.add(o.complete),y.done(o.success),y.fail(o.error),e=Nb(Jb,o,c,y)){if(y.readyState=1,l&&q.trigger("ajaxSend",[y,o]),k)return y;o.async&&o.timeout>0&&(i=a.setTimeout(function(){y.abort("timeout")},o.timeout));try{k=!1,e.send(v,A)}catch(z){if(k)throw z;A(-1,z)}}else A(-1,"No Transport");function A(b,c,d,h){var j,m,n,v,w,x=c;k||(k=!0,i&&a.clearTimeout(i),e=void 0,g=h||"",y.readyState=b>0?4:0,j=b>=200&&b<300||304===b,d&&(v=Pb(o,y,d)),v=Qb(o,v,y,j),j?(o.ifModified&&(w=y.getResponseHeader("Last-Modified"),w&&(r.lastModified[f]=w),w=y.getResponseHeader("etag"),w&&(r.etag[f]=w)),204===b||"HEAD"===o.type?x="nocontent":304===b?x="notmodified":(x=v.state,m=v.data,n=v.error,j=!n)):(n=x,!b&&x||(x="error",b<0&&(b=0))),y.status=b,y.statusText=(c||x)+"",j?s.resolveWith(p,[m,x,y]):s.rejectWith(p,[y,x,n]),y.statusCode(u),u=void 0,l&&q.trigger(j?"ajaxSuccess":"ajaxError",[y,o,j?m:n]),t.fireWith(p,[y,x]),l&&(q.trigger("ajaxComplete",[y,o]),--r.active||r.event.trigger("ajaxStop")))}return y},getJSON:function(a,b,c){return r.get(a,b,c,"json")},getScript:function(a,b){return r.get(a,void 0,b,"script")}}),r.each(["get","post"],function(a,b){r[b]=function(a,c,d,e){return r.isFunction(c)&&(e=e||d,d=c,c=void 0),r.ajax(r.extend({url:a,type:b,dataType:e,data:c,success:d},r.isPlainObject(a)&&a))}}),r._evalUrl=function(a){return r.ajax({url:a,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},r.fn.extend({wrapAll:function(a){var b;return this[0]&&(r.isFunction(a)&&(a=a.call(this[0])),b=r(a,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstElementChild)a=a.firstElementChild;return a}).append(this)),this},wrapInner:function(a){return r.isFunction(a)?this.each(function(b){r(this).wrapInner(a.call(this,b))}):this.each(function(){var b=r(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=r.isFunction(a);return this.each(function(c){r(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(a){return this.parent(a).not("body").each(function(){r(this).replaceWith(this.childNodes)}),this}}),r.expr.pseudos.hidden=function(a){return!r.expr.pseudos.visible(a)},r.expr.pseudos.visible=function(a){return!!(a.offsetWidth||a.offsetHeight||a.getClientRects().length)},r.ajaxSettings.xhr=function(){try{return new a.XMLHttpRequest}catch(b){}};var Rb={0:200,1223:204},Sb=r.ajaxSettings.xhr();o.cors=!!Sb&&"withCredentials"in Sb,o.ajax=Sb=!!Sb,r.ajaxTransport(function(b){var c,d;if(o.cors||Sb&&!b.crossDomain)return{send:function(e,f){var g,h=b.xhr();if(h.open(b.type,b.url,b.async,b.username,b.password),b.xhrFields)for(g in b.xhrFields)h[g]=b.xhrFields[g];b.mimeType&&h.overrideMimeType&&h.overrideMimeType(b.mimeType),b.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest");for(g in e)h.setRequestHeader(g,e[g]);c=function(a){return function(){c&&(c=d=h.onload=h.onerror=h.onabort=h.onreadystatechange=null,"abort"===a?h.abort():"error"===a?"number"!=typeof h.status?f(0,"error"):f(h.status,h.statusText):f(Rb[h.status]||h.status,h.statusText,"text"!==(h.responseType||"text")||"string"!=typeof h.responseText?{binary:h.response}:{text:h.responseText},h.getAllResponseHeaders()))}},h.onload=c(),d=h.onerror=c("error"),void 0!==h.onabort?h.onabort=d:h.onreadystatechange=function(){4===h.readyState&&a.setTimeout(function(){c&&d()})},c=c("abort");try{h.send(b.hasContent&&b.data||null)}catch(i){if(c)throw i}},abort:function(){c&&c()}}}),r.ajaxPrefilter(function(a){a.crossDomain&&(a.contents.script=!1)}),r.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(a){return r.globalEval(a),a}}}),r.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET")}),r.ajaxTransport("script",function(a){if(a.crossDomain){var b,c;return{send:function(e,f){b=r("<script>").prop({charset:a.scriptCharset,src:a.url}).on("load error",c=function(a){b.remove(),c=null,a&&f("error"===a.type?404:200,a.type)}),d.head.appendChild(b[0])},abort:function(){c&&c()}}}});var Tb=[],Ub=/(=)\?(?=&|$)|\?\?/;r.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=Tb.pop()||r.expando+"_"+ub++;return this[a]=!0,a}}),r.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(Ub.test(b.url)?"url":"string"==typeof b.data&&0===(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ub.test(b.data)&&"data");if(h||"jsonp"===b.dataTypes[0])return e=b.jsonpCallback=r.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(Ub,"$1"+e):b.jsonp!==!1&&(b.url+=(vb.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||r.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){void 0===f?r(a).removeProp(e):a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,Tb.push(e)),g&&r.isFunction(f)&&f(g[0]),g=f=void 0}),"script"}),o.createHTMLDocument=function(){var a=d.implementation.createHTMLDocument("").body;return a.innerHTML="<form></form><form></form>",2===a.childNodes.length}(),r.parseHTML=function(a,b,c){if("string"!=typeof a)return[];"boolean"==typeof b&&(c=b,b=!1);var e,f,g;return b||(o.createHTMLDocument?(b=d.implementation.createHTMLDocument(""),e=b.createElement("base"),e.href=d.location.href,b.head.appendChild(e)):b=d),f=C.exec(a),g=!c&&[],f?[b.createElement(f[1])]:(f=qa([a],b,g),g&&g.length&&r(g).remove(),r.merge([],f.childNodes))},r.fn.load=function(a,b,c){var d,e,f,g=this,h=a.indexOf(" ");return h>-1&&(d=pb(a.slice(h)),a=a.slice(0,h)),r.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(e="POST"),g.length>0&&r.ajax({url:a,type:e||"GET",dataType:"html",data:b}).done(function(a){f=arguments,g.html(d?r("<div>").append(r.parseHTML(a)).find(d):a)}).always(c&&function(a,b){g.each(function(){c.apply(this,f||[a.responseText,b,a])})}),this},r.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){r.fn[b]=function(a){return this.on(b,a)}}),r.expr.pseudos.animated=function(a){return r.grep(r.timers,function(b){return a===b.elem}).length},r.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=r.css(a,"position"),l=r(a),m={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=r.css(a,"top"),i=r.css(a,"left"),j=("absolute"===k||"fixed"===k)&&(f+i).indexOf("auto")>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),r.isFunction(b)&&(b=b.call(a,c,r.extend({},h))),null!=b.top&&(m.top=b.top-h.top+g),null!=b.left&&(m.left=b.left-h.left+e),"using"in b?b.using.call(a,m):l.css(m)}},r.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){r.offset.setOffset(this,a,b)});var b,c,d,e,f=this[0];if(f)return f.getClientRects().length?(d=f.getBoundingClientRect(),b=f.ownerDocument,c=b.documentElement,e=b.defaultView,{top:d.top+e.pageYOffset-c.clientTop,left:d.left+e.pageXOffset-c.clientLeft}):{top:0,left:0}},position:function(){if(this[0]){var a,b,c=this[0],d={top:0,left:0};return"fixed"===r.css(c,"position")?b=c.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),B(a[0],"html")||(d=a.offset()),d={top:d.top+r.css(a[0],"borderTopWidth",!0),left:d.left+r.css(a[0],"borderLeftWidth",!0)}),{top:b.top-d.top-r.css(c,"marginTop",!0),left:b.left-d.left-r.css(c,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent;while(a&&"static"===r.css(a,"position"))a=a.offsetParent;return a||ra})}}),r.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c="pageYOffset"===b;r.fn[a]=function(d){return T(this,function(a,d,e){var f;return r.isWindow(a)?f=a:9===a.nodeType&&(f=a.defaultView),void 0===e?f?f[b]:a[d]:void(f?f.scrollTo(c?f.pageXOffset:e,c?e:f.pageYOffset):a[d]=e)},a,d,arguments.length)}}),r.each(["top","left"],function(a,b){r.cssHooks[b]=Pa(o.pixelPosition,function(a,c){if(c)return c=Oa(a,b),Ma.test(c)?r(a).position()[b]+"px":c})}),r.each({Height:"height",Width:"width"},function(a,b){r.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){r.fn[d]=function(e,f){var g=arguments.length&&(c||"boolean"!=typeof e),h=c||(e===!0||f===!0?"margin":"border");return T(this,function(b,c,e){var f;return r.isWindow(b)?0===d.indexOf("outer")?b["inner"+a]:b.document.documentElement["client"+a]:9===b.nodeType?(f=b.documentElement,Math.max(b.body["scroll"+a],f["scroll"+a],b.body["offset"+a],f["offset"+a],f["client"+a])):void 0===e?r.css(b,c,h):r.style(b,c,e,h)},b,g?e:void 0,g)}})}),r.fn.extend({bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)},holdReady:function(a){a?r.readyWait++:r.ready(!0)}}),r.isArray=Array.isArray,r.parseJSON=JSON.parse,r.nodeName=B,"function"==typeof define&&define.amd&&define("jquery",[],function(){return r});var Vb=a.jQuery,Wb=a.$;return r.noConflict=function(b){return a.$===r&&(a.$=Wb),b&&a.jQuery===r&&(a.jQuery=Vb),r},b||(a.jQuery=a.$=r),r});
diff --git a/res/js/app.js b/res/js/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..f8a548ad7f6ac29115677813d9bf67c12a40b966
--- /dev/null
+++ b/res/js/app.js
@@ -0,0 +1,69 @@
+const senderColorHandler = new SenderColorHandler();
+const mircColorHandler = new MircColorHandler();
+
+class App {
+    constructor() {
+        this.navigation = new Navigation();
+        this.urlBar = new UrlBar();
+        this.buffers = [];
+
+        this.loadingQuery = 0;
+
+        this.render();
+        this.urlBar.addEventListener("search", (query) => this.search(query));
+        this.navigation.addEventListener("search", (query) => this.search(query));
+        this.urlBar.init();
+    }
+
+    render() {
+        const wrapper = document.createElement("div");
+            wrapper.appendChild(this.navigation.elem);
+            const results = document.createElement("div");
+                results.classList.add("results");
+            wrapper.appendChild(results);
+        this.elem = wrapper;
+        this.resultContainer = results;
+
+        this.buffers.forEach((buffer) => this.insert(buffer));
+    }
+
+    search(query) {
+        this.clear();
+        this.loadingQuery++;
+        const queryId = this.loadingQuery;
+        load("web/search/", {query: query}).then((result) => {
+            if (this.loadingQuery != queryId)
+                return;
+
+            this.buffers = result.map((buffer) => {
+                return new Buffer(buffer.bufferid, buffer.buffername, buffer.networkname, buffer.messages.map((msg) => {
+                    return new Context(new MessagePreview(msg.messageid, msg.time, msg.sender, msg.message, msg.preview));
+                }));
+            });
+            this.buffers.forEach((buffer) => this.insert(buffer));
+        });
+        this.navigation.historyView.add(new HistoryElement(query));
+        this.navigation.input.value = query;
+        this.urlBar.set(query);
+    }
+
+    clear() {
+        while (this.buffers.length) {
+            const buffer = this.buffers.pop();
+            this.resultContainer.removeChild(buffer.elem);
+        }
+    }
+
+    clearAll() {
+        this.clear();
+        this.navigation.historyView.clear();
+        this.urlBar.clear();
+    }
+
+    insert(buffer) {
+        this.resultContainer.appendChild(buffer.elem);
+    }
+}
+
+const app = new App();
+document.body.insertBefore(app.elem, document.body.firstChild);
\ No newline at end of file
diff --git a/res/js/component/buffer.js b/res/js/component/buffer.js
new file mode 100644
index 0000000000000000000000000000000000000000..f95d6cd9a8ef4f027189db54e0ee691e0b24430e
--- /dev/null
+++ b/res/js/component/buffer.js
@@ -0,0 +1,39 @@
+class Buffer {
+    constructor(id, name, network, contextList = []) {
+        this.id = id;
+        this.name = name;
+        this.network = network;
+        this.contextList = contextList;
+
+        this.render();
+    }
+
+    render() {
+        const buffer = document.createElement("div");
+            buffer.classList.add("buffer");
+            const title = document.createElement("h2");
+                title.classList.add("title");
+                const titleValue = document.createTextNode(this.network + " - " + this.name);
+                title.appendChild(titleValue);
+            buffer.appendChild(title);
+            const contextWrap = document.createElement("div");
+                contextWrap.classList.add("container");
+                const loadMoreBtn = new LoadMore(translation.results.show_more);
+                loadMoreBtn.addEventListener("click", this.loadMore);
+                contextWrap.appendChild(loadMoreBtn.elem);
+            buffer.appendChild(contextWrap);
+        this.elem = buffer;
+        this.insertContainer = contextWrap;
+        this.loadMoreBtn = loadMoreBtn;
+
+        this.contextList.forEach((context) => this.insert(context));
+    }
+
+    loadMore() {
+        /* load data */
+    }
+
+    insert(context) {
+        this.insertContainer.insertBefore(context.elem, this.loadMoreBtn.elem);
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/context.js b/res/js/component/context.js
new file mode 100644
index 0000000000000000000000000000000000000000..8b2e4cd93e3736a8301fb860505ddb0463136dfa
--- /dev/null
+++ b/res/js/component/context.js
@@ -0,0 +1,56 @@
+class Context {
+    constructor(preview, beforeList=[], afterList=[]) {
+        this.preview = preview;
+        this.beforeList = beforeList;
+        this.afterList = afterList;
+
+        this.render();
+    }
+
+    render() {
+        const context = document.createElement("div");
+            context.classList.add("context");
+            const containerBefore = document.createElement("div");
+                containerBefore.classList.add("container");
+                containerBefore.classList.add("before");
+                const loadBeforeBtn = new LoadMore(translation.context.load_earlier);
+                loadBeforeBtn.addEventListener("click", this.loadBefore);
+                containerBefore.appendChild(loadBeforeBtn.elem);
+            context.appendChild(containerBefore);
+        
+            context.appendChild(this.preview.elem);
+        
+            const containerAfter = document.createElement("div");
+                containerAfter.classList.add("container");
+                containerAfter.classList.add("after");
+                const loadAfterBtn = new LoadMore(translation.context.load_later);
+                loadAfterBtn.addEventListener("click", this.loadAfter);
+                containerAfter.appendChild(loadAfterBtn.elem);
+            context.appendChild(containerAfter);
+        this.elem = context;
+        this.containerBefore = containerBefore;
+        this.loadBeforeBtn = loadBeforeBtn;
+        this.containerAfter = containerAfter;
+        this.loadAfterBtn = loadAfterBtn;
+        
+        this.beforeList.forEach(this.insertBefore);
+        this.afterList.forEach(this.insertAfter);
+    }
+
+    loadBefore() {
+        /* load data */
+    }
+
+    insertBefore(message) {
+        this.containerBefore.insertBefore(message.elem, this.insertBeforeTarget);
+        this.insertBeforeTarget = message.elem;
+    }
+
+    loadAfter() {
+        /* load data */
+    }
+
+    insertAfter(message) {
+        this.containerAfter.insertBefore(message.elem, this.insertAfterTarget);
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/history.js b/res/js/component/history.js
new file mode 100644
index 0000000000000000000000000000000000000000..b06c50067fb5a024c66af43971cfcdb1e342db21
--- /dev/null
+++ b/res/js/component/history.js
@@ -0,0 +1,84 @@
+const HISTORY_KEY = "history";
+const HISTORY_MAX_LENGTH = 4;
+
+class HistoryView {
+    constructor() {
+        this.index = -1;
+
+        this.elements = this.load().map(function (query) {
+            return new HistoryElement(query);
+        });
+
+        this.render();
+    }
+
+    render() {
+        const historyView = document.createElement("div");
+            historyView.classList.add("history");
+            const list = document.createElement("ul");
+                const noHistory = new NoHistoryElement();
+                list.appendChild(noHistory.elem);
+            historyView.appendChild(list);
+        this.elem = historyView;
+        this.list = list;
+        this.noHistory = noHistory;
+
+        this.elements.forEach((elem) => this.insert(elem));
+    }
+
+    insert(item) {
+        this.list.insertBefore(item.elem, this.list.firstChild);
+        if (this.noHistory.elem.parentNode === this.list)
+            this.list.removeChild(this.noHistory.elem);
+    }
+
+    add(item) {
+        const idx = this.elements.map((item) => item.query).indexOf(item.query);
+        if (idx !== -1) {
+            this.list.removeChild(this.elements[idx].elem);
+            this.elements.splice(idx, 1);
+        }
+
+        this.elements.push(item);
+        this.insert(item);
+
+        this.truncate();
+
+        this.store();
+    }
+
+    clear() {
+        while (this.elements.length) {
+            this.list.removeChild(this.elements.pop().elem);
+        }
+        this.store();
+        this.list.appendChild(this.noHistory.elem);
+    }
+
+    load() {
+        const loaded = localStorage[HISTORY_KEY];
+        return JSON.parse(loaded===undefined ? "[]" : loaded);
+    }
+
+    store() {
+        localStorage[HISTORY_KEY] = JSON.stringify(this.elements.map((item) => item.query));
+    }
+
+    navigateBefore() {
+        this.index++;
+        this.index %= this.elements.length;
+    }
+
+    navigateLater() {
+        this.index--;
+        if (this.index < 0)
+            this.index = -1;
+        else
+            this.index %= this.elements.length;
+    }
+
+    truncate() {
+        while (this.elements.length > HISTORY_MAX_LENGTH)
+            this.list.removeChild(this.elements.shift().elem);
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/historyelement.js b/res/js/component/historyelement.js
new file mode 100644
index 0000000000000000000000000000000000000000..b046d1ad88ed4cb1d896d5b8bd1b914cf63cc756
--- /dev/null
+++ b/res/js/component/historyelement.js
@@ -0,0 +1,19 @@
+class HistoryElement {
+    constructor(query) {
+        this.query = query;
+
+        this.render();
+    }
+
+    render() {
+        const wrapper = document.createElement("li");
+            const icon = document.createElement("span");
+                icon.classList.add("icon");
+                const iconValue = document.createTextNode("history");
+                icon.appendChild(iconValue);
+            wrapper.appendChild(icon);
+            const queryValue = document.createTextNode(this.query);
+            wrapper.appendChild(queryValue);
+        this.elem = wrapper;
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/loadmore.js b/res/js/component/loadmore.js
new file mode 100644
index 0000000000000000000000000000000000000000..52edb1495ae67223f0edc217f94414da25b6e401
--- /dev/null
+++ b/res/js/component/loadmore.js
@@ -0,0 +1,11 @@
+class LoadMore extends Component {
+    constructor(text) {
+        super();
+        const button = document.createElement("div");
+            button.classList.add("inline-button");
+            button.addEventListener("click", (event) => this.sendEvent("click", [event]));
+            const buttonValue = document.createTextNode(text);
+            button.appendChild(buttonValue);
+        this.elem = button;
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/message.js b/res/js/component/message.js
new file mode 100644
index 0000000000000000000000000000000000000000..66395e52f7ca4c8516f249a54c17591309ceb286
--- /dev/null
+++ b/res/js/component/message.js
@@ -0,0 +1,45 @@
+class Message {
+    constructor(id, time, sender, content) {
+        this.id = id;
+        this.time = time;
+        this.sender = sender;
+        this.content = content;
+
+        this.render();
+    }
+
+    render() {
+        const message = document.createElement("div");
+            message.classList.add("message");
+            const time = document.createElement("time");
+                const timeValue = document.createTextNode(new Date(message.time.replace(" ", "T") + "Z").toLocaleString());
+                time.appendChild(timeValue);
+            message.appendChild(time);
+            const container = document.createElement("div");
+                container.classList.add("container");
+                const sender = document.createElement("div");
+                    sender.classList.add("sender");
+                    sender.style.color = senderColorHandler.nickToColor(this.getNick());
+                    const senderValue = document.createTextNode(this.getNick());
+                    sender.appendChild(senderValue);
+                container.appendChild(sender);
+                const content = document.createElement("div");
+                    content.classList.add("content");
+                    mircColorHandler.render(this.content).forEach((elem) => content.appendChild(elem));
+                container.appendChild(content);
+            message.appendChild(container);
+        this.elem = message;
+    }
+
+    getNick() {
+        return this.sender.split("!")[0];
+    }
+
+    getIdent() {
+        return this.sender.split("@")[0].split("!")[1];
+    }
+
+    getHost() {
+        return this.sender.split("@")[1];
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/messagePreview.js b/res/js/component/messagePreview.js
new file mode 100644
index 0000000000000000000000000000000000000000..27160d18b5b26213b729fdf441e275df70f03ea7
--- /dev/null
+++ b/res/js/component/messagePreview.js
@@ -0,0 +1,51 @@
+class MessagePreview {
+    constructor(id, time, sender, content, preview) {
+        this.id = id;
+        this.time = time;
+        this.sender = sender;
+        this.content = content;
+        this.preview = preview;
+
+        this.render();
+    }
+
+    render() {
+        const message = document.createElement("div");
+            message.classList.add("message");
+            message.classList.add("preview");
+            const time = document.createElement("time");
+                const timeValue = document.createTextNode(new Date(this.time.replace(" ", "T") + "Z").toLocaleString());
+                time.appendChild(timeValue);
+            message.appendChild(time);
+            const container = document.createElement("div");
+                container.classList.add("container");
+                const sender = document.createElement("div");
+                    sender.classList.add("sender");
+                    sender.style.color = senderColorHandler.nickToColor(this.getNick());
+                    const senderValue = document.createTextNode(this.getNick());
+                    sender.appendChild(senderValue);
+                container.appendChild(sender);
+                const content = document.createElement("div");
+                    content.classList.add("content");
+                mircColorHandler.render(this.content).forEach((elem) => content.appendChild(elem));
+                container.appendChild(content);
+                const preview = document.createElement("div");
+                    preview.classList.add("preview");
+                mircColorHandler.highlight(this.preview).forEach((elem) => preview.appendChild(elem));
+                container.appendChild(preview);
+        message.appendChild(container);
+        this.elem = message;
+    }
+
+    getNick() {
+        return this.sender.split("!")[0];
+    }
+
+    getIdent() {
+        return this.sender.split("@")[0].split("!")[1];
+    }
+
+    getHost() {
+        return this.sender.split("@")[1];
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/nav.js b/res/js/component/nav.js
new file mode 100644
index 0000000000000000000000000000000000000000..3519586bb0517b3beda1260a7033798700a38899
--- /dev/null
+++ b/res/js/component/nav.js
@@ -0,0 +1,70 @@
+const keyMapping = {
+    13: "Enter",
+    27: "Escape",
+    38: "ArrowUp",
+    40: "ArrowDown"
+};
+
+class Navigation extends Component {
+    constructor() {
+        super();
+        this.render();
+    }
+
+    render() {
+        const nav = document.createElement("div");
+            nav.classList.add("nav");
+            const wrapper = document.createElement("div");
+                wrapper.classList.add("container");
+                const searchBar = document.createElement("div");
+                    searchBar.classList.add("searchBar");
+                    const searchIcon = document.createElement("div");
+                        searchIcon.classList.add("icon");
+                        const searchIconValue = document.createTextNode("search");
+                        searchIcon.appendChild(searchIconValue);
+                    searchBar.appendChild(searchIcon);
+                    const input = document.createElement("input");
+                        input.classList.add("search");
+                        input.placeholder = translation.search;
+                        input.type = "text";
+                        input.autocomplete = "off";
+                        input.addEventListener("focus", () => this.elem.classList.add("focus"));
+                        input.addEventListener("blur", () => this.elem.classList.remove("focus"));
+                        input.addEventListener("keydown", (e) => {
+                            switch (e.key || keyMapping[e.keyCode]) {
+                                case "ArrowUp": {
+                                    this.historyView.navigateLater();
+                                } break;
+                                case "ArrowDown": {
+                                    this.historyView.navigateBefore();
+                                } break;
+                                case "Enter": {
+                                    this.sendEvent("search", [this.input.value]);
+                                    this.input.blur();
+                                } break;
+                                case "Escape": {
+                                    this.input.blur();
+                                } break;
+                            }
+                        });
+                    searchBar.appendChild(input);
+                wrapper.appendChild(searchBar);
+            nav.appendChild(wrapper);
+            const actions = document.createElement("div");
+                actions.classList.add("actions");
+                const logout = document.createElement("a");
+                    logout.title = translation.logout;
+                    logout.href = "login.php?action=logout";
+                    logout.classList.add("icon");
+                    const logoutValue = document.createTextNode("exit_to_app");
+                    logout.appendChild(logoutValue);
+                actions.appendChild(logout);
+            nav.appendChild(actions);
+            const historyView = new HistoryView();
+            nav.appendChild(historyView.elem);
+        this.elem = nav;
+
+        this.input = input;
+        this.historyView = historyView;
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/nohistoryelement.js b/res/js/component/nohistoryelement.js
new file mode 100644
index 0000000000000000000000000000000000000000..bfaed8023d95064e64fe1a0f23ee71c52a7d5a85
--- /dev/null
+++ b/res/js/component/nohistoryelement.js
@@ -0,0 +1,12 @@
+class NoHistoryElement {
+    constructor() {
+        this.render();
+    }
+
+    render() {
+        const wrapper = document.createElement("p");
+            const value = document.createTextNode(translation.history.error_unavailable);
+            wrapper.appendChild(value);
+        this.elem = wrapper;
+    }
+}
\ No newline at end of file
diff --git a/res/js/component/urlbar.js b/res/js/component/urlbar.js
new file mode 100644
index 0000000000000000000000000000000000000000..76108a0e6fe830a75dcc708c4946f2a01c70c555
--- /dev/null
+++ b/res/js/component/urlbar.js
@@ -0,0 +1,24 @@
+class UrlBar extends Component {
+    constructor() {
+        super();
+        window.addEventListener("hashchange", (e) => {
+            this.sendEvent("search", [this.get()]);
+        });
+    }
+
+    set(value) {
+        window.location.hash = value;
+    }
+
+    init() {
+        this.sendEvent("search", [this.get()]);
+    }
+
+    get() {
+        return decodeURIComponent(window.location.hash.substr(1));
+    }
+
+    clear() {
+        this.set("");
+    }
+}
\ No newline at end of file
diff --git a/res/js/util/component.js b/res/js/util/component.js
new file mode 100644
index 0000000000000000000000000000000000000000..9f0cb16a217824c1566322bb8e2aae3bca07f55d
--- /dev/null
+++ b/res/js/util/component.js
@@ -0,0 +1,26 @@
+class Component {
+    constructor() {
+        this.eventListeners = {};
+    }
+
+    addEventListener(type, handler) {
+        this.getListeners(type).push(handler);
+    }
+
+    removeEventListener(type, handler) {
+        const listeners = this.getListeners(type);
+        listeners.splice(listeners.indexOf(handler), 1);
+    }
+
+    getListeners(type) {
+        if (!this.eventListeners[type])
+            this.eventListeners[type] = [];
+        return this.eventListeners[type];
+    }
+
+    sendEvent(type, argv) {
+        this.getListeners(type).forEach((listener) => {
+            listener.apply(null, argv);
+        })
+    }
+}
\ No newline at end of file
diff --git a/res/js/util/highlighthandler.js b/res/js/util/highlighthandler.js
new file mode 100644
index 0000000000000000000000000000000000000000..5ebf623e8518bff5fa515d4a5bf4d936360c3ac1
--- /dev/null
+++ b/res/js/util/highlighthandler.js
@@ -0,0 +1,5 @@
+class HighlightHandler {
+    render(text) {
+
+    }
+}
\ No newline at end of file
diff --git a/res/js/util/loader.js b/res/js/util/loader.js
new file mode 100644
index 0000000000000000000000000000000000000000..b0efe4ffeb558c2aaff9d98613610f4b56513229
--- /dev/null
+++ b/res/js/util/loader.js
@@ -0,0 +1,36 @@
+function load(url, data=null) {
+    return new Promise((resolve, reject) => {
+        const encodeData = (data) => {
+            const result = [];
+            for (key in data) {
+                if (data.hasOwnProperty(key)) {
+                    result.push(encodeURIComponent(key) + "=" + encodeURIComponent(data[key]));
+                }
+            }
+            return result.join("");
+        };
+
+        const request = new XMLHttpRequest();
+        const method = data===null ? "GET" : "POST";
+        request.onreadystatechange = () => {
+            if (request.readyState == 4) {
+                if (request.status >= 200 && request.status < 300) {
+                    try {
+                        resolve(JSON.parse(request.responseText));
+                    } catch (e) {
+                        reject(e);
+                    }
+                } else {
+                    reject(request.status + ": " + request.responseText);
+                }
+            }
+        };
+        request.open(method, url, true);
+        if (data!==null) {
+            request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
+            request.send(encodeData(data));
+        } else {
+            request.send();
+        }
+    });
+}
\ No newline at end of file
diff --git a/res/js/util/mirccolorhandler.js b/res/js/util/mirccolorhandler.js
new file mode 100644
index 0000000000000000000000000000000000000000..f848f58c3def1ad3d9798d62342990787c035da1
--- /dev/null
+++ b/res/js/util/mirccolorhandler.js
@@ -0,0 +1,209 @@
+class MircColorHandler {
+    render(text) {
+        const CODE_BOLD = "\x02";
+        const CODE_COLOR = "\x03";
+        const CODE_ITALIC = "\x1D";
+        const CODE_UNDERLINE = "\x1F";
+        const CODE_SWAP = "\x16";
+        const CODE_RESET = "\x0F";
+
+        const readNumber = function (str, start, end) {
+            if (start >= end || start >= str.length)
+                return -1;
+            else
+                return parseInt(str.substr(start, end), 10);
+        };
+
+        const findEndOfNumber = function (str, start) {
+            const validCharCodes = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
+            let i;
+            let tmp = str.substr(start, 2);
+            for (i = 0; i < 2 && i < tmp.length; i++) {
+                if (validCharCodes.indexOf(tmp.charAt(i)) === -1)
+                    break
+            }
+            return i + start;
+        };
+
+        const unescape = function (str) {
+            return str.replace(/&lt;/g, "<").replace(/&gt;/g, ">");
+        };
+
+        const fromState = function (state) {
+            const elem = document.createElement("span");
+            if (state.bold) elem.classList.add("irc_bold");
+            if (state.italic) elem.classList.add("irc_italic");
+            if (state.underline) elem.classList.add("irc_underline");
+            if (state.foreground!==null) elem.dataset["irc_foreground"] = state.foreground;
+            if (state.background!==null) elem.dataset["irc_background"] = state.background;
+            return elem;
+        };
+
+        let apply = function (lastTag, str, i, normalCount, nodes) {
+            const s = unescape(str.substr(i - normalCount, normalCount));
+            if (normalCount === 0)
+                return;
+
+            lastTag.appendChild(document.createTextNode(s));
+            nodes.push(lastTag);
+        };
+
+        const formatString = function (str) {
+            if (!str)
+                return document.createTextNode("");
+
+            let state = {
+                bold: false,
+                italic: false,
+                underline: false,
+                foreground: null,
+                background: null
+            };
+            let lastTag = fromState(state);
+
+            let nodes = [];
+
+            let normalCount = 0;
+            for (let i = 0; i < str.length; i++) {
+                const character = str.charAt(i);
+                switch (character) {
+                    case CODE_BOLD: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        state.bold = !state.bold;
+                        lastTag = fromState(state);
+                    }
+                        break;
+                    case CODE_ITALIC: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        state.italic = !state.italic;
+                        lastTag = fromState(state);
+                    }
+                        break;
+                    case CODE_UNDERLINE: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        state.underline = !state.underline;
+                        lastTag = fromState(state);
+                    }
+                        break;
+                    case CODE_COLOR: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        let foregroundStart = i + 1;
+                        let foregroundEnd = findEndOfNumber(str, foregroundStart);
+
+                        if (foregroundEnd > foregroundStart) {
+                            let foreground = readNumber(str, foregroundStart, foregroundEnd);
+
+                            let background = -1;
+                            let backgroundStart = foregroundEnd + 1;
+                            let backgroundEnd = -1;
+
+                            if (str.length > foregroundEnd && str.charAt(foregroundEnd) === ',') {
+                                backgroundEnd = findEndOfNumber(str, backgroundStart);
+                                background = readNumber(str, backgroundStart, backgroundEnd);
+                            }
+
+                            if (state.foreground !== null) {
+                                if (background === -1)
+                                    background = state.background;
+                            }
+
+                            state.foreground = foreground === -1 ? null : foreground;
+                            state.background = background === -1 ? null : background;
+                            lastTag = fromState(state);
+
+                            i = ((backgroundEnd === -1) ? foregroundEnd : backgroundEnd ) - 1;
+                        } else if (state.foreground !== null) {
+                            state.foreground = null;
+                            state.background = null;
+                            lastTag = fromState(state);
+                        }
+                    }
+                        break;
+                    case CODE_SWAP: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        if (state.foreground != null) {
+                            state.foreground = state.background;
+                            state.background = state.foreground;
+                            lastTag = fromState(state);
+                        }
+                    }
+                        break;
+                    case CODE_RESET: {
+                        apply(lastTag, str, i, normalCount, nodes);
+                        normalCount = 0;
+
+                        state.bold = false;
+                        state.italic = false;
+                        state.underline = false;
+                        state.foreground = null;
+                        state.background = null;
+                        lastTag = fromState(state);
+                    }
+                        break;
+                    default: {
+                        normalCount++;
+                    }
+                        break;
+                }
+            }
+
+            apply(lastTag, str, str.length, normalCount, nodes);
+
+            return nodes;
+        };
+
+        return formatString(text);
+    }
+
+    highlight(text) {
+        let nodes = [];
+
+        let highlight = false;
+
+        let patternStart = "<b>";
+        let patternEnd = "</b>";
+
+        let pattern = patternStart;
+
+        let groupStart = 0;
+
+        let addFragment = function () {
+            const groupEnd = index === -1 ? text.length : index;
+            if (groupStart == groupEnd)
+                return;
+
+            if (highlight) {
+                const highlightNode = document.createElement("span");
+                highlightNode.classList.add("irc_highlight");
+                highlightNode.appendChild(document.createTextNode(text.substr(groupStart, groupEnd - groupStart)));
+                nodes.push(highlightNode);
+            } else {
+                nodes.push(document.createTextNode(text.substr(groupStart, groupEnd - groupStart)));
+            }
+        };
+
+        let index = -1;
+        while ((index = text.indexOf(pattern, groupStart)) < text.length && index > 0) {
+            addFragment();
+
+            groupStart = index + pattern.length;
+            pattern = highlight ? patternStart : patternEnd;
+
+            highlight = !highlight;
+        }
+
+        addFragment();
+
+        return nodes;
+    }
+}
\ No newline at end of file
diff --git a/res/js/util/sendercolorhandler.js b/res/js/util/sendercolorhandler.js
new file mode 100644
index 0000000000000000000000000000000000000000..ce757f21300a10f79efec8eca11c15e9a59614d1
--- /dev/null
+++ b/res/js/util/sendercolorhandler.js
@@ -0,0 +1,68 @@
+class SenderColorHandler {
+    constructor(sendercolors = [
+        "#e90d7f",
+        "#8e55e9",
+        "#b30e0e",
+        "#17b339",
+        "#58afb3",
+        "#9d54b3",
+        "#b39775",
+        "#3176b3",
+        "#e90d7f",
+        "#8e55e9",
+        "#b30e0e",
+        "#17b339",
+        "#58afb3",
+        "#9d54b3",
+        "#b39775",
+        "#3176b3"
+    ]) {
+        this.sendercolors = sendercolors;
+    }
+
+    static reflect(crc, n) {
+        let j = 1, crcout = 0;
+        for (let i = (1 << (n - 1)); i > 0; i >>= 1) {
+            if ((crc & i) > 0) {
+                crcout |= j;
+            }
+            j <<= 1;
+        }
+        return crcout;
+    }
+
+    static qChecksum(str) {
+        let crc = 0xffff;
+        const crcHighBitMask = 0x8000;
+
+        for (let i = 0; i < str.length; i++) {
+            const b = str.codePointAt(i);
+            const c = SenderColorHandler.reflect(b, 8);
+            for (let j = 0x80; j > 0; j >>= 1) {
+                let highBit = crc & crcHighBitMask;
+                crc <<= 1;
+                if ((c & j) > 0) {
+                    highBit ^= crcHighBitMask;
+                }
+                if (highBit > 0) {
+                    crc ^= 0x1021;
+                }
+            }
+        }
+
+        crc = SenderColorHandler.reflect(crc, 16);
+        crc ^= 0xffff;
+        crc &= 0xffff;
+
+        return crc;
+    }
+
+    static senderIndex(str) {
+        const nickToHash = str.replace(/_*$/, "").toLowerCase();
+        return SenderColorHandler.qChecksum(nickToHash) & 0xF;
+    }
+
+    nickToColor(nick) {
+        return this.sendercolors[SenderColorHandler.senderIndex(nick)];
+    }
+}
\ No newline at end of file
diff --git a/res/material-icons.css b/res/material-icons.css
deleted file mode 100644
index 326ae4daa7f9dc09779795af507821e4dd04fad7..0000000000000000000000000000000000000000
--- a/res/material-icons.css
+++ /dev/null
@@ -1,35 +0,0 @@
-@font-face {
-  font-family: 'Material Icons';
-  font-style: normal;
-  font-weight: 400;
-  src: local('Material Icons'),
-       local('MaterialIcons-Regular'),
-       url(MaterialIcons-Regular.woff2) format('woff2'),
-       url(MaterialIcons-Regular.woff) format('woff'),
-       url(MaterialIcons-Regular.ttf) format('truetype');
-}
-
-.material-icons {
-  font-family: 'Material Icons';
-  font-weight: normal;
-  font-style: normal;
-  font-size: 24px;  /* Preferred icon size */
-  display: inline-block;
-  line-height: 1;
-  text-transform: none;
-  letter-spacing: normal;
-  word-wrap: normal;
-  white-space: nowrap;
-  direction: ltr;
-
-  /* Support for all WebKit browsers. */
-  -webkit-font-smoothing: antialiased;
-  /* Support for Safari and Chrome. */
-  text-rendering: optimizeLegibility;
-
-  /* Support for Firefox. */
-  -moz-osx-font-smoothing: grayscale;
-
-  /* Support for IE. */
-  font-feature-settings: 'liga';
-}
diff --git a/res/search.js b/res/search.js
index 98254197c0ac1a8b816e5a5695f3bcb6d297b2fa..6091cae373a2033928c7e44b0f06e8faa091fc72 100644
--- a/res/search.js
+++ b/res/search.js
@@ -1,3 +1,4 @@
+/*
 var state = {
     query: "",
     selected_history_entry: -1,
@@ -5,6 +6,31 @@ var state = {
     open: []
 };
 
+var bind_click = function (elem, handler) {
+    elem.unbind("mousedown");
+    elem.unbind("mouseup");
+
+    elem.mousedown(function (e) {
+        getSelection().removeAllRanges();
+    });
+
+    elem.mouseup(function (e) {
+        if (e.which === 1 && getSelection().isCollapsed)
+            handler(e);
+    });
+};
+
+var make_select_buffer = function (buffer, id) {
+    state.buffers[buffer].selected = true;
+    apply_selection();
+};
+
+var make_select_context = function (buffer, id) {
+    state.buffers[buffer].selected = true;
+    state.buffers[buffer].contexts[id].selected = true;
+    apply_selection();
+};
+
 var search_history = {
     max_size: 8,
     get: function () {
@@ -60,33 +86,20 @@ var render = {
             render.no_more();
     },
     buffer: {
-        auto: function (buffer) {
-            return (buffer.selected) ? render.buffer.full(buffer) : render.buffer.overview(buffer);
-        },
-        overview: function (buffer) {
-            return (
-                "<buffer id='buffer" + buffer.id + "' data-bufferid='" + buffer.id + "'>" + (
-                    "<h2>" + buffer.network + " – " + buffer.name + "</h2>" +
-                    "<article>" + (
-                        buffer.contexts.slice(0, 4).map(render.context.auto).join("") +
-                        "<inline-button class='load_more'>" + (buffer.contexts.length > 4 ? translation.results.show_more : translation.results.load_more) + "</inline-button>"
-                    ) + "</article>"
-                ) + "</buffer>"
-            )
-        },
         full: function (buffer) {
             return (
-                "<buffer id='buffer" + buffer.id + "' data-bufferid='" + buffer.id + "' class='selected'>" + (
+                "<buffer id='buffer" + buffer.id + "' data-bufferid='" + buffer.id + "'>" + (
                     "<h2>" + buffer.network + " – " + buffer.name + "</h2>" +
                     "<article>" + (
-                        buffer.contexts.map(render.context.auto).join("") +
+                        buffer.contexts.map(render.context.full).join("") +
                         "<inline-button class='load_more'>" + translation.results.load_more + "</inline-button>"
                     ) + "</article>"
                 ) + "</buffer>"
             )
         },
         update: function (id) {
-            var renderedBuffer = render.buffer.auto(state.buffers[id]);
+            $("#buffer" + id).unbind();
+            var renderedBuffer = render.buffer.full(state.buffers[id]);
             if ($("#buffer" + id).length)
                 $("#buffer" + id).replaceWith(renderedBuffer);
             else
@@ -97,8 +110,8 @@ var render = {
         attach: function (elem) {
             elem.unbind();
             var id = elem.data("bufferid");
-            elem.click(make_toggle_buffer(id));
-            elem.find(".load_more").click(function (e) {
+            bind_click(elem, make_toggle_buffer(id));
+            bind_click(elem.find(".load_more"), function (e) {
                 e.stopPropagation();
 
                 if (state.buffers[id].selected || state.buffers[id].contexts.length <= 4)
@@ -107,34 +120,29 @@ var render = {
                 deselect_buffers(id);
                 state.open.push(make_toggle_buffer(id));
                 state.buffers[id].selected = true;
-                render.buffer.update(id);
             });
             state.buffers[id].contexts.forEach(function (context) {
                 var ctx = elem.find("#context" + context.id);
-                if (ctx.length)
+                if (ctx.length) {
+                    ctx.unbind();
                     render.context.attach(ctx);
+                }
             })
         }
     },
     context: {
-        auto: function (context) {
-            return context.selected ? render.context.full(context) : render.context.overview(context);
-        },
-        overview: function (context) {
-            return (
-                "<context id='context" + context.id + "' data-contextid='" + context.id + "' data-bufferid='" + context.buffer + "'>" + (
-                    render.message(context.original, true, true)
-                ) + "</context>"
-            )
-        },
         full: function (context) {
             return (
-                "<context id='context" + context.id + "' data-contextid='" + context.id + "' data-bufferid='" + context.buffer + "' class='selected'>" + (
-                    "<inline-button class='load_before'>" + translation.context.load_earlier + "</inline-button>" + (
-                        context.before.map(render.message).join("") +
-                        render.message(context.original, true) +
+                "<context id='context" + context.id + "' data-contextid='" + context.id + "' data-bufferid='" + context.buffer + "'>" + (
+                    "<div class='before'>" +(
+                        "<inline-button class='load_before'>" + translation.context.load_earlier + "</inline-button>" +
+                        context.before.map(render.message).join("")
+                    ) + "</div>" +
+                    render.message(context.original, true) +
+                    "<div class='after'>" +(
                         context.after.map(render.message).join("")
-                    ) + "<inline-button class='load_after'>" + translation.context.load_later + "</inline-button>"
+                        + "<inline-button class='load_after'>" + translation.context.load_later + "</inline-button>"
+                    ) + "</div>"
                 ) + "</context>"
             )
         },
@@ -146,17 +154,17 @@ var render = {
                 console.log("Undefined buffer: " + bufferid);
             }
 
-            elem.click(function (e) {
+            bind_click(elem, function (e) {
                 e.stopPropagation();
             });
             $("#message" + state.buffers[bufferid].contexts[id].original.messageid).unbind();
-            $("#message" + state.buffers[bufferid].contexts[id].original.messageid).click(make_toggle_context(bufferid, id));
-            elem.find(".load_before").click(function (e) {
+            bind_click($("#message" + state.buffers[bufferid].contexts[id].original.messageid), make_toggle_context(bufferid, id));
+            bind_click(elem.find(".load_before"), function (e) {
                 e.stopPropagation();
 
                 load.context.earlier(bufferid, id, 5);
             });
-            elem.find(".load_after").click(function (e) {
+            bind_click(elem.find(".load_after"), function (e) {
                 e.stopPropagation();
 
                 load.context.later(bufferid, id, 5);
@@ -166,7 +174,7 @@ var render = {
     message: function (message, highlight, preview) {
         var content = preview === true ? message.preview : message.message;
         return (
-            "<message id='message" + message.messageid + "' data-messageid='" + message.messageid + "' " + (highlight === true ? "" : "class='faded'") + ">" + (
+            "<message id='message" + message.messageid + "' data-messageid='" + message.messageid + "' " + (highlight === true ? "class='original'" : "") + ">" + (
                 "<time>" + new Date(message.time.replace(" ", "T") + "Z").toLocaleString() + "</time>" +
                 "<div class='container'>" + (
                     "<sender style='color: " + sendercolor(message.sender.split("!")[0]) + "'>" + message.sender.split("!")[0] + "</sender>" +
@@ -187,6 +195,10 @@ var render = {
             if (history.length == 0) {
                 container.append("<p>" + translation.history.error_unavailable + "</p>");
             }
+ "<li id='history" + id + "' data-query='" + btoa(query) + "'>" + (
+ "<span class='icon'>history</span>" +
+ query
+ ) + "</li>"
         },
         item: function (id, query) {
             return (
@@ -199,7 +211,7 @@ var render = {
         attach: function (elem) {
             elem.unbind();
             var query = atob(elem.data("query"));
-            elem.click(function (e) {
+            bind_click(elem, function (e) {
                 e.stopPropagation();
 
                 $("#q").val(query);
@@ -244,7 +256,6 @@ var load = {
                         "id": ctx++
                     };
                 }));
-                render.buffer.update(id);
             });
         }
     },
@@ -264,7 +275,7 @@ var load = {
             load.context.raw(earliest, bufferid, amount, 0, function (messages) {
                 var newmsgs = messages.slice(0, messages.length - 1);
                 context.before = newmsgs.concat(context.before);
-                render.buffer.update(bufferid);
+                $("#buffer"+bufferid+" #context"+contextid+" .before .load_before").after(newmsgs.map(render.message).join(""))
             })
         },
         later: function (bufferid, contextid, amount) {
@@ -274,7 +285,7 @@ var load = {
             load.context.raw(latest, bufferid, 0, amount, function (messages) {
                 var newmsgs = messages.slice(1);
                 context.after = context.after.concat(newmsgs);
-                render.buffer.update(bufferid);
+                $("#buffer"+bufferid+" #context"+contextid+" .after .load_after").before(newmsgs.map(render.message).join(""))
             })
         }
     }
@@ -284,7 +295,7 @@ var search = function () {
     var results = $("#results");
     results.children().remove();
     $("#q").blur();
-    results.click(deselect_buffers);
+    bind_click(results, deselect_buffers);
     state = {
         "query": $("#q").val(),
         "selected_history_entry": -1,
@@ -305,21 +316,21 @@ var deselect_buffers = function (except) {
         if (key !== except && buffer.selected) {
             buffer.selected = false;
             unselect_contexts(key);
-            render.buffer.update(key);
         }
     });
     state.open = [];
 };
 
 var unselect_contexts = function (bufferid) {
-    state.buffers[bufferid].contexts = state.buffers[bufferid].contexts.map(function (context) {
+    state.buffers[bufferid].contexts.forEach(function (context) {
         context.selected = false;
-        return context
     })
 };
 
 var make_toggle_buffer = function (id) {
     return function (e) {
+        console.log("toggle buffer " + id);
+
         e.stopPropagation();
 
         if (state.buffers[id].selected) {
@@ -331,12 +342,14 @@ var make_toggle_buffer = function (id) {
             state.open.push(make_toggle_buffer(id));
             state.buffers[id].selected = true;
         }
-        render.buffer.update(id);
+        apply_selection();
     }
 };
 
 var make_toggle_context = function (buffer, id) {
     return function (e) {
+        console.log("toggle_context " + buffer + " " + id);
+
         e.stopPropagation();
 
         var context = state.buffers[buffer].contexts[id];
@@ -356,10 +369,19 @@ var make_toggle_context = function (buffer, id) {
             if (context.before.length === 0) load.context.earlier(buffer, id, 5);
             if (context.after.length === 0) load.context.later(buffer, id, 5);
         }
-        render.buffer.update(buffer);
+        apply_selection();
     }
 };
 
+var apply_selection = function () {
+    $.each(state.buffers, function (key, buffer) {
+        $("#buffer"+key).toggleClass("selected", state.buffers[key].selected);
+        state.buffers[key].contexts.map(function (ctx) {
+            $("#buffer"+key+" #context"+ctx.id).toggleClass("selected", ctx.selected);
+        })
+    });
+};
+
 var hashChange = function () {
     var input = $("#q");
     var newquery = decodeURIComponent(location.hash.substr(1));
@@ -381,28 +403,7 @@ var init = function () {
 
     $(window).on("hashchange", hashChange);
 
-    $("#q").on("keypress", function (e) {
-        var key = e.which || e.keyCode;
-        if (key === 13) {
-            search();
-        }
-        if (key === 40) {
-            $("#history" + state.selected_history_entry).removeClass("selected");
-            state.selected_history_entry = (state.selected_history_entry + 1) % get_history().length;
-            $("#q").val(get_history().reverse()[state.selected_history_entry]);
-            $("#history" + state.selected_history_entry).addClass("selected");
-        } else if (key === 38) {
-            $("#history" + state.selected_history_entry).removeClass("selected");
-            if (state.selected_history_entry === 0) {
-                state.selected_history_entry = -1;
-                $("#q").val("");
-            } else {
-                state.selected_history_entry = (state.selected_history_entry - 1) % get_history().length;
-                $("#q").val(get_history().reverse()[state.selected_history_entry]);
-                $("#history" + state.selected_history_entry).addClass("selected");
-            }
-        }
-    });
+
 
     $("#q").on("focus", function () {
         $("#autocomplete").addClass("active");
@@ -418,4 +419,23 @@ var init = function () {
     hashChange();
     render.history.all(search_history.get());
 };
-init();
\ No newline at end of file
+init();
+
+ $("#q").on("keypress", function (e) {
+ const key = e.which || e.keyCode;
+ if (key === 13) {
+ search();
+ }
+
+ const index_before = historyHandler.index;
+ if (key === 40) {
+ historyHandler.navigateBefore();
+ } else if (key === 38) {
+ historyHandler.navigateLater();
+ }
+ if (index_before != historyHandler.index) {
+ $("[data-history="+index_before+"]").removeClass("selected");
+ $("[data-history="+historyHandler.index+"]").addClass("selected");
+ }
+ });
+*/
\ No newline at end of file
diff --git a/res/sendercolor.js b/res/sendercolor.js
deleted file mode 100644
index a1011481cd0ff617b4d4955639e5e77149df72f6..0000000000000000000000000000000000000000
--- a/res/sendercolor.js
+++ /dev/null
@@ -1,64 +0,0 @@
-const sendercolor = function (nick) {
-    var sendercolors = [
-        "#e90d7f",
-        "#8e55e9",
-        "#b30e0e",
-        "#17b339",
-        "#58afb3",
-        "#9d54b3",
-        "#b39775",
-        "#3176b3",
-        "#e90d7f",
-        "#8e55e9",
-        "#b30e0e",
-        "#17b339",
-        "#58afb3",
-        "#9d54b3",
-        "#b39775",
-        "#3176b3"
-    ];
-
-    var reflect = function (crc, n) {
-        var j = 1, crcout = 0;
-        for (var i = (1 << (n - 1)); i > 0; i >>= 1) {
-            if ((crc & i) > 0) {
-                crcout |= j;
-            }
-            j <<= 1;
-        }
-        return crcout;
-    };
-
-    var qChecksum = function (str) {
-        var crc = 0xffff;
-        var crcHighBitMask = 0x8000;
-
-        for (var i = 0; i < str.length; i++) {
-            var b = str.codePointAt(i);
-            var c = reflect(b, 8);
-            for (var j = 0x80; j > 0; j >>= 1) {
-                var highBit = crc & crcHighBitMask;
-                crc <<= 1;
-                if ((c & j) > 0) {
-                    highBit ^= crcHighBitMask;
-                }
-                if (highBit > 0) {
-                    crc ^= 0x1021;
-                }
-            }
-        }
-
-        crc = reflect(crc, 16);
-        crc ^= 0xffff;
-        crc &= 0xffff;
-
-        return crc;
-    };
-
-    var senderIndex = function (str) {
-        var nickToHash = str.replace(/_*$/, "").toLowerCase();
-        return qChecksum(nickToHash) & 0xF;
-    };
-
-    return sendercolors[senderIndex(nick)];
-};
\ No newline at end of file
diff --git a/templates/login.phtml b/templates/login.phtml
index cfca65c020fecb9a80a33a8cf70ba6062b2df8bf..da9394f9109618eb2fcf912d6e5b507fccfe0567 100644
--- a/templates/login.phtml
+++ b/templates/login.phtml
@@ -12,8 +12,8 @@
 
     <link rel="icon" type="image/png" href="favicon.png">
 
-    <link rel="stylesheet" href="res/login.css">
-    <link rel="stylesheet" href="res/material-icons.css">
+    <link rel="stylesheet" href="res/css/login.css">
+    <link rel="stylesheet" href="res/css/icons.css">
 </head>
 <body>
 
diff --git a/templates/search.phtml b/templates/search.phtml
index 6d79b2f7cdc3693561f04e17e27bf063a9fcb6c8..b043bb7a8ad7c1416c27edc22197e10e9ac2190d 100644
--- a/templates/search.phtml
+++ b/templates/search.phtml
@@ -12,38 +12,27 @@
 
     <link rel="icon" type="image/png" href="favicon.png">
 
-    <link rel="stylesheet" href="res/search.css">
-    <link rel="stylesheet" href="res/material-icons.css">
+    <link rel="stylesheet" href="res/css/search.css">
 </head>
 <body>
-<nav>
-    <div class="wrapper">
-        <div id="searchbar">
-            <div id="searchicon" class="icon">search</div>
-            <input name="q" id="q" placeholder="<?php $t('search'); ?>" type="text" autocomplete="off">
-        </div>
-    </div>
-    <div id="actions">
-        <a title="<?php $t('logout'); ?>" href="login.php?action=logout">
-            <span class="icon">account_circle</span>
-        </a>
-    </div>
-    <div id="autocomplete">
-        <ul></ul>
-    </div>
-</nav>
 
-<section id="results">
-</section>
-
-<div id="modal-background"></div>
-<div id="bg"></div>
-
-<script src="res/jquery.js"></script>
 <script>
-    var translation = <?php echo json_encode($translation); ?>;
+    const translation = <?php echo json_encode($translation); ?>;
 </script>
-<script src="res/sendercolor.js"></script>
-<script src="res/search.js"></script>
+<script src="res/js/util/loader.js"></script>
+<script src="res/js/util/component.js"></script>
+<script src="res/js/util/mirccolorhandler.js"></script>
+<script src="res/js/util/sendercolorhandler.js"></script>
+<script src="res/js/component/nohistoryelement.js"></script>
+<script src="res/js/component/historyelement.js"></script>
+<script src="res/js/component/history.js"></script>
+<script src="res/js/component/nav.js"></script>
+<script src="res/js/component/messagePreview.js"></script>
+<script src="res/js/component/message.js"></script>
+<script src="res/js/component/loadmore.js"></script>
+<script src="res/js/component/context.js"></script>
+<script src="res/js/component/buffer.js"></script>
+<script src="res/js/component/urlbar.js"></script>
+<script src="res/js/app.js"></script>
 </body>
 </html>
diff --git a/web/backlog/index.php b/web/backlog/index.php
index 83855ec1e0587129bee5185f34ccb4d74373e30f..a70db8b3830021d27d7e69cca73d1ff62a03318c 100644
--- a/web/backlog/index.php
+++ b/web/backlog/index.php
@@ -10,12 +10,12 @@ require_once '../../backend/helper/SessionHelper.php';
 $session = SessionHelper::getInstance();
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 if (!$backend->authenticate($session->username ?: '', $session->password ?: '')) {
     $session->destroy();
     $renderer->renderJsonError(false);
 } else {
     syslog(LOG_INFO, json_encode($_GET));
-    $renderer->renderJson($backend->context($_GET['anchor'] ?: 0, $_GET['buffer'] ?: 0, $_GET['before'], $_GET['after']));
+    $renderer->renderJson($backend->context($_REQUEST['anchor'] ?: 0, $_REQUEST['buffer'] ?: 0, $_REQUEST['before'], $_REQUEST['after']));
 }
\ No newline at end of file
diff --git a/web/search/index.php b/web/search/index.php
index 6e8f950e1613d66082e6aa6720034748a3d16fd4..dac580a0bf3413e7e324ce55bf85274d83fc3395 100644
--- a/web/search/index.php
+++ b/web/search/index.php
@@ -10,11 +10,11 @@ require_once '../../backend/helper/SessionHelper.php';
 $session = SessionHelper::getInstance();
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 if (!$backend->authenticate($session->username ?: '', $session->password ?: '')) {
     $session->destroy();
     $renderer->renderJsonError(false);
 } else {
-    $renderer->renderJson($backend->find($_GET['query'] ?: "", $_GET['since'] ?: null, $_GET['before'] ?: null, $_GET['buffer'] ?: null, $_GET['network'] ?: null, 4));
+    $renderer->renderJson($backend->find($_REQUEST['query'] ?: "", $_REQUEST['since'] ?: null, $_REQUEST['before'] ?: null, $_REQUEST['buffer'] ?: null, $_REQUEST['network'] ?: null, 4));
 }
\ No newline at end of file
diff --git a/web/searchbuffer/index.php b/web/searchbuffer/index.php
index 54d2b525082a8b24dc413085cf84af69f8e7aa79..ff679a7cf6cf88d5eb4fadfabbe0f3e099fecb63 100644
--- a/web/searchbuffer/index.php
+++ b/web/searchbuffer/index.php
@@ -10,11 +10,11 @@ require_once '../../backend/helper/SessionHelper.php';
 $session = SessionHelper::getInstance();
 $config = Config::createFromGlobals();
 $renderer = new RendererHelper($config);
-$backend = Backend::createFromConfig($config);
+$backend = Database::createFromConfig($config);
 
 if (!$backend->authenticate($session->username ?: '', $session->password ?: '')) {
     $session->destroy();
     $renderer->renderJsonError(false);
 } else {
-    $renderer->renderJson($backend->findInBuffer($_GET['query'] ?: "", $_GET['since'] ?: null, $_GET['before'] ?: null, $_GET['buffer'] ?: 0, $_GET['offset'] ?: 0, $_GET['limit'] ?: 20));
+    $renderer->renderJson($backend->findInBuffer($_REQUEST['query'] ?: "", $_REQUEST['since'] ?: null, $_REQUEST['before'] ?: null, $_REQUEST['buffer'] ?: 0, $_REQUEST['offset'] ?: 0, $_REQUEST['limit'] ?: 20));
 }
\ No newline at end of file