/* Input Number Spinner */
.spinner {
  width: 100px;
}

.spinner input {
  text-align: right;
}

.input-group-btn-vertical {
  position: relative;
  white-space: nowrap;
  width: 1%;
  vertical-align: middle;
  display: table-cell;
}

.input-group-btn-vertical>.btn {
  display: block;
  float: none;
  width: 100%;
  max-width: 100%;
  padding: 11.26px;
  margin-left: -1px;
  position: relative;
  border-radius: 0;
}

.input-group-btn-vertical>.btn:first-child {
  border-top-right-radius: 4px;
}

.input-group-btn-vertical>.btn:last-child {
  margin-top: -2px;
  border-bottom-right-radius: 4px;
}

.input-group-btn-vertical i {
  position: absolute;
  top: 2.8px;
  left: 4.8px;
}

.input-group-btn-vertical .btn-default {
  transition-timing-function: ease-in-out;
  background-color: #3e4bc1;
  color: #fff;
}

.input-group-btn-vertical .plus:hover {
  background-color: #14c490;
}

.input-group-btn-vertical .plus:active {
  background-color: rgba(0, 255, 0, 1);
  box-shadow: none !important;
}

.input-group-btn-vertical .minus:hover {
  background-color: rgba(255, 0, 0, 0.8);
}

.input-group-btn-vertical .minus:active {
  background-color: #ea4775;
  box-shadow: none !important;
}

/* Result - Copy Button */
#resultCopy {
  top: 2px;
  height: 100%;
}

#resultCopy i {
  top: 14px;
  left: 4.8px;
}

#resultCopy:hover {
  background-color: rgba(0, 0, 0, 0.8);
}

#resultCopy:active {
  background-color: rgba(0, 0, 0, 1);
  box-shadow: none !important;
}

/* Options Box */
.optionsBox {

  background-color: rgba(0, 0, 0, 0.1) !important;
}

.optionsBox h1 {
  color: #FFFFFF;
}

/*.optionsBox .input-group-text {*/
/*  background-color: rgba(0, 0, 0, 0.8);*/
/*  color: #FFF !important;*/
/*}*/

.optionsBox .custom-select-lg {
  font-size: 100%;
}

.optionsBox .optionButtons {
  position: relative;
  display: inherit;
  padding: 0 0;
}

.optionsBox .button-2c {
  height: 31px;
  padding: 4px 20px !important;
  margin: 0 5px !important;
  color: #FFF;
  background-color: rgb(255, 0, 0);
  box-shadow: 0 6px rgba(255, 0, 0, 0.7);
}

.optionsBox .button-2c:hover {
  box-shadow: 0 4px rgba(255, 0, 0, 0.7);
}

@media screen and (min-width: 767px) {
  .optionButtons #ACButton {
    left: 16px;
  }

  .bootstrap-switch-handle-on {
    height: 36px;
  }
}

@media screen and (max-width: 766px) {
  .bitwiseButtons {
    display: none !important;
  }

  .inputLabel {
    display: none !important;
  }

  .binaryInputs {
    border-radius: 5px !important;
  }

  .rightBox, .my-4 {
    display: none !important;
  }

  #operand1System, #operand2System, #resultSystem, .operandSystemContainer, .bitwiseButtonsContainer, .optionButtonsContainer, .ribbon, .h1Options {
    display: none !important;
  }

  .footer, .header {
    display: none !important;
  }

  .optionsBox {
    margin-top: -40px;
  }

  .optionContainer h1 {
    margin-bottom: 30px;
  }

  .inputs {
    margin-top: -15px;
    background: #ddd;
  }

  #BTNContainer {
    margin-top: -10px;
    margin-bottom: -60px;
  }

  #BTNContainer button {
    margin-top: 20px !important;
  }

  #BTNContainer .BTNRow {
    margin-top: -25px !important;
  }

  .inputs .button-2c {
    padding: 10px 20px !important;
  }
}

.bootstrap-switch-null * {
  cursor: not-allowed !important;
}

/* Inputs */
.inputs .input-group {
  margin-top: 15px;
}

.inputs .inputLabel {
  min-width: 128px;
}

.inputs .systemOutput {
  height: 48px !important;
}

.inputs .bitwiseButtons {
  position: relative;
  display: inherit;
  padding: 0 0;
}

.inputs .button-2c {
  height: 42px;
  padding: 10px 20px;
  margin: 0 5px;
  background-color: rgba(0, 0, 0, 0.4);
  box-shadow: 0 6px rgba(0, 0, 0, 0.7);
}

.inputs .binaryInputs {
  font-size: 1rem !important;
}

.inputs .button-2c:hover {
  box-shadow: 0 4px rgba(0, 0, 0, 0.7);
}

/* Inputs - Lower Functional Buttons */
.inputs .functionalButtons {
  margin-top: 20px;
}

.inputs .functionalButtons .button-2c {
  height: 42px;
  padding: 8px 40px;
  margin: 0 5px;
  background-color: rgba(0, 0, 0, 0.8);
  box-shadow: 0 6px rgba(0, 0, 0, 0.7) !important;
}

