/* Astrix Enterprise — Keycloak login theme */

:root {
  --orange:      #f97316;
  --orange-dark: #ea6c0a;
  --orange-light:#fff7ed;
  --slate-50:    #f8fafc;
  --slate-100:   #f1f5f9;
  --slate-200:   #e2e8f0;
  --slate-400:   #94a3b8;
  --slate-500:   #64748b;
  --slate-700:   #334155;
  --slate-900:   #0f172a;

  --pf-v5-global--primary-color--100: var(--orange);
  --pf-v5-global--primary-color--200: var(--orange-dark);
  --pf-v5-global--active-color--100:  var(--orange);
  --pf-v5-global--link--Color:        var(--orange);
  --pf-v5-global--link--Color--hover: var(--orange-dark);
  --pf-v5-global--FontFamily--heading: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --pf-v5-global--FontFamily--text:    ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* ── Reset PatternFly bottom-line trick everywhere ── */
*::after { --pf-v5-c-form-control--after--BorderBottomColor: transparent; }

/* ── Full-page background ── */
html, body,
.login-pf body, body.login-pf, html.login-pf {
  margin: 0 !important;
  padding: 0 !important;
  min-height: 100vh !important;
  background: #eef2f7 !important;
  font-family: var(--pf-v5-global--FontFamily--text) !important;
}

/* ── Page centering ── */
.pf-v5-c-login,
.login-pf-page {
  min-height: 100vh !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: center !important;
  padding: 0 !important;
}

/* ── Container becomes the two-column layout ── */
.pf-v5-c-login__container,
.login-pf-page .container-fluid {
  width: 100% !important;
  max-width: 1100px !important;
  margin: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  padding: 40px 24px !important;
}

/* ── Hide old realm header ── */
#kc-header,
.pf-v5-c-login__header {
  display: none !important;
}

/* ── Left illustration panel ── */
.pf-v5-c-login__main::before,
.login-pf-page .card-pf::before {
  display: none !important;
}

/* ── Card — glass card on right ── */
.pf-v5-c-login__main,
.login-pf-page .card-pf {
  background: rgba(255, 255, 255, 0.82) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border: 1px solid rgba(255, 255, 255, 0.80) !important;
  border-radius: 24px !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.10), 0 2px 10px rgba(249,115,22,0.06) !important;
  padding: 48px 44px 40px !important;
  width: 100% !important;
  max-width: 440px !important;
  flex-shrink: 0 !important;
}

/* ── Header ── */
.pf-v5-c-login__main-header,
.login-pf-header {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  margin-bottom: 28px !important;
  gap: 0 !important;
}

#kc-page-title,
.pf-v5-c-login__main-title,
.pf-v5-c-login__main-header .pf-v5-c-title,
.login-pf-header h1 {
  color: var(--slate-900) !important;
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.25 !important;
  margin: 0 0 4px !important;
  text-align: center !important;
}

.pf-v5-c-login__main-header-desc,
.pf-v5-c-login__main-header .pf-v5-c-content p {
  color: var(--slate-500) !important;
  font-size: 0.875rem !important;
  margin: 4px 0 0 !important;
  text-align: center !important;
}

.pf-v5-c-login__main-header-utilities { display: none !important; }

/* ── Form labels ── */
.pf-v5-c-form__label-text,
.pf-v5-c-form__label,
.login-pf-page .control-label {
  color: var(--slate-700) !important;
  font-weight: 600 !important;
  font-size: 0.8125rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}

.pf-v5-c-form__group,
.form-group {
  margin-bottom: 1.1rem !important;
}

/* ── Kill ALL PF5 bottom-line pseudo-elements ── */
.pf-v5-c-form-control::after,
.pf-v5-c-form-control::before,
.pf-v5-c-input-group::after,
.pf-v5-c-input-group > *::after,
.pf-v5-c-input-group__item::after,
.pf-v5-c-input-group__item::before {
  display: none !important;
  content: none !important;
  border: none !important;
}

/* ── Inputs ── */
.pf-v5-c-form-control {
  --pf-v5-c-form-control--after--BorderBottomColor: transparent !important;
  --pf-v5-c-form-control--m-focus--after--BorderBottomColor: transparent !important;
  background: #ffffff !important;
  border: 2px solid var(--slate-200) !important;
  border-radius: 14px !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04) !important;
  padding: 0 16px !important;
  min-height: 52px !important;
  font-size: 0.9375rem !important;
  color: var(--slate-900) !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  position: relative !important;
}

.pf-v5-c-form-control:focus,
.pf-v5-c-form-control:focus-within,
input.pf-v5-c-form-control:focus {
  border-color: var(--orange) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,0.15) !important;
  outline: none !important;
}

.pf-v5-c-form-control > input,
.pf-v5-c-form-control input {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
  min-height: 48px !important;
  width: 100% !important;
  font-size: 0.9375rem !important;
}

/* ── Password group ── */
.pf-v5-c-input-group {
  background: #ffffff !important;
  border: 2px solid var(--slate-200) !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04) !important;
}

