Edit in JSFiddle

.wrap {
  margin: 2em 3em;
  position: relative;
  border: 1px solid #ccc;
  height: 200px;
  display: inline-block;
  width: 200px;
  white-space: nowrap;
}

.ori,
.trans {
  width: 150px;
  height: 100px;
  border: 1px solid #7a0006;
  background: #cf0009;
  left: 50%;
  top: 50px;
  margin-left: -75px;
  position: absolute;
}

.ori {
  z-index: 0;
  opacity: 0.1;
}

.trans {
  z-index: 10;
  opacity: 0.5;
  background-color: #1564cf;
  transition: transform 1s;
}

.translate:hover {
  transform: translate(50px, -20px);
}

.translateX:hover {
  transform: translateX(50%);
}

.translateY:hover {
  transform: translateY(-100%);
}
<!DOCTYPE html>
<html lang="ko">
  <head></head>
  <body>
    <div class="wrap">
      translate(50px,-20px)
      <div class="ori"></div>
      <div class="trans translate">translate(50px,-20px)</div>
    </div>
    <div class="wrap">
      translateX(50%)
      <div class="ori"></div>
      <div class="trans translateX">translateX(50%)</div>
    </div>
    <div class="wrap">
      translateY(-100%)
      <div class="ori"></div>
      <div class="trans translateY">translateY(100%)</div>
    </div>
  </body>
</html>