/* LOGIN */
.page-login {
  background: #fff;
  width: 100%;
  overflow: hidden;
}
.login-cover {
  position: relative;
  min-height: 100vh;
}
.login-cover img.cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  object-position: center center;
}
.login-cover:before {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(51, 51, 51, 0) 0%, #212121 100%);
  z-index: 2;
}
.login-cover .caption {
  position: relative;
  z-index: 3;
  padding: 40px;
}
.login-cover .caption h3 {
  font-size: 2rem;
}
@media (max-width: 800px) {
  .page-login {
    overflow: auto;
  }
}

/* layout tweaks for the login form column */
.login-box .container-tight {
  max-width: 420px;
}
.login-box {
  padding: 40px 30px;
}

/* Prototype class aliases: support `.loginbox` and `.box` used by original prototype markup */
.loginbox .box {
  max-width: 420px;
  margin: 0 auto;
}
.loginbox {
  padding: 40px 30px;
}
.loginbox .box {
  max-width: 520px;
  margin: 0 auto;
  padding: 22px;
  background: transparent;
}
.loginbox {
  padding: 48px 40px;
}
.loginbox .box p {
  margin-bottom: 0.9rem;
}

/* make form controls full-width and comfortable */
.loginbox .box .form-control {
  width: 100%;
  box-sizing: border-box;
}
.loginbox .box .btn {
  min-height: 50px;
}
