/* ============================================================
   MODERN THEME - LCR Outbound Switch
   Premium Design System
   ============================================================ */

/* === DESIGN TOKENS === */
:root {
  /* Primary Palette - Refined Emerald */
  --color-primary: #10B981;
  --color-primary-hover: #059669;
  --color-primary-active: #047857;
  --color-primary-light: #D1FAE5;
  --color-primary-50: #ECFDF5;
  --color-primary-100: #D1FAE5;
  --color-primary-200: #A7F3D0;
  --color-primary-300: #6EE7B7;
  --color-primary-400: #34D399;
  --color-primary-500: #10B981;
  --color-primary-600: #059669;
  --color-primary-700: #047857;

  /* Neutral Palette - Slate */
  --color-bg: #F1F5F9;
  --color-bg-subtle: #F8FAFC;
  --color-surface: #FFFFFF;
  --color-surface-raised: #FFFFFF;
  --color-surface-hover: #F8FAFC;
  --color-border: #E2E8F0;
  --color-border-light: #F1F5F9;
  --color-border-strong: #CBD5E1;

  /* Text */
  --color-text: #0F172A;
  --color-text-secondary: #475569;
  --color-text-tertiary: #94A3B8;
  --color-text-inverse: #FFFFFF;
  --color-text-link: #10B981;

  /* Semantic */
  --color-success: #10B981;
  --color-success-light: #ECFDF5;
  --color-warning: #F59E0B;
  --color-warning-light: #FFFBEB;
  --color-error: #EF4444;
  --color-error-light: #FEF2F2;
  --color-info: #3B82F6;
  --color-info-light: #EFF6FF;

  /* Accent Colors for Stats */
  --color-teal: #14B8A6;
  --color-blue: #3B82F6;
  --color-violet: #8B5CF6;
  --color-amber: #F59E0B;
  --color-rose: #F43F5E;
  --color-cyan: #06B6D4;

  /* Shadows - Subtle, layered */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.08), 0 8px 10px -6px rgba(0, 0, 0, 0.04);
  --shadow-glow: 0 0 20px rgba(16, 185, 129, 0.15);
  --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-card-hover: 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04);

  /* Border Radius */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;
  --radius-full: 9999px;

  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'SF Mono', 'Fira Code', 'Fira Mono', 'Roboto Mono', monospace;
  --text-xs: 0.6875rem;
  --text-sm: 0.8125rem;
  --text-base: 0.875rem;
  --text-md: 0.9375rem;
  --text-lg: 1.0625rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --leading-tight: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;

  /* Spacing */
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;

  /* Transitions */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-spring: 500ms cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Layout */
  --header-height: 60px;
  --sidebar-width: 16.875rem;
  --sidebar-collapsed-width: 56px;
  --content-max-width: 1400px;
}

/* === BASE RESET & TYPOGRAPHY === */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-sans) !important;
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--color-text);
  background-color: var(--color-bg) !important;
  letter-spacing: -0.011em;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-sans) !important;
  letter-spacing: -0.02em;
  font-weight: 600;
  color: var(--color-text);
  line-height: var(--leading-tight);
}

h1 { font-size: var(--text-3xl); }
h2 { font-size: var(--text-2xl); }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }
h5 { font-size: var(--text-md); font-weight: 600; }
h6 { font-size: var(--text-base); font-weight: 600; }

p { color: var(--color-text-secondary); }

a {
  color: var(--color-text-link);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover {
  color: var(--color-primary-hover);
  text-decoration: none;
}

::selection {
  background-color: var(--color-primary-200);
  color: var(--color-primary-700);
}

/* === SCROLLBAR === */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: var(--color-border-strong);
  border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-tertiary);
}

/* === ANIMATIONS === */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-16px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.animate-fade-in {
  animation: fadeIn 0.4s ease forwards;
}

.animate-fade-in-up {
  animation: fadeInUp 0.5s ease forwards;
}

.animate-slide-in {
  animation: slideInLeft 0.4s ease forwards;
}

.animate-scale-in {
  animation: scaleIn 0.3s ease forwards;
}

/* Staggered entrance */
.stagger-1 { animation-delay: 0.05s; opacity: 0; }
.stagger-2 { animation-delay: 0.1s; opacity: 0; }
.stagger-3 { animation-delay: 0.15s; opacity: 0; }
.stagger-4 { animation-delay: 0.2s; opacity: 0; }
.stagger-5 { animation-delay: 0.25s; opacity: 0; }
.stagger-6 { animation-delay: 0.3s; opacity: 0; }


/* === HEADER / NAVBAR === */
.navbar.fixed-top {
  height: var(--header-height) !important;
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
  box-shadow: var(--shadow-xs) !important;
  padding: 0 !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 1030;
  transition: box-shadow var(--transition-base);
}

.navbar.fixed-top:hover {
  box-shadow: var(--shadow-sm) !important;
}

.navbar-brand.wmin-200 {
  min-width: var(--sidebar-width) !important;
  display: flex;
  align-items: center;
  padding: 0 var(--space-4) !important;
  border-right: 1px solid var(--color-border) !important;
  border-left: none !important;
}

.logo-style {
  font-weight: 700 !important;
  font-size: 1.125rem !important;
  letter-spacing: -0.03em;
  font-family: var(--font-sans) !important;
}

.logo-outbound-colors {
  color: var(--color-text) !important;
}

.logo-switch-colors {
  color: var(--color-primary) !important;
  font-weight: 800;
}

.navbar .dropdown-menu {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: var(--space-2) !important;
  margin-top: var(--space-2) !important;
  animation: fadeInDown 0.2s ease;
  background: var(--color-surface) !important;
}

