/* 
 * GymMeet Pro CSS - Environment-driven color palette
 * 
 * IMPORTANT: Colors are now loaded from environment variables!
 * 
 * How it works:
 * 1. Environment variables (.env) define base brand colors
 * 2. Django settings.py loads these into BRAND_COLORS
 * 3. Dynamic CSS view (/static/css/brand-colors.css) generates variations
 * 4. This CSS file provides fallback values and structural styles
 * 
 * To change colors:
 * - Update .env file: BRAND_PRIMARY_COLOR=#your-color
 * - Restart Django server
 * - Colors automatically generate variations and RGB values
 * 
 * Updated: 2025-01-12 - Migrated to environment-based colors
 */

:root {
  /* === FALLBACK BRAND COLORS === */
  /* These are overridden by dynamic CSS from environment variables */
  --primary: #1549DE;      /* Fallback: Professional blue */
  --primary-light: #4470ed;/* Fallback: Lighter blue for hover states */
  --primary-dark: #0d2d8b; /* Fallback: Darker blue for active states */
  --secondary: #6c757d;    /* Fallback: Professional gray */
  --secondary-dark: #5a6268; /* Fallback: Darker secondary for hover states */
  --navy: #081e5d;         /* Fallback: Dark navy blue */
  --deep-blue: #040f2e;    /* Fallback: Deep blue for accents */
  
  /* === FALLBACK BOOTSTRAP COLORS === */
  /* These are overridden by dynamic CSS from environment variables */
  --bs-primary: #1549DE;   /* Fallback: Professional blue */
  --bs-secondary: #6c757d; /* Fallback: Professional gray */
  --bs-secondary-dark: #5a6268; /* Fallback: Darker secondary for hover states */
  --bs-success: #198754;   /* Fallback: Success green */
  --bs-info: #0dcaf0;      /* Fallback: Info cyan */
  --bs-warning: #ffc107;   /* Fallback: Warning yellow */
  --bs-danger: #dc3545;    /* Fallback: Danger red */
  --bs-light: #f8f9fa;     /* Fallback: Light gray */
  --bs-dark: #212529;      /* Fallback: Dark */
  --bs-purple: #6f42c1;    /* Fallback: Purple accent */
  
  /* === FALLBACK COLOR VARIATIONS === */
  /* These are overridden by dynamic CSS that generates variations from environment colors */
  /* Primary color variations (50-900 scale) - FALLBACK VALUES */
  --primary-50: #e7edfc;
  --primary-100: #d0dbfa;
  --primary-200: #a1b7f6;
  --primary-300: #7393f1;
  --primary-400: #4470ed;
  --primary-500: #1549DE;  /* Base color */
  --primary-600: #113dba;
  --primary-700: #0d2d8b;
  --primary-800: #081e5d;
  --primary-900: #040f2e;
  
  /* Success color variations */
  --success-50: #e9fbf2;
  --success-100: #d3f7e6;
  --success-200: #a8efce;
  --success-300: #7de7b6;
  --success-400: #52df9e;
  --success-500: #198754;  /* Base color */
  --success-600: #1fac6b;
  --success-700: #178150;
  --success-800: #0f5635;
  --success-900: #072b1a;
  
  /* Warning color variations */
  --warning-50: #fef8e5;
  --warning-100: #fff2cc;
  --warning-200: #fee599;
  --warning-300: #fed866;
  --warning-400: #ffcc32;
  --warning-500: #ffc107;  /* Base color */
  --warning-600: #cc9900;
  --warning-700: #997200;
  --warning-800: #664c00;
  --warning-900: #332600;
  
  /* Danger color variations */
  --danger-50: #fbe9ea;
  --danger-100: #f7d3d6;
  --danger-200: #efa8ae;
  --danger-300: #e87c86;
  --danger-400: #e0515e;
  --danger-500: #dc3545;   /* Base color */
  --danger-600: #ad1e2b;
  --danger-700: #821620;
  --danger-800: #560f15;
  --danger-900: #2b070a;
  
  /* === SEMANTIC COLORS === */
  --success: #28a745;      /* Green for success/approved */
  --success-light: #d4edda; /* Light green background */
  --success-alt: #20c997;  /* Alternative success green */
  --warning: #ffc107;      /* Yellow for warnings/pending */
  --warning-light: #fff3cd; /* Light yellow background */
  --warning-alt: #fd7e14;  /* Alternative warning orange */
  --danger: #dc3545;       /* Red for errors/withdrawn */
  --danger-light: #f8d7da; /* Light red background */
  --info: #17a2b8;         /* Blue for information */
  --info-light: #d1ecf1;   /* Light blue background */
  --info-alt: #0dcaf0;     /* Alternative info cyan */
  
  /* === NEUTRAL COLORS === */
  --white: #ffffff;        /* Pure white */
  --black: #000000;        /* Pure black */
  --dark: #090707;         /* Almost black for text */
  --light: #f8f9fa;        /* Light background */
  --gray-100: #f8f9fa;     /* Lightest gray */
  --gray-200: #e9ecef;     /* Light gray (cards, borders) */
  --gray-300: #dee2e6;     /* Medium-light gray */
  --gray-400: #ced4da;     /* Medium gray */
  --gray-500: #adb5bd;     /* Medium gray */
  --gray-600: #6c757d;     /* Muted text */
  --gray-700: #495057;     /* Dark text */
  --gray-800: #343a40;     /* Darker text */
  --gray-900: #212529;     /* Darkest text */
  
  /* === LEGACY ALIASES === */
  --gray: var(--gray-600);         /* Muted text - legacy alias */
  --light-gray: var(--gray-200);   /* Background for cards - legacy alias */
  
  /* === TEXT COLORS === */
  --text-on-dark: #ffffff;         /* White text for dark backgrounds */
  --text-muted-on-dark: #ced4da;   /* Light gray text for dark backgrounds */
  --text-primary: var(--dark);     /* Primary text color */
  --text-secondary: var(--gray-600); /* Secondary text color */
  --text-muted: var(--gray-500);   /* Muted text color */
  
  /* === BORDER COLORS === */
  --border-color: var(--gray-200); /* Standard border color */
  --border-light: var(--gray-100); /* Light border color */
  --border-dark: var(--gray-300);  /* Dark border color */
  
  /* === SHADOW COLORS === */
  --shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.12);
  --shadow-lg: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --shadow-modern: 0 2px 15px rgba(0, 0, 0, 0.08);
  --shadow-modern-hover: 0 8px 25px rgba(0, 0, 0, 0.15);
  
  /* === FALLBACK GRADIENT COLORS === */
  /* These are overridden by dynamic CSS that generates gradients from environment colors */
  --gradient-primary: linear-gradient(135deg, #1549DE 0%, #4470ed 100%);
  --gradient-success: linear-gradient(135deg, #198754 0%, #52df9e 100%);
  --gradient-warning: linear-gradient(135deg, #ffc107 0%, #ffcc32 100%);
  --gradient-info: linear-gradient(135deg, #d1ecf1 0%, #bee5eb 100%);
  
  /* === CARD COLORS === */
  --card-bg: var(--white);
  --card-border: var(--border-color);
  --card-shadow: var(--shadow-modern);
  --card-shadow-hover: var(--shadow-modern-hover);
  
  /* === EMAIL TEMPLATE COLORS === */
  --email-header-bg: var(--bs-primary);
  --email-success-bg: var(--success);
  --email-warning-bg: var(--warning-alt);
  --email-border: #ddd;
  --email-bg-light: #f2f2f2;
  --email-text-dark: #333;
  
  /* === PWA COLORS === */
  --pwa-theme-color: var(--primary);
  --pwa-status-bar: var(--primary);
  
  /* === BOOTSTRAP CSS VARIABLE OVERRIDES === */
  /* Override Bootstrap 5 CSS variables to match our brand */
  --bs-primary-rgb: 21, 73, 222;      /* Professional blue RGB */
  --bs-secondary-rgb: 108, 117, 125;  /* Bootstrap secondary gray RGB */
  --bs-success-rgb: 25, 135, 84;      /* Bootstrap success green RGB */
  --bs-info-rgb: 13, 202, 240;        /* Bootstrap info cyan RGB */
  --bs-warning-rgb: 255, 193, 7;      /* Bootstrap warning yellow RGB */
  --bs-danger-rgb: 220, 53, 69;       /* Bootstrap danger red RGB */
  --bs-light-rgb: 248, 249, 250;      /* Bootstrap light gray RGB */
  --bs-dark-rgb: 33, 37, 41;          /* Bootstrap dark RGB */
  
  /* Bootstrap semantic color overrides - use the hex values */
  /* Note: These should override Bootstrap's default CSS variables */
  --bs-primary: #1549DE;      /* Professional blue - matches brand */
  --bs-secondary: #6c757d;    /* Bootstrap secondary gray */
  --bs-success: #198754;      /* Bootstrap success green */
  --bs-info: #0dcaf0;         /* Bootstrap info cyan */
  --bs-warning: #ffc107;      /* Bootstrap warning yellow */
  --bs-danger: #dc3545;       /* Bootstrap danger red */
  --bs-light: #f8f9fa;        /* Bootstrap light gray */
  --bs-dark: #212529;         /* Bootstrap dark */
  --bs-purple: #6f42c1;       /* Bootstrap purple */
  
  /* Bootstrap gray scale overrides */
  --bs-gray-100: var(--gray-100);
  --bs-gray-200: var(--gray-200);
  --bs-gray-300: var(--gray-300);
  --bs-gray-400: var(--gray-400);
  --bs-gray-500: var(--gray-500);
  --bs-gray-600: var(--gray-600);
  --bs-gray-700: var(--gray-700);
  --bs-gray-800: var(--gray-800);
  --bs-gray-900: var(--gray-900);
  
  /* Bootstrap border colors */
  --bs-border-color: var(--border-color);
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  
  /* Bootstrap body colors */
  --bs-body-color: var(--text-primary);
  --bs-body-bg: var(--white);
  
  /* Bootstrap link colors */
  --bs-link-color: var(--bs-primary);
  --bs-link-hover-color: #0a58ca;
}

/* Base styles */
body {
  font-family: 'Arial', sans-serif;
  color: var(--dark);
  background-color: var(--light);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
}

/* Fix for dark background situations */
.bg-primary, .bg-primary-dark, .bg-dark, .bg-navy, .bg-deep-blue, 
.card-header.bg-primary, .card-header.bg-dark, .card-header.bg-navy {
  color: var(--text-on-dark) !important;
}

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

/* Navigation bar */
.navbar {
  background-color: var(--primary) !important;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
}

.navbar-dark .navbar-brand {
  color: var(--white);
  font-weight: 700;
  letter-spacing: 0.5px;
}

.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.85);
  transition: color 0.3s ease;
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link:focus {
  color: var(--white);
}

.navbar-dark .navbar-nav .active > .nav-link {
  font-weight: 600;
  color: var(--white);
}

.dropdown-menu {
  border: none;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  z-index: 1050; /* Ensure dropdowns appear above other content */
}

.dropdown-item:hover, .dropdown-item:focus {
  background-color: var(--primary-light);
  color: var(--white);
}

/* Fix dropdown overflow in table-responsive containers */
.table-responsive {
  overflow: visible; /* Allow dropdowns to extend beyond table bounds */
}

/* Create a positioned context for dropdowns while allowing overflow */
.table-responsive .dropdown {
  position: relative; /* Provide positioning context for dropdown menu */
}

.table-responsive .dropdown-menu {
  position: absolute !important; /* Use absolute positioning relative to dropdown container */
  z-index: 1050;
  /* Bootstrap's data-bs-boundary="viewport" will handle proper positioning */
}

/* Force proper positioning for dropdowns in table cells */
.table-responsive td .dropdown {
  position: relative !important;
}

.table-responsive td .dropdown-menu {
  position: absolute !important;
  z-index: 1060; /* Higher z-index to ensure visibility */
}

/* Ensure dropdowns don't get clipped by card containers */
.card .dropdown-menu {
  z-index: 1040;
}

/* Fix dropdown positioning in card bodies */
.card-body .dropdown {
  position: static;
}

.card-body .dropdown-menu {
  position: absolute;
  z-index: 1040;
}

/* Utility classes for dropdown positioning */
.dropdown-menu-fixed {
  position: fixed !important;
  z-index: 1050;
}

/* Cards */
.card {
  border: 1px solid var(--card-border);
  box-shadow: var(--card-shadow);
  transition: box-shadow 0.3s ease;
  margin-bottom: 1.5rem;
  background-color: var(--card-bg);
}

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

/* Modern card styles */
.modern-card {
  background: var(--card-bg);
  border-radius: 12px;
  box-shadow: var(--card-shadow);
  border: 1px solid var(--card-border);
  transition: all 0.3s ease;
}

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

.card-header {
  font-weight: 600;
}

.card-body {
  color: var(--dark);
}

.card-header.bg-primary {
  background-color: var(--primary) !important;
  color: var(--text-on-dark) !important;
}

.card-header.bg-success {
  background-color: var(--success) !important;
  color: var(--text-on-dark) !important;
}

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

.card-header.bg-danger {
  background-color: var(--danger) !important;
  color: var(--text-on-dark) !important;
}

.card-header.bg-info {
  background-color: var(--info) !important;
  color: var(--text-on-dark) !important;
}

.card-header.bg-secondary {
  background-color: var(--secondary) !important;
  color: var(--text-on-dark) !important;
}

/* Buttons */
.btn-primary {
  background-color: var(--primary);
  border-color: var(--primary);
  color: var(--text-on-dark);
}

.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
  background-color: var(--primary-light);
  border-color: var(--primary-light);
  color: var(--text-on-dark);
}

.btn-outline-primary {
  color: var(--primary);
  border-color: var(--primary);
}

.btn-outline-primary:hover, .btn-outline-primary:focus {
  background-color: var(--primary);
  border-color: var(--primary);
  color: var(--text-on-dark);
}

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

.btn-secondary:hover, .btn-secondary:focus, .btn-secondary:active {
  background-color: var(--secondary-dark);
  border-color: var(--secondary-dark);
  color: var(--text-on-dark);
}

/* Forms */
.form-control:focus, .form-select:focus {
  border-color: var(--primary-400);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Tables */
table {
  background-color: var(--white);
  color: var(--dark);
}

table tr {
  background-color: var(--white);
}

table td, table th {
  color: var(--dark);
}

.table-dark th {
  background-color: var(--primary-dark) !important;
  color: var(--text-on-dark) !important;
  border-color: var(--primary) !important;
}

.table-dark td {
  background-color: var(--primary) !important;
  color: var(--text-on-dark) !important;
  border-color: var(--primary-light) !important;
}

.table-hover tbody tr:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.05);
}

