input:-webkit-autofill {
    color: #2a2a2a !important;}
input,button{
  outline: none;}
textarea{
  padding: 15px;
  resize: none;
  border: 1px solid #ccc;
  border-radius: 3px;
  margin: 12px 0;
  outline: none;}

.small{
  font-size: 12px;
}
.hidden{
  display: none;
}
#registrations{
  text-align:center;
  margin-bottom: 60px;
}
#registrations .input_container{
  position: relative;
}
#registrations .field-info {
  margin-top: 15px;
  padding-left: 10px;
}

#registrations .errors,
#registrations .field-info {
  position: absolute;
  left: 50%;
  text-align: left;
  width: 350px;
  margin-top: 0;
  margin-left: 150px;
  font-size: 13px;
  line-height: 1.5;
}
#registrations .errors{
  color: #c3144a;
}
#registrations .field_with_errors input{
  border: 1px solid #c3144a;
}

.errorMessage {
  color: #ff0000;
}

#registrations .remember_me label{
  position: relative;
  left: -60px;
  color: #5F6062;
  font-size: 12px;
}
#registrations .terms{
  position:relative;
  display: block;
  width: 269px;
  margin: 10px auto;
  text-align: left;
  font-size: 15px;
  line-height: 25px;
  height:60px;
}

#registrations .terms_checkbox,
#registrations .terms_checkbox + label
{
  position: absolute;
  left: 0px;
  top: 5px;
}
#registrations hr{
  width: 70%;
  color: #ccc;
  height: 1px;
  background: #ccc;
  border: none;
}
#registrations .tb-select{
  width: 269px;
  margin: 12px auto;
}

/*
 * regflow status
 * */
#registrations .regflow-status{
  position:relative;
  width: 50%;
  margin: 0 auto;
  padding-bottom: 30px;
  z-index: 0;
}

#registrations .regflow-status:before,
#registrations .regflow-status:after{
  content: "";
  display: block;
  position: absolute;
  width: 45%;
  top: 20px;
  z-index: -1;}

#registrations .regflow-status:before{
  left: 20px}
#registrations .regflow-status:after{
  right: 25px}
#registrations .regflow-status li{
  font-family: "Raleway-SemiBold", arial;
  display: inline-block;
  font-size: 12px;
  color: #888;
  z-index: 1;
}
#registrations .regflow-status li:first-child{
  float: left;}
#registrations .regflow-status li:last-child{
  float: right;}

/* icons */
#registrations .regflow-status li:before{
  content: "";
  display: block;
  width: 22px;
  height: 22px;
  margin: 10px auto;
  border-radius: 100%;
  background: white;
  background-size: 22px 22px;
  background-position: center;
  background-repeat: no-repeat;}

/* step 1*/
#registrations .step1:before,
#registrations .step1:after{
  border-bottom: 1px solid #ccc;}
#registrations .step1 li:nth-child(1):before{
  background-image: url("https://static.opentok.com/img/icons/next-step-arrow-x2.png")}
#registrations .step1 li:nth-child(2):before,
#registrations .step1 li:nth-child(3):before{
  box-shadow: 0 0 0 1px #ccc;}

/* step 2*/
#registrations .step2:before{
  border-bottom: 1px solid #0097ca;}
#registrations .step2:after{
  border-bottom: 1px solid #ccc;}
#registrations .step2 li:nth-child(1):before{
  background-image: url("https://static.opentok.com/img/icons/completed-step-check-x2.png")}
#registrations .step2 li:nth-child(2):before{
  background-image: url("https://static.opentok.com/img/icons/next-step-arrow-x2.png")}

#registrations .step2 li:nth-child(3):before{
  box-shadow: 0 0 0 1px #ccc;}

/* step 3*/

#registrations .step3:after{
  border-bottom: 1px solid #0097ca;}
#registrations .step3:before{
  border-bottom: 1px solid #e6a745;}

#registrations .step3 li:nth-child(1):before,
#registrations .step3 li:nth-child(2):before{
  background-image: url("https://static.opentok.com/img/icons/completed-step-check-x2.png")}
#registrations .step3 li:nth-child(3):before{
  background-image: url("https://static.opentok.com/img/icons/next-step-arrow-x2.png")}
/*
 * Ribbons
 * */