.navbar .dropdown-item {
  border-radius: var(--radius-sm) !important;
  padding: var(--space-2) var(--space-3) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
  transition: all var(--transition-fast) !important;
  line-height: 1.5 !important;
}

.navbar .dropdown-item:hover {
  background-color: var(--color-surface-hover) !important;
  color: var(--color-text) !important;
}

.navbar .dropdown-divider {
  border-color: var(--color-border-light) !important;
  margin: var(--space-1) 0 !important;
}

.navbar-nav-link,
.header-nav-link {
  color: var(--color-text-secondary) !important;
  transition: all var(--transition-fast) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-2) var(--space-3) !important;
}

.navbar-nav-link:hover,
.header-nav-link:hover {
  color: var(--color-text) !important;
  background-color: var(--color-surface-hover) !important;
}

/* User avatar in header */
.btn.rounded-round.btn-icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: var(--radius-full) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast) !important;
}

.btn.rounded-round.btn-icon:hover {
  transform: scale(1.05);
  box-shadow: var(--shadow-md);
}

/* Hamburger icon */
.fa-bars {
  color: var(--color-text-tertiary) !important;
  font-size: 1rem !important;
  transition: color var(--transition-fast);
}
.fa-bars:hover {
  color: var(--color-text) !important;
}


/* === SIDEBAR === */
.sidebar.sidebar-light {
  background: var(--color-surface) !important;
  border-right: 1px solid var(--color-border) !important;
  box-shadow: none !important;
  width: var(--sidebar-width) !important;
  box-sizing: border-box !important;
}

.sidebar.sidebar-light .sidebar-content {
  width: var(--sidebar-width) !important;
  box-sizing: border-box !important;
}

.sidebar-content {
  padding-top: var(--space-2);
}

.sidebar-user .card-body {
  padding: var(--space-4) var(--space-5) !important;
  border-bottom: 1px solid var(--color-border-light);
}

.sidebar-user .media {
  align-items: center;
}

.sidebar-user img.rounded-circle {
  width: 40px !important;
  height: 40px !important;
  border-radius: var(--radius-full) !important;
  object-fit: cover;
  border: 2px solid var(--color-border-light);
  transition: border-color var(--transition-fast);
}

.sidebar-user img.rounded-circle:hover {
  border-color: var(--color-primary-300);
}

.sidebar-user .font-weight-semibold {
  font-size: var(--text-sm) !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  text-transform: capitalize;
}

.sidebar-user .font-size-sm {
  font-size: var(--text-xs) !important;
  color: var(--color-text-tertiary) !important;
}

/* Sidebar navigation heading */
.sidebar-heading {
  font-size: 0.625rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--color-text-tertiary) !important;
  padding: var(--space-4) var(--space-5) var(--space-2) !important;
}

.nav-sidebar .nav-item-header {
  padding: var(--space-6) var(--space-5) var(--space-2) !important;
}

/* Sidebar nav links */
.nav-sidebar .nav-link {
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  padding: var(--space-2) var(--space-5) !important;
  margin: 1px var(--space-2) !important;
  border-radius: var(--radius-md) !important;
  border-left: none !important;
  transition: all var(--transition-fast) !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--space-2);
}

.nav-sidebar .nav-link:hover {
  color: var(--color-text) !important;
  background-color: var(--color-surface-hover) !important;
}

.nav-sidebar .nav-link .side-menu_icon {
  font-size: var(--text-base) !important;
  color: var(--color-text-tertiary) !important;
  width: 20px;
  text-align: center;
  transition: color var(--transition-fast);
}

.nav-sidebar .nav-link:hover .side-menu_icon {
  color: var(--color-primary) !important;
}

/* Active sidebar link */
.sidebar-light .nav-sidebar > .nav-item > .nav-link.active,
.sidebar-light .nav-group-sub .nav-item > .nav-link.active {
  color: var(--color-primary-700) !important;
  background-color: var(--color-primary-50) !important;
  border-left: none !important;
  font-weight: 600 !important;
}

.sidebar-light .nav-sidebar > .nav-item > .nav-link.active .side-menu_icon,
.sidebar-light .nav-group-sub .nav-item > .nav-link.active .side-menu_icon {
  color: var(--color-primary) !important;
}

/* Sidebar submenu group */
.sidebar-light .nav-sidebar > .nav-item-open > .nav-link:not(.disabled) {
  color: var(--color-text) !important;
  background-color: var(--color-surface-hover) !important;
  border-left: none !important;
  font-weight: 600 !important;
}

.nav-sidebar .nav-item-submenu > .nav-link::after,
.nav-sidebar .nav-item-submenu > a::after {
  transition: transform var(--transition-base) !important;
}

.nav-sidebar .nav-item-open > .nav-link::after,
.nav-sidebar .nav-item-open > a::after {
  transform: rotate(90deg);
}

.nav-group-sub {
  padding: var(--space-1) 0 !important;
}

.nav-group-sub .nav-link {
  padding-left: calc(var(--space-5) + 28px) !important;
  font-size: var(--text-xs) !important;
  font-weight: 400 !important;
}

.sidebar-light .nav-sidebar .nav-link:not(.disabled):hover {
  background-color: var(--color-surface-hover) !important;
  color: var(--color-text) !important;
}

/* Sidebar card */
.card.card-sidebar-mobile {
  border: none !important;
  box-shadow: none !important;
  margin: 0 !important;
  background: transparent !important;
}

/* Collapsed sidebar */
.sidebar-xs .sidebar-main.sidebar-light .nav-sidebar > .nav-item-submenu > .nav-group-sub {
  background-color: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: var(--space-2) !important;
}

/* Mobile sidebar toggle */
.sidebar-mobile-toggler {
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: var(--space-3) var(--space-4) !important;
}