/* Badges */
.badge.bg-primary {
  background-color: var(--primary) !important;
  color: var(--text-on-dark) !important;
}

.badge.bg-secondary {
  background-color: var(--secondary) !important;
  color: var(--text-on-dark) !important;
}

.badge.bg-success {
  background-color: var(--success) !important;
  color: var(--text-on-dark) !important;
}

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

.badge.bg-danger {
  background-color: var(--danger) !important;
  color: var(--text-on-dark) !important;
}

.badge.bg-info {
  background-color: var(--info) !important;
  color: var(--text-on-dark) !important;
}

/* Alerts */
.alert-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.15);
  color: var(--primary-700);
  border-color: rgba(var(--bs-primary-rgb), 0.2);
}

/* Breadcrumbs */
.breadcrumb {
  background-color: transparent;
  padding: 0.75rem 0;
}

.breadcrumb-item.active {
  color: var(--primary);
  font-weight: 500;
}

.breadcrumb-item a {
  color: var(--gray);
  text-decoration: none;
}

.breadcrumb-item a:hover {
  color: var(--primary);
}

/* Footer */
footer {
  background-color: var(--primary-dark);
  color: var(--text-on-dark);
  padding: 1.5rem 0;
  margin-top: 3rem;
}

footer a {
  color: rgba(255, 255, 255, 0.8);
}

