@import url(//fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900);
@import url(//fonts.googleapis.com/css?family=Open+Sans%3A300%2C400%2C400italic%2C500%2C600%2C700%2C700%2C800&amp;ver=3.8.5);

body {
  font-family: "Open Sans", "Roboto", "Helvetica Neue", Helvetica, Arial,
    sans-serif;
}

#login-wrap {
  position: absolute;
  left: 0;
  right: 0;
  margin-top: 50vh; /* poussé de la moitié de hauteur de viewport */
  transform: translateY(-50%); /* tiré de la moitié de sa propre hauteur */
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus {
  border-radius: 4px;
  background-color: #fe3466;
  border: transparent;
  color: #ffffff;
  letter-spacing: 3pt !important;
}

.btn-primary:hover,
.btn-primary:focus {
  opacity: 0.9;
}

.card-login {
  background-color: #f7f7f7;
  -moz-box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
  -webkit-box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
  max-width: 500px;
}

.card-login > .card-title {
  padding: 10px 15px;
  border-bottom: 1px solid transparent;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  letter-spacing: 3pt !important;
  font-weight: 500 !important;
  text-align: center;
  font-size: 11pt;
  background-color: #333;
  color: #fff;
}