/* === PAGE HEADER / BREADCRUMB === */
.page-header.page-header-light {
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border-light) !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.page-header .page-title h4 {
  font-size: var(--text-lg) !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  margin: 0 !important;
  padding: var(--space-4) var(--space-5) !important;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.page-header .page-title h4 .icon-arrow-left52 {
  display: none !important;
}

.page-header .page-title h4 .font-weight-semibold {
  font-weight: 600 !important;
}

.breadcrumb-line {
  background: transparent !important;
  border-top: 1px solid var(--color-border-light) !important;
  padding: var(--space-2) var(--space-5) !important;
}

.breadcrumb {
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
}

.breadcrumb-item {
  font-size: var(--text-xs) !important;
  color: var(--color-text-tertiary) !important;
}

.breadcrumb-item.active {
  color: var(--color-text-secondary) !important;
  font-weight: 500 !important;
}

.breadcrumb-item .icon-home2 {
  font-size: var(--text-xs) !important;
}


/* === CONTENT AREA === */
.content-wrapper {
  background: var(--color-bg) !important;
  margin-top: 0 !important;
  border-radius: 0 !important;
  min-height: calc(100vh - var(--header-height));
}

.content {
  padding: var(--space-6) !important;
  animation: fadeIn 0.3s ease;
}

@media (max-width: 768px) {
  .content {
    padding: var(--space-4) !important;
  }
}


/* === CARDS === */
.card {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-card) !important;
  transition: box-shadow var(--transition-base), transform var(--transition-base) !important;
  margin-bottom: var(--space-5) !important;
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--shadow-card-hover) !important;
}

.card-header {
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border-light) !important;
  padding: var(--space-4) var(--space-5) !important;
}

.card-header .card-title {
  font-size: var(--text-md) !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  margin: 0 !important;
  letter-spacing: -0.01em;
}

.card-body {
  padding: var(--space-5) !important;
}

.card-footer {
  background: var(--color-bg-subtle) !important;
  border-top: 1px solid var(--color-border-light) !important;
  padding: var(--space-3) var(--space-5) !important;
}

/* Dashboard stat cards */
.card.card-body {
  padding: var(--space-5) !important;
}

/* Theme title design override */
.theme-title-design {
  background: transparent !important;
  color: var(--color-text) !important;
  margin: 0 !important;
  padding: var(--space-4) var(--space-5) !important;
  font-weight: 600 !important;
  font-size: var(--text-lg) !important;
  letter-spacing: -0.01em;
  border-bottom: 1px solid var(--color-border-light);
}


/* === BUTTONS === */
.btn {
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: var(--text-sm) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-2) var(--space-4) !important;
  transition: all var(--transition-fast) !important;
  border: 1px solid transparent !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  line-height: 1.5 !important;
  letter-spacing: -0.01em;
}

.btn:focus {
  box-shadow: 0 0 0 3px var(--color-primary-200) !important;
  outline: none !important;
}

.btn:active {
  transform: scale(0.98);
}

/* Primary button */
.btn-theme,
.btn-primary,
.main-button,
.search-button,
.light-green-theme {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-color: var(--color-primary) !important;
  box-shadow: 0 1px 2px rgba(16, 185, 129, 0.2) !important;
}

.btn-theme:hover,
.btn-primary:hover,
.main-button:hover,
.search-button:hover,
.light-green-theme:hover {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
  color: var(--color-text-inverse) !important;
  transform: translateY(-1px);
}

.btn-theme:active,
.btn-primary:active {
  background: var(--color-primary-active) !important;
  transform: translateY(0) scale(0.98);
}

/* Secondary / Cancel button */
.btn-theme-cancel,
.btn-secondary,
.btn-outline-custom-secondary {
  background: var(--color-surface) !important;
  color: var(--color-text-secondary) !important;
  border: 1px solid var(--color-border) !important;
}

.btn-theme-cancel:hover,
.btn-secondary:hover,
.btn-outline-custom-secondary:hover {
  background: var(--color-surface-hover) !important;
  border-color: var(--color-border-strong) !important;
  color: var(--color-text) !important;
}

/* Danger button */
.btn-danger {
  background: var(--color-error) !important;
  color: var(--color-text-inverse) !important;
  border-color: var(--color-error) !important;
}

.btn-danger:hover {
  background: #DC2626 !important;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}

/* Disabled */
.btn:disabled,
.btn.disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Button sizes */
.btn-sm {
  padding: var(--space-1) var(--space-3) !important;
  font-size: var(--text-xs) !important;
  border-radius: var(--radius-sm) !important;
}

.btn-lg {
  padding: var(--space-3) var(--space-6) !important;
  font-size: var(--text-base) !important;
  border-radius: var(--radius-lg) !important;
}


/* === FORMS & INPUTS === */
.form-control {
  font-family: var(--font-sans) !important;
  font-size: var(--text-sm) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-2) var(--space-3) !important;
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  transition: all var(--transition-fast) !important;
  height: auto !important;
  line-height: 1.5 !important;
}

.form-control:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-100) !important;
  outline: none !important;
}

.form-control:hover:not(:focus):not(:disabled) {
  border-color: var(--color-border-strong) !important;
}

.form-control::placeholder {
  color: var(--color-text-tertiary) !important;
}

.form-control:disabled,
.form-control[readonly],
.read-only-form-control {
  background: var(--color-bg-subtle) !important;
  color: var(--color-text-secondary) !important;
  cursor: default;
}

/* Labels */
.form-group label,
.font-weight-semibold {
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  color: var(--color-text) !important;
  margin-bottom: var(--space-1) !important;
}

.form-group-float-label {
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  margin-bottom: var(--space-1) !important;
}