footer a:hover {
  color: var(--white);
}

/* Meet cards */
.card-header.bg-classification-regular {
  background-color: var(--primary);
  color: var(--text-on-dark);
}

.card-header.bg-classification-states {
  background-color: var(--deep-blue);
  color: var(--text-on-dark);
}

.card-header.bg-classification-regionals {
  background-color: var(--secondary);
  color: var(--text-on-dark);
}

/* Registration status indicators */
.registration-status.approved {
  color: var(--success);
}

.registration-status.pending {
  color: var(--warning);
}

.registration-status.withdrawn {
  color: var(--danger);
}

/* Pagination */
.pagination .page-link {
  color: var(--primary);
}

.pagination .page-item.active .page-link {
  background-color: var(--primary);
  border-color: var(--primary);
  color: var(--text-on-dark);
}

/* Team members specific styles */
.team-header {
  background-color: var(--primary);
  color: var(--text-on-dark);
  padding: 1rem;
  border-radius: 0.25rem;
  margin-bottom: 1rem;
}

.team-header h2, .team-header h3, .team-header h4 {
  color: var(--text-on-dark);
  margin-bottom: 0;
}

.team-details {
  background-color: var(--light-gray);
  padding: 1rem;
  border-radius: 0.25rem;
  margin-bottom: 1rem;
}

