:root {
    --primary-color: #3b82f6;
    --primary-color-light: rgba(59, 130, 246, 0.1);
    --primary-color-dark: #2563eb;
    
    --secondary-color: #6c757d;
    --secondary-color-light: rgba(108, 117, 125, 0.1);
    
    --success-color: #10b981;
    --danger-color: #ef4444;
    --warning-color: #f59e0b;
    --info-color: #3b82f6;
    
    --text-color: #1f2937;
    --text-muted: #6b7280;
    --text-light: #9ca3af;
    
    --bg-white: #ffffff;
    --bg-light: #f9fafb;
    --bg-gray: #f3f4f6;
    
    --border-color: #e5e7eb;
    --border-color-light: #f3f4f6;
    
    --navbar-height: 60px;
    --navbar-height-mobile: 56px;
    --top-banner-height: 0px;
    --navbar-bg-color: #ffffff;
    --navbar-text-color: #333333;
    --navbar-logo-height: 44px;
    
    --card-border-radius: 12px;
    --button-border-radius: 8px;
    --input-border-radius: 8px;
    
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    
    --transition-fast: 150ms ease;
    --transition-normal: 200ms ease;
    --transition-slow: 300ms ease;
    
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;
    
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;
    
    --font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
}

.tos-webcommerce {
    font-family: var(--font-family);
    color: var(--text-color);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.tos-webcommerce .text-primary { color: var(--primary-color) !important; }
.tos-webcommerce .text-secondary { color: var(--secondary-color) !important; }
.tos-webcommerce .text-success { color: var(--success-color) !important; }
.tos-webcommerce .text-danger { color: var(--danger-color) !important; }
.tos-webcommerce .text-warning { color: var(--warning-color) !important; }
.tos-webcommerce .text-muted { color: var(--text-muted) !important; }

.tos-webcommerce .bg-primary { background-color: var(--primary-color) !important; }
.tos-webcommerce .bg-secondary { background-color: var(--secondary-color) !important; }
.tos-webcommerce .bg-success { background-color: var(--success-color) !important; }
.tos-webcommerce .bg-danger { background-color: var(--danger-color) !important; }
.tos-webcommerce .bg-warning { background-color: var(--warning-color) !important; }
.tos-webcommerce .bg-light { background-color: var(--bg-light) !important; }
.tos-webcommerce .bg-white { background-color: var(--bg-white) !important; }

.tos-webcommerce .btn-primary {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.tos-webcommerce .btn-primary:hover,
.tos-webcommerce .btn-primary:focus {
    background-color: var(--primary-color-dark);
    border-color: var(--primary-color-dark);
}

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

.tos-webcommerce .btn-outline-primary:hover,
.tos-webcommerce .btn-outline-primary:focus {
    background-color: var(--primary-color);
    color: white;
}

.tos-webcommerce .form-control:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem var(--primary-color-light);
}

.tos-webcommerce .border-primary { border-color: var(--primary-color) !important; }

.tos-webcommerce .shadow-sm { box-shadow: var(--shadow-sm); }
.tos-webcommerce .shadow-md { box-shadow: var(--shadow-md); }
.tos-webcommerce .shadow-lg { box-shadow: var(--shadow-lg); }
.tos-webcommerce .shadow-xl { box-shadow: var(--shadow-xl); }

.tos-webcommerce .card {
    border-radius: var(--card-border-radius);
    border-color: var(--border-color);
}

.tos-webcommerce .btn {
    border-radius: var(--button-border-radius);
    transition: all var(--transition-fast);
}

.tos-webcommerce .form-control,
.tos-webcommerce .form-select {
    border-radius: var(--input-border-radius);
}

[x-cloak] {
    display: none !important;
}

.tos-webcommerce .loading-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid var(--border-color);
    border-radius: 50%;
    border-top-color: var(--primary-color);
    animation: spin 0.8s linear infinite;
}

.tos-webcommerce .loading-spinner-lg {
    width: 40px;
    height: 40px;
    border-width: 3px;
}

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

.tos-webcommerce .skeleton {
    background: linear-gradient(90deg, var(--bg-gray) 25%, var(--bg-light) 50%, var(--bg-gray) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
    border-radius: var(--button-border-radius);
}

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

.tos-webcommerce .toast-container {
    position: fixed;
    bottom: var(--spacing-lg);
    left: 50%;
    transform: translateX(-50%);
    z-index: var(--z-tooltip);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.tos-webcommerce .toast {
    background: var(--bg-white);
    border-radius: var(--card-border-radius);
    box-shadow: var(--shadow-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    min-width: 300px;
    max-width: 90vw;
    animation: toast-in 0.3s ease;
}

.tos-webcommerce .toast.toast-success {
    border-left: 4px solid var(--success-color);
}

.tos-webcommerce .toast.toast-error {
    border-left: 4px solid var(--danger-color);
}

.tos-webcommerce .toast.toast-warning {
    border-left: 4px solid var(--warning-color);
}

.tos-webcommerce .toast .toast-action {
    margin-left: auto;
    padding: var(--spacing-xs) var(--spacing-sm);
    background: transparent;
    border: none;
    color: var(--primary-color);
    font-weight: 600;
    cursor: pointer;
}

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

@media (prefers-reduced-motion: reduce) {
    .tos-webcommerce .loading-spinner,
    .tos-webcommerce .skeleton {
        animation: none;
    }
    
    .tos-webcommerce .toast {
        animation: none;
    }
    
    .tos-webcommerce * {
        transition-duration: 0.01ms !important;
    }
}

@media (max-width: 767px) {
    :root {
        --navbar-height: var(--navbar-height-mobile);
        --spacing-lg: 1rem;
        --spacing-xl: 1.5rem;
    }
}

.cart-undo-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: #1f2937;
    color: white;
    padding: 12px 16px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
    z-index: 9999;
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
    min-width: 280px;
    max-width: 90vw;
}

.cart-undo-toast.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.cart-undo-toast .toast-message {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    font-size: 14px;
}

.cart-undo-toast .toast-message svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.cart-undo-toast .toast-message .truncate {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 180px;
}

.cart-undo-toast .toast-undo-btn {
    background: transparent;
    border: none;
    color: #60a5fa;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    padding: 4px 8px;
    margin: -4px -8px -4px 0;
    border-radius: 6px;
    transition: background 0.15s ease;
    white-space: nowrap;
}

.cart-undo-toast .toast-undo-btn:hover {
    background: rgba(96, 165, 250, 0.15);
}

.cart-undo-toast .toast-progress {
    position: absolute;
    bottom: 0;
    left: 12px;
    right: 12px;
    height: 3px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 0 0 10px 10px;
    overflow: hidden;
}

.cart-undo-toast .toast-progress::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    background: #60a5fa;
    animation: toast-progress 5s linear forwards;
}

@keyframes toast-progress {
    from { width: 100%; }
    to { width: 0%; }
}

@media (max-width: 480px) {
    .cart-undo-toast {
        bottom: 16px;
        left: 16px;
        right: 16px;
        transform: translateX(0) translateY(100px);
        min-width: auto;
        max-width: none;
    }
    
    .cart-undo-toast.show {
        transform: translateX(0) translateY(0);
    }
    
    .cart-undo-toast .toast-message .truncate {
        max-width: 140px;
    }
}

/* Checkout Progress Indicator */
.checkout-progress-container {
    width: 100%;
    margin: var(--spacing-xl) 0;
    padding: 0 var(--spacing-md);
}

.checkout-progress {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 800px;
    margin: 0 auto;
    position: relative;
    padding: 0;
}

.step {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 1;
    flex: 1;
}

.step-line {
    position: absolute;
    top: 15px;
    left: 50%;
    width: 100%;
    height: 2px;
    background-color: var(--border-color);
    z-index: -1;
}

.step:last-child .step-line {
    display: none;
}

.step.completed .step-line {
    background-color: var(--primary-color);
}

.step-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    background-color: transparent;
}

