:root {
  --primary-color: #4F46E5;
  --primary-light: #818CF8;
  --primary-dark: #3730A3;
  --primary-50: #EEF2FF;
  --primary-100: #E0E7FF;
  --primary-200: #C7D2FE;
  --primary-300: #A5B4FC;
  --primary-400: #818CF8;
  --primary-500: #6366F1;
  --primary-600: #4F46E5;
  --primary-700: #4338CA;
  --primary-800: #3730A3;
  --primary-900: #312E81;
  
  --secondary-color: #10B981;
  --secondary-light: #34D399;
  --secondary-dark: #059669;
  --secondary-50: #ECFDF5;
  --secondary-100: #D1FAE5;
  --secondary-200: #A7F3D0;
  --secondary-300: #6EE7B7;
  --secondary-400: #34D399;
  --secondary-500: #10B981;
  --secondary-600: #059669;
  --secondary-700: #047857;
  --secondary-800: #065F46;
  --secondary-900: #064E3B;
  
  --accent-color: #F59E0B;
  --accent-light: #FBBF24;
  --accent-dark: #D97706;
  
  --success-color: #10B981;
  --warning-color: #F59E0B;
  --danger-color: #EF4444;
  --info-color: #3B82F6;
  
  --text-primary: #111827;
  --text-secondary: #4B5563;
  --text-muted: #9CA3AF;
  --text-disabled: #D1D5DB;
  
  --bg-primary: #FFFFFF;
  --bg-secondary: #F9FAFB;
  --bg-tertiary: #F3F4F6;
  --bg-quaternary: #E5E7EB;
  
  --border-color: #E5E7EB;
  --border-light: #F3F4F6;
  --border-dark: #D1D5DB;
  
  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  
  --radius-xs: 0.125rem;
  --radius-sm: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-2xl: 1rem;
  --radius-3xl: 1.5rem;
  --radius-full: 9999px;
  
  --transition-instant: 100ms ease-in-out;
  --transition-fast: 150ms ease-in-out;
  --transition-normal: 200ms ease-in-out;
  --transition-slow: 300ms ease-in-out;
  --transition-slower: 500ms ease-in-out;
  
  --font-family-base: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --font-family-heading: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
  --font-family-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;
  --font-size-4xl: 2.25rem;
  --font-size-5xl: 3rem;
  
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  
  --spacing-0: 0;
  --spacing-1: 0.25rem;
  --spacing-2: 0.5rem;
  --spacing-3: 0.75rem;
  --spacing-4: 1rem;
  --spacing-5: 1.25rem;
  --spacing-6: 1.5rem;
  --spacing-8: 2rem;
  --spacing-10: 2.5rem;
  --spacing-12: 3rem;
  --spacing-16: 4rem;
  --spacing-20: 5rem;
  --spacing-24: 6rem;
  
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  
  --breakpoint-xs: 0;
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --breakpoint-xxl: 1400px;
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-normal);
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  min-height: 100vh;
}

*:focus {
  outline: none;
}

*:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}

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

a:hover,
a:focus {
  color: var(--primary-dark);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-heading);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  color: var(--text-primary);
  margin-bottom: var(--spacing-4);
}

h1 { font-size: var(--font-size-5xl); }
h2 { font-size: var(--font-size-4xl); }
h3 { font-size: var(--font-size-3xl); }
h4 { font-size: var(--font-size-2xl); }
h5 { font-size: var(--font-size-xl); }
h6 { font-size: var(--font-size-lg); }

h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child {
  margin-bottom: 0;
}

p {
  margin-bottom: var(--spacing-4);
}

p:last-child {
  margin-bottom: 0;
}