/* Error messages */
.form-text.text-danger {
  font-size: var(--text-xs) !important;
  color: var(--color-error) !important;
  margin-top: var(--space-1) !important;
  font-weight: 500;
}

/* Input groups */
.input-group-text {
  background: var(--color-bg) !important;
  border: 1px solid var(--color-border) !important;
  color: var(--color-text-tertiary) !important;
  border-radius: var(--radius-md) 0 0 var(--radius-md) !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-2) var(--space-3) !important;
}

/* Select controls */
.Select-control {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  min-height: 38px !important;
}

/* React Select overrides */
.css-yk16xz-control,
.css-1pahdxg-control {
  border-color: var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  min-height: 38px !important;
  box-shadow: none !important;
}

.css-1pahdxg-control {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-100) !important;
}

/* Textarea */
textarea.form-control {
  border-radius: var(--radius-md) !important;
  resize: vertical;
}

/* Checkbox */
.form-check-input-styled-custom,
.form-check-input {
  accent-color: var(--color-primary) !important;
}

.checkbox-theme {
  color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}


/* === TABLES === */
.table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}

.table thead th {
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-tertiary) !important;
  background: var(--color-bg-subtle) !important;
  border-bottom: 1px solid var(--color-border) !important;
  padding: var(--space-3) var(--space-4) !important;
  white-space: nowrap;
  border-top: none !important;
}

.table tbody td {
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
  padding: var(--space-3) var(--space-4) !important;
  border-bottom: 1px solid var(--color-border-light) !important;
  border-top: none !important;
  vertical-align: middle;
  transition: background-color var(--transition-fast);
}

.table-hover tbody tr:hover td {
  background-color: var(--color-surface-hover) !important;
  color: var(--color-text) !important;
}

.table tbody tr:last-child td {
  border-bottom: none !important;
}

.table-responsive {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
}

/* Table header style override */
.table-heading-style {
  color: var(--color-text-tertiary) !important;
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  border-bottom: 1px solid var(--color-border) !important;
}

.table-style {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden;
}

/* Action icons in tables */
.table-action-icon {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-sm) !important;
  padding: var(--space-1) var(--space-2) !important;
  color: var(--color-text-tertiary);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.table-action-icon:hover {
  background: var(--color-primary-50);
  border-color: var(--color-primary-200);
  color: var(--color-primary);
}

.edit-button {
  color: var(--color-primary) !important;
  transition: color var(--transition-fast);
}

.edit-button:hover {
  color: var(--color-primary-hover) !important;
}


/* === PAGINATION === */
.pagination {
  padding-left: 0 !important;
  gap: var(--space-1);
  margin: var(--space-4) 0 0 !important;
}

.pagination .page-item .page-link {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  color: var(--color-text-secondary) !important;
  font-size: var(--text-xs) !important;
  font-weight: 500 !important;
  padding: var(--space-2) var(--space-3) !important;
  transition: all var(--transition-fast) !important;
  background: var(--color-surface) !important;
  min-width: 36px;
  text-align: center;
}

.pagination .page-item .page-link:hover {
  background: var(--color-surface-hover) !important;
  border-color: var(--color-border-strong) !important;
  color: var(--color-text) !important;
}

.pagination .page-item.active .page-link {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  box-shadow: 0 2px 4px rgba(16, 185, 129, 0.2) !important;
}

.pagination > li:hover > a,
.pagination > li.active > a,
.pagination > li.active:hover > a {
  background: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
}

.pagination-parent {
  display: flex;
  justify-content: flex-end;
}

.records-info {
  font-size: var(--text-xs) !important;
  color: var(--color-text-tertiary) !important;
  font-weight: 500;
}


/* === MODALS === */
.modal-dialog {
  animation: scaleIn 0.25s ease !important;
}

.modal-content {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-xl) !important;
  overflow: hidden;
}

.modal-header {
  background: var(--color-surface) !important;
  border-bottom: 1px solid var(--color-border-light) !important;
  padding: var(--space-5) var(--space-6) !important;
}

.modal-header .modal-title {
  font-size: var(--text-lg) !important;
  font-weight: 600 !important;
  color: var(--color-text) !important;
  letter-spacing: -0.01em;
}

.modal-header .close {
  font-size: 1.5rem !important;
  color: var(--color-text-tertiary) !important;
  opacity: 1 !important;
  transition: all var(--transition-fast);
  border-radius: var(--radius-md);
  padding: var(--space-1) var(--space-2) !important;
  margin: calc(-0.5 * var(--space-2)) calc(-0.5 * var(--space-2)) calc(-0.5 * var(--space-2)) auto !important;
}

.modal-header .close:hover {
  color: var(--color-text) !important;
  background: var(--color-surface-hover);
}

.modal-body {
  padding: var(--space-5) var(--space-6) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
}

.modal-footer {
  background: var(--color-bg-subtle) !important;
  border-top: 1px solid var(--color-border-light) !important;
  padding: var(--space-4) var(--space-6) !important;
  gap: var(--space-2);
}

.modal-backdrop {
  background: rgba(15, 23, 42, 0.5) !important;
  backdrop-filter: blur(4px);
}

/* Danger modal header */
.modal-header.bg-danger {
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border-bottom: 2px solid var(--color-error-light) !important;
}


/* === PROGRESS BARS === */
.progress {
  height: 6px !important;
  border-radius: var(--radius-full) !important;
  background: var(--color-border-light) !important;
  overflow: hidden;
}