.step-circle {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: var(--bg-white);
    border: 2px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
    transition: all var(--transition-normal);
    z-index: 2;
}

.step.active .step-circle {
    border-color: var(--primary-color);
    background-color: var(--primary-color);
    color: white;
    box-shadow: 0 0 0 4px var(--primary-color-light);
}

.step.completed .step-circle {
    border-color: var(--primary-color);
    background-color: var(--primary-color);
    color: white;
}

.step-label {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--text-muted);
    transition: color var(--transition-normal);
    text-align: center;
}

.step.active .step-label {
    color: var(--primary-color);
    font-weight: 600;
}

.step.completed .step-label {
    color: var(--text-color);
}

@media (max-width: 640px) {
    .step-label {
        font-size: var(--font-size-xs);
        max-width: 60px;
    }
    
    .checkout-progress-container {
        margin: var(--spacing-md) 0;
    }
}

@media (max-width: 400px) {
    .step-label {
        display: none;
    }
    
    .step.active .step-label {
        display: block;
        white-space: nowrap;
    }
}

.skip-to-content {
    position: absolute;
    top: -100px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--primary-color, #3b82f6);
    color: white;
    padding: 12px 24px;
    border-radius: 0 0 8px 8px;
    font-weight: 600;
    font-size: 14px;
    z-index: 10000;
    transition: top 0.2s ease;
    text-decoration: none;
}

