:root {
            /* Consistent Color System */
            --primary-blue: #3b82f6;
            --primary-purple: #8b5cf6;
            --primary-gradient: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);
            --success-green: #10b981;
            --success-gradient: linear-gradient(135deg, #10b981 0%, #34d399 100%);
            --warning-yellow: #f59e0b;
            --warning-gradient: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
            --danger-red: #ef4444;
            --danger-gradient: linear-gradient(135deg, #ef4444 0%, #f87171 100%);

            /* Enhanced Light Theme - Better Contrast */
            --bg-primary: #f8fafc;
            --bg-secondary: #ffffff;
            --bg-sidebar: rgba(255, 255, 255, 0.95);
            --bg-card: rgba(255, 255, 255, 0.9);
            --bg-glass: rgba(255, 255, 255, 0.7);

            --text-primary: #0f172a;
            --text-secondary: #374151;
            --text-muted: #6b7280;
            --text-white: #ffffff;

            --border-light: #e2e8f0;
            --border-medium: #cbd5e1;
            --border-focus: #3b82f6;

            --shadow-light: 0 1px 3px 0 rgba(0, 0, 0, 0.12);
            --shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, 0.15);
            --shadow-dark: 0 10px 15px -3px rgba(0, 0, 0, 0.2);
        }

        [data-theme="dark"] {
            /* Enhanced Dark Theme - Better Readability */
            --bg-primary: #1e293b;
            --bg-secondary: #0f172a;
            --bg-sidebar: rgba(15, 23, 42, 0.95);
            --bg-card: rgba(30, 41, 59, 0.8);
            --bg-glass: rgba(30, 41, 59, 0.6);

            --text-primary: #f1f5f9;
            --text-secondary: #e2e8f0;
            --text-muted: #94a3b8;

            --border-light: #334155;
            --border-medium: #475569;
            --border-focus: #60a5fa;

            --shadow-light: 0 1px 3px 0 rgba(0, 0, 0, 0.4);
            --shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
            --shadow-dark: 0 10px 15px -3px rgba(0, 0, 0, 0.5);
        }

        /* Enhanced Text Readability - Clean System */
        
        /* Light Theme Text Improvements */
        :not([data-theme="dark"]) .text-gray-300,
        :not([data-theme="dark"]) .text-gray-400,
        :not([data-theme="dark"]) .text-gray-500 {
            color: var(--text-secondary) !important;
        }

        :not([data-theme="dark"]) .text-gray-600,
        :not([data-theme="dark"]) .text-gray-700 {
            color: var(--text-primary) !important;
        }

        /* Navigation and interactive elements */
        :not([data-theme="dark"]) nav a,
        :not([data-theme="dark"]) .sidebar a,
        :not([data-theme="dark"]) .nav-link {
            color: var(--text-primary) !important;
        }

        /* Dark Theme Text Improvements */
        [data-theme="dark"] .text-gray-300,
        [data-theme="dark"] .text-gray-400,
        [data-theme="dark"] .text-gray-500 {
            color: var(--text-secondary) !important;
        }

        [data-theme="dark"] .text-gray-600,
        [data-theme="dark"] .text-gray-700 {
            color: var(--text-primary) !important;
        }

        /* Navigation and interactive elements in dark mode */
        [data-theme="dark"] nav a,
        [data-theme="dark"] .nav-link,
        [data-theme="dark"] .sidebar a {
            color: var(--text-secondary) !important;
        }

        /* Headings in both themes */
        h1, h2, h3, h4, h5, h6 {
            color: var(--text-primary) !important;
        }

        /* Labels and table headers */
        label, th, thead {
            color: var(--text-primary) !important;
        }

        /* Enhanced DataTable Styling with Better Contrast */
        .datatable-wrapper .dataTables_length select,
        .datatable-wrapper .dataTables_filter input,
        .datatable-wrapper .dataTables_info,
        .datatable-wrapper .dataTables_paginate {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 12px !important;
            border: 1px solid var(--border-medium) !important;
            color: var(--text-primary) !important;
            transition: all 0.3s ease !important;
            padding: 8px 12px !important;
        }

        .datatable-wrapper .dataTables_wrapper {
            background: var(--bg-card) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 16px !important;
            border: 1px solid var(--border-light) !important;
        }

        .datatable-wrapper th,
        .datatable-wrapper td {
            border-bottom: 1px solid var(--border-light) !important;
            color: var(--text-primary) !important;
            transition: all 0.2s ease !important;
            padding: 12px 16px !important;
        }

        .datatable-wrapper th {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            font-weight: 600 !important;
            color: var(--text-primary) !important;
            border-bottom: 2px solid var(--border-medium) !important;
        }

        .datatable-wrapper tr:hover {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(10px) !important;
            transform: translateY(-1px) !important;
        }

        /* Enhanced Column Filters with Better Readability */
        .column-filter-input {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(10px) !important;
            border: 1px solid var(--border-light) !important;
            border-radius: 8px !important;
            font-size: 11px !important;
            padding: 6px 10px !important;
            transition: all 0.2s ease !important;
            margin-top: 4px !important;
            color: var(--text-primary) !important;
        }

        .column-filter-input::placeholder {
            color: var(--text-muted) !important;
            font-size: 10px !important;
        }

        .column-filter-input:focus {
            background: var(--bg-secondary) !important;
            border-color: var(--border-focus) !important;
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15) !important;
            outline: none !important;
        }

        /* DataTables inside Modals - Fix styling issues */
        .modal .datatable-wrapper .dataTables_length select,
        .modal .datatable-wrapper .dataTables_filter input,
        .modal .datatable-wrapper .dataTables_info,
        .modal .datatable-wrapper .dataTables_paginate {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 8px !important;
            border: 1px solid var(--border-medium) !important;
            color: var(--text-primary) !important;
            transition: all 0.3s ease !important;
            padding: 6px 10px !important;
            font-size: 0.875rem !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper {
            background: var(--bg-card) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 12px !important;
            border: 1px solid var(--border-light) !important;
            padding: 1rem !important;
        }

        .modal .datatable-wrapper th,
        .modal .datatable-wrapper td {
            border-bottom: 1px solid var(--border-light) !important;
            color: var(--text-primary) !important;
            transition: all 0.2s ease !important;
            padding: 10px 12px !important;
            font-size: 0.875rem !important;
        }

        .modal .datatable-wrapper th {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            font-weight: 600 !important;
            color: var(--text-primary) !important;
            border-bottom: 2px solid var(--border-medium) !important;
            font-size: 0.875rem !important;
        }

        .modal .datatable-wrapper tr:hover {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(10px) !important;
            transform: translateY(-1px) !important;
        }

        /* Modal DataTable pagination styling */
        .modal .datatable-wrapper .dataTables_paginate .paginate_button {
            background: var(--bg-glass) !important;
            border: 1px solid var(--border-medium) !important;
            border-radius: 6px !important;
            color: var(--text-primary) !important;
            margin: 0 2px !important;
            padding: 6px 10px !important;
            transition: all 0.2s ease !important;
            font-size: 0.875rem !important;
        }

        .modal .datatable-wrapper .dataTables_paginate .paginate_button:hover {
            background: var(--bg-secondary) !important;
            border-color: var(--border-focus) !important;
            transform: translateY(-1px) !important;
        }

        .modal .datatable-wrapper .dataTables_paginate .paginate_button.current {
            background: var(--primary-blue) !important;
            border-color: var(--primary-blue) !important;
            color: white !important;
        }

        .modal .datatable-wrapper .dataTables_paginate .paginate_button.disabled {
            opacity: 0.5 !important;
            cursor: not-allowed !important;
        }

        /* Modal DataTable controls layout */
        .modal .datatable-wrapper .dataTables_length,
        .modal .datatable-wrapper .dataTables_filter {
            margin-bottom: 1rem !important;
        }

        .modal .datatable-wrapper .dataTables_info {
            margin-top: 0.5rem !important;
            font-size: 0.875rem !important;
        }

        /* Ensure DataTables in modals without explicit wrapper also get styling */
        .modal table.dataTable {
            background: var(--bg-card) !important;
            border-radius: 12px !important;
            border: 1px solid var(--border-light) !important;
            overflow: hidden !important;
        }

        .modal table.dataTable thead th {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            font-weight: 600 !important;
            color: var(--text-primary) !important;
            border-bottom: 2px solid var(--border-medium) !important;
            padding: 12px 16px !important;
            font-size: 0.875rem !important;
        }

        .modal table.dataTable tbody td {
            border-bottom: 1px solid var(--border-light) !important;
            color: var(--text-primary) !important;
            padding: 10px 12px !important;
            font-size: 0.875rem !important;
        }

        .modal table.dataTable tbody tr:hover {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(10px) !important;
        }

        /* DataTables controls in modals without wrapper */
        .modal .dataTables_wrapper .dataTables_length select,
        .modal .dataTables_wrapper .dataTables_filter input {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 8px !important;
            border: 1px solid var(--border-medium) !important;
            color: var(--text-primary) !important;
            padding: 6px 10px !important;
            font-size: 0.875rem !important;
        }

        .modal .dataTables_wrapper .dataTables_info,
        .modal .dataTables_wrapper .dataTables_paginate {
            color: var(--text-primary) !important;
            font-size: 0.875rem !important;
        }

        .modal .dataTables_wrapper .dataTables_paginate .paginate_button {
            background: var(--bg-glass) !important;
            border: 1px solid var(--border-medium) !important;
            border-radius: 6px !important;
            color: var(--text-primary) !important;
            margin: 0 2px !important;
            padding: 6px 10px !important;
            transition: all 0.2s ease !important;
            font-size: 0.875rem !important;
        }

        .modal .dataTables_wrapper .dataTables_paginate .paginate_button:hover {
            background: var(--bg-secondary) !important;
            border-color: var(--border-focus) !important;
            transform: translateY(-1px) !important;
        }

        .modal .dataTables_wrapper .dataTables_paginate .paginate_button.current {
            background: var(--primary-blue) !important;
            border-color: var(--primary-blue) !important;
            color: white !important;
        }

        .modal .dataTables_wrapper .dataTables_paginate .paginate_button.disabled {
            opacity: 0.5 !important;
            cursor: not-allowed !important;
        }

        /* Modal size variations */
        .modal-xl {
            max-width: 95vw !important;
            width: 95vw !important;
            max-height: 90vh !important;
        }

        .modal-xl .modal-content {
            max-height: 90vh !important;
            overflow-y: auto !important;
        }

        .modal-xl .modal-body {
            max-height: calc(90vh - 120px) !important;
            overflow-y: auto !important;
            padding: 1.5rem !important;
        }

        /* Ensure proper spacing in modal DataTables */
        .modal .datatable-wrapper {
            margin: 0 !important;
            padding: 0 !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper {
            margin: 0 !important;
            padding: 1rem !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper .dataTables_length,
        .modal .datatable-wrapper .dataTables_wrapper .dataTables_filter {
            float: none !important;
            display: inline-block !important;
            margin: 0.5rem 1rem 0.5rem 0 !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper .dataTables_filter {
            float: right !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper .dataTables_info {
            float: none !important;
            clear: both !important;
            text-align: center !important;
            margin: 0.5rem 0 !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper .dataTables_paginate {
            float: none !important;
            text-align: center !important;
            margin: 0.5rem 0 !important;
        }

        .modal .datatable-wrapper .dataTables_wrapper .dataTables_paginate .paginate_button {
            display: inline-block !important;
        }

        /* Responsive adjustments for modal DataTables */
        @media (max-width: 768px) {
            .modal-xl {
                max-width: 98vw !important;
                width: 98vw !important;
                margin: 1vh auto !important;
            }

            .modal .datatable-wrapper .dataTables_wrapper .dataTables_length,
            .modal .datatable-wrapper .dataTables_wrapper .dataTables_filter {
                display: block !important;
                width: 100% !important;
                margin: 0.25rem 0 !important;
                text-align: left !important;
            }

            .modal .datatable-wrapper .dataTables_wrapper .dataTables_filter {
                text-align: right !important;
            }

            .modal .datatable-wrapper th,
            .modal .datatable-wrapper td {
                padding: 6px 8px !important;
                font-size: 0.8rem !important;
            }
        }

        /* Modern Search Builder Styling */
        .dtsb-searchBuilder {
            background: rgba(255, 255, 255, 0.9);
            backdrop-filter: blur(20px);
            border: 1px solid rgba(255, 255, 255, 0.2);
            border-radius: 16px;
            box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.1);
            padding: 0;
            margin: 12px 0;
            position: relative;
            overflow: hidden;
        }

        .dark .dtsb-searchBuilder {
            background: rgba(17, 24, 39, 0.9);
            border-color: rgba(255, 255, 255, 0.1);
            box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3);
        }

        .dtsb-searchBuilder::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 2px;
            background: linear-gradient(90deg, transparent, var(--primary-blue), transparent);
            animation: lightSweep 2s ease-in-out infinite;
        }

        @keyframes lightSweep {
            0%, 100% { transform: translateX(-100%); }
            50% { transform: translateX(100%); }
        }

        /* Hide Title Row for Minimal Design */
        .dtsb-titleRow {
            display: none;
        }

        .dark .dtsb-titleRow {
            background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
            border-bottom-color: rgba(255, 255, 255, 0.1);
        }

        .dtsb-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 0;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .dtsb-title::before {
            content: '';
            width: 6px;
            height: 6px;
            background: linear-gradient(135deg, var(--primary-blue), var(--primary-purple));
            border-radius: 50%;
            animation: pulseGlow 2s ease-in-out infinite;
        }

        @keyframes pulseGlow {
            0%, 100% { opacity: 0.7; box-shadow: 0 0 0 0 rgba(59, 130, 246, 0.4); }
            50% { opacity: 1; box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2); }
        }

        /* Main Container */
        .dtsb-group {
            padding: 16px;
            background: rgba(255, 255, 255, 0.5);
            backdrop-filter: blur(10px);
            border-radius: 0 0 16px 16px;
        }

        .dark .dtsb-group {
            background: rgba(17, 24, 39, 0.5);
        }

        /* Main Add Button - Icon Only */
        .dtsb-group > .dtsb-add {
            width: auto; /* Let it be compact */
            min-width: 48px;
            max-width: 48px;
            height: 48px;
            padding: 0;
            margin: 0;
            background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(139, 92, 246, 0.1) 100%);
            border: 1px solid rgba(59, 130, 246, 0.2);
            color: var(--primary-blue);
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.3s ease;
            box-shadow: none;
            font-size: 0; /* Hide text */
            position: relative;
        }

        .dtsb-group > .dtsb-add:hover {
            background: linear-gradient(135deg, rgba(59, 130, 246, 0.2) 0%, rgba(139, 92, 246, 0.2) 100%);
            border-color: rgba(59, 130, 246, 0.4);
            transform: translateY(-1px);
            box-shadow: 0 4px 20px 0 rgba(59, 130, 246, 0.2);
        }

        /* Search/Lens Icon */
        .dtsb-group > .dtsb-add::before {
            content: '';
            background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"></circle><path d="m21 21-4.35-4.35"></path></svg>');
            background-size: 20px 20px;
            background-repeat: no-repeat;
            background-position: center;
            width: 24px;
            height: 24px;
            opacity: 0.7;
            transition: opacity 0.3s ease;
        }

        .dtsb-group > .dtsb-add:hover::before {
            opacity: 1;
        }

        .dark .dtsb-group > .dtsb-add {
            color: var(--primary-blue);
        }

        /* Condition Builder - Beautiful Cards */
        .dtsb-condition {
            background: linear-gradient(135deg, rgba(248, 250, 252, 0.8) 0%, rgba(241, 245, 249, 0.6) 100%);
            backdrop-filter: blur(15px);
            border: 1px solid rgba(226, 232, 240, 0.3);
            border-radius: 12px;
            padding: 16px;
            margin: 12px 0;
            color: var(--text-primary);
            box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.1);
            position: relative;
            transition: all 0.3s ease;
        }

        .dtsb-condition:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 24px 0 rgba(0, 0, 0, 0.15);
        }

        .dark .dtsb-condition {
            background: linear-gradient(135deg, rgba(31, 41, 55, 0.8) 0%, rgba(17, 24, 39, 0.6) 100%);
            border-color: rgba(75, 85, 99, 0.3);
            box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.3);
        }

        .dark .dtsb-condition:hover {
            box-shadow: 0 8px 24px 0 rgba(0, 0, 0, 0.4);
        }

        /* Elegant Form Controls */
        .dtsb-criteria select,
        .dtsb-criteria input[type="text"],
        .dtsb-criteria input[type="number"],
        .dtsb-criteria input[type="date"] {
            background: rgba(255, 255, 255, 0.9);
            border: 1px solid rgba(226, 232, 240, 0.6);
            border-radius: 8px;
            padding: 8px 12px;
            font-size: 13px;
            color: var(--text-primary);
            transition: all 0.2s ease;
            backdrop-filter: blur(10px);
        }

        .dtsb-criteria select:focus,
        .dtsb-criteria input:focus {
            border-color: var(--primary-blue);
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
            background: rgba(255, 255, 255, 0.9);
            outline: none;
        }

        .dark .dtsb-criteria select,
        .dark .dtsb-criteria input[type="text"],
        .dark .dtsb-criteria input[type="number"],
        .dark .dtsb-criteria input[type="date"] {
            background: rgba(17, 24, 39, 0.9);
            border-color: rgba(75, 85, 99, 0.6);
            color: var(--text-primary);
        }

        .dark .dtsb-criteria select:focus,
        .dark .dtsb-criteria input:focus {
            background: rgba(17, 24, 39, 0.9);
            border-color: var(--primary-blue);
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
        }

        /* Modern Button Styles */
        .dtsb-button {
            background: var(--primary-gradient);
            color: white;
            border: none;
            border-radius: 8px;
            padding: 8px 16px;
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            cursor: pointer;
            transition: all 0.3s ease;
            box-shadow: 0 2px 8px 0 rgba(99, 102, 241, 0.3);
            display: inline-flex;
            align-items: center;
            gap: 6px;
        }

        .dtsb-button:hover {
            transform: translateY(-1px);
            box-shadow: 0 4px 16px 0 rgba(99, 102, 241, 0.4);
        }

        .dtsb-button:active {
            transform: translateY(0);
        }

        /* Specialized Button Types */
        .dtsb-button.dtsb-add {
            background: linear-gradient(135deg, #10b981 0%, #34d399 100%);
            box-shadow: 0 2px 8px 0 rgba(16, 185, 129, 0.3);
        }

        .dtsb-button.dtsb-add:hover {
            box-shadow: 0 4px 16px 0 rgba(16, 185, 129, 0.4);
        }

        .dtsb-button.dtsb-clearAll {
            background: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);
            box-shadow: 0 2px 8px 0 rgba(220, 38, 38, 0.3);
        }

        .dtsb-button.dtsb-clearAll:hover {
            box-shadow: 0 4px 16px 0 rgba(220, 38, 38, 0.4);
        }

        .dtsb-button.dtsb-delete {
            background: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);
            box-shadow: 0 2px 8px 0 rgba(220, 38, 38, 0.3);
            padding: 6px 12px;
        }

        .dtsb-button.dtsb-delete:hover {
            box-shadow: 0 4px 16px 0 rgba(220, 38, 38, 0.4);
        }

        /* Logic Connectors */
        .dtsb-logic {
            color: var(--text-secondary);
            font-weight: 600;
            font-size: 12px;
            text-transform: uppercase;
            letter-spacing: 1px;
            margin: 12px 0;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .dtsb-logic::before,
        .dtsb-logic::after {
            content: '';
            flex: 1;
            height: 1px;
            background: linear-gradient(90deg, transparent, rgba(59, 130, 246, 0.3), transparent);
        }

        /* Nested Groups Styling */
        .dtsb-group .dtsb-group {
            background: rgba(255, 255, 255, 0.4);
            border-left: 3px solid var(--primary-blue);
            margin-left: 16px;
            border-radius: 8px;
        }

        .dark .dtsb-group .dtsb-group {
            background: rgba(17, 24, 39, 0.4);
        }

        /* Responsive Adjustments */
        @media (max-width: 768px) {
            .dtsb-searchBuilder {
                margin: 8px 0;
                padding: 0;
            }

            .dtsb-titleRow {
                padding: 10px 12px;
            }

            .dtsb-group {
                padding: 12px;
            }

            .dtsb-group > .dtsb-add {
                padding: 10px 20px;
                font-size: 13px;
            }

            .dtsb-condition {
                padding: 12px;
                margin: 8px 0;
            }
        }

        /* Loading Animation */
        .dtsb-searchBuilder.loading {
            animation: searchBuilderPulse 1.5s ease-in-out infinite;
        }

        @keyframes searchBuilderPulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.8; }
        }

        /* Modal styles with glassmorphism */
        .modal {
            display: none;
            animation: modalFadeIn 0.3s ease-out;
        }

        .modal.show {
            display: flex;
        }

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

        /* Modal backdrops with blur */
        .modal-backdrop {
            background: rgba(0, 0, 0, 0.6);
            backdrop-filter: blur(8px);
            animation: backdropFadeIn 0.3s ease-out;
        }

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

        /* Enhanced Modal Input Styling */
        .modal input,
        .modal select,
        .modal textarea {
            transition: all 0.2s ease-in-out;
        }

        /* Light mode modal inputs - ensure proper visibility */
        .modal input:not(.dark):not([class*="dark"]),
        .modal select:not(.dark):not([class*="dark"]),
        .modal textarea:not(.dark):not([class*="dark"]) {
            background-color: #ffffff !important;
            color: #111827 !important;
            border-color: #d1d5db !important;
        }

        .modal input:not(.dark):not([class*="dark"])::placeholder,
        .modal select:not(.dark):not([class*="dark"])::placeholder,
        .modal textarea:not(.dark):not([class*="dark"])::placeholder {
            color: #9ca3af !important;
        }

        .modal input:not(.dark):not([class*="dark"]):focus,
        .modal select:not(.dark):not([class*="dark"]):focus,
        .modal textarea:not(.dark):not([class*="dark"]):focus {
            background-color: #ffffff !important;
            color: #111827 !important;
            border-color: #3b82f6 !important;
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
        }

        /* Dark mode modal inputs */
        .dark .modal input,
        .dark .modal select,
        .dark .modal textarea {
            background-color: #374151 !important;
            color: #f9fafb !important;
            border-color: #4b5563 !important;
        }

        .dark .modal input::placeholder,
        .dark .modal select::placeholder,
        .dark .modal textarea::placeholder {
            color: #9ca3af !important;
        }

        .dark .modal input:focus,
        .dark .modal select:focus,
        .dark .modal textarea:focus {
            background-color: #374151 !important;
            color: #f9fafb !important;
            border-color: #60a5fa !important;
            box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.2) !important;
        }

        /* Modal input icons visibility fix */
        .modal .absolute .inset-y-0 .left-0 .pointer-events-none i,
        .modal [data-feather] {
            transition: color 0.2s ease-in-out;
        }

        /* Light mode icon colors */
        .modal:not(.dark) .absolute.inset-y-0.left-0.pointer-events-none i,
        .modal:not(.dark) [data-feather]:not(.text-white) {
            color: #6b7280 !important;
        }

        .modal:not(.dark) .absolute.inset-y-0.left-0.pointer-events-none i:hover,
        .modal:not(.dark) [data-feather]:not(.text-white):hover {
            color: #4b5563 !important;
        }

        /* Dark mode icon colors */
        .dark .modal .absolute.inset-y-0.left-0.pointer-events-none i,
        .dark .modal [data-feather]:not(.text-white) {
            color: #9ca3af !important;
        }

        .dark .modal .absolute.inset-y-0.left-0.pointer-events-none i:hover,
        .dark .modal [data-feather]:not(.text-white):hover {
            color: #d1d5db !important;
        }

        /* Modern loading spinner with pulse */
        .spinner {
            border: 4px solid transparent;
            border-top: 4px solid transparent;
            border-right: 4px solid var(--primary-gradient);
            border-radius: 50%;
            width: 32px;
            height: 32px;
            animation: spin 1s linear infinite;
            position: relative;
        }

        .spinner::before {
            content: '';
            position: absolute;
            top: -4px;
            left: -4px;
            right: -4px;
            bottom: -4px;
            border: 4px solid rgba(59, 130, 246, 0.2);
            border-radius: 50%;
            animation: pulse 2s infinite;
        }

        /* Override spinner for login button */
        #login-btn .spinner {
            width: 20px !important;
            height: 20px !important;
            border-width: 2px !important;
            border-top-width: 2px !important;
            border-right-width: 2px !important;
            flex-shrink: 0;
        }

        #login-btn .spinner::before {
            top: -2px !important;
            left: -2px !important;
            right: -2px !important;
            bottom: -2px !important;
            border-width: 2px !important;
        }

        /* Login button specific styling */
        #login-btn {
            min-width: 200px;
            white-space: nowrap;
        }

        #login-btn span {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            min-width: 0;
        }

        /* Responsive login button text */
        @media (max-width: 640px) {
            #login-btn {
                min-width: 160px;
                padding: 12px 16px;
            }
        }

        @keyframes spin {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }

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

        /* Enhanced Modern Cards with Better Contrast */
        .modern-card {
            border-radius: 20px !important;
            background: var(--bg-secondary) !important;
            box-shadow: var(--shadow-medium) !important;
            border: 1px solid var(--border-light) !important;
            transition: all 0.3s cubic-bezier(0.4, 0, 0, 0.2, 1) !important;
            color: var(--text-primary) !important;
            position: relative !important;
        }

        .modern-card:hover {
            transform: translateY(-2px) scale(1.01) !important;
            box-shadow: var(--shadow-dark), 0 0 0 1px var(--border-focus) !important;
        }

        /* Fix recent activities text visibility - override modern-card color rule */
        .modern-card #recent-activity .font-medium {
            color: #111827 !important; /* text-gray-900 */
        }
        
        [data-theme="dark"] .modern-card #recent-activity .font-medium {
            color: #ffffff !important; /* text-white */
        }
        
        .modern-card #recent-activity .text-sm {
            color: #4b5563 !important; /* text-gray-600 */
        }
        
        [data-theme="dark"] .modern-card #recent-activity .text-sm {
            color: #d1d5db !important; /* text-gray-300 */
        }
        
        .modern-card #recent-activity .text-gray-500 {
            color: #6b7280 !important; /* text-gray-500 */
        }
        
        [data-theme="dark"] .modern-card #recent-activity .text-gray-500 {
            color: #9ca3af !important; /* text-gray-400 */
        }
        
        /* Fix hover state - make title dark on hover */
        .modern-card #recent-activity div:hover .font-medium {
            color: #111827 !important; /* text-gray-900 - dark on hover */
        }
        
        [data-theme="dark"] .modern-card #recent-activity div:hover .font-medium {
            color: #374151 !important; /* text-gray-700 - dark on hover */
        }
        
        .modern-card #recent-activity div:hover .text-sm {
            color: #4b5563 !important; /* text-gray-600 */
        }
        
        [data-theme="dark"] .modern-card #recent-activity div:hover .text-sm {
            color: #d1d5db !important; /* text-gray-300 */
        }
        
        .modern-card #recent-activity div:hover .text-gray-500 {
            color: #6b7280 !important; /* text-gray-500 */
        }
        
        [data-theme="dark"] .modern-card #recent-activity div:hover .text-gray-500 {
            color: #9ca3af !important; /* text-gray-400 */
        }

        /* Sidebar specific styling */
        #main-app .w-64.modern-card {
            background: var(--bg-sidebar) !important;
            backdrop-filter: blur(12px) !important;
            border: 1px solid var(--border-light) !important;
        }

        /* Enhanced Glassmorphism Cards with Better Contrast */
        .glass-card {
            border-radius: 16px !important;
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            border: 1px solid var(--border-light) !important;
            box-shadow: var(--shadow-light) !important;
            color: var(--text-primary) !important;
        }

        /* Enhanced status badges with gradients */
        .status-badge {
            padding: 4px 12px;
            border-radius: 12px;
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.05em;
            backdrop-filter: blur(10px);
            transition: all 0.2s ease;
        }

        .status-attivo, .status-attiva {
            background: var(--success-gradient);
            color: white;
            box-shadow: 0 4px 15px 0 rgba(79, 172, 254, 0.4);
        }

        .status-sospeso, .status-sospesa {
            background: var(--warning-gradient);
            color: white;
            box-shadow: 0 4px 15px 0 rgba(250, 112, 154, 0.4);
        }

        .status-bannato, .status-bannata {
            background: var(--danger-gradient);
            color: white;
            box-shadow: 0 4px 15px 0 rgba(255, 154, 158, 0.4);
        }

        .status-in-revisione {
            background: linear-gradient(135deg, #a855f7 0%, #ec4899 100%);
            color: white;
            box-shadow: 0 4px 15px 0 rgba(168, 85, 247, 0.4);
        }

        .status-disattiva {
            background: rgba(156, 163, 175, 0.8);
            backdrop-filter: blur(10px);
            color: white;
            box-shadow: 0 4px 15px 0 rgba(156, 163, 175, 0.4);
        }

        .dark .status-disattiva {
            background: rgba(75, 85, 99, 0.8);
            box-shadow: 0 4px 15px 0 rgba(75, 85, 99, 0.4);
        }

        /* Enhanced Custom Scrollbar with Better Visibility */
        .custom-scrollbar::-webkit-scrollbar {
            width: 10px !important;
        }

        .custom-scrollbar::-webkit-scrollbar-track {
            background: var(--bg-glass) !important;
            border-radius: 8px !important;
            backdrop-filter: blur(10px) !important;
            border: 1px solid var(--border-light) !important;
        }

        .custom-scrollbar::-webkit-scrollbar-thumb {
            background: var(--primary-gradient) !important;
            border-radius: 8px !important;
            transition: all 0.2s ease !important;
            border: 1px solid var(--border-light) !important;
        }

        .custom-scrollbar::-webkit-scrollbar-thumb:hover {
            background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
            transform: scale(1.1) !important;
        }

        /* Enhanced Form Inputs with Improved Contrast */
        .input-modern {
            background: var(--bg-glass) !important;
            backdrop-filter: blur(20px) !important;
            border: 1px solid var(--border-medium) !important;
            border-radius: 12px !important;
            transition: all 0.3s cubic-bezier(0.4, 0, 0, 0.2, 1) !important;
            box-shadow: var(--shadow-light) !important;
            color: var(--text-primary) !important;
        }

        .input-modern:focus {
            background: var(--bg-secondary) !important;
            border-color: var(--border-focus) !important;
            box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15), var(--shadow-medium) !important;
            transform: translateY(-1px) !important;
            outline: none !important;
        }

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

        /* Enhanced buttons with gradients */
        .btn-modern {
            background: var(--primary-gradient);
            border-radius: 12px;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            box-shadow: 0 4px 15px 0 rgba(102, 126, 234, 0.4);
            position: relative;
            overflow: hidden;
        }

        .btn-modern::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
            transition: left 0.5s;
        }

        .btn-modern:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 25px 0 rgba(102, 126, 234, 0.6);
        }

        .btn-modern:hover::before {
            left: 100%;
        }

        /* Enhanced Skeleton Loader with Better Contrast */
        .skeleton {
            background: linear-gradient(90deg, var(--border-light) 25%, var(--border-medium) 50%, var(--border-light) 75%) !important;
            background-size: 200% 100% !important;
            animation: loading 1.5s infinite !important;
            border-radius: 4px !important;
        }

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

        /* Simplified Dark Mode Styles */
        .dark {
            background: var(--bg-primary) !important;
            color: var(--text-primary) !important;
        }

        /* DataTable Responsive Breakpoints */
        @media (max-width: 640px) {
            /* Mobile - Hide columns with min-tablet and min-desktop */
            .min-tablet, .min-desktop {
                display: none !important;
            }
            
            /* Ensure important columns are visible */
            .all {
                display: table-cell !important;
            }
            
            /* Compact mobile styling */
            .datatable-wrapper .dataTables_wrapper {
                font-size: 0.875rem;
            }
            
            .datatable-wrapper th,
            .datatable-wrapper td {
                padding: 8px !important;
            }
            
            /* Action buttons on mobile */
            .datatable-wrapper .btn-action {
                padding: 4px 8px;
                font-size: 0.75rem;
            }
            
            /* Enhanced Mobile DataTable Experience */
            /* Compact table headers */
            .datatable-wrapper thead th {
                font-size: 0.75rem !important;
                padding: 6px 4px !important;
            }
            
            /* Compact table cells */
            .datatable-wrapper tbody td {
                font-size: 0.8125rem !important;
                padding: 6px 4px !important;
                line-height: 1.25 !important;
            }
            
            /* Hide unnecessary elements on mobile */
            .datatable-wrapper .dataTables_length,
            .datatable-wrapper .dataTables_filter {
                margin-bottom: 0.5rem !important;
                font-size: 0.875rem !important;
            }
            
            /* Compact pagination */
            .datatable-wrapper .dataTables_paginate {
                margin-top: 0.5rem !important;
            }
            
            .datatable-wrapper .dataTables_paginate .paginate_button {
                padding: 4px 8px !important;
                font-size: 0.75rem !important;
            }
            
            /* Better action buttons on mobile */
            .datatable-wrapper .action-buttons {
                display: flex;
                gap: 2px;
                justify-content: center;
            }
            
            .datatable-wrapper .action-buttons button {
                padding: 4px 6px !important;
                font-size: 0.7rem !important;
                min-width: auto !important;
            }
        }

        @media (min-width: 641px) and (max-width: 1024px) {
            /* Tablet - Hide columns with min-desktop */
            .min-desktop {
                display: none !important;
            }
            
            /* Show tablet columns */
            .min-tablet, .all {
                display: table-cell !important;
            }
        }

        @media (min-width: 1025px) {
            /* Desktop - Show all columns */
            .min-desktop, .min-tablet, .all {
                display: table-cell !important;
            }
        }

        /* Responsive improvements */
        @media (max-width: 768px) {
            .sidebar-mobile {
                position: fixed;
                top: 0;
                left: 0;
                width: 280px;
                height: 100vh;
                z-index: 9999;
                transform: translateX(-100%);
                transition: transform 0.3s ease-in-out;
                box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
                margin: 0 !important; /* FIX: Rimuove m-6 che causa spazio nero */
            }
            
            /* Rimuove tutti i margini dal sidebar e dai suoi elementi figli in mobile */
            .sidebar-mobile,
            .sidebar-mobile > [class*="m-"] {
                margin: 0 !important;
            }
            
            /* Assicura che il sidebar mobile non abbia sticky positioning */
            .sidebar-mobile.sticky {
                position: fixed !important;
                top: 0 !important;
            }

            .sidebar-mobile.show {
                transform: translateX(0);
            }

            .sidebar-overlay {
                position: fixed;
                top: 0;
                left: 0;
                width: 100vw;
                height: 100vh;
                background: rgba(0, 0, 0, 0.5);
                z-index: 9998;
                opacity: 0;
                visibility: hidden;
                transition: opacity 0.3s ease, visibility 0.3s ease;
            }

            .sidebar-overlay.show {
                opacity: 1;
                visibility: visible;
            }

            /* Menu nascosto: contenuto a tutta larghezza */
            .sidebar-mobile:not(.show) ~ .flex-1.main-content-area {
                margin-left: 0;
                width: 100%;
            }
            
            /* Menu visibile: contenuto sempre a tutta larghezza (menu è fixed sopra) */
            .sidebar-mobile.show ~ .flex-1.main-content-area {
                margin-left: 0;
                width: 100%;
            }

            /* Assicura che il contenuto principale occupi sempre tutto lo spazio in mobile */
            @media (max-width: 768px) {
                .main-content-area {
                    margin-left: 0 !important;
                    width: 100% !important;
                    min-height: 100vh;
                }
                
                /* Rimuove margini dall'header in mobile */
                .main-content-area header {
                    margin-left: 0 !important;
                    margin-right: 1rem !important;
                }
            }

            /* Transizioni fluide per il contenuto principale */
            .main-content-area {
                transition: margin-left 0.3s ease-in-out, width 0.3s ease-in-out;
            }
        }

        /* Enhanced Toast Notifications */
        .toast {
            background: var(--bg-card) !important;
            backdrop-filter: blur(20px) !important;
            border-radius: 12px !important;
            border: 1px solid var(--border-medium) !important;
            box-shadow: var(--shadow-dark) !important;
            animation: toastSlideIn 0.3s ease-out !important;
            color: var(--text-primary) !important;
        }

        @keyframes toastSlideIn {
            from {
                transform: translateX(100%);
                opacity: 0;
            }
            to {
                transform: translateX(0);
                opacity: 1;
            }
        }

        @keyframes shimmer {
            0% { transform: translateX(-100%); }
            100% { transform: translateX(100%); }
        }

        /* Animate spin slow */
        .animate-spin-slow {
            animation: spin 3s linear infinite;
        }

        /* Custom animations for theme toggle */
        @keyframes themeRotate {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }

        #theme-toggle:hover .animate-spin-slow {
            animation: themeRotate 0.6s ease-in-out;
        }

        /* Dropdown fade in animation */
        .dropdown-enter {
            animation: dropdownFadeIn 0.2s ease-out forwards;
        }

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

        /* Enhanced Quick Action Buttons */
        .quick-action-btn {
            background: var(--bg-secondary) !important;
            border: 2px solid var(--border-medium) !important;
            color: var(--text-primary) !important;
            transition: all 0.3s ease !important;
            border-radius: 8px !important;
        }

        .quick-action-btn:hover {
            background: var(--bg-glass) !important;
            border-color: var(--border-focus) !important;
            box-shadow: var(--shadow-medium) !important;
            transform: translateY(-1px) !important;
        }

        .quick-action-btn span,
        .quick-action-btn i {
            color: inherit !important;
        }

        /* Sidebar collapse/expand animations */
        #main-app .w-64.modern-card {
            transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1), margin 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        }

        #main-app .w-64.modern-card.collapsed {
            width: 6.0rem; /* 104px collapsed for better clickability */
            overflow-x: hidden; /* Hide horizontal scrollbar when collapsed */
        }

        /* Rimuovo regola desktop che confligge con mobile */

        /* Hide text in collapsed state, keep icons and toggle button visible */
        #main-app .w-64.modern-card.collapsed .font-medium,
        #main-app .w-64.modern-card.collapsed nav span {
            display: none;
            transition: opacity 0.3s ease, visibility 0.3s ease;
        }

        /* Hide logo text in collapsed state but keep logo icon visible */
        #main-app .w-64.modern-card.collapsed h1,
        #main-app .w-64.modern-card.collapsed p {
            display: none;
            transition: opacity 0.3s ease, visibility 0.3s ease;
        }

        /* Center logo icon in collapsed state */
        #main-app .w-64.modern-card.collapsed .p-6 .flex.items-center .flex.items-center {
            justify-content: center;
        }

        #main-app .w-64.modern-card:not(.collapsed) .font-medium,
        #main-app .w-64.modern-card:not(.collapsed) nav span {
            display: inline;
            transition: opacity 0.3s ease;
        }

        #main-app .w-64.modern-card:not(.collapsed) h1,
        #main-app .w-64.modern-card:not(.collapsed) p {
            opacity: 1;
            visibility: visible;
            transition: opacity 0.3s ease, visibility 0.3s ease;
        }

        /* Always keep sidebar toggle button visible */
        #sidebar-toggle {
            opacity: 1 !important;
            visibility: visible !important;
        }



