/* ═══════════════════════════════════════════════════
   IT-Trail Keycloak Login Theme
   Exact match of www.ittrail.at "Dimension" design
   Per-client branding via CSS custom properties
   ═══════════════════════════════════════════════════ */

/* Self-hosted Source Sans 3 (successor to Source Sans Pro) — GDPR compliant */
@font-face {
  font-family: "Source Sans Pro";
  font-style: normal;
  font-weight: 300 600;
  font-display: swap;
  src: url("../fonts/SourceSans3-Regular-LatinExt.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Source Sans Pro";
  font-style: normal;
  font-weight: 300 600;
  font-display: swap;
  src: url("../fonts/SourceSans3-Regular.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Source Sans Pro";
  font-style: italic;
  font-weight: 300 600;
  font-display: swap;
  src: url("../fonts/SourceSans3-Italic-LatinExt.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Source Sans Pro";
  font-style: italic;
  font-weight: 300 600;
  font-display: swap;
  src: url("../fonts/SourceSans3-Italic.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ── Branding Custom Properties (overridden via JS) ─ */
:root {
  --brand-primary: #ffffff;
  --brand-bg: #1b1f22;
  --brand-logo-url: url("../img/logo.png");

  /* Global colours */
  --pf-global--BackgroundColor--100: transparent !important;
  --pf-global--BackgroundColor--light-100: transparent !important;
  --pf-global--BackgroundColor--200: transparent !important;
  --pf-global--BackgroundColor--light-200: transparent !important;
  --pf-global--BackgroundColor--light-300: transparent !important;
  --pf-global--Color--100: #ffffff !important;
  --pf-global--Color--dark-100: #ffffff !important;
  --pf-global--Color--200: rgba(255, 255, 255, 0.6) !important;
  --pf-global--primary-color--100: #ffffff !important;
  --pf-global--primary-color--dark-100: #ffffff !important;
  --pf-global--primary-color--200: rgba(255, 255, 255, 0.8) !important;
  --pf-global--BorderColor--100: #ffffff !important;
  --pf-global--BorderColor--200: rgba(255, 255, 255, 0.5) !important;
  --pf-global--BorderColor--300: #ffffff !important;
  --pf-global--active-color--100: #ffffff !important;
  --pf-global--link--Color: #ffffff !important;
  --pf-global--link--Color--hover: #ffffff !important;
  --pf-global--link--Color--dark--100: #ffffff !important;

  /* Form control overrides */
  --pf-c-form-control--BackgroundColor: transparent !important;
  --pf-c-form-control--Color: #ffffff !important;
  --pf-c-form-control--BorderTopColor: #ffffff !important;
  --pf-c-form-control--BorderRightColor: #ffffff !important;
  --pf-c-form-control--BorderBottomColor: #ffffff !important;
  --pf-c-form-control--BorderLeftColor: #ffffff !important;
  --pf-c-form-control--hover--BorderBottomColor: #ffffff !important;
  --pf-c-form-control--focus--BorderBottomColor: #ffffff !important;
  --pf-c-form-control--m-expanded--BorderBottomColor: #ffffff !important;
  --pf-c-form-control--placeholder--Color: rgba(255, 255, 255, 0.4) !important;
  --pf-c-form-control--disabled--Color: rgba(255, 255, 255, 0.3) !important;
  --pf-c-form-control--disabled--BackgroundColor: rgba(255, 255, 255, 0.05) !important;
  --pf-c-form-control--disabled--BorderBottomColor: rgba(255, 255, 255, 0.3) !important;
  --pf-c-form-control--FontSize: 1rem !important;
  --pf-c-form-control--LineHeight: 2.75rem !important;
  --pf-c-form-control--BorderWidth: 1px !important;
  --pf-c-form-control--BorderRadius: 4px !important;

  /* Primary button overrides */
  --pf-c-button--m-primary--BackgroundColor: #ffffff !important;
  --pf-c-button--m-primary--Color: #1b1f22 !important;
  --pf-c-button--m-primary--hover--BackgroundColor: rgba(255, 255, 255, 0.9) !important;
  --pf-c-button--m-primary--hover--Color: #1b1f22 !important;
  --pf-c-button--m-primary--active--BackgroundColor: rgba(255, 255, 255, 0.8) !important;
  --pf-c-button--m-primary--active--Color: #1b1f22 !important;
  --pf-c-button--m-primary--focus--BackgroundColor: rgba(255, 255, 255, 0.9) !important;
  --pf-c-button--m-primary--focus--Color: #1b1f22 !important;

  /* Secondary / link button overrides */
  --pf-c-button--m-secondary--BackgroundColor: transparent !important;
  --pf-c-button--m-secondary--Color: #ffffff !important;
  --pf-c-button--m-secondary--BorderColor: #ffffff !important;
  --pf-c-button--m-link--Color: #ffffff !important;
  --pf-c-button--m-link--hover--Color: #ffffff !important;

  /* Control (toggle) button overrides (password eye icon) */
  --pf-c-button--m-control--BackgroundColor: transparent !important;
  --pf-c-button--m-control--Color: rgba(255, 255, 255, 0.5) !important;
  --pf-c-button--m-control--BorderTopColor: #ffffff !important;
  --pf-c-button--m-control--BorderRightColor: #ffffff !important;
  --pf-c-button--m-control--BorderBottomColor: #ffffff !important;
  --pf-c-button--m-control--BorderLeftColor: #ffffff !important;
  --pf-c-button--m-control--hover--BackgroundColor: rgba(255, 255, 255, 0.075) !important;
  --pf-c-button--m-control--hover--Color: #ffffff !important;
  --pf-c-button--m-control--hover--BorderBottomColor: #ffffff !important;
  --pf-c-button--m-control--focus--BackgroundColor: rgba(255, 255, 255, 0.075) !important;
  --pf-c-button--m-control--focus--BorderBottomColor: #ffffff !important;
  --pf-c-button--m-control--active--BackgroundColor: rgba(255, 255, 255, 0.075) !important;
  --pf-c-button--m-control--active--BorderBottomColor: #ffffff !important;
  --pf-c-button--m-control--after--BorderWidth: 0 !important;

  /* Alert overrides */
  --pf-c-alert--BackgroundColor: rgba(255, 255, 255, 0.075) !important;
  --pf-c-alert__icon--Color: #ffffff !important;

  /* Form label */
  --pf-c-form__label--Color: #ffffff !important;
  --pf-c-form__label--FontSize: 0.8rem !important;

  /* Input group */
  --pf-c-input-group--BackgroundColor: transparent !important;

  /* Focus ring */
  --pf-global--focus--Color: #ffffff !important;
  --pf-global--focus--Width: 1px !important;
}

/* Override PF4 light-mode context on compound selectors */
.pf-c-page,
.pf-c-login,
.pf-c-login__main,
.pf-c-card,
.pf-m-light,
[class*="pf-"] {
  --pf-global--BackgroundColor--100: transparent !important;
  --pf-global--BackgroundColor--light-100: transparent !important;
  --pf-global--Color--100: #ffffff !important;
  --pf-global--primary-color--100: #ffffff !important;
}

/* Override PF4 variables directly on form-control */
.pf-c-form-control {
  --pf-c-form-control--BackgroundColor: transparent !important;
  --pf-c-form-control--Color: #ffffff !important;
  --pf-c-form-control--BorderTopColor: #ffffff !important;
  --pf-c-form-control--BorderRightColor: #ffffff !important;
  --pf-c-form-control--BorderBottomColor: #ffffff !important;
  --pf-c-form-control--BorderLeftColor: #ffffff !important;
}
.pf-c-form-control:hover {
  --pf-c-form-control--BorderBottomColor: #ffffff !important;
}
.pf-c-form-control:focus {
  --pf-c-form-control--BorderBottomColor: #ffffff !important;
}

/* Override PF4 variables directly on buttons */
.pf-c-button.pf-m-primary {
  --pf-c-button--m-primary--BackgroundColor: #ffffff !important;
  --pf-c-button--m-primary--Color: #1b1f22 !important;
}
.pf-c-button.pf-m-primary:hover {
  --pf-c-button--m-primary--hover--BackgroundColor: rgba(255, 255, 255, 0.9) !important;
}
.pf-c-button.pf-m-control {
  --pf-c-button--m-control--BackgroundColor: transparent !important;
  --pf-c-button--m-control--Color: rgba(255, 255, 255, 0.5) !important;
  --pf-c-button--m-control--BorderTopColor: #ffffff !important;
  --pf-c-button--m-control--BorderRightColor: #ffffff !important;
  --pf-c-button--m-control--BorderBottomColor: #ffffff !important;
  --pf-c-button--m-control--BorderLeftColor: #ffffff !important;
}

/* ── Reset & Base ────────────────────────────────── */
html, html.login-pf {
  height: 100%;
  box-sizing: border-box;
}
*, *:before, *:after {
  box-sizing: inherit;
}

body, html.login-pf body {
  background: var(--brand-bg) !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: #ffffff !important;
  min-height: 100vh !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Background Overlay Texture ──────────────────── */
.login-pf-page {
  background: var(--brand-bg) !important;
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
}
.login-pf-page::before {
  content: '' !important;
  display: block !important;
  position: fixed !important;
  top: 0; left: 0; right: 0; bottom: 0;
  background-image: linear-gradient(to top, rgba(19, 21, 25, 0.5), rgba(19, 21, 25, 0.5)),
                     url("../img/overlay.png") !important;
  background-size: auto, 256px 256px !important;
  background-position: center, center !important;
  background-repeat: no-repeat, repeat !important;
  z-index: 0 !important;
  pointer-events: none !important;
}
.login-pf-page > * {
  position: relative !important;
  z-index: 1 !important;
}

/* ── Header — Logo + App Name ────────────────────── */
#kc-header, .login-pf-page-header {
  background: transparent !important;
  width: 100% !important;
  text-align: center !important;
  padding: 0 !important;
  margin-bottom: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

/* Logo circle — like IT-Trail's bordered circle logo */
#kc-header-wrapper {
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  letter-spacing: 0.2rem !important;
  text-transform: uppercase !important;
  color: #ffffff !important;
  position: relative !important;
  padding-top: 6.5rem !important;
  margin-bottom: 1.5rem !important;
}

/* Circular logo image above the name */
#kc-header-wrapper::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 5.5rem !important;
  height: 5.5rem !important;
  border: solid 1px #ffffff !important;
  border-radius: 100% !important;
  background: var(--brand-logo-url) no-repeat center center !important;
  background-size: 60% !important;
}

/* Vertical connecting line — signature design element */
#kc-header-wrapper::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  top: 5.5rem !important;
  left: calc(50% - 0.5px) !important;
  width: 1px !important;
  height: 0.5rem !important;
  background: #ffffff !important;
}

/* ── Login Card ──────────────────────────────────── */
.card-pf {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  max-width: 32rem !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 2rem !important;
  position: relative !important;
}
.card-pf::before, .card-pf::after {
  display: none !important;
}

/* ── Page Title (hidden — logo + app name is enough) ─ */
.login-pf-header {
  display: none !important;
}

/* ── Powered By + Ecosystem Notice ────────────────── */
.ittrail-powered-by {
  text-align: center !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.7rem !important;
  color: rgba(255, 255, 255, 0.35) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15rem !important;
  margin-top: -1.5rem !important;
  margin-bottom: 1.5rem !important;
}

.ittrail-ecosystem-notice {
  text-align: center !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.85rem !important;
  color: rgba(255, 255, 255, 0.5) !important;
  margin-bottom: 2rem !important;
  line-height: 1.5 !important;
}

/* ── Typography ──────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: "Source Sans Pro", sans-serif !important;
  color: #ffffff !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2rem !important;
}

p, span, div {
  font-family: "Source Sans Pro", sans-serif;
}

strong, b {
  color: #ffffff !important;
  font-weight: 600 !important;
}

/* ── Labels ──────────────────────────────────────── */
label,
.pf-c-form__label,
.pf-c-form__label-text {
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.8rem !important;
  color: #ffffff !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2rem !important;
}

/* ── Form Inputs ─────────────────────────────────── */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
.pf-c-form-control {
  background-color: transparent !important;
  border: solid 1px #ffffff !important;
  border-radius: 4px !important;
  color: #ffffff !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 1rem !important;
  padding: 0 1rem !important;
  height: 2.75rem !important;
  line-height: 2.75rem !important;
  outline: 0 !important;
  box-shadow: none !important;
  display: block !important;
  width: 100% !important;
  transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out, background-color 0.2s ease-in-out !important;
}
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
.pf-c-form-control:focus {
  background: transparent !important;
  background-color: transparent !important;
  border-color: #ffffff !important;
  box-shadow: 0 0 0 1px #ffffff !important;
}
input::placeholder,
.pf-c-form-control::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
}

/* ── Password Field Group ────────────────────────── */
.pf-c-input-group {
  display: flex !important;
  width: 100% !important;
}
.pf-c-input-group .pf-c-form-control {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  border-right: none !important;
  flex: 1 !important;
}
.pf-c-input-group .pf-c-button.pf-m-control {
  background: transparent !important;
  border: solid 1px #ffffff !important;
  border-left: none !important;
  border-radius: 0 4px 4px 0 !important;
  color: rgba(255, 255, 255, 0.5) !important;
  padding: 0 0.75rem !important;
  cursor: pointer !important;
  min-width: 2.75rem !important;
  height: 2.75rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out !important;
}
.pf-c-input-group .pf-c-button.pf-m-control:hover {
  background: rgba(255, 255, 255, 0.075) !important;
  color: #ffffff !important;
}
.pf-c-input-group .pf-c-button.pf-m-control:focus {
  box-shadow: 0 0 0 1px #ffffff !important;
}

/* ── Form Groups ─────────────────────────────────── */
.form-group {
  margin-bottom: 1.5rem !important;
}
.login-pf-settings {
  margin-bottom: 1rem !important;
}

/* ── Submit Button (Primary — White fill) ────────── */
#kc-login,
.pf-c-button.pf-m-primary.pf-m-block {
  -moz-appearance: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  background-color: #ffffff !important;
  border: 0 !important;
  border-radius: 4px !important;
  box-shadow: none !important;
  color: #1b1f22 !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2rem !important;
  height: 2.75rem !important;
  line-height: 2.75rem !important;
  padding: 0 1.75rem !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out !important;
}
#kc-login:hover,
.pf-c-button.pf-m-primary.pf-m-block:hover {
  background-color: rgba(255, 255, 255, 0.9) !important;
}
#kc-login:active,
.pf-c-button.pf-m-primary.pf-m-block:active {
  background-color: rgba(255, 255, 255, 0.8) !important;
}

/* ── Default / Outline Buttons ───────────────────── */
.pf-c-button.pf-m-secondary,
.btn-default,
.button {
  -moz-appearance: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  background-color: transparent !important;
  border: 0 !important;
  border-radius: 4px !important;
  box-shadow: inset 0 0 0 1px #ffffff !important;
  color: #ffffff !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2rem !important;
  height: 2.75rem !important;
  line-height: 2.75rem !important;
  padding: 0 1.75rem !important;
  cursor: pointer !important;
  transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out !important;
}
.pf-c-button.pf-m-secondary:hover,
.btn-default:hover,
.button:hover {
  background-color: rgba(255, 255, 255, 0.075) !important;
}
.pf-c-button.pf-m-secondary:active,
.btn-default:active,
.button:active {
  background-color: rgba(255, 255, 255, 0.175) !important;
}

/* ── PF4 Button Ring Reset ───────────────────────── */
.pf-c-button::after {
  display: none !important;
}

/* ── Links ───────────────────────────────────────── */
a {
  border-bottom: dotted 1px rgba(255, 255, 255, 0.5) !important;
  text-decoration: none !important;
  color: inherit !important;
  transition: color 0.2s ease-in-out, border-bottom-color 0.2s ease-in-out !important;
}
a:hover, a:focus {
  border-bottom-color: transparent !important;
  color: #ffffff !important;
  text-decoration: none !important;
}

/* ── Registration / Info Section ─────────────────── */
#kc-info, #kc-info-wrapper, #kc-registration-container {
  text-align: center !important;
  margin-top: 2rem !important;
  padding-top: 0 !important;
  border-top: none !important;
  background: transparent !important;
  background-color: transparent !important;
}
html body .login-pf-page #kc-registration,
html body .login-pf-page #kc-registration span,
html body .login-pf-page #kc-registration div,
html body .login-pf-page #kc-info,
html body .login-pf-page #kc-info span,
html body .login-pf-page #kc-info div,
html body .login-pf-page #kc-info-wrapper,
#kc-registration,
#kc-registration span {
  color: rgba(255, 255, 255, 0.6) !important;
  font-size: 0.9rem !important;
  font-weight: 300 !important;
}
html body .login-pf-page #kc-registration a,
html body .login-pf-page #kc-info a,
#kc-registration a {
  color: #ffffff !important;
  font-weight: 300 !important;
  border-bottom: dotted 1px rgba(255, 255, 255, 0.5) !important;
}
html body .login-pf-page #kc-registration a:hover,
html body .login-pf-page #kc-info a:hover,
#kc-registration a:hover {
  border-bottom-color: transparent !important;
}