.pf-v5-c-input-group:focus-within {
  border-color: var(--orange) !important;
  box-shadow: 0 0 0 3px rgba(249,115,22,0.15) !important;
}

.pf-v5-c-input-group .pf-v5-c-form-control,
.pf-v5-c-input-group input.pf-v5-c-form-control,
.pf-v5-c-input-group > .pf-v5-c-form-control,
.pf-v5-c-form-control.pf-m-plain,
.pf-v5-c-input-group .pf-v5-c-form-control.pf-m-plain {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  min-height: 52px !important;
}

.pf-v5-c-input-group .pf-v5-c-button,
.pf-v5-c-input-group .pf-v5-c-button.pf-m-control,
.pf-v5-c-input-group .pf-v5-c-button.pf-m-plain {
  background: transparent !important;
  border: none !important;
  border-left: none !important;
  box-shadow: none !important;
  color: var(--slate-400) !important;
  padding: 0 14px !important;
  transition: color 0.15s !important;
}

.pf-v5-c-input-group .pf-v5-c-button:hover {
  color: var(--orange) !important;
  background: transparent !important;
}

/* Kill autofill yellow */
input:-webkit-autofill,
input:-webkit-autofill:focus,
input:-webkit-autofill:hover {
  -webkit-box-shadow: 0 0 0 1000px #ffffff inset !important;
  box-shadow: 0 0 0 1000px #ffffff inset !important;
  -webkit-text-fill-color: var(--slate-900) !important;
}

/* ── Forgot password ── */
#kc-form-options,
.login-pf-settings {
  display: flex !important;
  justify-content: flex-end !important;
  margin-top: -0.2rem !important;
  margin-bottom: 1.4rem !important;
}

#kc-form-options a,
.pf-v5-c-login__main-footer a,
.login-pf-settings a {
  color: var(--orange) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}

#kc-form-options a:hover {
  color: var(--orange-dark) !important;
  text-decoration: underline !important;
}

/* ── Sign In button ── */
.pf-v5-c-button.pf-m-primary,
.login-pf-page .pf-v5-c-button.pf-m-primary,
.login-pf-page .btn-primary {
  background: linear-gradient(135deg, #ff6b00 0%, #ff8c42 100%) !important;
  border: none !important;
  border-radius: 14px !important;
  min-height: 52px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em !important;
  width: 100% !important;
  color: #fff !important;
  box-shadow: 0 6px 20px rgba(249,115,22,0.38) !important;
  transition: transform 0.15s, box-shadow 0.15s !important;
}

.pf-v5-c-button.pf-m-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 28px rgba(249,115,22,0.46) !important;
}

#kc-form-buttons,
.pf-v5-c-form__actions {
  margin-top: 0.5rem !important;
}

/* ── Secondary ── */
.pf-v5-c-button.pf-m-secondary {
  border-radius: 14px !important;
  min-height: 46px !important;
}

/* ── Alerts ── */
.pf-v5-c-alert, .alert {
  border-radius: 12px !important;
  margin-bottom: 1rem !important;
}
.pf-v5-c-alert.pf-m-danger, .alert-error { border-left: 4px solid #dc2626; }
.pf-v5-c-alert.pf-m-success, .alert-success { border-left: 4px solid #16a34a; }
.pf-v5-c-helper-text__item-text.pf-m-error, .kc-feedback-text {
  color: #b91c1c !important;
  font-size: 0.8125rem !important;
}

/* ── Footer ── */
.pf-v5-c-login__main-footer-band, #kc-info {
  border-top: 1px solid var(--slate-200);
  margin-top: 1.5rem;
  padding-top: 1rem;
  color: var(--slate-400);
  font-size: 0.8125rem;
  text-align: center;
}

/* ── OTP ── */
#kc-totp-settings, #kc-totp-secret-key {
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  padding: 14px;
  margin: 12px 0;
  border-radius: 12px;
}
#kc-totp-secret-qr-code {
  display: flex;
  justify-content: center;
  margin: 12px 0 16px;
}
#kc-totp-secret-qr-code img, img[src*="qr"] {
  max-width: 180px;
  border-radius: 10px;
  border: 1px solid var(--slate-200);
  padding: 10px;
  background: #fff;
}
#kc-otp-login-form input, input[name="totp"], input[name="totpSecret"] {
  letter-spacing: 0.18em;
  text-align: center;
  font-size: 1.1rem !important;
  font-weight: 600;
}

/* ── Mobile ── */
@media (max-width: 640px) {
  .pf-v5-c-login__container,
  .login-pf-page .container-fluid {
    padding: 20px 16px !important;
  }
  .pf-v5-c-login__main,
  .login-pf-page .card-pf {
    padding: 32px 24px 28px !important;
    border-radius: 18px !important;
    max-width: 100% !important;
  }
}

/* Force light */
.pf-v5-theme-dark.login-pf body,
.pf-v5-theme-dark body.login-pf {
  background: linear-gradient(135deg, #f5f7fa 0%, #eef2f7 100%) !important;
}
.pf-v5-theme-dark .pf-v5-c-login__main {
  background: rgba(255,255,255,0.82) !important;
  color: var(--slate-900) !important;
}