/* Status badges keep their colors - remove global override to allow proper text colors */
.status-badge {
    /* color: white !important; - REMOVED to fix readability issues */
}

/* Simplified Page-Specific Table Overrides */
.page-linee-credito .datatable-wrapper tbody tr {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-light) !important;
}

.page-linee-credito .datatable-wrapper tbody tr:nth-child(even) {
    background: var(--bg-glass) !important;
}

.page-linee-credito .datatable-wrapper tbody tr a {
    color: var(--primary-blue) !important;
}

.page-linee-credito .datatable-wrapper tbody tr .status-badge {
    color: white !important;
}

/* Account Table in Modal - Enhanced Light & Dark Theme Support */
#account-table-container table {
    background: var(--bg-secondary) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid var(--border-light) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

/* Light theme specific table styling */
:not([data-theme="dark"]) #account-table-container table {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
}

/* Dark theme specific table styling */
[data-theme="dark"] #account-table-container table {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

#account-table-container thead {
    background: var(--bg-glass) !important;
    backdrop-filter: blur(20px) !important;
}

#account-table-container th {
    background: transparent !important;
    color: var(--text-primary) !important;
    font-weight: 600 !important;
    border-bottom: 2px solid var(--border-medium) !important;
    padding: 12px 16px !important;
}

