*:not(.bold) {
   margin: 0;
   padding: 0;
   list-style: none;
   outline: 0;
   border: 0;
   font-size: 0;
   line-height: 0;
   box-sizing: border-box;
   -webkit-text-size-adjust: none;
   -webkit-backface-visibility: hidden;
}

::-webkit-scrollbar {
   height: 0 !important;
   width: 0 !important;
}


body {
   width: 100%;
   color: #fff;
   font-family: 'Open Sans', 'Helvetica Neue', helvetica, sans-serif;
    -webkit-font-smoothing: subpixel-antialiased;
   background-color: #000;
   text-align: center;

}

a {
   text-decoration: none;
   color: #000;
}
a:hover {}

#app {
   margin: auto auto;
        //width: 320px;
}

#header {
   position: fixed;
   top: 0;
   background-color: #000;
   height: 45px;
   text-align: center;
   box-shadow: 0 2px 2px 0 rgba(0,0,0,0.1), 0 1px 0 0 rgba(0,0,0,0.1);
   width: 100%;
   z-index: 11000;
}
#header .back-button {
   display: none;
   position: absolute;
   left: 0px;
   z-index: 10;
   height: 40px;
   padding: 10px 10px 10px 10px;
   margin: 3px 0px 0px 0px;
   cursor: pointer;
}
#header .logo-image {
   z-index: 10;
   height: 45px;
   padding: 10px 10px 10px 10px;
   margin-left: 5px;
   cursor: pointer;
}
#header .logo-text {
   height: 45px;
   padding: 13px 10px 13px 0px;
   cursor: pointer;
}

#banner-wrapper {
  padding: 0px 13px;
  margin-top: 45px;
  margin-bottom: -45px
}
.banner {
  height: 50px;
  color: #fff;
  padding: 4px 12px;
  font-size: 15px;
  font-weight: 300;
  text-transform: uppercase;
  text-align: left;
  clear: both;
  line-height: 20px;
}
#banner {
  background-color: #212121;
  margin-bottom: 6px;
}
.bold {
  font-weight: bold;
}

#container {
   margin-top: 45px;
   -webkit-overflow-scrolling: touch;

  -webkit-transform: translate3d(0,0,0);
  transform: translate3d(0,0,0);
   position: relative;
   /*margin-bottom:45px;*/
}

#gifs {
   margin: 0 auto 45px;
   padding: 0 10px 0 10px;
   overflow: auto;

}

#gifs > li {
   display: inline-block;
        //display: block;
   width: 145px;
   margin: 10px 0px 0px 0px;
   border-radius: 3px;
        //box-shadow: 0 1px 3px 0 rgba(0,0,0,0.33);
   background-color: #212121;
}
#gifs > li img {
   width: 100%;
   border-radius: 3px 3px 0 0;
   background-color: #000;
            //-webkit-animation: fadein 1s forwards;
//        -webkit-animation: fadein 1s forwards;
}

.tags {
   text-align: left;
   padding: 7px 0px 7px 7px;
   width: 100%;
   background-color: #000;
   border-radius: 0px 0px 3px 3px;
}

.tags > a {
   color: #33c5f3;
   display: inline-block;
        //display: block;
   margin-right: 5px;
   font-size: 11px;
   line-height: 14px;
}

.tags .tag {
   color: #33c5f3;
   display: inline-block;
        //display: block;
   margin-right: 5px;
   font-size: 11px;
   line-height: 14px;
   cursor: pointer;
}

.actions {
   border-top: 1px solid #f0f0f0;
   height: 40px;
   background-color: #fff;
   border-radius: 0px 0px 3px 3px;
   display: none;
}
.actions > a {
   display: inline-block;


}
.actions img {
   background-color: #fff !important;
}


.tags a:after {
}

.tags a:last-child:after {
   content: "";
}

.tag:after {
}

.tag:last-child:after {
   content: "";
}

@-webkit-keyframes fadein {
   from { opacity:0; }
   to { opacity:1; }
}

@-webkit-keyframes fadeout {
   from { opacity:1; }
   to { opacity:0; }
}