.team-details h3 {
  color: var(--dark);
}

.team-member-list {
  background-color: var(--white);
  border-radius: 0.25rem;
  overflow: hidden;
}

.team-member-row {
  border-bottom: 1px solid var(--light-gray);
  padding: 0.75rem 0;
}

/* Custom styles for meet listings */
.meet-card {
  height: 100%;
  transition: transform 0.2s ease;
}

.meet-card:hover {
  transform: translateY(-5px);
}

.meet-details {
  font-size: 0.9rem;
}

/* Custom styles for athlete listings */
.athlete-list-item {
  border-left: 4px solid var(--primary);
  padding-left: 1rem;
  margin-bottom: 1rem;
}

/* Custom animation for pending approvals */
@keyframes pulse {
  0% { opacity: 1; }
  50% { opacity: 0.7; }
  100% { opacity: 1; }
}

.needs-approval {
  animation: pulse 2s infinite;
}

/* Media queries for responsive design */
@media (max-width: 768px) {
  .card-title {
    font-size: 1.25rem;
  }
  
  .table-responsive {
    border: none;
  }
}

/* === UTILITY CLASSES === */

/* Background Color Utilities */
.bg-bs-primary { background-color: var(--bs-primary) !important; }
.bg-bs-secondary { background-color: var(--bs-secondary) !important; }
.bg-bs-success { background-color: var(--bs-success) !important; }
.bg-bs-info { background-color: var(--bs-info) !important; }
.bg-bs-warning { background-color: var(--bs-warning) !important; }
.bg-bs-danger { background-color: var(--bs-danger) !important; }
.bg-bs-light { background-color: var(--bs-light) !important; }
.bg-bs-dark { background-color: var(--bs-dark) !important; }
.bg-bs-purple { background-color: var(--bs-purple) !important; }