.skip-to-content:focus {
    top: 0;
    outline: 2px solid var(--primary-color, #3b82f6);
    outline-offset: 2px;
}

.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.loading-overlay-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.loading-message {
    font-size: 14px;
    color: var(--text-muted, #6b7280);
    font-weight: 500;
}

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

/* ==========================================================================
   Dark Mode Theme
   ========================================================================== */

[data-theme="dark"] {
	/* Backgrounds */
	--bg-white: #1a1a2e;
	--bg-light: #16162a;
	--bg-gray: #252540;

	/* Text */
	--text-color: #f1f1f1;
	--text-muted: #a0a0b0;
	--text-light: #6b6b80;

	/* Borders */
	--border-color: #3a3a50;
	--border-color-light: #2a2a40;

	/* Navbar */
	--navbar-bg-color: #1a1a2e;
	--navbar-text-color: #f1f1f1;

	/* Shadows - adjusted for dark backgrounds */
	--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
	--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);
	--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.6);

	/* Primary color - uses dynamic dark accent set by JS */
	--primary-color: var(--primary-color-dark, #60a5fa);

	/* Status colors - slightly brighter for dark mode */
	--success-color: #34d399;
	--danger-color: #f87171;
	--warning-color: #fbbf24;
	--info-color: #60a5fa;
}

/* Smooth theme transitions */
html {
	transition: background-color 200ms ease, color 200ms ease;
}

html * {
	transition: background-color 200ms ease, color 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

/* Disable transitions for users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
	html,
	html * {
		transition: none !important;
	}
}

/* Dark mode body and main container */
[data-theme="dark"] body,
[data-theme="dark"] .tos-webcommerce {
	background-color: var(--bg-light);
	color: var(--text-color);
}

/* Cards in dark mode */
[data-theme="dark"] .card,
[data-theme="dark"] .tos-webcommerce .card {
	background-color: var(--bg-white);
	border-color: var(--border-color);
}

/* Form inputs in dark mode */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select,
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] input[type="tel"],
[data-theme="dark"] textarea {
	background-color: var(--bg-gray);
	border-color: var(--border-color);
	color: var(--text-color);
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
	color: var(--text-light);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus {
	border-color: var(--primary-color);
	box-shadow: 0 0 0 0.2rem rgba(96, 165, 250, 0.25);
}

/* Loading overlay in dark mode */
[data-theme="dark"] .loading-overlay {
	background: rgba(22, 22, 42, 0.9);
}

/* Toast notifications in dark mode */
[data-theme="dark"] .tos-webcommerce .toast {
	background: var(--bg-white);
	color: var(--text-color);
}

[data-theme="dark"] .cart-undo-toast {
	background: var(--bg-gray);
}

/* Product images - subtle border to prevent disappearing on dark bg */
[data-theme="dark"] .product-card img,
[data-theme="dark"] .item-image img,
[data-theme="dark"] .website-image img {
	border: 1px solid var(--border-color);
	border-radius: var(--card-border-radius, 8px);
}

/* Navbar dark mode overrides */
[data-theme="dark"] .webcommerce-navbar {
	background-color: var(--navbar-bg-color) !important;
	border-bottom-color: var(--border-color);
}

[data-theme="dark"] .webcommerce-navbar .navbar-menu-item,
[data-theme="dark"] .webcommerce-navbar .action-btn,
[data-theme="dark"] .webcommerce-navbar .brand-text {
	color: var(--navbar-text-color);
}

[data-theme="dark"] .navbar-dropdown-menu,
[data-theme="dark"] .dropdown-menu {
	background-color: var(--bg-white);
	border-color: var(--border-color);
}

[data-theme="dark"] .dropdown-item {
	color: var(--text-color);
}

[data-theme="dark"] .dropdown-item:hover {
	background-color: var(--bg-gray);
}

/* Mobile menu dark mode */
[data-theme="dark"] .mobile-menu {
	background-color: var(--bg-white);
}

[data-theme="dark"] .mobile-menu-item {
	color: var(--text-color);
}

[data-theme="dark"] .mobile-menu-item:hover {
	background-color: var(--bg-gray);
}

[data-theme="dark"] .mobile-menu-overlay {
	background-color: rgba(0, 0, 0, 0.7);
}

/* Footer dark mode */
[data-theme="dark"] .webcommerce-footer {
	background-color: var(--bg-white);
	border-top-color: var(--border-color);
}

/* Search input dark mode */
[data-theme="dark"] .search-input-wrapper {
	background-color: var(--bg-gray);
	border-color: var(--border-color);
}

[data-theme="dark"] .search-input {
	background-color: transparent;
	color: var(--text-color);
}

[data-theme="dark"] .search-suggestions {
	background-color: var(--bg-white);
	border-color: var(--border-color);
}

[data-theme="dark"] .suggestion-item:hover {
	background-color: var(--bg-gray);
}

/* Skeleton loader dark mode */
[data-theme="dark"] .skeleton {
	background: linear-gradient(90deg, var(--bg-gray) 25%, var(--bg-white) 50%, var(--bg-gray) 75%);
	background-size: 200% 100%;
}

/* ==========================================================================
   Navbar Dark Mode - Override hardcoded colors in navbar.css
   ========================================================================== */

/* Main navbar background */
[data-theme="dark"] .webcommerce-navbar {
	background: var(--bg-white) !important;
	border-bottom-color: var(--border-color) !important;
}

/* Brand text */
[data-theme="dark"] .brand-text {
	color: var(--text-color) !important;
}

/* Menu items */
[data-theme="dark"] .navbar-menu-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .navbar-menu-item:hover {
	background: var(--bg-gray) !important;
	color: var(--primary-color) !important;
}

/* Dropdown chevron */
[data-theme="dark"] .navbar-menu-dropdown .dropdown-toggle .dropdown-chevron,
[data-theme="dark"] .navbar-menu-dropdown .dropdown-toggle .fa-chevron-down,
[data-theme="dark"] .navbar-menu-dropdown .dropdown-toggle i.fa {
	color: var(--text-color) !important;
}

/* Navbar dropdown menu */
[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu {
	background: var(--bg-white) !important;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 10px 15px -3px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu::before {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu .dropdown-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu .dropdown-item:hover {
	background: var(--bg-gray) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu .dropdown-item i {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .navbar-menu-dropdown .navbar-dropdown-menu .dropdown-item:hover i {
	color: var(--primary-color) !important;
}

/* Search input */
[data-theme="dark"] .search-input-wrapper {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .search-input-wrapper:focus-within {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .search-icon {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .search-input {
	color: var(--text-color) !important;
}

[data-theme="dark"] .search-input::placeholder {
	color: var(--text-light) !important;
}

/* Search suggestions */
[data-theme="dark"] .search-suggestions {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .suggestions-header {
	color: var(--text-muted) !important;
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .suggestion-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .suggestion-item:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .suggestion-item.recent i {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .suggestion-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .suggestion-item.view-all {
	border-top-color: var(--border-color) !important;
}

[data-theme="dark"] .suggestions-loading {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .no-results {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .no-results i {
	color: var(--text-light) !important;
}

/* Action buttons (Wishlist, Cart, Account) */
[data-theme="dark"] .action-btn {
	color: var(--text-color) !important;
}

[data-theme="dark"] .action-btn:hover {
	background: var(--bg-gray) !important;
	color: var(--primary-color) !important;
}

/* User dropdown menu */
[data-theme="dark"] .dropdown-menu {
	background: var(--bg-white) !important;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .dropdown-header {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .dropdown-header .user-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .dropdown-header .user-email {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .dropdown-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .dropdown-item:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .dropdown-item i {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .dropdown-item:hover i {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .dropdown-divider {
	border-top-color: var(--border-color) !important;
}

/* Mobile menu button */
[data-theme="dark"] .mobile-menu-btn {
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-btn:hover {
	background: var(--bg-gray) !important;
}

/* Mobile search */
[data-theme="dark"] .mobile-search {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .mobile-search .search-input-wrapper {
	background: var(--bg-gray) !important;
}

/* Mobile menu */
[data-theme="dark"] .mobile-menu {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .mobile-menu-header {
	background: var(--bg-white) !important;
	border-bottom-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-close {
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-close:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .mobile-menu-user {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .mobile-menu-user-info .user-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-user-info .user-email {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .mobile-menu-nav {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .mobile-menu-nav-title {
	color: var(--text-light) !important;
}

[data-theme="dark"] .mobile-menu-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .mobile-menu-item:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .mobile-menu-item i {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .mobile-menu-item:hover i {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .mobile-dropdown-content {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .mobile-dropdown-item span {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .mobile-dropdown-item:hover span {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .mobile-menu-divider {
	border-top-color: var(--border-color) !important;
}

/* Top banner - keep primary color but adjust text if needed */
[data-theme="dark"] .top-contact-banner {
	border-bottom: 1px solid var(--border-color);
}

/* ==========================================================================
   Product Card Dark Mode - Override hardcoded colors in product_card.css
   ========================================================================== */

/* Product card background and border */
[data-theme="dark"] .product-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .product-card:hover {
	border-color: var(--border-color-light) !important;
}

/* Product image container */
[data-theme="dark"] .product-image-container {
	background: var(--bg-gray) !important;
}

/* Product placeholder */
[data-theme="dark"] .product-placeholder {
	background: linear-gradient(135deg, var(--bg-gray), var(--bg-white)) !important;
	color: var(--text-light) !important;
}

/* Product name */
[data-theme="dark"] .product-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .product-card:hover .product-name {
	color: var(--primary-color) !important;
}

/* Product prices */
[data-theme="dark"] .price-current {
	color: var(--text-color) !important;
}

[data-theme="dark"] .price-current.sale {
	color: var(--danger-color) !important;
}

[data-theme="dark"] .price-original {
	color: var(--text-muted) !important;
}

/* Product rating */
[data-theme="dark"] .product-rating .review-count {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .product-rating .stars .star-empty {
	color: var(--text-light) !important;
}

/* Quick action buttons */
[data-theme="dark"] .quick-action-btn {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .quick-action-btn:hover {
	background: var(--primary-color) !important;
	color: white !important;
}

[data-theme="dark"] .quick-action-btn.active {
	color: var(--danger-color) !important;
}

[data-theme="dark"] .quick-action-btn.active:hover {
	background: var(--danger-color) !important;
	color: white !important;
}

/* ==========================================================================
   Additional Common Components Dark Mode
   ========================================================================== */

/* Breadcrumbs */
[data-theme="dark"] .breadcrumb {
	background: transparent !important;
}

[data-theme="dark"] .breadcrumb-item a {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .breadcrumb-item.active {
	color: var(--text-color) !important;
}

[data-theme="dark"] .breadcrumb-item + .breadcrumb-item::before {
	color: var(--text-light) !important;
}

/* Pagination */
[data-theme="dark"] .page-link {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .page-link:hover {
	background: var(--bg-gray) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .page-item.active .page-link {
	background: var(--primary-color) !important;
	border-color: var(--primary-color) !important;
	color: white !important;
}

[data-theme="dark"] .page-item.disabled .page-link {
	background: var(--bg-gray) !important;
	color: var(--text-light) !important;
}

/* Alerts */
[data-theme="dark"] .alert {
	border-color: var(--border-color) !important;
}

/* Modals */
[data-theme="dark"] .modal-content {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .modal-header {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .modal-footer {
	border-top-color: var(--border-color) !important;
}

[data-theme="dark"] .modal-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .btn-close {
	filter: invert(1) !important;
}

/* Tables */
[data-theme="dark"] .table {
	color: var(--text-color) !important;
}

[data-theme="dark"] .table thead th {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .table tbody td {
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd) {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .table-hover tbody tr:hover {
	background: var(--bg-gray) !important;
}

/* Buttons - secondary/outline variants */
[data-theme="dark"] .btn-outline-secondary {
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .btn-outline-secondary:hover {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .btn-light {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

/* Links */
[data-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item) {
	color: var(--primary-color);
}

/* HR dividers */
[data-theme="dark"] hr {
	border-color: var(--border-color) !important;
}

/* ==========================================================================
   Homepage Sections Dark Mode - Override inline styles in templates
   ========================================================================== */

/* Category Section - from category_carousel.html */
[data-theme="dark"] .category-section-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .category-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .category-card:hover .category-name {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .category-icon-wrapper {
	background: var(--bg-gray) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .category-icon-placeholder {
	color: var(--text-light) !important;
}

[data-theme="dark"] .category-arrow {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .category-arrow:hover {
	background: var(--bg-gray) !important;
}

/* Video Section - from video_carousel.html */
[data-theme="dark"] .video-section-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .video-thumbnail-wrapper {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .video-arrow {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .video-arrow:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .video-play-btn {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
}

/* Brand Section - from brand_carousel.html */
[data-theme="dark"] .brand-section-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .brand-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .brand-arrow {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
}

/* Featured Products Section */
[data-theme="dark"] .featured-section-title,
[data-theme="dark"] .section-title,
[data-theme="dark"] h2.section-title,
[data-theme="dark"] .products-section-title {
	color: var(--text-color) !important;
}

/* Flash Sale Section */
[data-theme="dark"] .flash-sale-title {
	color: var(--text-color) !important;
}

/* Shop page filters sidebar */
[data-theme="dark"] .filters-sidebar {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .filter-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .filter-header {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .category-item {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .category-item:hover {
	color: var(--primary-color) !important;
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .category-count {
	background: var(--bg-white) !important;
	color: var(--text-muted) !important;
}

/* Webcommerce general text colors */
[data-theme="dark"] .webcommerce-shop h1,
[data-theme="dark"] .webcommerce-shop h2,
[data-theme="dark"] .webcommerce-shop h3,
[data-theme="dark"] .webcommerce-shop h4,
[data-theme="dark"] .webcommerce-shop h5,
[data-theme="dark"] .webcommerce-shop h6 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .webcommerce-shop p,
[data-theme="dark"] .webcommerce-shop span:not(.badge),
[data-theme="dark"] .webcommerce-shop label {
	color: var(--text-color);
}

/* Glide carousel arrows in dark mode */
[data-theme="dark"] .glide__arrow {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .glide__arrow:hover {
	background: var(--bg-gray) !important;
}

/* General body and container backgrounds */
[data-theme="dark"] .tos-webcommerce,
[data-theme="dark"] .webcommerce-shop {
	background-color: var(--bg-light) !important;
}

[data-theme="dark"] .container,
[data-theme="dark"] .container-fluid {
	color: var(--text-color);
}

/* Section containers that might have white backgrounds */
[data-theme="dark"] section {
	background-color: transparent;
}

[data-theme="dark"] .section-light,
[data-theme="dark"] .bg-white,
[data-theme="dark"] .bg-light {
	background-color: var(--bg-white) !important;
}

/* All text elements that might have dark text on dark background */
[data-theme="dark"] .text-dark,
[data-theme="dark"] .text-gray-900,
[data-theme="dark"] .text-gray-800,
[data-theme="dark"] .text-gray-700 {
	color: var(--text-color) !important;
}

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

[data-theme="dark"] .text-muted {
	color: var(--text-muted) !important;
}

/* ==========================================================================
   Footer Dark Mode - Override hardcoded colors in footer.css
   ========================================================================== */

/* Main footer background */
[data-theme="dark"] .webcommerce-footer {
	background-color: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .footer-main {
	background-color: var(--bg-white) !important;
}

/* Footer headings and brand */
[data-theme="dark"] .footer-brand,
[data-theme="dark"] .footer-heading {
	color: var(--text-color) !important;
}

/* Footer text and links */
[data-theme="dark"] .footer-description,
[data-theme="dark"] .footer-link,
[data-theme="dark"] .copyright-text {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .footer-link:hover {
	color: var(--primary-color) !important;
}

/* Social links */
[data-theme="dark"] .social-link {
	background-color: var(--bg-gray) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .social-link:hover {
	background-color: var(--primary-color) !important;
	color: white !important;
}

/* Logo items (payment/shipping) */
[data-theme="dark"] .logo-item {
	background-color: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .logo-item:hover {
	border-color: var(--border-color-light) !important;
}

[data-theme="dark"] .logo-text {
	color: var(--text-color) !important;
}

/* Footer bottom */
[data-theme="dark"] .footer-bottom {
	background-color: var(--bg-light) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .powered-by,
[data-theme="dark"] .powered-by span,
[data-theme="dark"] .powered-text {
	color: var(--text-muted) !important;
}

/* Footer utility classes override */
[data-theme="dark"] .webcommerce-footer .text-gray-400,
[data-theme="dark"] .webcommerce-footer .text-gray-500,
[data-theme="dark"] .webcommerce-footer .text-gray-600 {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .webcommerce-footer .bg-white {
	background-color: var(--bg-white) !important;
}

[data-theme="dark"] .webcommerce-footer .bg-gray-50 {
	background-color: var(--bg-gray) !important;
}

[data-theme="dark"] .webcommerce-footer .border-gray-200 {
	border-color: var(--border-color) !important;
}

/* ==========================================================================
   Top Banner Dark Mode - Adjust for better contrast with dark theme
   ========================================================================== */

[data-theme="dark"] .top-contact-banner {
	background-color: var(--bg-gray) !important;
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .top-contact-banner .contact-link,
[data-theme="dark"] .top-contact-banner .social-link,
[data-theme="dark"] .top-contact-banner .banner-text,
[data-theme="dark"] .top-contact-banner span {
	color: var(--text-color) !important;
}

[data-theme="dark"] .top-contact-banner .fa,
[data-theme="dark"] .top-contact-banner .fas,
[data-theme="dark"] .top-contact-banner .far,
[data-theme="dark"] .top-contact-banner .fab,
[data-theme="dark"] .top-contact-banner i {
	color: var(--text-color) !important;
}

[data-theme="dark"] .top-contact-banner .contact-link:hover,
[data-theme="dark"] .top-contact-banner .social-link:hover {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .top-contact-banner .contact-link:hover i,
[data-theme="dark"] .top-contact-banner .social-link:hover i {
	color: var(--primary-color) !important;
}

/* ==========================================================================
   Shop Page & Product Cards - Comprehensive Dark Mode
   ========================================================================== */

/* Page titles */
[data-theme="dark"] .page-title,
[data-theme="dark"] .products-header h1,
[data-theme="dark"] .products-header h2,
[data-theme="dark"] .section-header h3,
[data-theme="dark"] .section-header p,
[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(--text-color) !important;
}

/* Product card - all elements */
[data-theme="dark"] .product-card,
[data-theme="dark"] .product-item,
[data-theme="dark"] .item-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .product-card .card,
[data-theme="dark"] .product-card .card-body {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .product-card .card-title,
[data-theme="dark"] .product-card .product-name,
[data-theme="dark"] .product-name,
[data-theme="dark"] .product-title,
[data-theme="dark"] .item-name,
[data-theme="dark"] .card-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .product-card .product-brand,
[data-theme="dark"] .product-brand {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .product-card .product-price,
[data-theme="dark"] .product-price,
[data-theme="dark"] .current-price,
[data-theme="dark"] .price-current {
	color: var(--text-color) !important;
}

[data-theme="dark"] .product-card .original-price,
[data-theme="dark"] .original-price,
[data-theme="dark"] .price-original {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .product-rating .stars .star-empty,
[data-theme="dark"] .product-rating .review-count {
	color: var(--text-muted) !important;
}

/* Search and filter section */
[data-theme="dark"] .search-filter-section {
	background: var(--bg-white) !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .search-input {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .search-input::placeholder {
	color: var(--text-light) !important;
}

[data-theme="dark"] .sort-label {
	color: var(--text-color) !important;
}

/* Custom select dropdown */
[data-theme="dark"] .custom-select-dropdown,
[data-theme="dark"] select.form-select,
[data-theme="dark"] .form-select {
	background-color: var(--bg-gray) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23f1f1f1' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .custom-select-dropdown option,
[data-theme="dark"] select option {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
}

/* Flash sale and featured sections */
[data-theme="dark"] .flash-sale-products-section,
[data-theme="dark"] .featured-products-section {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .featured-products-section h3 {
	color: var(--primary-color) !important;
}

/* Search results dropdown */
[data-theme="dark"] #search-results-container {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .dropdown-item {
	color: var(--text-color) !important;
}

[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .recent-search:hover {
	background-color: var(--bg-gray) !important;
}

/* Products grid container */
[data-theme="dark"] .products-grid {
	background: transparent !important;
}

/* Item card specific */
[data-theme="dark"] .item-card .product-info {
	background: var(--bg-white) !important;
}

/* All spans and paragraphs in product area */
[data-theme="dark"] .product-card span,
[data-theme="dark"] .product-card p,
[data-theme="dark"] .product-info span,
[data-theme="dark"] .product-info p {
	color: var(--text-color);
}

/* Product placeholder */
[data-theme="dark"] .product-image-placeholder {
	background: linear-gradient(135deg, var(--bg-gray), var(--bg-white)) !important;
}

/* Category pills/tags */
[data-theme="dark"] .category-tag,
[data-theme="dark"] .category-pill {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .filter-pill {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .filter-pill:hover {
	background: var(--bg-white) !important;
	border-color: var(--primary-color) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .filter-pill.active {
	background: var(--primary-color) !important;
	border-color: var(--primary-color) !important;
	color: #ffffff !important;
}

[data-theme="dark"] .filter-pills .filter-pill.active,
[data-theme="dark"] .shop-filter-inline .filter-pill.active,
[data-theme="dark"] a.filter-pill.active,
[data-theme="dark"] button.filter-pill.active {
	background: var(--primary-color) !important;
	border-color: var(--primary-color) !important;
	color: #ffffff !important;
}

/* ==========================================================================
   All Products Page Dark Mode
   ========================================================================== */

/* All products container */
[data-theme="dark"] .all-products-container {
	background: var(--bg-light) !important;
}

/* Breadcrumb */
[data-theme="dark"] .all-products-header {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .breadcrumb-nav,
[data-theme="dark"] .breadcrumb-nav a,
[data-theme="dark"] .breadcrumb-nav span {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .breadcrumb-nav a:hover {
	color: var(--primary-color) !important;
}

/* Filter sidebar */
[data-theme="dark"] .filter-sidebar {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .filter-sidebar-title {
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .filter-sidebar-title a {
	color: var(--primary-color) !important;
}

[data-theme="dark"] .filter-group-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .filter-option {
	color: var(--text-color) !important;
}

[data-theme="dark"] .filter-option span {
	color: var(--text-color) !important;
}

/* Mobile filter toggle */
[data-theme="dark"] .mobile-filter-toggle {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

/* Sort dropdown */
[data-theme="dark"] .sort-select {
	background-color: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23a0a0b0'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E") !important;
}

[data-theme="dark"] .sort-label {
	color: var(--text-muted) !important;
}

/* Page title and count */
[data-theme="dark"] .page-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .result-count {
	color: var(--text-muted) !important;
}

/* Empty state */
[data-theme="dark"] .empty-state {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .empty-icon {
	background: var(--bg-gray) !important;
	color: var(--text-muted) !important;
}

[data-theme="dark"] .empty-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .empty-desc {
	color: var(--text-muted) !important;
}

/* Reset Filters / Empty action button - ensure white text */
[data-theme="dark"] .empty-action {
	color: #ffffff !important;
}

/* Pagination */
[data-theme="dark"] .page-btn {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .page-btn:hover {
	border-color: var(--primary-color) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .page-btn.active {
	background: var(--primary-color) !important;
	border-color: var(--primary-color) !important;
	color: #ffffff !important;
}

[data-theme="dark"] .page-btn.disabled {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-light) !important;
}

/* Product detail page */
[data-theme="dark"] .item-detail,
[data-theme="dark"] .product-detail {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .item-detail .item-name,
[data-theme="dark"] .product-detail .product-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-detail .item-description,
[data-theme="dark"] .product-description {
	color: var(--text-muted) !important;
}

/* Item page breadcrumb wrapper */
[data-theme="dark"] .item-breadcrumbs-wrapper,
[data-theme="dark"] .item-breadcrumbs-wrapper.bg-gray-50 {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .item-breadcrumbs-wrapper nav,
[data-theme="dark"] .item-breadcrumbs-wrapper a,
[data-theme="dark"] .item-breadcrumbs-wrapper span {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-breadcrumbs-wrapper a:hover {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-breadcrumbs-wrapper span.text-gray-900 {
	color: var(--text-color) !important;
}

/* Item page main sections */
[data-theme="dark"] .item-page,
[data-theme="dark"] .item-page.bg-white,
[data-theme="dark"] .item-page-main {
	background: var(--bg-light) !important;
}

/* Item details section */
[data-theme="dark"] .item-details-section h1,
[data-theme="dark"] .item-details-section .text-gray-900 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-details-section .text-gray-400,
[data-theme="dark"] .item-details-section .text-gray-500,
[data-theme="dark"] .item-details-section .text-gray-600 {
	color: var(--text-muted) !important;
}

/* Item category badge */
[data-theme="dark"] .item-details-section a.bg-gray-100,
[data-theme="dark"] .item-details-section .bg-gray-100 {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-details-section a.bg-gray-100:hover {
	background: var(--bg-white) !important;
}

/* Item page tabs/description section */
[data-theme="dark"] .item-page section.bg-white,
[data-theme="dark"] .product-page-content section.bg-white,
[data-theme="dark"] section.bg-white.rounded-xl {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .tab-navigation {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .tab-btn {
	color: var(--text-muted) !important;
	background: transparent !important;
}

[data-theme="dark"] .tab-btn:hover {
	color: var(--text-color) !important;
	background: var(--bg-gray) !important;
}

/* Active tab - high specificity to override inline !important */
[data-theme="dark"] .tab-btn.tab-active,
[data-theme="dark"] .tab-active,
[data-theme="dark"] .item-page .tab-btn.tab-active,
[data-theme="dark"] .item-page .tab-active {
	color: var(--primary-color) !important;
	background: var(--bg-white) !important;
	border-bottom-color: var(--primary-color) !important;
}

[data-theme="dark"] .tab-btn.tab-inactive,
[data-theme="dark"] .tab-inactive {
	color: var(--text-muted) !important;
	background: transparent !important;
}

[data-theme="dark"] .tab-content {
	background: var(--bg-white) !important;
	color: var(--text-color) !important;
}

/* Prose styling for description content */
[data-theme="dark"] .prose,
[data-theme="dark"] .prose p,
[data-theme="dark"] .prose li,
[data-theme="dark"] .prose span {
	color: var(--text-color) !important;
}

[data-theme="dark"] .prose h1,
[data-theme="dark"] .prose h2,
[data-theme="dark"] .prose h3,
[data-theme="dark"] .prose h4,
[data-theme="dark"] .prose h5,
[data-theme="dark"] .prose h6 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .prose a {
	color: var(--primary-color) !important;
}

/* Item page breadcrumbs */
[data-theme="dark"] .item-breadcrumbs {
	background: var(--bg-gray) !important;
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-breadcrumbs a {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-breadcrumbs a:hover {
	color: var(--primary-color) !important;
}

/* Border colors on item page */
[data-theme="dark"] .border-gray-100,
[data-theme="dark"] .border-gray-200 {
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .border-t {
	border-top-color: var(--border-color) !important;
}

[data-theme="dark"] .border-b {
	border-bottom-color: var(--border-color) !important;
}

/* Quantity selector */
[data-theme="dark"] .qty-input,
[data-theme="dark"] .quantity-input {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

/* All links that might be dark */
[data-theme="dark"] .product-card a,
[data-theme="dark"] .item-card a {
	color: var(--text-color);
}

[data-theme="dark"] .product-card a:hover,
[data-theme="dark"] .item-card a:hover {
	color: var(--primary-color);
}

/* ==========================================================================
   My Account Page Dark Mode
   ========================================================================== */

/* Account page background */
[data-theme="dark"] .account-page-wrapper {
	background-color: var(--bg-light) !important;
}

/* Breadcrumb */
[data-theme="dark"] .account-breadcrumb,
[data-theme="dark"] .account-breadcrumb a {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .account-breadcrumb a:hover {
	color: var(--primary-color) !important;
}

/* Sidebar card */
[data-theme="dark"] .account-sidebar-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .user-profile-header {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .user-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .user-email {
	color: var(--text-muted) !important;
}

/* Sidebar navigation */
[data-theme="dark"] .nav-item-link {
	color: var(--text-color) !important;
}

[data-theme="dark"] .nav-item-link:hover {
	background-color: var(--bg-gray) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .nav-item-link.active {
	background-color: rgba(96, 165, 250, 0.1) !important;
	color: var(--primary-color) !important;
}

[data-theme="dark"] .nav-item-link i {
	color: inherit !important;
}

/* Content card */
[data-theme="dark"] .account-content-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .content-title {
	color: var(--text-color) !important;
}

/* Tabs */
[data-theme="dark"] .account-tabs {
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .tab-link {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .tab-link:hover,
[data-theme="dark"] .tab-link.active {
	color: var(--primary-color) !important;
}

/* Biodata section */
[data-theme="dark"] .biodata-avatar-section {
	background-color: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .biodata-avatar-text h4 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .biodata-avatar-text p {
	color: var(--text-muted) !important;
}

/* Form elements */
[data-theme="dark"] .form-label {
	color: var(--text-color) !important;
}

[data-theme="dark"] .form-control {
	background-color: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .form-control::placeholder {
	color: var(--text-light) !important;
}

[data-theme="dark"] .form-control[readonly],
[data-theme="dark"] .form-control[disabled] {
	background-color: var(--bg-light) !important;
	color: var(--text-muted) !important;
}

/* Orders list */
[data-theme="dark"] .order-card {
	border-color: var(--border-color) !important;
	background: var(--bg-white) !important;
}

[data-theme="dark"] .order-header {
	background-color: var(--bg-gray) !important;
	border-bottom-color: var(--border-color) !important;
}

[data-theme="dark"] .order-number {
	color: var(--text-color) !important;
}

[data-theme="dark"] .order-date {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .order-body {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .item-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-qty {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .order-item-more {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .total-label {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .total-amount {
	color: var(--text-color) !important;
}

[data-theme="dark"] .order-footer {
	border-top-color: var(--border-color) !important;
}

/* Empty state */
[data-theme="dark"] .empty-state h5 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .empty-state p {
	color: var(--text-muted) !important;
}

/* ==========================================================================
   Cart Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .cart-container,
[data-theme="dark"] .shopping-cart {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .cart-item,
[data-theme="dark"] .cart-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-item-name,
[data-theme="dark"] .cart-item-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .cart-item-price,
[data-theme="dark"] .cart-item-total {
	color: var(--text-color) !important;
}

[data-theme="dark"] .cart-item-qty {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .cart-summary {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-summary-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .cart-summary-row {
	color: var(--text-color) !important;
}

[data-theme="dark"] .cart-summary-row span {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .cart-total {
	color: var(--text-color) !important;
	border-top-color: var(--border-color) !important;
}

/* Cart table */
[data-theme="dark"] .cart-table {
	background: var(--bg-white) !important;
}

[data-theme="dark"] .cart-table thead th {
	background: var(--bg-gray) !important;
	color: var(--text-muted) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-table tbody tr {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-table tbody td {
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

/* Cart item details */
[data-theme="dark"] .item-title,
[data-theme="dark"] .cart-table .item-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-subtitle,
[data-theme="dark"] .cart-table .item-subtitle {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-mobile-price {
	color: var(--text-color) !important;
}

/* Cart quantity controls */
[data-theme="dark"] .number-spinner .cart-btn {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .number-spinner .cart-qty,
[data-theme="dark"] .cart-qty {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

/* Cart notes textarea */
[data-theme="dark"] .cart-table textarea,
[data-theme="dark"] .cart-container textarea,
[data-theme="dark"] textarea[name="notes"] {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-table textarea::placeholder {
	color: var(--text-light) !important;
}

/* No image placeholder */
[data-theme="dark"] .no-image-cart-item {
	background: var(--bg-gray) !important;
	color: var(--text-muted) !important;
}

/* Cart buttons */
[data-theme="dark"] .cart-container .btn-default,
[data-theme="dark"] .cart-container .btn-secondary,
[data-theme="dark"] .btn-past-orders,
[data-theme="dark"] .btn-continue-shopping {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .cart-container .btn-default:hover,
[data-theme="dark"] .cart-container .btn-secondary:hover {
	background: var(--bg-white) !important;
}

/* Address cards */
[data-theme="dark"] .address-card,
[data-theme="dark"] .shipping-address-card,
[data-theme="dark"] .billing-address-card,
[data-theme="dark"] .address-section {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .address-card h5,
[data-theme="dark"] .address-card h6,
[data-theme="dark"] .address-card .address-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .address-card p,
[data-theme="dark"] .address-card span,
[data-theme="dark"] .address-card .address-text {
	color: var(--text-muted) !important;
}

/* Empty address state */
[data-theme="dark"] .no-address-message,
[data-theme="dark"] .empty-address {
	color: var(--text-muted) !important;
}

/* Payment summary */
[data-theme="dark"] .payment-summary,
[data-theme="dark"] .payment-summary-card,
[data-theme="dark"] .order-summary {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .payment-summary h4,
[data-theme="dark"] .payment-summary h5,
[data-theme="dark"] .payment-summary-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .payment-summary-row,
[data-theme="dark"] .summary-row {
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .payment-summary-row span,
[data-theme="dark"] .summary-label {
	color: var(--text-muted) !important;
}

/* Shipping section */
[data-theme="dark"] .shipping-section,
[data-theme="dark"] .biteship-shipping-section {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .shipping-section h4 {
	color: var(--text-color) !important;
}

[data-theme="dark"] .shipping-option-item {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .shipping-option-item:hover {
	background: var(--bg-gray) !important;
}

[data-theme="dark"] .shipping-option-item.selected {
	background: var(--bg-gray) !important;
	border-color: var(--primary-color) !important;
}

[data-theme="dark"] .selected-shipping-display {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

/* Section titles */
[data-theme="dark"] .section-title,
[data-theme="dark"] .cart-section-title {
	color: var(--text-color) !important;
}

/* Add New button styling */
[data-theme="dark"] .btn-add-address,
[data-theme="dark"] .add-address-btn,
[data-theme="dark"] [class*="add-new"] {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

/* Checkbox styling */
[data-theme="dark"] .cart-container input[type="checkbox"] + label,
[data-theme="dark"] .cart-container .form-check-label,
[data-theme="dark"] .checkbox label,
[data-theme="dark"] .label-area {
	color: var(--text-color) !important;
}

/* Frappe card (address sections wrapper) */
[data-theme="dark"] .frappe-card,
[data-theme="dark"] [data-section="shipping-address"],
[data-theme="dark"] [data-section="billing-address"] {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] [data-section="shipping-address"] h6,
[data-theme="dark"] [data-section="billing-address"] h6 {
	color: var(--text-color) !important;
}

/* Add New / Select Address buttons */
[data-theme="dark"] .btn-new-address {
	background: var(--bg-gray) !important;
	color: var(--text-color) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .btn-new-address:hover {
	background: var(--bg-white) !important;
}

/* Select Address button - ensure white text on primary color */
[data-theme="dark"] .btn-select-address {
	color: #ffffff !important;
}

/* Empty address message box */
[data-theme="dark"] .text-muted.text-center.p-3 {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .text-muted.text-center.p-3 p,
[data-theme="dark"] .text-muted.text-center.p-3 i {
	color: var(--text-muted) !important;
}

/* Address card */
[data-theme="dark"] .address-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .address-card.active {
	background: var(--bg-gray) !important;
	border-color: var(--primary-color) !important;
}

[data-theme="dark"] .address-card .card-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .address-card .card-text,
[data-theme="dark"] .address-display-text {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .address-card .card-link {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .address-card .card-link:hover {
	color: var(--primary-color) !important;
}

/* Address picker in modal */
[data-theme="dark"] .address-picker-card,
[data-theme="dark"] .address-picker-item {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .address-picker-card:hover,
[data-theme="dark"] .address-picker-item:hover {
	background: var(--bg-gray) !important;
}

/* ==========================================================================
   Item Detail Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .item-page,
[data-theme="dark"] .product-page {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .item-title,
[data-theme="dark"] .product-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-price,
[data-theme="dark"] .product-price-display {
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-description,
[data-theme="dark"] .product-description {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-stock-status {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .item-details-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .item-specifications th,
[data-theme="dark"] .item-specifications td {
	border-color: var(--border-color) !important;
	color: var(--text-color) !important;
}

[data-theme="dark"] .item-specifications th {
	background: var(--bg-gray) !important;
}

/* ==========================================================================
   Wishlist Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .wishlist-container {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .wishlist-item {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .wishlist-item-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .wishlist-item-price {
	color: var(--text-color) !important;
}

/* ==========================================================================
   Address Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .address-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .address-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .address-details {
	color: var(--text-muted) !important;
}

[data-theme="dark"] .address-form label {
	color: var(--text-color) !important;
}

/* ==========================================================================
   Login/Register Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .login-container,
[data-theme="dark"] .register-container {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .login-card,
[data-theme="dark"] .register-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .login-title,
[data-theme="dark"] .register-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .login-subtitle,
[data-theme="dark"] .register-subtitle {
	color: var(--text-muted) !important;
}

/* ==========================================================================
   Checkout/Shipping Page Dark Mode
   ========================================================================== */

[data-theme="dark"] .checkout-container {
	background: var(--bg-light) !important;
}

[data-theme="dark"] .checkout-card,
[data-theme="dark"] .shipping-card {
	background: var(--bg-white) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .checkout-title,
[data-theme="dark"] .shipping-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .checkout-step-title {
	color: var(--text-color) !important;
}

[data-theme="dark"] .shipping-option {
	background: var(--bg-gray) !important;
	border-color: var(--border-color) !important;
}

[data-theme="dark"] .shipping-option-name {
	color: var(--text-color) !important;
}

[data-theme="dark"] .shipping-option-price {
	color: var(--text-muted) !important;
}

/* ==========================================================================
   Global Text Overrides - Catch All
   ========================================================================== */

/* Any remaining dark text */
[data-theme="dark"] [style*="color: #1f2937"],
[data-theme="dark"] [style*="color: #2c3e50"],
[data-theme="dark"] [style*="color: #374151"],
[data-theme="dark"] [style*="color: #4a5568"],
[data-theme="dark"] [style*="color: #1a1a2e"] {
	color: var(--text-color) !important;
}

/* Any remaining gray text */
[data-theme="dark"] [style*="color: #6c757d"],
[data-theme="dark"] [style*="color: #718096"],
[data-theme="dark"] [style*="color: #9ca3af"] {
	color: var(--text-muted) !important;
}

/* Any remaining white backgrounds */
[data-theme="dark"] [style*="background: white"],
[data-theme="dark"] [style*="background-color: white"],
[data-theme="dark"] [style*="background: #fff"],
[data-theme="dark"] [style*="background-color: #fff"],
[data-theme="dark"] [style*="background: #ffffff"],
[data-theme="dark"] [style*="background-color: #ffffff"] {
	background-color: var(--bg-white) !important;
}

/* Ensure all body text is readable */
[data-theme="dark"] body {
	color: var(--text-color) !important;
	background-color: var(--bg-light) !important;
}
