body#loginpage,
body.loginpage {
  min-height: 100vh;
  margin: 0;
  padding: 32px 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(180deg, #f7f9fc 0%, #e8eef8 100%);
  text-align: center;
}

#logincontainer {
  width: 100%;
  max-width: 440px;
  text-transform: none !important;
}

.toschke-brand {
  margin-bottom: 40px;
}

.toschke-brand .crest {
  height: 180px;
  width: auto;
  display: block;
  margin: 0 auto 12px auto;
}

.toschke-brand .brand-title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 42px;
  line-height: 1.05;
  color: #0b2447;
}

.toschke-brand .brand-subtitle {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 30px;
  letter-spacing: 6px;
  color: #19376d;
  margin-bottom: 50px;
}

.form-signin {
  width: 420px;
  max-width: 100%;
  margin: 0 auto;
  padding: 32px 28px;
  border: 0;
  border-radius: 20px;
  box-shadow: 0 24px 60px rgba(11, 36, 71, 0.18);
  text-align: left;
}

.form-signin h2 {
  font-weight: 400;
  text-transform: none;
  text-align: center;
  margin-bottom: 24px;
}

.form-signin .btn {
  border-radius: 999px;
}

.compatibility {
  max-width: 420px;
  margin: 16px auto 0;
}

@media (prefers-color-scheme: dark) {
  body#loginpage,
  body.loginpage {
    background: linear-gradient(180deg, #0b2447 0%, #19376d 100%);
  }

  .toschke-brand .brand-title,
  .toschke-brand .brand-subtitle {
    color: #f4f7fb;
  }
}

@media (max-width: 576px) {
  body#loginpage,
  body.loginpage {
    padding: 24px 12px;
  }

  .toschke-brand {
    margin-bottom: 28px;
  }

  .toschke-brand .crest {
    height: 144px;
  }

  .toschke-brand .brand-title {
    font-size: 34px;
  }

  .toschke-brand .brand-subtitle {
    font-size: 24px;
    letter-spacing: 4px;
    margin-bottom: 36px;
  }

  .form-signin {
    padding: 24px 20px;
  }
}
