.lf-wrap {
  width: 100%;
}

.lf-alert {
  padding: 10px 12px;
  border-radius: 10px;
  margin: 0px 0px 16px;
}

.lf-alert--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

/* Role selector block (fieldset) */
.lf-role {
  border: 0;
  padding: 0;
  margin: 0px 0px 0px 0px;
}

/* Heading "Select Role" */
.lf-role__label {
  display: block;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.3;
  color: #0b3b8c;
  margin: 0px 0px 0px 0px;
}

/* Each option on its own row with normal font weight */
.lf-role__option {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0px 0px 0px;
  font-weight: 400;
  color: inherit;
  width: 100%;
}

/* Radio appearance */
.lf-role__option input[type="radio"] {
  width: 16px;
  height: 16px;
  accent-color: #0b3b8c;
  cursor: pointer;
}

.lf-role__option span {
  cursor: pointer;
}

/* Labels & Inputs */
.lf-label {
  display: block;
  font-weight: 600;
  margin: 22px 0 8px;
}

.lf-input {
  width: 100%;
  border: none;
  border-bottom: 1px solid #d1d5db;
  background: transparent;
  padding: 12px 2px 10px;
  outline: none;
  font-size: 16px;
}

.lf-input:focus {
  border-bottom-color: #111111;
}

/* Button */
.lf-btn {
  display: block;
  width: 100%;
  margin: 28px 0 0;
  padding: 14px 16px;
  background: #0a0a0a;
  color: #ffffff;
  border: none;
  border-radius: 2px;
  font-weight: 600;
  cursor: pointer;
}

.lf-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Row under the button */
.lf-row-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 20px 0 0;
  gap: 12px;
  flex-wrap: wrap;
}

.lf-remember {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.lf-forgot {
  color: #0a0a0a;
  text-decoration: underline;
  font-weight: 400 !important;
}
