.auth-ui-header .ham-menu-bg {
  display: none !important;
}

.password-input-unique-id-wrapper .show-hide__button {
  top: 0.1875rem;
  color: #0a41c5;
}

.usb--wrapper:focus-within:after {
  content: "";
  border: 2px solid #235ae4;
  border-radius: 0.25rem;
  height: calc(100% + 0.75rem);
  position: absolute;
  left: -0.375rem;
  top: -0.375rem;
  width: calc(100% + 0.75rem);
  z-index: -1;
}

.usb--wrapper:focus-within label,
.usb--wrapper:focus-within.is-value label {
  color: #66666a;
  font-family: Circular-USB, sans-serif;
  font-weight: 400;
  font-size: 0.75rem;
  line-height: 1.5;
  top: 0;
}

.usb--wrapper:focus-within .usb--basic-input {
  outline: transparent;
  border-top: 0 solid #235ae4;
  border-right: 0 solid #235ae4;
  border-bottom: 1px solid #235ae4;
  border-left: 0 solid #235ae4;
}

.usb--wrapper:focus-within.is-value .usb--basic-input {
  border-bottom-width: 2px;
  color: #4c4c50;
}

.password-input-unique-id-wrapper:focus-within .show-hide__button {
  color: #0a41c5;
}

.otp-page-desc {
  color: #63637f;
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0 0 1.25rem;
  max-width: 26rem;
}

.otp-digit-row {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-start;
  max-width: 22rem;
  margin: 0 0 1.5rem;
  flex-wrap: nowrap;
}

.otp-digit {
  width: 2.625rem;
  height: 2.875rem;
  text-align: center;
  font-size: 1.25rem;
  border: 1px solid #cdcdd3;
  border-radius: 0.25rem;
  font-family: inherit;
  color: #2e2e32;
  background: #fff;
  box-sizing: border-box;
  padding: 0;
}

.otp-digit:focus {
  outline: 2px solid #235ae4;
  outline-offset: 1px;
  border-color: #235ae4;
}

.otp-back-wrap {
  margin-top: 1rem;
}

#otp-resend,
.flow-resend {
  display: inline-block;
  margin-top: 0.75rem;
  cursor: pointer;
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  text-align: left;
}

.otp-info {
  margin: 0 0 1.25rem;
  max-width: 26rem;
  color: #2e2e32;
  font-size: 0.9375rem;
  line-height: 1.5;
}

.otp-info strong {
  display: block;
  font-size: 1.125rem;
  font-weight: 600;
  color: #0a0a0a;
  margin-bottom: 0.375rem;
}

.otp-info-detail {
  display: block;
  color: #63637f;
}

.complete-step-inner {
  text-align: center;
  max-width: 28rem;
  margin-left: auto;
  margin-right: auto;
}

#step-complete .aw-usb-authenticate {
  width: 100%;
}

#step-complete .aw-usb-authenticate > .fdicdisclosure {
  width: 100%;
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
}

#step-complete .aw-usb-authenticate > div:not(.fdicdisclosure) {
  width: 100%;
}

#step-complete .complete-inner.complete-step-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 28rem;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

#step-complete .complete-inner.complete-step-inner > * {
  max-width: 100%;
}

#step-complete .complete-title-text,
#step-complete #complete-title {
  text-align: center;
  width: 100%;
}

#step-complete .flow-page-desc,
#step-complete .complete-msg,
#step-complete .complete-footnote,
#step-complete .complete-timer {
  text-align: center;
  width: 100%;
}

#step-complete .auth-continue-button-align {
  display: flex;
  justify-content: center;
  width: 100%;
}

#step-complete .auth-continue-button-align a.usb-button,
#step-complete .complete-actions a.usb-button {
  margin-left: auto;
  margin-right: auto;
}

#step-complete .flow-back-wrap {
  text-align: center;
  width: 100%;
}

#step-complete #ReactLoginWidgetApp.login-widget {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 48vh;
}

.usb-complete-icon {
  width: 4rem;
  height: 4rem;
  margin: 0 auto 1.25rem;
  border-radius: 50%;
  background: #e8f5e9;
  color: #1b5e20;
  display: flex;
  align-items: center;
  justify-content: center;
}

.usb-complete-check {
  width: 2rem;
  height: 2rem;
}

.complete-title-text {
  margin: 0 0 0.75rem;
  font-size: 1.5rem;
  font-weight: 600;
  color: #0a0a0a;
}

.complete-footnote {
  color: #63637f;
  font-size: 0.8125rem;
  line-height: 1.45;
  margin: 0 0 1.25rem;
  max-width: 24rem;
  margin-left: auto;
  margin-right: auto;
}

