/* ============================================================
   iSkill Masters – Material Design Override
   Transforms AdminLTE 3 into a polished, Material-UI-like theme.
   Author: Sankale  |  Updated: Feb 2026
   ============================================================ */

/* ---------- 0. CSS Custom Properties (Design Tokens) ---------- */
:root {
  --md-primary:        #1565C0;
  --md-primary-dark:   #0D47A1;
  --md-primary-light:  #42A5F5;
  --md-accent:         #00BFA5;
  --md-accent-dark:    #00897B;
  --md-surface:        #FFFFFF;
  --md-background:     #F5F7FA;
  --md-sidebar:        #0A1929;
  --md-sidebar-hover:  rgba(255,255,255,.08);
  --md-sidebar-active: rgba(21,101,192,.35);
  --md-text-primary:   #212121;
  --md-text-secondary: #616161;
  --md-text-hint:      #9E9E9E;
  --md-divider:        #E0E0E0;
  --md-success:        #2E7D32;
  --md-warning:        #F57F17;
  --md-danger:         #C62828;
  --md-info:           #0277BD;
  --md-radius:         8px;
  --md-radius-lg:      12px;
  --md-shadow-1:       0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.14);
  --md-shadow-2:       0 3px 6px rgba(0,0,0,.10), 0 3px 6px rgba(0,0,0,.12);
  --md-shadow-3:       0 10px 20px rgba(0,0,0,.10), 0 6px 6px rgba(0,0,0,.10);
  --md-shadow-4:       0 14px 28px rgba(0,0,0,.12), 0 10px 10px rgba(0,0,0,.08);
  --md-transition:     all .25s cubic-bezier(.4,0,.2,1);
}