.progress-bar {
  border-radius: var(--radius-full) !important;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.progress-bar-success,
.bg-success {
  background: var(--color-primary) !important;
}

.progress-bar-info,
.bg-info:not(.modal-header) {
  background: var(--color-info) !important;
}

.progress-bar-danger {
  background: var(--color-rose) !important;
}

.progress-bar-animated {
  animation: none !important;
  background-image: none !important;
}


/* === ALERTS === */
.alert {
  border-radius: var(--radius-lg) !important;
  border: 1px solid !important;
  padding: var(--space-3) var(--space-4) !important;
  font-size: var(--text-sm) !important;
}

.alert-warning {
  background: var(--color-warning-light) !important;
  border-color: #FDE68A !important;
  color: #92400E !important;
}

.alert-danger {
  background: var(--color-error-light) !important;
  border-color: #FECACA !important;
  color: #991B1B !important;
}

.alert-success {
  background: var(--color-success-light) !important;
  border-color: #A7F3D0 !important;
  color: #065F46 !important;
}

.alert-info {
  background: var(--color-info-light) !important;
  border-color: #BFDBFE !important;
  color: #1E3A5F !important;
}


/* === BADGES === */
.badge {
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: var(--text-xs) !important;
  padding: 3px 8px !important;
  border-radius: var(--radius-sm) !important;
  letter-spacing: 0;
}

.badge.bg-success {
  background: var(--color-success-light) !important;
  color: #065F46 !important;
}

.badge.bg-danger {
  background: var(--color-error-light) !important;
  color: #991B1B !important;
}

.badge.bg-warning,
.badge.bg-warning-400 {
  background: var(--color-warning-light) !important;
  color: #92400E !important;
}

.badge.bg-info {
  background: var(--color-info-light) !important;
  color: #1E3A5F !important;
}


/* === TABS === */
.nav-tabs {
  border-bottom: 1px solid var(--color-border) !important;
}

.nav-tabs .nav-link {
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
  border: none !important;
  padding: var(--space-3) var(--space-4) !important;
  transition: all var(--transition-fast) !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
}

.nav-tabs .nav-link:hover {
  color: var(--color-text) !important;
  border-bottom-color: var(--color-border-strong) !important;
}

.nav-tabs .nav-link.active {
  color: var(--color-primary) !important;
  border-bottom-color: var(--color-primary) !important;
  background: transparent !important;
  font-weight: 600 !important;
}

.nav-tabs-top .nav-link.active:before {
  background-color: var(--color-primary) !important;
}

.RRT__tab--selected {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
}


/* === TOOLTIPS === */
.tooltip-inner {
  background: var(--color-text) !important;
  border-radius: var(--radius-md) !important;
  font-size: var(--text-xs) !important;
  font-family: var(--font-sans) !important;
  padding: var(--space-1) var(--space-2) !important;
}


/* === NOTIFICATIONS / PNOTIFY === */
.ui-pnotify {
  font-family: var(--font-sans) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  border: 1px solid var(--color-border) !important;
}

.brighttheme-info {
  background-color: var(--color-info) !important;
  border-color: var(--color-info) !important;
  border-radius: var(--radius-lg) !important;
}

.brighttheme-success {
  background-color: var(--color-success) !important;
  border-color: var(--color-success) !important;
  border-radius: var(--radius-lg) !important;
}

.brighttheme-error {
  background-color: var(--color-error) !important;
  border-color: var(--color-error) !important;
  border-radius: var(--radius-lg) !important;
}


/* === LOADING STATES === */
.loading-container-app {
  z-index: 10001 !important;
}

.loading-content-app {
  background: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-full) !important;
  padding: var(--space-2) var(--space-4) !important;
  font-size: var(--text-xs) !important;
  font-weight: 500 !important;
  box-shadow: var(--shadow-lg) !important;
  animation: pulse 1.5s ease infinite;
}

/* Spinner override */
.icon-spinner4.spinner,
.icon-spinner2.spinner {
  animation: spin 0.8s linear infinite !important;
}


/* === DASHBOARD SPECIFIC === */
/* Stat cards */
.stat-card-modern {
  position: relative;
  overflow: hidden;
}

.stat-card-modern::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -15%;
  width: 120px;
  height: 120px;
  border-radius: var(--radius-full);
  opacity: 0.08;
}

.stat-card-modern:nth-child(1)::before { background: var(--color-primary); }
.stat-card-modern:nth-child(2)::before { background: var(--color-info); }
.stat-card-modern:nth-child(3)::before { background: var(--color-amber); }


/* === REACT SELECT OVERRIDE === */
.css-1wa3eu0-placeholder {
  color: var(--color-text-tertiary) !important;
  font-size: var(--text-sm) !important;
}

.css-1okebmr-indicatorSeparator {
  background-color: var(--color-border) !important;
}

.css-tlfecz-indicatorContainer,
.css-1gtu0rj-indicatorContainer {
  color: var(--color-text-tertiary) !important;
}

.css-26l3qy-menu {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
  z-index: 100 !important;
  overflow: hidden;
}

.css-4ljt9a-MenuList {
  padding: var(--space-1) !important;
}

.css-yt9ioa-option,
.css-1n7v3ny-option {
  font-size: var(--text-sm) !important;
  border-radius: var(--radius-sm) !important;
  padding: var(--space-2) var(--space-3) !important;
}

.css-1n7v3ny-option {
  background: var(--color-surface-hover) !important;
  color: var(--color-text) !important;
}

.css-9gakcf-option {
  background: var(--color-primary-50) !important;
  color: var(--color-primary-700) !important;
  border-radius: var(--radius-sm) !important;
}


/* === DATEPICKER OVERRIDE === */
.react-datepicker {
  font-family: var(--font-sans) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-lg) !important;
}