/* ── Social / Identity Provider Buttons ──────────── */
#kc-social-providers {
  margin-top: 2rem !important;
  padding-top: 2rem !important;
  border-top: solid 1px #ffffff !important;
}
#kc-social-providers a,
#kc-social-providers .pf-c-button {
  display: block !important;
  background-color: transparent !important;
  border: 0 !important;
  border-radius: 4px !important;
  box-shadow: inset 0 0 0 1px #ffffff !important;
  color: #ffffff !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2rem !important;
  height: 2.75rem !important;
  line-height: 2.75rem !important;
  padding: 0 1rem !important;
  margin-bottom: 0.75rem !important;
  text-align: center !important;
  transition: background-color 0.2s ease-in-out !important;
}
#kc-social-providers a:hover,
#kc-social-providers .pf-c-button:hover {
  background-color: rgba(255, 255, 255, 0.075) !important;
}
#kc-social-providers a:active,
#kc-social-providers .pf-c-button:active {
  background-color: rgba(255, 255, 255, 0.175) !important;
}

/* ── Alerts / Error Messages ─────────────────────── */
.alert, .pf-c-alert {
  background: rgba(255, 255, 255, 0.075) !important;
  border: none !important;
  border-radius: 4px !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 300 !important;
  color: #ffffff !important;
  padding: 0.75rem 1rem !important;
  margin-bottom: 1.5rem !important;
}
.alert-error, .alert-danger,
.pf-c-alert.pf-m-danger {
  background: rgba(255, 76, 76, 0.15) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 76, 76, 0.4) !important;
  color: #ff9999 !important;
}
.alert-warning, .pf-c-alert.pf-m-warning {
  background: rgba(255, 200, 55, 0.1) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 200, 55, 0.3) !important;
  color: #ffd966 !important;
}
.alert-success, .pf-c-alert.pf-m-success {
  background: rgba(46, 204, 113, 0.1) !important;
  box-shadow: inset 0 0 0 1px rgba(46, 204, 113, 0.3) !important;
  color: #82e6ad !important;
}
.alert-info, .pf-c-alert.pf-m-info {
  background: rgba(255, 255, 255, 0.05) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.15) !important;
  color: rgba(255, 255, 255, 0.7) !important;
}
.kc-feedback-text {
  color: inherit !important;
}
.pf-c-alert__icon {
  color: inherit !important;
}