/* ---------- 1. Typography & Base ---------- */
body, .wrapper {
  font-family: 'Roboto', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif !important;
  background: var(--md-background) !important;
  color: var(--md-text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.card-title, .content-header h1 {
  font-weight: 500 !important;
  letter-spacing: .01em;
  color: var(--md-text-primary);
}

.content-header h1 {
  font-size: 1.45rem !important;
}

/* ---------- 2. Cards – Material Elevation ---------- */
.card {
  border: none !important;
  border-radius: var(--md-radius-lg) !important;
  box-shadow: var(--md-shadow-1) !important;
  transition: var(--md-transition);
  overflow: hidden;
  margin-bottom: 1.5rem;
}
.card:hover {
  box-shadow: var(--md-shadow-2) !important;
}
.card-header {
  background: var(--md-surface) !important;
  border-bottom: 1px solid var(--md-divider) !important;
  padding: 1rem 1.25rem !important;
  font-weight: 500;
}
.card-header .card-title {
  font-size: 1.05rem !important;
  margin-bottom: 0;
}
.card-body {
  padding: 1.25rem !important;
}
.card-footer {
  background: var(--md-surface) !important;
  border-top: 1px solid var(--md-divider) !important;
  padding: 1rem 1.25rem !important;
}

/* Card colour accents (keep "card-info / card-primary" headers themed) */
.card-info > .card-header,
.card-primary > .card-header {
  background: linear-gradient(135deg, var(--md-primary), var(--md-primary-light)) !important;
  color: #fff !important;
  border-bottom: none !important;
}
.card-info > .card-header .card-title,
.card-primary > .card-header .card-title {
  color: #fff !important;
}
.card-success > .card-header {
  background: linear-gradient(135deg, var(--md-success), #43A047) !important;
  color: #fff !important;
  border-bottom: none !important;
}
.card-warning > .card-header {
  background: linear-gradient(135deg, var(--md-warning), #FF8F00) !important;
  color: #fff !important;
  border-bottom: none !important;
}
.card-danger > .card-header {
  background: linear-gradient(135deg, var(--md-danger), #E53935) !important;
  color: #fff !important;
  border-bottom: none !important;
}

/* ---------- 3. Buttons – Material Raised ---------- */
.btn {
  border-radius: 6px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  font-size: .8125rem !important;
  letter-spacing: .04em;
  padding: .45rem 1.1rem !important;
  transition: var(--md-transition);
  box-shadow: var(--md-shadow-1);
  border: none !important;
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.15);
  opacity: 0;
  transition: opacity .3s;
}
.btn:hover::after { opacity: 1; }
.btn:active { transform: scale(.97); }

.btn-primary {
  background: linear-gradient(135deg, var(--md-primary), var(--md-primary-light)) !important;
  color: #fff !important;
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--md-primary-dark), var(--md-primary)) !important;
  box-shadow: var(--md-shadow-2) !important;
}
.btn-success {
  background: linear-gradient(135deg, var(--md-success), #43A047) !important;
  color: #fff !important;
}
.btn-success:hover {
  box-shadow: var(--md-shadow-2) !important;
}
.btn-info {
  background: linear-gradient(135deg, var(--md-info), #039BE5) !important;
  color: #fff !important;
}
.btn-info:hover {
  box-shadow: var(--md-shadow-2) !important;
}
.btn-danger {
  background: linear-gradient(135deg, var(--md-danger), #E53935) !important;
  color: #fff !important;
}
.btn-danger:hover {
  box-shadow: var(--md-shadow-2) !important;
}
.btn-warning {
  background: linear-gradient(135deg, var(--md-warning), #FF8F00) !important;
  color: #fff !important;
}
.btn-default, .btn-flat {
  background: #fff !important;
  color: var(--md-primary) !important;
  border: 1px solid var(--md-divider) !important;
  box-shadow: none !important;
}
.btn-default:hover, .btn-flat:hover {
  background: #F5F5F5 !important;
  box-shadow: var(--md-shadow-1) !important;
}
.btn-xs {
  padding: .25rem .65rem !important;
  font-size: .72rem !important;
  border-radius: 4px !important;
}
.btn-sm {
  padding: .35rem .85rem !important;
  font-size: .76rem !important;
}

/* ---------- 4. Form Controls – Material-Inspired ---------- */
.form-control {
  border: 1px solid var(--md-divider) !important;
  border-radius: 6px !important;
  padding: .55rem .85rem !important;
  font-size: .9rem !important;
  background: #FAFAFA !important;
  transition: var(--md-transition);
  color: var(--md-text-primary) !important;
}
.form-control:focus {
  border-color: var(--md-primary) !important;
  box-shadow: 0 0 0 3px rgba(21,101,192,.15) !important;
  background: #fff !important;
  outline: none;
}
.form-control::placeholder {
  color: var(--md-text-hint) !important;
}

label, .form-group label {
  font-weight: 500 !important;
  font-size: .85rem !important;
  color: var(--md-text-secondary) !important;
  margin-bottom: .35rem !important;
  letter-spacing: .01em;
}

select.form-control {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23616161' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right .75rem center !important;
  padding-right: 2rem !important;
}

textarea.form-control {
  min-height: 80px;
}

.input-group-text {
  background: #FAFAFA !important;
  border: 1px solid var(--md-divider) !important;
  border-radius: 0 6px 6px 0 !important;
  color: var(--md-text-hint) !important;
}
.input-group .form-control {
  border-right: none !important;
  border-radius: 6px 0 0 6px !important;
}

/* ---------- 5. Tables – Clean & Polished ---------- */
.table {
  border-collapse: separate !important;
  border-spacing: 0;
}
.table thead th {
  background: var(--md-primary) !important;
  color: #fff !important;
  font-weight: 500 !important;
  font-size: .82rem !important;
  text-transform: uppercase;
  letter-spacing: .03em;
  border: none !important;
  padding: .75rem 1rem !important;
  white-space: nowrap;
}
.table thead th:first-child { border-radius: 8px 0 0 0; }
.table thead th:last-child  { border-radius: 0 8px 0 0; }

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(21,101,192,.03) !important;
}
.table tbody td {
  padding: .7rem 1rem !important;
  font-size: .875rem;
  vertical-align: middle !important;
  border-top: 1px solid #F0F0F0 !important;
}
.table tbody tr {
  transition: background .2s;
}
.table tbody tr:hover {
  background-color: rgba(21,101,192,.06) !important;
}
.table-bordered {
  border: none !important;
}
.table-bordered td, .table-bordered th {
  border: none !important;
  border-top: 1px solid #F0F0F0 !important;
}

/* DataTables overrides */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
  border: 1px solid var(--md-divider) !important;
  border-radius: 6px !important;
  padding: .35rem .65rem !important;
  background: #FAFAFA !important;
  transition: var(--md-transition);
}
.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--md-primary) !important;
  box-shadow: 0 0 0 3px rgba(21,101,192,.15) !important;
  background: #fff !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 6px !important;
  border: none !important;
  margin: 0 2px !important;
  transition: var(--md-transition);
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--md-primary) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: var(--md-shadow-1);
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
  background: rgba(21,101,192,.1) !important;
  color: var(--md-primary) !important;
  border: none !important;
}
.dataTables_wrapper .dataTables_info {
  font-size: .82rem;
  color: var(--md-text-secondary);
}

/* ---------- 6. Alerts – Material Snackbar Style ---------- */
.alert {
  border: none !important;
  border-radius: var(--md-radius) !important;
  box-shadow: var(--md-shadow-1);
  font-weight: 400;
  font-size: .9rem;
  padding: .85rem 1.25rem !important;
}
.alert-success {
  background: #E8F5E9 !important;
  color: var(--md-success) !important;
  border-left: 4px solid var(--md-success) !important;
}
.alert-warning {
  background: #FFF8E1 !important;
  color: #E65100 !important;
  border-left: 4px solid var(--md-warning) !important;
}
.alert-danger {
  background: #FFEBEE !important;
  color: var(--md-danger) !important;
  border-left: 4px solid var(--md-danger) !important;
}
.alert-info {
  background: #E1F5FE !important;
  color: var(--md-info) !important;
  border-left: 4px solid var(--md-info) !important;
}
.alert .close {
  opacity: .6;
  text-shadow: none;
}
.alert .close:hover { opacity: 1; }

/* ---------- 7. Sidebar – Material Dark Theme ---------- */
.main-sidebar {
  background: var(--md-sidebar) !important;
  box-shadow: var(--md-shadow-3) !important;
  transition: var(--md-transition);
}
[class*=sidebar-dark-] {
  background: var(--md-sidebar) !important;
}
[class*=sidebar-dark-] .brand-link {
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  padding: .9rem 1rem !important;
}
.brand-link .brand-text {
  font-weight: 600 !important;
  font-size: 1.1rem !important;
  letter-spacing: .02em;
}
.brand-image {
  border: 2px solid rgba(255,255,255,.2);
}

/* User Panel */
[class*=sidebar-dark-] .user-panel {
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  padding-bottom: .75rem !important;
}
.user-panel .image img {
  border: 2px solid rgba(255,255,255,.25) !important;
  width: 42px !important;
  height: 42px !important;
  object-fit: cover;
}
.user-panel .info a {
  font-weight: 500 !important;
  font-size: .88rem !important;
}

/* Sidebar nav links */
[class*=sidebar-dark-] .nav-sidebar > .nav-item > .nav-link {
  border-radius: 6px !important;
  margin: 2px 8px !important;
  padding: .6rem .85rem !important;
  transition: var(--md-transition);
  font-size: .875rem;
}
[class*=sidebar-dark-] .nav-sidebar > .nav-item > .nav-link:hover {
  background: var(--md-sidebar-hover) !important;
}
[class*=sidebar-dark-] .nav-sidebar > .nav-item > .nav-link.active,
[class*=sidebar-dark-] .nav-sidebar > .nav-item.menu-open > .nav-link {
  background: var(--md-sidebar-active) !important;
  color: var(--md-primary-light) !important;
}
[class*=sidebar-dark-] .nav-sidebar .nav-icon {
  font-size: 1rem;
  width: 1.6rem;
  text-align: center;
}
[class*=sidebar-dark-] .nav-treeview {
  background: rgba(0,0,0,.15) !important;
  border-radius: 0 0 6px 6px;
  margin: 0 8px !important;
  padding: 4px 0;
}
[class*=sidebar-dark-] .nav-treeview > .nav-item > .nav-link {
  padding: .4rem .85rem .4rem 2.2rem !important;
  font-size: .83rem;
  border-radius: 4px !important;
  margin: 1px 4px !important;
  transition: var(--md-transition);
}
[class*=sidebar-dark-] .nav-treeview > .nav-item > .nav-link:hover {
  background: rgba(255,255,255,.06) !important;
}
[class*=sidebar-dark-] .nav-treeview > .nav-item > .nav-link.active {
  color: var(--md-primary-light) !important;
}
.form-control-sidebar {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
  color: #ccc !important;
  border-radius: 6px !important;
}
.form-control-sidebar:focus {
  background: rgba(255,255,255,.12) !important;
  border-color: var(--md-primary-light) !important;
}

/* ---------- 8. Top Navbar – Clean & Elevated ---------- */
.main-header.navbar {
  background: var(--md-surface) !important;
  border-bottom: none !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.08) !important;
  min-height: 56px;
}
.main-header .nav-link {
  color: var(--md-text-secondary) !important;
  transition: var(--md-transition);
  padding: .5rem .75rem !important;
  border-radius: 50%;
}
.main-header .nav-link:hover {
  color: var(--md-primary) !important;
  background: rgba(21,101,192,.06);
}
.main-header .navbar-badge {
  font-size: .6rem;
  padding: 2px 5px;
  border-radius: 10px;
}

