html {
  font-size: 14px;
}

/* AI chat inline link (shared across system / ops / landing assistants) */
.nf-ai-link {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    margin: 2px 2px;
    border-radius: 12px;
    background: rgba(245, 158, 11, 0.12);
    color: #b45309 !important;
    text-decoration: none !important;
    font-weight: 500;
    border: 1px solid rgba(245, 158, 11, 0.3);
    transition: background 0.15s, transform 0.1s;
}
.nf-ai-link:hover {
    background: rgba(245, 158, 11, 0.22);
    transform: translateY(-1px);
    text-decoration: none !important;
}
.nf-ai-link i {
    font-size: 0.85em;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

/* ============================================
   FIELDCHERRY ENHANCED THEME SYSTEM
   Unified Brand Experience & Professional Polish
   ============================================ */

:root {
    /* Primary Brand Colors */
    --primary-color: #275378;
    --primary-dark: #1B3A54;
    --primary-light: #326B98;
    --secondary-color: #AD2227;
    --secondary-dark: #8B1A1E;
    --secondary-light: #D44347;
    
    /* Semantic Colors */
    --success-color: #10b981;
    --success-dark: #059669;
    --info-color: #3b82f6;
    --warning-color: #f59e0b;
    --danger-color: #ef4444;
    
    /* Neutral Palette */
    --gray-50: #f9fafb;
    --gray-100: #f3f4f6;
    --gray-200: #e5e7eb;
    --gray-300: #d1d5db;
    --gray-400: #9ca3af;
    --gray-500: #6b7280;
    --gray-600: #4b5563;
    --gray-700: #374151;
    --gray-800: #1f2937;
    --gray-900: #111827;
    
    /* Gradients */
    --gradient-primary: linear-gradient(135deg, #275378 0%, #326B98 100%);
    --gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);
    --gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    --gradient-warning: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    
    /* Shadows */
    --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 -1px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    --shadow-glow: 0 0 20px rgba(0, 97, 190, 0.3);
    
    /* Spacing */
    --space-xs: 0.25rem;
    --space-sm: 0.5rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    
    /* Border Radius */
    --radius-sm: 0.375rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-full: 9999px;
    
    /* 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);
}

/* Dark Mode Support */
[data-theme="dark"] {
    /* Inverted Grays */
    --gray-50: #111827;
    --gray-100: #1f2937;
    --gray-200: #374151;
    --gray-300: #4b5563;
    --gray-400: #6b7280;
    --gray-500: #9ca3af;
    --gray-600: #d1d5db;
    --gray-700: #e5e7eb;
    --gray-800: #f3f4f6;
    --gray-900: #f9fafb;
    
    /* Enhanced Dark Mode Shadows */
    --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
    --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.4), 0 1px 2px -1px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -2px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -4px rgba(0, 0, 0, 0.3);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] body {
    background-color: var(--gray-100);
    color: var(--gray-800);
}

/* General card dark mode - EXCEPT form cards which stay white */
[data-theme="dark"] .card:not(:has(form)):not(:has(.form-control)):not(:has(.form-select)) {
    background-color: var(--gray-800);
    color: #1f2937;
    border: 1px solid var(--gray-700);
}

[data-theme="dark"] .card:not(:has(form)):not(:has(.form-control)):not(:has(.form-select)) .card-header {
    background-color: var(--gray-800);
    border-bottom: 1px solid var(--gray-600);
    color: #1f2937;
}

[data-theme="dark"] .card:not(:has(form)):not(:has(.form-control)):not(:has(.form-select)) .card-body {
    color: #1f2937;
}

/* Keep form cards white in dark mode for better usability */
[data-theme="dark"] .card:has(form),
[data-theme="dark"] .card:has(.form-control),
[data-theme="dark"] .card:has(.form-select) {
    background-color: white;
    color: var(--gray-900);
}

/* Pricing cards - preserve original backgrounds */
[data-theme="dark"] .bg-primary {
    background-color: #275378 !important;
}

[data-theme="dark"] .bg-dark {
    background-color: #1f2937 !important;
}

[data-theme="dark"] .text-white {
    color: white !important;
}

[data-theme="dark"] .text-white-50 {
    color: rgba(255, 255, 255, 0.5) !important;
}

/* Ensure pricing card headers with custom backgrounds stay as intended */
[data-theme="dark"] .card-header.bg-primary,
[data-theme="dark"] .card-header.bg-dark,
[data-theme="dark"] .card-header.bg-light {
    border-bottom: none;
}

[data-theme="dark"] .card-header.bg-primary {
    background-color: #275378 !important;
}

[data-theme="dark"] .card-header.bg-dark {
    background-color: #1f2937 !important;
}

[data-theme="dark"] .card-header.bg-light {
    background-color: #f3f4f6 !important;
}

/* Keep text colors correct in pricing headers */
[data-theme="dark"] .card-header.bg-primary h1,
[data-theme="dark"] .card-header.bg-primary h2,
[data-theme="dark"] .card-header.bg-primary h3,
[data-theme="dark"] .card-header.bg-primary h4,
[data-theme="dark"] .card-header.bg-primary h5,
[data-theme="dark"] .card-header.bg-primary h6,
[data-theme="dark"] .card-header.bg-primary .pricing-amount,
[data-theme="dark"] .card-header.bg-primary span {
    color: white !important;
}

[data-theme="dark"] .card-header.bg-dark h1,
[data-theme="dark"] .card-header.bg-dark h2,
[data-theme="dark"] .card-header.bg-dark h3,
[data-theme="dark"] .card-header.bg-dark h4,
[data-theme="dark"] .card-header.bg-dark h5,
[data-theme="dark"] .card-header.bg-dark h6,
[data-theme="dark"] .card-header.bg-dark .pricing-amount,
[data-theme="dark"] .card-header.bg-dark .text-white,
[data-theme="dark"] .card-header.bg-dark .text-white-50,
[data-theme="dark"] .card-header.bg-dark span {
    color: white !important;
}

[data-theme="dark"] .card-header.bg-light h1,
[data-theme="dark"] .card-header.bg-light h2,
[data-theme="dark"] .card-header.bg-light h3,
[data-theme="dark"] .card-header.bg-light h4,
[data-theme="dark"] .card-header.bg-light h5,
[data-theme="dark"] .card-header.bg-light h6,
[data-theme="dark"] .card-header.bg-light .pricing-amount,
[data-theme="dark"] .card-header.bg-light span {
    color: #1f2937 !important;
}

[data-theme="dark"] .card-header.bg-white h1,
[data-theme="dark"] .card-header.bg-white h2,
[data-theme="dark"] .card-header.bg-white h3,
[data-theme="dark"] .card-header.bg-white h4,
[data-theme="dark"] .card-header.bg-white h5,
[data-theme="dark"] .card-header.bg-white h6,
[data-theme="dark"] .card-header.bg-white .pricing-amount,
[data-theme="dark"] .card-header.bg-white span {
    color: #1f2937 !important;
}

/* Keep white header white in dark mode */
[data-theme="dark"] .card-header.bg-white {
    background-color: white !important;
    border-bottom: none;
}

/* Keep all bg-white elements white in dark mode (including pricing cards) */
[data-theme="dark"] .bg-white {
    background-color: white !important;
}

/* Ensure bg-light stays light in dark mode */
[data-theme="dark"] .bg-light {
    background-color: #f3f4f6 !important;
}

[data-theme="dark"] .navbar-top {
    background-color: var(--gray-800);
    border-bottom: 1px solid var(--gray-600);
}

[data-theme="dark"] .footer {
    background-color: var(--gray-800);
    border-top: 1px solid var(--gray-600);
}

[data-theme="dark"] .dropdown-menu {
    background-color: var(--gray-700);
    border-color: var(--gray-600);
}

[data-theme="dark"] .dropdown-item {
    color: var(--gray-300);
    text-decoration: none;
}

[data-theme="dark"] .dropdown-item:hover {
    background-color: var(--gray-600);
    color: var(--primary-light);
    text-decoration: none;
}

/* Dark mode mega menu */
[data-theme="dark"] .mega-menu-col:not(:last-child) {
    border-right-color: var(--gray-600);
}
[data-theme="dark"] .mega-menu-col-header {
    color: var(--gray-400);
}
[data-theme="dark"] .mega-menu-footer {
    background: var(--gray-800);
}
[data-theme="dark"] .mega-menu .dropdown-divider {
    border-color: var(--gray-600);
}

/* General dark mode form styles - but NOT inside cards (forms stay light) */
[data-theme="dark"] body:not(:has(.card)) .form-control,
[data-theme="dark"] .modal-content .form-control,
[data-theme="dark"] .dropdown-menu .form-control {
    background-color: var(--gray-700);
    border-color: var(--gray-600);
    color: var(--gray-200);
}

[data-theme="dark"] body:not(:has(.card)) .form-select,
[data-theme="dark"] .modal-content .form-select,
[data-theme="dark"] .dropdown-menu .form-select {
    background-color: var(--gray-700);
    border-color: var(--gray-600);
    color: var(--gray-200);
}

[data-theme="dark"] body:not(:has(.card)) .form-control:focus,
[data-theme="dark"] .modal-content .form-control:focus {
    background-color: var(--gray-700);
    border-color: var(--primary-color);
    color: var(--gray-200);
}

[data-theme="dark"] body:not(:has(.card)) .form-select:focus,
[data-theme="dark"] .modal-content .form-select:focus {
    background-color: var(--gray-700);
    border-color: var(--primary-color);
    color: var(--gray-200);
}

[data-theme="dark"] .breadcrumb-item a {
    color: var(--primary-light);
}

[data-theme="dark"] .breadcrumb-item a:hover {
    color: var(--secondary-light);
}

/* Text-muted in dark mode - but keep readable in forms */
[data-theme="dark"] body:not(:has(.card)) .text-muted,
[data-theme="dark"] .modal-content .text-muted,
[data-theme="dark"] .navbar-top .text-muted,
[data-theme="dark"] .footer .text-muted {
    color: var(--gray-400) !important;
}

[data-theme="dark"] .modal-content {
    background-color: var(--gray-800);
    color: var(--gray-200);
}

[data-theme="dark"] .modal-header {
    border-bottom-color: var(--gray-600);
}

[data-theme="dark"] .modal-footer {
    border-top-color: var(--gray-600);
}

[data-theme="dark"] .table {
    color: var(--gray-200);
}

[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .list-group-item {
    background-color: var(--gray-700);
    border-color: var(--gray-600);
    color: var(--gray-200);
}

/* Alert dark mode override is below in form section - keep forms light */

/* Dark Mode Text Colors - Applied to dark backgrounds only */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
    color: var(--gray-800);
}

/* Light text for headings on dark backgrounds - but NOT in form cards */
[data-theme="dark"] .card:not(:has(form)) h1,
[data-theme="dark"] .card:not(:has(form)) h2,
[data-theme="dark"] .card:not(:has(form)) h3,
[data-theme="dark"] .card:not(:has(form)) h4,
[data-theme="dark"] .card:not(:has(form)) h5,
[data-theme="dark"] .card:not(:has(form)) h6,
[data-theme="dark"] .modal-content h1,
[data-theme="dark"] .modal-content h2,
[data-theme="dark"] .modal-content h3,
[data-theme="dark"] .modal-content h4,
[data-theme="dark"] .modal-content h5,
[data-theme="dark"] .modal-content h6,
[data-theme="dark"] .navbar-top h1,
[data-theme="dark"] .navbar-top h2,
[data-theme="dark"] .navbar-top h3,
[data-theme="dark"] .navbar-top h4,
[data-theme="dark"] .navbar-top h5,
[data-theme="dark"] .navbar-top h6 {
    color: var(--gray-800);
}

/* Form labels - will be overridden for cards below */

/* Keep labels dark on white backgrounds */
[data-theme="dark"] .bg-white .form-label,
[data-theme="dark"] .bg-light .form-label {
    color: var(--gray-700);
}

[data-theme="dark"] .navbar-brand-logo {
    filter: brightness(1.3);
}

[data-theme="dark"] .nav-link {
    color: var(--gray-400);
}

[data-theme="dark"] .nav-link:hover {
    color: var(--primary-light);
}

[data-theme="dark"] .btn-outline-primary {
    border-color: var(--primary-light);
    color: var(--primary-light);
}

[data-theme="dark"] .btn-outline-primary:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: white;
}

[data-theme="dark"] .text-gradient {
    background: linear-gradient(135deg, var(--primary-light) 0%, var(--secondary-light) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
    color: var(--gray-500);
}

/* Keep white backgrounds white in dark mode where needed */
[data-theme="dark"] .bg-white {
    background-color: white !important;
}

[data-theme="dark"] .bg-light {
    background-color: var(--gray-100) !important;
}

/* Preserve border colors */
[data-theme="dark"] .border-primary {
    border-color: #275378 !important;
}

/* Preserve badge colors */
[data-theme="dark"] .badge.bg-primary {
    background-color: #275378 !important;
    color: white !important;
}

[data-theme="dark"] .badge.bg-success {
    background-color: #10b981 !important;
    color: white !important;
}

/* Popular badge on pricing cards */
.card .position-absolute.top-0 {
    z-index: 10;
}

.card .position-absolute.top-0 .badge {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    font-weight: 700;
    letter-spacing: 0.5px;
}

/* Keep text dark on white backgrounds */
[data-theme="dark"] .bg-white h1,
[data-theme="dark"] .bg-white h2,
[data-theme="dark"] .bg-white h3,
[data-theme="dark"] .bg-white h4,
[data-theme="dark"] .bg-white h5,
[data-theme="dark"] .bg-white h6,
[data-theme="dark"] .bg-white p,
[data-theme="dark"] .bg-white span,
[data-theme="dark"] .bg-white div {
    color: var(--gray-900);
}

[data-theme="dark"] .bg-white .text-muted {
    color: var(--gray-600) !important;
}

/* Theme Toggle Button */
.theme-toggle {
    position: relative;
    width: 50px;
    height: 26px;
    background-color: var(--gray-300);
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-base);
    padding: 0;
    overflow: hidden;
}