#step-complete .complete-msg {
  margin-left: auto;
  margin-right: auto;
}

.complete-timer {
  font-size: 0.9375rem;
  color: #2e2e32;
  font-weight: 500;
  line-height: 1.5;
  margin: 0 auto 1rem;
  max-width: 24rem;
}

.complete-timer #redirectSeconds,
.complete-timer #redirectUnit {
  font-variant-numeric: tabular-nums;
}

.complete-actions {
  margin-top: 0.5rem;
}

#step-card .card-step-intro {
  margin: 0 0 1.25rem;
  max-width: 26rem;
  color: #2e2e32;
  font-size: 0.9375rem;
  line-height: 1.5;
}

#step-card .card-step-intro strong {
  display: block;
  font-size: 1.125rem;
  font-weight: 600;
  color: #0a0a0a;
  margin-bottom: 0.375rem;
}

.card-step-detail {
  display: block;
  color: #63637f;
}

#step-billing .card-step-intro {
  margin-bottom: 1.625rem;
}

.card-row-2 .card-cvv-wrap {
  flex: 1 1 8rem;
  min-width: 7rem;
}

#step-card .card-input-stack {
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
  width: 100%;
  max-width: 26rem;
  margin-bottom: 0.25rem;
}

#step-card .card-input-stack > .usb--wrapper#wrapper_card_number {
  width: 100%;
  margin-bottom: 0;
}

#step-card .card-row-2 {
  align-items: flex-start;
  width: 100%;
  margin-bottom: 0;
  gap: 1rem 1.25rem;
}

#step-card .card-atm-pin-wrap {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-top: 0.125rem;
}

#step-card .card-atm-pin-wrap .password-input-unique-id-wrapper {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  width: 100%;
  gap: 0.25rem;
}

#step-card .card-atm-pin-wrap .usb--wrapper {
  flex: 1 1 auto;
  min-width: 0;
  width: 1%;
}

#step-card .card-atm-pin-wrap .show-hide__button {
  flex: 0 0 auto;
  align-self: flex-end;
  margin-bottom: 0.125rem;
  white-space: nowrap;
}

.flow-otp-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.resend-row {
  margin-top: 0.25rem;
}

.flow-page-desc {
  color: #63637f;
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0 0 1.25rem;
  max-width: 26rem;
}

.card-row-2 {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  margin-bottom: 0.5rem;
}

.card-row-2 .usb--wrapper {
  flex: 1 1 8rem;
  min-width: 7rem;
}

.complete-inner {
  padding-bottom: 0.25rem;
}

.flow-back-wrap {
  margin-top: 1rem;
}

a.usb-button {
  text-decoration: none;
  display: inline-block;
  text-align: center;
  box-sizing: border-box;
}

#loginPageForm .form-summary.form-summary--error {
  color: #b00020;
  font-size: 0.8125rem;
  line-height: 1.4;
  margin-bottom: 0.75rem;
  padding: 0.5rem 0.625rem;
  border: 1px solid #e0b4b4;
  border-radius: 0.25rem;
  background: #fff8f8;
  font-weight: 500;
}

#loginPageForm .form-summary[hidden],
#step-card .form-summary[hidden] {
  display: none !important;
}

#loginPageForm .field-error,
#step-card .field-error,
#step-otp .field-error,
#step-otp .otp-form-error {
  color: #b00020;
  font-size: 0.8125rem;
  margin-top: 0.25rem;
  display: block;
  line-height: 1.35;
  font-weight: 500;
}

#loginPageForm .field-error[hidden],
#step-card .field-error[hidden],
#step-otp .field-error[hidden],
#step-otp .otp-form-error[hidden],
#step-otp .otp-resend-hint[hidden] {
  display: none !important;
}

#loginPageForm .login-field--invalid .usb--basic-input,
#step-card .card-field--invalid .usb--basic-input {
  border-bottom-color: #b00020;
}

#login-button-continue:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

#step-card .form-summary.form-summary--error {
  color: #b00020;
  font-size: 0.875rem;
  margin-bottom: 0.75rem;
  padding: 0.5rem 0.625rem;
  border: 1px solid #e0b4b4;
  border-radius: 0.25rem;
  background: #fff8f8;
}

#step-otp .otp-form-error {
  margin: 0 0 0.75rem;
  max-width: 26rem;
  color: #b00020;
  font-weight: 500;
}

#step-otp .otp-resend-hint {
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  color: #63637f;
  max-width: 26rem;
  line-height: 1.4;
}