/* ── Checkbox ────────────────────────────────────── */
.checkbox label, .checkbox-inline {
  color: rgba(255, 255, 255, 0.6) !important;
  font-weight: 300 !important;
  font-size: 0.85rem !important;
}
input[type="checkbox"] {
  accent-color: #ffffff !important;
}

/* ── Locale Selector ─────────────────────────────── */
#kc-locale {
  z-index: 100 !important;
}
#kc-locale ul {
  background: rgba(27, 31, 34, 0.95) !important;
  border: solid 1px #ffffff !important;
  border-radius: 4px !important;
}
#kc-locale a {
  color: rgba(255, 255, 255, 0.6) !important;
  border-bottom: none !important;
}
#kc-locale a:hover {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.075) !important;
}

/* ── Misc Containers ─────────────────────────────── */
#kc-content, #kc-content-wrapper, #kc-form, #kc-form-wrapper,
#kc-info-wrapper, #kc-registration-container {
  background: transparent !important;
  background-color: transparent !important;
}
/* Force white text on all form-related containers to beat PF3/PF4 grays */
html body .login-pf-page .card-pf,
html body .login-pf-page .card-pf span,
html body .login-pf-page .card-pf div,
html body .login-pf-page .card-pf p,
html body .login-pf-page #kc-content,
html body .login-pf-page #kc-content span,
html body .login-pf-page #kc-form-options,
html body .login-pf-page #kc-form-options span {
  color: rgba(255, 255, 255, 0.7) !important;
}
/* "Required fields" asterisk text */
html body .login-pf-page .subtitle,
html body .login-pf-page .required-field-text,
html body .login-pf-page span.required {
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 0.8rem !important;
}