[data-theme="dark"] .theme-toggle {
    background-color: var(--primary-color);
}

.theme-toggle-slider {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 22px;
    height: 22px;
    background-color: white;
    border-radius: 50%;
    transition: transform var(--transition-base);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
}

[data-theme="dark"] .theme-toggle-slider {
    transform: translateX(24px);
}

.theme-toggle:hover {
    background-color: var(--gray-400);
}

[data-theme="dark"] .theme-toggle:hover {
    background-color: var(--primary-dark);
}

/* ============================================
   BREADCRUMB NAVIGATION
   ============================================ */

.breadcrumb {
    background-color: transparent;
    padding: 0.75rem 0;
    margin-bottom: 0;
    font-size: 0.9rem;
}

.breadcrumb-item {
    color: var(--gray-600);
}

.breadcrumb-item a {
    color: var(--primary-color);
    text-decoration: none;
    transition: all 0.2s ease;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.breadcrumb-item a:hover {
    color: var(--secondary-color);
    text-decoration: none;
    transform: translateX(2px);
}

.breadcrumb-item.active {
    color: var(--gray-700);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.breadcrumb-item + .breadcrumb-item::before {
    content: "/";
    color: var(--gray-400);
    font-size: 1rem;
    padding-right: 0.5rem;
}

/* Breadcrumb icons */
.breadcrumb-item i {
    font-size: 0.9rem;
    vertical-align: middle;
}

/* Dark mode breadcrumb */
[data-theme="dark"] .breadcrumb-item {
    color: var(--gray-500);
}

[data-theme="dark"] .breadcrumb-item.active {
    color: var(--gray-400);
}

[data-theme="dark"] .breadcrumb-item + .breadcrumb-item::before {
    color: var(--gray-500);
}

/* ============================================
   GLOBAL LAYOUT & TYPOGRAPHY
   ============================================ */

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: var(--gray-50);
    color: var(--gray-800);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

main {
    flex: 1;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    line-height: 1.2;
    color: var(--gray-900);
    margin-bottom: 1rem;
}

/* Ensure modal header text stays white when parent has text-white */
.modal-header.text-white h1,
.modal-header.text-white h2,
.modal-header.text-white h3,
.modal-header.text-white h4,
.modal-header.text-white h5,
.modal-header.text-white h6,
.modal-header.text-white .modal-title {
    color: #fff !important;
}

.display-6 {
    font-weight: 800;
}

a {
    color: var(--primary-color);
    text-decoration: none;
    transition: color var(--transition-base);
}

a:hover {
    color: var(--primary-dark);
    text-decoration: none;
}

a:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

.btn:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Focus visible for better keyboard navigation */
*:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
    border-radius: 4px;
}

button:focus-visible,
.btn:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 3px;
}

/* Remove default focus outline but keep focus-visible */
*:focus:not(:focus-visible) {
    outline: none;
}

/* ============================================
   GLOBAL BUTTON TEXT & ICON COLOR ENFORCEMENT
   ============================================ */

/* Ensure all colored buttons have white text and icons */
.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-success,
.btn-success:hover,
.btn-success:focus,
.btn-success:active,
.btn-info,
.btn-info:hover,
.btn-info:focus,
.btn-info:active,
.btn-danger,
.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active {
    color: white !important;
}

/* Ensure all icons inside colored buttons are white */
.btn-primary i,
.btn-primary .bi,
.btn-success i,
.btn-success .bi,
.btn-info i,
.btn-info .bi,
.btn-danger i,
.btn-danger .bi,
.btn-warning i,
.btn-warning .bi {
    color: white !important;
}

/* Warning button text should be white (or dark depending on your warning color) */
.btn-warning,
.btn-warning:hover,
.btn-warning:focus,
.btn-warning:active {
    color: #000 !important; /* Dark text for yellow background for contrast */
}

/* If your warning button has a darker background, use white */
.btn-warning.text-white,
.btn-warning.text-white i,
.btn-warning.text-white .bi {
    color: white !important;
}

/* ============================================
   ENHANCED BUTTON SYSTEM
   ============================================ */

.btn {
    font-weight: 600;
    border-radius: var(--radius-md);
    padding: 0.625rem 1.25rem;
    transition: all var(--transition-base);
    position: relative;
    overflow: hidden;
}

.btn-primary {
    background: var(--gradient-primary);
    border: none;
    color: white !important;
    box-shadow: var(--shadow-sm);
}

.btn-primary i {
    color: white !important;
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--secondary-color) 0%, var(--primary-color) 100%);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md), var(--shadow-glow);
    color: white !important;
}

.btn-primary:active {
    transform: translateY(0);
}

.btn-success {
    background: var(--gradient-success);
    border: none;
    color: white !important;
}

.btn-success i {
    color: white !important;
}

.btn-success:hover {
    color: white !important;
}

.btn-info {
    background: var(--gradient-info);
    border: none;
    color: white !important;
}

.btn-info i {
    color: white !important;
}

.btn-info:hover {
    color: white !important;
}

.btn-teal {
    background: linear-gradient(135deg, #0dcaf0 0%, #17a2b8 100%);
    border: none;
    color: white !important;
}

.btn-teal i {
    color: white !important;
}

.btn-teal:hover {
    background: linear-gradient(135deg, #17a2b8 0%, #138496 100%);
    color: white !important;
}

.btn-warning {
    color: #000 !important;
}

.btn-warning i {
    color: #000 !important;
}

.btn-warning:hover {
    color: #000 !important;
}

.btn-danger {
    color: white !important;
}

.btn-danger i {
    color: white !important;
}

.btn-danger:hover {
    color: white !important;
}

.btn-outline-primary {
    border: 2px solid var(--primary-color);
    color: var(--primary-color);
    background: transparent;
}

.btn-outline-primary:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: white !important;
    transform: translateY(-2px);
}

.btn-outline-primary:hover i {
    color: white !important;
}

.btn-outline-danger {
    border: 2px solid #dc3545;
    color: #dc3545;
    background: transparent;
}

.btn-outline-danger:hover {
    background-color: #dc3545;
    border-color: #dc3545;
    color: white !important;
    transform: translateY(-2px);
}

.btn-outline-danger:hover i {
    color: white !important;
}

.btn-outline-dark {
    border: 2px solid #212529;
    color: #212529;
    background: transparent;
}

.btn-outline-dark:hover {
    background-color: #212529;
    border-color: #212529;
    color: white !important;
    transform: translateY(-2px);
}

.btn-outline-dark:hover i {
    color: white !important;
}

.btn-outline-warning {
    border: 2px solid #f59e0b;
    color: #f59e0b;
    background: transparent;
}

.btn-outline-warning:hover {
    background-color: #f59e0b;
    border-color: #f59e0b;
    color: white !important;
    transform: translateY(-2px);
}

.btn-outline-warning:hover i {
    color: white !important;
}

.btn-outline-blue {
    border: 2px solid #3b82f6;
    color: #3b82f6;
    background: transparent;
}

.btn-outline-blue:hover {
    background-color: #3b82f6;
    border-color: #3b82f6;
    color: white !important;
    transform: translateY(-2px);
}

.btn-outline-blue:hover i {
    color: white !important;
}

/* Solid Blue Button */
.btn-blue {
    background-color: #3b82f6;
    color: #fff;
    border-color: #3b82f6;
}

.btn-blue:hover,
.btn-blue:focus,
.btn-blue:active {
    background-color: #2563eb;
    border-color: #2563eb;
    color: #fff;
}

/* Solid Purple Button */
.btn-purple {
    background-color: #6f42c1;
    color: #fff;
    border-color: #6f42c1;
}

.btn-purple:hover,
.btn-purple:focus,
.btn-purple:active {
    background-color: #5a32a3;
    border-color: #5a32a3;
    color: #fff;
}

/* Loading State Button */
.btn-loading {
    position: relative;
    pointer-events: none;
    opacity: 0.65;
}

.btn-loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid transparent;
    border-radius: 50%;
    border-top-color: currentColor;
    animation: spin 0.6s linear infinite;
}

/* ============================================
   CARD SYSTEM
   (See ENHANCED CARD SYSTEM below for .card base)
   ============================================ */

.hover-card {
    cursor: pointer;
    transition: all var(--transition-slow);
}

.hover-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-xl);
}

/* ============================================
   ICON SYSTEM
   ============================================ */

.icon-gradient {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.icon-box {
    width: 70px;
    height: 70px;
    border-radius: var(--radius-lg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
}

.icon-box-primary {
    background: linear-gradient(135deg, rgba(0, 97, 190, 0.1) 0%, rgba(10, 164, 235, 0.1) 100%);
    color: var(--primary-color);
}

.icon-box-success {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(5, 150, 105, 0.1) 100%);
    color: var(--success-color);
}

.icon-box-info {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(37, 99, 235, 0.1) 100%);
    color: var(--info-color);
}

.icon-hover-grow {
    transition: transform var(--transition-base);
}

.icon-hover-grow:hover,
.icon-box:hover .icon-hover-grow {
    transform: scale(1.2);
}

.icon-hover-bounce {
    display: inline-block;
    transition: transform var(--transition-base);
}

.icon-hover-bounce:hover,
.nav-link:hover .icon-hover-bounce {
    animation: bounce 0.5s ease;
}

.icon-glow {
    color: var(--warning-color);
    filter: drop-shadow(0 0 8px rgba(245, 158, 11, 0.5));
}

.icon-success {
    color: var(--success-color);
}

.icon-info {
    color: var(--info-color);
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes spin {
    to { transform: rotate(360deg); }
}

@keyframes bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-5px); }
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in {
    animation: fadeIn 0.6s ease-out;
}

/* ============================================
   FORM ENHANCEMENTS
   ============================================ */

.form-control,
.form-select {
    border-radius: var(--radius-md);
    border: 2px solid var(--gray-300);
    padding: 0.75rem 1rem;
    transition: all var(--transition-base);
    background-color: white;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(0, 97, 190, 0.1);
    background-color: white;
}

.form-control:disabled,
.form-select:disabled {
    background-color: var(--gray-100);
    cursor: not-allowed;
    opacity: 0.6;
}

.form-label {
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 0.5rem;
    display: inline-block;
}

.form-text {
    font-size: 0.875rem;
    color: var(--gray-600);
    margin-top: 0.25rem;
}

.input-group-text {
    background-color: var(--gray-100);
    border: 2px solid var(--gray-300);
    border-right: none;
    color: var(--gray-600);
    font-weight: 500;
}

.input-group .form-control {
    border-left: none;
}

.input-group:focus-within .input-group-text {
    border-color: var(--primary-color);
    background-color: rgba(0, 97, 190, 0.05);
    color: var(--primary-color);
}

.input-group:focus-within .form-control {
    border-color: var(--primary-color);
}

/* Invalid feedback styling */
.invalid-feedback {
    font-size: 0.875rem;
    color: var(--danger-color);
    margin-top: 0.25rem;
}

.form-control.is-invalid,
.form-select.is-invalid {
    border-color: var(--danger-color);
}

.form-control.is-valid,
.form-select.is-valid {
    border-color: var(--success-color);
}

/* ============================================
   AVATAR SYSTEM
   ============================================ */

.user-avatar-lg {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--primary-color);
}