small,
.small {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-1) var(--spacing-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.badge-primary {
  background-color: var(--primary-color);
  color: white;
}

.badge-success {
  background-color: var(--success-color);
  color: white;
}

.badge-warning {
  background-color: var(--warning-color);
  color: white;
}

.badge-danger {
  background-color: var(--danger-color);
  color: white;
}

.badge-info {
  background-color: var(--info-color);
  color: white;
}

.badge-light {
  background-color: var(--bg-tertiary);
  color: var(--text-secondary);
}

.badge-dark {
  background-color: var(--text-primary);
  color: white;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-3) var(--spacing-5);
  font-family: var(--font-family-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  user-select: none;
  touch-action: manipulation;
  white-space: nowrap;
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn:active {
  transform: translateY(0);
}

.btn:disabled,
.btn.disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.btn-primary {
  background: linear-gradient(135deg, var(--primary-color), var(--primary-dark));
  color: white;
  border-color: var(--primary-color);
}

.btn-primary:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--primary-light), var(--primary-color));
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.4);
}

.btn-primary:active:not(:disabled) {
  background: var(--primary-dark);
}

.btn-success {
  background: linear-gradient(135deg, var(--success-color), var(--secondary-dark));
  color: white;
  border-color: var(--success-color);
}

.btn-success:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--secondary-light), var(--success-color));
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
}

.btn-warning {
  background: linear-gradient(135deg, var(--warning-color), var(--accent-dark));
  color: white;
  border-color: var(--warning-color);
}

.btn-warning:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--accent-light), var(--warning-color));
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
}

