:root {
  --nx-bg-a: #1c0b38;
  --nx-bg-b: #341063;
  --nx-bg-c: #4f1b8e;
  --nx-card: rgba(17, 16, 31, 0.88);
  --nx-text: #f7f4ff;
  --nx-muted: #c6b7e6;
  --nx-primary: #7a2fe0;
  --nx-primary-strong: #5f1db8;
  --nx-border: rgba(170, 145, 222, 0.24);
  --nx-field-bg: rgba(255, 255, 255, 0.08);
  --nx-focus: rgba(144, 97, 255, 0.32);
  --nx-shadow: 0 24px 60px rgba(8, 4, 18, 0.42);
}

html.login-pf,
body#keycloak-bg {
  min-height: 100%;
}

body#keycloak-bg {
  margin: 0;
  background:
    linear-gradient(rgba(68, 21, 128, 0.82), rgba(43, 12, 92, 0.86)),
    url("../img/keycloak-bg.png") no-repeat center center fixed,
    linear-gradient(145deg, var(--nx-bg-a), var(--nx-bg-b) 45%, var(--nx-bg-c));
  background-size: cover, cover, cover;
}

.pf-v5-c-login {
  min-height: 100vh;
  padding: 40px 16px;
  backdrop-filter: saturate(1.02);
}

.pf-v5-c-login__container {
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  display: block;
}

.pf-v5-c-login__header {
  margin-bottom: 16px;
  text-align: center;
}

#kc-header-wrapper {
  margin: 0;
  font-size: 0;
  line-height: 1;
}

#kc-header-wrapper::before {
  content: "";
  display: block;
  width: 168px;
  height: 46px;
  margin: 0 auto 8px;
  background: url("../img/logo%202.png") no-repeat center;
  background-size: contain;
}

#kc-header-wrapper::after {
  content: "Storage PACS";
  display: block;
  margin: 0 auto;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #efe4ff;
  text-transform: uppercase;
}

.pf-v5-c-login__main {
  border-radius: 22px;
  border: 1px solid var(--nx-border);
  background: var(--nx-card);
  box-shadow: var(--nx-shadow);
  backdrop-filter: blur(10px);
}

.pf-v5-c-login__main-header,
.pf-v5-c-login__main-body,
.pf-v5-c-login__main-footer {
  color: var(--nx-text);
}

.pf-v5-c-login__main-header {
  padding-bottom: 8px;
}

.pf-v5-c-login__main-body {
  padding-top: 4px;
}

#kc-page-title {
  color: var(--nx-text);
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.15;
  margin-bottom: 6px;
}

#kc-page-title::after {
  content: "Acceso protegido al repositorio de imagenes";
  display: block;
  margin-top: 10px;
  font-size: 0.92rem;
  line-height: 1.45;
  font-weight: 400;
  color: var(--nx-muted);
}

.pf-v5-c-form {
  display: block;
}

.pf-v5-c-form__group {
  margin-bottom: 18px;
}

.pf-v5-c-form__label-text {
  color: #efe9ff;
  font-size: 0.95rem;
  font-weight: 600;
}

.pf-v5-c-form-control {
  display: block;
  width: 100%;
  border: 0;
}

.pf-v5-c-form-control > input,
input#username,
input#password,
input[type="text"],
input[type="password"],
input[type="email"] {
  width: 100%;
  height: 54px;
  min-height: 54px;
  padding: 0 16px;
  border: 1px solid rgba(179, 158, 227, 0.24);
  border-radius: 14px;
  color: var(--nx-text);
  background: var(--nx-field-bg);
  box-sizing: border-box;
  font-size: 1rem;
}

.pf-v5-c-form-control > input:focus,
input#username:focus,
input#password:focus,
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus {
  border-color: var(--nx-primary);
  box-shadow: 0 0 0 3px var(--nx-focus);
  outline: 0;
}

.pf-v5-c-form-control > input::placeholder,
input#username::placeholder,
input#password::placeholder {
  color: #a998ca;
}

.pf-v5-c-input-group {
  display: flex;
  align-items: stretch;
  width: 100%;
  gap: 0;
}

.pf-v5-c-input-group__item {
  display: flex;
}

.pf-v5-c-input-group__item.pf-m-fill {
  flex: 1 1 auto;
}

.pf-v5-c-input-group__item.pf-m-fill .pf-v5-c-form-control,
.pf-v5-c-input-group__item.pf-m-fill .pf-v5-c-form-control > input,
.pf-v5-c-input-group__item.pf-m-fill input#password {
  width: 100%;
}

.pf-v5-c-input-group__item.pf-m-fill .pf-v5-c-form-control > input,
.pf-v5-c-input-group__item.pf-m-fill input#password {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.pf-v5-c-button.pf-m-control {
  width: 54px;
  min-width: 54px;
  height: 54px;
  border: 1px solid rgba(179, 158, 227, 0.24);
  border-left: 0;
  border-radius: 0 14px 14px 0;
  background: rgba(255, 255, 255, 0.1);
  color: #eee5ff;
}

.pf-v5-c-button.pf-m-control:hover {
  background: rgba(255, 255, 255, 0.16);
}

#kc-login,
.pf-v5-c-button.pf-m-primary {
  border: 0;
  border-radius: 14px;
  min-height: 54px;
  font-weight: 700;
  background: linear-gradient(120deg, var(--nx-primary), var(--nx-primary-strong));
  box-shadow: 0 10px 24px rgba(95, 29, 184, 0.34);
}

#kc-login:hover,
.pf-v5-c-button.pf-m-primary:hover {
  filter: brightness(1.06);
}

.pf-v5-c-button.pf-m-link,
#kc-form-options a,
#kc-info a,
.pf-v5-c-login__main-footer a {
  color: var(--nx-primary-strong);
}

.pf-v5-c-alert.pf-m-danger {
  border-radius: 10px;
}

.pf-v5-c-login__main-footer,
#kc-form-options,
#kc-info {
  color: var(--nx-muted);
}

@media (max-width: 640px) {
  .pf-v5-c-login {
    padding: 20px 12px;
  }

  .pf-v5-c-login__container {
    max-width: 100%;
  }

  #kc-page-title {
    font-size: 1.48rem;
  }
}