.inputs .button-2c:hover {
  box-shadow: 0 4px rgba(0, 0, 0, 0.7) !important;
}

.inputs .active {
  border: 2px solid #FFFFFF;
  /*background-color: rgba(0, 0, 0, 1) !important;*/
  /*padding: 8px 38px;*/
  padding: 5px 30px;
  background: red;
}

.inputs .button-2c:hover {
  /*box-shadow: 0 4px rgba(135, 193, 230, 0.7);*/
}

/* GitHub Logo */
.gitHubText {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  line-height: 24px;
  transition: 0.125s ease-in-out;
}

.gitHubText:hover {
  text-decoration: none;
  color: rgba(255, 255, 255, 1);
}

.gitHubLogo {
  height: 80px;
  color: rgba(255, 255, 255, 1) !important;
}

.gitHubLogo:hover {
  color: rgba(255, 255, 255, 1) !important;
}

/* Title */
.titleSpan {
  font-size: 12px;
  font-weight: bold;
  margin-top: 10px;
  position: relative;
}

.titleSpan ul {
  list-style-type: none;
  display: inline-table;
  width: 30%;
  padding: 0 0 0 0;
  margin: 0 0 0 0;
}

header {
  padding-bottom: 16px !important;
}

.fa {
  color: #FFFFFF;
}

/*.input-group-text {*/
/*  color: #FFFFFF !important;*/
/*  background-color: rgba(0, 0, 0, 0.7) !important;*/
/*}*/

.form-control {
  color: #000000 !important;
}

.input-group-btn-vertical .btn {
  /*border: #FFFFFF 1px solid;*/
  border: 0;
}

/* Remove Input spinner */
/* Hide HTML5 Up and Down arrows. */
input[type="number"]::-webkit-outer-spin-button, input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance: textfield;
}

.ribbon img {
  z-index: 5;
}

.button-1 {
  border: 3px solid #fff;
  color: #fff;
}

/* Button 1a */
.button-1a:hover,
.button-1a:active {
  color: #0e83cd;
  background: #fff;
}

/* Button 1b */
.button-1b:after {
  width: 100%;
  height: 0;
  top: 0;
  left: 0;
  background: #fff;
}

.button-1b:hover,
.button-1b:active {
  color: #0e83cd;
}

.button-1b:hover:after,
.button-1b:active:after {
  height: 100%;
}

/* Button 1c */
.button-1c:after {
  width: 0%;
  height: 100%;
  top: 0;
  left: 0;
  background: #fff;
}

.button-1c:hover,
.button-1c:active {
  color: #0e83cd;
}

.button-1c:hover:after,
.button-1c:active:after {
  width: 100%;
}

/* Button 1d */
.button-1d {
  overflow: hidden;
}

