input:focus,
select:focus,
textarea:focus,
button:focus {
    outline: none;
}

span.line {
    display: inline-block;
}

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #17202C inset;
    -webkit-text-fill-color: white;
}

/*Avatar CSS*/
.avatar {
    display: flex;
    flex-direction: row;
    align-items: center;
    top: 16px;
    right: 50px;
    height: 32px;
    z-index: 7;
    position: absolute;
    cursor: pointer;

  }

  .avatar:focus  .avatar-settings-container {
      display: block!important;
  }

  .avatar-text:hover .avatar-settings-container {
      display: block!important;
  }

  .avatar:hover  .avatar-settings-container {
      display: block!important;
  }

  .avatar-text{
    font-size: 16px;
    font-family: "proxima-nova";
    font-style: normal;
    font-weight: normal;
    line-height: 24px;
    color: white;
    padding-right: 5px;
  }

  .avatar-text:hover {
    text-decoration: underline;
  }

  .avatar-settings-container{
    display: none;
    z-index: 7;
    position: absolute;
    width: 150px;
    height: 55px;
    top: 30px;
    right: -5px;
    background: #17202B;
    border: 1px solid #243044;
    box-sizing: border-box;
    box-shadow: 0px 20px 44px rgba(0, 0, 0, 0.13);
    border-radius: 8px;
    padding: 16px;
  }


  .pw-caret {
    margin-left: 7px;
    display: inline-block;
    vertical-align: middle;
    border-top: 5px solid white;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;

  }

  /*Loader CSS*/
  .loader {
    width: 100px;
    height: 100px;
    border: 20px solid white;
    border-top: 20px solid #7DDEFB;
    border-radius: 100%;
    margin: auto;
    animation: spin 1s infinite linear;
  }

  @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
  }

  /* Background CSS */
  .page {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    overflow: hidden;
    padding:0px;
    margin:0px;
    left: 0%;
    right: 0%;
    top: 0em;
    height: 100%;
    width: 100%;
    background-color: #141A23;
  }

  .main-container {
    z-index: 6;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: flex;
    position: absolute;
  }

  .background-container{
    display: flex;
    justify-content: center;
    opacity: 0.3;
    height: 100%;
    width: 100%;
  }

  .background-gradient {
    z-index: 3;
    position: absolute;
    height: 100%;
    width: 100%;
    left: 0%;
    right: 0%;
    bottom: 0em;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 10%, #121A24 80%);
  }


  .background {
    /* z-index: 3; */
    position: absolute;
    height: 1301px;
    width: 100%;
    left: 0%;
    right: 0%;
    top: 0px;
    background: linear-gradient(180deg, #11303D 0%, rgba(31, 104, 51, 0) 100%);
  }

  .background-2 {
    /* z-index: 2; */
    position: absolute;
    height: 909px;
    width: 100%;
    left: 0%;
    right: 0%;
    top: 0px;
    background: linear-gradient(180deg, #022F87 0%, rgba(0, 0, 0, 0) 100%);
  }

  .logo-container{
    z-index: 5;
    margin: 20px 0;
  }

  /* Text CSS */
  .title{
    color: white;
    font-style: normal;
    font-weight: normal;
    font-size: 48px;
    line-height: 32px;
    font-family: "proxima-nova";
    text-align: center;
    margin: 12px;
  }

  .regular-text{
    color: white;
    font-style: normal;
    font-weight: normal;
    font-size: 16px;
    line-height: 24px;
    font-family: "proxima-nova";
    text-align: center;
  }

  .link-container  {
    color: white;
    font-style: normal;
    font-weight: normal;
    font-size: 16px;
    line-height: 24px;
    font-family: "proxima-nova";
  }

  .link-container a {
    color: white;
    font-style: normal;
    font-weight: normal;
    font-size: 16px;
    line-height: 24px;
    font-family: "proxima-nova";
    text-align: center;
  }

  .link-container a:hover .link-container a:focus{
    color: white!important;
    text-decoration: underline;
  }

  /* Form CSS */

form {
    width: 100%;
    padding-bottom: 10px;
}

.form-container {
    z-index: 5;
    border-radius: 8px;
    background-color: #1E2735;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 24px;
    flex-shrink: 0;
    align-self: stretch;
    padding: 20px 0px;
    width: 506px;
    box-shadow: 0px 1px 5.6px 0px #35404F;
}

@media only screen and (max-width: 500px){
  .form-container {
      width: 364px;
  }
}

.form-group {
    padding-left: 40px;
    padding-right: 40px;
}

.form-group-submit {
    display: flex;
    justify-content: flex-end;
}

.form-title{
    color: white;
    font-style: normal;
    font-weight: 500;
    font-size: 28px;
    line-height: 32px;
    font-family: "proxima-nova";
    text-align: center;
}


.form-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    align-self: stretch;
    padding: 0px 20px;
}

.form-item {
    padding: 0px 40px;
}

.form-button {
    -webkit-appearance: none;
    cursor: pointer;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    min-width: 124px;
    height: 48px;
    background: linear-gradient(207.43deg, #FFE37E -10.71%, #22BACF 131.76%);
    box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.05);
    border-color: #121A24;
    border-style: solid;
    border-radius: 100px;
    font-family: "proxima-nova";
    font-weight: normal;
    color: #121A24;
    font-style: normal;
    font-size: 16px;
    line-height: 24px;
}

  .form-button-text {
    cursor: pointer;
    font-family: "proxima-nova";
    font-weight: normal;
    color: #121A24;
    font-style: normal;
    font-size: 16px;
    line-height: 24px;
    margin: 0;
  }

.clickable-icon-container{
    cursor: pointer;
}

.visibility-icon-container{
  cursor: pointer;
}

.validation-icon-container{
  cursor: pointer;
}

.pw-form-input-control {
  width: 90%;
  font-family: "proxima-nova";
  font-weight: normal;
  font-size: 16px;
  color: white;
  background-color: transparent;
  border: 0;
  margin-right: 5px;
}

.pw-input-container {
    display: flex;
    align-items: center;
    flex-direction: row;
    border-style: solid;
    border-radius: 100px;
    border: 1px solid #35404F;
    background-color: #17202C;
    width: 100%;
    height: 48px;
    padding: 12px 16px 12px 24px;
}

.pw-input-container:focus-within{
    border: 1px solid #7DDEFB!important;
    box-sizing: border-box;
    box-shadow: 0px 0px 0px 2px #0F151E, 0px 0px 0px 4px rgba(96, 177, 215, 0.3);
}

.pw-checkbox-container{
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
}

.hidden-checkbox {
  display: none;
}

/* Validation CSS */
.invalid-container {
  border-color: #EE7064!important;
}

.validation-error-text {
  height: 16px;
  display: block;
  margin: 3px;
  color: #EE7064;
  font-family: "proxima-nova";
  font-weight: normal;
  font-style: normal;
  font-size: 12px;
  line-height: 16px;
}

/*Link CSS*/

.redirect-link-container a {
  color: #7DDEFB;
}

.redirect-link-container a:hover .redirect-link-container a:focus{
  color: #7DDEFB!important;
  text-decoration: underline;
}


.background-svg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    z-index: -1;
}

.separator-container {
    width: 80%;
}

.separator {
    display: flex;
    align-items: center;
    text-align: center;
    color: white;
}

.separator::before,
.separator::after {
    content: '';
    flex: 1;
    border-bottom: 0.5px solid #fff;
}

.separator:not(:empty)::before {
    margin-right: .25em;
}

.separator:not(:empty)::after {
    margin-left: .25em;
}
