.buttonModel {
  padding: 7px 10px;
  border: unset;
  border-radius: 15px;
  color: #d0d0d0;
  z-index: 1;
  background: #e8e8e8;
  position: relative;
  font-weight: 1000;
  font-size: 12px;
  -webkit-box-shadow: 4px 8px 19px -3px rgba(196, 196, 196, 0.27);
  box-shadow: 4px 8px 19px -3px rgba(0, 0, 0, 0.27);
  transition: all 250ms;
  overflow: hidden;
}
.buttonModel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  border-radius: 15px;
  background-color: #979797;
  z-index: -1;
  -webkit-box-shadow: 4px 8px 19px -3px rgba(39, 39, 39, 0.27);
  box-shadow: 4px 8px 19px -3px rgba(39, 38, 38, 0.27);
  transition: all 250ms;
}
.buttonModel:hover {
  color: #e8e8e8;
}

.buttonModel:hover::before {
  width: 100%;
}