#account-table-container td {
    background: transparent !important;
    color: var(--text-primary) !important;
    border-bottom: 1px solid var(--border-light) !important;
    transition: all 0.2s ease !important;
    padding: 16px !important;
}

/* Specific fix for Nome Account column - First column */
#account-table-container td:first-child,
#account-table-container .account-nome-col {
    font-weight: 600 !important;
}

/* Light theme specific for Nome Account */
:not([data-theme="dark"]) #account-table-container td:first-child {
    color: #0f172a !important;
    font-weight: 600 !important;
}

/* Dark theme specific for Nome Account */
[data-theme="dark"] #account-table-container td:first-child,
[data-theme="dark"] #account-table-container .account-nome-col {
    font-weight: 600 !important;
    color: #ffffff0d !important;
}

/* Light theme specific for Nome Account */
:not([data-theme="dark"]) #account-table-container td:first-child,
:not([data-theme="dark"]) #account-table-container .account-nome-col {
    color: #ffffffbd !important;
    font-weight: 600 !important;
}

#account-table-container tbody tr:hover {
    background: var(--bg-glass) !important;
    backdrop-filter: blur(10px) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

/* Light theme specific hover effects */
:not([data-theme="dark"]) #account-table-container tbody tr:hover {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08) !important;
}

/* Dark theme specific hover effects */
[data-theme="dark"] #account-table-container tbody tr:hover {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
}