.fade-in {
   opacity: 0;
            //-webkit-animation: fadein 1s ease-in-out;
   -webkit-animation: fadein .3s forwards;
}

.fade-out {
   opacity: 1;
   -webkit-animation: fadeout 1s;
}

#categories {
   position: relative;
   top: 0;
   left: 0;
   z-index: 40;
   background-color: #fff;
   display: none;
   text-align: left;
}

#categories > li {
        //font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
   display: inline-block;
   font-size: 18px;
   line-height: 38px;
        //font-weight: 300;
        //letter-spacing: -1px;
   width: 100%;
   color: white;
   text-transform: capitalize;
   height: 40px;
   //border-bottom: 1px solid #e1e1e1;
   padding: 0px 0px 0px 15px;
   opacity: 1;
   -webkit-transition: all 0.1s linear;
}
#categories > li:hover:not(.subtitle) {
  opacity: 0.6;
}

.category {
   position: absolute;
   top: 0;
   left: 0;
   z-index: 100;
   width: 100%;
   background-color: #fff;
   display: none;
   text-align: left;
}

.category > li {
        //font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
   display: inline-block;
   font-size: 16px;
   line-height: 38px;
        //font-weight: 300;
        //letter-spacing: -1px;
   width: 100%;
   color: #000;
   text-transform: capitalize;
   height: 40px;
   border-bottom: 1px solid #e1e1e1;
   padding: 0px 0px 0px 15px;
}


#footer {
   display: table;
   text-align: left;
   position: fixed;
   bottom: 0;
        //background-color: #212121;
   background-color: #000;
   //height: 45px;
   height: 40px;
        //height: 48px;
        //overflow: hidden;
   width: 100%;
   z-index: 1000;
   box-shadow: 0 -2px -2px 0 rgba(0,255,0,0.1), 0 1px 0 0 rgba(255,0,0,0.1);
}

#footer a {
   display: table-cell;
   width: 50px;
}

#searchbar {
   display: table-cell;
        //float: left;
        //position: fixed;
        //bottom: 48px;
        //height: 40px;
        //z-index: 20;
        //width: 100%;
   background-color: #f0f0f0;
   background-color: #000;
   padding: 6px 3px 6px 6px;
   -webkit-box-shadow: 0 1px 0px rgba(0,0,0,.1);
   width: 400px;
   position: relative;
   left: 8px;
}

#searchbar input {
    //   height: 100%;
   height: 33px;
   width: 100%;
   padding: 0px 15px 0px 20px;
   font-size: 14px;
   line-height: 24px;
   border-radius: 0px;
   background-color: #fff;
   color: #000;
}

#footer #categories-button {
   border-left: 5px solid #000;
   width: 45px;
   height: 100%;
   background-image: url(../img/icon_menu.png);
   background-repeat: no-repeat;
   background-size: 25px 25px;
   background-position: center;
   cursor: pointer;
   position: relative;
   left: 5px
}

/*#footer #search-button {
   border-right: 3px solid #000;
   width: 50px;
   height: 100%;
   background-image: url(../img/icon_search.png);
   background-repeat: no-repeat;
   background-size: 25px 25px;
   background-position: center;
   cursor: pointer;
}*/


  /*ATTEMPT FOR NEW COLORFUL SEARCH ICON*/
#footer #search-button {
   border-right: 0px solid #000;
   width: 50px;
   height: 100%;
   background-image: url(../img/icon_search_color.png);
   background-repeat: no-repeat;
   background-size: 34px 34px;
   background-position: center;
   cursor: pointer;
   position: relative;
   left: -3px;
}



#gif-detail {
   /*display: none;*/
   position: fixed;
   width:100%;
   top:45px;
   left:0;
   z-index:10000;
   text-align: left;
   background-color: #000;
   height: 100%;
}

#gif-detail-gif-wrapper {
  position: relative;
}