.user-avatar-lg-fallback {
    width: 120px;
    height: 120px;
    background: var(--gradient-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: white;
    font-weight: 700;
}

.verified-badge-pos {
    position: absolute;
    bottom: 0;
    right: 0;
    transform: translate(30%, 30%);
}

.verified-badge-circle {
    width: 38px;
    height: 38px;
    font-size: 1.2rem;
}

/* ============================================
   TIP DISMISS BUTTON
   ============================================ */

.tip-dismiss-btn {
    top: 8px;
    right: 8px;
    z-index: 10;
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
}

.tip-dismiss-btn .bi {
    color: #000;
    opacity: 0.6;
}

.tip-dismiss-btn:hover .bi {
    opacity: 1;
}

/* ============================================
   WORKFLOW STEP LINK (clickable badge)
   ============================================ */

.workflow-step-link {
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.workflow-step-link:hover {
    transform: scale(1.2);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

/* ============================================
   RECORDING CIRCLE
   ============================================ */

.record-circle {
    width: 120px;
    height: 120px;
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
}

/* ============================================
   EMPTY STATE
   ============================================ */

.empty-state-icon {
    font-size: 4rem;
    opacity: 0.3;
}

.empty-state-icon-md {
    font-size: 3rem;
}

/* ============================================
   CTA GRADIENT CARD
   ============================================ */

.cta-gradient {
    background: linear-gradient(135deg, #275378 0%, #326B98 100%);
}

/* ============================================
BADGES (See BADGE ENHANCEMENTS below for base)
============================================ */

/* ============================================
ALERTS (See ALERT ENHANCEMENTS below for base)
============================================ */

/* ============================================
   TABLES
   ============================================ */

.table {
    border-collapse: separate;
    border-spacing: 0;
}

.table thead th {
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.5px;
    color: var(--gray-600);
    border-bottom: 2px solid var(--gray-300);
    padding: 1rem;
}

.table tbody td {
    padding: 1rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--gray-200);
}

.table-row-hover {
    transition: background-color var(--transition-fast);
}

.table-row-hover:hover {
    background-color: var(--gray-50);
    cursor: pointer;
}

/* Prevent scrollbars on data tables inside cards */
.card .table-responsive {
    overflow: visible !important;
}

.card .table-responsive table {
    display: table !important;
    overflow-x: visible !important;
    white-space: normal !important;
}

/* Disable hover lift on cards that contain data tables */
.card:has(.table-responsive):hover {
    transform: none;
}

/* ============================================
   GRID ACTION BUTTONS
   Borderless, uniform-size icon buttons for
   table row action columns across all pages.
   ============================================ */

.grid-action-btn {
    border: none !important;
    background: transparent;
    width: 32px;
    height: 32px;
    min-height: 32px !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 !important;
    border-radius: 6px;
    font-size: 1rem;
    transition: background-color 0.2s ease;
}

.grid-action-btn:hover {
    background-color: rgba(0, 0, 0, 0.08);
}

.grid-action-btn:focus {
    box-shadow: none;
}

/* ============================================
   STATUS INDICATORS
   ============================================ */

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 0.5rem;
}

.status-active {
    background-color: var(--success-color);
    box-shadow: 0 0 8px rgba(16, 185, 129, 0.5);
}

.status-inactive {
    background-color: var(--gray-400);
}

.status-warning {
    background-color: var(--warning-color);
    box-shadow: 0 0 8px rgba(245, 158, 11, 0.5);
}

/* GPS Indicator */
.gps-indicator {
    display: inline-flex;
    align-items: center;
}

.gps-pulse {
    width: 8px;
    height: 8px;
    background-color: var(--success-color);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.hover-link {
    transition: color var(--transition-fast);
}

.hover-link:hover {
    color: var(--primary-color) !important;
}

.shadow-glow-primary {
    box-shadow: 0 0 20px rgba(0, 97, 190, 0.4);
}

.text-gradient {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hover-card {
    transition: all var(--transition-base);
    cursor: pointer;
}

.hover-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-xl) !important;
}

.hover-lift {
    transition: all var(--transition-base);
}

.hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg) !important;
}

.hover-scale {
    transition: transform var(--transition-base);
}

.hover-scale:hover {
    transform: scale(1.05);
}

/* ============================================
   RESPONSIVE HELPERS
   ============================================ */

@media (max-width: 768px) {
    .hero-section {
        min-height: 500px;
        padding: 2rem 0;
    }
    
    .display-1 {
        font-size: 3.5rem;
    }
    
    .display-2 {
        font-size: 3rem;
    }
    
    .display-3 {
        font-size: 2.5rem;
    }
    
    .display-5 {
        font-size: 2rem;
    }
    
    .display-6 {
        font-size: 1.75rem;
    }
    
    .btn-lg {
        padding: 0.75rem 1.5rem;
        font-size: 1rem;
    }
    
    .card-body {
        padding: 1rem;
    }
    
    .navbar-brand {
        font-size: 1.25rem;
    }
    
    /* Stack buttons on mobile */
    .btn-group {
        flex-direction: column;
    }
    
    /* Improve table responsiveness */
    .table-responsive {
        margin-bottom: 1rem;
    }
    
    /* Better spacing on mobile */
    .py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
}

@media (max-width: 576px) {
.display-1 {
    font-size: 2.5rem;
}
    
.display-2 {
    font-size: 2.25rem;
}
    
.display-3 {
    font-size: 2rem;
}
    
.display-4 {
    font-size: 1.75rem;
}
    
.display-5 {
    font-size: 1.5rem;
}
    
.display-6 {
    font-size: 1.25rem;
}
    
    /* Better padding for small screens */
    .container-fluid {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* Tablet specific improvements */
@media (min-width: 768px) and (max-width: 1024px) {
    .card-body {
        padding: 1.25rem;
    }
}

/* ============================================
ENHANCED CARD SYSTEM
   ============================================ */

.card {
    border-radius: var(--radius-xl);
    border: none;
    overflow: hidden;
    transition: all var(--transition-base);
    background: white;
    box-shadow: var(--shadow-sm);
}

/* Allow badges to show above pricing cards */
#pricingCards .card.position-relative {
    overflow: visible;
    margin-top: 1rem;
}

/* Only lift cards that opt-in with .hover-lift or .hover-card */
.card.hover-lift:hover,
.card.hover-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.shadow-sm {
    box-shadow: var(--shadow-sm) !important;
}

.shadow {
    box-shadow: var(--shadow-md) !important;
}

.shadow-lg {
    box-shadow: var(--shadow-lg) !important;
}

.card-header {
    background: white;
    border-bottom: 1px solid var(--gray-200);
    padding: 1.25rem 1.5rem;
    font-weight: 600;
}

.card-body {
    padding: 1.5rem;
}

.card-footer {
    background: var(--gray-50);
    border-top: 1px solid var(--gray-200);
    padding: 1rem 1.5rem;
}

/* Action Cards */
.action-card {
    cursor: pointer;
    transition: all var(--transition-base);
    border: 2px solid transparent;
}

.action-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--primary-color);
}

.action-icon {
    width: 80px;
    height: 80px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Stat Cards */
.stat-card {
    transition: all var(--transition-base);
    border-left: 4px solid transparent;
}

.stat-card:hover {
    transform: translateX(4px);
    border-left-color: var(--primary-color);
    box-shadow: var(--shadow-md);
}

.stat-icon {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Card decorative gradient bars */
.card .position-absolute.top-0.start-0.w-100[style*="height:6px"],
.card .position-absolute.top-0.start-0.w-100[style*="height:8px"] {
    z-index: 1;
}

/* Ensure card content is above gradient bars */
.card-header,
.card-body {
    position: relative;
    z-index: 2;
}

/* ============================================
   FORM CONTROLS ENHANCEMENT
   ============================================ */

.form-control,
.form-select {
    border-radius: var(--radius-md);
    border: 2px solid var(--gray-200);
    padding: 0.625rem 1rem;
    transition: all var(--transition-base);
    font-size: 0.9375rem;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(0, 97, 190, 0.1);
}

.form-label {
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: var(--space-sm);
}

/* Custom Switch Enhancement */
.form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

/* ============================================
   TABLE ENHANCEMENTS
   ============================================ */

.table {
    border-collapse: separate;
    border-spacing: 0;
}

.table thead th {
    background-color: var(--gray-50);
    color: var(--gray-700);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    padding: 1rem;
    border: none;
}

.table tbody tr {
    transition: all var(--transition-fast);
}

.table-hover tbody tr:hover {
    background-color: var(--gray-50);
    transform: scale(1.01);
    box-shadow: var(--shadow-sm);
}

.table tbody td {
    padding: 1rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--gray-200);
}

/* ============================================
   BADGE ENHANCEMENTS
   ============================================ */

.badge {
    padding: 0.375rem 0.75rem;
    border-radius: var(--radius-full);
    font-weight: 600;
    font-size: 0.75rem;
    letter-spacing: 0.025em;
}

.badge-primary {
    background: var(--gradient-primary);
}

.badge-success {
    background: var(--gradient-success);
}

.badge-warning {
    background: var(--gradient-warning);
}

.badge-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* ============================================
   ALERT ENHANCEMENTS
   ============================================ */

.alert {
    border-radius: var(--radius-lg);
    border: none;
    padding: 1rem 1.25rem;
    font-weight: 500;
    box-shadow: var(--shadow-sm);
    border-left: 4px solid transparent;
}

.alert-success {
    background-color: #d1fae5;
    color: #065f46;
    border-left-color: var(--success-color);
}

.alert-success i {
    color: var(--success-color);
}

.alert-danger {
    background-color: #fee2e2;
    color: #991b1b;
    border-left-color: var(--danger-color);
}

.alert-danger i {
    color: var(--danger-color);
}

.alert-info {
    background-color: #dbeafe;
    color: #1e40af;
    border-left-color: var(--info-color);
}

.alert-info i.bi-lightbulb-fill {
    color: var(--warning-color);
}

.alert-warning {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--warning-dark);
    border-left-color: var(--warning-color);
}

.alert-warning i {
    color: var(--warning-color);
}

.alert-dismissible .btn-close {
    padding: 1rem;
    opacity: 0.5;
    transition: opacity var(--transition-base);
}

.alert-dismissible .btn-close:hover {
    opacity: 1;
}

/* ============================================
   ANIMATIONS & TRANSITIONS
   ============================================ */

@keyframes spinner {
    to { transform: rotate(360deg); }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.5;
    }
}

@keyframes slideInUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes bounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

.animate-slideInUp {
    animation: slideInUp var(--transition-slow) ease-out;
}

.animate-fadeIn {
    animation: fadeIn var(--transition-slow) ease-out;
}

.animate-bounce {
    animation: bounce 1s ease-in-out infinite;
}

/* Smooth scrolling for the entire page */
html {
    scroll-behavior: smooth;
}

/* Reduce motion for users who prefer it */
@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;
    }
}

/* ============================================
   SKELETON LOADERS
   ============================================ */

.skeleton {
    background: linear-gradient(
        90deg,
        var(--gray-200) 25%,
        var(--gray-100) 50%,
        var(--gray-200) 75%
    );
    background-size: 200% 100%;
    animation: loading 1.5s ease-in-out infinite;
    border-radius: var(--radius-md);
}

@keyframes loading {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

.skeleton-text {
    height: 1rem;
    margin-bottom: var(--space-sm);
}

.skeleton-title {
    height: 1.5rem;
    width: 60%;
    margin-bottom: var(--space-md);
}

/* ============================================
   NAVBAR ENHANCEMENTS
   ============================================ */

.navbar-brand {
    transition: all var(--transition-base);
    text-decoration: none;
}

.navbar-brand-logo {
    height: 75px;
    width: auto;
    transition: transform var(--transition-base);
}

.navbar-brand:hover .navbar-brand-logo {
    transform: scale(1.03);
}

.navbar-brand:hover {
    transform: scale(1.03);
    text-decoration: none;
}

.nav-link {
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--gray-700);
    letter-spacing: 0.01em;
    transition: color var(--transition-base), background-color var(--transition-base);
    position: relative;
    padding: 0.5rem 0.875rem;
    border-radius: var(--radius-md);
    text-decoration: none;
}

.nav-link:hover {
    color: var(--primary-color);
    background-color: rgba(0, 97, 190, 0.06);
    text-decoration: none;
}

.nav-link:active {
    background-color: rgba(0, 97, 190, 0.1);
}

.navbar-top .nav-link::after {
    content: '';
    position: absolute;
    width: 4px;
    height: 4px;
    bottom: 2px;
    left: 50%;
    background: var(--primary-color);
    border-radius: 50%;
    transition: all var(--transition-base);
    transform: translateX(-50%) scale(0);
    opacity: 0;
}

.navbar-top .nav-link:hover::after {
    transform: translateX(-50%) scale(1);
    opacity: 1;
}

.navbar-top {
    background: white;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
    border-bottom: 1px solid #e9ecef;
    transition: all var(--transition-base);
}

[data-theme="dark"] .nav-link {
    color: var(--gray-400);
}

[data-theme="dark"] .nav-link:hover {
    color: var(--primary-light);
    background-color: rgba(0, 97, 190, 0.1);
}

/* ============================================
   FOOTER ENHANCEMENTS
   ============================================ */

.footer {
    margin-top: auto;
    background: var(--gray-900);
    padding: 3rem 0 1rem;
    color: white;
}

.footer a {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    transition: color var(--transition-base);
}

.footer a:hover,
.footer .hover-link:hover {
    color: var(--primary-light);
    text-decoration: none;
}

.footer h5,
.footer h6 {
    color: white;
}

.footer .text-white-50 {
    color: rgba(255, 255, 255, 0.6) !important;
}

[data-theme="dark"] .footer {
    background: var(--gray-900);
    border-top: 1px solid var(--gray-700);
}

/* Newsletter Form in Footer */
.footer .form-control {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: white;
}

.footer .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.footer .form-control:focus {
    background: rgba(255, 255, 255, 0.15);
    border-color: var(--primary-color);
    color: white;
    box-shadow: 0 0 0 3px rgba(0, 97, 190, 0.25);
}