/* User dropdown in navbar */
.user-menu .dropdown-toggle {
  display: flex !important;
  align-items: center;
  gap: .5rem;
  border-radius: 24px !important;
  padding: 4px 12px 4px 4px !important;
}
.user-menu .dropdown-toggle:hover {
  background: rgba(21,101,192,.06) !important;
}
.user-menu .user-image {
  border-radius: 50%;
  width: 34px !important;
  height: 34px !important;
  object-fit: cover;
  border: 2px solid var(--md-divider);
}
.dropdown-menu {
  border: none !important;
  border-radius: var(--md-radius) !important;
  box-shadow: var(--md-shadow-3) !important;
  padding: .5rem 0;
  animation: mdFadeIn .2s ease;
}
@keyframes mdFadeIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dropdown-item {
  padding: .5rem 1rem;
  font-size: .875rem;
  transition: var(--md-transition);
  border-radius: 4px;
  margin: 0 4px;
}
.dropdown-item:hover {
  background: rgba(21,101,192,.06) !important;
  color: var(--md-primary) !important;
}

/* ---------- 9. Breadcrumbs – Material Style ---------- */
.breadcrumb {
  background: transparent !important;
  padding: 0 !important;
  margin: 0;
  font-size: .85rem;
}
.breadcrumb-item a {
  color: var(--md-primary) !important;
  text-decoration: none;
  font-weight: 500;
}
.breadcrumb-item a:hover {
  text-decoration: underline;
}
.breadcrumb-item.active {
  color: var(--md-text-hint) !important;
}
.breadcrumb-item + .breadcrumb-item::before {
  content: '›' !important;
  color: var(--md-text-hint);
  font-weight: 600;
}