.react-datepicker__header {
  background: var(--color-bg-subtle) !important;
  border-bottom: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

.react-datepicker__day--selected {
  background: var(--color-primary) !important;
  border-radius: var(--radius-md) !important;
}

.react-datepicker__day:hover {
  background: var(--color-primary-50) !important;
  border-radius: var(--radius-md) !important;
}


/* === CIRCULAR PROGRESSBAR === */
.CircularProgressbar {
  width: 160px !important;
}

.CircularProgressbar .CircularProgressbar-path {
  stroke-linecap: round;
}


/* === COLLAPSE ANIMATION === */
.collapse {
  transition: height 0.25s ease !important;
}


/* === UTILITY CLASSES === */
.text-premium {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-teal) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.glass-card {
  background: rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
}

.gradient-primary {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-teal) 100%);
}

.gradient-info {
  background: linear-gradient(135deg, var(--color-info) 0%, var(--color-cyan) 100%);
}

.gradient-amber {
  background: linear-gradient(135deg, var(--color-amber) 0%, #F97316 100%);
}

.shadow-primary {
  box-shadow: 0 4px 14px rgba(16, 185, 129, 0.25);
}

.hover-lift {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.hover-lift:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}


/* === PRINT OVERRIDE === */
@media print {
  .noprint {
    display: none !important;
  }
}


/* === RESPONSIVE === */
@media (max-width: 991.98px) {
  .navbar-brand.wmin-200 {
    min-width: auto !important;
    border-right: none !important;
  }
}

@media (max-width: 767.98px) {
  :root {
    --header-height: 56px;
  }

  .card {
    border-radius: var(--radius-md) !important;
  }

  .modal-content {
    border-radius: var(--radius-lg) !important;
    margin: var(--space-4);
  }
}


/* === FIX BOOTSTRAP OVERRIDES CLASHING === */
.bg-white {
  background-color: var(--color-surface) !important;
}

.text-muted {
  color: var(--color-text-tertiary) !important;
  font-size: inherit !important;
}

.font-weight-semibold {
  font-weight: 600 !important;
}

/* Override border_left_line for header brand */
.border_left_line {
  min-width: var(--sidebar-width) !important;
}

/* Fix content top spacing */
.navbar-top-custom {
  padding-top: var(--header-height) !important;
}

/* Override sidebar active states from old theme */
.sidebar-light .nav-sidebar > .nav-item-open > .nav-link:not(.disabled),
.sidebar-light .card[class*=bg-]:not(.bg-light):not(.bg-white):not(.bg-transparent) .nav-sidebar > .nav-item-open > .nav-link:not(.disabled) {
  color: var(--color-text) !important;
  background: var(--color-surface-hover) !important;
  border-left: none !important;
}

.sidebar-light .nav-sidebar > .nav-item > .nav-link.active,
.sidebar-light .card[class*=bg-]:not(.bg-light):not(.bg-white):not(.bg-transparent) .nav-sidebar > .nav-item > .nav-link.active {
  color: var(--color-primary-700) !important;
  background: var(--color-primary-50) !important;
  border-left: none !important;
}

/* Remove duplicate left border - brand already has border-right */
.left_boder_line {
  border-left: none !important;
}

/* Align navbar collapse content with breadcrumb/content below */
.c_navbar-collapse {
  margin-left: 0 !important;
  padding-left: var(--space-6) !important;
  padding-right: var(--space-6) !important;
}

/* JSON view */
.react-json-view {
  border-radius: var(--radius-lg) !important;
  font-family: var(--font-mono) !important;
}

/* Multi-select */
.multi-select .dropdown-heading {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
}

/* Typeahead */
.rbt-input-main {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
}

.rbt-input-main:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-100) !important;
}


/* === STICKY TABLE HEADER === */
.stickeyHeader {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--color-bg-subtle) !important;
}

.stickeyHeader th {
  background: var(--color-bg-subtle) !important;
  color: var(--color-text-tertiary) !important;
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  white-space: nowrap;
  padding: var(--space-3) var(--space-4) !important;
  border-bottom: 1px solid var(--color-border) !important;
  border-top: none !important;
}


/* === BADGE OVERRIDES === */
.badge.bg-blue {
  background: var(--color-info-light) !important;
  color: #1E40AF !important;
  font-weight: 500 !important;
  padding: 4px 10px !important;
  border-radius: var(--radius-sm) !important;
  font-size: var(--text-xs) !important;
}

.badge.badge-success,
.badge.bg-success-400 {
  background: var(--color-success-light) !important;
  color: #065F46 !important;
}

.badge.badge-danger {
  background: var(--color-error-light) !important;
  color: #991B1B !important;
}

.badge.bg-warning {
  background: var(--color-warning-light) !important;
  color: #92400E !important;
}

.badge.fs-12 {
  font-size: var(--text-xs) !important;
}


/* === DATATABLE HEADER === */
.datatable-header {
  padding: var(--space-3) 0 !important;
  border: none !important;
  margin-bottom: var(--space-2) !important;
}

.dataTables_filter input,
.dataTables_filter .form-control {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-2) var(--space-3) !important;
  transition: all var(--transition-fast) !important;
}

.dataTables_filter input:focus,
.dataTables_filter .form-control:focus {
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 3px var(--color-primary-100) !important;
}