.footer .alert {
    font-size: 0.85rem;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.text-gradient {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.bg-gradient-primary {
    background: var(--gradient-primary);
}

.hover-lift {
    transition: transform var(--transition-base);
}

.hover-lift:hover {
    transform: translateY(-4px);
}

.hover-scale {
    transition: transform var(--transition-base);
}

.hover-scale:hover {
    transform: scale(1.05);
}

/* ============================================
   COLORFUL ICON SYSTEM
   ============================================ */

/* Primary Icons with Gradient */
.icon-gradient {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Colorful Icon Classes */
.icon-primary {
    color: var(--primary-color);
    filter: drop-shadow(0 2px 4px rgba(0, 97, 190, 0.3));
}

.icon-secondary {
    color: var(--secondary-color);
    filter: drop-shadow(0 2px 4px rgba(10, 164, 235, 0.3));
}

.icon-success {
    color: var(--success-color);
    filter: drop-shadow(0 2px 4px rgba(16, 185, 129, 0.3));
}

.icon-info {
    color: var(--info-color);
    filter: drop-shadow(0 2px 4px rgba(59, 130, 246, 0.3));
}

.icon-warning {
    color: var(--warning-color);
    filter: drop-shadow(0 2px 4px rgba(245, 158, 11, 0.3));
}

.icon-danger {
    color: var(--danger-color);
    filter: drop-shadow(0 2px 4px rgba(239, 68, 68, 0.3));
}

/* Icon Backgrounds with Color */
.icon-box {
    width: 60px;
    height: 60px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
    transition: all var(--transition-base);
}

.icon-circle {
    width: 60px;
    height: 60px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all var(--transition-base);
}

.feature-icon {
    transition: all var(--transition-base);
}

.feature-icon:hover {
    transform: scale(1.1);
}

/* Step Numbers for How It Works sections */
.step-number {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--gradient-primary);
    color: white;
    font-weight: 700;
    font-size: 1.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    margin: 0 auto;
}

.icon-box-primary {
    background: linear-gradient(135deg, rgba(0, 97, 190, 0.1) 0%, rgba(10, 164, 235, 0.1) 100%);
    color: var(--primary-color);
}

.icon-box-success {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(5, 150, 105, 0.1) 100%);
    color: var(--success-color);
}

.icon-box-info {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(37, 99, 235, 0.1) 100%);
    color: var(--info-color);
}

.icon-box-warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.1) 0%, rgba(217, 119, 6, 0.1) 100%);
    color: var(--warning-color);
}

.icon-box-danger {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.1) 0%, rgba(220, 38, 38, 0.1) 100%);
    color: var(--danger-color);
}

.icon-box:hover {
    transform: scale(1.1) rotate(5deg);
    box-shadow: var(--shadow-lg);
}

/* Large Feature Icons */
.icon-feature {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: inline-block;
    transition: all var(--transition-base);
}

.icon-feature:hover {
    transform: scale(1.15);
}

/* Icon with Glow Effect */
.icon-glow {
    animation: icon-glow 2s ease-in-out infinite;
}

@keyframes icon-glow {
    0%, 100% {
        filter: drop-shadow(0 0 5px currentColor);
    }
    50% {
        filter: drop-shadow(0 0 15px currentColor);
    }
}

