/* E-Shop Template - Modern Design System */
/* Pro barevná schémata viz themes.css */

/* CSS Custom Properties - Mapování na theme proměnné */
:root {
    /* Primary colors - používají theme proměnné */
    --primary: var(--text-primary, #1a1a2e);
    --primary-light: var(--color-slate-800, #16213e);
    --secondary: var(--text-secondary, #64748b);
    --secondary-light: var(--text-muted, #94a3b8);

    /* Accent - mapováno na theme */
    --accent: var(--accent-500, #0ea5e9);
    --accent-hover: var(--accent-600, #0284c7);
    --accent-light: var(--accent-100, #e0f2fe);
    --accent-gradient: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));

    /* Status colors */
    --success: var(--color-success, #10b981);
    --success-light: var(--color-success-light, #d1fae5);
    --warning: var(--color-warning, #f59e0b);
    --warning-light: var(--color-warning-light, #fef3c7);
    --error: var(--color-error, #ef4444);
    --error-light: var(--color-error-light, #fee2e2);

    /* Backgrounds - používají theme proměnné */
    --bg: var(--bg-primary, #ffffff);
    --bg-alt: var(--bg-secondary, #f8fafc);
    --bg-dark: var(--bg-tertiary, #f1f5f9);
    --bg-card: var(--card-bg, #ffffff);

    /* Borders & Shadows */
    --border: var(--border-primary, #e2e8f0);
    --border-light: var(--border-secondary, #f1f5f9);
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow: var(--card-shadow, 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1));
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-colored: var(--theme-shadow, 0 4px 14px 0 rgb(14 165 233 / 0.39));

    /* Radius */
    --radius-sm: 6px;
    --radius: 10px;
    --radius-lg: 14px;
    --radius-xl: 20px;

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition: 200ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Base Styles */
html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--primary);
    background-color: var(--bg-alt);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Focus styles for accessibility */
*:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

/* Selection */
::selection {
    background: var(--accent-light);
    color: var(--primary);
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--bg-alt);
}

::-webkit-scrollbar-thumb {
    background: var(--secondary-light);
    border-radius: 5px;
    border: 2px solid var(--bg-alt);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--secondary);
}

/* ============================================
   BUTTONS
   ============================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    font-weight: 600;
    font-size: 14px;
    border-radius: var(--radius);
    transition: all var(--transition);
    cursor: pointer;
    border: none;
    text-decoration: none;
}

.btn-primary {
    background: var(--accent-gradient);
    color: white;
    box-shadow: var(--shadow-colored);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--theme-shadow, 0 6px 20px 0 rgb(14 165 233 / 0.45));
}

/* Global override for hardcoded cyan/teal gradients to use theme */
[class*="from-cyan"][class*="to-teal"],
[class*="from-cyan-500"][class*="to-teal-500"],
[class*="bg-gradient-to-r"][class*="from-cyan"],
[class*="bg-cyan-500"],
[class*="bg-teal-500"] {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%)) !important;
}

/* Override cyan text colors */
[class*="text-cyan-500"],
[class*="text-cyan-600"],
[class*="text-teal-500"],
[class*="text-teal-600"] {
    color: var(--accent-500, #0ea5e9) !important;
}

/* Override cyan shadows */
[class*="shadow-cyan"] {
    --tw-shadow-color: var(--accent-500, #0ea5e9);
    box-shadow: var(--theme-shadow, 0 4px 14px 0 rgba(14, 165, 233, 0.39)) !important;
}

/* Override cyan borders */
[class*="border-cyan"] {
    border-color: var(--accent-500, #0ea5e9) !important;
}

/* Override cyan focus rings */
[class*="focus:ring-cyan"]:focus,
[class*="focus:border-cyan"]:focus {
    --tw-ring-color: var(--accent-500, #0ea5e9);
    border-color: var(--accent-500, #0ea5e9) !important;
}

.btn-secondary {
    background: var(--bg);
    color: var(--primary);
    border: 1px solid var(--border);
}

.btn-secondary:hover {
    background: var(--bg-alt);
    border-color: var(--secondary-light);
}

.btn-ghost {
    background: transparent;
    color: var(--secondary);
}

.btn-ghost:hover {
    background: var(--bg-alt);
    color: var(--primary);
}

/* ============================================
   CATEGORY SIDEBAR (Homepage)
   ============================================ */
.category-sidebar {
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.category-sidebar-header {
    background: var(--accent-gradient);
    color: white;
    padding: 14px 18px;
    font-weight: 700;
    font-size: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.category-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 18px;
    color: var(--primary);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: all var(--transition-fast);
    border-bottom: 1px solid var(--border-light);
    position: relative;
}

.category-item:hover {
    background: var(--accent-light);
    color: var(--accent-hover);
    padding-left: 22px;
}

.category-item .category-icon {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-alt);
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.category-item:hover .category-icon {
    background: var(--accent);
    color: white;
}

.category-item .category-arrow {
    margin-left: auto;
    opacity: 0;
    transform: translateX(-4px);
    transition: all var(--transition-fast);
}

.category-item:hover .category-arrow {
    opacity: 1;
    transform: translateX(0);
}

/* Expandable subcategories */
.category-group {
    border-bottom: 1px solid var(--border-light);
}

.category-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 18px;
    cursor: pointer;
    font-weight: 500;
    font-size: 14px;
    transition: all var(--transition-fast);
}

.category-group-header:hover {
    background: var(--bg-alt);
}

.category-group-icon {
    transition: transform var(--transition);
}

.category-group.expanded .category-group-icon {
    transform: rotate(180deg);
}

.category-group-items {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-slow);
    background: var(--bg-alt);
}

.category-group.expanded .category-group-items {
    max-height: 500px;
}

.category-subitem {
    display: block;
    padding: 10px 18px 10px 48px;
    font-size: 13px;
    color: var(--secondary);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.category-subitem:hover {
    color: var(--accent);
    background: var(--bg);
}

/* ============================================
   MEGA MENU (Subpages)
   ============================================ */
.mega-menu-trigger {
    background: var(--accent-gradient);
    color: white;
    padding: 10px 20px;
    font-weight: 600;
    font-size: 14px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all var(--transition);
    border: none;
}

.mega-menu-trigger:hover {
    box-shadow: var(--shadow-colored);
    transform: translateY(-1px);
}

.mega-menu-container {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-xl);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all var(--transition);
    z-index: 100;
    border-top: 3px solid var(--accent);
}

.mega-menu-trigger:hover + .mega-menu-container,
.mega-menu-container:hover {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.mega-menu-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 24px;
    padding: 24px 32px;
}

.mega-menu-column h4 {
    font-weight: 700;
    font-size: 14px;
    color: var(--primary);
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--accent);
    display: inline-block;
}

.mega-menu-column a {
    display: block;
    padding: 6px 0;
    font-size: 13px;
    color: var(--secondary);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.mega-menu-column a:hover {
    color: var(--accent);
    padding-left: 6px;
}

/* ============================================
   PRODUCT CARDS - Modern Compact Design
   ============================================ */
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
}

@media (min-width: 1024px) {
    .product-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media (min-width: 1280px) {
    .product-grid {
        grid-template-columns: repeat(6, 1fr);
    }
}

.product-card {
    background: var(--bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition);
    position: relative;
    border: 1px solid transparent;
}

.product-card:hover {
    border-color: var(--accent-light);
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}

.product-card-image {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--bg-alt);
}

.product-card-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 12px;
    transition: transform var(--transition-slow);
}

.product-card:hover .product-card-image img {
    transform: scale(1.08);
}

/* Badges */
.product-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 700;
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.product-badge-sale {
    background: var(--error);
    color: white;
}

.product-badge-new {
    background: var(--success);
    color: white;
}

.product-badge-hot {
    background: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);
    color: white;
}

/* Wishlist button */
.product-wishlist {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 32px;
    height: 32px;
    background: var(--bg);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--transition);
    opacity: 0;
    box-shadow: var(--shadow);
}

.product-card:hover .product-wishlist {
    opacity: 1;
}

.product-wishlist:hover {
    background: var(--error-light);
    color: var(--error);
    transform: scale(1.1);
}

.product-wishlist.active {
    opacity: 1;
    color: var(--error);
    background: var(--error-light);
}

/* Quick add button */
.product-quick-add {
    position: absolute;
    bottom: 8px;
    left: 8px;
    right: 8px;
    background: var(--accent-gradient);
    color: white;
    border: none;
    padding: 10px;
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all var(--transition);
    opacity: 0;
    transform: translateY(8px);
    box-shadow: var(--shadow-colored);
}

.product-card:hover .product-quick-add {
    opacity: 1;
    transform: translateY(0);
}

.product-quick-add:hover {
    transform: translateY(-2px);
}

/* Product info */
.product-card-info {
    padding: 12px;
}

.product-card-category {
    font-size: 11px;
    color: var(--secondary-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.product-card-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--primary);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 8px;
    min-height: 36px;
}

.product-card-title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.product-card-title a:hover {
    color: var(--accent);
}

/* Rating */
.product-card-rating {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 8px;
}

.product-rating-stars {
    display: flex;
    gap: 1px;
    color: #fbbf24;
    font-size: 12px;
}

.product-rating-count {
    font-size: 11px;
    color: var(--secondary-light);
}

/* Price */
.product-card-price {
    display: flex;
    align-items: baseline;
    gap: 6px;
    flex-wrap: wrap;
}

.product-price-current {
    font-size: 16px;
    font-weight: 700;
    color: var(--primary);
}

.product-price-original {
    font-size: 12px;
    color: var(--secondary-light);
    text-decoration: line-through;
}

.product-price-discount {
    font-size: 11px;
    font-weight: 600;
    color: var(--error);
    background: var(--error-light);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
}

/* Stock status */
.product-card-stock {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    margin-top: 6px;
}

.product-stock-indicator {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}

.product-stock-in {
    background: var(--success);
}

.product-stock-low {
    background: var(--warning);
}

.product-stock-out {
    background: var(--secondary-light);
}

/* ============================================
   HEADER - Modern Design
   ============================================ */
.header-main {
    background: var(--header-bg, var(--bg));
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 50;
}

[data-mode="dark"] .header-main {
    background: var(--color-slate-800, #1e293b);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

[data-mode="dark"] .header-main a {
    color: var(--text-secondary, #cbd5e1);
}

[data-mode="dark"] .header-main a:hover {
    color: var(--accent-400, #22d3ee);
}

[data-mode="dark"] .header-main .text-gray-900,
[data-mode="dark"] .header-main .text-gray-700 {
    color: var(--text-primary, #e2e8f0) !important;
}

[data-mode="dark"] .header-main .mobile-menu-btn {
    color: var(--text-primary, #e2e8f0);
}

.header-top {
    background: var(--header-top-bg, var(--color-slate-900, #0f172a));
    color: var(--header-top-text, white);
    font-size: 12px;
    padding: 6px 0;
}

.header-search {
    flex: 1;
    max-width: 600px;
    position: relative;
}

.header-search input {
    width: 100%;
    padding: 12px 16px 12px 48px;
    border: 2px solid var(--border);
    border-radius: var(--radius-xl);
    font-size: 14px;
    transition: all var(--transition);
    background: var(--bg-alt);
}

.header-search input:focus {
    border-color: var(--accent);
    background: var(--bg);
    box-shadow: 0 0 0 4px var(--accent-light);
}

.header-search-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--secondary);
}

.header-search-btn {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--accent-gradient);
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: var(--radius-lg);
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    transition: all var(--transition);
}

.header-search-btn:hover {
    box-shadow: var(--shadow-colored);
}

/* Header icons */
.header-icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 8px 12px;
    color: var(--primary);
    text-decoration: none;
    font-size: 11px;
    font-weight: 500;
    transition: all var(--transition-fast);
    border-radius: var(--radius);
    position: relative;
}

.header-icon:hover {
    background: var(--bg-alt);
    color: var(--accent);
}

.header-icon svg {
    width: 24px;
    height: 24px;
}

.header-icon-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    min-width: 18px;
    height: 18px;
    background: var(--accent-gradient);
    color: white;
    font-size: 10px;
    font-weight: 700;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
}

/* Cart preview */
.cart-preview {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 16px;
    background: var(--accent-light);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all var(--transition);
}

.cart-preview:hover {
    background: var(--accent);
    color: white;
}

.cart-preview:hover .cart-preview-total {
    color: white;
}

.cart-preview-icon {
    position: relative;
}

.cart-preview-total {
    font-weight: 700;
    color: var(--primary);
    transition: color var(--transition);
}

/* ============================================
   HERO SECTION
   ============================================ */
.hero-banner {
    background: var(--theme-gradient);
    border-radius: var(--radius-xl);
    overflow: hidden;
    position: relative;
    min-height: 300px;
    display: flex;
    align-items: center;
}

.hero-content {
    padding: 40px;
    color: white;
    max-width: 50%;
}

.hero-content h1 {
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 16px;
}

.hero-content p {
    font-size: 1.125rem;
    opacity: 0.9;
    margin-bottom: 24px;
}

.hero-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: white;
    color: var(--accent);
    padding: 14px 28px;
    font-weight: 700;
    font-size: 14px;
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all var(--transition);
    box-shadow: var(--shadow-md);
}

.hero-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

/* ============================================
   SECTION HEADERS
   ============================================ */
.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
}

.section-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary);
    position: relative;
    padding-left: 16px;
}

.section-title::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 24px;
    background: var(--accent-gradient);
    border-radius: 2px;
}

.section-link {
    color: var(--accent);
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: gap var(--transition);
}

.section-link:hover {
    gap: 8px;
}

/* ============================================
   BENEFITS BAR
   ============================================ */
.benefits-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    padding: 24px 0;
}

.benefit-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: all var(--transition);
}

.benefit-item:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.benefit-icon {
    width: 48px;
    height: 48px;
    background: var(--accent-light);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    flex-shrink: 0;
}

.benefit-text h4 {
    font-weight: 600;
    font-size: 14px;
    color: var(--primary);
    margin-bottom: 2px;
}

.benefit-text p {
    font-size: 12px;
    color: var(--secondary);
}

/* ============================================
   FILTERS SIDEBAR
   ============================================ */
.filter-card {
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.filter-header {
    padding: 16px;
    font-weight: 700;
    font-size: 16px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.filter-section {
    border-bottom: 1px solid var(--border-light);
}

.filter-section:last-child {
    border-bottom: none;
}

.filter-section-header {
    padding: 14px 16px;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background var(--transition-fast);
}

.filter-section-header:hover {
    background: var(--bg-alt);
}

.filter-section-content {
    padding: 0 16px 16px;
}

.filter-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    cursor: pointer;
    font-size: 14px;
    transition: color var(--transition-fast);
}

.filter-option:hover {
    color: var(--accent);
}

.filter-checkbox {
    width: 18px;
    height: 18px;
    border: 2px solid var(--border);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--transition-fast);
}

.filter-option input:checked + .filter-checkbox {
    background: var(--accent-gradient);
    border-color: var(--accent);
}

.filter-count {
    margin-left: auto;
    font-size: 12px;
    color: var(--secondary-light);
}

/* Price range slider */
.price-range {
    padding: 8px 0;
}

.price-range-inputs {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.price-range-inputs input {
    flex: 1;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 13px;
    text-align: center;
}

.price-slider-track {
    height: 6px;
    background: var(--border);
    border-radius: 3px;
    position: relative;
}

.price-slider-range {
    position: absolute;
    height: 100%;
    background: var(--accent-gradient);
    border-radius: 3px;
}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    padding: 16px 0;
}

.breadcrumb a {
    color: var(--secondary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

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

.breadcrumb-separator {
    color: var(--secondary-light);
}

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

/* ============================================
   TABS
   ============================================ */
.tabs {
    display: flex;
    gap: 4px;
    background: var(--bg-alt);
    padding: 4px;
    border-radius: var(--radius-lg);
    margin-bottom: 24px;
}

.tab-btn {
    flex: 1;
    padding: 12px 20px;
    font-weight: 600;
    font-size: 14px;
    color: var(--secondary);
    background: transparent;
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all var(--transition);
}

.tab-btn:hover {
    color: var(--primary);
}

.tab-btn.active {
    background: var(--bg);
    color: var(--primary);
    box-shadow: var(--shadow-sm);
}

/* ============================================
   TOAST NOTIFICATIONS
   ============================================ */
.toast {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    animation: toastSlideIn var(--transition-slow) ease;
    border-left: 4px solid var(--success);
}

.toast-success {
    border-left-color: var(--success);
}

.toast-error {
    border-left-color: var(--error);
}

.toast-warning {
    border-left-color: var(--warning);
}

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

/* ============================================
   MODAL
   ============================================ */
.modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition);
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.modal-backdrop.active {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background: var(--bg);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    max-width: 500px;
    width: 100%;
    max-height: 90vh;
    overflow: auto;
    transform: scale(0.9);
    transition: transform var(--transition);
}

.modal-backdrop.active .modal-content {
    transform: scale(1);
}

/* ============================================
   FORMS
   ============================================ */
.form-group {
    margin-bottom: 20px;
}

.form-label {
    display: block;
    font-weight: 600;
    font-size: 13px;
    color: var(--primary);
    margin-bottom: 6px;
}

.form-input {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--border);
    border-radius: var(--radius);
    font-size: 14px;
    transition: all var(--transition);
    background: var(--bg);
}

.form-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 4px var(--accent-light);
}

.form-input:hover:not(:focus) {
    border-color: var(--secondary-light);
}

/* ============================================
   QUANTITY INPUT
   ============================================ */
.quantity-selector {
    display: flex;
    align-items: center;
    background: var(--bg-alt);
    border-radius: var(--radius);
    overflow: hidden;
}

.quantity-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 18px;
    color: var(--secondary);
    transition: all var(--transition-fast);
}

.quantity-btn:hover {
    background: var(--border);
    color: var(--primary);
}

.quantity-value {
    width: 48px;
    text-align: center;
    font-weight: 600;
    font-size: 14px;
    border: none;
    background: transparent;
}

.quantity-value::-webkit-outer-spin-button,
.quantity-value::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* ============================================
   STAR RATING
   ============================================ */
.star-rating {
    display: flex;
    gap: 2px;
}

.star-rating .star {
    color: #fbbf24;
}

.star-rating .star-empty {
    color: var(--border);
}

/* ============================================
   LOADING STATES
   ============================================ */
.skeleton {
    background: linear-gradient(90deg, var(--bg-alt) 25%, var(--border) 50%, var(--bg-alt) 75%);
    background-size: 200% 100%;
    animation: skeletonShimmer 1.5s infinite;
    border-radius: var(--radius);
}

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

.spinner {
    width: 24px;
    height: 24px;
    border: 3px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spinnerRotate 0.8s linear infinite;
}

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

/* ============================================
   FOOTER
   ============================================ */
.footer {
    background: var(--footer-bg, var(--color-slate-900, #0f172a));
    color: var(--footer-text, white);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 48px;
    padding: 48px 0;
}

.footer-column h4 {
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 20px;
    color: white;
}

.footer-column a {
    display: block;
    padding: 6px 0;
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 14px;
    transition: all var(--transition-fast);
}

.footer-column a:hover {
    color: var(--accent-400, white);
    padding-left: 6px;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: 24px 0;
    text-align: center;
    color: rgba(255, 255, 255, 0.5);
    font-size: 13px;
}

/* ============================================
   MOBILE MENU
   ============================================ */
.mobile-menu {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 300px;
    background: var(--bg);
    box-shadow: var(--shadow-xl);
    transform: translateX(-100%);
    transition: transform var(--transition-slow);
    z-index: 200;
    overflow-y: auto;
}

.mobile-menu.active {
    transform: translateX(0);
}

.mobile-menu-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition);
    z-index: 199;
}

.mobile-menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
    .product-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .benefits-bar {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 32px;
    }

    .mega-menu-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .product-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .product-card-info {
        padding: 10px;
    }

    .product-card-title {
        font-size: 12px;
        min-height: 32px;
    }

    .product-price-current {
        font-size: 14px;
    }

    .benefits-bar {
        grid-template-columns: 1fr;
    }

    .hero-content {
        max-width: 100%;
        padding: 24px;
    }

    .hero-content h1 {
        font-size: 1.75rem;
    }

    .section-title {
        font-size: 1.25rem;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
}

/* ============================================
   FEATURED PRODUCT BANNER
   ============================================ */
.featured-product-banner {
    display: flex;
    align-items: stretch;
    background: var(--bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
    border: 1px solid var(--border);
}

.featured-product-image {
    width: 200px;
    min-height: 200px;
    background: var(--bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 20px;
}

.featured-product-image img {
    max-width: 100%;
    max-height: 160px;
    object-fit: contain;
}

.featured-product-content {
    flex: 1;
    padding: 24px 32px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.featured-product-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 12px;
}

.featured-product-description {
    font-size: 14px;
    color: var(--secondary);
    line-height: 1.6;
    margin-bottom: 16px;
    font-style: italic;
}

.featured-product-pricing {
    font-size: 14px;
    color: var(--primary);
}

.featured-pricing-label {
    margin-bottom: 8px;
    color: var(--secondary);
}

.featured-pricing-row {
    padding: 2px 0;
}

.featured-pricing-row strong {
    color: var(--primary);
    font-weight: 700;
}

.featured-product-actions {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 24px;
    justify-content: center;
    border-left: 1px solid var(--border);
}

.btn-outline {
    background: transparent;
    color: var(--primary);
    border: 2px solid var(--border);
    padding: 12px 24px;
    border-radius: 24px;
    font-weight: 500;
    font-size: 14px;
    text-align: center;
    text-decoration: none;
    transition: all var(--transition);
    white-space: nowrap;
}

.btn-outline:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-light);
}

@media (max-width: 1024px) {
    .featured-product-banner {
        flex-wrap: wrap;
    }

    .featured-product-image {
        width: 160px;
    }

    .featured-product-content {
        flex: 1;
        min-width: 250px;
    }

    .featured-product-actions {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        border-left: none;
        border-top: 1px solid var(--border);
    }
}

@media (max-width: 768px) {
    .featured-product-banner {
        flex-direction: column;
    }

    .featured-product-image {
        width: 100%;
        min-height: 160px;
    }

    .featured-product-content {
        padding: 20px;
    }

    .featured-product-title {
        font-size: 1.25rem;
    }

    .featured-product-actions {
        padding: 16px;
        gap: 8px;
    }

    .btn-outline {
        flex: 1;
        min-width: calc(50% - 4px);
    }
}

/* ============================================
   UTILITIES
   ============================================ */
.text-gradient {
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.bg-gradient {
    background: var(--accent-gradient);
}

.shadow-colored {
    box-shadow: var(--shadow-colored);
}

.hide-mobile {
    display: none;
}

@media (min-width: 769px) {
    .hide-mobile {
        display: block;
    }

    .show-mobile-only {
        display: none !important;
    }
}

/* ============================================
   HEADER MENU - Full Width Navigation Bar
   ============================================ */
.header-menu {
    background: var(--header-menu-bg, linear-gradient(135deg, var(--color-slate-800, #1e293b) 0%, var(--color-slate-900, #0f172a) 100%));
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    position: relative;
    z-index: 40;
}

.header-menu-list {
    display: flex;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.header-menu-item {
    position: relative;
}

.header-menu-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 20px;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: all var(--transition);
    white-space: nowrap;
}

.header-menu-link:hover {
    color: white;
    background: rgba(255, 255, 255, 0.1);
}

.header-menu-link svg {
    opacity: 0.7;
    transition: opacity var(--transition);
}

.header-menu-link:hover svg {
    opacity: 1;
}

/* Categories button - special styling */
.header-menu-link-categories {
    background: var(--accent-gradient);
    color: white;
    font-weight: 600;
    padding: 14px 24px;
}

.header-menu-link-categories:hover {
    background: var(--accent-gradient);
    filter: brightness(1.1);
}

.header-menu-link-categories svg {
    opacity: 1;
}

/* Arrow rotation on hover */
.header-menu-categories:hover .header-menu-link-categories svg:last-child {
    transform: rotate(180deg);
}

/* ============================================
   HEADER MEGA MENU (Dropdown)
   ============================================ */
.header-mega-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 800px;
    background: var(--bg);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-xl);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all var(--transition);
    z-index: 100;
    border-top: 3px solid var(--accent);
}

.header-menu-categories:hover .header-mega-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.header-mega-menu-inner {
    padding: 0;
}

.header-mega-menu-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    padding: 24px;
}

.header-mega-menu-column {
    padding: 0 16px;
    border-right: 1px solid var(--border-light);
}

.header-mega-menu-column:last-child {
    border-right: none;
}

.header-mega-menu-column h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    font-size: 14px;
    color: var(--primary);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--accent);
}

.header-mega-menu-column h4 svg {
    color: var(--accent);
}

.header-mega-menu-column a {
    display: block;
    padding: 8px 0;
    font-size: 13px;
    color: var(--secondary);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.header-mega-menu-column a:hover {
    color: var(--accent);
    padding-left: 8px;
}

.header-mega-menu-footer {
    background: var(--bg-alt);
    padding: 16px 24px;
    border-top: 1px solid var(--border);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

.header-mega-menu-all {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--accent);
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    transition: all var(--transition);
}

.header-mega-menu-all:hover {
    gap: 12px;
}

/* Header action icons */
.header-action-icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    padding: 8px 12px;
    color: var(--primary);
    text-decoration: none;
    font-size: 11px;
    font-weight: 500;
    transition: all var(--transition-fast);
    border-radius: var(--radius);
    position: relative;
}

.header-action-icon:hover {
    background: var(--bg-alt);
    color: var(--accent);
}

/* Promo banners */
.promo-banner {
    display: block;
    padding: 32px;
    border-radius: var(--radius-xl);
    color: white;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: all var(--transition);
}

.promo-banner:hover {
    transform: translateY(-4px);
    box-shadow: var(--theme-shadow, 0 20px 25px -5px rgba(14, 165, 233, 0.15));
}

.promo-banner-primary {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
}

.promo-banner-secondary {
    background: var(--theme-gradient-dark, linear-gradient(135deg, var(--accent-700, #0369a1) 0%, var(--accent-900, #0c4a6e) 100%));
}

/* Dark mode promo banners */
[data-mode="dark"] .promo-banner-primary {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
    box-shadow: 0 4px 20px rgba(var(--accent-rgb, 14, 165, 233), 0.3);
}

[data-mode="dark"] .promo-banner-secondary {
    background: linear-gradient(135deg, rgba(var(--accent-rgb, 14, 165, 233), 0.15) 0%, rgba(var(--accent-rgb, 14, 165, 233), 0.05) 100%);
    border: 1px solid rgba(var(--accent-rgb, 14, 165, 233), 0.2);
}

[data-mode="dark"] .promo-banner:hover {
    box-shadow: 0 20px 40px rgba(var(--accent-rgb, 14, 165, 233), 0.25);
}

/* ============================================
   HEADER MENU RESPONSIVE
   ============================================ */
@media (max-width: 1200px) {
    .header-mega-menu {
        min-width: 600px;
    }

    .header-mega-menu-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .header-mega-menu-column:nth-child(4),
    .header-mega-menu-column:nth-child(5) {
        display: none;
    }
}

@media (max-width: 900px) {
    .header-menu-link {
        padding: 14px 12px;
        font-size: 13px;
    }

    .header-menu-link svg {
        display: none;
    }

    .header-menu-link-categories svg:first-child {
        display: block;
    }
}

/* Dark mode adjustments */
[data-mode="dark"] .header-mega-menu {
    background: var(--bg);
    border-color: var(--accent);
}

[data-mode="dark"] .header-mega-menu-column {
    border-color: var(--border);
}

[data-mode="dark"] .header-mega-menu-footer {
    background: var(--bg-alt);
    border-color: var(--border);
}

/* ============================================
   Page Hero Headers
   ============================================ */

/* ============================================
   Theme-aware Utility Classes
   ============================================ */

/* Gradient background using theme */
.bg-gradient {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
}

/* Text accent color */
.text-accent {
    color: var(--accent-500, #0ea5e9);
}

.text-accent:hover {
    color: var(--accent-600, #0284c7);
}

/* Shadow with accent color */
.shadow-colored {
    box-shadow: var(--theme-shadow, 0 4px 14px 0 rgba(14, 165, 233, 0.39));
}

/* Focus border accent */
.focus\:border-accent:focus {
    border-color: var(--accent-500, #0ea5e9) !important;
}

/* Checkbox with accent color */
.accent-checkbox {
    accent-color: var(--accent-500, #0ea5e9);
}

/* Hover background gradient */
.hover\:bg-gradient:hover {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
}

/* Page hero banner - contained with rounded corners */
.hero-page-banner {
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    border-radius: var(--radius-xl, 20px);
    position: relative;
    overflow: hidden;
}

.hero-page-banner::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
    opacity: 0.15;
    pointer-events: none;
}

.hero-page-banner::after {
    content: '';
    position: absolute;
    right: -50px;
    bottom: -50px;
    width: 200px;
    height: 200px;
    background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
    pointer-events: none;
}

.hero-page-banner h1,
.hero-page-banner p {
    position: relative;
    z-index: 1;
}

/* ============================================
   DARK MODE - Comprehensive Styles
   ============================================ */

/* Body & Main backgrounds */
[data-mode="dark"] body {
    background-color: var(--bg-primary, #0f172a);
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] main {
    background-color: var(--bg-primary, #0f172a);
}

/* Breadcrumb area */
[data-mode="dark"] .bg-white,
[data-mode="dark"] [class*="bg-white"] {
    background-color: var(--bg-secondary, #1e293b) !important;
}

[data-mode="dark"] .bg-slate-50,
[data-mode="dark"] [class*="bg-slate-50"] {
    background-color: var(--bg-primary, #0f172a) !important;
}

/* Product Cards */
[data-mode="dark"] .product-card {
    background: var(--card-bg, #1e293b);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] .product-card:hover {
    border-color: var(--accent-500, #0ea5e9);
}

[data-mode="dark"] .product-card-image {
    background: var(--bg-tertiary, #334155);
}

[data-mode="dark"] .product-card-title a {
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] .product-card-title a:hover {
    color: var(--accent-500, #0ea5e9);
}

[data-mode="dark"] .product-card-category {
    color: var(--text-muted, #94a3b8);
}

[data-mode="dark"] .product-price-current {
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] .product-price-original {
    color: var(--text-muted, #64748b);
}

/* Filter Cards / Sidebar */
[data-mode="dark"] .filter-card,
[data-mode="dark"] aside .bg-white,
[data-mode="dark"] aside [class*="rounded-xl"][class*="bg-white"] {
    background: var(--card-bg, #1e293b) !important;
    border-color: var(--border-primary, #334155) !important;
}

[data-mode="dark"] .filter-card .accordion-item button,
[data-mode="dark"] .filter-card h3,
[data-mode="dark"] .filter-card h4,
[data-mode="dark"] aside .font-semibold {
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] .filter-card label span,
[data-mode="dark"] .filter-card .text-sm {
    color: var(--text-secondary, #94a3b8);
}

[data-mode="dark"] .filter-card input[type="checkbox"] {
    background-color: var(--bg-tertiary, #334155);
    border-color: var(--border-primary, #475569);
}

[data-mode="dark"] .filter-card input[type="number"],
[data-mode="dark"] .filter-card input[type="text"] {
    background-color: var(--bg-tertiary, #334155);
    border-color: var(--border-primary, #475569);
    color: var(--text-primary, #e2e8f0);
}

/* Sorting bar */
[data-mode="dark"] .border-slate-200,
[data-mode="dark"] [class*="border-slate-200"] {
    border-color: var(--border-primary, #334155) !important;
}

[data-mode="dark"] select,
[data-mode="dark"] .form-select {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
    color: var(--text-primary, #e2e8f0);
}

/* Text colors */
[data-mode="dark"] .text-slate-900,
[data-mode="dark"] [class*="text-slate-900"] {
    color: var(--text-primary, #e2e8f0) !important;
}

[data-mode="dark"] .text-slate-800,
[data-mode="dark"] [class*="text-slate-800"] {
    color: var(--text-primary, #e2e8f0) !important;
}

[data-mode="dark"] .text-slate-700,
[data-mode="dark"] [class*="text-slate-700"] {
    color: var(--text-secondary, #cbd5e1) !important;
}

[data-mode="dark"] .text-slate-600,
[data-mode="dark"] [class*="text-slate-600"] {
    color: var(--text-secondary, #94a3b8) !important;
}

[data-mode="dark"] .text-slate-500,
[data-mode="dark"] [class*="text-slate-500"] {
    color: var(--text-muted, #64748b) !important;
}

[data-mode="dark"] .text-gray-900,
[data-mode="dark"] [class*="text-gray-900"] {
    color: var(--text-primary, #e2e8f0) !important;
}

[data-mode="dark"] .text-gray-600,
[data-mode="dark"] [class*="text-gray-600"] {
    color: var(--text-secondary, #94a3b8) !important;
}

/* Border colors */
[data-mode="dark"] .border-slate-100,
[data-mode="dark"] [class*="border-slate-100"] {
    border-color: var(--border-primary, #334155) !important;
}

[data-mode="dark"] .border-gray-200,
[data-mode="dark"] [class*="border-gray-200"] {
    border-color: var(--border-primary, #334155) !important;
}

[data-mode="dark"] .border-gray-100,
[data-mode="dark"] [class*="border-gray-100"] {
    border-color: var(--border-secondary, #1e293b) !important;
}

/* View toggle buttons */
[data-mode="dark"] button[class*="rounded"][class*="border"] {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-mode="dark"] button[class*="rounded"][class*="border"]:hover {
    background-color: var(--bg-tertiary, #334155);
    color: var(--text-primary, #e2e8f0);
}

/* Pagination */
[data-mode="dark"] .pagination a,
[data-mode="dark"] .pagination span {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
    color: var(--text-secondary, #94a3b8);
}

[data-mode="dark"] .pagination a:hover {
    background-color: var(--bg-tertiary, #334155);
    color: var(--text-primary, #e2e8f0);
}

/* Modal & Dropdown backgrounds */
[data-mode="dark"] .modal-content,
[data-mode="dark"] .dropdown-menu {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
}

/* Theme panel in dark mode */
[data-mode="dark"] #theme-panel-content {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] #theme-panel-content h4 {
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] #theme-panel-content button[data-set-mode] {
    background-color: var(--bg-tertiary, #334155);
    border-color: var(--border-primary, #475569);
    color: var(--text-secondary, #94a3b8);
}

[data-mode="dark"] #theme-panel-content button[data-set-mode]:hover {
    background-color: var(--bg-primary, #0f172a);
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] #theme-panel-toggle {
    background-color: var(--bg-secondary, #1e293b);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] #theme-panel-toggle svg {
    color: var(--text-secondary, #94a3b8);
}

/* Category sidebar */
[data-mode="dark"] .category-sidebar {
    background: var(--card-bg, #1e293b);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] .category-sidebar-header {
    color: var(--text-primary, #e2e8f0);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] .category-item {
    color: var(--text-secondary, #94a3b8);
    border-color: var(--border-secondary, #1e293b);
}

[data-mode="dark"] .category-item:hover {
    background: var(--bg-tertiary, #334155);
    color: var(--text-primary, #e2e8f0);
}

/* Benefits bar */
[data-mode="dark"] .benefits-bar {
    background: var(--card-bg, #1e293b);
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] .benefit-item h4 {
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] .benefit-item p {
    color: var(--text-muted, #64748b);
}

/* Section titles */
[data-mode="dark"] .section-title {
    color: var(--text-primary, #e2e8f0);
}

/* Mobile menu in dark mode */
[data-mode="dark"] .mobile-menu {
    background: var(--bg-secondary, #1e293b);
}

[data-mode="dark"] .mobile-menu a {
    color: var(--text-secondary, #94a3b8);
    border-color: var(--border-secondary, #334155);
}

[data-mode="dark"] .mobile-menu a:hover {
    color: var(--text-primary, #e2e8f0);
}

/* ============================================
   DARK MODE - Account Pages & Forms
   ============================================ */

/* Account sidebar */
[data-mode="dark"] aside,
[data-mode="dark"] .account-sidebar {
    background: var(--card-bg, #1e293b) !important;
}

/* All white backgrounds to dark */
[data-mode="dark"] .bg-white,
[data-mode="dark"] [class*="bg-white"] {
    background-color: var(--card-bg, #1e293b) !important;
}

/* Slate backgrounds */
[data-mode="dark"] .bg-slate-50,
[data-mode="dark"] [class*="bg-slate-50"] {
    background-color: var(--bg-primary, #0f172a) !important;
}

[data-mode="dark"] .bg-slate-100,
[data-mode="dark"] [class*="bg-slate-100"] {
    background-color: var(--bg-secondary, #1e293b) !important;
}

[data-mode="dark"] .bg-slate-200,
[data-mode="dark"] [class*="bg-slate-200"] {
    background-color: var(--bg-tertiary, #334155) !important;
}

/* Gray backgrounds */
[data-mode="dark"] .bg-gray-50,
[data-mode="dark"] [class*="bg-gray-50"] {
    background-color: var(--bg-primary, #0f172a) !important;
}

[data-mode="dark"] .bg-gray-100,
[data-mode="dark"] [class*="bg-gray-100"] {
    background-color: var(--bg-secondary, #1e293b) !important;
}

/* Cards, panels, sections */
[data-mode="dark"] .rounded-xl,
[data-mode="dark"] .rounded-2xl,
[data-mode="dark"] .rounded-lg {
    border-color: var(--border-primary, #334155);
}

[data-mode="dark"] [class*="shadow-sm"],
[data-mode="dark"] [class*="shadow-lg"] {
    --tw-shadow-color: rgba(0, 0, 0, 0.3);
}

/* Form inputs */
[data-mode="dark"] input,
[data-mode="dark"] textarea,
[data-mode="dark"] select {
    background-color: var(--bg-tertiary, #334155) !important;
    border-color: var(--border-primary, #475569) !important;
    color: var(--text-primary, #e2e8f0) !important;
}

[data-mode="dark"] input::placeholder,
[data-mode="dark"] textarea::placeholder {
    color: var(--text-muted, #64748b) !important;
}

[data-mode="dark"] input:focus,
[data-mode="dark"] textarea:focus,
[data-mode="dark"] select:focus {
    border-color: var(--accent-500, #0ea5e9) !important;
}

/* Labels */
[data-mode="dark"] label {
    color: var(--text-secondary, #cbd5e1);
}

/* Links */
[data-mode="dark"] a:not(.btn):not([class*="bg-"]) {
    color: inherit;
}

[data-mode="dark"] a[class*="text-cyan"],
[data-mode="dark"] a[class*="text-blue"],
[data-mode="dark"] a.text-accent {
    color: var(--accent-500, #0ea5e9) !important;
}

/* Badges and tags */
[data-mode="dark"] [class*="bg-green-100"],
[data-mode="dark"] [class*="bg-emerald-100"] {
    background-color: rgba(16, 185, 129, 0.2) !important;
}

[data-mode="dark"] [class*="bg-yellow-100"],
[data-mode="dark"] [class*="bg-amber-100"] {
    background-color: rgba(245, 158, 11, 0.2) !important;
}

[data-mode="dark"] [class*="bg-red-100"],
[data-mode="dark"] [class*="bg-rose-100"] {
    background-color: rgba(239, 68, 68, 0.2) !important;
}

[data-mode="dark"] [class*="bg-blue-100"],
[data-mode="dark"] [class*="bg-cyan-100"] {
    background-color: rgba(14, 165, 233, 0.2) !important;
}

/* Hover states for list items */
[data-mode="dark"] [class*="hover:bg-slate-50"]:hover,
[data-mode="dark"] [class*="hover:bg-gray-50"]:hover {
    background-color: var(--bg-tertiary, #334155) !important;
}

[data-mode="dark"] [class*="hover:bg-slate-100"]:hover,
[data-mode="dark"] [class*="hover:bg-gray-100"]:hover {
    background-color: var(--bg-tertiary, #334155) !important;
}

/* Dividers */
[data-mode="dark"] hr,
[data-mode="dark"] [class*="divide-"] > * {
    border-color: var(--border-primary, #334155);
}

/* Tables */
[data-mode="dark"] table {
    background-color: var(--card-bg, #1e293b);
}

[data-mode="dark"] th {
    background-color: var(--bg-tertiary, #334155);
    color: var(--text-primary, #e2e8f0);
}

[data-mode="dark"] td {
    border-color: var(--border-primary, #334155);
    color: var(--text-secondary, #cbd5e1);
}

[data-mode="dark"] tr:hover {
    background-color: var(--bg-tertiary, #334155);
}

/* Stat cards */
[data-mode="dark"] [class*="rounded"][class*="p-"] {
    background-color: var(--card-bg, #1e293b);
}

/* Account menu items */
[data-mode="dark"] aside nav a,
[data-mode="dark"] aside ul a,
[data-mode="dark"] .account-menu a {
    color: var(--text-secondary, #94a3b8);
    background-color: transparent !important;
}

[data-mode="dark"] aside nav a:hover,
[data-mode="dark"] aside ul a:hover,
[data-mode="dark"] .account-menu a:hover {
    background-color: var(--bg-tertiary, #334155) !important;
    color: var(--text-primary, #e2e8f0);
}

/* Only active item gets accent - check for specific active classes */
[data-mode="dark"] aside nav a[class*="bg-cyan-50"],
[data-mode="dark"] aside ul a[class*="bg-cyan-50"],
[data-mode="dark"] aside nav a[class*="text-cyan-600"],
[data-mode="dark"] aside ul a[class*="text-cyan-600"] {
    background-color: rgba(14, 165, 233, 0.15) !important;
    color: var(--accent-500, #0ea5e9) !important;
}

/* Icon boxes */
[data-mode="dark"] [class*="bg-slate-100"][class*="rounded"] {
    background-color: var(--bg-tertiary, #334155) !important;
}

/* Order status badges */
[data-mode="dark"] [class*="border"][class*="text-green"] {
    border-color: var(--color-success, #10b981) !important;
    color: var(--color-success, #10b981) !important;
}

[data-mode="dark"] [class*="border"][class*="text-yellow"],
[data-mode="dark"] [class*="border"][class*="text-amber"] {
    border-color: var(--color-warning, #f59e0b) !important;
    color: var(--color-warning, #f59e0b) !important;
}

/* Quick action cards at bottom */
[data-mode="dark"] [class*="border-2"][class*="rounded-xl"] {
    background-color: var(--card-bg, #1e293b) !important;
    border-color: var(--border-primary, #334155) !important;
}

[data-mode="dark"] [class*="border-2"][class*="rounded-xl"]:hover {
    border-color: var(--accent-500, #0ea5e9) !important;
}

/* Red/logout text */
[data-mode="dark"] [class*="text-red"],
[data-mode="dark"] [class*="text-rose"] {
    color: #f87171 !important;
}

/* Hero banner button - both light and dark modes */
.hero-btn {
    background: rgba(255, 255, 255, 0.15) !important;
    backdrop-filter: blur(10px);
    color: white !important;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
    padding: 0.875rem 2rem;
    border-radius: 12px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: all 0.2s ease;
}

.hero-btn:hover {
    background: rgba(255, 255, 255, 0.25) !important;
    border-color: rgba(255, 255, 255, 0.5) !important;
    transform: translateY(-2px);
}

/* ============================================
   REAL ESTATE / CATALOG TEMPLATE STYLES
   ============================================ */

/* Property Cards */
.property-card {
    border: 1px solid var(--border);
    transition: all var(--transition);
}

.property-card:hover {
    border-color: var(--accent-300);
}

[data-mode="dark"] .property-card {
    background: var(--color-slate-800);
    border-color: var(--color-slate-700);
}

[data-mode="dark"] .property-card:hover {
    border-color: var(--accent-500);
}

[data-mode="dark"] .property-card h3 {
    color: var(--color-slate-100);
}

[data-mode="dark"] .property-card .text-gray-500,
[data-mode="dark"] .property-card .text-gray-600 {
    color: var(--color-slate-400) !important;
}

[data-mode="dark"] .property-card .text-gray-900 {
    color: var(--color-slate-100) !important;
}

[data-mode="dark"] .property-card .border-t {
    border-color: var(--color-slate-700);
}

/* Testimonial Cards */
.testimonial-card {
    border: 1px solid transparent;
    transition: all var(--transition);
}

.testimonial-card:hover {
    border-color: var(--accent-200);
    box-shadow: var(--shadow-lg);
}

[data-mode="dark"] .testimonial-card {
    background: var(--color-slate-800);
    border-color: var(--color-slate-700);
}

[data-mode="dark"] .testimonial-card:hover {
    border-color: var(--accent-500);
}

[data-mode="dark"] .testimonial-card .text-gray-700 {
    color: var(--color-slate-300) !important;
}

[data-mode="dark"] .testimonial-card .text-gray-900 {
    color: var(--color-slate-100) !important;
}

[data-mode="dark"] .testimonial-card .text-gray-500 {
    color: var(--color-slate-400) !important;
}

/* Service Cards */
.service-card {
    border: 1px solid transparent;
    transition: all var(--transition);
}

[data-mode="dark"] .service-card {
    background: var(--color-slate-800);
    border-color: var(--color-slate-700);
}

[data-mode="dark"] .service-card:hover {
    background: var(--color-slate-700);
    border-color: var(--accent-500);
}

[data-mode="dark"] .service-card h3 {
    color: var(--color-slate-100);
}

[data-mode="dark"] .service-card p {
    color: var(--color-slate-400);
}

/* Hero button primary (solid white) */
.hero-btn-primary {
    background: rgba(255, 255, 255, 0.95) !important;
    color: var(--accent-800, #155e75) !important;
    font-weight: 700;
    transition: all 0.2s ease;
    -webkit-text-fill-color: var(--accent-800, #155e75);
}

.hero-btn-primary:hover {
    background: white !important;
    color: var(--accent-900, #164e63) !important;
    -webkit-text-fill-color: var(--accent-900, #164e63);
    transform: translateY(-2px);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

[data-mode="dark"] .hero-btn-primary {
    background: white !important;
    color: var(--accent-800, #155e75) !important;
    -webkit-text-fill-color: var(--accent-800, #155e75);
}

[data-mode="dark"] .hero-btn-primary:hover {
    background: var(--color-slate-100) !important;
    color: var(--accent-900, #164e63) !important;
    -webkit-text-fill-color: var(--accent-900, #164e63);
}

/* Stats gradient text */
.text-gradient {
    background: var(--theme-gradient, linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Text accent utility */
.text-accent {
    color: var(--accent-500, #0ea5e9);
}

.text-accent:hover {
    color: var(--accent-600, #0891b2);
}

[data-mode="dark"] .text-accent {
    color: var(--accent-400, #22d3ee);
}

[data-mode="dark"] .text-accent:hover {
    color: var(--accent-300, #67e8f9);
}

/* Form inputs dark mode */
[data-mode="dark"] input,
[data-mode="dark"] select,
[data-mode="dark"] textarea {
    background: var(--color-slate-700);
    border-color: var(--color-slate-600);
    color: var(--color-slate-100);
}

[data-mode="dark"] input::placeholder,
[data-mode="dark"] textarea::placeholder {
    color: var(--color-slate-400);
}

[data-mode="dark"] input:focus,
[data-mode="dark"] select:focus,
[data-mode="dark"] textarea:focus {
    border-color: var(--accent-500);
    outline: none;
    box-shadow: 0 0 0 3px rgba(var(--accent-rgb, 14, 165, 233), 0.2);
}

[data-mode="dark"] label {
    color: var(--color-slate-200);
}

/* CTA section forms in dark mode should stay light */
.bg-gradient input,
.bg-gradient select,
.bg-gradient textarea {
    background: white;
    border-color: #e2e8f0;
    color: #1a1a2e;
}

.bg-gradient label {
    color: #374151;
}

/* Mobile menu dark mode */
[data-mode="dark"] #mobile-menu {
    background: var(--color-slate-800);
    border-left: 1px solid var(--color-slate-700);
}

[data-mode="dark"] #mobile-menu .border-b {
    border-color: var(--color-slate-700);
}

[data-mode="dark"] #mobile-menu a {
    color: var(--color-slate-200);
}

[data-mode="dark"] #mobile-menu a:hover {
    background: var(--color-slate-700);
}

/* Section backgrounds dark mode */
[data-mode="dark"] .bg-gray-50,
[data-mode="dark"] section.bg-gray-50 {
    background: var(--color-slate-900) !important;
}

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

/* Contact form card in dark mode */
[data-mode="dark"] .bg-white.rounded-2xl {
    background: var(--color-slate-800) !important;
    border: 1px solid var(--color-slate-700);
}

[data-mode="dark"] .bg-white.rounded-2xl h3 {
    color: var(--color-slate-100);
}

/* Filter tabs dark mode */
[data-mode="dark"] button.bg-white {
    background: var(--color-slate-800) !important;
    border-color: var(--color-slate-600);
    color: var(--color-slate-200);
}

[data-mode="dark"] button.bg-white:hover {
    background: var(--color-slate-700) !important;
}

/* Section titles dark mode */
[data-mode="dark"] h2.text-gray-900,
[data-mode="dark"] h3.text-gray-900 {
    color: var(--color-slate-100) !important;
}

[data-mode="dark"] p.text-gray-600 {
    color: var(--color-slate-400) !important;
}

/* How I work section line */
[data-mode="dark"] .bg-gradient.h-0\.5 {
    opacity: 0.5;
}

/* Logo switching for light/dark mode */
.logo-light {
    display: block;
}

.logo-dark {
    display: none;
}

[data-mode="dark"] .logo-light {
    display: none;
}

[data-mode="dark"] .logo-dark {
    display: block;
}

/* E-book section dark mode */
[data-mode="dark"] #ebook {
    background: var(--color-slate-800);
}

[data-mode="dark"] #ebook h2 {
    color: var(--color-slate-100);
}

[data-mode="dark"] #ebook p {
    color: var(--color-slate-400);
}

[data-mode="dark"] #ebook .text-gray-700 {
    color: var(--color-slate-300) !important;
}

[data-mode="dark"] #ebook img {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}