/* Text Color Utilities */
.text-bs-primary { color: var(--bs-primary) !important; }
.text-bs-secondary { color: var(--bs-secondary) !important; }
.text-bs-success { color: var(--bs-success) !important; }
.text-bs-info { color: var(--bs-info) !important; }
.text-bs-warning { color: var(--bs-warning) !important; }
.text-bs-danger { color: var(--bs-danger) !important; }
.text-bs-light { color: var(--bs-light) !important; }
.text-bs-dark { color: var(--bs-dark) !important; }
.text-bs-purple { color: var(--bs-purple) !important; }

/* Border Color Utilities */
.border-bs-primary { border-color: var(--bs-primary) !important; }
.border-bs-secondary { border-color: var(--bs-secondary) !important; }
.border-bs-success { border-color: var(--bs-success) !important; }
.border-bs-info { border-color: var(--bs-info) !important; }
.border-bs-warning { border-color: var(--bs-warning) !important; }
.border-bs-danger { border-color: var(--bs-danger) !important; }
.border-bs-light { border-color: var(--bs-light) !important; }
.border-bs-dark { border-color: var(--bs-dark) !important; }

/* Shadow Utilities */
.shadow-modern { box-shadow: var(--shadow-modern) !important; }
.shadow-modern-hover:hover { box-shadow: var(--shadow-modern-hover) !important; }

