/*
	===============================
			@Import	Function
	===============================
*/
/*
	===============================
			@Import	Mixins
	===============================
*/
html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden; /* Prevent scrolling */
    background-color: #000000;
    z-index: -1;
}
.outer {
  position:relative;
  height:100vh;
  overflow:hidden;
  z-index: 0;
}
.bgvideo {
    position: absolute; /* Changed from fixed to absolute for better compatibility */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ensures the video covers the entire container */
    z-index: -1; /* Places the video behind other elements */
    opacity: 0.8; /* Optional: Adjusts visibility to make text more readable */
    overflow: hidden;
}
.form-form {
    position:absolute;
  width: 50%;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  margin: 0 auto; }
  .form-form .form-form-wrap {
    max-width: 480px;
    margin: 0 auto;
    min-width: 311px;
    min-height: 100%;
    align-self: center;
    width: 100%;
    height: 100vh;
    justify-content: center; }
.form-form {
    position: relative;
    width: 50%;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    margin: 0 auto;
    z-index: 1;}
  .form-form .form-container {
    align-items: center;
    display: flex;
    flex-grow: 1;
    width: 100%;
    min-height: 100%; }
    .form-form .form-container .form-content {
        display: block;
        width: 100%;
        padding: 25px;
        text-align: center;
        background: #ffffff;
        border-radius: 16px;
        box-shadow: 0 4px 30px rgba(0, 0, 0, 1.1);
        backdrop-filter: blur(5px);
        -webkit-backdrop-filter: blur(5px);
        border: 1px solid rgba(255, 255, 255, 0.3);}
      .form-form .form-container .form-content h1 {
        font-size: 32px;
        color: #3b3f5c; }
.form-form .form-container .form-content h1 {
    font-family: 'Sofachrome Rg';
    font-weight: 400;
    font-style: italic;
    color:#af2d31;
    text-shadow: #5a5e59 1px 1px;
    letter-spacing: 0.1em;
    text-underline-offset: 0.09em;}
.form-form .form-container .form-content h3 {
    width: 295px;
    margin-left: auto;
    margin-right: auto; }

      .form-form .form-container .form-content > p {
        font-size: 13px;
        color: #888ea8;
        font-weight: 600;
        margin-bottom: 35px; }
  .form-form .form-form-wrap .user-meta {
    margin-bottom: 35px; }
    .form-form .form-form-wrap .user-meta img {
      width: 52px;
      height: 52px;
      border-radius: 50%;
      margin-right: 15px;
      border: 4px solid #e0e6ed; }
    .form-form .form-form-wrap .user-meta div {
      align-self: center; }
    .form-form .form-form-wrap .user-meta p {
      font-size: 31px;
      color: #3b3f5c;
      margin-bottom: 0; }
  .form-form .form-form-wrap h1 .brand-name {
    color: #3b3f5c;
    font-weight: 600; }
  .form-form .form-form-wrap p.signup-link {
    font-size: 14px;
    color: #3b3f5c;
    font-weight: 700;
    margin-bottom: 15px;
    text-align: center;
    margin-top: 50px; }
    .form-form .form-form-wrap p.signup-link.register {
      font-size: 13px;
      color: #888ea8;
      font-weight: 600;
      margin-bottom: 25px;
      margin-top: 0; }
    .form-form .form-form-wrap p.signup-link.recovery {
      margin-top: 0; }
    .form-form .form-form-wrap p.signup-link a {
      color: #4361ee;
      border-bottom: 1px solid; }
  .form-form .form-form-wrap form .field-wrapper {
    width: 100%; }
    .form-form .form-form-wrap form .field-wrapper.input {
      padding: 11px 0px 16px 0;
      border-bottom: none;
      position: relative; }
      .form-form .form-form-wrap form .field-wrapper.input:focus {
        border: 1px solid #000; }
    .form-form .form-form-wrap form .field-wrapper.toggle-pass p {
      font-weight: 600;
      color: #3b3f5c;
      margin-bottom: 0; }
    .form-form .form-form-wrap form .field-wrapper .logged-in-user-name {
      font-size: 37px;
      color: #3b3f5c; }
    .form-form .form-form-wrap form .field-wrapper label {
      font-size: 10px;
      font-weight: 700;
      color: #3b3f5c;
      margin-bottom: 8px; }
    .form-form .form-form-wrap form .field-wrapper.terms_condition {
      margin-bottom: 20px; }
      .form-form .form-form-wrap form .field-wrapper.terms_condition label {
        font-size: 14px;
        color: #888ea8;
        padding-left: 31px;
        font-weight: 100; }
      .form-form .form-form-wrap form .field-wrapper.terms_condition a {
        color: #4361ee; }
    .form-form .form-form-wrap form .field-wrapper svg.feather-user {
      top: 53px; }
    .form-form .form-form-wrap form .field-wrapper svg.feather-lock {
      top: 50px; }
    .form-form .form-form-wrap form .field-wrapper svg.feather-at-sign {
      top: 47px; }
      .form-form .form-form-wrap form .field-wrapper svg.feather-at-sign.register {
        top: 53px; }
    .form-form .form-form-wrap form .field-wrapper svg:not(.feather-eye) {
      position: absolute;
      left: 12px;
      color: #888ea8;
      fill: rgba(0, 23, 55, 0.08);
      width: 20px;
      height: 20px; }
    .form-form .form-form-wrap form .field-wrapper svg.feather-eye {
      position: absolute;
      top: 49px;
      right: 13px;
      color: #888ea8;
      fill: rgba(0, 23, 55, 0.08);
      width: 17px;
      cursor: pointer; }
    .form-form .form-form-wrap form .field-wrapper input {
      display: inline-block;
      vertical-align: middle;
      border-radius: 6px;
      min-width: 50px;
      max-width: 635px;
      width: 100%;
      -ms-transition: all 0.2s ease-in-out 0s;
      transition: all 0.2s ease-in-out 0s;
      color: #3b3f5c;
      font-weight: 500;
      font-size: 16px;
      padding: 13px 35px 13px 46px; }
      .form-form .form-form-wrap form .field-wrapper input::-webkit-input-placeholder, .form-form .form-form-wrap form .field-wrapper input::-ms-input-placeholder, .form-form .form-form-wrap form .field-wrapper input::-moz-placeholder {
        color: #bfc9d4;
        font-size: 14px; }
    .form-form .form-form-wrap form .field-wrapper button.btn {
      align-self: center;
      width: 100%;
      padding: 11px 14px;
      font-size: 16px;
      letter-spacing: 2px; }
    .form-form .form-form-wrap form .field-wrapper a.forgot-pass-link {
      font-weight: 600;
      color: #888ea8;
      display: block;
      letter-spacing: 1px;
      font-size: 12px;
      margin-bottom: 8px; }
    .form-form .form-form-wrap form .field-wrapper .n-chk .new-control-indicator {
      top: 2px;
      border: 1px solid #bfc9d4;
      background-color: #f1f2f3; }
      .form-form .form-form-wrap form .field-wrapper .n-chk .new-control-indicator:after {
        top: 54%; }

.new-control.new-checkbox.checkbox-primary > input:checked ~ span.new-control-indicator {
  border: none; }

.form-form .form-form-wrap form .division {
  text-align: center;
  font-size: 13px;
  margin: 35px 0 38px 0; }

.form-form .form-form-wrap form .social {
  text-align: center; }
  .form-form .form-form-wrap form .social a {
    background: transparent;
    box-shadow: none;
    border: 1px solid #e0e6ed;
    padding: 12px 10px;
    width: 181px; }
    .form-form .form-form-wrap form .social a.social-fb {
      margin-right: 15px; }
      .form-form .form-form-wrap form .social a.social-fb svg, .form-form .form-form-wrap form .social a.social-fb .brand-name {
        color: #4361ee; }
.form-form a:hover {
    color: #555555;
    text-decoration: underline!important; }
.strength-bar {
    display: flex;
    margin-top: 10px; }
.strength-bar div {
    width: 20%;
    height: 5px;
    margin: 0 2px;
    background-color: #ddd;
    border-radius: 2px; }
.strength-bar .strength-weak {
    background-color: red; }

.strength-bar .strength-fair {
    background-color: orange; }

.strength-bar .strength-good {
    background-color: yellow;
}

.strength-bar .strength-strong {
    background-color: lightgreen;
}

.strength-bar .strength-very-strong {
    background-color: green;
}

.error-message {
    color: red;
    margin-bottom: 10px;
}

/* Styles for dynamic password requirements with icons */
.password-requirements {
    list-style-type: none;
    padding: 0;
    margin-top: 10px;
    font-size: 0.9em;
}

.password-requirements li {
    display: flex;
    align-items: center;
    color: #6c757d;
}

.password-requirements li.valid {
    color: green;
}

.password-requirements li i {
    margin-right: 10px;
    font-size: 1.2em;
}

.password-requirements li i.fa-check-circle {
    color: green;
}

.password-requirements li i.fa-times-circle {
    color: red;
}
.popover {
        border-radius: 15px; /* Light grey background */
        border: 1px solid #ddd;    /* Light border */
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Subtle shadow */
    }

    /* Style the arrow of the popover */
    .popover .arrow::before {
        border-top-color: #f8f9fa; /* Match the background color of the popover */
    }

    /* Customize the header of the popover, if used */
    .popover-header {
        background-color: #343a40; /* Dark header background */
        color: #fff;               /* White text */
        font-weight: bold;
        border-bottom: 1px solid #ddd;
    }

    /* Customize the body of the popover */
    .popover-body {
        padding: 10px;
        font-size: 0.8em;
        color: #333;               /* Dark text color */
        white-space: nowrap;
    }

    /* Style individual list items inside the popover body */
    .popover-body .password-requirements {
        list-style-type: none; /* Remove default bullet points */
        padding: 0;
        margin: 0;
    }

    .popover-body .password-requirements li {
        display: flex;
        align-items: center;
        margin-bottom: 5px;
    }

    /* Valid and invalid states for password requirements */
    .popover-body .password-requirements li.valid {
        color: #36ba82;
    }

    .popover-body .password-requirements li i {
        margin-right: 8px;
    }

    .popover-body .password-requirements li.valid i {
        color: #36ba82;
    }

    .popover-body .password-requirements li i.fa-times-circle {
        color: #e30901;
    }
@media (max-width: 991px) {
  .form-form {
    width: 100%; }
    .form-form .form-form-wrap {
      min-width: 100%;
      margin: 0 auto; }
    .form-form .form-container .form-content {
      border-radius: 0px; } }

@media (max-width: 575px) {
  .form-form .form-form-wrap form .field-wrapper.toggle-pass {
    margin-bottom: 28px; }
  .form-form .form-form-wrap form .social a.social-fb, .form-form .form-form-wrap form .social a.social-github {
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 10px;
    display: block; } }

@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .form-form .form-form-wrap {
    width: 100%; }
  .form-form .form-container {
    height: 100%; } }
/* Specific adjustments for Chrome */
@media screen and (-webkit-min-device-pixel-ratio:0) {
    .bgvideo {
        position: fixed; /* Set to fixed only for Chrome to avoid overflow issues */
    }
}
@supports (-ms-ime-align: auto) {
  .form-form .form-form-wrap {
    height: 100%; } }
/* Specific adjustments for Safari */
@supports (-webkit-backdrop-filter: none) {
    #bgVideo {
        object-fit: cover; /* Safari-specific fix to ensure the video covers the entire screen */
    }
}