.button-1d:after {
  width: 0;
  height: 103%;
  top: 50%;
  left: 50%;
  background: #fff;
  opacity: 0;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

.button-1d:hover,
.button-1d:active {
  color: #0e83cd;
}

.button-1d:hover:after {
  width: 90%;
  opacity: 1;
}

.button-1d:active:after {
  width: 101%;
  opacity: 1;
}

/* Button 1e */
.button-1e {
  overflow: hidden;
}

.button-1e:after {
  width: 100%;
  height: 0;
  top: 50%;
  left: 50%;
  background: #fff;
  opacity: 0;
  -webkit-transform: translateX(-50%) translateY(-50%) rotate(45deg);
  -moz-transform: translateX(-50%) translateY(-50%) rotate(45deg);
  -ms-transform: translateX(-50%) translateY(-50%) rotate(45deg);
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
}

.button-1e:hover,
.button-1e:active {
  color: #0e83cd;
}

.button-1e:hover:after {
  height: 260%;
  opacity: 1;
}

.button-1e:active:after {
  height: 400%;
  opacity: 1;
}

/* Button 1f */
.button-1f {
  overflow: hidden;
}

.button-1f:after {
  width: 101%;
  height: 0;
  top: 50%;
  left: 50%;
  background: #fff;
  opacity: 0;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

.button-1f:hover,
.button-1f:active {
  color: #0e83cd;
}

.button-1f:hover:after {
  height: 75%;
  opacity: 1;
}

.button-1f:active:after {
  height: 130%;
  opacity: 1;
}

/* Button 2 */
.button-2 {
  background: #cb4e4e;
  color: #fff;
  box-shadow: 0 6px #ab3c3c;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

/* Button 2a */
.button-2a {
  border-radius: 0 0 5px 5px;
}

.button-2a:hover {
  box-shadow: 0 4px #ab3c3c;
  top: 2px;
}

.button-2a:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2b */
.button-2b {
  border-radius: 0 0 5px 5px;
}

.button-2b:hover {
  box-shadow: 0 8px #ab3c3c;
  top: -2px;
}

.button-2b:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2c */
.button-2c {
  border-radius: 5px;
}

.button-2c:hover {
  box-shadow: 0 4px #ab3c3c;
  top: 2px;
}

.button-2c:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2d */
.button-2d {
  border-radius: 5px;
}

.button-2d:hover {
  box-shadow: 0 8px #ab3c3c;
  top: -2px;
}

.button-2d:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2e */
.button-2e {
  border-radius: 5px;
  box-shadow: -6px 0 #ab3c3c;
}

.button-2e:hover {
  box-shadow: -4px 0 #ab3c3c;
  left: -2px;
}

.button-2e:active {
  box-shadow: 0 0 #ab3c3c;
  left: -6px;
}

/* Button 2f */
.button-2f {
  border-radius: 5px;
  box-shadow: 6px 0 #ab3c3c;
}

.button-2f:hover {
  box-shadow: 4px 0 #ab3c3c;
  left: 2px;
}

.button-2f:active {
  box-shadow: 0 0 #ab3c3c;
  left: 6px;
}

/* Button 2g */
.button-2g {
  border-radius: 40px;
}

.button-2g:hover {
  box-shadow: 0 4px #ab3c3c;
  top: 2px;
}

.button-2g:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2h */
.button-2h {
  border-radius: 20px;
}

.button-2h:hover {
  box-shadow: 0 4px #ab3c3c;
  top: 2px;
}

.button-2h:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2i */
.button-2i {
  border-radius: 50%;
  width: 90px;
  height: 90px;
  padding: 0;
}

.button-2i:hover {
  box-shadow: 0 4px #ab3c3c;
  top: 2px;
}

.button-2i:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 2j */
.button-2j {
  border-radius: 50%;
  width: 90px;
  height: 90px;
  padding: 0;
}

.button-2j:hover {
  box-shadow: 0 8px #ab3c3c;
  top: -2px;
}

.button-2j:active {
  box-shadow: 0 0 #ab3c3c;
  top: 6px;
}

/* Button 3 */
.button-3 {
  background: #fcad26;
  color: #fff;
}

.button-3:hover {
  background: #f29e0d;
}

.button-3:active {
  background: #f58500;
  top: 2px;
}

.button-3:before {
  position: absolute;
  height: 100%;
  left: 0;
  top: 0;
  line-height: 3;
  font-size: 140%;
  width: 60px;
}

/* Button 3a */
.button-3a {
  padding: 25px 60px 25px 120px;
}

.button-3a:before {
  background: rgba(0, 0, 0, 0.05);
}

/* Button 3b */
.button-3b {
  padding: 25px 60px 25px 120px;
  border-radius: 10px;
}

.button-3b:before {
  border-right: 2px solid rgba(255, 255, 255, 0.5);
}

/* Button 3c */
.button-3c {
  padding: 80px 20px 20px 20px;
  border-radius: 10px;
  box-shadow: 0 3px #da9622;
}

.button-3c:active {
  box-shadow: 0 3px #dc7801;
}

.button-3c:before {
  height: 60px;
  width: 100%;
  line-height: 60px;
  background: #fff;
  color: #f29e0d;
  border-radius: 10px 10px 0 0;
}

.button-3c:active:before {
  color: #f58500;
}

/* Button 3d */
.button-3d {
  padding: 25px 60px 25px 120px;
  border-radius: 10px;
}

.button-3d:before {
  background: #fff;
  color: #fcad26;
  z-index: 2;
  border-radius: 10px 0 0 10px;
}

.button-3d:after {
  width: 20px;
  height: 20px;
  background: #fff;
  z-index: 1;
  left: 55px;
  top: 50%;
  margin: -10px 0 0 -10px;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.button-3d:active:before {
  color: #f58500;
}

.button-3d:active {
  top: 0;
}

.button-3d:active:after {
  left: 60px;
}

/* Button 3e */
.button-3e {
  padding: 25px 120px 25px 60px;
  overflow: hidden;
}

.button-3e:before {
  left: auto;
  right: 10px;
  z-index: 2;
}

.button-3e:after {
  width: 30%;
  height: 200%;
  background: rgba(255, 255, 255, 0.1);
  z-index: 1;
  right: 0;
  top: 0;
  margin: -5px 0 0 -5px;
  -webkit-transform-origin: 0 0;
  -webkit-transform: rotate(-20deg);
  -moz-transform-origin: 0 0;
  -moz-transform: rotate(-20deg);
  -ms-transform-origin: 0 0;
  -ms-transform: rotate(-20deg);
  transform-origin: 0 0;
  transform: rotate(-20deg);
}

.button-3e:hover:after {
  width: 40%;
}

/* Button 4 */
.button-4 {
  border-radius: 50px;
  border: 3px solid #fff;
  color: #fff;
  overflow: hidden;
}

.button-4:active {
  border-color: #17954c;
  color: #17954c;
}

.button-4:hover {
  background: #24b662;
}

.button-4:before {
  position: absolute;
  height: 100%;
  font-size: 125%;
  line-height: 3.5;
  color: #fff;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
}

.button-4:active:before {
  color: #17954c;
}

/* Button 4a */
.button-4a:before {
  left: 130%;
  top: 0;
}

.button-4a:hover:before {
  left: 80%;
}

/* Button 4b */
.button-4b:before {
  left: -50%;
  top: 0;
}

.button-4b:hover:before {
  left: 10%;
}

/* Button 4c */
.button-4c:before {
  left: 70%;
  opacity: 0;
  top: 0;
}

.button-4c:hover:before {
  left: 80%;
  opacity: 1;
}

/* Button 4d */
.button-4d:before {
  left: 30%;
  opacity: 0;
  top: 0;
}

.button-4d:hover:before {
  left: 10%;
  opacity: 1;
}

/* Button 5 */
.button-5 {
  background: #823aa0;
  color: #fff;
  height: 70px;
  min-width: 260px;
  line-height: 24px;
  font-size: 16px;
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  backface-visibility: hidden;
}

.button-5:active {
  background: #9053a9;
  top: 2px;
}

.button-5 span {
  display: inline-block;
  width: 100%;
  height: 100%;
  -webkit-transition: all 0.3s;
  -webkit-backface-visibility: hidden;
  -moz-transition: all 0.3s;
  -moz-backface-visibility: hidden;
  transition: all 0.3s;
  backface-visibility: hidden;
}

.button-5:before {
  position: absolute;
  height: 100%;
  width: 100%;
  line-height: 2.5;
  font-size: 180%;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
}

.button-5:active:before {
  color: #703b87;
}

/* Button 5a */
.button-5a:hover span {
  -webkit-transform: translateY(300%);
  -moz-transform: translateY(300%);
  -ms-transform: translateY(300%);
  transform: translateY(300%);
}

.button-5a:before {
  left: 0;
  top: -100%;
}

.button-5a:hover:before {
  top: 0;
}

/* Button 5b */
.button-5b:hover span {
  -webkit-transform: translateX(200%);
  -moz-transform: translateX(200%);
  -ms-transform: translateX(200%);
  transform: translateX(200%);
}

.button-5b:before {
  left: -100%;
  top: 0;
}

.button-5b:hover:before {
  left: 0;
}

/* Button 6 */
.button-6 {
  color: #fff;
  background: #226fbe;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-6:active {
  top: 2px;
}

/* Button 6a */
.button-6a {
  border: 4px solid #226fbe;
}

.button-6a:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6b */
.button-6b {
  border: 4px solid #226fbe;
  border-radius: 15px;
}

.button-6b:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6c */
.button-6c {
  border: 4px solid #226fbe;
  border-radius: 60px;
}

.button-6c:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6d */
.button-6d {
  border: 2px dashed #226fbe;
}

.button-6d:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6e */
.button-6e {
  border: 2px dashed #226fbe;
  border-radius: 15px;
}

.button-6e:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6f */
.button-6f {
  border: 2px dashed #226fbe;
  border-radius: 60px;
}

.button-6f:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6g */
.button-6g {
  border: 2px dotted #226fbe;
}

.button-6g:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6h */
.button-6h {
  border: 2px dotted #226fbe;
  border-radius: 15px;
}

.button-6h:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6i */
.button-6i {
  border: 2px dotted #226fbe;
  border-radius: 60px;
}

.button-6i:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6j */
.button-6j {
  border: 4px double #226fbe;
}

.button-6j:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6k */
.button-6k {
  border: 4px double #226fbe;
  border-radius: 15px;
}

.button-6k:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 6l */
.button-6l {
  border: 4px double #226fbe;
  border-radius: 60px;
}

.button-6l:hover {
  background: transparent;
  color: #226fbe;
}

/* Button 7 */
.button-7 {
  background: #17aa56;
  color: #fff;
  border-radius: 7px;
  box-shadow: 0 5px #119e4d;
  padding: 25px 60px 25px 90px;
}

/* Button 7a */
.button-7a {
  overflow: hidden;
}

.button-7a:before {
  position: absolute;
  left: 0;
  width: 40%;
  font-size: 160%;
  line-height: 0.8;
  color: #0a833d;
}

.button-7a.button-activated {
  -webkit-animation: fadeOutText 0.5s;
  -moz-animation: fadeOutText 0.5s;
  animation: fadeOutText 0.5s;
}

.button-7a.button-activated:before {
  -webkit-animation: moveToRight 0.5s;
  -moz-animation: moveToRight 0.5s;
  animation: moveToRight 0.5s;
}

@-webkit-keyframes fadeOutText {
  0% {
    color: transparent;
  }

  80% {
    color: transparent;
  }

  100% {
    color: #fff;
  }
}

@-moz-keyframes fadeOutText {
  0% {
    color: transparent;
  }

  80% {
    color: transparent;
  }

  100% {
    color: #fff;
  }
}

@keyframes fadeOutText {
  0% {
    color: transparent;
  }

  80% {
    color: transparent;
  }

  100% {
    color: #fff;
  }
}

@-webkit-keyframes moveToRight {
  80% {
    -webkit-transform: translateX(250%);
  }

  81% {
    opacity: 1;
    -webkit-transform: translateX(250%);
  }

  82% {
    opacity: 0;
    -webkit-transform: translateX(250%);
  }

  83% {
    opacity: 0;
    -webkit-transform: translateX(-50%);
  }

  84% {
    opacity: 1;
    -webkit-transform: translateX(-50%);
  }

  100% {
    -webkit-transform: translateX(0%);
  }
}

@-moz-keyframes moveToRight {
  80% {
    -moz-transform: translateX(250%);
  }

  81% {
    opacity: 1;
    -moz-transform: translateX(250%);
  }

  82% {
    opacity: 0;
    -moz-transform: translateX(250%);
  }

  83% {
    opacity: 0;
    -moz-transform: translateX(-50%);
  }

  84% {
    opacity: 1;
    -moz-transform: translateX(-50%);
  }

  100% {
    -moz-transform: translateX(0%);
  }
}

@keyframes moveToRight {
  80% {
    transform: translateX(250%);
  }

  81% {
    opacity: 1;
    transform: translateX(250%);
  }

  82% {
    opacity: 0;
    transform: translateX(250%);
  }

  83% {
    opacity: 0;
    transform: translateX(-50%);
  }

  84% {
    opacity: 1;
    transform: translateX(-50%);
  }

  100% {
    transform: translateX(0%);
  }
}

/* Button 7b */
.button-7b {
  overflow: hidden;
}

.button-7b:before {
  position: absolute;
  left: 0;
  width: 40%;
  font-size: 160%;
  line-height: 0.8;
  color: #0a833d;
}

.button-7b.button-activated:before {
  -webkit-animation: scaleUp 0.5s;
  -moz-animation: scaleUp 0.5s;
  animation: scaleUp 0.5s;
}

@-webkit-keyframes scaleUp {
  80% {
    opacity: 0;
    -webkit-transform: scale(2);
  }

  100% {
    opacity: 0;
    -webkit-transform: scale(2);
  }
}

@-moz-keyframes scaleUp {
  80% {
    opacity: 0;
    -moz-transform: scale(2);
  }

  100% {
    opacity: 0;
    -moz-transform: scale(2);
  }
}

@keyframes scaleUp {
  80% {
    opacity: 0;
    transform: scale(2);
  }

  100% {
    opacity: 0;
    transform: scale(2);
  }
}

/* Icon only style */
.button-icon-only {
  font-size: 0;
  padding: 25px 30px;
}

.button-icon-only:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-size: 26px;
  line-height: 54px;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Button 7c */
.button-7c {
  overflow: hidden;
}

.button-7c:before {
  color: #fff;
  z-index: 1;
}

.button-7c:after {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  z-index: 0;
  width: 0;
  background: #0a833d;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-7c.button-activated:after {
  -webkit-animation: fillToRight 0.7s forwards;
  -moz-animation: fillToRight 0.7s forwards;
  animation: fillToRight 0.7s forwards;
}

@-webkit-keyframes fillToRight {
  to {
    width: 100%;
  }
}

@-moz-keyframes fillToRight {
  to {
    width: 100%;
  }
}

@keyframes fillToRight {
  to {
    width: 100%;
  }
}

/* Button 7d */
.button-7d {
  overflow: hidden;
}

.button-7d:before {
  color: #fff;
  z-index: 1;
}

.button-7d:after {
  position: absolute;
  top: 0;
  left: 0;
  height: 0;
  width: 100%;
  z-index: 0;
  background: #21bb63;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-7d.button-activated:after {
  -webkit-animation: emptyBottom 0.7s forwards;
  -moz-animation: emptyBottom 0.7s forwards;
  animation: emptyBottom 0.7s forwards;
}

@-webkit-keyframes emptyBottom {
  to {
    height: 100%;
  }
}

@-moz-keyframes emptyBottom {
  to {
    height: 100%;
  }
}

@keyframes emptyBottom {
  to {
    height: 100%;
  }
}

/* Button 7e */
.button-7e:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  font-size: 26px;
  line-height: 54px;
  color: #ea515e;
  -webkit-transform: scale(0);
  -moz-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
  opacity: 0;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-7e.button-activated:after {
  -webkit-animation: scaleFade 0.5s forwards;
  -moz-animation: scaleFade 0.5s forwards;
  animation: scaleFade 0.5s forwards;
}

@-webkit-keyframes scaleFade {
  50% {
    opacity: 1;
    -webkit-transform: scale(1);
  }

  100% {
    opacity: 0;
    -webkit-transform: scale(2.5);
  }
}

@-moz-keyframes scaleFade {
  50% {
    opacity: 1;
    -moz-transform: scale(1);
  }

  100% {
    opacity: 0;
    -moz-transform: scale(2.5);
  }
}

@keyframes scaleFade {
  50% {
    opacity: 1;
    transform: scale(1);
  }

  100% {
    opacity: 0;
    transform: scale(2.5);
  }
}

/* Button 7f */
.button-7f:before {
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: #fff;
}

.button-7f:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  font-size: 26px;
  line-height: 54px;
  color: #ffe44d;
  visibility: hidden;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: #ffe44d;
  -webkit-transform: scale(4);
  -moz-transform: scale(4);
  -ms-transform: scale(4);
  transform: scale(4);
  opacity: 0;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-7f.button-activated:after {
  visibility: visible;
  -webkit-animation: dropDown 0.3s forwards;
  -moz-animation: dropDown 0.3s forwards;
  animation: dropDown 0.3s forwards;
}

@-webkit-keyframes dropDown {
  to {
    opacity: 1;
    -webkit-transform: scale(1);
  }
}

@-moz-keyframes dropDown {
  to {
    opacity: 1;
    -moz-transform: scale(1);
  }
}

@keyframes dropDown {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Button 7g */
.button-7g:after {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 1;
  font-size: 26px;
  line-height: 54px;
  color: #0a833d;
  visibility: hidden;
  -webkit-transform: scale(2);
  -moz-transform: scale(2);
  -ms-transform: scale(2);
  transform: scale(2);
  opacity: 0;
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}

.button-7g.button-activated:after {
  visibility: visible;
  -webkit-animation: dropDownFade 0.5s forwards;
  -moz-animation: dropDownFade 0.5s forwards;
  animation: dropDownFade 0.5s forwards;
}

@-webkit-keyframes dropDownFade {
  50% {
    opacity: 1;
    -webkit-transform: scale(1);
  }

  100% {
    opacity: 0;
    -webkit-transform: scale(1.5);
  }
}

@-moz-keyframes dropDownFade {
  50% {
    opacity: 1;
    -moz-transform: scale(1);
  }

  100% {
    opacity: 0;
    -moz-transform: scale(1.5);
  }
}

@keyframes dropDownFade {
  50% {
    opacity: 1;
    transform: scale(1);
  }

  100% {
    opacity: 0;
    transform: scale(1.5);
  }
}

/* Button 7h */
.button-7h span {
  display: inline-block;
  width: 100%;
}

.button-7h:before {
  position: absolute;
  left: 0;
  width: 40%;
  font-size: 160%;
  line-height: 0.8;
  color: #0a833d;
}

/* Success and error */
.button-success,
.button-error {
  color: transparent;
}

.button-success:after,
.button-error:after {
  z-index: 1;
  color: #fff;
  left: 40%;
}

.button-success:before {
  content: "\e001";
}

.button-success:after {
  content: "Success!";
  -webkit-animation: moveUp 0.5s;
  -moz-animation: moveUp 0.5s;
  animation: moveUp 0.5s;
}

@-webkit-keyframes moveUp {
  0% {
    -webkit-transform: translateY(50%);
    opacity: 0;
  }

  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
  }
}

@-moz-keyframes moveUp {
  0% {
    -moz-transform: translateY(50%);
    opacity: 0;
  }

  100% {
    opacity: 1;
    -moz-transform: translateY(0);
  }
}

@keyframes moveUp {
  0% {
    transform: translateY(50%);
    opacity: 0;
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.button-error {
  -webkit-animation: shake 0.5s;
  -moz-animation: shake 0.5s;
  animation: shake 0.5s;
}

/* From Dan Eden's animate.css: http://daneden.me/animate/ */
@-webkit-keyframes shake {
  0%, 100% {
    -webkit-transform: translateX(0);
  }

  10%, 30%, 50%, 70%, 90% {
    -webkit-transform: translateX(-10px);
  }

  20%, 40%, 60%, 80% {
    -webkit-transform: translateX(10px);
  }
}

@-moz-keyframes shake {
  0%, 100% {
    -moz-transform: translateX(0);
  }

  10%, 30%, 50%, 70%, 90% {
    -moz-transform: translateX(-10px);
  }

  20%, 40%, 60%, 80% {
    -moz-transform: translateX(10px);
  }
}

@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }

  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-10px);
  }

  20%, 40%, 60%, 80% {
    transform: translateX(10px);
  }
}

.button-error:before {
  content: "\e002";
}

.button-error:after {
  content: "Error!";
  -webkit-animation: scaleFromUp 0.5s;
  -moz-animation: scaleFromUp 0.5s;
  animation: scaleFromUp 0.5s;
}

@-webkit-keyframes scaleFromUp {
  0% {
    -webkit-transform: scale(0);
    opacity: 0;
  }

  100% {
    opacity: 1;
    -webkit-transform: scale(1);
  }
}

@-moz-keyframes scaleFromUp {
  0% {
    -moz-transform: scale(0);
    opacity: 0;
  }

  100% {
    opacity: 1;
    -moz-transform: scale(1);
  }
}

@keyframes scaleFromUp {
  0% {
    transform: scale(0);
    opacity: 0;
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* Special trash effect */
.trash-effect {
  position: relative;
  max-width: 320px;
  margin: 60px auto 0;
}

.trash-effect .icon-file {
  font-size: 30px;
  position: absolute;
  width: 50px;
  height: 50px;
  left: 50%;
  top: 50%;
  margin: -45px 0 0 -25px;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  -webkit-transform: translateX(90px) translateY(20px) scale(1);
  -moz-transform: translateX(90px) translateY(20px) scale(1);
  -ms-transform: translateX(90px) translateY(20px) scale(1);
  transform: translateX(90px) translateY(20px) scale(1);
}

.trash-effect .icon-file:nth-child(2) {
  -webkit-transform: translateX(140px) translateY(-10px) scale(1);
  -moz-transform: translateX(140px) translateY(-10px) scale(1);
  -ms-transform: translateX(140px) translateY(-10px) scale(1);
  transform: translateX(140px) translateY(-10px) scale(1);
  -webkit-transition-delay: 0.1s;
  -moz-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.trash-effect .icon-file:nth-child(3) {
  -webkit-transform: translateX(140px) translateY(50px) scale(1);
  -moz-transform: translateX(140px) translateY(50px) scale(1);
  -ms-transform: translateX(140px) translateY(50px) scale(1);
  transform: translateX(140px) translateY(50px) scale(1);
  -webkit-transition-delay: 0.2s;
  -moz-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.trash-effect.trash-effect-active .icon-file {
  -webkit-transform: translateX(-100px) translateY(-10px) scale(0);
  -moz-transform: translateX(-100px) translateY(-10px) scale(0);
  -ms-transform: translateX(-100px) translateY(-10px) scale(0);
  transform: translateX(-100px) translateY(-10px) scale(0);
}

/* Button 7i */
.button-7i {
  box-shadow: none;
  border-radius: 0 0 7px 7px;
  padding: 27px 33px;
  -webkit-transform: translateX(-100px);
  -moz-transform: translateX(-100px);
  -ms-transform: translateX(-100px);
  transform: translateX(-100px);
}

.button-7i:before {
  line-height: 45px;
}

.button-7i:after {
  height: 11px;
  /* should be 10px but in Chrome Version 34.0.1847.131 there's a gap because of the transform of the button */
  width: 100%;
  background: #17aa56;
  border-radius: 7px 7px 0 0;
  left: 0;
  top: -10px;
  z-index: 1;
  -webkit-transform-origin: 0 100%;
  -moz-transform-origin: 0 100%;
  -ms-transform-origin: 0 100%;
  transform-origin: 0 100%;
}

.trash-effect-active .button-7i:after {
  -webkit-animation: openTrash 0.5s;
  -moz-animation: openTrash 0.5s;
  animation: openTrash 0.5s;
}

@-webkit-keyframes openTrash {
  50% {
    -webkit-transform: rotate(-35deg);
  }

  100% {
    -webkit-transform: rotate(0deg);
  }
}

@-moz-keyframes openTrash {
  50% {
    -moz-transform: rotate(-35deg);
  }

  100% {
    -moz-transform: rotate(0deg);
  }
}

@keyframes openTrash {
  50% {
    transform: rotate(-35deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

/* Button 8 */
.perspective {
  -webkit-perspective: 800px;
  -moz-perspective: 800px;
  perspective: 800px;
  display: inline-block;
}

.button-8 {
  display: block;
  background: #5cbcf6;
  outline: 1px solid transparent;
  /* FF jagged edges fix */
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
  transform-style: preserve-3d;
}

.button-8:active {
  background: #55b7f3;
}

/* Button 8a */
.button-8a:after {
  width: 100%;
  height: 42%;
  /* should be 40% but there's a gap in Chrome Version 34.0.1847.131 */
  left: 0;
  top: -40%;
  background: #49a7df;
  -webkit-transform-origin: 0% 100%;
  -webkit-transform: rotateX(90deg);
  -moz-transform-origin: 0% 100%;
  -moz-transform: rotateX(90deg);
  transform-origin: 0% 100%;
  transform: rotateX(90deg);
}

.button-8a:hover {
  -webkit-transform: rotateX(-15deg);
  -moz-transform: rotateX(-15deg);
  -ms-transform: rotateX(-15deg);
  transform: rotateX(-15deg);
}

/* Button 8b */
.button-8b:after {
  width: 100%;
  height: 40%;
  left: 0;
  top: 100%;
  background: #49a7df;
  -webkit-transform-origin: 0% 0%;
  -webkit-transform: rotateX(-90deg);
  -moz-transform-origin: 0% 0%;
  -moz-transform: rotateX(-90deg);
  -ms-transform-origin: 0% 0%;
  -ms-transform: rotateX(-90deg);
  transform-origin: 0% 0%;
  transform: rotateX(-90deg);
}

.button-8b:hover {
  -webkit-transform: rotateX(15deg);
  -moz-transform: rotateX(15deg);
  -ms-transform: rotateX(15deg);
  transform: rotateX(15deg);
}

/* Button 8c */
.button-8c:after {
  width: 21%;
  /* should be 20% but there's a gap in Chrome Version 34.0.1847.131 */
  height: 100%;
  left: -20%;
  top: 0;
  background: #49a7df;
  -webkit-transform-origin: 100% 0%;
  -webkit-transform: rotateY(-90deg);
  -moz-transform-origin: 100% 0%;
  -moz-transform: rotateY(-90deg);
  -ms-transform-origin: 100% 0%;
  -ms-transform: rotateY(-90deg);
  transform-origin: 100% 0%;
  transform: rotateY(-90deg);
}

.button-8c:hover {
  -webkit-transform: rotateY(15deg);
  -moz-transform: rotateY(15deg);
  -ms-transform: rotateY(15deg);
  transform: rotateY(15deg);
}

/* Button 8d */
.button-8d:after {
  width: 20%;
  height: 100%;
  left: 100%;
  top: 0;
  background: #49a7df;
  -webkit-transform-origin: 0% 0%;
  -webkit-transform: rotateY(90deg);
  -moz-transform-origin: 0% 0%;
  -moz-transform: rotateY(90deg);
  -ms-transform-origin: 0% 0%;
  -ms-transform: rotateY(90deg);
  transform-origin: 0% 0%;
  transform: rotateY(90deg);
}

.button-8d:hover {
  -webkit-transform: rotateY(-15deg);
  -moz-transform: rotateY(-15deg);
  -ms-transform: rotateY(-15deg);
  transform: rotateY(-15deg);
}

/* Button 8e */
.button-8e {
  -webkit-transform: rotateX(-15deg);
  -moz-transform: rotateX(-15deg);
  -ms-transform: rotateX(-15deg);
  transform: rotateX(-15deg);
}

.button-8e:after {
  width: 100%;
  height: 42%;
  /* should be 40% but there's a gap in Chrome Version 34.0.1847.131 */
  left: 0;
  top: -40%;
  background: #49a7df;
  -webkit-transform-origin: 0% 100%;
  -webkit-transform: rotateX(90deg);
  -moz-transform-origin: 0% 100%;
  -moz-transform: rotateX(90deg);
  -ms-transform-origin: 0% 100%;
  -ms-transform: rotateX(90deg);
  transform-origin: 0% 100%;
  transform: rotateX(90deg);
}

.button-8e:active {
  -webkit-transform: rotateX(0deg);
  -moz-transform: rotateX(0deg);
  -ms-transform: rotateX(0deg);
  transform: rotateX(0deg);
}

/* Button 8f */
.button-8f {
  -webkit-transform: rotateX(15deg);
  -moz-transform: rotateX(15deg);
  -ms-transform: rotateX(15deg);
  transform: rotateX(15deg);
}

.button-8f:after {
  width: 100%;
  height: 40%;
  left: 0;
  top: 100%;
  background: #49a7df;
  -webkit-transform-origin: 0% 0%;
  -webkit-transform: rotateX(-90deg);
  -moz-transform-origin: 0% 0%;
  -moz-transform: rotateX(-90deg);
  -ms-transform-origin: 0% 0%;
  -ms-transform: rotateX(-90deg);
  transform-origin: 0% 0%;
  transform: rotateX(-90deg);
}

.button-8f:active {
  -webkit-transform: rotateX(0deg);
  -moz-transform: rotateX(0deg);
  -ms-transform: rotateX(0deg);
  transform: rotateX(0deg);
}

/* Button 8g */
.button-8g {
  background: #fff;
  color: #999;
}

.button-8g:active {
  background: #fff;
}

.button-8g:after,
.button-8g:before {
  text-transform: uppercase;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  line-height: 70px;
}

.button-8g:after {
  top: -98%;
  /* should be -100% but there's a gap in Chrome Version 34.0.1847.131 */
  background: #7aca7c;
  color: #358337;
  content: 'It worked!';
  -webkit-transform-origin: 0% 100%;
  -webkit-transform: rotateX(90deg);
  -moz-transform-origin: 0% 100%;
  -moz-transform: rotateX(90deg);
  -ms-transform-origin: 0% 100%;
  -ms-transform: rotateX(90deg);
  transform-origin: 0% 100%;
  transform: rotateX(90deg);
}

.button-8g:before {
  top: 100%;
  background: #e96a6a;
  color: #a33a3a;
  content: 'Error!';
  font-weight: 700;
  font-family: 'Lato', Calibri, Arial, sans-serif;
  -webkit-transform-origin: 0% 0%;
  -webkit-transform: rotateX(-90deg);
  -moz-transform-origin: 0% 0%;
  -moz-transform: rotateX(-90deg);
  -ms-transform-origin: 0% 0%;
  -ms-transform: rotateX(-90deg);
  transform-origin: 0% 0%;
  transform: rotateX(-90deg);
}

.button-8g.button-success3d {
  background: #aaa;
  -webkit-transform-origin: 50% 100%;
  -webkit-transform: rotateX(-90deg) translateY(100%);
  -moz-transform-origin: 50% 100%;
  -moz-transform: rotateX(-90deg) translateY(100%);
  -ms-transform-origin: 50% 100%;
  -ms-transform: rotateX(-90deg) translateY(100%);
  transform-origin: 50% 100%;
  transform: rotateX(-90deg) translateY(100%);
}

.button-8g.button-error3d {
  background: #aaa;
  -webkit-transform-origin: 50% 0%;
  -webkit-transform: rotateX(90deg) translateY(-100%);
  -moz-transform-origin: 50% 0%;
  -moz-transform: rotateX(90deg) translateY(-100%);
  -ms-transform-origin: 50% 0%;
  -ms-transform: rotateX(90deg) translateY(-100%);
  transform-origin: 50% 0%;
  transform: rotateX(90deg) translateY(-100%);
}