.btn-danger {
  background: linear-gradient(135deg, var(--danger-color), #DC2626);
  color: white;
  border-color: var(--danger-color);
}

.btn-danger:hover:not(:disabled) {
  background: linear-gradient(135deg, #F87171, var(--danger-color));
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.btn-info {
  background: linear-gradient(135deg, var(--info-color), #2563EB);
  color: white;
  border-color: var(--info-color);
}

.btn-info:hover:not(:disabled) {
  background: linear-gradient(135deg, #60A5FA, var(--info-color));
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

.btn-default {
  background-color: var(--bg-primary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

.btn-default:hover:not(:disabled) {
  background-color: var(--bg-secondary);
  border-color: var(--border-dark);
}

.btn-light {
  background-color: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border-color);
}

.btn-light:hover:not(:disabled) {
  background-color: var(--bg-tertiary);
  border-color: var(--border-dark);
}

.btn-dark {
  background-color: var(--text-primary);
  color: white;
  border-color: var(--text-primary);
}

.btn-dark:hover:not(:disabled) {
  background-color: var(--text-secondary);
  border-color: var(--text-secondary);
}

.btn-link {
  background: transparent;
  color: var(--primary-color);
  border-color: transparent;
  padding: var(--spacing-3) 0;
}

.btn-link:hover:not(:disabled) {
  color: var(--primary-dark);
  text-decoration: underline;
  background: transparent;
  box-shadow: none;
  transform: none;
}

.btn-lg {
  padding: var(--spacing-4) var(--spacing-6);
  font-size: var(--font-size-base);
}

.btn-sm {
  padding: var(--spacing-2) var(--spacing-4);
  font-size: var(--font-size-xs);
}

.btn-xs {
  padding: var(--spacing-1) var(--spacing-3);
  font-size: 0.6875rem;
}

.btn-block {
  display: flex;
  width: 100%;
}

.btn-rounded {
  border-radius: var(--radius-full);
}

.btn-icon {
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border-radius: var(--radius-lg);
}

.btn-icon.btn-sm {
  width: 2rem;
  height: 2rem;
}

.btn-icon.btn-lg {
  width: 3rem;
  height: 3rem;
}

.form-control {
  display: block;
  width: 100%;
  padding: var(--spacing-3) var(--spacing-4);
  font-family: var(--font-family-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  line-height: 1.5;
  color: var(--text-primary);
  background-color: var(--bg-primary);
  background-image: none;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  appearance: none;
}

.form-control::placeholder {
  color: var(--text-muted);
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
  outline: none;
}

.form-control:disabled,
.form-control[readonly] {
  background-color: var(--bg-secondary);
  color: var(--text-disabled);
  cursor: not-allowed;
}

.form-control.no-border {
  border: none;
  background-color: transparent;
  padding: var(--spacing-3) 0;
}

.form-control.no-border:focus {
  box-shadow: none;
  border: none;
}

.form-control-lg {
  padding: var(--spacing-4) var(--spacing-5);
  font-size: var(--font-size-base);
}

.form-control-sm {
  padding: var(--spacing-2) var(--spacing-3);
  font-size: var(--font-size-xs);
}

.input-group {
  display: flex;
  width: 100%;
  position: relative;
  align-items: stretch;
}

.input-group .form-control {
  flex: 1;
  min-width: 0;
}

.input-group .form-control:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.input-group .form-control:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.input-group-addon {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-3) var(--spacing-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  line-height: 1.5;
  color: var(--text-secondary);
  background-color: var(--bg-tertiary);
  border: 1px solid var(--border-color);
  white-space: nowrap;
  transition: all var(--transition-fast);
}

.input-group-addon:first-child {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.input-group-addon:last-child {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.input-group-addon:hover {
  background-color: var(--border-color);
  cursor: pointer;
}

.input-group-addon:disabled {
  background-color: var(--bg-secondary);
  color: var(--text-disabled);
  cursor: not-allowed;
}

.panel {
  background-color: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: all var(--transition-normal);
}

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

.panel-heading {
  padding: var(--spacing-5);
  background-color: var(--bg-secondary);
  border-bottom: 1px solid var(--border-color);
  font-weight: var(--font-weight-semibold);
}

.panel-body {
  padding: var(--spacing-5);
}

.panel-footer {
  padding: var(--spacing-4) var(--spacing-5);
  background-color: var(--bg-secondary);
  border-top: 1px solid var(--border-color);
}

.panel-default {
  border-color: var(--border-color);
}

.panel-default > .panel-heading {
  background-color: var(--bg-secondary);
  color: var(--text-primary);
}

.panel-default > .panel-footer {
  background-color: var(--bg-secondary);
}

.alert {
  padding: var(--spacing-4) var(--spacing-5);
  margin-bottom: var(--spacing-4);
  border: none;
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
  animation: fadeInDown var(--transition-slower) ease-out;
}

.alert-success {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.1), rgba(5, 150, 105, 0.05));
  border-left: 4px solid var(--success-color);
  color: #065F46;
}

.alert-warning {
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.1), rgba(217, 119, 6, 0.05));
  border-left: 4px solid var(--warning-color);
  color: #92400E;
}

.alert-danger {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.1), rgba(220, 38, 38, 0.05));
  border-left: 4px solid var(--danger-color);
  color: #991B1B;
}

.alert-info {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(37, 99, 235, 0.05));
  border-left: 4px solid var(--info-color);
  color: #1E40AF;
}

.table {
  width: 100%;
  margin-bottom: var(--spacing-4);
  background-color: transparent;
  border-collapse: collapse;
  border-spacing: 0;
}

.table > thead > tr > th,
.table > tbody > tr > td,
.table > tfoot > tr > td {
  padding: var(--spacing-3) var(--spacing-4);
  vertical-align: middle;
  border-top: 1px solid var(--border-color);
}

.table > thead > tr > th {
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  background-color: var(--bg-secondary);
  border-bottom: 2px solid var(--border-color);
  border-top: none;
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

.table > tbody > tr:hover {
  background-color: var(--bg-secondary);
}

.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: rgba(249, 250, 251, 0.5);
}

.table-bordered {
  border: 1px solid var(--border-color);
}

.table-bordered > thead > tr > th,
.table-bordered > tbody > tr > td,
.table-bordered > tfoot > tr > td {
  border: 1px solid var(--border-color);
}

.list-group {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  border-radius: var(--radius-lg);
}

.list-group-item {
  position: relative;
  display: flex;
  align-items: center;
  padding: var(--spacing-4) var(--spacing-5);
  margin-bottom: -1px;
  background-color: var(--bg-primary);
  border: 1px solid var(--border-color);
  transition: all var(--transition-fast);
}

.list-group-item:first-child {
  border-top-left-radius: var(--radius-lg);
  border-top-right-radius: var(--radius-lg);
}

.list-group-item:last-child {
  margin-bottom: 0;
  border-bottom-left-radius: var(--radius-lg);
  border-bottom-right-radius: var(--radius-lg);
}

.list-group-item:hover {
  background-color: var(--bg-secondary);
  transform: translateX(4px);
}

.list-group-item.active {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: white;
}

.nav-tabs {
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
  border-bottom: 1px solid var(--border-color);
}

.nav-tabs > li {
  margin-bottom: -1px;
}

.nav-tabs > li > a {
  display: block;
  padding: var(--spacing-3) var(--spacing-5);
  color: var(--text-secondary);
  background-color: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  transition: all var(--transition-fast);
  font-weight: var(--font-weight-medium);
}

.nav-tabs > li > a:hover {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
  color: var(--primary-color);
}

.nav-tabs > li.active > a {
  background-color: var(--bg-primary);
  border-color: var(--border-color) var(--border-color) var(--bg-primary);
  color: var(--primary-color);
  font-weight: var(--font-weight-semibold);
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-index-modal);
  display: none;
  width: 100%;
  height: 100%;
  overflow: hidden;
  outline: 0;
}

.modal.in {
  display: block;
}

.modal-dialog {
  position: relative;
  width: auto;
  margin: var(--spacing-4);
  pointer-events: none;
}

.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background-color: var(--bg-primary);
  background-clip: padding-box;
  border: none;
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-2xl);
  outline: 0;
  animation: fadeInUp var(--transition-slower) ease-out;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-5);
  border-bottom: 1px solid var(--border-color);
}