.gif-detail-hover-banner {
   background-color: rgba(0,0,0,0.5);
   width: 100%;
   height: 40px;
   position: absolute;
   top: -40px;
   text-align: center;
   padding: 10px;
   z-index: 1000;
   -webkit-transition: all .25s cubic-bezier(.77,0,.175,1);
}
.gif-detail-hover-banner-active {
  top: 0px;
}

#gif-detail #gif-detail-gif {
  width: 100%;
}

#gif-detail #loader {
    display:none;
    z-index:2;
    position:absolute;
    top: 50px;
    right:5px;
    width:20px;
}

#share-menu {
   /*display: none;*/
   z-index: 200;
   letter-spacing: 0px;
   position: absolute;
   bottom: 45px;
   padding-bottom: 10px;
   background-color: #000;
   width: 100%;
   text-align:left;
   font-weight:200;
   -webkit-font-smoothin:  subpixel-antialiased;
}
#share-menu .cancel {
   height: 45px;
   width: 100%;
   background-color: #212121;
   text-align: left;
   font-size: 16px;
   line-height: 45px;
   color: #fff;
}

#share-menu #copy-gif {
   width: 100%;
   background-color: #000;
   height: 45px;
   font-size: 16px;
   line-height: 45px;
   color: #fff;
   padding-left: 10px;
}
#gif-detail-tags {
  background: #000;
  padding: 6px 0px;
}
#share-menu #gif-detail-link,
#share-menu #gif-detail-tags{
   width: 100%;
   height: auto;
   padding-left: 10px;
   /*background-color: #000;*/
}
#gif-detail-link-wrapper {
  padding: 0px 10px;
}
#gif-detail-link {
  background: #353535;
  font-size: 16px;
  color: #fff;
  float: left;
}
#gif-detail-link-text {
  line-height: normal;
  padding: 10px;
  float: left;
  font-size: 15px;
}
.gif-detail-link-btn {
  font-weight: 400;
  font-size: 15px;
  color: #fff;
  line-height: normal;
  float: right;
  padding: 10px 20px;
  cursor: pointer;
  text-align: center;
  width: 115px;
  background-color: #ff6666;
  -webkit-transition: all .23s cubic-bezier(.77,0,.175,1);
}
.gif-detail-link-btn.active {
  background-color: #9933ff;
}

#share-menu #gif-detail-link a,
#share-menu #gif-detail-tags .gif-detail-tag{
  font-family: 'Open Sans', 'Helvetica Neue', helvetica, sans-serif;
   color: #fff;
   font-size: 14px;
   line-height: 46px;
   margin: 0px 10px 0px 0px;
   cursor: pointer;
   background-color: #212121;
   padding: 10px;
   font-weight: 300;
}

#share-menu #gif-detail-tags .gif-detail-tag {
  text-transform: uppercase;
}

/*#share-menu #gif-detail-tags .gif-detail-tag:after {
   content: ",";
}

#share-menu #gif-detail-tags .gif-detail-tag:last-child:after {
   content: "";
}*/

#share-menu .share-menu {
   width: 100%;
   text-align: center;
   height: 45px;
   font-size: 16px;
   line-height: 45px;
   color: #fff;
   background-color: #212121;
}

#share-menu .share-menu > li {
   float: left;
   display: inline-block;
   width: 55px;
   height: 100%;
   line-height: 70px;
}
#share-menu .share-menu > li img {
   height: 25px;
}

.sms-button {
   background-color: #212121;
}
.facebook-button {
   background-color: #3b5997;
}
.twitter-button {
   background-color: #00acee;
}
.email-button {
   background-color: #212121;
}


#categories {
  background-color: black;
  min-height: 555px;
}

#categories .subtitle {
  /*font-weight: bold;*/
  font-family: 'Open Sans Extrabold', 'Helvetica Neue', helvetica, sans-serif;
  background: black;
  color:black;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 22px;
  margin: 3px 7px;
  padding-left: 7px;
  width: 97%;
  cursor: pointer;
}
#categories #subtitle-reactions {
  background: #22cdfd;
}
#categories #subtitle-emotions {
  background: #43fecd;
}
#categories #subtitle-actions{
  background: #983797;
}
#categories #subtitle-animals {
  background: #fffe9f;
}
#categories #subtitle-celebrities {
  background: #3a9bfc;
}
#categories #subtitle-tv {
  background: #fd6769;
}
#categories #subtitle-movies {
  background: #3dcccb;
}
#categories #subtitle-music {
  background: #676bfb;
}
#categories #subtitle-popular {
  background: #ca3cca;
}