.content-header {
  padding: 1rem .5rem .5rem !important;
}

/* ---------- 10. Footer – Subtle & Clean ---------- */
.main-footer {
  background: var(--md-surface) !important;
  border-top: 1px solid var(--md-divider) !important;
  color: var(--md-text-hint) !important;
  font-size: .8rem !important;
  padding: .75rem 1rem !important;
}
.main-footer a {
  color: var(--md-primary) !important;
  font-weight: 500;
}

/* ---------- 11. Login / Register Pages ---------- */
.login-page, .register-page {
  background: #F5F7FA !important;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-box, .register-box {
  width: 420px !important;
  max-width: 95vw;
}
.login-box .card, .register-box .card {
  border-radius: var(--md-radius) !important;
  box-shadow: var(--md-shadow-1) !important;
  border: 1px solid var(--md-divider) !important;
  overflow: hidden;
}
.login-box .card-outline, .register-box .card-outline {
  border-top: none !important;
}
.login-box .card-header, .register-box .card-header {
  background: var(--md-surface) !important;
  border-bottom: 1px solid var(--md-divider) !important;
  padding: 1.25rem 1rem !important;
}
.login-box .card-header a, .register-box .card-header a {
  color: var(--md-text-primary) !important;
  font-weight: 600 !important;
  text-decoration: none;
}
.login-box .card-body, .register-box .card-body {
  padding: 1.5rem !important;
}
.login-box-msg {
  font-size: .9rem !important;
  color: var(--md-text-secondary) !important;
  margin-bottom: 1rem !important;
}
.login-box .input-group, .register-box .input-group {
  margin-bottom: .85rem !important;
}
.login-box .btn-primary, .register-box .btn-primary {
  width: 100%;
}
.login-box .icheck-primary label, .register-box .icheck-primary label {
  font-size: .82rem !important;
  color: var(--md-text-secondary) !important;
}

