.jkeyboard {
  display: inline-block;
}
.jkeyboard, .jkeyboard .jline, .jkeyboard .jline ul {
  display: block;
  margin: 0;
  padding: 0;
}
.jkeyboard .jline {
  text-align: center;
  border-bottom: none;
  line-height: 0;
}
.jkeyboard .jline ul li {
  font-family: 'Open Sans', arial;;
  font-size: 12px;
  font-weight: bold;
  display: inline-block;
  border: 1px solid #ccc;
  -webkit-box-shadow: 0 0 3px #ccc;
  -webkit-box-shadow: inset 0 0 3px #ccc;
  margin: 2px;
  color: #333;
  border-radius: 4px;
  width: 29px;
  height: 29px;
  box-sizing: border-box;
  text-align: center;
  line-height: 27px;
  overflow: hidden;
  cursor: pointer;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: -moz-none;
  -ms-user-select: none;
  user-select: none;
}
.jkeyboard .jline ul li.uppercase {
  text-transform: uppercase;
}
.jkeyboard .jline ul li:hover, .jkeyboard .jline ul li:active {
  background-color: #e6e6e6;
  color: #222;
}
.jkeyboard .jline .return {
  width: 60px;
}
.jkeyboard .jline .space {
  width: 256px;
}
.jkeyboard .jline .numeric_switch {
  width: 34px;
}
.jkeyboard .jline .layout_switch {
  background: url("../assets/locale.png") no-repeat center center;
  background-size: 17px;
}
.jkeyboard .jline .shift {
  width: 50px;
  background: url("../assets/shift.png") no-repeat center center;
  background-size: 24px;
}
.jkeyboard .jline .backspace {
  width: 50px;
  background: url("../assets/backspace.png") no-repeat center center;
  background-size: 17px;
}

.keyboard_off_img {
  opacity: 0.5;
}