/* Icon Pulse Animation */
.icon-pulse {
    animation: icon-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes icon-pulse {
    0%, 100% {
        opacity: 1;
        transform: scale(1);
    }
    50% {
        opacity: 0.8;
        transform: scale(1.05);
    }
}

/* Multi-color Icons */
.icon-rainbow {
    background: linear-gradient(45deg, #275378, #326B98, #10b981, #3b82f6, #f59e0b);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    background-size: 200% 200%;
    animation: rainbow-shift 3s ease infinite;
}

@keyframes rainbow-shift {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* Icon Badges */
.icon-badge {
    position: relative;
}

.icon-badge::after {
    content: attr(data-badge);
    position: absolute;
    top: -8px;
    right: -8px;
    background: var(--danger-color);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

/* Specific Icon Colors for Context */
/* These only apply when NO color utility class or inline style is present */
/* This allows .text-white, .text-success, etc. to take precedence */

/* IMPORTANT: Icons inherit color from parent if parent has text color utilities */
.text-white .bi,
.text-white [class^="bi-"],
.text-white [class*=" bi-"],
.text-primary .bi,
.text-primary [class^="bi-"],
.text-primary [class*=" bi-"],
.text-secondary .bi,
.text-secondary [class^="bi-"],
.text-secondary [class*=" bi-"],
.text-success .bi,
.text-success [class^="bi-"],
.text-success [class*=" bi-"],
.text-danger .bi,
.text-danger [class^="bi-"],
.text-danger [class*=" bi-"],
.text-warning .bi,
.text-warning [class^="bi-"],
.text-warning [class*=" bi-"],
.text-info .bi,
.text-info [class^="bi-"],
.text-info [class*=" bi-"],
.text-light .bi,
.text-light [class^="bi-"],
.text-light [class*=" bi-"],
.text-dark .bi,
.text-dark [class^="bi-"],
.text-dark [class*=" bi-"],
.text-muted .bi,
.text-muted [class^="bi-"],
.text-muted [class*=" bi-"] {
    color: inherit !important;
}

/* Icons also inherit from buttons and links */
.btn .bi,
.btn [class^="bi-"],
.btn [class*=" bi-"] {
    color: inherit !important;
}

a .bi,
a [class^="bi-"],
a [class*=" bi-"] {
    color: inherit;
}

/* Default icon colors - ONLY when no other color is specified */
.bi-house-door-fill:not([class*="text-"]):not([style*="color"]) { color: #275378; }
.bi-briefcase-fill:not([class*="text-"]):not([style*="color"]) { color: #AD2227; }
.bi-folder-fill:not([class*="text-"]):not([style*="color"]) { color: #f59e0b; }
.bi-file-earmark-text-fill:not([class*="text-"]):not([style*="color"]) { color: #3b82f6; }
.bi-mic-fill:not([class*="text-"]):not([style*="color"]) { color: #10b981; }
.bi-geo-alt-fill:not([class*="text-"]):not([style*="color"]) { color: #ef4444; }
.bi-camera-fill:not([class*="text-"]):not([style*="color"]) { color: #8b5cf6; }
.bi-bell-fill:not([class*="text-"]):not([style*="color"]) { color: #f59e0b; }
.bi-gear-fill:not([class*="text-"]):not([style*="color"]) { color: #6b7280; }
.bi-person-fill:not([class*="text-"]):not([style*="color"]) { color: #275378; }
.bi-check-circle-fill:not([class*="text-"]):not([style*="color"]) { color: #10b981; }
.bi-x-circle-fill:not([class*="text-"]):not([style*="color"]) { color: #ef4444; }
.bi-exclamation-triangle-fill:not([class*="text-"]):not([style*="color"]) { color: #f59e0b; }
.bi-info-circle-fill:not([class*="text-"]):not([style*="color"]) { color: #3b82f6; }
.bi-star-fill:not([class*="text-"]):not([style*="color"]) { color: #fbbf24; }
.bi-heart-fill:not([class*="text-"]):not([style*="color"]) { color: #ec4899; }
.bi-shield-fill-check:not([class*="text-"]):not([style*="color"]) { color: #10b981; }
.bi-cloud-arrow-up-fill:not([class*="text-"]):not([style*="color"]) { color: #0ea5e9; }
.bi-download:not([class*="text-"]):not([style*="color"]) { color: #8b5cf6; }
.bi-share-fill:not([class*="text-"]):not([style*="color"]) { color: #3b82f6; }
.bi-trash-fill:not([class*="text-"]):not([style*="color"]) { color: #ef4444; }
.bi-pencil-square:not([class*="text-"]):not([style*="color"]) { color: #f59e0b; }
.bi-eye-fill:not([class*="text-"]):not([style*="color"]) { color: #06b6d4; }
.bi-plus-circle-fill:not([class*="text-"]):not([style*="color"]) { color: #10b981; }
.bi-list-check:not([class*="text-"]):not([style*="color"]) { color: #275378; }
.bi-calendar3:not([class*="text-"]):not([style*="color"]) { color: #8b5cf6; }
.bi-clock-history:not([class*="text-"]):not([style*="color"]) { color: #06b6d4; }
.bi-archive-fill:not([class*="text-"]):not([style*="color"]) { color: #6b7280; }
.bi-lightning-charge-fill:not([class*="text-"]):not([style*="color"]) { color: #fbbf24; }
.bi-rocket-takeoff-fill:not([class*="text-"]):not([style*="color"]) { color: #275378; }
.bi-award-fill:not([class*="text-"]):not([style*="color"]) { color: #fbbf24; }
.bi-gift-fill:not([class*="text-"]):not([style*="color"]) { color: #ec4899; }
.bi-tag-fill:not([class*="text-"]):not([style*="color"]) { color: #10b981; }
.bi-phone-fill:not([class*="text-"]):not([style*="color"]) { color: #3b82f6; }
.bi-send-fill:not([class*="text-"]):not([style*="color"]) { color: #275378; }
.bi-envelope-fill:not([class*="text-"]):not([style*="color"]) { color: #f59e0b; }
.bi-envelope-heart:not([class*="text-"]):not([style*="color"]) { color: #ec4899; }
.bi-shield-check:not([class*="text-"]):not([style*="color"]) { color: #10b981; }

/* Icon Hover Effects */
.icon-hover-grow {
    transition: all var(--transition-base);
}

.icon-hover-grow:hover {
    transform: scale(1.2);
}

.icon-hover-spin {
    transition: transform var(--transition-base);
}

.icon-hover-spin:hover {
    transform: rotate(360deg);
}

.icon-hover-bounce:hover {
    animation: icon-bounce 0.5s ease;
}

@keyframes icon-bounce {
    0%, 100% { transform: translateY(0); }
    25% { transform: translateY(-10px); }
    75% { transform: translateY(-5px); }
}

/* GPS Pulse Indicator */
.gps-pulse {
    display: inline-block;
    position: relative;
    width: 12px;
    height: 12px;
    background-color: var(--success-color);
    border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7);
    animation: gps-pulse 2s infinite;
}

@keyframes gps-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(16, 185, 129, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(16, 185, 129, 0);
    }
}

/* Status Indicators */
.status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: var(--space-xs);
}

.status-active {
    background-color: var(--success-color);
}

.status-pending {
    background-color: var(--warning-color);
}

.status-inactive {
    background-color: var(--gray-400);
}

/* Spinner */
.spinner {
    border: 3px solid rgba(0, 97, 190, 0.1);
    border-radius: 50%;
    border-top: 3px solid var(--primary-color);
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@media (max-width: 768px) {
    .hero-section {
        min-height: 400px !important;
    }
}

/* ============================================
   HOMEPAGE HERO SECTION
   ============================================ */

/* ============================================
   HOMEPAGE HERO SECTION - ENHANCED
   ============================================ */

.hero-section {
    background: linear-gradient(135deg, #1B3A54 0%, #326B98 50%, #275378 100%);
    min-height: 500px; /* Reduced from 600px */
    color: white;
    padding: 3rem 0; /* Reduced from 4rem */
    position: relative;
    overflow: hidden;
}

/* Animated gradient background */
.hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, 
        rgba(0, 74, 145, 0.5) 0%, 
        rgba(10, 164, 235, 0.4) 50%,
        rgba(7, 123, 184, 0.5) 100%);
    background-size: 200% 200%;
    animation: gradientShift 15s ease infinite;
    z-index: 0;
}

@keyframes gradientShift {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

.hero-section .container {
    position: relative;
    z-index: 1;
}

.hero-section .text-white-50 {
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Modern Hero Buttons */
.hero-cta-group {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.btn-hero-primary,
.btn-hero-secondary {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.75rem;
    border-radius: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border: none;
    position: relative;
    overflow: hidden;
}

.btn-hero-primary {
    background: white;
    color: #275378;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.btn-hero-primary:hover {
    background: #f8f9fa;
    color: #1B3A54;
    transform: translateY(-4px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.3);
}

.btn-hero-secondary {
    background: rgba(255, 255, 255, 0.15);
    color: white;
    border: 2px solid rgba(255, 255, 255, 0.3);
    backdrop-filter: blur(10px);
}

.btn-hero-secondary:hover {
    background: rgba(255, 255, 255, 0.25);
    color: white;
    border-color: rgba(255, 255, 255, 0.5);
    transform: translateY(-4px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.btn-hero-icon {
    font-size: 1.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.btn-hero-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
}

.btn-hero-title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.2;
    display: block;
}

.btn-hero-subtitle {
    font-size: 0.75rem;
    font-weight: 500;
    opacity: 0.8;
    line-height: 1.2;
    display: block;
    margin-top: 0.15rem;
}

/* Hero Secondary Links */
.hero-secondary-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.hero-link {
    color: white;
    text-decoration: none;
    font-weight: 500;
    font-size: 0.95rem;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 2px solid transparent;
}

.hero-link:hover {
    color: white;
    border-bottom-color: rgba(255, 255, 255, 0.5);
    transform: translateX(4px);
}

.hero-link i {
    transition: transform 0.2s ease;
}

.hero-link:hover i {
    transform: scale(1.15);
}

/* Dark mode adjustments for hero section */
[data-theme="dark"] .hero-section .badge.bg-opacity-25 {
    color: #1f2937 !important;
}

[data-theme="dark"] .hero-section .badge.bg-white:not(.bg-opacity-25) {
    background-color: white !important;
    color: #1f2937 !important;
}

[data-theme="dark"] .hero-section .container,
[data-theme="dark"] .hero-section .row,
[data-theme="dark"] .hero-section .row.align-items-center,
[data-theme="dark"] .hero-section .col-lg-6,
[data-theme="dark"] .hero-image-container {
    background-color: transparent !important;
}

.hero-image-container {
    position: relative;
}

/* Responsive Hero Buttons */
@media (max-width: 767.98px) {
    .hero-cta-group {
        flex-direction: column;
        width: 100%;
    }
    
    .btn-hero-primary,
    .btn-hero-secondary {
        width: 100%;
        justify-content: flex-start;
    }
    
    .hero-secondary-links {
        justify-content: center;
    }
}

.animated-float {
    animation: float 3s ease-in-out infinite;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0px);
    }
    50% {
        transform: translateY(-20px);
    }
}

.step-number {
    display: inline-block;
    width: 40px;
    height: 40px;
    background: var(--gradient-primary);
    color: white;
    border-radius: 50%;
    line-height: 40px;
    font-weight: 700;
    font-size: 1.25rem;
}

.hover-card {
    transition: all var(--transition-base);
}

.hover-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-xl);
}

.icon-circle {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ============================================
   MOBILE-RESPONSIVE DESIGN
   Industry Standard Breakpoints & Best Practices
   ============================================ */

/* Mobile First Approach - Base styles above are for mobile */

/* Touch-Friendly Controls */
@media (max-width: 767.98px) {
    /* Increase touch target sizes for mobile (minimum 44x44px per Apple HIG) */
    .btn:not(.grid-action-btn) {
        min-height: 44px;
        padding: 0.75rem 1.5rem;
        font-size: 1rem;
    }
    
    .form-control,
    .form-select {
        min-height: 44px;
        font-size: 16px; /* Prevents zoom on iOS */
        padding: 0.75rem 1rem;
    }
    
    .nav-link {
        padding: 0.75rem 1rem;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    
    /* Mobile Navigation */
    .navbar-toggler {
        border: none;
        padding: 0.5rem;
        min-height: 44px;
        min-width: 44px;
    }
    
    .navbar-collapse {
        background: white;
        margin-top: 1rem;
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-lg);
        padding: 1rem;
    }
    
    [data-theme="dark"] .navbar-collapse {
        background: var(--gray-800);
    }
    
    .navbar-nav {
        padding: 0.5rem 0;
    }
    
    .navbar-nav .nav-item {
        margin: 0.25rem 0;
    }
    
    /* Hero Section Mobile */
    .hero-section {
        min-height: auto !important;
        padding: 3rem 0 !important;
    }
    
    .hero-section .display-3 {
        font-size: 2rem !important;
        line-height: 1.2;
    }
    
    .hero-section .display-4 {
        font-size: 1.75rem !important;
    }
    
    .hero-section .display-5 {
        font-size: 1.5rem !important;
    }
    
    .hero-section .lead {
        font-size: 1rem !important;
    }
    
    .hero-image-container {
        margin-top: 2rem;
    }
    
    /* Stack buttons vertically on mobile */
    .d-grid.gap-3.d-md-flex {
        display: grid !important;
    }
    
    .d-grid .btn {
        width: 100%;
    }
    
    /* Cards and Containers */
    .card {
        margin-bottom: 1rem;
    }
    
    .card-body {
        padding: 1.25rem;
    }
    
    /* Full-width modals on mobile */
    .modal-dialog {
        margin: 0.5rem;
        max-width: calc(100% - 1rem);
    }
    
    .modal-content {
        border-radius: var(--radius-lg);
    }
    
    /* Tables - Responsive Approach */
    .table-responsive {
        border-radius: var(--radius-lg);
        margin-bottom: 1rem;
    }
    
    /* Make table scrollable horizontally - only inside table-responsive */
    .table-responsive > table {
        display: table;
        width: 100%;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
    }
    
    /* Reduce table padding for mobile */
    .table thead th,
    .table tbody td {
        padding: 0.75rem 0.5rem;
        font-size: 0.875rem;
    }
    
    /* Forms - Full Width on Mobile */
    .col-md-6.col-lg-5,
    .col-md-8,
    .col-lg-6,
    .col-lg-8 {
        max-width: 100% !important;
    }
    
    /* Spacing Adjustments */
    .py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
    
    .my-5 {
        margin-top: 2rem !important;
        margin-bottom: 2rem !important;
    }
    
    .mb-5 {
        margin-bottom: 2rem !important;
    }
    
    .mt-5 {
        margin-top: 2rem !important;
    }
    
    /* Container Padding */
    .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    
    /* Footer Mobile */
    .footer {
        padding: 2rem 0 1rem;
        text-align: center;
    }
    
    .footer .row > div {
        margin-bottom: 1.5rem;
    }
    
    /* Hide desktop-only elements */
    .d-none.d-md-block,
    .d-none.d-lg-block {
        display: none !important;
    }
    
    /* Text Size Adjustments */
    h1, .h1 {
        font-size: 2rem;
    }
    
    h2, .h2 {
        font-size: 1.75rem;
    }
    
    h3, .h3 {
        font-size: 1.5rem;
    }
    
    h4, .h4 {
        font-size: 1.25rem;
    }
    
    /* Icon Sizes */
    .icon-feature {
        font-size: 2rem;
    }
    
    .icon-box,
    .icon-circle {
        width: 60px;
        height: 60px;
    }
    
    .feature-icon {
        width: 60px !important;
        height: 60px !important;
        line-height: 60px !important;
        font-size: 1.5rem !important;
    }
    
    /* Stat Cards Mobile */
    .stat-card {
        margin-bottom: 1rem;
    }
    
    /* Action Cards Mobile */
    .action-card {
        margin-bottom: 1rem;
    }
    
    /* Remove hover effects on touch devices */
    .hover-lift:hover,
    .hover-scale:hover,
    .hover-card:hover {
        transform: none;
    }
    
    /* Breadcrumb Mobile */
    .breadcrumb {
        font-size: 0.875rem;
        flex-wrap: wrap;
    }
    
    /* Alert Mobile */
    .alert {
        font-size: 0.875rem;
        padding: 0.75rem 1rem;
    }
    
    /* Badge Mobile */
    .badge {
        font-size: 0.7rem;
        padding: 0.3rem 0.6rem;
    }
    
    /* Step Numbers */
    .step-number {
        width: 36px;
        height: 36px;
        line-height: 36px;
        font-size: 1.1rem;
    }
    
    /* User Avatar */
    .user-avatar {
        width: 32px;
        height: 32px;
        font-size: 0.875rem;
    }
    
    /* Dropdown Menu Mobile */
    .dropdown-menu {
        min-width: 200px;
        font-size: 0.95rem;
    }
    
    /* Social Proof Section */
    .py-4.bg-white.border-bottom .row > div {
        margin-bottom: 1rem;
    }
    
    .py-4.bg-white.border-bottom .row > div:last-child {
        margin-bottom: 0;
    }

    /* ---- Dashboard Hero Section ---- */
    .dashboard-hero {
        text-align: center;
    }

    .dashboard-hero .d-flex.align-items-center.gap-4 {
        flex-direction: column;
        gap: 1rem !important;
        text-align: center;
    }

    .dashboard-hero .display-6 {
        font-size: 1.5rem !important;
    }

    /* ---- Subscription / Usage Stats Row ---- */
    .d-flex.align-items-center.gap-4.mt-2.small {
        flex-wrap: wrap;
        gap: 0.5rem !important;
    }

    /* ---- Demo / Subscription Info Cards ---- */
    .card-body .d-flex.align-items-start .flex-grow-1 span.text-muted.ms-2 {
        display: block;
        margin-left: 0 !important;
        margin-top: 0.25rem;
    }

    /* ---- Page Header Partial ---- */
    .d-flex.align-items-center.gap-3 > .bi.fs-2 {
        font-size: 1.5rem !important;
    }

    .display-6 {
        font-size: 1.5rem !important;
    }

    .fs-5 {
        font-size: 1rem !important;
    }

    /* ---- Card Headers with Search / Buttons ---- */
    .card-header .d-flex.justify-content-between.align-items-center {
        flex-direction: column;
        gap: 0.75rem;
        align-items: stretch !important;
    }

    .card-header .d-flex.justify-content-between .input-group {
        max-width: 100% !important;
    }

    .card-header .d-flex.justify-content-between h4,
    .card-header .d-flex.justify-content-between h5 {
        text-align: center;
    }

    /* ---- Tip Cards with Inline Buttons ---- */
    .card-body .d-flex.align-items-center > .btn.ms-3 {
        margin-left: 0 !important;
        margin-top: 0.75rem;
        align-self: flex-start;
    }

    .card-body .d-flex.align-items-center:has(> .btn.ms-3) {
        flex-wrap: wrap;
    }

    /* ---- Hero Trust Badges ---- */
    .hero-section .text-white.small {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
        align-items: center;
    }

    .hero-section .text-white.small .mx-2 {
        display: none;
    }

    /* ---- Hero Secondary Links ---- */
    .hero-secondary-links .mx-3 {
        display: none;
    }

    .hero-secondary-links {
        flex-direction: column;
        gap: 0.25rem !important;
        align-items: center;
    }

    /* ---- Navbar Collapsed Auth Buttons ---- */
    .navbar-nav .nav-item.ms-2 {
        margin-left: 0 !important;
        margin-top: 0.5rem;
    }

    .navbar-nav .nav-item .btn-outline-primary,
    .navbar-nav .nav-item .btn-primary {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    /* ---- Theme Toggle in Collapsed Nav ---- */
    .navbar-nav .nav-item:has(.theme-toggle) {
        margin-left: 0 !important;
        margin-top: 0.75rem;
        display: flex;
        justify-content: center;
    }

    /* ---- Subscription Info Wrapping ---- */
    .card-body .d-flex.align-items-center.justify-content-between.flex-wrap {
        flex-direction: column;
        align-items: stretch !important;
        gap: 1rem !important;
        text-align: center;
    }

    .card-body .d-flex.align-items-center.justify-content-between.flex-wrap .btn {
        width: 100%;
    }

    /* ---- Quick Actions Grid ---- */
    .quick-action-btn .fs-3 {
        font-size: 1.5rem !important;
    }

    /* ---- Tables: Hide Less Important Columns ---- */
    .table .d-none-mobile {
        display: none !important;
    }

    /* ---- Footer Center Alignment ---- */
    .footer .d-flex.gap-2.flex-wrap {
        justify-content: center;
    }

    .footer .input-group {
        max-width: 100%;
    }

    /* ---- Management Nav ---- */
    #managementNavbar {
        padding: 0.75rem;
    }

    #managementNavbar .navbar-nav {
        margin-bottom: 0.75rem;
    }

    #managementNavbar .btn {
        width: 100%;
        text-align: center;
        justify-content: center;
        margin-top: 0.5rem;
    }

    /* ---- Pricing Toggle Button Group ---- */
    .btn-group[role="group"] {
        flex-direction: row;
        width: auto;
    }

    /* ---- General: Reduce Large Gaps ---- */
    .gap-4 {
        gap: 1rem !important;
    }

    .gap-3 {
        gap: 0.75rem !important;
    }

    /* ---- General: Prevent Horizontal Overflow ---- */
    .container-fluid {
        overflow-x: hidden;
    }

    img {
        max-width: 100%;
        height: auto;
    }

    /* ---- Inline Flex with Many Items ---- */
    .d-inline-flex.gap-1 {
        flex-wrap: wrap;
    }

    /* ---- Card Action Buttons ---- */
    .card-header .d-flex.justify-content-between.align-items-center .btn {
        width: 100%;
        justify-content: center;
    }

    /* ---- Profile Page ---- */
    .user-avatar-lg,
    .user-avatar-lg-fallback {
        width: 80px !important;
        height: 80px !important;
    }

    /* ---- Details Page Header Row ---- */
    .row.mb-4 > .col-12.col-lg-8 .d-flex.align-items-center.gap-3 {
        flex-direction: column;
        text-align: center;
    }

    .row.mb-4 > .col-12.col-lg-4.text-lg-end {
        text-align: center !important;
    }

    /* ---- Fix overflow on very long text ---- */
    .card-body,
    .card-header,
    .alert {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    /* ---- Intervention Details Action Buttons ---- */
    .d-flex.flex-wrap.gap-2 {
        justify-content: center;
    }

    /* ---- Intervention Details - Compact Mobile Toolbars ---- */
    .card-header .btn.btn-sm {
        min-height: 36px;
        padding: 0.375rem 0.625rem;
        font-size: 0.8125rem;
        width: auto !important;
    }

    .card-header .form-control-sm,
    .card-header .form-select-sm {
        min-height: 36px;
        padding: 0.25rem 0.5rem;
        font-size: 0.8125rem;
    }

    .card-header .input-group-text {
        padding: 0.25rem 0.5rem;
        font-size: 0.8125rem;
    }

    .details-filter-form {
        width: 100%;
        order: 10;
    }

    .details-filter-form .input-group {
        max-width: none !important;
        flex: 1;
    }

    .details-filter-form .form-select {
        flex: 0 0 auto;
        width: auto;
    }

    /* Billing action buttons compact sizing on mobile */
    .billing-actions .btn {
        min-height: 36px !important;
        padding: 0.375rem 0.625rem !important;
        font-size: 0.8125rem !important;
        width: auto !important;
    }
}

/* ============================================
   CUSTOM RESPONSIVE UTILITY CLASSES
   Bootstrap 5 doesn't include w-*-auto natively
   ============================================ */
@media (min-width: 992px) {
    .w-lg-auto {
        width: auto !important;
    }
    
    .ms-lg-2 {
        margin-left: 0.5rem !important;
    }
}

@media (min-width: 768px) {
    .w-md-auto {
        width: auto !important;
    }
}

/* ============================================
   TABLET RESPONSIVE (768px - 991px)
   ============================================ */
@media (min-width: 768px) and (max-width: 991.98px) {
    .hero-section .display-3 {
        font-size: 2.5rem;
    }
    
    .container {
        max-width: 720px;
    }
    
    /* Cards in Grid */
    .row.g-4 > [class*="col-"] {
        padding: 0.75rem;
    }
    
    /* Adjust columns for tablet */
    .col-md-3,
    .col-md-4,
    .col-md-6 {
        margin-bottom: 1rem;
    }
}

/* ============================================
   SMALL MOBILE DEVICES (< 576px)
   Extra Small Phones
   ============================================ */
@media (max-width: 575.98px) {
    /* Further reduce sizes for very small screens */
    .hero-section .display-3 {
        font-size: 1.75rem !important;
    }
    
    .display-5 {
        font-size: 1.25rem !important;
    }
    
    .btn-lg {
        padding: 0.75rem 1.25rem;
        font-size: 1rem;
    }
    
    .modal-dialog {
        margin: 0.25rem;
        max-width: calc(100% - 0.5rem);
    }
    
    /* Single column layout */
    .row.g-4 {
        margin-left: 0;
        margin-right: 0;
    }
    
    .row.g-4 > * {
        padding-left: 0;
        padding-right: 0;
    }
    
    /* Full width images */
    img {
        max-width: 100%;
        height: auto;
    }
    
    /* Container tighter padding */
    .container-fluid.px-4 {
        padding-left: 0.75rem !important;
        padding-right: 0.75rem !important;
    }

    /* Dashboard hero even smaller */
    .dashboard-hero .display-6 {
        font-size: 1.25rem !important;
    }
    
    .dashboard-hero .rounded-circle[style*="width: 72px"] {
        width: 56px !important;
        height: 56px !important;
    }
    
    .dashboard-hero .user-avatar[style*="width:56px"] {
        width: 44px !important;
        height: 44px !important;
        font-size: 1.5rem !important;
    }

    /* Stat cards - smaller numbers */
    .dashboard-stats .fw-bold.fs-4 {
        font-size: 1.25rem !important;
    }

    /* Card body tighter padding */
    .card-body {
        padding: 1rem;
    }
    
    .card-body.p-4 {
        padding: 1rem !important;
    }
    
    .card-body.p-5 {
        padding: 1.25rem !important;
    }

    /* Quick action buttons smaller icons */
    .btn .bi.d-block.fs-3 {
        font-size: 1.25rem !important;
    }

    /* Footer tighter on small screens */
    .footer.py-5 {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
    
    /* Hero buttons padding */
    .btn-hero-primary,
    .btn-hero-secondary {
        padding: 0.75rem 1.25rem;
    }
    
    .btn-hero-icon {
        font-size: 1.25rem;
    }

    /* Pricing cards */
    .pricing-amount {
        font-size: 2rem !important;
    }

    /* Breadcrumb overflow */
    .breadcrumb {
        overflow-x: auto;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    /* Tip dismiss button positioning */
    .tip-dismiss-btn {
        top: 0.25rem;
        right: 0.25rem;
    }
    
    /* Demo warning inline text */
    .card-body .d-flex.align-items-start {
        flex-wrap: wrap;
    }
    
    /* Table: very compact on small phones */
    .table thead th,
    .table tbody td {
        padding: 0.5rem 0.35rem;
        font-size: 0.8rem;
    }
}

/* ============================================
   LANDSCAPE MOBILE OPTIMIZATION
   ============================================ */
@media (max-height: 500px) and (orientation: landscape) {
    .hero-section {
        min-height: 400px !important;
        padding: 2rem 0 !important;
    }
    
    .modal-dialog {
        margin: 1rem auto;
        max-height: calc(100vh - 2rem);
        overflow-y: auto;
    }
}

/* ============================================
   TOUCH DEVICE OPTIMIZATIONS
   ============================================ */
@media (hover: none) and (pointer: coarse) {
    /* Remove hover effects for touch devices */
    .btn:hover {
        transform: none;
    }
    
    .nav-link:hover::after {
        transform: translateX(-50%) scale(0);
        opacity: 0;
    }
    
    .card:hover {
        transform: none;
    }
    
    .icon-box:hover,
    .icon-feature:hover {
        transform: none;
    }
    
    /* Increase tap targets */
    a, button, input, select, textarea {
        -webkit-tap-highlight-color: rgba(0, 97, 190, 0.1);
    }
    
    /* Prevent text selection issues */
    * {
        -webkit-touch-callout: default;
        -webkit-user-select: auto;
        user-select: auto;
    }
}

/* ============================================
   PRINT STYLES
   ============================================ */
@media print {
    .navbar-top,
    .footer,
    .btn,
    .breadcrumb {
        display: none !important;
    }
    
    .card {
        border: 1px solid #ddd;
        box-shadow: none !important;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.5;
    }
    
    h1 {
        font-size: 18pt;
    }
    
    h2 {
        font-size: 16pt;
    }
    
    h3 {
        font-size: 14pt;
    }
}

/* ============================================
   PROGRESSIVE WEB APP (PWA) SUPPORT
   ============================================ */
@media (display-mode: standalone) {
    /* Styles for when app is installed as PWA */
    .navbar-top {
        padding-top: env(safe-area-inset-top);
    }
    
    body {
        padding-bottom: env(safe-area-inset-bottom);
    }
    
    /* Add safe area for iOS notch */
    .main-wrapper {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
}

/* ============================================
   ACCESSIBILITY IMPROVEMENTS FOR MOBILE
   ============================================ */

/* Focus Visible for Keyboard Navigation */
:focus-visible {
    outline: 3px solid var(--primary-color);
    outline-offset: 2px;
}

/* Skip to main content link */
.skip-to-main {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--primary-color);
    color: white;
    padding: 8px 16px;
    text-decoration: none;
    z-index: 100;
}

.skip-to-main:focus {
    top: 0;
}

/* Screen Reader Only Class */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* ============================================
   PERFORMANCE OPTIMIZATIONS
   ============================================ */

/* Reduce animations on low-performance devices */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ============================================
   DARK MODE MOBILE ADJUSTMENTS
   ============================================ */
@media (max-width: 767.98px) {
    [data-theme="dark"] .navbar-collapse {
        background: var(--gray-800);
        border: 1px solid var(--gray-700);
    }
    
    [data-theme="dark"] .hero-section {
        background: linear-gradient(135deg, #1B3A54 0%, #275378 100%);
    }
}

/* ============================================
   ENHANCED FORM VALIDATION & MESSAGING SYSTEM
   Professional Icons, Animations & Feedback
   ============================================ */

/* Success & Error Message Containers */
.alert-success,
.alert-danger,
.alert-warning,
.alert-info {
    display: flex;
    align-items: center;
    border: none;
    border-radius: var(--radius-lg);
    padding: 1rem 1.25rem;
    font-weight: 500;
    box-shadow: var(--shadow-sm);
    animation: slideInDown 0.3s ease-out;
}

@keyframes slideInDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.alert-success {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    color: #000000 !important;
    border-left: 4px solid var(--success-color);
}

.alert-danger {
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    color: #000000 !important;
    border-left: 4px solid var(--danger-color);
}

.alert-warning {
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    color: #000000 !important;
    border-left: 4px solid var(--warning-color);
}

.alert-info {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
    color: #000000 !important;
    border-left: 4px solid var(--info-color);
}

/* Force black text for all alert content including spans and strong tags */
.alert-success *,
.alert-danger *,
.alert-warning *,
.alert-info * {
    color: #000000 !important;
}

/* Alert Icons Styling */
.alert i.bi {
    font-size: 1.25rem;
    margin-right: 0.75rem;
    flex-shrink: 0;
}

.alert-success i.bi {
    color: var(--success-color) !important;
}

.alert-danger i.bi {
    color: var(--danger-color) !important;
}

.alert-warning i.bi {
    color: var(--warning-color) !important;
}

.alert-info i.bi {
    color: var(--info-color) !important;
}

/* Animated Success Icon */
.alert-success i.bi-check-circle-fill,
.alert-success i.bi-check-circle {
    animation: successPulse 0.5s ease-in-out;
}

@keyframes successPulse {
    0% {
        transform: scale(0);
        opacity: 0;
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Animated Error Icon */
.alert-danger i.bi-exclamation-triangle-fill,
.alert-danger i.bi-x-circle-fill {
    animation: errorShake 0.5s ease-in-out;
}

@keyframes errorShake {
    0%, 100% {
        transform: translateX(0);
    }
    10%, 30%, 50%, 70%, 90% {
        transform: translateX(-5px);
    }
    20%, 40%, 60%, 80% {
        transform: translateX(5px);
    }
}

/* Alert Close Button */
.alert .btn-close {
    margin-left: auto;
    opacity: 0.8;
    filter: brightness(0) invert(1);
}

.alert .btn-close:hover {
    opacity: 1;
    transform: scale(1.1);
}

/* Prevent stacked alerts from touching */
.alert + .alert {
    margin-top: 1rem !important;
}

/* Hide alerts properly */
.alert.d-none {
    display: none !important;
    margin-bottom: 0 !important;
}

/* Form Validation States */
.form-control.is-valid,
.form-select.is-valid {
    border-color: var(--success-color);
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2310b981' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

.form-control.is-invalid,
.form-select.is-invalid {
    border-color: var(--danger-color);
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23ef4444'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23ef4444' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.form-control.is-valid:focus,
.form-select.is-valid:focus {
    border-color: var(--success-color);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15);
}

.form-control.is-invalid:focus,
.form-select.is-invalid:focus {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

/* Validation Feedback Messages */
.valid-feedback,
.invalid-feedback {
    display: none;
    margin-top: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
}

.valid-feedback {
    color: var(--success-color);
}

.invalid-feedback {
    color: var(--danger-color);
}

.was-validated .form-control:valid ~ .valid-feedback,
.was-validated .form-select:valid ~ .valid-feedback,
.form-control.is-valid ~ .valid-feedback,
.form-select.is-valid ~ .valid-feedback {
    display: block;
    animation: slideInUp 0.3s ease-out;
}

.was-validated .form-control:invalid ~ .invalid-feedback,
.was-validated .form-select:invalid ~ .invalid-feedback,
.form-control.is-invalid ~ .invalid-feedback,
.form-select.is-invalid ~ .invalid-feedback {
    display: block;
    animation: slideInUp 0.3s ease-out;
}

/* Input Icons */
.input-group-text {
    background-color: #f8f9fa;
    border: 2px solid var(--gray-200);
    border-right: none;
    transition: all var(--transition-base);
}

.input-group > .form-control,
.input-group > .form-select {
    border-left: none;
}

.input-group .form-control:focus ~ .input-group-text,
.input-group .input-group-text ~ .form-control:focus {
    border-color: var(--primary-color);
}

.input-group-text i.bi {
    color: var(--gray-500);
    font-size: 1.1rem;
}

/* Focused Input Icons */
.input-group:focus-within .input-group-text {
    background-color: rgba(0, 97, 190, 0.05);
    border-color: var(--primary-color);
}

.input-group:focus-within .input-group-text i.bi {
    color: var(--primary-color);
}

/* Valid State Input Icons */
.input-group .form-control.is-valid ~ .input-group-text,
.input-group:has(.form-control.is-valid) .input-group-text {
    background-color: rgba(16, 185, 129, 0.05);
    border-color: var(--success-color);
}

.input-group .form-control.is-valid ~ .input-group-text i.bi,
.input-group:has(.form-control.is-valid) .input-group-text i.bi {
    color: var(--success-color);
}

/* Invalid State Input Icons */
.input-group .form-control.is-invalid ~ .input-group-text,
.input-group:has(.form-control.is-invalid) .input-group-text {
    background-color: rgba(239, 68, 68, 0.05);
    border-color: var(--danger-color);
}

.input-group .form-control.is-invalid ~ .input-group-text i.bi,
.input-group:has(.form-control.is-invalid) .input-group-text i.bi {
    color: var(--danger-color);
}

/* Enhanced Form Labels */
.form-label {
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
}

.form-label .text-danger {
    margin-left: 0.25rem;
}

.form-label i.bi {
    margin-right: 0.5rem;
    color: var(--gray-500);
}

/* Form Text / Help Text */
.form-text {
    margin-top: 0.375rem;
    font-size: 0.875rem;
    color: var(--gray-600);
}

.form-text i.bi {
    margin-right: 0.25rem;
    font-size: 0.875rem;
}

/* Loading Spinner in Forms */
.form-loading {
    position: relative;
}

.form-loading::after {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    top: 50%;
    right: 1rem;
    margin-top: -10px;
    border: 2px solid rgba(0, 97, 190, 0.2);
    border-radius: 50%;
    border-top-color: var(--primary-color);
    animation: spinner 0.6s linear infinite;
}

/* Required Field Indicator */
.required-indicator {
    color: var(--danger-color);
    font-weight: bold;
    margin-left: 0.25rem;
}

/* Character Counter */
.char-counter {
    text-align: right;
    font-size: 0.875rem;
    color: var(--gray-600);
    margin-top: 0.375rem;
}

.char-counter.text-danger {
    color: var(--danger-color) !important;
    font-weight: 600;
}

/* Form Progress Indicator */
.form-progress {
    height: 4px;
    background-color: var(--gray-200);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.form-progress-bar {
    height: 100%;
    background: var(--gradient-primary);
    transition: width 0.3s ease;
}

/* Password Strength Indicator */
.password-strength {
    height: 4px;
    background-color: var(--gray-200);
    border-radius: 2px;
    margin-top: 0.5rem;
    overflow: hidden;
}

.password-strength-bar {
    height: 100%;
    transition: all 0.3s ease;
}

.password-strength-weak .password-strength-bar {
    width: 33%;
    background-color: var(--danger-color);
}

.password-strength-medium .password-strength-bar {
    width: 66%;
    background-color: var(--warning-color);
}

.password-strength-strong .password-strength-bar {
    width: 100%;
    background-color: var(--success-color);
}

/* Checkbox & Radio Enhancements */
.form-check-input {
    width: 1.25em;
    height: 1.25em;
    margin-top: 0.125em;
    cursor: pointer;
    border: 2px solid var(--gray-300);
    transition: all var(--transition-base);
}

.form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.form-check-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(0, 97, 190, 0.15);
}

.form-check-label {
    cursor: pointer;
    user-select: none;
}

/* File Upload Styling */
input[type="file"] {
    cursor: pointer;
}

input[type="file"]::file-selector-button {
    padding: 0.5rem 1rem;
    margin-right: 1rem;
    background: var(--gradient-primary);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-weight: 600;
    transition: all var(--transition-base);
}

input[type="file"]::file-selector-button:hover {
    background: linear-gradient(135deg, var(--secondary-color) 0%, var(--primary-color) 100%);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

/* Select Dropdown Enhancement */
.form-select {
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

/* Floating Labels */
.form-floating > .form-control,
.form-floating > .form-select {
    height: calc(3.5rem + 2px);
    line-height: 1.25;
}

.form-floating > label {
    padding: 1rem 0.75rem;
    color: var(--gray-500);
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
    opacity: 0.65;
    transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}

/* Dark Mode Alert Adjustments - Keep text BLACK for readability */
[data-theme="dark"] .alert-success {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
    color: #000000 !important;
    border-left: 4px solid var(--success-color);
}

[data-theme="dark"] .alert-danger {
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    color: #000000 !important;
    border-left: 4px solid var(--danger-color);
}

[data-theme="dark"] .alert-warning {
    background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
    color: #000000 !important;
    border-left: 4px solid var(--warning-color);
}

[data-theme="dark"] .alert-info {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
    color: #000000 !important;
    border-left: 4px solid var(--info-color);
}

/* Force BLACK text for ALL alert content in dark mode */
[data-theme="dark"] .alert-success *,
[data-theme="dark"] .alert-danger *,
[data-theme="dark"] .alert-warning *,
[data-theme="dark"] .alert-info * {
    color: #000000 !important;
}

/* Keep only icons with their respective colors */
[data-theme="dark"] .alert-success i.bi {
    color: var(--success-color) !important;
}

[data-theme="dark"] .alert-danger i.bi {
    color: var(--danger-color) !important;
}

[data-theme="dark"] .alert-warning i.bi {
    color: var(--warning-color) !important;
}

[data-theme="dark"] .alert-info i.bi {
    color: var(--info-color) !important;
}

/* ============================================
   FORCE FORMS TO STAY LIGHT IN DARK MODE
   Keep all form pages readable and consistent
   ============================================ */

/* Keep card backgrounds white in forms even in dark mode */
[data-theme="dark"] .card {
    background-color: white !important;
    color: #1f2937 !important;
}

/* EXCEPT: Pricing cards with colored headers should keep their headers */
[data-theme="dark"] .card-header.bg-primary {
    background: linear-gradient(135deg, #275378 0%, #326B98 100%) !important;
    color: white !important;
}

[data-theme="dark"] .card-header.bg-dark {
    background: #1f2937 !important;
    color: white !important;
}

[data-theme="dark"] .card-header.bg-light {
    background-color: #f3f4f6 !important;
    color: #1f2937 !important;
}

[data-theme="dark"] .card-header.bg-white {
    background-color: white !important;
    color: #1f2937 !important;
}

/* Keep pricing card header text white on dark backgrounds */
[data-theme="dark"] .card-header.bg-primary h1,
[data-theme="dark"] .card-header.bg-primary h2,
[data-theme="dark"] .card-header.bg-primary h3,
[data-theme="dark"] .card-header.bg-primary h4,
[data-theme="dark"] .card-header.bg-primary h5,
[data-theme="dark"] .card-header.bg-primary h6,
[data-theme="dark"] .card-header.bg-primary .pricing-amount,
[data-theme="dark"] .card-header.bg-primary span,
[data-theme="dark"] .card-header.bg-primary div {
    color: white !important;
}

[data-theme="dark"] .card-header.bg-dark h1,
[data-theme="dark"] .card-header.bg-dark h2,
[data-theme="dark"] .card-header.bg-dark h3,
[data-theme="dark"] .card-header.bg-dark h4,
[data-theme="dark"] .card-header.bg-dark h5,
[data-theme="dark"] .card-header.bg-dark h6,
[data-theme="dark"] .card-header.bg-dark .pricing-amount,
[data-theme="dark"] .card-header.bg-dark span,
[data-theme="dark"] .card-header.bg-dark div,
[data-theme="dark"] .card-header.bg-dark .small {
    color: white !important;
}

/* Keep light header text dark */
[data-theme="dark"] .card-header.bg-light h1,
[data-theme="dark"] .card-header.bg-light h2,
[data-theme="dark"] .card-header.bg-light h3,
[data-theme="dark"] .card-header.bg-light h4,
[data-theme="dark"] .card-header.bg-light h5,
[data-theme="dark"] .card-header.bg-light h6,
[data-theme="dark"] .card-header.bg-light .pricing-amount,
[data-theme="dark"] .card-header.bg-light span,
[data-theme="dark"] .card-header.bg-light div {
    color: #1f2937 !important;
}

[data-theme="dark"] .card-body {
    background-color: white !important;
}

/* Keep all pricing card body content dark and readable */
[data-theme="dark"] .card .card-body,
[data-theme="dark"] .card-body {
    color: #1f2937 !important;
}

[data-theme="dark"] .card .card-body ul,
[data-theme="dark"] .card .card-body li,
[data-theme="dark"] .card .card-body p {
    color: #1f2937 !important;
}

/* Keep pricing card badges visible */
[data-theme="dark"] .card .badge.bg-success {
    background-color: #10b981 !important;
    color: white !important;
}

[data-theme="dark"] .card .badge.bg-primary {
    background: linear-gradient(135deg, #275378 0%, #326B98 100%) !important;
    color: white !important;
}

/* Keep info section cards readable */
[data-theme="dark"] .card.bg-light {
    background-color: #f3f4f6 !important;
}

[data-theme="dark"] .card.bg-light .card-body,
[data-theme="dark"] .card.bg-light h1,
[data-theme="dark"] .card.bg-light h2,
[data-theme="dark"] .card.bg-light h3,
[data-theme="dark"] .card.bg-light h4,
[data-theme="dark"] .card.bg-light h5,
[data-theme="dark"] .card.bg-light h6,
[data-theme="dark"] .card.bg-light p,
[data-theme="dark"] .card.bg-light div {
    color: #1f2937 !important;
}

[data-theme="dark"] .card-header {
    background-color: white !important;
    color: #1f2937 !important;
    border-bottom-color: #e5e7eb !important;
}

/* Force all headings in cards to be dark */
[data-theme="dark"] .card h1,
[data-theme="dark"] .card h2,
[data-theme="dark"] .card h3,
[data-theme="dark"] .card h4,
[data-theme="dark"] .card h5,
[data-theme="dark"] .card h6 {
    color: #1f2937 !important;
}

/* Force all paragraphs and text in cards to be dark (except alerts) */
[data-theme="dark"] .card p:not(.alert p),
[data-theme="dark"] .card span:not(.alert span),
[data-theme="dark"] .card div:not(.alert div) {
    color: #1f2937 !important;
}

/* Force form labels to be dark and visible */
[data-theme="dark"] .card .form-label,
[data-theme="dark"] .form-label {
    color: #374151 !important;
    font-weight: 600 !important;
}

/* Force form controls to stay light with dark text */
[data-theme="dark"] .card .form-control,
[data-theme="dark"] .card .form-select,
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: white !important;
    border-color: #d1d5db !important;
    color: #1f2937 !important;
}

[data-theme="dark"] .card .form-control::placeholder,
[data-theme="dark"] .form-control::placeholder {
    color: #9ca3af !important;
}

[data-theme="dark"] .card .form-control:focus,
[data-theme="dark"] .card .form-select:focus,
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: white !important;
    border-color: #275378 !important;
    color: #1f2937 !important;
    box-shadow: 0 0 0 3px rgba(39, 83, 120, 0.1) !important;
}

/* Force input group text to stay light */
[data-theme="dark"] .card .input-group-text,
[data-theme="dark"] .input-group-text {
    background-color: #f9fafb !important;
    border-color: #d1d5db !important;
    color: #6b7280 !important;
}

/* Force input group icons to stay visible */
[data-theme="dark"] .card .input-group-text i.bi,
[data-theme="dark"] .input-group-text i.bi {
    color: #6b7280 !important;
}

[data-theme="dark"] .card .input-group:focus-within .input-group-text,
[data-theme="dark"] .input-group:focus-within .input-group-text {
    background-color: rgba(39, 83, 120, 0.05) !important;
    border-color: #275378 !important;
    color: #275378 !important;
}

[data-theme="dark"] .card .input-group:focus-within .input-group-text i.bi,
[data-theme="dark"] .input-group:focus-within .input-group-text i.bi {
    color: #275378 !important;
}

/* Force text-muted to be readable */
[data-theme="dark"] .card .text-muted,
[data-theme="dark"] .card .form-text {
    color: #6b7280 !important;
}

/* Force small text to be visible */
[data-theme="dark"] .card small,
[data-theme="dark"] .card .small {
    color: #6b7280 !important;
}

/* Preserve CTA gradient card appearance in dark mode */
/* Uses .card.cta-gradient-card for higher specificity to beat .card p:not(.alert p) etc. */
[data-theme="dark"] .card.cta-gradient-card {
    background: linear-gradient(135deg, #275378 0%, #326B98 100%) !important;
    color: white !important;
}

[data-theme="dark"] .card.cta-gradient-card .card-body {
    background-color: transparent !important;
    color: white !important;
}

[data-theme="dark"] .card.cta-gradient-card .card-body h1,
[data-theme="dark"] .card.cta-gradient-card .card-body h2,
[data-theme="dark"] .card.cta-gradient-card .card-body h3,
[data-theme="dark"] .card.cta-gradient-card .card-body h4,
[data-theme="dark"] .card.cta-gradient-card .card-body h5,
[data-theme="dark"] .card.cta-gradient-card .card-body h6,
[data-theme="dark"] .card.cta-gradient-card .card-body p,
[data-theme="dark"] .card.cta-gradient-card .card-body span,
[data-theme="dark"] .card.cta-gradient-card .card-body div,
[data-theme="dark"] .card.cta-gradient-card .card-body small,
[data-theme="dark"] .card.cta-gradient-card .card-body .small,
[data-theme="dark"] .card.cta-gradient-card .card-body i {
    color: white !important;
}

[data-theme="dark"] .card.cta-gradient-card .card-body a:not(.btn) {
    color: white !important;
}

[data-theme="dark"] .card.cta-gradient-card .card-body .btn-light {
    background-color: white !important;
    color: #275378 !important;
}

[data-theme="dark"] .card.cta-gradient-card .card-body .btn-outline-light {
    border-color: white !important;
    color: white !important;
}

/* Keep buttons consistent in forms */
[data-theme="dark"] .card .btn-primary,
[data-theme="dark"] .btn-primary {
    background: linear-gradient(135deg, #275378 0%, #326B98 100%) !important;
    border: none !important;
    color: white !important;
}

[data-theme="dark"] .card .btn-outline-secondary,
[data-theme="dark"] .btn-outline-secondary {
    border-color: #d1d5db !important;
    color: #374151 !important;
    background: white !important;
}

[data-theme="dark"] .card .btn-outline-secondary:hover,
[data-theme="dark"] .btn-outline-secondary:hover {
    background-color: #f3f4f6 !important;
    color: #1f2937 !important;
    border-color: #9ca3af !important;
}

/* Keep validation feedback visible */
[data-theme="dark"] .card .valid-feedback,
[data-theme="dark"] .valid-feedback {
    color: #10b981 !important;
}

[data-theme="dark"] .card .invalid-feedback,
[data-theme="dark"] .invalid-feedback {
    color: #ef4444 !important;
}

/* Keep text-danger visible */
[data-theme="dark"] .card .text-danger,
[data-theme="dark"] .text-danger {
    color: #ef4444 !important;
}

/* Keep links visible in forms */
[data-theme="dark"] .card a:not(.btn):not(.alert a) {
    color: #275378 !important;
}

[data-theme="dark"] .card a:not(.btn):not(.alert a):hover {
    color: #AD2227 !important;
}

/* Force textarea to stay light */
[data-theme="dark"] .card textarea.form-control,
[data-theme="dark"] textarea.form-control {
    background-color: white !important;
    color: #1f2937 !important;
    border-color: #d1d5db !important;
}

/* Keep checkboxes and radio buttons visible */
[data-theme="dark"] .card .form-check-label,
[data-theme="dark"] .form-check-label {
    color: #374151 !important;
}

[data-theme="dark"] .card .form-check-input,
[data-theme="dark"] .form-check-input {
    background-color: white !important;
    border-color: #d1d5db !important;
}

/* Keep file inputs styled properly */
[data-theme="dark"] .card input[type="file"],
[data-theme="dark"] input[type="file"] {
    color: #374151 !important;
}

/* Keep select dropdowns readable */
[data-theme="dark"] .card select option,
[data-theme="dark"] select option {
    background-color: white !important;
    color: #1f2937 !important;
}

/* Container backgrounds in dark mode - but NOT form cards */
[data-theme="dark"] .container:not(:has(.card)) {
    background-color: var(--gray-100);
}

/* Toast Notifications (Alternative to Alerts) */
.toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1050;
}

.toast {
    background: white;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    padding: 1rem 1.25rem;
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    min-width: 300px;
    animation: slideInRight 0.3s ease-out;
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(100%);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.toast.toast-success {
    border-left: 4px solid var(--success-color);
}

.toast.toast-error {
    border-left: 4px solid var(--danger-color);
}

.toast.toast-warning {
    border-left: 4px solid var(--warning-color);
}

.toast.toast-info {
    border-left: 4px solid var(--info-color);
}

.toast i.bi {
    font-size: 1.5rem;
    margin-right: 0.75rem;
}

.toast-success i.bi {
    color: var(--success-color);
}

.toast-error i.bi {
    color: var(--danger-color);
}

.toast-warning i.bi {
    color: var(--warning-color);
}

.toast-info i.bi {
    color: var(--info-color);
}

/* Workflow Bubbles (HowItWorks) */
.nf-how-bubble-content {
    min-height: 270px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}
.nf-how-bubble-example {
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.nf-how-bubble-badge {
    width: 100%;
    display: block;
    text-align: center;
    white-space: normal;
}
.nf-how-bubble-col {
    flex: 0 0 220px;
    max-width: 220px;
    min-width: 220px;
    padding-left: 12px;
    padding-right: 12px;
}

/* Center the bubbles row on larger screens */
@media (min-width: 992px) {
    .row:has(.nf-how-bubble-col) {
        justify-content: center;
    }
}

@media (max-width: 991.98px) {
    .nf-how-bubble-col {
        flex: 1 1 100%;
        max-width: 100%;
        min-width: 0;
    }
}

/* ============================================
   MANAGEMENT NAV - DESKTOP STYLING
   ============================================ */

#managementNavbar .navbar-nav .nav-link {
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--gray-600);
    letter-spacing: 0.01em;
    padding: 0.5rem 0.875rem;
    border-radius: var(--radius-md);
    transition: color var(--transition-base), background-color var(--transition-base);
    text-decoration: none;
}

#managementNavbar .navbar-nav .nav-link:hover {
    color: var(--primary-color);
    background-color: rgba(0, 97, 190, 0.06);
    text-decoration: none;
}

#managementNavbar .navbar-nav .nav-link.active {
    color: var(--primary-color);
    background-color: rgba(0, 97, 190, 0.08);
}

[data-theme="dark"] #managementNavbar .navbar-nav .nav-link {
    color: var(--gray-400);
}

[data-theme="dark"] #managementNavbar .navbar-nav .nav-link:hover {
    color: var(--primary-light);
    background-color: rgba(0, 97, 190, 0.12);
}

[data-theme="dark"] #managementNavbar .navbar-nav .nav-link.active {
    color: var(--primary-light);
    background-color: rgba(0, 97, 190, 0.15);
}

/* ============================================
   MANAGEMENT NAV - ALWAYS VISIBLE ON MOBILE
   Override Bootstrap collapse below lg breakpoint
   so nav items show directly without hamburger.
   ============================================ */

@media (max-width: 991.98px) {
    /* Hide the hamburger toggler and "Menu" brand label */
    .navbar:has(#managementNavbar) .navbar-toggler,
    .navbar:has(#managementNavbar) .navbar-brand {
        display: none !important;
    }

    /* Force the collapse to always be visible */
    #managementNavbar {
        display: flex !important;
        flex-basis: auto !important;
        flex-wrap: nowrap;
        align-items: center;
        background: transparent !important;
        box-shadow: none !important;
        margin-top: 0 !important;
        border-radius: 0 !important;
        padding: 0 !important;
    }

    /* Horizontal scrollable nav strip */
    #managementNavbar .navbar-nav {
        flex-direction: row !important;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        margin-bottom: 0 !important;
        gap: 0;
        scrollbar-width: none;
    }

    #managementNavbar .navbar-nav::-webkit-scrollbar {
        display: none;
    }

    #managementNavbar .navbar-nav .nav-item {
        flex-shrink: 0;
    }

    #managementNavbar .navbar-nav .nav-link {
        white-space: nowrap;
        padding: 0.5rem 0.625rem;
        font-size: 0.8125rem;
        min-height: auto;
    }

    /* Hide link text, show icon-only on small phones */
    #managementNavbar .nav-link .mgmt-nav-text {
        display: inline;
    }

    /* Download App button - compact */
    #managementNavbar > a.btn {
        flex-shrink: 0;
        width: auto !important;
        margin-top: 0 !important;
        padding: 0.375rem 0.625rem !important;
        font-size: 0.75rem;
        white-space: nowrap;
    }
}

/* Extra small phones: icon-only management nav */
@media (max-width: 575.98px) {
    #managementNavbar .nav-link .mgmt-nav-text {
        display: none;
    }

    #managementNavbar .navbar-nav .nav-link {
        padding: 0.5rem 0.5rem;
        font-size: 1rem;
    }

    #managementNavbar .navbar-nav .nav-link i {
        margin-right: 0 !important;
    }

    /* Hide Download App button on very small screens to save space */
    #managementNavbar > a.btn {
        display: none !important;
    }
}

/* ============================================
   TOP NAVBAR - BURGER MENU ON MOBILE
   Proper Bootstrap collapse behavior below lg
   ============================================ */

@media (max-width: 991.98px) {
    /* Burger toggler styling */
    .navbar-top .navbar-toggler {
        border: 1px solid rgba(0, 0, 0, 0.15);
        padding: 0.375rem 0.5rem;
        min-height: 44px;
        min-width: 44px;
        display: flex !important;
        align-items: center;
        justify-content: center;
    }

    [data-theme="dark"] .navbar-top .navbar-toggler {
        border-color: rgba(255, 255, 255, 0.2);
    }

    /* Collapse panel styling */
    .navbar-top #navbarNav {
        background: #ffffff;
        margin-top: 0.75rem;
        border-radius: var(--radius-lg, 0.75rem);
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
        padding: 1rem;
        border: 1px solid rgba(0, 0, 0, 0.08);
    }

    [data-theme="dark"] .navbar-top #navbarNav {
        background: var(--gray-800, #1e293b);
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
        border-color: rgba(255, 255, 255, 0.1);
    }

    /* Stack nav items vertically */
    .navbar-top #navbarNav .navbar-nav {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0.125rem;
        padding: 0.25rem 0;
    }

    .navbar-top #navbarNav .navbar-nav .nav-item {
        margin: 0 !important;
    }

    /* Nav links full-width with touch-friendly targets */
    .navbar-top #navbarNav .navbar-nav .nav-link {
        padding: 0.625rem 0.75rem;
        border-radius: var(--radius-md, 0.5rem);
        font-size: 0.9375rem;
        min-height: 44px;
        display: flex;
        align-items: center;
        transition: background-color 0.15s ease;
    }

    .navbar-top #navbarNav .navbar-nav .nav-link:hover,
    .navbar-top #navbarNav .navbar-nav .nav-link:focus {
        background: rgba(0, 0, 0, 0.04);
    }

    [data-theme="dark"] .navbar-top #navbarNav .navbar-nav .nav-link:hover,
    [data-theme="dark"] .navbar-top #navbarNav .navbar-nav .nav-link:focus {
        background: rgba(255, 255, 255, 0.08);
    }

    /* View toggle - keep horizontal, center in panel */
    .navbar-top #navbarNav .nav-view-toggle {
        flex-direction: row;
        justify-content: center;
        padding: 0.375rem 0;
        gap: 0.25rem;
    }

    .navbar-top #navbarNav .nav-view-toggle .nav-view-btn {
        flex: 1;
        text-align: center;
        justify-content: center;
    }

    .navbar-top #navbarNav .nav-view-toggle > span.text-muted {
        display: inline !important;
    }

    /* Auth buttons full-width in collapsed menu */
    .navbar-top #navbarNav .navbar-nav .nav-item .btn {
        width: 100%;
        justify-content: center;
        min-height: 44px !important;
        font-size: 0.875rem;
    }

    /* User dropdown - full width */
    .navbar-top #navbarNav .dropdown .dropdown-toggle {
        width: 100%;
    }

    .navbar-top #navbarNav .dropdown .user-avatar {
        width: 32px;
        height: 32px;
        font-size: 0.8125rem;
    }

    /* Dropdown menu inside collapsed nav - static positioning */
    .navbar-top #navbarNav .navbar-nav .dropdown-menu {
        position: static !important;
        float: none;
        box-shadow: none;
        border: 1px solid rgba(0, 0, 0, 0.08);
        border-radius: var(--radius-md, 0.5rem);
        margin-top: 0.25rem;
        padding: 0.5rem;
    }

    [data-theme="dark"] .navbar-top #navbarNav .navbar-nav .dropdown-menu {
        border-color: rgba(255, 255, 255, 0.1);
        background: var(--gray-700, #334155);
    }

    /* Theme toggle separator and centering */
    .navbar-top #navbarNav .navbar-nav .nav-item:has(.theme-toggle) {
        display: flex;
        justify-content: center;
        padding-top: 0.5rem;
        margin-top: 0.25rem;
        border-top: 1px solid rgba(0, 0, 0, 0.08);
    }

    [data-theme="dark"] .navbar-top #navbarNav .navbar-nav .nav-item:has(.theme-toggle) {
        border-top-color: rgba(255, 255, 255, 0.1);
    }

    /* Clear Bootstrap margin utilities for stacked layout */
    .navbar-top #navbarNav .navbar-nav .nav-item.ms-lg-2 {
        margin-left: 0 !important;
    }

    .navbar-top #navbarNav .navbar-nav .nav-item.mt-2 {
        margin-top: 0.25rem !important;
    }
}

/* Phone-specific top nav adjustments */
@media (max-width: 767.98px) {
    .navbar-top .navbar-brand-logo {
        height: 44px !important;
    }

    .navbar-top #navbarNav {
        padding: 0.75rem;
    }
}

/* Extra small phones */
@media (max-width: 575.98px) {
    .navbar-top .navbar-brand-logo {
        height: 36px !important;
    }
}

/* Custom purple outline button */
.btn-outline-purple {
    border: 2px solid #6f42c1;
    color: #6f42c1;
    background: transparent;
}

.btn-outline-purple:hover,
.btn-outline-purple:focus,
.btn-outline-purple:active,
.btn-outline-purple.active {
    color: #fff;
    background-color: #6f42c1;
    border-color: #6f42c1;
    transform: translateY(-2px);
}

.btn-outline-purple:hover i {
    color: white !important;
}

/* ============================================
   FC INLINE DATE-TIME PICKER
   ============================================ */

.fc-dt-field {
    position: relative;
}

.fc-dt-trigger {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    background: white;
    border: 2px solid var(--gray-200);
    border-radius: var(--radius-md);
    padding: 0.875rem 1rem;
    cursor: pointer;
    text-align: left;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

.fc-dt-trigger:hover {
    border-color: var(--primary-color);
}

.fc-dt-trigger.fc-dt-open {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(39, 83, 120, 0.1);
}

.fc-dt-field-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.125rem;
}

.fc-dt-field-value {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--gray-800);
}

.fc-dt-placeholder {
    color: var(--gray-400) !important;
    font-weight: 400 !important;
}

.fc-dt-panel {
    position: relative;
    margin-top: 0.5rem;
    background: white;
    border: 2px solid var(--primary-color);
    border-radius: var(--radius-lg);
    padding: 1rem;
    box-shadow: var(--shadow-lg);
    z-index: 10;
}

/* Calendar header */
.fc-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.fc-cal-title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--gray-800);
}

.fc-cal-nav {
    border: none;
    background: var(--gray-100);
    border-radius: var(--radius-md);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.fc-cal-nav:hover {
    background: var(--gray-200);
}

/* Calendar grid */
.fc-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.fc-cal-dow {
    text-align: center;
    font-size: 0.6875rem;
    font-weight: 700;
    color: var(--gray-500);
    padding: 0.25rem 0;
    text-transform: uppercase;
}

.fc-cal-day {
    text-align: center;
    padding: 0.375rem 0;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast);
    user-select: none;
}

.fc-cal-day:not(.fc-cal-past):hover {
    background: var(--gray-100);
    color: var(--primary-color);
}

.fc-cal-past {
    color: var(--gray-300);
    cursor: default;
}

.fc-cal-today {
    color: var(--primary-color);
    font-weight: 700;
    border: 2px solid var(--primary-color);
}

.fc-cal-selected {
    background: var(--primary-color);
    color: white !important;
    font-weight: 700;
}

.fc-cal-selected:hover {
    background: var(--primary-dark) !important;
}

/* Time slots */
.fc-times-label {
    margin-top: 0.75rem;
    margin-bottom: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--gray-600);
    display: block;
}

.fc-times-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px;
    margin-top: 0.25rem;
}

.fc-time-slot {
    text-align: center;
    padding: 0.375rem 0.25rem;
    border-radius: var(--radius-sm);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
    user-select: none;
}

.fc-time-slot:hover {
    background: rgba(39, 83, 120, 0.08);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.fc-time-selected {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: white !important;
    font-weight: 700;
}

/* Done button */
.fc-dt-done {
    margin-top: 0.75rem;
}

/* Dark mode adjustments */
[data-theme="dark"] .fc-dt-trigger {
    background: white;
    border-color: #d1d5db;
    color: #1f2937;
}

[data-theme="dark"] .fc-dt-panel {
    background: white;
    color: #1f2937;
}

[data-theme="dark"] .fc-dt-panel * {
    color: #1f2937;
}

[data-theme="dark"] .fc-cal-selected,
[data-theme="dark"] .fc-time-selected {
    color: white !important;
}