/* ---------- 12. Content Wrapper ---------- */
.content-wrapper {
  background: var(--md-background) !important;
}
.content {
  padding: 0 .5rem !important;
}

/* ---------- 13. Badges & Chips ---------- */
.badge {
  border-radius: 12px !important;
  font-weight: 500 !important;
  font-size: .72rem !important;
  padding: .25rem .65rem !important;
  letter-spacing: .02em;
}

/* ---------- 14. Modals ---------- */
.modal-content {
  border: none !important;
  border-radius: var(--md-radius-lg) !important;
  box-shadow: var(--md-shadow-4) !important;
}
.modal-header {
  border-bottom: 1px solid var(--md-divider) !important;
  padding: 1rem 1.25rem !important;
}
.modal-footer {
  border-top: 1px solid var(--md-divider) !important;
  padding: .75rem 1.25rem !important;
}

/* ---------- 15. Scrollbar ---------- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,.18);
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,.3); }

/* ---------- 16. Utility – Inline delete forms ---------- */
.datatable_inline_delete {
  display: inline;
}

/* ---------- 17. Select2 Material override ---------- */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  border: 1px solid var(--md-divider) !important;
  border-radius: 6px !important;
  min-height: 38px !important;
  background: #FAFAFA !important;
  transition: var(--md-transition);
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--md-primary) !important;
  box-shadow: 0 0 0 3px rgba(21,101,192,.15) !important;
}
.select2-dropdown {
  border: none !important;
  box-shadow: var(--md-shadow-3) !important;
  border-radius: var(--md-radius) !important;
}
.select2-results__option--highlighted {
  background: rgba(21,101,192,.1) !important;
  color: var(--md-primary) !important;
}

/* ---------- 18. Animations ---------- */
@keyframes mdSlideIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.content-wrapper .card {
  animation: mdSlideIn .35s ease;
}

/* ---------- 19. Home Welcome Card ---------- */
.welcome-card {
  background: linear-gradient(135deg, var(--md-primary), var(--md-primary-light)) !important;
  color: #fff !important;
  border-radius: var(--md-radius-lg) !important;
  padding: 2.5rem !important;
  text-align: center;
}
.welcome-card h2 { color: #fff !important; font-weight: 300 !important; }
.welcome-card h3 { color: rgba(255,255,255,.85) !important; font-weight: 400 !important; font-style: italic; }
.welcome-card .img-circle {
  border: 3px solid rgba(255,255,255,.4) !important;
  box-shadow: 0 4px 15px rgba(0,0,0,.2);
}
.welcome-card .btn-warning {
  margin-top: 1.5rem;
  background: rgba(255,255,255,.2) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.4) !important;
  backdrop-filter: blur(4px);
}
.welcome-card .btn-warning:hover {
  background: rgba(255,255,255,.35) !important;
}

