@import url('open.iconic/font/css/open-iconic-bootstrap.min.css');

/* ===== CSS Variables (Theme) ===== */
:root {
    /* Colors */
    --color-primary: #2563eb;
    --color-primary-dark: #1d4ed8;
    --color-primary-darker: #1e40af;
    --color-primary-light: #60a5fa;
    --color-primary-lighter: #dbeafe;

    --color-accent: #ef4444;
    /* Red Accent */
    --color-accent-hover: #dc2626;

    --color-secondary: #4b5563;
    --color-text: #050505;
    --color-text-light: #4b5563;
    --color-bg-light: #f9fafb;
    --color-bg-lighter: #ffffff;
    --color-border: rgba(37, 99, 235, 0.15);
    
    /* Layout Variables */
    --color-bg-layout: #eef2f6;
    --color-bg-card: #ffffff;
    --color-surface: #f1f5f9;
    --color-nav-hover: rgba(0, 0, 0, 0.05);
    --color-border-subtle: rgba(0, 0, 0, 0.05);
    --color-text-nav: #334155;
    --color-text-nav-hover: #0f172a;

    /* Status Colors */
    --color-success: #047857;
    --color-warning: #d97706;
    --color-error: #dc2626;
    --color-info: #1d4ed8;

    /* Spacing */
    --spacing-xs: 0.375rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;

    /* Border Radius */
    --radius-sm: 6px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 20px;

    /* Shadows */
    --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 12px rgba(37, 99, 235, 0.1);
    --shadow-lg: 0 8px 24px rgba(37, 99, 235, 0.12);
    --shadow-xl: 0 12px 32px rgba(37, 99, 235, 0.15);

    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 0.5s ease;

    /* Typography - Responsive sizes using clamp */
    /* clamp(min, preferred, max) */
    --font-size-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
    --font-size-sm: clamp(0.8125rem, 0.75rem + 0.3125vw, 0.95rem);
    --font-size-base: clamp(0.9rem, 0.85rem + 0.25vw, 1rem);
    --font-size-lg: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
    --font-size-xl: clamp(1.125rem, 1rem + 0.625vw, 1.25rem);
    --font-size-2xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
    --font-size-3xl: clamp(1.5rem, 1.2rem + 1.5vw, 2.5rem);
    --font-size-4xl: clamp(1.75rem, 1.5rem + 2vw, 3rem);
}

html,
body {
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: var(--font-size-base);
    font-weight: 500;
    /* Enhanced text sharpness */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    letter-spacing: -0.01em;
    background-color: var(--color-bg-layout);
    color: var(--color-text);
}

html.dark-mode, 
body.dark-mode {
    --color-text: #f8fafc;
    --color-text-light: #94a3b8;
    --color-bg-light: #1e293b;
    --color-bg-lighter: #334155;
    
    --color-bg-layout: #0f172a;
    --color-bg-card: #1e293b;
    --color-surface: #334155;
    --color-nav-hover: rgba(255, 255, 255, 0.05);
    --color-border-subtle: #2d3748; /* Darker border for dark mode */
    --color-border: rgba(255, 255, 255, 0.15);
    --color-text-nav: #cbd5e1;
    --color-text-nav-hover: #ffffff;
    --color-shadow: rgba(0, 0, 0, 0.5); /* Stronger shadow in dark mode */
}

/* Base Theme Overrides for Bootstrap in Dark Mode */
[data-bs-theme="dark"] .bg-white {
    background-color: var(--color-bg-card) !important;
}

[data-bs-theme="dark"] .text-dark {
    color: var(--color-text) !important;
}

[data-bs-theme="dark"] .card {
    background-color: var(--color-bg-card);
    border-color: var(--color-border);
}

[data-bs-theme="dark"] .card-header {
    background-color: var(--color-bg-card);
    border-bottom-color: var(--color-border);
}

/* Bulletproof Theme Toggle Button using purely CSS */
.theme-toggle-btn::before {
    content: "🌙";
}

[data-bs-theme="dark"] .theme-toggle-btn::before {
    content: "☀️";
}

html,
body {
    height: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* ===== Typography ===== */
h1,
.h1 {
    font-size: var(--font-size-4xl);
    font-weight: 700;
    color: var(--color-primary-darker);
}

h2,
.h2 {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--color-primary-darker);
}

h3,
.h3 {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--color-primary-darker);
}

h4,
.h4 {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text);
}

h5,
.h5 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--color-text);
}

h6,
.h6 {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
}