/* === INPUT GROUP MODERN === */
.input-group .form-control.border-right-0 {
  border-right: none !important;
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.input-group-append .search-button {
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-top-right-radius: var(--radius-md) !important;
  border-bottom-right-radius: var(--radius-md) !important;
}


/* === TABLE ROW HOVER === */
.table-striped tbody tr:nth-of-type(odd) {
  background-color: var(--color-bg-subtle) !important;
}

.table-striped tbody tr:nth-of-type(even) {
  background-color: var(--color-surface) !important;
}

.table-striped tbody tr:hover {
  background-color: #F0FDF4 !important;
}


/* === EXPAND/COLLAPSE ICONS IN TABLES === */
.icon-plus-circle2,
.icon-minus-circle2 {
  color: var(--color-text-tertiary) !important;
  cursor: pointer;
  transition: color var(--transition-fast);
}

.icon-plus-circle2:hover {
  color: var(--color-primary) !important;
}

.icon-minus-circle2:hover {
  color: var(--color-error) !important;
}


/* === LEFT ALIGN TABLE CLASS === */
.left_align td {
  text-align: left;
  padding: var(--space-3) var(--space-4) !important;
  font-size: var(--text-sm) !important;
  color: var(--color-text-secondary) !important;
  vertical-align: middle;
}


/* === TEXT COLOR OVERRIDES === */
.text-success,
.text-success-600 {
  color: var(--color-success) !important;
}

.text-danger,
.text-danger-600 {
  color: var(--color-error) !important;
}

.text-warning-600 {
  color: var(--color-warning) !important;
}

.text-primary {
  color: var(--color-info) !important;
}


/* === BORDER STYLE OVERRIDES === */
.border-top-success {
  border-top: 2px solid var(--color-primary) !important;
}

.border-bottom-success {
  border-bottom: none !important;
}

.border-left-dark-alpha,
.border-right-dark-alpha {
  border: none !important;
}


/* === SPINNER/LOADING IN DELETE === */
.spinner-border.spinner-border-sm {
  width: 14px;
  height: 14px;
  border-width: 2px;
  border-color: var(--color-text-inverse);
  border-right-color: transparent;
}


/* === SWITCH TOGGLE === */
.react-switch-bg {
  border-radius: var(--radius-full) !important;
}


/* === CSV LINK === */
.csv-link,
a.csv-download {
  color: var(--color-primary) !important;
  font-size: var(--text-sm) !important;
  text-decoration: none !important;
}

.csv-link:hover,
a.csv-download:hover {
  color: var(--color-primary-hover) !important;
  text-decoration: underline !important;
}


/* === EMPTY STATE === */
.dataTables_info {
  font-size: var(--text-sm) !important;
  color: var(--color-text-tertiary) !important;
  padding: var(--space-4) 0 !important;
}


/* === CARD BORDER REMOVAL === */
.card.rounded-0 {
  border-radius: var(--radius-lg) !important;
}

.border-top-success.border-bottom-success.rounded-0 {
  border-radius: var(--radius-lg) !important;
  border-top: none !important;
  border-bottom: none !important;
}


/* === PROGRESS BAR VARIANTS (react-bootstrap) === */
.progress-bar.bg-danger {
  background: var(--color-rose) !important;
}

.progress-bar.bg-info {
  background: var(--color-info) !important;
}

.progress-bar.bg-success {
  background: var(--color-primary) !important;
}


/* === LOGIN PAGE === */
.page-login,
.bg-loginAuth,
.c-login-cover {
  display: none !important;
}

/* Override old login styles when modern login is used */
.login-mt-10,
.login-mt-16 {
  margin-top: 0 !important;
}

/* === EMPTY STATE PATTERN === */
.empty-state {
  text-align: center;
  padding: var(--space-12) var(--space-6);
  color: var(--color-text-tertiary);
}

.empty-state i {
  font-size: 2.5rem;
  color: var(--color-border-strong);
  margin-bottom: var(--space-4);
  display: block;
}

.empty-state p {
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  margin: 0;
}


/* === NOTIFICATION OVERRIDE === */
.alert-styled-left {
  border-left: 3px solid !important;
  border-radius: var(--radius-lg) !important;
}


/* === FORM CONTAINER OVERRIDES === */
.form_style {
  width: 100% !important;
  margin: 0 !important;
}

.form_container {
  margin: 0 !important;
}

.user_card {
  display: none !important;
}


/* === RESPONSIVE TABLE === */
@media (max-width: 768px) {
  .table thead th,
  .table tbody td {
    padding: var(--space-2) var(--space-3) !important;
    font-size: var(--text-xs) !important;
  }
}


/* === SMOOTH TRANSITIONS === */
.nav-link,
.btn,
.form-control,
.card,
.badge,
a {
  transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
}


/* === FOCUS VISIBLE === */
*:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

button:focus:not(:focus-visible),
a:focus:not(:focus-visible),
input:focus:not(:focus-visible) {
  outline: none;
}


/* === CHART.JS CANVAS === */
canvas {
  border-radius: var(--radius-md);
}


/* === ANIMATION KEYFRAME FOR SPIN (used in login) === */
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}


/* ============================================================
   GLOBAL CLEANUP — Remove duplicate lines & modernize old classes
   ============================================================ */

/* --- Remove multiple dividing lines at top of pages --- */
/* Card headers - clean up borders but keep content visible */
.card-header.header-elements-inline.p-0 {
  border: none !important;
  background: transparent !important;
  min-height: 0 !important;
}

/* Empty datatable headers and their filter wrappers */
.dataTables_wrapper .datatable-header {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
}

.dataTables_wrapper .datatable-header .dataTables_filter:empty,
.dataTables_wrapper .datatable-header:empty {
  display: none !important;
}

/* Remove border-0 class conflicting with card borders */
.datatable-header.border-0 {
  border: none !important;
}

/* No-footer wrapper cleanup */
.dataTables_wrapper.no-footer {
  border: none !important;
}

/* Remove stale DataTable internal borders */
.dataTables_wrapper .datatable-scroll {
  border: none !important;
}


/* --- Old Limitless border classes → clean modern --- */
.border-left-dark-alpha,
.border-right-dark-alpha {
  border-left: none !important;
  border-right: none !important;
}

.border-top-success {
  border-top: none !important;
}

.border-bottom-success {
  border-bottom: none !important;
}