/* ---------- 20. Card Outline Override ---------- */
.card-outline.card-primary {
  border-top: 3px solid var(--md-primary) !important;
}
.card-outline.card-info {
  border-top: 3px solid var(--md-info) !important;
}
.card-outline.card-success {
  border-top: 3px solid var(--md-success) !important;
}
.card-outline.card-danger {
  border-top: 3px solid var(--md-danger) !important;
}
.card-outline.card-warning {
  border-top: 3px solid var(--md-warning) !important;
}

/* ---------- 21. Outline Buttons ---------- */
.btn-outline-primary {
  background: transparent !important;
  color: var(--md-primary) !important;
  border: 2px solid var(--md-primary) !important;
  box-shadow: none !important;
}
.btn-outline-primary:hover {
  background: rgba(21,101,192,.08) !important;
  color: var(--md-primary-dark) !important;
  box-shadow: var(--md-shadow-1) !important;
}
.btn-outline-secondary {
  background: transparent !important;
  color: var(--md-text-secondary) !important;
  border: 2px solid var(--md-divider) !important;
  box-shadow: none !important;
}
.btn-outline-secondary:hover {
  background: rgba(0,0,0,.04) !important;
}

/* ---------- 22. Page-Header Actions Row ---------- */
.card-header .btn.float-sm-right {
  margin-top: -2px;
}

/* ---------- 23. Tabs – Material Style ---------- */
.nav-tabs {
  border-bottom: 2px solid var(--md-divider) !important;
}
.nav-tabs .nav-link {
  border: none !important;
  border-bottom: 3px solid transparent !important;
  padding: .65rem 1.25rem !important;
  font-weight: 500;
  color: var(--md-text-secondary) !important;
  transition: var(--md-transition);
  text-transform: uppercase;
  font-size: .8125rem;
  letter-spacing: .03em;
}
.nav-tabs .nav-link:hover {
  border-bottom-color: rgba(21,101,192,.3) !important;
  color: var(--md-primary) !important;
  background: transparent !important;
}
.nav-tabs .nav-link.active {
  color: var(--md-primary) !important;
  border-bottom-color: var(--md-primary) !important;
  background: transparent !important;
}

/* ---------- 24. Progress Bars ---------- */
.progress {
  border-radius: 20px !important;
  height: .5rem;
  background: #E0E0E0 !important;
}
.progress-bar {
  border-radius: 20px !important;
  background: linear-gradient(90deg, var(--md-primary), var(--md-primary-light)) !important;
}

/* ---------- 25. Pagination – Material Style ---------- */
.pagination .page-link {
  border: none !important;
  border-radius: 6px !important;
  margin: 0 2px;
  padding: .4rem .75rem;
  color: var(--md-text-secondary) !important;
  font-weight: 500;
  transition: var(--md-transition);
}
.pagination .page-link:hover {
  background: rgba(21,101,192,.08) !important;
  color: var(--md-primary) !important;
}
.pagination .page-item.active .page-link {
  background: var(--md-primary) !important;
  color: #fff !important;
  box-shadow: var(--md-shadow-1);
}

/* ---------- 26. Tooltip Overrides ---------- */
.tooltip-inner {
  background: #37474F !important;
  border-radius: 6px !important;
  font-size: .78rem;
  padding: .4rem .8rem;
}

/* ---------- 27. Dual-List & Multi-select ---------- */
.dual-listbox .dual-listbox__search {
  border: 1px solid var(--md-divider) !important;
  border-radius: 6px !important;
  padding: .45rem .75rem !important;
}

/* ---------- 28. Responsive Polish ---------- */
@media (max-width: 768px) {
  .content-header h1 { font-size: 1.2rem !important; }
  .card-body { padding: 1rem !important; }
  .welcome-card { padding: 1.5rem !important; }
  .welcome-card h2 { font-size: 1.3rem !important; }
  .login-box, .register-box { width: 95vw !important; }
}