#account-table-container tbody tr:hover td {
    background: transparent !important;
}

/* Enhanced button contrast for both themes */
#account-table-container button {
    transition: all 0.2s ease !important;
    border-radius: 6px !important;
}

#account-table-container button:hover {
    transform: scale(1.05) !important;
    background-color: var(--bg-glass) !important;
}

/* Light theme specific hover */
:not([data-theme="dark"]) #account-table-container button:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

/* Dark theme specific hover */
[data-theme="dark"] #account-table-container button:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
}

/* Status badges in account table - Enhanced for both themes */
#account-table-container .status-badge {
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    padding: 0.25rem 0.75rem !important;
    border-radius: 9999px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.025em !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

/* Dark theme status badge enhancements */
[data-theme="dark"] #account-table-container .status-badge {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Additional contrast fixes for all table cells */
#account-table-container td:nth-child(2),
#account-table-container td:nth-child(3),
#account-table-container td:nth-child(4) {
    /* Use default theme variables instead of forcing color */
}

/* Light theme specific for secondary columns */
:not([data-theme="dark"]) #account-table-container td:nth-child(2),
:not([data-theme="dark"]) #account-table-container td:nth-child(3),
:not([data-theme="dark"]) #account-table-container td:nth-child(4) {
    color: #374151 !important;
}

