html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  background: #f4f7fb;
  overflow-wrap: anywhere;
}

.site-shell {
  min-height: 100vh;
  padding: 32px 16px;
}

.form-card {
  max-width: 820px;
  margin: 0 auto;
  border: 0;
  border-radius: 1.25rem;
  box-shadow: 0 1.5rem 3rem rgba(15, 23, 42, 0.12);
}

.site-header {
  padding-bottom: 0.25rem;
}

.site-logo-link {
  line-height: 0;
}

.site-logo {
  display: block;
  max-width: min(280px, 100%);
  width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

.site-footer {
  color: #6c757d;
  font-size: 0.875rem;
}

.site-footer-line {
  margin-bottom: 0.35rem;
}

.brand-kicker {
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: #0d6efd;
}

.form-intro {
  color: #5f6b7a;
  font-size: 1.05rem;
}

.required-note {
  font-size: 0.875rem;
  color: #6c757d;
}

textarea.form-control {
  min-height: 130px;
}

.footer-note {
  color: #6c757d;
  font-size: 0.9rem;
}

.btn-lg {
  padding-top: 0.9rem;
  padding-bottom: 0.9rem;
}

@media (max-width: 575.98px) {
  .site-shell {
    padding: 18px 10px;
  }

  .form-card .card-body {
    padding: 1.25rem;
  }

  h1 {
    font-size: 2rem;
  }

  /* Outranks Bootstrap .display-5 so the home hero scales on narrow screens */
  h1.display-5 {
    font-size: 2rem;
    line-height: 1.2;
  }

  .brand-kicker {
    font-size: 0.72rem;
    letter-spacing: 0.05em;
  }

  .site-header {
    padding-left: 0.125rem;
    padding-right: 0.125rem;
  }
}