.login-pf-signup {
  font-size: 0.9rem !important;
}

hr {
  border: 0 !important;
  border-bottom: solid 1px rgba(255, 255, 255, 0.3) !important;
  margin: 1.5rem 0 !important;
}

code {
  background: rgba(255, 255, 255, 0.075) !important;
  border-radius: 4px !important;
  font-size: 0.9rem !important;
  padding: 0.25rem 0.65rem !important;
}

/* ── Container Sizing ────────────────────────────── */
.login-pf .container-fluid,
.login-pf .container {
  max-width: 36rem !important;
  margin: 0 auto !important;
  padding: 0 1.5rem !important;
}

/* ── PF4 Deep Selector Overrides (nuclear) ──────── */
/* These use high-specificity selectors to beat PF4's compound rules */
html body .pf-c-form-control,
html body input.pf-c-form-control,
html body select.pf-c-form-control,
html body textarea.pf-c-form-control,
.login-pf .pf-c-form-control {
  background-color: transparent !important;
  background: transparent !important;
  color: #ffffff !important;
  border: solid 1px #ffffff !important;
  border-top-color: #ffffff !important;
  border-right-color: #ffffff !important;
  border-bottom-color: #ffffff !important;
  border-left-color: #ffffff !important;
  box-shadow: none !important;
}
html body .pf-c-form-control:hover,
.login-pf .pf-c-form-control:hover {
  border-bottom-color: #ffffff !important;
  background-color: transparent !important;
}
html body .pf-c-form-control:focus,
.login-pf .pf-c-form-control:focus {
  background: transparent !important;
  background-color: transparent !important;
  border-color: #ffffff !important;
  border-bottom-color: #ffffff !important;
  box-shadow: 0 0 0 1px #ffffff !important;
}

