@import url('https://fonts.googleapis.com/css2?family=PT+Sans&display=swap');

:root {
  --textColor: #000000;
  --textOffColor: #666666;
  --baseColor: #c6c8cc;
  --baseDarkColor: #9e9e9e;
  --baseLightColor: #283b48;
  --secColor: #141414;
  
  /* Overrides patternfly variables */
  --pf-global--primary-color--100: #2f5a8a;
  --pf-global--primary-color--200: #24456a;

  --pf-global--Color--Light-100: #000000;
  --pf-global--primary-color--dark-100: #2f5a8a;

  --pf-global--BorderColor--200: #b9b9b9;
  --pf-global--BorderColor--300: #dde2e6;
}

/* Login Header */

.login-pf #kc-header {
  display: none; /* no need to display as logo is now part of the form container */
 }


/* Login Body */

.login-pf body {
  background: #fff;
  font-family: 'PT Sans', Arial, sans-serif;
  font-size: 18px;
}

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

.login-pf-page {
  display: flex;
  flex-direction: column;
  width: 50%;
  height: 100%;
  align-items: center;
  justify-content: space-between;
  padding-top: 5%;
  overflow-y: auto;
}

/* Login Card, Logo, Title Header */

.login-pf .card-pf {
  background-color: transparent;
  color: var(--pf-global--Color--Light-100);
  border-top: 0;
  width: 100%;
}

.login-pf .card-pf .kc-brand-logo {
  margin: 10% 0;
  text-align: center;
}

.login-pf .card-pf h1 {
  color: var(--pf-global--Color--Light-100);
}

/* Login - Reset Password */
.login-pf-page .login-pf-signup {
   color: var(--textOffColor);
}

#kc-info-wrapper {
  background-color: #dfe4eb;
}

/* Login Welcome */

.login-pf-welcome {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 50%;
  background-image: url('../img/brand-bg.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: #fff;
  padding: 5%;
  gap: 5%;
}

.login-pf-welcome .kc-welcome-main {
  width: 20%;
}

.login-pf-welcome .kc-welcome-main h1 {
  font-size: 30px;
}

.login-pf-welcome .kc-welcome-footer {
  display: flex;
  justify-content: space-between;
}


/* Login Form */

.login-pf .pf-c-form-control {
 height: 45px;
}

.login-pf .pf-c-form-control:focus-visible {
  outline: none;
  border: 1px solid var(--pf-global--BorderColor--200);
}

.login-pf .pf-c-form-control:hover {
  --pf-c-form-control--hover--BorderBottomColor: var(--pf-global--BorderColor--300);
}

.login-pf .checkbox {
  color: var(--textOffColor);
  font-size: 14px;
}

.login-pf .checkbox input[type="checkbox"] {
  top: 1px;
}

.login-pf .checkbox input[type="checkbox"]:checked {
  accent-color: #2f5a8a;
}


/* Login Button */

#kc-login {
  border: none;
  padding: 11px 15px;
  font-size: 16px;
}

#kc-login:active:focus {
  background: linear-gradient(145deg, #1c3756, #7d97b6) !important;
  outline: none;
}

/* Login Link */

.login-pf a {
  color: var(--pf-global--primary-color--100);
}

.login-pf a:hover {
  color: var(--pf-global--primary-color--200);
}


/* Login Footer */

.footer {
  text-align: center;
  font-size: 15px;
}

.text-muted {
  color: var(--textOffColor);
}

/* Hide Social Login Buttons */
#kc-social-providers {
  display: none;
}

/* Media Queries */

/* Mobile phones and low resolution ipads */
@media (max-width: 767px) {

  .login-pf body {
    background: #fff;
    background-image: unset;
    font-size: 16px;
  }

  .login-pf-page {
    padding-top: 5% !important;
  }

  .footer p {
    font-size: small;
  }
}

 /* Tablets, Ipads in portrait mode */
@media (max-width: 1024px){

  .login-pf-welcome {
    display: none;
  }

  .login-pf-page {
    width: 100%;
    padding-top: 15%;
  }

}

@media (max-height: 695px) {

  .form-group {
    margin-bottom: 10px;
  }

  .login-pf-welcome {
    display: none;
  }

  .login-pf-page {
    width: 100%;
  }

}

