:root {
  --bs-app-theme: #0077cc !important;
  --bs-app-theme-rgb: 0, 119, 204 !important;
  --bs-app-theme-color: #ffffff !important;
  --bs-app-theme-color-rgb: 255, 255, 255 !important;
  --bs-app-theme-hover: #005fa3 !important;
  --bs-app-theme-hover-border-color: #005fa3 !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(0, 119, 204, 0.25) !important;
}

/* Login divider line */
.login-divider .line {
  background-color: rgba(0, 119, 204, 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;
}