p {
    line-height: 1.7;
}

/* ===== Links ===== */
a {
    color: var(--color-primary-dark);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-primary);
}

/* ===== Containers ===== */
.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 clamp(1rem, 5vw, 2rem);
}

.container-sm {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.container-lg {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

/* ===== Buttons ===== */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: var(--font-size-base);
    text-decoration: none;
    cursor: pointer;
    border: 1px solid transparent;
    transition: all var(--transition-normal);
}

.btn-primary {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: white;
    box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3);
    border-color: rgba(37, 99, 235, 0.4);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary-darker) 100%);
    box-shadow: 0 6px 20px rgba(37, 99, 235, 0.4);
    transform: translateY(-2px);
}

.btn-secondary {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
    color: var(--color-primary-dark);
    border: 1.5px solid rgba(37, 99, 235, 0.3);
}

.btn-secondary:hover {
    border-color: var(--color-primary-dark);
    background: rgba(37, 99, 235, 0.08);
    color: var(--color-primary-darker);
}

.btn-sm {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.btn-lg {
    padding: 1rem var(--spacing-xl);
    font-size: var(--font-size-lg);
}

/* ===== Cards ===== */
.card {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(15px);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    transition: all var(--transition-normal);
    display: flex;
    flex-direction: column;
}

.card:hover {
    border-color: rgba(37, 99, 235, 0.3);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid rgba(37, 99, 235, 0.1);
}

.card-title {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text);
}

.card-subtitle {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
}

.card-body {
    flex: 1;
}

.card-footer {
    display: flex;
    gap: var(--spacing-md);
    margin-top: auto;
}

/* ===== Badges ===== */
.badge {
    display: inline-block;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1px solid;
}

.badge-success {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.12) 0%, rgba(52, 211, 153, 0.1) 100%);
    color: var(--color-success);
    border-color: rgba(16, 185, 129, 0.2);
}

.badge-warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.12) 0%, rgba(217, 119, 6, 0.1) 100%);
    color: var(--color-warning);
    border-color: rgba(245, 158, 11, 0.2);
}

.badge-error {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.12) 0%, rgba(220, 38, 38, 0.1) 100%);
    color: var(--color-error);
    border-color: rgba(239, 68, 68, 0.2);
}

.badge-info {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.12) 0%, rgba(37, 99, 235, 0.1) 100%);
    color: var(--color-info);
    border-color: rgba(59, 130, 246, 0.2);
}

/* ===== Input Elements ===== */
input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="button"]):not([type="submit"]):not([type="reset"]):not(.dxbl-text-edit-input),
textarea:not(.dxbl-text-edit-input),
select:not(.dxbl-text-edit-input) {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid rgba(37, 99, 235, 0.2);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    transition: all var(--transition-fast);
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(10px);
    color: var(--color-text);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="button"]):not([type="submit"]):not([type="reset"]):focus,