html body .pf-c-button.pf-m-primary,
.login-pf .pf-c-button.pf-m-primary,
html body #kc-login {
  background-color: #ffffff !important;
  color: #1b1f22 !important;
  border: 0 !important;
  box-shadow: none !important;
}
html body .pf-c-button.pf-m-primary:hover,
.login-pf .pf-c-button.pf-m-primary:hover,
html body #kc-login:hover {
  background-color: rgba(255, 255, 255, 0.9) !important;
  color: #1b1f22 !important;
}

html body .pf-c-button.pf-m-control,
.login-pf .pf-c-button.pf-m-control,
html body .pf-c-input-group .pf-c-button.pf-m-control {
  background-color: transparent !important;
  background: transparent !important;
  color: rgba(255, 255, 255, 0.5) !important;
  border: solid 1px #ffffff !important;
  border-left: none !important;
  box-shadow: none !important;
}
html body .pf-c-button.pf-m-control:hover,
.login-pf .pf-c-button.pf-m-control:hover {
  background-color: rgba(255, 255, 255, 0.075) !important;
  color: #ffffff !important;
  border-bottom-color: #ffffff !important;
}
/* PF4 ::after pseudo on buttons (focus ring) */
html body .pf-c-button.pf-m-control::after,
html body .pf-c-button.pf-m-primary::after {
  border: 0 !important;
  box-shadow: none !important;
}