/* Dark theme specific for secondary columns */
[data-theme="dark"] #account-table-container td:nth-child(2),
[data-theme="dark"] #account-table-container td:nth-child(3),
[data-theme="dark"] #account-table-container td:nth-child(4) {
    /* No custom color or text-shadow - use default theme variables */
}

/* Light theme specific for secondary columns */
:not([data-theme="dark"]) #account-table-container td:nth-child(2),
:not([data-theme="dark"]) #account-table-container td:nth-child(3),
:not([data-theme="dark"]) #account-table-container td:nth-child(4) {
    color: #374151 !important;
}



/* Enhanced Footer Styling */
.footer {
    background: var(--bg-secondary) !important;
    color: var(--text-secondary) !important;
    text-align: center !important;
    padding: 1rem !important;
    border-top: 1px solid var(--border-light) !important;
    position: relative !important;
    z-index: 10 !important;
}

.footer p {
    margin: 0 !important;
    font-size: 0.875rem !important;
    font-weight: 400 !important;
}

.footer-heart-icon {
    color: var(--danger-red) !important;
    display: inline-block !important;
    margin: 0 2px !important;
}

/* Tag Management Styles - Enhanced Visibility */
#new-tag-name {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: 2px solid var(--border-light) !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    transition: all 0.2s ease !important;
}