/* Gradient Background Utilities */
.bg-gradient-primary { background: var(--gradient-primary) !important; }
.bg-gradient-success { background: var(--gradient-success) !important; }
.bg-gradient-warning { background: var(--gradient-warning) !important; }
.bg-gradient-info { background: var(--gradient-info) !important; }

/* Button Gradient Utilities */
.btn-gradient-primary {
  background: var(--gradient-primary);
  border: none;
  color: var(--white);
  transition: all 0.3s ease;
}

.btn-gradient-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  color: var(--white);
}

.btn-gradient-success {
  background: var(--gradient-success);
  border: none;
  color: var(--white);
  transition: all 0.3s ease;
}

.btn-gradient-success:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  color: var(--white);
}

.btn-gradient-warning {
  background: var(--gradient-warning);
  border: none;
  color: var(--white);
  transition: all 0.3s ease;
}

.btn-gradient-warning:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  color: var(--white);
}

/* Card Utilities */
.card-modern {
  background: var(--card-bg);
  border-radius: 12px;
  box-shadow: var(--card-shadow);
  border: 1px solid var(--card-border);
  transition: all 0.3s ease;
}

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

/* Text Color Utilities - Extended */
.text-primary-brand { color: var(--primary) !important; }
.text-secondary-brand { color: var(--secondary) !important; }
.text-navy { color: var(--navy) !important; }
.text-deep-blue { color: var(--deep-blue) !important; }

/* Background Color Utilities - Extended */
.bg-primary-brand { background-color: var(--primary) !important; }
.bg-secondary-brand { background-color: var(--secondary) !important; }
.bg-navy { background-color: var(--navy) !important; }
.bg-deep-blue { background-color: var(--deep-blue) !important; }

/* === BOOTSTRAP EXTENSION UTILITIES === */

/* Enhanced Bootstrap Button Variants */
.btn-gradient {
  border: none;
  color: var(--white);
  transition: all 0.3s ease;
}

.btn-gradient:hover {
  transform: translateY(-2px);
  color: var(--white);
  text-decoration: none;
}

.btn-outline-bs-primary {
  color: var(--bs-primary);
  border-color: var(--bs-primary);
  background: transparent;
}

.btn-outline-bs-primary:hover {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: var(--white);
}

.btn-outline-bs-success {
  color: var(--bs-success);
  border-color: var(--bs-success);
  background: transparent;
}

.btn-outline-bs-success:hover {
  background-color: var(--bs-success);
  border-color: var(--bs-success);
  color: var(--white);
}

/* Enhanced Alert Variants */
.alert-bs-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.1);
  border-color: var(--bs-primary);
  color: var(--primary-700);
}