.modal-title {
  margin: 0;
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: var(--spacing-5);
  overflow-y: auto;
  max-height: calc(100vh - 200px);
}

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: var(--spacing-4) var(--spacing-5);
  border-top: 1px solid var(--border-color);
}

.close {
  float: right;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  color: var(--text-secondary);
  text-shadow: 0 1px 0 var(--bg-primary);
  opacity: 0.5;
  cursor: pointer;
  transition: all var(--transition-fast);
  background: transparent;
  border: none;
  padding: 0;
}

.close:hover {
  color: var(--text-primary);
  opacity: 1;
}

.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: var(--z-index-dropdown);
  display: none;
  min-width: 10rem;
  padding: var(--spacing-2);
  margin: var(--spacing-1) 0 0;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  text-align: left;
  list-style: none;
  background-color: var(--bg-primary);
  background-clip: padding-box;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  animation: fadeInDown var(--transition-slow) ease-out;
}

.dropdown-menu.show {
  display: block;
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  width: 100%;
  padding: var(--spacing-3) var(--spacing-4);
  clear: both;
  font-weight: var(--font-weight-normal);
  color: var(--text-primary);
  text-align: inherit;
  white-space: nowrap;
  background-color: transparent;
  border: none;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.dropdown-item:hover {
  background-color: var(--bg-secondary);
  color: var(--primary-color);
}

.pagination {
  display: flex;
  padding-left: 0;
  list-style: none;
  border-radius: var(--radius-md);
  gap: var(--spacing-1);
}

.pagination > li > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 var(--spacing-3);
  margin-left: -1px;
  line-height: 1.25;
  color: var(--primary-color);
  background-color: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  font-weight: var(--font-weight-medium);
}

.pagination > li > a:hover {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.pagination > .active > a {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: white;
}

.progress {
  display: flex;
  height: 0.5rem;
  overflow: hidden;
  font-size: var(--font-size-xs);
  background-color: var(--bg-tertiary);
  border-radius: var(--radius-full);
}

.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: white;
  text-align: center;
  background-color: var(--primary-color);
  transition: width var(--transition-slow) ease-in-out;
  border-radius: var(--radius-full);
}

.progress-bar-primary {
  background: linear-gradient(90deg, var(--primary-color), var(--primary-light));
}

.progress-bar-success {
  background: linear-gradient(90deg, var(--success-color), var(--secondary-light));
}

.progress-bar-warning {
  background: linear-gradient(90deg, var(--warning-color), var(--accent-light));
}