#new-tag-name:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
    outline: none !important;
}

#new-tag-name::placeholder {
    color: var(--text-muted) !important;
    opacity: 1 !important;
}

#new-tag-color {
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    cursor: pointer !important;
    border-radius: 0.5rem !important;
    transition: all 0.2s ease !important;
}

#new-tag-color:hover {
    transform: scale(1.05) !important;
    border-color: var(--border-focus) !important;
}

#create-tag-btn {
    opacity: 1 !important;
    visibility: visible !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 100px !important;
    transition: all 0.2s ease !important;
}

#create-tag-btn:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Dark mode specific fixes for tag inputs */
[data-theme="dark"] #new-tag-name {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-medium) !important;
}

[data-theme="dark"] #new-tag-name:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.2) !important;
}

/* Tag selection dropdown improvements */
#contabilita-tag-select {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border: 2px solid var(--border-light) !important;
    min-height: 120px !important;
}

#contabilita-tag-select:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1) !important;
    outline: none !important;
}

#contabilita-tag-select option {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    padding: 8px 12px !important;
}

/* Selected tags container */
#selected-tags {
    background-color: var(--bg-primary) !important;
    border: 2px solid var(--border-light) !important;
    min-height: 50px !important;
    padding: 12px !important;
}

/* Tag pills styling */
.tag-remove-btn {
    opacity: 0.8 !important;
    transition: opacity 0.2s ease !important;
}

.tag-remove-btn:hover {
    opacity: 1 !important;
}