.alert-bs-success {
  background-color: rgba(var(--bs-success-rgb), 0.1);
  border-color: var(--bs-success);
  color: #0f5132;
}

.alert-bs-warning {
  background-color: rgba(var(--bs-warning-rgb), 0.1);
  border-color: var(--bs-warning);
  color: #664d03;
}

.alert-bs-danger {
  background-color: rgba(var(--bs-danger-rgb), 0.1);
  border-color: var(--bs-danger);
  color: #842029;
}

/* Enhanced Badge Variants */
.badge-bs-primary { 
  background-color: var(--bs-primary) !important; 
  color: var(--white) !important; 
}

.badge-bs-secondary { 
  background-color: var(--bs-secondary) !important; 
  color: var(--white) !important; 
}

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

.badge-bs-warning { 
  background-color: var(--bs-warning) !important; 
  color: var(--dark) !important; 
}

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

.badge-bs-info { 
  background-color: var(--bs-info) !important; 
  color: var(--dark) !important; 
}

/* Form Control Enhancements */
.form-control-modern {
  border-radius: 8px;
  border: 2px solid var(--border-color);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-control-modern:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Table Enhancements */
.table-modern {
  border: none;
  box-shadow: var(--shadow-sm);
}

.table-modern thead th {
  background-color: var(--gray-100);
  border-bottom: 2px solid var(--border-color);
  font-weight: 600;
  color: var(--gray-700);
}

.table-modern tbody tr:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.05);
}

/* Card Enhancements */
.card-enhanced {
  border: 1px solid var(--border-color);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.3s ease;
}

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

.card-enhanced .card-header {
  background-color: var(--gray-50);
  border-bottom: 1px solid var(--border-color);
  font-weight: 600;
}

/* Consistent Color Mapping Classes */
.text-brand-primary { color: var(--primary) !important; }
.text-brand-secondary { color: var(--secondary) !important; }
.bg-brand-primary { background-color: var(--primary) !important; }
.bg-brand-secondary { background-color: var(--secondary) !important; }
.border-brand-primary { border-color: var(--primary) !important; }
.border-brand-secondary { border-color: var(--secondary) !important; }

/* ============================================================================
   IMPROVED CHECKBOX STYLING - Enhanced visibility and user experience
   ============================================================================ */

/* Enhanced checkbox styling for better visibility */
.form-check-input[type="checkbox"] {
  width: 1.2em;
  height: 1.2em;
  border: 2px solid var(--border-color);
  border-radius: 4px;
  background-color: var(--white);
  transition: all 0.2s ease-in-out;
  cursor: pointer;
  position: relative;
  margin-top: 0.125em;
  flex-shrink: 0;
}

.form-check-input[type="checkbox"]:hover {
  border-color: var(--primary);
  box-shadow: 0 0 0 0.1rem rgba(var(--bs-primary-rgb), 0.15);
}

.form-check-input[type="checkbox"]:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
  outline: none;
}

.form-check-input[type="checkbox"]:checked {
  background-color: var(--primary);
  border-color: var(--primary);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
  background-size: 0.8em;
  background-position: center;
  background-repeat: no-repeat;
}

.form-check-input[type="checkbox"]:checked:hover {
  background-color: var(--primary-600);
  border-color: var(--primary-600);
}

.form-check-input[type="checkbox"]:checked:focus {
  background-color: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Improved styling for labels containing checkboxes */
.list-group-item.form-check,
.list-group-item label,
label.list-group-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem;
  cursor: pointer;
  transition: background-color 0.15s ease-in-out;
}

.list-group-item:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.04);
}

.list-group-item:has(.form-check-input:checked) {
  background-color: rgba(var(--bs-primary-rgb), 0.08);
  border-color: var(--primary);
}

/* Ensure proper spacing and alignment in checkbox containers */
.form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  min-height: 1.5rem;
  padding-left: 0;
}

.form-check .form-check-input {
  margin-left: 0;
  margin-right: 0;
}

.form-check-label {
  cursor: pointer;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}
