:root {
  /* Steel/azure palette — derived from login splash (login-bg-20). Single source of truth. */
  --steel-50:  #EAF3FA;
  --steel-100: #CFE6F4;
  --steel-200: #A9D2EC;
  --steel-300: #7FBCE2;
  --steel-400: #43A3D4;
  --steel-500: #3291CB;
  --steel-600: #0E6FB5; /* primary (AA on white) */
  --steel-700: #0A5A95; /* hover / active */
  --steel-800: #084C7E; /* deep — sidebar, panel headings */
  --steel-900: #063A60; /* deepest — flyout */
  --steel-600-rgb: 14, 111, 181;

  /* App theme tokens (consumed by template + components) */
  --bs-app-theme: var(--steel-600) !important;
  --bs-app-theme-rgb: 14, 111, 181 !important;
  --bs-app-theme-color: #ffffff !important;
  --bs-app-theme-color-rgb: 255, 255, 255 !important;
  --bs-app-theme-hover: var(--steel-700) !important;
  --bs-app-theme-hover-border-color: var(--steel-700) !important;
}

button.btn.btn-primary,
button.btn.btn-primary:focus,
button.btn.btn-primary:active,
button.btn.btn-primary.active,
button.btn.btn-primary:focus:active,
button.btn.btn-primary:visited,
button.btn.btn-primary:target,
button.btn.btn-primary:focus-visible {
  background-color: var(--bs-app-theme) !important;
  border-color: var(--bs-app-theme) !important;
  color: var(--bs-app-theme-color) !important;
  box-shadow: none !important;
  outline: none !important;
}

button.btn.btn-primary:active,
button.btn.btn-primary.active {
  background-color: var(--bs-app-theme-hover) !important;
  border-color: var(--bs-app-theme-hover-border-color) !important;
  color: var(--bs-app-theme-color) !important;
  box-shadow: none !important;
}

button.btn.btn-theme,
button.btn.btn-theme:focus,
button.btn.btn-theme:active,
button.btn.btn-theme.active,
button.btn.btn-theme:focus:active,
button.btn.btn-theme:visited,
button.btn.btn-theme:target,
button.btn.btn-theme:focus-visible {
  background-color: var(--bs-app-theme) !important;
  border-color: var(--bs-app-theme) !important;
  color: var(--bs-app-theme-color) !important;
  box-shadow: none !important;
  outline: none !important;
}

button.btn.btn-theme:active,
button.btn.btn-theme.active {
  background-color: var(--bs-app-theme-hover) !important;
  border-color: var(--bs-app-theme-hover-border-color) !important;
  color: var(--bs-app-theme-color) !important;
  box-shadow: none !important;
}

.login.login-v2 .login-header .brand .logo {
  display: inline-block;
  width: 149px;
  height: 52px;
  background-image: url('/assets/img/logo_only.svg') !important;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border: none !important;
  background-color: transparent !important;
  font-size: 0;
}

/* Override Parsley.js error styling to match Bootstrap's alert-danger */
.login .form-floating .form-control {
  background-color: #fff !important;
}

.gritter-error {
  background-color: #331211 !important;   /* Bootstrap bg-subtle */
  color: #ff9d9a !important;              /* Bootstrap text-emphasis */
  border-left: 5px solid #f5c2c7;         /* Bootstrap border-subtle */
  font-weight: 500;
  border-radius: 4px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.gritter-success {
  background-color: #102b18 !important;    /* Dark green background */
  color: #9ae6b4 !important;               /* Bootstrap-like success text (#198754 alt) */
  border-left: 5px solid #7dd3a9;          /* Subtle green border */
  font-weight: 500;
  border-radius: 4px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.gritter-title-success {
  color: #75b798 !important; /* Bootstrap success-emphasis */
  font-weight: bold;
}
.gritter-title-info {
  color: #6ea8fe !important; /* Bootstrap info-emphasis */
  font-weight: bold;
}
.gritter-title-warning {
  color: #ffda6a !important; /* Bootstrap warning-emphasis */
  font-weight: bold;
}
.gritter-title-error {
  color: #ff9d9a !important; /* Bootstrap danger-emphasis */
  font-weight: bold;
}

.login .form-control.parsley-success {
  border-color: #28a745 !important;
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25) !important;
}

.login .form-control.parsley-error {
  border-color: #dc3545 !important;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

/* Blue theme link styling */
a.text-primary,
.login a {
  color: var(--bs-app-theme) !important;
}

a.text-primary:hover,
.login a:hover {
  color: var(--bs-app-theme-hover) !important;
}

/* Outline theme button */
.btn-outline-theme {
  color: var(--bs-app-theme) !important;
  border-color: var(--bs-app-theme) !important;
  background-color: transparent !important;
}

.btn-outline-theme:hover,
.btn-outline-theme:focus {
  color: var(--bs-app-theme-color) !important;
  background-color: var(--bs-app-theme) !important;
  border-color: var(--bs-app-theme) !important;
}

/* Login header brand styling for news-feed layout */
.login.login-with-news-feed .login-header .brand b {
  color: var(--bs-app-theme) !important;
}

/* Form focus states with blue theme */
.login .form-control:focus {
  border-color: var(--bs-app-theme) !important;
  box-shadow: 0 0 0 0.2rem rgba(var(--steel-600-rgb), 0.25) !important;
}

/* Login divider line */
.login-divider .line {
  background-color: rgba(var(--steel-600-rgb), 0.3) !important;
}

/* Icon in login header */
.login .login-header .icon {
  color: #dee2e6 !important;
}

/* Brand logo and text styling */
.login .login-header .brand-logo {
  height: 24px;
  width: auto;
  filter: none !important;
  opacity: 1 !important;
}

.login .login-header .brand-text {
  font-size: 1.75rem;
  letter-spacing: -0.5px;
}

.login .login-header .brand-text b {
  color: #2d353c;
  font-weight: 700;
}

.login .login-header .brand-text .text-gray-500 {
  font-weight: 300;
  margin-left: 2px;
}