textarea:focus,
select:focus {
    outline: none;
    border-color: rgba(37, 99, 235, 0.4);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* ===== Grid Utilities ===== */
.grid {
    display: grid;
    gap: var(--spacing-lg);
}

.grid-2 {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid-3 {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-4 {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* ===== Flex Utilities ===== */
.flex {
    display: flex;
}

.flex-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

.flex-between {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.gap-sm {
    gap: var(--spacing-sm);
}

.gap-md {
    gap: var(--spacing-md);
}

.gap-lg {
    gap: var(--spacing-lg);
}

/* ===== Spacing Utilities ===== */
.p-0 {
    padding: 0;
}

.p-sm {
    padding: var(--spacing-sm);
}

.p-md {
    padding: var(--spacing-md);
}

.p-lg {
    padding: var(--spacing-lg);
}

.p-xl {
    padding: var(--spacing-xl);
}

.m-0 {
    margin: 0;
}

.m-sm {
    margin: var(--spacing-sm);
}

.m-md {
    margin: var(--spacing-md);
}

.m-lg {
    margin: var(--spacing-lg);
}

.m-xl {
    margin: var(--spacing-xl);
}

.mt-sm {
    margin-top: var(--spacing-sm);
}

.mt-md {
    margin-top: var(--spacing-md);
}

.mt-lg {
    margin-top: var(--spacing-lg);
}

.mb-sm {
    margin-bottom: var(--spacing-sm);
}

.mb-md {
    margin-bottom: var(--spacing-md);
}

.mb-lg {
    margin-bottom: var(--spacing-lg);
}

/* ===== Text Utilities ===== */
.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.text-muted {
    color: var(--color-text-light);
}

.text-primary {
    color: var(--color-primary-dark);
}

.text-success {
    color: var(--color-success);
}

.text-warning {
    color: var(--color-warning);
}

.text-error {
    color: var(--color-error);
}

.font-sm {
    font-size: var(--font-size-sm);
}

.font-md {
    font-size: var(--font-size-base);
}

.font-lg {
    font-size: var(--font-size-lg);
}

.font-bold {
    font-weight: 700;
}

.font-semibold {
    font-weight: 600;
}

.font-normal {
    font-weight: 400;
}

/* ===== Empty State ===== */
.empty-state {
    text-align: center;
    padding: var(--spacing-2xl);
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(10px);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
}

.empty-icon {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
}

.empty-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
}

.empty-text {
    font-size: 1rem;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
}

/* ===== Pagination ===== */
.pagination {
    display: flex;
    gap: var(--spacing-sm);
    justify-content: center;
    margin-top: var(--spacing-2xl);
}

.page-btn {
    padding: var(--spacing-xs) var(--spacing-md);
    border: 1px solid rgba(37, 99, 235, 0.2);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.7);
    color: var(--color-primary-darker);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.page-btn:hover {
    border-color: rgba(37, 99, 235, 0.4);
    background: rgba(37, 99, 235, 0.05);
}

.page-btn.active {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: white;
    border-color: rgba(37, 99, 235, 0.3);
}

/* ===== Animations ===== */
@keyframes fadeInLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes float {

    0%,
    100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-15px);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.animate-fade-left {
    animation: fadeInLeft 0.8s ease-out;
}

.animate-fade-right {
    animation: fadeInRight 0.8s ease-out;
}

.animate-float {
    animation: float 6s ease-in-out infinite;
}

.spinner {
    border: 4px solid rgba(37, 99, 235, 0.1);
    border-radius: 50%;
    border-top: 4px solid var(--color-primary);
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin: 20px auto;
}

/* ===== Validation ===== */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

.button-link {
    text-decoration: unset;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

/* ===== Original Site Styles ===== */
.title {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding-bottom: 0.625rem;
}

.title.title-secondary {
    padding-top: 0.313rem;
    padding-bottom: 0;
    color: var(--bs-secondary-color);
}

.title-header-text {
    font-size: 2.5rem;
    line-height: 3rem;
    font-weight: 600;
    letter-spacing: 0rem;
    padding: 0.3125rem 0;
}

.title-content-text {
    font-size: 1.75rem;
    font-weight: 400;
    line-height: 2.5rem;
    letter-spacing: 0rem;
}

.main-content {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
}

.block-content {
    width: 31.25rem;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    max-width: 100%;
}

.or {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.or .or-line {
    border-bottom: 1px solid var(--bs-body-color);
    width: 100%;
    opacity: 0.2;
}

.or .or-text {
    padding: 0 0.625rem 0px 0.625rem;
    font-size: 0.75rem;
    line-height: 1.125rem;
    color: var(--bs-body-color);
    opacity: 0.7;
}

.links-area {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    padding-top: 0.625rem;
}

.links-container {
    display: flex;
    gap: 0.25rem;
    justify-content: center;
    align-items: center;
}

.links-container .dot {
    height: 0.3125rem;
    width: 0.3125rem;
    margin: 0 0.1875rem;
    border-radius: 50%;
    background-color: var(--bs-body-color);
    opacity: 0.7;
}

.manage-layout {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.info-message::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0.15;
    background: var(--bs-primary);
    z-index: -1;
}

.info-message {
    padding: 0.625rem 1rem 0.625rem 1rem;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.info-message.info-panel {
    margin-bottom: 0.625rem;
}

.manage-content {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.large-input {
    height: 4.3125rem;
    font-size: 1.875rem;
}

.title-content-text-secondary {
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.button-group {
    display: flex;
    flex-direction: row;
    gap: 0.625rem;
}

.confirm-button {
    margin-top: 0.3125rem;
}

.display-desktop {
    display: block;
}

.display-mobile {
    display: none;
}

.icon-external-provider {
    width: 1rem;
    height: 1rem;
}

.icon-google {
    background-image: url("/images/account/providers/google-logo.svg")
}

.icon-facebook {
    background-image: url("/images/account/providers/facebook-logo.svg")
}

.icon-microsoft {
    background-image: url("/images/account/providers/microsoft-logo.svg")
}

.icon-twitter {
    background-image: url("/images/account/providers/x-logo.svg")
}

/* Loading and Error Styles */
.loading-indicator {
    text-align: center;
    padding: 2rem;
}

.error-message {
    text-align: center;
    padding: 2rem;
    color: #dc3545;
}

.error-message button {
    margin-top: 1rem;
    padding: 0.5rem 1rem;
    background-color: #dc3545;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

/* Remove background from all card headers */
::deep .dxbl-card-header,
::deep .card-header,
::deep .dxbl-grid-header,
.dxbl-card-header,
.card-header,
.dxbl-grid-header {
    background-color: transparent !important;
    background-image: none !important;
    background: transparent !important;
}

/* Specifically target headers with gradients */
::deep .dxbl-card-header[style*="background"],
::deep .card-header[style*="background"],
.card-header[style*="background"] {
    background: transparent !important;
}

/* TopNav Dropdown Styling - Global overrides for Bootstrap dropdowns */
.topnav-navbar .dropdown-menu,
.topnav-navbar .dropdown-menu.topnav-dropdown {
    background: linear-gradient(135deg, #1e40af 0%, #1d4ed8 50%, #2563eb 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25) !important;
}

/* TopNav Main Nav Links - White text for all navbar links */
.topnav-navbar .nav-link,
.topnav-navbar .navbar-nav .nav-link,
.topnav-navbar a.nav-link.topnav-link {
    color: #ffffff !important;
}

.topnav-navbar .nav-link:hover,
.topnav-navbar .navbar-nav .nav-link:hover,
.topnav-navbar a.nav-link.topnav-link:hover {
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.15) !important;
}

.topnav-navbar .nav-link.active,
.topnav-navbar .navbar-nav .nav-link.active,
.topnav-navbar a.nav-link.topnav-link.active {
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.25) !important;
}

.topnav-navbar .dropdown-menu .dropdown-item,
.topnav-navbar .dropdown-item.topnav-dropdown-item,
.dropdown-menu.topnav-dropdown .dropdown-item {
    color: #ffffff !important;
    padding: 0.5rem 1.25rem;
    font-weight: 500;
}

.topnav-navbar .dropdown-menu .dropdown-item:hover,
.topnav-navbar .dropdown-menu .dropdown-item:focus,
.topnav-navbar .dropdown-item.topnav-dropdown-item:hover,
.topnav-navbar .dropdown-item.topnav-dropdown-item:focus {
    background: rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
}

.topnav-navbar .dropdown-menu .dropdown-item.active,
.topnav-navbar .dropdown-item.topnav-dropdown-item.active {
    background: rgba(255, 255, 255, 0.25) !important;
    color: #ffffff !important;
}

.topnav-navbar .dropdown-menu .dropdown-divider {
    border-color: rgba(255, 255, 255, 0.2);
}

/* ===== Responsive Design ===== */
@media (max-width: 1024px) {
    .grid-2 {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    }
}

@media (max-width: 768px) {

    h1,
    .h1 {
        font-size: 2rem;
    }

    h2,
    .h2 {
        font-size: 1.5rem;
    }

    h3,
    .h3 {
        font-size: 1.25rem;
    }

    .grid-2,
    .grid-3,
    .grid-4 {
        grid-template-columns: 1fr;
    }

    .flex-col-mobile {
        flex-direction: column;
    }

    .display-desktop {
        display: none;
    }

    .display-mobile {
        display: block;
    }
}

/* ===== Global DevExpress Overrides ===== */
/* Checkbox Visibility Override - Global */
.dxbl-checkbox.dxbl-checkbox-checked .dxbl-checkbox-input-container,
.dxbl-checkbox.dxbl-checkbox-indeterminate .dxbl-checkbox-input-container {
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    box-shadow: none !important;
    /* Remove any default glow */
}

/* Ensure the checkmark icon is white and visible */
.dxbl-checkbox.dxbl-checkbox-checked .dxbl-checkbox-icon,
.dxbl-checkbox.dxbl-checkbox-indeterminate .dxbl-checkbox-icon {
    color: white !important;
    fill: white !important;
    opacity: 1 !important;
    display: block !important;
}

/* Specific SVG path targeting if icon is inline SVG */
.dxbl-checkbox.dxbl-checkbox-checked .dxbl-checkbox-icon path,
.dxbl-checkbox.dxbl-checkbox-indeterminate .dxbl-checkbox-icon path {
    fill: white !important;
    stroke: white !important;
}