.ribbon{
  background-color:#063f5f;
  text-align: center;
  padding: 20px 0;
  line-height: 30px;
}
.ribbon span{
  font-family: "Raleway-SemiBold", arial;
  color: white;
}
.ribbon a{
  padding: 0 20px;
}
.ribbon-white{
  background-color:white;
  text-align: center;
  padding: 20px 0;
  line-height: 30px;
  box-shadow:inset 0 0 10px rgba(0,0,0,0.3);
}
.ribbon-white span{
  font-family: "Raleway-SemiBold", arial;
  color:#5F6062;
}
.ribbon-white a{
  padding: 0 20px;
  color:#5F6062 !important;
}

.reset-password-container {
  width: 234px;
  margin: 6px auto;
}

#password_rules {
  width: 234px;
  margin: 0 auto;
  text-align: left;
  color: #616266;
  margin: 8px auto;
}

.password_validation {
  background-repeat: no-repeat;
  background-size: 14px 14px;
  background-position: 0px 4px;
  padding-left: 20px;
  line-height: 21px;
  font-size: 12px;
}

.password_validation.fail {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%239B9DA3' d='M8 1.067a6.933 6.933 0 1 0 0 13.866A6.933 6.933 0 0 0 8 1.067zM0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8zm11.577-3.577a.533.533 0 0 1 0 .754L8.754 8l2.823 2.823a.533.533 0 1 1-.754.754L8 8.754l-2.823 2.823a.533.533 0 1 1-.754-.754L7.246 8 4.423 5.177a.533.533 0 1 1 .754-.754L8 7.246l2.823-2.823a.533.533 0 0 1 .754 0z'/%3E%3C/svg%3E");
}

.password_validation.success {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' id='Vlt-icon-check-circle-negative'%3E%3Cpath fill='%2306ba77' d='M8 0C3.6 0 0 3.6 0 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zM7 11.4L3.6 8 5 6.6l2 2 4-4L12.4 6 7 11.4z'/%3E%3C/svg%3E");
}


/*
 * custom checkbox
 * */
[type="checkbox"]:not(:checked),
[type="checkbox"]:checked {
  position: absolute;
  left: -9999px;
  opacity: 0;

}
[type="checkbox"]:not(:checked) + label,
[type="checkbox"]:checked + label {
  position: relative;
  padding-left: 35px;
  cursor: pointer;
  line-height: 25px;
  -webkit-user-select: none;  /* Chrome all / Safari all */
  -moz-user-select: none;     /* Firefox all */
  -ms-user-select: none;      /* IE 10+ */
  user-select: none;
}

/* checkbox aspect */
[type="checkbox"]:not(:checked) + label:before,
[type="checkbox"]:checked + label:before {
  content: '';
  position: absolute;
  left:0; top: 2px;
  width: 20px; height: 20px;
  background-size: 100%;
  background-position: center;
  background-repeat: no-repeat;
  background-color:white;
}
[type="checkbox"]:checked + label:before {
  background-image: url("https://static.opentok.com/img/icons/rememberme-check-2x.png");
}

[type="checkbox"]:not(:checked) + label:before{
  background-image: url("https://static.opentok.com/img/icons/rememberme-uncheck-2x.png");
}

/* checked mark aspect */
[type="checkbox"]:not(:checked) + label:after,
[type="checkbox"]:checked + label:after {
  position: absolute;
  top: 0; left: 4px;
  transition: all .2s;
  /*color: #0099cb;
  font-size: 15px;
  font-family: "Raleway-Light", arial;
  content: '✔';*/
}
/* checked mark aspect changes */
[type="checkbox"]:not(:checked) + label:after {
  opacity: 0;
  /*transform: scale(0);*/
}
[type="checkbox"]:checked + label:after {
  opacity: 1;
  /*transform: scale(1);*/
}
/* disabled checkbox */
[type="checkbox"]:disabled:not(:checked) + label:before,
[type="checkbox"]:disabled:checked + label:before {
  box-shadow: none;
}
[type="checkbox"]:disabled:checked + label:after {
  color:#0099cb;
}
[type="checkbox"]:disabled + label {
  color: #aaa;
}
/* accessibility */
[type="checkbox"]:checked:focus + label:before,
[type="checkbox"]:not(:checked):focus + label:before {
}

.login-container > form > .Vlt-input {
  margin-bottom: 12px;
}

.login-links {
  width: 100%;
  display: flex;
  justify-content: space-between;
}

.login-links a {
  margin: auto 0;
  color: black;
  text-decoration: underline;
}

.login-gray-box {
  background: #F3F3F5;
  padding: 16px 25px;
}

.phone-content {
  padding: 40px 63px 40px;
}

#deviceOptionsModal button {
  width: 157px;
  height: 40px;
}
