html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin: 0;
  background: linear-gradient(180deg, #f5f8fc 0%, #eef3f9 100%);
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

.form-control::placeholder,
textarea.form-control::placeholder {
  color: #8b97a6;
  font-style: italic;
  font-weight: 500;
  opacity: 1;
}

.form-control:placeholder-shown,
.form-select {
  background-color: #f9fbff;
}

.form-label {
  color: #2a3d52;
  font-weight: 500;
}

.report-shell {
  max-width: 980px;
  margin: 0 auto;
}

.main-shell {
  min-height: calc(100vh - 72px);
  display: block;
  padding: 1rem 1rem 2rem;
}

.landing-shell {
  max-width: 900px;
  margin: 2rem auto 0;
}

.required-dot {
  color: #b42318;
  font-weight: 700;
  margin-left: 0.25rem;
}

.required-block .required-field::after {
  content: " required";
  color: #6b7280;
  font-size: 0.72rem;
  font-weight: 500;
  margin-left: 0.35rem;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.accordion-button:not(.collapsed) {
  background-color: #e8f1ff;
  color: #123b67;
}

.env-banner {
  position: sticky;
  top: 0;
  z-index: 3;
  width: 100%;
  text-align: center;
  border-bottom: 1px solid transparent;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 0.42rem 0.8rem;
  backdrop-filter: blur(8px) saturate(130%);
  -webkit-backdrop-filter: blur(8px) saturate(130%);
}

.env-banner__label {
  display: inline-block;
}

.env-banner--staging {
  color: #6c5a08;
  background: rgba(255, 245, 191, 0.88);
  border-bottom-color: rgba(150, 129, 34, 0.35);
}

.env-banner--development {
  color: #fff0f0;
  background: rgba(146, 32, 32, 0.9);
  border-bottom-color: rgba(255, 162, 162, 0.35);
}

.env-banner--default {
  color: #d9e3f0;
  background: rgba(26, 36, 52, 0.88);
  border-bottom-color: rgba(190, 209, 233, 0.3);
}