.progress-bar-danger {
  background: linear-gradient(90deg, var(--danger-color), #F87171);
}

.progress-bar-info {
  background: linear-gradient(90deg, var(--info-color), #60A5FA);
}

.label {
  display: inline-block;
  padding: var(--spacing-1) var(--spacing-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  color: white;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: var(--radius-sm);
}

.label-primary {
  background-color: var(--primary-color);
}

.label-success {
  background-color: var(--success-color);
}

.label-warning {
  background-color: var(--warning-color);
}

.label-danger {
  background-color: var(--danger-color);
}

.label-info {
  background-color: var(--info-color);
}

.label-default {
  background-color: var(--text-secondary);
}

.well {
  min-height: 20px;
  padding: var(--spacing-5);
  margin-bottom: var(--spacing-5);
  background-color: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
}

.thumbnail {
  display: block;
  padding: var(--spacing-1);
  margin-bottom: var(--spacing-5);
  line-height: var(--line-height-normal);
  background-color: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  transition: all var(--transition-normal);
}

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

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

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

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

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

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

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

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

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

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

.bg-warning {
  background-color: var(--warning-color) !important;
}

.bg-danger {
  background-color: var(--danger-color) !important;
}

.bg-light {
  background-color: var(--bg-secondary) !important;
}

.bg-white {
  background-color: var(--bg-primary) !important;
}

.m-t {
  margin-top: var(--spacing-4) !important;
}

.m-b {
  margin-bottom: var(--spacing-4) !important;
}

.m-l {
  margin-left: var(--spacing-4) !important;
}

.m-r {
  margin-right: var(--spacing-4) !important;
}

.p-t {
  padding-top: var(--spacing-4) !important;
}

.p-b {
  padding-bottom: var(--spacing-4) !important;
}

.p-l {
  padding-left: var(--spacing-4) !important;
}

.p-r {
  padding-right: var(--spacing-4) !important;
}

.m-t-sm {
  margin-top: var(--spacing-2) !important;
}

.m-b-sm {
  margin-bottom: var(--spacing-2) !important;
}

.m-l-sm {
  margin-left: var(--spacing-2) !important;
}

.m-r-sm {
  margin-right: var(--spacing-2) !important;
}

.p-t-sm {
  padding-top: var(--spacing-2) !important;
}

.p-b-sm {
  padding-bottom: var(--spacing-2) !important;
}

.p-l-sm {
  padding-left: var(--spacing-2) !important;
}

.p-r-sm {
  padding-right: var(--spacing-2) !important;
}

.m-t-lg {
  margin-top: var(--spacing-6) !important;
}

.m-b-lg {
  margin-bottom: var(--spacing-6) !important;
}

.m-l-lg {
  margin-left: var(--spacing-6) !important;
}

.m-r-lg {
  margin-right: var(--spacing-6) !important;
}

.p-t-lg {
  padding-top: var(--spacing-6) !important;
}

.p-b-lg {
  padding-bottom: var(--spacing-6) !important;
}

.p-l-lg {
  padding-left: var(--spacing-6) !important;
}

.p-r-lg {
  padding-right: var(--spacing-6) !important;
}

.m-n {
  margin: 0 !important;
}

.p-n {
  padding: 0 !important;
}

.pull-left {
  float: left !important;
}

.pull-right {
  float: right !important;
}

.text-center {
  text-align: center !important;
}

.text-left {
  text-align: left !important;
}

.text-right {
  text-align: right !important;
}

.font-bold {
  font-weight: var(--font-weight-bold) !important;
}

.font-semibold {
  font-weight: var(--font-weight-semibold) !important;
}

.font-medium {
  font-weight: var(--font-weight-medium) !important;
}

.font-normal {
  font-weight: var(--font-weight-normal) !important;
}

.font-thin {
  font-weight: var(--font-weight-light) !important;
}

.wrapper {
  padding: var(--spacing-5);
}

.wrapper-md {
  padding: var(--spacing-6);
}

.wrapper-lg {
  padding: var(--spacing-8);
}

.b-a {
  border: 1px solid var(--border-color);
}

.b-t {
  border-top: 1px solid var(--border-color);
}

.b-b {
  border-bottom: 1px solid var(--border-color);
}

.b-l {
  border-left: 1px solid var(--border-color);
}

.b-r {
  border-right: 1px solid var(--border-color);
}

.no-border {
  border: none !important;
}

.no-radius {
  border-radius: 0 !important;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-right: calc(var(--spacing-4) * -1);
  margin-left: calc(var(--spacing-4) * -1);
}

.row-sm {
  margin-right: calc(var(--spacing-2) * -1);
  margin-left: calc(var(--spacing-2) * -1);
}

.row-lg {
  margin-right: calc(var(--spacing-5) * -1);
  margin-left: calc(var(--spacing-5) * -1);
}

.no-gutter {
  margin-right: 0;
  margin-left: 0;
}

.no-gutter > [class*="col"] {
  padding-right: 0;
  padding-left: 0;
}

.col,
.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6,
.col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12,
.col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6,
.col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12,
.col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6,
.col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12,
.col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6,
.col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {
  position: relative;
  min-height: 1px;
  padding-right: var(--spacing-4);
  padding-left: var(--spacing-4);
  width: 100%;
}

.row-sm > [class*="col"] {
  padding-right: var(--spacing-2);
  padding-left: var(--spacing-2);
}

.row-lg > [class*="col"] {
  padding-right: var(--spacing-5);
  padding-left: var(--spacing-5);
}

.col {
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
}

.col-xs-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
.col-xs-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
.col-xs-3 { flex: 0 0 25%; max-width: 25%; }
.col-xs-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
.col-xs-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
.col-xs-6 { flex: 0 0 50%; max-width: 50%; }
.col-xs-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
.col-xs-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
.col-xs-9 { flex: 0 0 75%; max-width: 75%; }
.col-xs-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
.col-xs-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
.col-xs-12 { flex: 0 0 100%; max-width: 100%; }

@media (min-width: 576px) {
  .col-sm-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-sm-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-sm-3 { flex: 0 0 25%; max-width: 25%; }
  .col-sm-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-sm-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-sm-6 { flex: 0 0 50%; max-width: 50%; }
  .col-sm-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-sm-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-sm-9 { flex: 0 0 75%; max-width: 75%; }
  .col-sm-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-sm-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-sm-12 { flex: 0 0 100%; max-width: 100%; }
}

@media (min-width: 768px) {
  .col-md-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-md-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-md-3 { flex: 0 0 25%; max-width: 25%; }
  .col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-md-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-md-6 { flex: 0 0 50%; max-width: 50%; }
  .col-md-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-md-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-md-9 { flex: 0 0 75%; max-width: 75%; }
  .col-md-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-md-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-md-12 { flex: 0 0 100%; max-width: 100%; }
}

@media (min-width: 992px) {
  .col-lg-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-lg-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-lg-3 { flex: 0 0 25%; max-width: 25%; }
  .col-lg-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-lg-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-lg-6 { flex: 0 0 50%; max-width: 50%; }
  .col-lg-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-lg-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-lg-9 { flex: 0 0 75%; max-width: 75%; }
  .col-lg-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-lg-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-lg-12 { flex: 0 0 100%; max-width: 100%; }
}

.visible-xs { display: none !important; }
.visible-sm { display: none !important; }
.visible-md { display: none !important; }
.visible-lg { display: none !important; }
.hidden-xs { display: block !important; }
.hidden-sm { display: block !important; }
.hidden-md { display: block !important; }
.hidden-lg { display: block !important; }

@media (max-width: 575px) {
  .visible-xs { display: block !important; }
  .hidden-xs { display: none !important; }
  .text-center-xs { text-align: center !important; }
}

@media (min-width: 576px) and (max-width: 767px) {
  .visible-sm { display: block !important; }
  .hidden-sm { display: none !important; }
}

@media (min-width: 768px) and (max-width: 991px) {
  .visible-md { display: block !important; }
  .hidden-md { display: none !important; }
}

@media (min-width: 992px) {
  .visible-lg { display: block !important; }
  .hidden-lg { display: none !important; }
}

.hide { display: none !important; }
.show { display: block !important; }
.invisible { visibility: hidden; }

.affix { position: fixed; }

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

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

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

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

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInUp {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}

@keyframes slideInDown {
  from {
    transform: translateY(-100%);
  }
  to {
    transform: translateY(0);
  }
}

@keyframes bounce {
  0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
  40% { transform: translateY(-10px); }
  60% { transform: translateY(-5px); }
}

@keyframes pulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
  20%, 40%, 60%, 80% { transform: translateX(5px); }
}

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

.animate-fade-in { animation: fadeIn var(--transition-slower) ease-in-out; }
.animate-fade-in-up { animation: fadeInUp var(--transition-slower) ease-in-out; }
.animate-fade-in-down { animation: fadeInDown var(--transition-slower) ease-in-out; }
.animate-fade-in-left { animation: fadeInLeft var(--transition-slower) ease-in-out; }
.animate-fade-in-right { animation: fadeInRight var(--transition-slower) ease-in-out; }
.animate-bounce { animation: bounce 1s ease-in-out; }
.animate-pulse { animation: pulse 2s ease-in-out infinite; }
.animate-shake { animation: shake 0.5s ease-in-out; }
.animate-spin { animation: spin 1s linear infinite; }

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

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

.hover-scale {
  transition: transform var(--transition-normal);
}

.hover-scale:hover {
  transform: scale(1.02);
}

.hover-glow {
  transition: box-shadow var(--transition-normal);
}

.hover-glow:hover {
  box-shadow: 0 0 20px rgba(79, 70, 229, 0.3);
}

.card {
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: all var(--transition-normal);
}

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

.card-header {
  padding: var(--spacing-5);
  background: linear-gradient(135deg, var(--bg-secondary), var(--bg-tertiary));
  border-bottom: 1px solid var(--border-color);
}

.card-body {
  padding: var(--spacing-6);
}

.card-footer {
  padding: var(--spacing-4) var(--spacing-5);
  background: var(--bg-secondary);
  border-top: 1px solid var(--border-color);
}

.stat-card {
  padding: var(--spacing-6);
  background: linear-gradient(135deg, var(--bg-primary), var(--bg-secondary));
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  transition: all var(--transition-normal);
}

.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.stat-icon {
  width: 3.5rem;
  height: 3.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  font-size: var(--font-size-2xl);
  color: white;
  background: linear-gradient(135deg, var(--primary-color), var(--primary-light));
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3);
}

.stat-icon.success {
  background: linear-gradient(135deg, var(--success-color), var(--secondary-light));
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.stat-icon.warning {
  background: linear-gradient(135deg, var(--warning-color), var(--accent-light));
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}

.stat-icon.danger {
  background: linear-gradient(135deg, var(--danger-color), #F87171);
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3);
}

.stat-icon.info {
  background: linear-gradient(135deg, var(--info-color), #60A5FA);
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.stat-value {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  line-height: var(--line-height-tight);
}

.stat-label {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin-top: var(--spacing-1);
}

.round {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-full);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-normal);
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.1), rgba(129, 140, 248, 0.1));
  color: var(--primary-color);
  border: 3px solid rgba(79, 70, 229, 0.1);
  transition: all var(--transition-normal);
}