.card.card-body.border-top-success.border-bottom-success,
.card.card-body.border-left-dark-alpha.border-right-dark-alpha {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-card) !important;
}


/* --- Old dark table headers → modern light --- */
thead.bg-dark,
thead tr.bg-dark,
tr.bg-dark th {
  background: var(--color-bg-subtle) !important;
  color: var(--color-text-tertiary) !important;
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  border-bottom: 1px solid var(--color-border) !important;
}

thead.bg-dark th,
thead tr.bg-dark th {
  background: var(--color-bg-subtle) !important;
  color: var(--color-text-tertiary) !important;
  font-size: var(--text-xs) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: var(--space-3) var(--space-4) !important;
  border-top: none !important;
  border-bottom: 1px solid var(--color-border) !important;
}

/* Light table header override */
.table.bg-light,
.table thead.bg-light,
table.bg-light {
  background: transparent !important;
}


/* --- Old badge classes → modern pill badges --- */
.badge.bg-blue,
.badge.badge-primary,
.badge.bg-primary {
  background: var(--color-primary-50) !important;
  color: var(--color-primary-700) !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}

.badge.bg-warning,
.badge.badge-warning {
  background: var(--color-warning-light) !important;
  color: #92400E !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}

.badge.bg-success,
.badge.badge-success {
  background: var(--color-success-light) !important;
  color: var(--color-primary-700) !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}

.badge.bg-danger,
.badge.badge-danger {
  background: var(--color-error-light) !important;
  color: #B91C1C !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}

.badge.bg-info,
.badge.badge-info {
  background: var(--color-info-light) !important;
  color: #1D4ED8 !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}

.badge.bg-secondary,
.badge.badge-secondary {
  background: var(--color-bg) !important;
  color: var(--color-text-secondary) !important;
  border: none !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--radius-full) !important;
  font-size: var(--text-xs) !important;
}


/* --- Old button classes → modern --- */
.btn.bg-blue,
.btn-primary {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)) !important;
  border: none !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-2) var(--space-4) !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
  transition: all var(--transition-base) !important;
}

.btn.bg-blue:hover,
.btn-primary:hover {
  box-shadow: 0 6px 20px rgba(16, 185, 129, 0.4) !important;
  transform: translateY(-1px);
}

.btn-success {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)) !important;
  border: none !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
}

.btn-danger {
  background: linear-gradient(135deg, #EF4444, #DC2626) !important;
  border: none !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}

.btn-warning {
  background: linear-gradient(135deg, #F59E0B, #D97706) !important;
  border: none !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
}

/* Small button variant */
.btn-sm {
  padding: var(--space-1) var(--space-3) !important;
  font-size: var(--text-xs) !important;
  border-radius: var(--radius-sm) !important;
}

/* Main action button class */
.main-button {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)) !important;
  border: none !important;
  color: var(--color-text-inverse) !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-2) var(--space-4) !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3) !important;
}


/* --- Old tab styling → modern --- */
.custom-tabs .nav-link.active,
.nav-tabs .nav-link.active {
  background-color: var(--color-primary-50) !important;
  color: var(--color-primary-700) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: var(--text-sm) !important;
}

.custom-tabs .nav-link,
.nav-tabs .nav-link {
  border: none !important;
  border-radius: var(--radius-md) !important;
  color: var(--color-text-secondary) !important;
  font-weight: 500 !important;
  font-size: var(--text-sm) !important;
  padding: var(--space-2) var(--space-4) !important;
  transition: all var(--transition-fast) !important;
}

.custom-tabs .nav-link:hover,
.nav-tabs .nav-link:hover {
  background-color: var(--color-bg) !important;
  color: var(--color-text) !important;
}

.nav-tabs {
  border-bottom: 1px solid var(--color-border-light) !important;
  padding: var(--space-2) !important;
  gap: var(--space-1);
}


/* --- Old checkbox styling → modern --- */
.custom-control.custom-checkbox .custom-control-input:checked ~ .custom-control-label::before {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.custom-checkbox .custom-control-label::before {
  border-radius: var(--radius-sm) !important;
  border: 1.5px solid var(--color-border-strong) !important;
}


/* --- Global edit/action icon buttons --- */
.edit-button i {
  cursor: pointer;
  padding: 6px;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
  font-size: 14px !important;
}

.edit-button i.fa-edit:hover {
  background: var(--color-primary-50);
  color: var(--color-primary) !important;
}

.edit-button i.fa-trash:hover {
  background: var(--color-error-light);
  color: var(--color-error) !important;
}


/* --- Card used as wrapper (no double border) --- */
.card.card-body {
  border-radius: var(--radius-lg) !important;
}

/* Remove stale header-elements-inline borders everywhere */
.header-elements-inline {
  border: none !important;
}

/* Clean up d-flex bg-light wrappers used in reports */
.d-flex.bg-light.rounded.border {
  background: var(--color-bg-subtle) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-3) !important;
}


/* --- Pagination modern --- */
.pagination .page-link {
  border: 1px solid var(--color-border) !important;
  color: var(--color-text-secondary) !important;
  font-size: var(--text-sm) !important;
  font-weight: 500 !important;
  border-radius: var(--radius-md) !important;
  margin: 0 2px !important;
  padding: var(--space-2) var(--space-3) !important;
  transition: all var(--transition-fast) !important;
}

.pagination .page-link:hover {
  background: var(--color-primary-50) !important;
  border-color: var(--color-primary-200) !important;
  color: var(--color-primary-700) !important;
}

.pagination .page-item.active .page-link {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
  box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3) !important;
}

.pagination .page-item.disabled .page-link {
  background: var(--color-bg-subtle) !important;
  color: var(--color-text-tertiary) !important;
  border-color: var(--color-border-light) !important;
}