#categories .popular_tag {
  cursor: pointer;
  display: none;
}

.gif_error_msg {
  text-align: center;
  margin:65px auto;
  color:black;
  font-size:18px;
  line-height: 1.3em;
  width:200px;
}


.giphy_gif_li {
  position: relative;
  cursor:pointer;
  padding-bottom:0px;
  background-color: black;
  /*background-color: red;*/
  display:inline-block;
}
.giphy_gif {
  background-color: black;
}
.gif_drag_cover {
  width:100%;
  /*height:100%;*/
  position: absolute;

  /*z-index:1000;*/
  /*background-color: red;*/
  top:0;
  right:0;
}


#gif-detail-cover {
  /*background-color: red;*/
  width:100%;
  position: absolute;
  top:0;
  right:0;
  z-index:5000;
}


#container {
  width:480px;
  height:500px;
}

#giphy_copy_box {
  display:block;
  visibility: visible;
  z-index:-1;
  font-weight:normal;
  font-size:14px;
  position: absolute;
  top:0;
  left:0;
}
#share-menu {

}
.mobile-share {
  display:none;
}
#copy-gif {
  display:none;
}


.hoverable-gif .caption {
  color: #FFFFFF;
  transition-delay: 0s !important;
  -webkit-transition-delay: 0s !important;
  transition: opacity .2s ease-in-out;
  -webkit-transition: opacity .2s ease-in-out;
  bottom: 0;
  left: 0;
  padding: 0 0px 5px 0px;
  margin: 0px;
  opacity: 1;
  width: 100%;
  height: 100px;
  position: absolute !important;
  text-transform: none;
  display:inline-block;
  background: -moz-linear-gradient(top,rgba(0,0,0,0) 0%, rgba(0,0,0,0.75) 100%) /* FF3.6+ */;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(0,0,0,0)), color-stop(100%,rgba(0,0,0,0.75))) /* Chrome,Safari4+ */;
  background: -webkit-linear-gradient(top,rgba(0,0,0,0) 0%, rgba(0,0,0,0.75) 100%) /* Chrome10+,Safari5.1+ */;
  background: -o-linear-gradient(top,rgba(0,0,0,0) 0%,rgba(0,0,0,0.75) 100%) /* Opera 11.10+ */;
  background: -ms-linear-gradient(top,rgba(0,0,0,0) 0%,rgba(0,0,0,0.75) 100%) /* IE10+ */;
  background: linear-gradient(to bottom,rgba(0,0,0,0) 0%,rgba(0,0,0,0.75) 100%) /* W3C */;
  z-index: 10;
}
.hoverable-gif:hover .caption {
  transition-delay: 1.5s !important;
  -webkit-transition-delay: 1.5s !important;
  // opacity:0.0;
}

.hoverable-gif .tags {
  max-height: 30px;
  line-height: 1;
  bottom: 0px;
  overflow: hidden;
  line-height: 30px;
  max-height: 20px;
  padding: 10px 10px 20px 10px;
}

.hoverable-gif .tags .tag {
  font-size: 12px;
  font-weight: 300;
  text-align: left;
  white-space: nowrap;
  word-wrap: normal;
  color: #FFFFFF;
}

.hashtag {
  font-family: sans-serif;
  font-weight: 400;
  font-size:12px;
  margin-right: 1px;
}

.loading_icon_box {
    position: absolute;
    bottom:6px;
    right:10px;
    z-index:7000;
}
.loading_icon {
    z-index:10000;
    width:40px;
    height:40px;
    bottom:1px;
    right:6px;
    position: fixed;
}
.loading_icon img {
    width:33px;
    height:33px;
}