/* ── Legal Footer ───────────────────────────────── */
.ittrail-legal-footer {
  text-align: center !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.75rem !important;
  color: rgba(255, 255, 255, 0.35) !important;
  margin-top: 3rem !important;
  padding-top: 1.5rem !important;
  border-top: solid 1px rgba(255, 255, 255, 0.1) !important;
}
.ittrail-legal-footer a {
  color: rgba(255, 255, 255, 0.5) !important;
  border-bottom: none !important;
  text-decoration: none !important;
  transition: color 0.2s ease-in-out !important;
}
.ittrail-legal-footer a:hover {
  color: #ffffff !important;
}
.ittrail-legal-sep {
  margin: 0 0.5rem !important;
  color: rgba(255, 255, 255, 0.25) !important;
}

/* ── Social Login Notice ────────────────────────── */
.ittrail-social-notice {
  text-align: center !important;
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.7rem !important;
  color: rgba(255, 255, 255, 0.35) !important;
  margin-top: 0.75rem !important;
  line-height: 1.4 !important;
}
.ittrail-social-notice a {
  color: rgba(255, 255, 255, 0.5) !important;
  border-bottom: none !important;
}
.ittrail-social-notice a:hover {
  color: #ffffff !important;
}

/* ── Terms Page ─────────────────────────────────── */
#kc-terms-text {
  font-family: "Source Sans Pro", sans-serif !important;
  font-weight: 300 !important;
  font-size: 0.95rem !important;
  color: rgba(255, 255, 255, 0.7) !important;
  line-height: 1.65 !important;
  text-align: center !important;
  margin-bottom: 2rem !important;
}
#kc-terms-text a {
  color: #ffffff !important;
  border-bottom: dotted 1px rgba(255, 255, 255, 0.5) !important;
}
#kc-terms-text a:hover {
  border-bottom-color: transparent !important;
}

/* ── Responsive ──────────────────────────────────── */
@media screen and (max-width: 736px) {
  #kc-header-wrapper {
    padding-top: 5.5rem !important;
    margin-bottom: 1rem !important;
    font-size: 0.85rem !important;
  }
  #kc-header-wrapper::before {
    width: 4.5rem !important;
    height: 4.5rem !important;
  }
  #kc-header-wrapper::after {
    top: 4.5rem !important;
    height: 0.5rem !important;
  }
  .card-pf {
    padding: 0 1rem !important;
  }
  html {
    font-size: 11pt !important;
  }
}

@media screen and (max-width: 360px) {
  html {
    font-size: 10pt !important;
  }
}