.round:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.2);
}

.avatar {
  display: inline-block;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 2px solid var(--border-color);
  transition: all var(--transition-fast);
}

.avatar:hover {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar-lg {
  width: 5rem;
  height: 5rem;
}

.avatar-sm {
  width: 2rem;
  height: 2rem;
}

.thumb-lg {
  width: 6rem;
  height: 6rem;
}

.hbox {
  display: flex;
  width: 100%;
  height: 100%;
}

.hbox .col {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.v-middle {
  align-items: center !important;
}

.v-top {
  align-items: flex-start !important;
}

.v-bottom {
  align-items: flex-end !important;
}

.vbox {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  min-height: 15rem;
}

.line {
  height: 1px;
  margin: var(--spacing-4) 0;
  background-color: var(--border-color);
}

.line-dashed {
  border-top: 1px dashed var(--border-color);
  background: none;
}

.line-lg {
  height: 2px;
  margin: var(--spacing-6) 0;
}

.dk {
  color: var(--text-primary);
}

.lter {
  color: var(--text-secondary);
}

.text-md {
  font-size: var(--font-size-sm);
}

.text-lg {
  font-size: var(--font-size-lg);
}

.text-xl {
  font-size: var(--font-size-xl);
}

.text-2x {
  font-size: var(--font-size-2xl);
}

.text-3x {
  font-size: var(--font-size-3xl);
}

.w-full {
  width: 100%;
}

.w-auto {
  width: auto;
}

.w-xxl {
  max-width: 30rem;
}

.w-auto-xs {
  width: 100%;
  max-width: 20rem;
}

@media (max-width: 767px) {
  .w-auto-xs {
    max-width: 100%;
  }
}

.h-full {
  height: 100%;
}

.m-t-n-xxl {
  margin-top: -3rem;
}

.m-t-n-xl {
  margin-top: -2rem;
}

.m-t-n-lg {
  margin-top: -1.5rem;
}

.m-t-n-md {
  margin-top: -1rem;
}

.m-t-n-sm {
  margin-top: -0.5rem;
}

.padder-v {
  padding-top: var(--spacing-4);
  padding-bottom: var(--spacing-4);
}

.padder {
  padding: var(--spacing-4);
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-wrap {
  flex-wrap: wrap;
}

.gap-sm {
  gap: var(--spacing-2);
}

.gap-md {
  gap: var(--spacing-4);
}

.gap-lg {
  gap: var(--spacing-6);
}

.clearfix::after {
  content: "";
  display: table;
  clear: both;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }

  .visible-xs {
    display: block !important;
  }

  .text-center-xs {
    text-align: center !important;
  }

  .text-left-xs {
    text-align: left !important;
  }

  .text-right-xs {
    text-align: right !important;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }

  .visible-sm {
    display: block !important;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .hidden-md {
    display: none !important;
  }

  .visible-md {
    display: block !important;
  }
}

@media (min-width: 1200px) {
  .hidden-lg {
    display: none !important;
  }

  .visible-lg {
    display: block !important;
  }
}

@media (max-width: 991px) {
  .hidden-sm-down {
    display: none !important;
  }

  .visible-sm-down {
    display: block !important;
  }
}

@media (min-width: 992px) {
  .hidden-md-up {
    display: none !important;
  }

  .visible-md-up {
    display: block !important;
  }
}

@media (max-width: 1199px) {
  .hidden-md-down {
    display: none !important;
  }

  .visible-md-down {
    display: block !important;
  }
}

@media (min-width: 1200px) {
  .hidden-lg-up {
    display: none !important;
  }

  .visible-lg-up {
    display: block !important;
  }
}

.print-only {
  display: none;
}

@media print {
  .print-only {
    display: block;
  }

  .no-print {
    display: none !important;
  }
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.scrollbar-thin::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.scrollbar-thin::-webkit-scrollbar-track {
  background: var(--bg-tertiary);
}

.scrollbar-thin::-webkit-scrollbar-thumb {
  background: var(--text-muted);
  border-radius: 3px;
}

.scrollbar-thin::-webkit-scrollbar-thumb:hover {
  background: var(--text-secondary);
}

@media (max-width: 320px) {
  html {
    font-size: 14px;
  }
}

@media (min-width: 321px) and (max-width: 375px) {
  html {
    font-size: 15px;
  }
}

@media (min-width: 376px) and (max-width: 414px) {
  html {
    font-size: 16px;
  }
}

@media (min-width: 415px) and (max-width: 767px) {
  html {
    font-size: 16px;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  html {
    font-size: 15px;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  html {
    font-size: 16px;
  }
}

@media (min-width: 1200px) {
  html {
    font-size: 16px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    --text-primary: #F9FAFB;
    --text-secondary: #D1D5DB;
    --text-muted: #9CA3AF;
    --text-disabled: #6B7280;
    
    --bg-primary: #1F2937;
    --bg-secondary: #111827;
    --bg-tertiary: #374151;
    --bg-quaternary: #4B5563;
    
    --border-color: #374151;
    --border-light: #4B5563;
    --border-dark: #6B7280;
  }
}
