/* Professional Dashboard Design System - Enhanced Smart Version */

/* Font Import */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* Enhanced Overview Dashboard Styles */
@import url('./public/css/overview-enhanced.css');

/* Smart Dynamic Sales Dashboard Styles */
@import url('./public/css/sales.css');


/* Final Polish & UX Enhancements */
@import url('./public/css/final-polish.css');

/* CSS Variables for Design System */
:root {
    /* === COLOR PALETTE === */
    /* Background & Surface */
    --background: hsl(0, 0%, 99%);
    --surface: hsl(0, 0%, 100%);
    --surface-secondary: hsl(210, 20%, 98%);
    --surface-tertiary: hsl(210, 20%, 96%);

    /* Text & Foreground */
    --foreground: hsl(210, 11%, 15%);
    --foreground-secondary: hsl(210, 8%, 35%);
    --foreground-tertiary: hsl(210, 6%, 55%);
    --foreground-muted: hsl(210, 4%, 65%);

    /* Primary Brand Colors */
    --primary: hsl(210, 100%, 50%);
    --primary-hover: hsl(210, 100%, 45%);
    --primary-active: hsl(210, 100%, 40%);
    --primary-foreground: hsl(0, 0%, 100%);

    /* Secondary Colors */
    --secondary: hsl(210, 25%, 92%);
    --secondary-hover: hsl(210, 25%, 88%);
    --secondary-foreground: hsl(210, 11%, 15%);

    /* Accent & Status Colors */
    --accent: hsl(210, 100%, 60%);
    --accent-hover: hsl(210, 100%, 55%);
    --accent-foreground: hsl(0, 0%, 100%);

    --success: hsl(142, 76%, 36%);
    --success-light: hsl(142, 76%, 95%);
    --warning: hsl(38, 92%, 50%);
    --warning-light: hsl(38, 92%, 95%);
    --destructive: hsl(0, 84%, 60%);
    --destructive-light: hsl(0, 84%, 95%);

    /* UI Elements */
    --border: hsl(210, 20%, 90%);
    --border-hover: hsl(210, 20%, 85%);
    --input: hsl(210, 20%, 94%);
    --input-border: hsl(210, 20%, 88%);
    --ring: hsl(210, 100%, 50%);

    /* Layout Specific */
    --topbar: hsl(0, 0%, 100%);
    --topbar-border: hsl(210, 20%, 90%);
    --sidebar-background: hsl(210, 25%, 98%);
    --sidebar-border: hsl(210, 20%, 92%);
    --sidebar-active: hsl(210, 100%, 50%);
    --sidebar-hover: hsl(210, 25%, 94%);

    /* Widget & Card */
    --card: hsl(0, 0%, 100%);
    --card-border: hsl(210, 20%, 92%);
    --card-shadow: hsl(210, 20%, 85%);

    /* Empty States */
    --empty-background: hsl(210, 25%, 98%);
    --empty-foreground: hsl(210, 6%, 55%);
    --empty-border: hsl(210, 20%, 88%);

    /* Overlays */
    --overlay: hsl(210, 11%, 15%);
    --backdrop: hsl(210, 11%, 15%);

    /* === SPACING SCALE === */
    --space-1: 0.25rem;
    /* 4px */
    --space-2: 0.5rem;
    /* 8px */
    --space-3: 0.75rem;
    /* 12px */
    --space-4: 1rem;
    /* 16px */
    --space-6: 1.5rem;
    /* 24px */
    --space-8: 2rem;
    /* 32px */
    --space-12: 3rem;
    /* 48px */
    --space-16: 4rem;
    /* 64px */

    /* === TYPOGRAPHY === */
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-size-xs: 0.75rem;
    /* 12px */
    --font-size-sm: 0.875rem;
    /* 14px */
    --font-size-base: 1rem;
    /* 16px */
    --font-size-lg: 1.125rem;
    /* 18px */
    --font-size-xl: 1.25rem;
    /* 20px */
    --font-size-2xl: 1.5rem;
    /* 24px */
    --font-size-3xl: 1.875rem;
    /* 30px */
    --font-size-4xl: 2.25rem;
    /* 36px */

    --line-height-tight: 1.25;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;

    /* === EFFECTS === */
    --radius-sm: 0.375rem;
    /* 6px */
    --radius: 0.5rem;
    /* 8px */
    --radius-lg: 0.75rem;
    /* 12px */
    --radius-xl: 1rem;
    /* 16px */

    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);

    /* === MOTION === */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 250ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);

    /* === GRID SYSTEM === */
    --grid-cols-desktop: 12;
    --grid-cols-tablet: 8;
    --grid-cols-mobile: 4;
    --grid-gap: 1.5rem;
    /* 24px */
    --container-padding: 1.5rem;
    /* 24px */
}

/* Dark Mode */
@media (prefers-color-scheme: dark) {
    :root {
        /* === DARK MODE OVERRIDES === */
        --background: hsl(210, 11%, 4%);
        --surface: hsl(210, 11%, 6%);
        --surface-secondary: hsl(210, 11%, 8%);
        --surface-tertiary: hsl(210, 11%, 10%);

        --foreground: hsl(210, 6%, 90%);
        --foreground-secondary: hsl(210, 6%, 75%);
        --foreground-tertiary: hsl(210, 6%, 60%);
        --foreground-muted: hsl(210, 6%, 45%);

        --primary: hsl(210, 100%, 65%);
        --primary-hover: hsl(210, 100%, 70%);
        --primary-active: hsl(210, 100%, 60%);
        --primary-foreground: hsl(210, 11%, 4%);

        --secondary: hsl(210, 11%, 12%);
        --secondary-hover: hsl(210, 11%, 16%);
        --secondary-foreground: hsl(210, 6%, 90%);

        --border: hsl(210, 11%, 15%);
        --border-hover: hsl(210, 11%, 20%);
        --input: hsl(210, 11%, 10%);
        --input-border: hsl(210, 11%, 15%);

        --topbar: hsl(210, 11%, 6%);
        --topbar-border: hsl(210, 11%, 12%);
        --sidebar-background: hsl(210, 11%, 4%);
        --sidebar-border: hsl(210, 11%, 10%);
        --sidebar-active: hsl(210, 100%, 65%);
        --sidebar-hover: hsl(210, 11%, 8%);

        --card: hsl(210, 11%, 6%);
        --card-border: hsl(210, 11%, 12%);
        --card-shadow: hsl(0, 0%, 0%);

        --empty-background: hsl(210, 11%, 8%);
        --empty-foreground: hsl(210, 6%, 55%);
        --empty-border: hsl(210, 11%, 15%);
    }
}

/* === BASE STYLES === */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-family);
    background-color: var(--background);
    color: var(--foreground);
    line-height: var(--line-height-normal);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* === LAYOUT === */
.dashboard-container {
    min-height: 100vh;
    position: relative;
    /* Changed from flex to relative positioning to prevent stacking context issues with fixed elements */
}

/* === TOPBAR === */
.topbar {
    height: 4rem;
    background-color: var(--topbar);
    border-bottom: 1px solid var(--topbar-border);
    padding: 0 var(--space-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 1000;
    backdrop-filter: blur(10px);
    box-sizing: border-box;
}

@media (prefers-color-scheme: dark) {
    .topbar {
        background: var(--topbar);
        backdrop-filter: blur(10px);
    }
}

/* RTL Topbar Color Fix */
.rtl .topbar {
    background: var(--topbar) !important;
    background-color: var(--topbar) !important;
}

@media (prefers-color-scheme: dark) {
    .rtl .topbar {
        background: var(--topbar) !important;
        background-color: var(--topbar) !important;
    }
}

/* OVERRIDE RTL.CSS - Higher specificity mobile fixes */
@media (max-width: 768px) {

    /* Force override RTL.css mobile topbar */
    body.rtl .topbar,
    html.rtl .topbar,
    .rtl .topbar {
        background: var(--topbar) !important;
        background-color: var(--topbar) !important;
        direction: rtl !important;
        height: 4rem !important;
        padding: 0 var(--space-3) !important;
        /* Override any RTL.css background overrides */
        background-image: none !important;
    }

    /* Critical: Override RTL.css white background on mobile */
    body.rtl .topbar,
    html.rtl .topbar {
        background: var(--topbar) !important;
        background-color: var(--topbar) !important;
    }

    @media (prefers-color-scheme: dark) {

        body.rtl .topbar,
        html.rtl .topbar,
        .rtl .topbar {
            background: var(--topbar) !important;
            background-color: var(--topbar) !important;
        }
    }

    /* Force hide search and brand text on mobile RTL */
    body.rtl .search-container,
    html.rtl .search-container,
    .rtl .search-container {
        display: none !important;
    }

    body.rtl .brand-text,
    html.rtl .brand-text,
    .rtl .brand-text {
        display: none !important;
    }

    /* DISABLED - Conflicts with index.html RTL mobile rules */
    /*
    Override RTL.css topbar layout
    body.rtl .topbar-left,
    html.rtl .topbar-left,
    .rtl .topbar-left {
        order: 2 !important;
        direction: rtl !important;
        flex-direction: row !important;
    }

    body.rtl .topbar-right,
    html.rtl .topbar-right,
    .rtl .topbar-right {
        order: 1 !important;
        direction: rtl !important;
        flex-direction: row-reverse !important;
    }
    */

    /* Critical: Override any white background from RTL.css */
    @media (max-width: 768px) {

        body.rtl .topbar,
        html.rtl .topbar,
        .rtl .topbar {
            background: var(--topbar) !important;
            background-color: var(--topbar) !important;
            /* Force override the rgba(255, 255, 255, 0.98) from RTL.css */
        }
    }

    /* Override RTL.css 3.75rem height specification */
    body.rtl .topbar,
    html.rtl .topbar,
    .rtl .topbar {
        height: 4rem !important;
        min-height: 4rem !important;
        max-height: 4rem !important;
    }
}

.topbar-left {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

.sidebar-toggle {
    background: none;
    border: none;
    padding: var(--space-2);
    color: var(--foreground-secondary);
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.sidebar-toggle:hover {
    color: var(--foreground);
    background-color: var(--secondary);
    transform: scale(1.05);
}

.sidebar-toggle.active {
    color: var(--primary);
    background-color: var(--secondary);
}

.brand {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.brand-icon {
    width: 2rem;
    height: 2rem;
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-foreground);
    font-weight: 700;
    font-size: var(--font-size-sm);
    box-shadow: var(--shadow-md);
}

.brand-text {
    font-weight: 700;
    color: var(--foreground);
    font-size: var(--font-size-lg);
}

.search-container {
    flex: 1;
    max-width: 28rem;
    margin: 0 var(--space-4);
}

.search-wrapper {
    position: relative;
}

.search-icon {
    position: absolute;
    left: var(--space-3);
    top: 50%;
    transform: translateY(-50%);
    width: 1rem;
    height: 1rem;
    color: var(--foreground-muted);
}

.search-input {
    width: 100%;
    padding: var(--space-2) var(--space-3) var(--space-2) 2.25rem;
    background-color: var(--input);
    border: 1px solid var(--input-border);
    border-radius: var(--radius-lg);
    color: var(--foreground-secondary);
    font-size: var(--font-size-sm);
    transition: all var(--transition-fast);
}

/* Desktop RTL: mirror the search field to match LTR styling */
html[dir='rtl'] .search-wrapper .search-icon {
    left: auto;
    right: var(--space-3);
}

html[dir='rtl'] .search-input {
    direction: rtl;
    text-align: right;
    padding: var(--space-2) 2.25rem var(--space-2) var(--space-3);
}

.search-input:focus {
    outline: none;
    border-color: var(--ring);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    transform: scale(1.02);
}

.search-input::placeholder {
    color: var(--foreground-muted);
}

.topbar-right {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

/* === TOPBAR MOBILE SEARCH (RTL/LTR Consistent) === */
.topbar-search-mobile {
    display: none;
}

@media (max-width: 1024px) {
    .topbar-search-mobile {
        display: block;
        flex: 0 1 auto;
        /* Prevent excessive growth */
        max-width: 280px;
        /* Reasonable max width */
        min-width: 160px;
        /* Minimum usable width */
        margin: 0 var(--space-1);
        /* Reduced margin */
    }

    .topbar-search-input-wrapper {
        position: relative;
        display: flex;
        align-items: center;
        background: var(--input);
        border: 1px solid var(--input-border);
        border-radius: var(--radius-lg);
        height: 2rem;
        /* match LTR slimmer look */
        box-sizing: border-box;
    }

    .topbar-search-input-wrapper .search-icon {
        position: absolute;
        inset-inline-start: 0.75rem;
        /* logical start -> flips in RTL */
        top: 50%;
        transform: translateY(-50%);
        width: 1rem;
        height: 1rem;
        color: var(--foreground-muted);
        pointer-events: none;
    }

    .topbar-search-input-wrapper .search-input {
        width: 100%;
        border: none;
        outline: none;
        background: transparent;
        color: var(--foreground-secondary);
        font-size: var(--font-size-sm);
        padding-block: 0.25rem;
        /* tighter vertical padding */
        padding-inline-start: 2.25rem;
        /* leave room for icon (swaps in RTL) */
        padding-inline-end: var(--space-3);
        border-radius: var(--radius-lg);
    }

    html[dir='rtl'] .topbar-search-input-wrapper .search-input {
        direction: rtl;
        text-align: right;
    }
}

/* Ensure LTR topbar always follows the screen */
html[dir='ltr'] .topbar {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
}

.topbar-btn {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--foreground-secondary);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: all var(--transition-fast);
}

.topbar-btn:hover {
    background-color: var(--secondary);
    transform: translateY(-1px);
}

.notification-btn {
    position: relative;
    background: none;
    border: none;
    padding: var(--space-2);
    color: var(--foreground-secondary);
    cursor: pointer;
    border-radius: var(--radius);
    transition: all var(--transition-fast);
}

.notification-btn:hover {
    color: var(--foreground);
    background-color: var(--secondary);
    transform: scale(1.05);
}

.notification-dot {
    position: absolute;
    top: -2px;
    right: -2px;
    width: 0.75rem;
    height: 0.75rem;
    background-color: var(--destructive);
    border-radius: 50%;
    /* Stop pulsing on topbar dot */
    animation: none !important;
}

.user-btn {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    background: none;
    border: none;
    color: var(--foreground-secondary);
    cursor: pointer;
    border-radius: var(--radius);
    transition: all var(--transition-fast);
}

.user-btn:hover {
    color: var(--foreground);
    background-color: var(--secondary);
}

.user-avatar {
    width: 2rem;
    height: 2rem;
    background: linear-gradient(135deg, var(--surface-secondary) 0%, var(--surface-tertiary) 100%);
    border: 1px solid var(--border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.icon {
    width: 1.25rem;
    height: 1.25rem;
}

.chevron-icon {
    width: 0.75rem;
    height: 0.75rem;
}

/* === MAIN LAYOUT === */
.main-layout {
    flex: 1;
    display: flex;
    overflow: visible;
    /* Layout spacing now handled by main-content margin */
}

/* Content offset next to fixed sidebar */
/* Add a subtle gap between sidebar and content */
:root {
    --sidebar-gap: 0.75rem;
}

.sidebar+.main-content {
    margin-left: calc(16rem + var(--sidebar-gap));
    transition: margin-left var(--transition-normal);
}

.sidebar.collapsed+.main-content {
    margin-left: calc(4rem + var(--sidebar-gap));
}

/* Fallback guard: if inline styles strip margins, keep a minimal gap so content never sits under sidebar */
.main-content {
    padding-inline-start: max(var(--sidebar-gap), 0px);
}

/* RTL Layout Fixes */
.rtl .main-layout {
    direction: rtl !important;
}

.rtl .sidebar {
    right: 0 !important;
    left: auto !important;
    border-right: none !important;
    border-left: 1px solid var(--sidebar-border) !important;
}

.rtl .sidebar+.main-content {
    margin-right: calc(16rem + var(--sidebar-gap)) !important;
    margin-left: 0 !important;
    transition: margin-right var(--transition-normal) !important;
}

.rtl .sidebar.collapsed+.main-content {
    margin-right: calc(4rem + var(--sidebar-gap)) !important;
    margin-left: 0 !important;
}

/* RTL Body and container fixes */
.rtl body {
    margin: 0 !important;
    padding: 0 !important;
}

.rtl .dashboard-container {
    margin: 0 !important;
    padding: 0 !important;
    width: 100vw !important;
}

.rtl .topbar {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 var(--space-4) !important;
    box-sizing: border-box !important;
}

/* UNIVERSAL SIDEBAR Z-INDEX OVERRIDE - ALWAYS MAXIMUM */
.sidebar,
.rtl .sidebar,
body.rtl .sidebar,
html.rtl .sidebar,
html[dir="rtl"] .sidebar,
.sidebar.mobile-open,
.sidebar.collapsed {
    z-index: 999 !important;
    /* NUCLEAR OPTION: Maximum possible z-index to always be above backdrop */
}

/* === SIDEBAR === */
.sidebar {
    width: 16rem;
    background-color: var(--sidebar-background);
    border-right: 1px solid var(--sidebar-border);
    display: flex;
    flex-direction: column;
    height: calc(100vh - 4rem);
    transition: width var(--transition-normal);
    position: fixed;
    top: 4rem;
    /* sits just under the topbar */
    left: 0;
    z-index: 100;
    /* MAXIMUM z-index to always be above backdrop */
}

.sidebar.collapsed {
    width: 4rem;
}

/* RTL Layout Support */
.rtl .sidebar {
    right: 0;
    left: auto;
    border-right: none;
    border-left: 1px solid var(--sidebar-border);
}

.rtl .sidebar+.main-content {
    margin-right: 280px;
    margin-left: 0;
}

.rtl .sidebar.collapsed+.main-content {
    margin-right: 4rem;
    margin-left: 0;
}

/* RTL Topbar fixes */
.rtl .topbar {
    padding: 0 var(--space-4);
}

.rtl .topbar-left {
    margin-left: auto;
    margin-right: 0;
}

.rtl .topbar-right {
    margin-right: auto;
    margin-left: 0;
}

/* RTL Body and container fixes to eliminate gaps */
.rtl body {
    margin: 0;
    padding: 0;
}

.rtl .dashboard-container {
    margin: 0;
    padding: 0;
}

/* RTL Navigation */
.rtl .nav-item {
    text-align: right;
}

.rtl .nav-icon {
    margin-left: 12px;
    margin-right: 0;
}

/* RTL Forms and Inputs */
.rtl input,
.rtl textarea,
.rtl select {
    text-align: right;
}

.rtl input[type="number"] {
    text-align: left;
    /* Numbers stay LTR */
}

/* RTL Tables */
.rtl table {
    direction: rtl;
}

.rtl th,
.rtl td {
    text-align: right;
}

/* RTL Currency and numbers */
.rtl .currency,
.rtl .number {
    direction: ltr;
    unicode-bidi: embed;
}

/* Padding adjustment handled by .main-layout.sidebar-collapsed class via JS */

.sidebar-nav {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding: var(--space-1) var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    max-height: calc(100vh - 120px);
}

/* When collapsed, prevent horizontal overflow */
.sidebar.collapsed .sidebar-nav {
    overflow-x: hidden;
    overflow-y: auto;
    padding: var(--space-1) 0;
}

.nav-section-title {
    padding: 0 var(--space-3);
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--foreground-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-1);
}

.nav-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.nav-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    text-decoration: none;
    color: var(--foreground-secondary);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    height: 2.5rem;
    position: relative;
    overflow: hidden;
}

.nav-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--primary);
    transform: scaleY(0);
    transition: transform var(--transition-fast);
}

.nav-item:hover {
    color: var(--foreground);
    background-color: var(--sidebar-hover);
    transform: translateX(4px);
}

.nav-item:hover::before {
    transform: scaleY(1);
}

.nav-item.active {
    background: linear-gradient(135deg, var(--sidebar-active) 0%, var(--primary-hover) 100%);
    color: var(--primary-foreground);
    box-shadow: var(--shadow-md);
}

.nav-item.active::before {
    transform: scaleY(1);
    background: var(--primary-foreground);
}

.nav-item.active:hover {
    background: linear-gradient(135deg, var(--primary-hover) 0%, var(--sidebar-active) 100%);
    transform: translateX(0);
}

.nav-icon {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
}

.nav-label {
    flex: 1;
    text-align: left;
    font-weight: 500;
}

.nav-badge {
    margin-left: auto;
    background: linear-gradient(135deg, var(--destructive) 0%, #ff6b6b 100%);
    color: white;
    font-size: var(--font-size-xs);
    padding: 0.125rem var(--space-2);
    border-radius: 9999px;
    font-weight: 600;
    box-shadow: var(--shadow-sm);
    /* Stop pulsing on sidebar/topbar badge */
    animation: none !important;
}

.sidebar-footer {
    padding: 0;
    margin-top: -20px;
    border-top: 1px solid var(--sidebar-border);
}

.collapse-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-1) var(--space-2);
    margin: 0;
    background: none;
    border: none;
    color: var(--foreground-secondary);
    cursor: pointer;
    border-radius: var(--radius);
    transition: all var(--transition-fast);
}

.collapse-btn:hover {
    color: var(--foreground);
    background-color: var(--sidebar-hover);
}

.collapse-text {
    font-size: var(--font-size-sm);
    font-weight: 500;
}

.chevron-right {
    width: 1rem;
    height: 1rem;
    transition: transform var(--transition-normal);
}

/* Collapsed sidebar visual adjustments */
/* Simple hide of labels & badges when collapsed for stability */
.sidebar.collapsed .nav-label,
.sidebar.collapsed .nav-badge {
    display: none;
}

.sidebar.collapsed .nav-item {
    justify-content: center;
    padding: var(--space-2);
    width: 100%;
    overflow: hidden;
}

.sidebar.collapsed .nav-item {
    gap: 0;
}

.sidebar.collapsed .nav-item .nav-icon {
    margin: 0 auto;
}

.sidebar.collapsed .nav-item svg {
    margin: 0;
}

.sidebar.collapsed .nav-item:hover {
    transform: none;
}

.sidebar.collapsed .nav-section-title {
    display: none;
}

/* Collapse button becomes icon-only */
/* Hide collapse text entirely when collapsed */
.sidebar.collapsed .collapse-text {
    display: none;
}

.sidebar.collapsed .collapse-btn {
    justify-content: center;
    width: 100%;
    overflow: hidden;
}

.sidebar.collapsed .collapse-btn {
    background: transparent;
    width: 100%;
    height: auto;
    padding: var(--space-2);
    border-radius: var(--radius);
}

.sidebar.collapsed .collapse-btn:hover {
    background: var(--sidebar-hover);
}

.sidebar.collapsed .sidebar-footer {
    padding: 0;
    overflow: hidden;
}

/* Arrow direction: points left when expanded (to collapse), right when collapsed (to expand) */
.sidebar:not(.collapsed) .chevron-right {
    transform: rotate(180deg);
}

/* === MAIN CONTENT === */
.main-content {
    flex: 1;
    /* Removed overflow-y:auto so body scroll drives layout; fixes fixed-position issues in RTL */
    background-color: var(--background);
    transition: margin-left var(--transition-normal);
    padding-top: 4rem;
    /* Account for fixed topbar */
    min-height: calc(100vh - 4rem);
}

/* Provide global scrolling on body instead of nested main-content scrolling */
body {
    overflow-y: auto;
}


/* === PAGE STYLES === */
.page {
    display: none;
    padding: var(--space-8);
    animation: fadeIn 0.3s ease-out;
}

.page.active {
    display: block;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.page-header {
    margin-bottom: var(--space-8);
}

.page-header h1 {
    font-size: var(--font-size-3xl);
    font-weight: 800;
    color: var(--foreground);
    margin-bottom: var(--space-2);
    background: linear-gradient(135deg, var(--foreground) 0%, var(--foreground-secondary) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.page-header p {
    font-size: var(--font-size-base);
    color: var(--foreground-secondary);
    font-weight: 400;
}

/* === KPI CARDS === */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-6);
    margin-bottom: var(--space-8);
}

.kpi-card {
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.smart-kpi {
    background: linear-gradient(135deg, var(--card) 0%, var(--surface-secondary) 100%);
    border: 1px solid var(--card-border);
    position: relative;
}

.smart-kpi::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--primary), transparent);
    opacity: 0.6;
}

.kpi-card.clickable {
    cursor: pointer;
}

.kpi-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
    border-color: var(--border-hover);
}

.smart-kpi:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.1), 0 0 25px rgba(59, 130, 246, 0.1);
}

.kpi-card.alert-kpi {
    border-color: var(--destructive);
    background: linear-gradient(135deg, var(--card) 0%, var(--destructive-light) 100%);
}

.kpi-card.alert-kpi:hover {
    box-shadow: 0 12px 25px rgba(220, 38, 127, 0.2);
}

.kpi-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
}

.kpi-header h3 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--foreground-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.kpi-icon {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--primary);
    opacity: 0.7;
}

.alert-icon {
    color: var(--destructive);
    animation: pulse 2s infinite;
}

.kpi-value {
    font-size: var(--font-size-3xl);
    font-weight: 800;
    color: var(--foreground);
    margin-bottom: var(--space-3);
    line-height: var(--line-height-tight);
}

.alert-value {
    color: var(--destructive);
}

.kpi-trend {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 600;
    margin-bottom: var(--space-4);
}

.kpi-trend.positive {
    color: var(--success);
}

.kpi-trend.negative {
    color: var(--destructive);
}

.trend-arrow {
    font-size: var(--font-size-lg);
    font-weight: 700;
}

.kpi-sparkline {
    height: 20px;
    opacity: 0.7;
}

.alert-badge {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    background: var(--destructive);
    color: white;
    font-size: var(--font-size-xs);
    padding: var(--space-1) var(--space-2);
    border-radius: 9999px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.pulse {
    animation: pulse 2s infinite;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.7;
    }
}

/* === ALERTS BANNER === */
.alerts-banner {
    background: linear-gradient(135deg, var(--warning-light) 0%, var(--destructive-light) 100%);
    border: 1px solid var(--warning);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    margin-bottom: var(--space-6);
    position: relative;
    overflow: hidden;
}

.alerts-banner::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--warning), transparent);
    animation: shimmer 2s infinite;
}

.smart-alert {
    box-shadow: 0 8px 32px rgba(251, 146, 60, 0.15);
    backdrop-filter: blur(10px);
}

.alert-header {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}

.alert-icon-container {
    background: var(--warning);
    color: white;
    padding: var(--space-2);
    border-radius: var(--radius);
    animation: pulse 2s infinite;
}

.alert-banner-icon {
    width: 1.25rem;
    height: 1.25rem;
}

.alert-content {
    flex: 1;
}

.alert-content h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--foreground);
    margin-bottom: var(--space-1);
}

.alert-content p {
    color: var(--foreground-secondary);
    font-size: var(--font-size-sm);
}

.alert-actions {
    display: flex;
    gap: var(--space-2);
}

.alert-btn {
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius);
    font-size: var(--font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    border: none;
}

.alert-btn.primary {
    background: var(--warning);
    color: white;
}

.alert-btn.primary:hover {
    background: var(--warning);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(251, 146, 60, 0.4);
}

.alert-btn.secondary {
    background: transparent;
    color: var(--foreground-secondary);
    border: 1px solid var(--border);
}

.alert-btn.secondary:hover {
    background: var(--secondary);
    transform: translateY(-1px);
}

.alert-items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-3);
}

.alert-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    background: rgba(255, 255, 255, 0.7);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.alert-item:hover {
    background: rgba(255, 255, 255, 0.9);
    transform: translateX(4px);
}

.alert-dot {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 50%;
    flex-shrink: 0;
}

.alert-dot.critical {
    background: var(--destructive);
    animation: pulse 1.5s infinite;
}

.alert-dot.urgent {
    background: var(--warning);
    animation: pulse 2s infinite;
}

.alert-dot.warning {
    background: var(--warning);
}

.alert-text {
    flex: 1;
    font-size: var(--font-size-sm);
    color: var(--foreground);
}

.alert-action {
    font-size: var(--font-size-xs);
    color: var(--foreground-muted);
    font-weight: 500;
}

/* === WIDGETS & CARDS === */
.widgets-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-bottom: var(--space-8);
}

@media (max-width: 1200px) {
    .widgets-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .widgets-grid {
        grid-template-columns: 1fr;
    }
}

.overview-widgets {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    grid-auto-flow: dense;
    gap: var(--space-6);
}

.widget-card {
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.widget-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
    transform: scaleX(0);
    transition: transform var(--transition-fast);
}

.widget-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.widget-card:hover::before {
    transform: scaleX(1);
}

.widget-card.small {
    grid-column: span 1;
}

.widget-card.medium {
    grid-column: span 2;
}

.widget-card.large {
    grid-column: span 3;
}

/* Expanded cash runway widget full-width override */
.forecast-widget.wide {
    grid-column: 1 / -1 !important;
    width: 100%;
}

.forecast-widget.wide .forecast-chart canvas#cashRunwayChart {
    width: 100% !important;
}

/* Runway scenario toggle buttons */
.scenario-toggle-group {
    display: flex;
    gap: 6px;
    background: var(--surface-secondary, #1e2530);
    padding: 4px;
    border-radius: 12px;
    border: 1px solid var(--border, #2a3542);
}

.runway-scenario-btn {
    all: unset;
    cursor: pointer;
    font: 500 11px/1 Inter;
    padding: 6px 10px;
    border-radius: 8px;
    color: var(--foreground-secondary, #94a3b8);
    background: transparent;
    transition: .18s ease;
    position: relative;
}

.runway-scenario-btn:hover {
    color: var(--foreground, #e2e8f0);
    background: rgba(255, 255, 255, .06);
}

.runway-scenario-btn.active {
    background: linear-gradient(135deg, #2563eb, #3b82f6);
    color: #fff;
    box-shadow: 0 4px 12px -4px rgba(37, 99, 235, .55);
}

.runway-scenario-btn:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Major Outflows Widget */
.major-outflows.smart-outflows {
    font-size: 12px;
}

.major-outflows.smart-outflows h4 {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0 0 10px;
    font: 600 14px/1.2 Inter;
}

.major-outflows.smart-outflows .header-icon {
    width: 18px;
    height: 18px;
}

.outflows-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.outflow-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--surface-alt, #142131);
    border: 1px solid var(--border, #1e293b);
    padding: 8px 10px;
    border-radius: 10px;
}

.outflow-item .outflow-date {
    width: 42px;
    text-align: center;
    display: flex;
    flex-direction: column;
    line-height: 1;
    background: #1e2d40;
    border: 1px solid #243447;
    border-radius: 8px;
    padding: 6px 4px;
}

.outflow-item .date-day {
    font: 600 14px Inter;
}

.outflow-item .date-month {
    font-size: 10px;
    color: #94a3b8;
    margin-top: 2px;
}

.outflow-item .outflow-content {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.outflow-item .outflow-description {
    font-weight: 600;
    color: var(--text-primary, #e2e8f0);
    font-size: 12px;
}

.outflow-item .outflow-details {
    font-size: 11px;
    color: #94a3b8;
}

.outflow-item .outflow-amount {
    font-weight: 600;
    font-size: 12px;
}

.outflow-item.urgent {
    border-color: #dc2626;
    box-shadow: 0 0 0 1px #dc2626;
}

.outflow-item.warning {
    border-color: #f59e0b;
    box-shadow: 0 0 0 1px #f59e0b;
}

@media (max-width: 1200px) {
    .widget-card.medium {
        grid-column: span 2;
    }

    .widget-card.large {
        grid-column: span 2;
    }
}

@media (max-width: 768px) {

    .widget-card.small,
    .widget-card.medium,
    .widget-card.large {
        grid-column: span 1;
    }
}

.widget-header {
    padding: var(--space-6);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.widget-title h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--foreground);
    margin-bottom: var(--space-1);
}

.widget-title p {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
}

.widget-content {
    padding: var(--space-6);
}

.widget-controls {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

/* === REVENUE WIDGET === */
.revenue-widget {
    background: linear-gradient(135deg, var(--card) 0%, var(--surface-secondary) 100%);
}

.timeframe-selector {
    display: flex;
    background: var(--surface-secondary);
    border-radius: var(--radius);
    padding: 2px;
}

.timeframe-btn {
    padding: var(--space-1) var(--space-3);
    background: none;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: 500;
    color: var(--foreground-secondary);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.timeframe-btn.active {
    background: var(--primary);
    color: var(--primary-foreground);
    box-shadow: var(--shadow-sm);
}

.timeframe-btn:hover:not(.active) {
    background: var(--secondary);
    color: var(--foreground);
}

.export-btn {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.export-btn:hover {
    background: var(--secondary);
    transform: translateY(-1px);
}

.export-btn svg {
    width: 0.875rem;
    height: 0.875rem;
}

.chart-container {
    padding: var(--space-6);
    position: relative;
}

.revenue-chart,
.runway-chart {
    width: 100%;
    height: 200px;
    background: var(--surface);
    border-radius: var(--radius);
    border: 1px solid var(--border);
}

.chart-tooltip {
    position: absolute;
    background: var(--overlay);
    color: white;
    padding: var(--space-2);
    border-radius: var(--radius);
    font-size: var(--font-size-xs);
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--transition-fast);
    z-index: 10;
}

.chart-legend {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-top: var(--space-4);
    justify-content: center;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
}

.legend-dot {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 50%;
}

.legend-dot.primary {
    background: var(--primary);
}

.legend-dot.secondary {
    background: var(--foreground-muted);
}

/* === PRODUCTS WIDGET === */
.products-widget {
    background: linear-gradient(135deg, var(--card) 0%, var(--success-light) 100%);
}

.view-all-btn {
    background: none;
    border: none;
    color: var(--primary);
    font-size: var(--font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.view-all-btn:hover {
    color: var(--primary-hover);
    transform: translateX(2px);
}

.products-list {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.product-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3);
    background: var(--surface);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 1px solid var(--border);
}

.product-item:hover {
    background: var(--surface-secondary);
    transform: translateX(4px);
    box-shadow: var(--shadow-sm);
}

.product-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.product-name {
    font-weight: 500;
    color: var(--foreground);
    font-size: var(--font-size-sm);
}

.product-revenue {
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
    font-weight: 600;
}

.product-chart {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    min-width: 120px;
}

.progress-bar {
    width: 80px;
    height: 6px;
    background: var(--surface-secondary);
    border-radius: 3px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--success) 0%, var(--primary) 100%);
    border-radius: 3px;
    transition: width var(--transition-slow);
}

.product-percentage {
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
    font-weight: 600;
    min-width: 32px;
    text-align: right;
}

/* === CASH RUNWAY WIDGET === */
.cash-runway-widget {
    background: linear-gradient(135deg, var(--card) 0%, var(--warning-light) 100%);
}

.scenario-btn {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--primary);
    color: var(--primary-foreground);
    border: none;
    border-radius: var(--radius);
    font-size: var(--font-size-xs);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.scenario-btn:hover {
    background: var(--primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

.scenario-btn svg {
    width: 0.875rem;
    height: 0.875rem;
}

.cash-forecast-container {
    padding: var(--space-6);
}

.forecast-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.forecast-metric {
    text-align: center;
    padding: var(--space-3);
    background: var(--surface);
    border-radius: var(--radius);
    border: 1px solid var(--border);
}

.metric-label {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
    margin-bottom: var(--space-1);
}

.metric-value {
    display: block;
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--foreground);
}

.metric-value.safe {
    color: var(--success);
}

.metric-value.warning {
    color: var(--warning);
}

.metric-value.critical {
    color: var(--destructive);
}

.forecast-chart {
    margin-bottom: var(--space-6);
}

.forecast-bands {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.band {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
}

.band-dot {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 50%;
}

.band-dot.safe {
    background: var(--success);
}

.band-dot.warning {
    background: var(--warning);
}

.band-dot.critical {
    background: var(--destructive);
}

.major-outflows {
    background: var(--surface);
    border-radius: var(--radius);
    padding: var(--space-4);
    border: 1px solid var(--border);
}

.major-outflows h4 {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--foreground);
    margin-bottom: var(--space-3);
}

.outflow-item {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--space-3);
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--border);
    align-items: center;
}

.outflow-item:last-child {
    border-bottom: none;
}

.outflow-type {
    font-size: var(--font-size-sm);
    color: var(--foreground);
    font-weight: 500;
}

.outflow-date {
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
}

.outflow-amount {
    font-size: var(--font-size-sm);
    color: var(--foreground);
    font-weight: 600;
    text-align: right;
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

/* Smart Widget Enhancements */
.smart-widget {
    background: linear-gradient(135deg, var(--card) 0%, var(--surface-secondary) 100%);
    border: 1px solid var(--card-border);
    backdrop-filter: blur(10px);
}

.smart-widget::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--primary), transparent);
    opacity: 0.6;
}

/* Alert Widget Animations */
.smart-alert {
    border-left: 4px solid var(--warning);
}

.pulse-alert {
    animation: pulse-glow 2s infinite;
}

@keyframes pulse-glow {

    0%,
    100% {
        box-shadow: var(--shadow-sm);
    }

    50% {
        box-shadow: 0 0 20px rgba(255, 193, 7, 0.3), var(--shadow-sm);
    }
}

/* Smart Forecast Widget */
.smart-forecast {
    background: linear-gradient(135deg, var(--card) 0%, var(--surface-secondary) 50%, var(--card) 100%);
    border: 1px solid var(--card-border);
    position: relative;
    overflow: hidden;
}

.smart-forecast::after {
    /* Shimmer/rotating blue overlay removed */
    content: none !important;
    animation: none !important;
    background: none !important;
    pointer-events: none;
}

@keyframes shimmer {
    0% {
        transform: none;
    }

    100% {
        transform: none;
    }
}

.widget-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
    border-color: var(--border-hover);
}

.smart-widget:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1), 0 0 20px rgba(59, 130, 246, 0.1);
}

.widget-card.small {
    grid-column: span 1;
}

.widget-card.medium {
    grid-column: span 2;
}

.widget-card.large {
    grid-column: span 3;
}

.widget-card.banner {
    grid-column: 1 / -1;
}

.widget-header {
    padding: var(--space-6) var(--space-6) var(--space-4);
    border-bottom: 1px solid var(--card-border);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    background: linear-gradient(135deg, var(--surface) 0%, var(--surface-secondary) 100%);
}

.widget-header h3 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--foreground);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.header-icon {
    width: 1.25rem;
    height: 1.25rem;
    color: var(--primary);
}

.widget-header p {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
    margin: var(--space-1) 0 0;
    line-height: var(--line-height-normal);
}

.widget-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.alert-count {
    background: var(--destructive);
    color: white;
    font-size: var(--font-size-xs);
    padding: var(--space-1) var(--space-2);
    border-radius: 9999px;
    font-weight: 700;
    /* Disable pulse for notifications universally */
    animation: none !important;
}

/* Mobile: disable pulsing/blue glow on notifications */
@media (hover: none) and (pointer: coarse) {

    .alert-count,
    .alert-badge,
    .kpi-card .alert-badge,
    .pulse,
    .widget-actions .smart-btn,
    .widget-actions .widget-action-btn {
        animation: none !important;
        box-shadow: none !important;
    }

    .widget-actions .smart-btn:focus,
    .widget-actions .widget-action-btn:focus,
    .widget-actions .smart-btn:active,
    .widget-actions .widget-action-btn:active {
        outline: none !important;
        box-shadow: none !important;
    }

    /* Remove tap highlight flash */
    .alert-count,
    .widget-action-btn,
    .smart-btn {
        -webkit-tap-highlight-color: transparent;
    }
}

.widget-content {
    padding: var(--space-6);
}

.widget-action-btn {
    padding: var(--space-2) var(--space-4);
    background-color: var(--primary);
    color: var(--primary-foreground);
    border: none;
    border-radius: var(--radius-lg);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.widget-action-btn:hover {
    background-color: var(--primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.widget-action-btn.secondary {
    background-color: var(--secondary);
    color: var(--secondary-foreground);
    border: 1px solid var(--border);
}

.widget-action-btn.secondary:hover {
    background-color: var(--secondary-hover);
}

/* Smart Button Enhancements */
.smart-btn {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
    border: none;
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
}

.smart-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.smart-btn:hover::before {
    left: 100%;
}

.btn-icon {
    width: 1rem;
    height: 1rem;
}

/* Smart Select Enhancements */
.smart-select {
    background: linear-gradient(135deg, var(--surface) 0%, var(--surface-secondary) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-2) var(--space-3);
    color: var(--foreground);
    font-size: var(--font-size-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    box-shadow: var(--shadow-sm);
    font-weight: 500;
}

/* === Global Modal Contrast Enhancements (non-calculations) === */
.modal-overlay:not(.calc-modal-overlay) .modal-content {
    background: linear-gradient(150deg, #141b23 0%, #0f141a 55%, #0b1116 100%);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 1.3rem;
    box-shadow: 0 18px 46px -12px rgba(0, 0, 0, .55), 0 8px 26px -10px rgba(0, 0, 0, .45);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    color: #e6edf3;
}

.modal-overlay:not(.calc-modal-overlay) {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 5vh 4vw;
    background: rgba(0, 0, 0, .55);
    /* CRITICAL: Remove backdrop-filter that creates stacking context */
    /* backdrop-filter: blur(6px); */
    /* -webkit-backdrop-filter: blur(6px); */
    overflow: visible !important;
    /* Allow content to overflow for dropdowns */
    /* Prevent creating stacking context that interferes with dropdowns */
    transform: none !important;
    will-change: auto !important;
    contain: none !important;
}

.modal-overlay:not(.calc-modal-overlay) {
    overflow: visible;
}

body[data-scroll-locked='1'] {
    overscroll-behavior: contain;
}

.modal-overlay:not(.calc-modal-overlay) .modal-content {
    max-width: clamp(640px, 70vw, 1100px);
    width: 100%;
    max-height: 84vh;
    display: flex;
    flex-direction: column;
    overflow: visible !important;
    /* CRITICAL: Allow dropdowns to escape modal bounds */
    position: relative;
    /* Prevent creating stacking context that traps dropdowns */
    transform: none !important;
    will-change: auto !important;
}

.modal-overlay:not(.calc-modal-overlay) .modal-body {
    padding: 1rem 1.25rem 1.35rem;
    overflow-y: auto !important;
    overflow-x: visible !important;
    /* Allow horizontal overflow for dropdowns */
    flex: 1;
    /* Prevent unwanted scrollbars */
    overscroll-behavior: contain;
    /* Smooth scrolling */
    -webkit-overflow-scrolling: touch;
}

.modal-overlay:not(.calc-modal-overlay) .modal-footer {
    flex-wrap: wrap;
}

.modal-overlay:not(.calc-modal-overlay) .modal-header {
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    padding: 1rem 1.25rem .85rem;
}

.modal-overlay:not(.calc-modal-overlay) .modal-title,
.modal-overlay:not(.calc-modal-overlay) h3 {
    color: #fff;
    letter-spacing: .02em;
    font-weight: 650;
}

.modal-overlay:not(.calc-modal-overlay) label {
    color: rgba(255, 255, 255, .72);
    font-weight: 500;
}

.modal-overlay:not(.calc-modal-overlay) input,
.modal-overlay:not(.calc-modal-overlay) select,
.modal-overlay:not(.calc-modal-overlay) textarea {
    background: rgba(255, 255, 255, .08);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: .85rem;
    padding: .65rem .8rem;
    font-size: .75rem;
    line-height: 1.2;
    transition: border-color .3s ease, box-shadow .35s ease, background-color .4s ease;
}

.modal-overlay:not(.calc-modal-overlay) input::placeholder,
.modal-overlay:not(.calc-modal-overlay) textarea::placeholder {
    color: rgba(255, 255, 255, .38);
}

.modal-overlay:not(.calc-modal-overlay) select option {
    background: #141b23;
    color: #fff;
}

.modal-overlay:not(.calc-modal-overlay) input:focus,
.modal-overlay:not(.calc-modal-overlay) select:focus,
.modal-overlay:not(.calc-modal-overlay) textarea:focus {
    outline: none;
    border-color: rgba(255, 255, 255, .55);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, .15);
}

.modal-overlay:not(.calc-modal-overlay) .modal-footer {
    border-top: 1px solid rgba(255, 255, 255, .08);
    padding: 1rem 1.25rem 1.15rem;
    display: flex;
    gap: .75rem;
    justify-content: flex-end;
    background: linear-gradient(180deg, rgba(255, 255, 255, .04), transparent);
}

.modal-overlay:not(.calc-modal-overlay) .btn,
.modal-overlay:not(.calc-modal-overlay) .action-btn {
    background: linear-gradient(135deg, #0d61ff, #1082ff);
    color: #fff;
    border: 1px solid #1175ff;
    border-radius: .85rem;
    padding: .65rem 1rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .03em;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    box-shadow: 0 6px 20px -8px rgba(13, 97, 255, .55);
    transition: background .4s ease, box-shadow .5s ease, transform .45s cubic-bezier(.6, .3, .2, 1);
}

.modal-overlay:not(.calc-modal-overlay) .btn:hover {
    filter: brightness(1.05);
    transform: translateY(-3px);
    box-shadow: 0 12px 32px -12px rgba(13, 97, 255, .6);
}

.modal-overlay:not(.calc-modal-overlay) .btn:active {
    transform: translateY(-1px) scale(.97);
    box-shadow: 0 4px 14px -6px rgba(13, 97, 255, .55);
}

.modal-overlay:not(.calc-modal-overlay) .btn.secondary {
    background: rgba(255, 255, 255, .08);
    color: #dce6f1;
    border: 1px solid rgba(255, 255, 255, .18);
    box-shadow: none;
}

.modal-overlay:not(.calc-modal-overlay) .btn.secondary:hover {
    background: rgba(255, 255, 255, .14);
}

/* Mobile Performance Optimizations */
@media (max-width: 768px) {

    /* Reduce unnecessary animations on mobile */
    .kpi-card,
    .widget-card,
    .nav-item {
        transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    /* Simplify hover effects on mobile */
    .kpi-card:hover,
    .widget-card:hover {
        transform: translateY(-2px);
    }

    /* Reduce backdrop filter complexity */
    .topbar {
        backdrop-filter: none;
        background: var(--topbar);
    }

    /* RTL topbar background fix */
    .rtl .topbar {
        background: var(--topbar) !important;
        background-color: var(--topbar) !important;
    }

    /* Optimize sidebar animation */
    .sidebar {
        will-change: transform;
    }

    .sidebar.mobile-open {
        will-change: auto;
    }
}

/* GLOBAL: Smart floating menu strategy - Performance optimized */
#je-floating-menu,
.je-floating-menu,
[id*="floating-menu"],
#customerActionMenu,
.customer-action-menu,
[class*="action-menu"] {
    position: fixed !important;
    z-index: 10000 !important;
    /* Reasonable z-index above modals */
    /* Smart positioning and rendering */
    transform: translateZ(0) !important;
    /* GPU acceleration without excessive layers */
    will-change: transform !important;
    contain: layout !important;
    /* Optimize rendering */
    pointer-events: auto !important;
    /* Ensure it renders correctly */
    backface-visibility: hidden !important;
    /* Performance optimization */
    perspective: 1000px !important;
    /* Ensure visibility */
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* CRITICAL: Fix modal content overflow clipping dropdowns */
.modal-content {
    overflow: visible !important;
    /* Allow dropdowns to escape */
}

.modal-content.large {
    overflow: visible !important;
    /* Specifically for large modals */
}

/* CRITICAL: Fix card header overflow clipping dropdowns */
.modal-entry-card-header {
    overflow: visible !important;
    /* Allow dropdowns to escape card headers */
    touch-action: pan-y !important;
}

/* CRITICAL: Customer action buttons - correct class names */
.cust-action-btn,
.modal-entry-card-menu {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    color: var(--foreground) !important;
    padding: 4px 8px !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 16px !important;
    line-height: 1 !important;
    /* CRITICAL: Prevent layout shifts */
    box-sizing: border-box !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 1 !important;
}

.cust-action-btn:hover,
.modal-entry-card-menu:hover {
    background: var(--secondary) !important;
    border-color: var(--border-hover) !important;
}

/* CRITICAL: Data grid wrapper overflow fix */
.data-grid-wrapper {
    overflow-x: visible !important;
    /* Allow horizontal dropdown escape */
    overflow-y: auto !important;
    /* Keep vertical scrolling */
}

/* CRITICAL: Table container fixes */
#customerTable {
    overflow: visible !important;
    position: relative !important;
}

/* CRITICAL: Force floating menu above ALL modal content */
.modal-overlay #je-floating-menu,
.modal-overlay .je-floating-menu,
.modal-overlay [id*="floating-menu"],
.modal-overlay #customerActionMenu,
.modal-overlay .customer-action-menu,
.modal-overlay .cust-action-menu,
.modal-overlay .ovb-action-menu,
.modal-overlay [class*="action-menu"] {
    z-index: 10001 !important;
    /* Above modal z-index (1000) */
    position: fixed !important;
    /* Relative to viewport, not modal */
    max-width: 92vw;
    width: auto;
    overflow: hidden !important;
    white-space: nowrap !important;
}

/* Mobile Dropdown Optimizations */
@media (max-width: 768px) {

    /* CRITICAL: Three dots menu mobile compatibility - Performance optimized */
    #je-floating-menu,
    .je-floating-menu,
    [id*="floating-menu"],
    .ovb-action-menu {
        position: fixed !important;
        z-index: 10000 !important;
        /* Reasonable z-index above modals */
        min-width: 120px !important;
        max-width: calc(100vw - 1rem) !important;
        /* Edge-aware sizing */
        background: var(--surface) !important;
        border: 1px solid var(--border) !important;
        border-radius: 8px !important;
        padding: 0.25rem 0 !important;
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15) !important;
        display: flex !important;
        flex-direction: column !important;
        font-size: 0.82rem !important;
        /* Smart rendering optimization */
        transform: translateZ(0) !important;
        /* GPU acceleration */
        will-change: transform !important;
        contain: layout !important;
        /* Optimize rendering */
        pointer-events: auto !important;
        backface-visibility: hidden !important;
    }

    /* Three dots menu buttons */
    .je-row-menu-btn,
    [class*="menu-btn"]:not(.mobile-menu-btn) {
        background: var(--surface) !important;
        border: 1px solid var(--border) !important;
        color: var(--foreground) !important;
        padding: 0.5rem !important;
        border-radius: 6px !important;
        cursor: pointer !important;
        min-width: 36px !important;
        min-height: 36px !important;
        max-width: 36px !important;
        /* CRITICAL: Prevent expansion */
        max-height: 36px !important;
        /* CRITICAL: Prevent expansion */
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        position: relative !important;
        z-index: 1 !important;
        /* CRITICAL: Prevent layout shifts */
        box-sizing: border-box !important;
        flex-shrink: 0 !important;
        flex-grow: 0 !important;
        overflow: hidden !important;
        /* Prevent any hover expansions */
        transition: background-color 0.15s ease, border-color 0.15s ease !important;
    }

    .je-row-menu-btn:hover,
    [class*="menu-btn"]:not(.mobile-menu-btn):hover {
        background: var(--secondary) !important;
        border-color: var(--border-hover) !important;
        /* CRITICAL: Prevent any layout changes that cause scrollbars */
        width: 36px !important;
        height: 36px !important;
        transform: none !important;
        border-width: 1px !important;
        padding: 0.5rem !important;
    }

    /* Three dots menu items (LTR) */
    #je-floating-menu button,
    .je-floating-menu button,
    [id*="floating-menu"] button,
    .ovb-action-menu button {
        all: unset !important;
        padding: 0.6rem 0.85rem !important;
        /* Better mobile touch targets */
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        /* LTR alignment */
        width: 100% !important;
        text-align: left !important;
        color: var(--foreground) !important;
        box-sizing: border-box !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        font-weight: 500 !important;
        font-size: 0.82rem !important;
        min-height: 40px !important;
        /* iOS touch target */
        transition: background 0.15s ease !important;
    }

    #je-floating-menu button:hover,
    .je-floating-menu button:hover,
    [id*="floating-menu"] button:hover,
    .ovb-action-menu button:hover {
        background: var(--secondary) !important;
    }

    #je-floating-menu button:focus,
    .je-floating-menu button:focus,
    [id*="floating-menu"] button:focus,
    .ovb-action-menu button:focus {
        background: var(--secondary) !important;
        outline: 2px solid var(--ring) !important;
        outline-offset: -2px !important;
    }

    /* Optimize all topbar dropdowns for mobile */
    .topbar-dropdown,
    #period-dropdown {
        position: fixed !important;
        top: 4rem !important;
        right: var(--space-2) !important;
        left: auto !important;
        width: calc(100vw - 2rem) !important;
        max-width: 280px !important;
        min-width: 240px !important;
        background: var(--surface) !important;
        border: 1px solid var(--border) !important;
        border-radius: var(--radius-lg) !important;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3) !important;
        z-index: 9999 !important;
        padding: var(--space-2) 0 !important;
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }

    /* Mobile dropdown items */
    .period-select-item {
        all: unset !important;
        display: block !important;
        width: 100% !important;
        padding: var(--space-3) var(--space-4) !important;
        color: var(--foreground-secondary) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        border-radius: 0 !important;
        box-sizing: border-box !important;
        font-size: var(--font-size-sm) !important;
        line-height: 1.4 !important;
    }

    .period-select-item:hover,
    .period-select-item:focus {
        background: var(--secondary) !important;
        color: var(--foreground) !important;
        outline: none !important;
    }

    /* Mobile dropdown lists */
    .topbar-dropdown ul {
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        max-height: 60vh !important;
        overflow-y: auto !important;
    }

    .topbar-dropdown li {
        margin: 0 !important;
        padding: 0 !important;
    }

    /* RTL Mobile Dropdown Positioning */
    .rtl .topbar-dropdown,
    .rtl #period-dropdown {
        right: auto !important;
        left: var(--space-2) !important;
        direction: rtl !important;
    }

    .rtl .period-select-item {
        text-align: right !important;
        direction: rtl !important;
    }

    /* Mobile topbar button optimizations */
    .topbar-btn {
        position: relative !important;
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1) !important;
        min-width: 44px !important;
        min-height: 44px !important;
    }

    /* Cloud status button mobile optimization */
    #cloud-status-indicator {
        padding: var(--space-2) !important;
        border-radius: var(--radius-md) !important;
        background: rgba(59, 130, 246, 0.1) !important;
        border: 1px solid rgba(59, 130, 246, 0.2) !important;
    }

    #cloud-status-indicator span {
        display: none !important;
        /* Hide text on mobile */
    }

    /* Notification button mobile optimization */
    .notification-btn {
        position: relative !important;
        padding: var(--space-2) !important;
    }

    .notification-dot {
        position: absolute !important;
        top: 6px !important;
        right: 6px !important;
        width: 8px !important;
        height: 8px !important;
        border-radius: 50% !important;
        background: var(--destructive) !important;
        border: 2px solid var(--topbar) !important;
    }

    /* User button mobile optimization */
    .user-btn {
        padding: var(--space-2) !important;
        border-radius: var(--radius-md) !important;
        background-color: var(--success) !important;
        color: white !important;
        opacity: 1 !important;
    }
}

.modal-overlay:not(.calc-modal-overlay) [disabled] {
    opacity: .5;
    cursor: not-allowed;
}

.modal-overlay:not(.calc-modal-overlay) .danger {
    background: linear-gradient(135deg, #dc2626, #ef4444);
    border-color: #dc2626;
}

.modal-overlay:not(.calc-modal-overlay) .danger:hover {
    filter: brightness(1.05);
}

.modal-overlay:not(.calc-modal-overlay) .section-heading {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: #86b7ff;
    margin: 1rem 0 .5rem;
    font-weight: 600;
}

.modal-overlay:not(.calc-modal-overlay) fieldset {
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 1rem;
    padding: 1rem 1.1rem 1.15rem;
    margin: 0 0 1.25rem;
    position: relative;
}

.modal-overlay:not(.calc-modal-overlay) fieldset legend {
    padding: 0 .55rem;
    font-size: .65rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: #141b23;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: .55rem;
    color: #9ecbff;
}

.modal-overlay:not(.calc-modal-overlay) .inline-help {
    font-size: .6rem;
    color: rgba(255, 255, 255, .5);
    margin-top: .35rem;
}

.modal-overlay:not(.calc-modal-overlay) .divider {
    height: 1px;
    background: linear-gradient(90deg, rgba(255, 255, 255, .2), rgba(255, 255, 255, 0));
    margin: 1.25rem 0;
    border: none;
}

.modal-overlay:not(.calc-modal-overlay) ::selection {
    background: #2563eb;
    color: #fff;
}

@media (prefers-reduced-motion: reduce) {
    .modal-overlay:not(.calc-modal-overlay) .btn {
        transition: background .25s ease, transform .3s ease;
    }

    .modal-overlay:not(.calc-modal-overlay) .btn:hover {
        transform: translateY(-2px);
    }
}

.smart-select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Product List Styles */
.product-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.smart-list .product-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4);
    background: linear-gradient(135deg, var(--surface-secondary) 0%, var(--surface-tertiary) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.smart-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--primary);
    transform: scaleY(0);
    transition: transform var(--transition-fast);
}

.smart-item.clickable {
    cursor: pointer;
}

.smart-item:hover {
    background: linear-gradient(135deg, var(--surface-tertiary) 0%, var(--surface-secondary) 100%);
    transform: translateX(6px);
    box-shadow: var(--shadow-lg);
}

.smart-item:hover::before {
    transform: scaleY(1);
}

.product-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    flex: 1;
}

.product-name {
    font-weight: 600;
    color: var(--foreground);
    font-size: var(--font-size-base);
}

.product-revenue {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
    font-weight: 600;
}

.product-stats {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--space-2);
    min-width: 80px;
}

.product-percentage {
    font-weight: 800;
    color: var(--primary);
    font-size: var(--font-size-lg);
}

/* Progress Bar */
.progress-bar {
    width: 60px;
    height: 4px;
    background-color: var(--surface-tertiary);
    border-radius: 2px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
    border-radius: 2px;
    transition: width var(--transition-slow);
}

/* Alert Styles */
.alert-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.smart-alerts .alert-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-6);
    background: linear-gradient(135deg, var(--surface-secondary) 0%, var(--surface) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.alert-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    transition: all var(--transition-fast);
}

.alert-item.high::before {
    background: linear-gradient(180deg, var(--destructive) 0%, #ff6b6b 100%);
}

.alert-item.medium::before {
    background: linear-gradient(180deg, var(--warning) 0%, #ffd93d 100%);
}

.alert-item.low::before {
    background: linear-gradient(180deg, var(--accent) 0%, #4dabf7 100%);
}

.alert-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    border-color: var(--border-hover);
}

.alert-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 2px;
    position: relative;
}

.alert-indicator.critical {
    background: var(--destructive);
    animation: pulse 2s infinite;
}

/* Do not pulse notification badges/dots anywhere */
.pulse,
.alert-badge,
.alerts-summary .alert-count,
.alert-icon-container,
.kpi-card.kpi-target-critical,
.alert-summary-card .alert-count {
    animation: none !important;
}

.alert-indicator.warning {
    background: var(--warning);
}

.alert-indicator.info {
    background: var(--accent);
}

.alert-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.alert-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}

.alert-title {
    font-weight: 700;
    color: var(--foreground);
    font-size: var(--font-size-base);
}

.alert-priority {
    background: var(--surface-tertiary);
    color: var(--foreground-secondary);
    font-size: var(--font-size-xs);
    padding: var(--space-1) var(--space-2);
    border-radius: 9999px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.alert-item.high .alert-priority {
    background: var(--destructive);
    color: white;
}

.alert-item.medium .alert-priority {
    background: var(--warning);
    color: white;
}

.alert-description {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
    line-height: var(--line-height-normal);
}

.alert-time {
    font-size: var(--font-size-xs);
    color: var(--foreground-muted);
    font-style: italic;
}

.alert-actions {
    display: flex;
    gap: var(--space-2);
    flex-shrink: 0;
    align-items: center;
}

.alert-action-btn {
    padding: var(--space-2) var(--space-3);
    border: none;
    border-radius: var(--radius-lg);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    gap: var(--space-1);
    position: relative;
    overflow: hidden;
}

.alert-action-btn.primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
    color: var(--primary-foreground);
    box-shadow: var(--shadow-sm);
}

.alert-action-btn.primary:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.alert-action-btn.secondary {
    background-color: var(--secondary);
    color: var(--secondary-foreground);
    border: 1px solid var(--border);
}

.alert-action-btn.secondary:hover {
    background-color: var(--secondary-hover);
}

/* Chart Styles */
.chart-container {
    position: relative;
    padding: var(--space-4);
}

.chart-container canvas {
    width: 100%;
    height: auto;
    max-height: 300px;
}

/* Smart Chart Enhancements */
.smart-chart {
    position: relative;
    background: linear-gradient(135deg, var(--surface) 0%, var(--surface-secondary) 100%);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.smart-chart::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--primary), transparent);
    opacity: 0.5;
}

.chart-tooltip {
    position: absolute;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-2) var(--space-3);
    box-shadow: var(--shadow-lg);
    z-index: 10;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-fast);
    font-size: var(--font-size-sm);
}

.chart-controls {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    display: flex;
    gap: var(--space-2);
    background: var(--surface);
    border-radius: var(--radius-lg);
    padding: var(--space-1);
    box-shadow: var(--shadow-sm);
}

.chart-control-btn {
    padding: var(--space-1) var(--space-2);
    background: transparent;
    border: none;
    border-radius: var(--radius);
    font-size: var(--font-size-xs);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
    color: var(--foreground-secondary);
}

.chart-control-btn.active,
.chart-control-btn:hover {
    background: var(--primary);
    color: var(--primary-foreground);
}

.chart-legend {
    display: flex;
    justify-content: center;
    gap: var(--space-4);
    padding: var(--space-3);
    border-top: 1px solid var(--border);
    background: var(--surface-secondary);
}

.legend-item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
    font-weight: 500;
}

.legend-color {
    width: 12px;
    height: 12px;
    border-radius: 2px;
}

.legend-color.conservative {
    background: #e74c3c;
}

.legend-color.current {
    background: var(--primary);
}

.legend-color.optimistic {
    background: #2ecc71;
}

/* Forecast Styles */
.forecast-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-6);
    margin-bottom: var(--space-6);
    padding: 0;
}

.smart-metrics .forecast-metric {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4);
    background: linear-gradient(135deg, var(--surface) 0%, var(--surface-secondary) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    transition: all var(--transition-fast);
}

.forecast-metric.primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
    color: white;
}

.forecast-metric:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.metric-icon {
    width: 3rem;
    height: 3rem;
    background: var(--surface-secondary);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.forecast-metric.primary .metric-icon {
    background: rgba(255, 255, 255, 0.2);
}

.metric-icon svg {
    width: 1.5rem;
    height: 1.5rem;
    color: var(--primary);
}

.forecast-metric.primary .metric-icon svg {
    color: white;
}

.metric-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    flex: 1;
}

.metric-label {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
    font-weight: 600;
}

.forecast-metric.primary .metric-label {
    color: rgba(255, 255, 255, 0.8);
}

.metric-value {
    font-size: var(--font-size-2xl);
    font-weight: 800;
    color: var(--foreground);
    line-height: var(--line-height-tight);
}

.forecast-metric.primary .metric-value {
    color: white;
}

.metric-trend {
    font-size: var(--font-size-sm);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.metric-trend.positive {
    color: var(--success);
}

.metric-trend.negative {
    color: var(--destructive);
}

.forecast-metric.primary .metric-trend {
    color: rgba(255, 255, 255, 0.9);
}

.major-outflows {
    margin-top: var(--space-6);
}

.smart-outflows h4 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--foreground);
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.outflows-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.outflow-item {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4);
    background: linear-gradient(135deg, var(--surface-secondary) 0%, var(--surface) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    position: relative;
    overflow: hidden;
}

.outflow-item.urgent::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--destructive);
}

.outflow-item:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.outflow-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-2);
    background: var(--surface-tertiary);
    border-radius: var(--radius-lg);
    min-width: 48px;
}

.date-day {
    font-size: var(--font-size-lg);
    font-weight: 800;
    color: var(--foreground);
    line-height: 1;
}

.date-month {
    font-size: var(--font-size-xs);
    color: var(--foreground-secondary);
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.05em;
}

.outflow-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.outflow-description {
    font-weight: 700;
    color: var(--foreground);
    font-size: var(--font-size-base);
}

.outflow-details {
    font-size: var(--font-size-sm);
    color: var(--foreground-secondary);
}

.outflow-amount {
    font-weight: 800;
    color: var(--foreground);
    font-size: var(--font-size-lg);
    text-align: right;
}

/* Utility Classes */
.min-h-96 {
    min-height: 24rem;
}

.flex {
    display: flex;
}

.items-center {
    align-items: center;
}

.justify-center {
    justify-content: center;
}

.bg-empty-background {
    background-color: var(--empty-background);
}

.rounded-lg {
    border-radius: var(--radius-lg);
}

.border {
    border: 1px solid var(--border);
}

.border-empty-border {
    border-color: var(--empty-border);
}

.text-center {
    text-align: center;
}

.space-y-4>*+* {
    margin-top: var(--space-4);
}

.space-y-2>*+* {
    margin-top: var(--space-2);
}

.w-16 {
    width: 4rem;
}

.h-16 {
    height: 4rem;
}

.rounded-full {
    border-radius: 9999px;
}

.bg-surface-secondary {
    background-color: var(--surface-secondary);
}

.border-border {
    border-color: var(--border);
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.text-2xl {
    font-size: var(--font-size-2xl);
}

.text-lg {
    font-size: var(--font-size-lg);
}

.font-semibold {
    font-weight: 600;
}

.text-foreground {
    color: var(--foreground);
}

.text-foreground-secondary {
    color: var(--foreground-secondary);
}

.text-foreground-muted {
    color: var(--foreground-muted);
}

.max-w-md {
    max-width: 28rem;
}

/* Responsive Design */
@media (max-width: 768px) {
    @media (max-width: 768px) {

        /* Mobile Modal Edge-Aware Optimization */
        .modal-overlay:not(.calc-modal-overlay) {
            padding: 1rem !important;
            /* Ensure modal never touches edges */
            align-items: flex-start !important;
            /* Start from top instead of center */
            padding-top: 2rem !important;
            /* Give space below topbar */
            overflow-y: auto !important;
            /* Allow scrolling if content is tall */
            -webkit-overflow-scrolling: touch !important;
            /* Smooth iOS scrolling */
        }

        .modal-overlay:not(.calc-modal-overlay) .modal-content {
            max-width: calc(100vw - 2rem) !important;
            /* Always 1rem margin on sides */
            width: calc(100vw - 2rem) !important;
            /* Full width minus margins */
            max-height: calc(100vh - 6rem) !important;
            /* Account for topbar and margins */
            min-height: auto !important;
            margin: 0 auto !important;
            display: flex !important;
            flex-direction: column !important;
            overflow: visible !important;
            /* CRITICAL: Allow dropdowns to show */
            position: relative !important;
            /* Enhanced mobile styling */
            border-radius: 12px !important;
            box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
        }

        .modal-overlay:not(.calc-modal-overlay) .modal-body {
            padding: 1rem !important;
            /* Comfortable mobile padding */
            overflow-y: auto !important;
            overflow-x: visible !important;
            /* CRITICAL: Allow horizontal overflow for dropdowns */
            flex: 1 !important;
            /* Mobile scrolling optimization */
            -webkit-overflow-scrolling: touch !important;
            overscroll-behavior: contain !important;
            /* CRITICAL: Prevent unwanted scrollbars */
            box-sizing: border-box !important;
            min-width: 0 !important;
            /* CRITICAL: Fix dropdown clipping in cards/containers */
            position: relative !important;
        }

        /* CRITICAL: Fix card/container overflow in modals */
        .modal-overlay .card,
        .modal-overlay [class*="card"],
        .modal-overlay .table-container,
        .modal-overlay [class*="table"],
        .modal-overlay .customer-item,
        .modal-overlay [class*="customer"],
        .modal-overlay .row,
        .modal-overlay [class*="row"] {
            overflow: visible !important;
            /* Allow dropdowns to escape */
            position: relative !important;
            contain: none !important;
        }

        /* AGGRESSIVE: Fix any element in modal that might clip dropdowns */
        .modal-overlay * {
            overflow-x: visible !important;
        }

        /* EXCEPTION: Keep necessary scrolling for specific elements */
        .modal-overlay .modal-body,
        .modal-overlay textarea,
        .modal-overlay input[type="text"],
        .modal-overlay pre,
        .modal-overlay code {
            overflow-x: auto !important;
        }

        /* Fix three dots button hover scrollbar issue */
        .modal-overlay .je-row-menu-btn {
            overflow: hidden !important;
            white-space: nowrap !important;
            text-overflow: ellipsis !important;
        }

        .modal-overlay:not(.calc-modal-overlay) .modal-header {
            padding: 1rem 1rem 0.5rem !important;
            border-bottom: 1px solid var(--border) !important;
            flex-shrink: 0 !important;
        }

        .modal-overlay:not(.calc-modal-overlay) .modal-footer {
            padding: 0.5rem 1rem 1rem !important;
            flex-shrink: 0 !important;
            flex-wrap: wrap !important;
            gap: 0.5rem !important;
        }
    }

    .kpi-grid {
        grid-template-columns: 1fr;
    }

    .widgets-grid {
        grid-template-columns: 1fr;
    }

    .page {
        padding: var(--space-4);
    }

    /* Mobile Topbar Optimization */
    .topbar {
        padding: 0 1.5rem 0 var(--space-3);
        /* Further increased right padding for full account button visibility */
        height: 4rem;
        backdrop-filter: none;
        /* Remove expensive filter on mobile */
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-1);
        /* Reduced gap for more space */
    }

    /* LTR Mobile: hide brand monogram ("D") to save space */
    html:not(.rtl) .brand-icon,
    body:not(.rtl) .brand-icon,
    html[dir='ltr'] .brand-icon {
        display: none !important;
    }

    .topbar-left {
        gap: var(--space-2);
        min-width: auto;
        flex-shrink: 0;
    }

    .topbar-right {
        gap: var(--space-1);
        flex-shrink: 0;
    }

    /* Critical: Mobile search field constraints */
    .topbar-search-mobile {
        flex: 0 1 auto !important;
        /* Prevent excessive growth */
        max-width: 200px !important;
        /* Reasonable mobile width */
        min-width: 140px !important;
        /* Minimum usable width */
        margin: 0 var(--space-1) !important;
        /* Tight margins */
    }

    /* Hide desktop search on mobile */
    .search-container {
        display: none;
    }

    .brand-text {
        display: none;
        /* Hide brand text on mobile to save space */
    }

    /* Force hide brand text on mobile for RTL */
    .rtl .brand-text {
        display: none !important;
    }

    .topbar-btn span {
        display: none;
        /* Hide button text on mobile */
    }

    .topbar-btn {
        padding: var(--space-2);
        min-width: auto;
    }

    /* Mobile Search in Sidebar */
    .mobile-search-container {
        display: block;
        padding: var(--space-3);
        border-bottom: 1px solid var(--sidebar-border);
        background-color: var(--sidebar-background);
    }

    .mobile-search-wrapper {
        position: relative;
    }

    .mobile-search-wrapper .search-icon {
        position: absolute;
        left: var(--space-3);
        top: 50%;
        transform: translateY(-50%);
        width: 1rem;
        height: 1rem;
        color: var(--foreground-muted);
    }

    .mobile-search-input {
        width: 100%;
        padding: var(--space-2) var(--space-3) var(--space-2) 2.25rem;
        background-color: var(--input);
        border: 1px solid var(--input-border);
        border-radius: var(--radius-lg);
        color: var(--foreground-secondary);
        font-size: var(--font-size-sm);
        transition: all var(--transition-fast);
    }

    .mobile-search-input:focus {
        outline: none;
        border-color: var(--ring);
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    }

    .mobile-search-input::placeholder {
        color: var(--foreground-muted);
    }

    /* Mobile: Remove sidebar margin from content */
    .sidebar+.main-content {
        margin-left: 0;
    }

    /* Mobile: Sidebar hidden by default, slides in from left */
    .sidebar {
        top: 4rem;
        height: calc(100vh - 4rem);
        transform: translateX(-100%);
        transition: transform var(--transition-normal);
        width: 16rem;
        /* keep full width for slide animation */
        z-index: 100;
        /* MAXIMUM z-index for mobile overlay - always above backdrop */
    }

    /* Mobile: Show sidebar when mobile-open class is present */
    .sidebar.mobile-open {
        transform: translateX(0);
    }

    /* Mobile: Ensure collapsed state doesn't override mobile behavior */
    .sidebar.collapsed {
        width: 16rem;
        /* Override collapsed width on mobile */
        transform: translateX(-100%);
        /* Still hidden unless mobile-open */
    }

    .sidebar.collapsed.mobile-open {
        transform: translateX(0);
        /* Show when mobile-open, even if collapsed */
    }

    .kpi-card {
        padding: var(--space-4);
    }

    .widget-header {
        padding: var(--space-4);
    }

    .widget-content {
        padding: var(--space-4);
    }
}

/* Hide mobile search on desktop */
.mobile-search-container {
    display: none;
}

/* RTL Mobile Optimization - SIMPLIFIED */
@media (max-width: 768px) {
    .rtl .topbar {
        direction: rtl;
        background: var(--topbar) !important;
    }

    /* RTL: Ensure search is hidden on mobile */
    .rtl .search-container {
        display: none !important;
    }

    /* RTL: Hide brand text on mobile */
    .rtl .brand-text {
        display: none !important;
    }

    /* RTL: Fix topbar layout */
    .rtl .topbar-left {
        order: 2;
        /* Move to right side */
        direction: rtl;
    }

    .rtl .topbar-right {
        order: 1;
        /* Move to left side */
        direction: rtl;
        flex-direction: row-reverse;
        /* Reverse button order */
    }

    .rtl .sidebar {
        right: 0;
        left: auto;
        transform: translateX(100%);
        border-left: 1px solid var(--sidebar-border);
        border-right: none;
    }

    .rtl .sidebar.mobile-open {
        transform: translateX(0);
    }

    .rtl .mobile-search-wrapper .search-icon {
        right: var(--space-3);
        left: auto;
    }

    .rtl .mobile-search-input {
        padding: var(--space-2) 2.25rem var(--space-2) var(--space-3);
        direction: rtl;
        text-align: right;
    }

    /* RTL: Fix dropdown positioning */
    .rtl #period-dropdown {
        right: auto;
        left: 20px;
        direction: rtl;
    }
}

/* Mobile Sidebar Backdrop */
.sidebar-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 45;
    /* Below sidebar (z-index: 50) but above content */
    opacity: 0;
    transition: opacity var(--transition-normal);
    pointer-events: none;
}

.sidebar-backdrop.active {
    opacity: 1;
    pointer-events: auto;
}

/* Desktop safety: never allow backdrop to block clicks on desktop widths */
@media (min-width: 769px) {

    .sidebar-backdrop,
    .sidebar-backdrop.active {
        opacity: 0 !important;
        pointer-events: none !important;
    }
}

/* Mobile backdrop positioning - LTR vs RTL */
@media (max-width: 768px) {

    /* LTR Mode: Backdrop covers full screen but appears behind sidebar */
    html[dir="ltr"] .sidebar-backdrop,
    html:not([dir="rtl"]) .sidebar-backdrop,
    body.ltr .sidebar-backdrop,
    body:not(.rtl) .sidebar-backdrop {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        height: 100% !important;
        z-index: 45 !important;
        /* Behind sidebar (z-index: 50) but above content */

        /* CRITICAL: Override any RTL positioning that might be stuck */
        transform: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* LTR Mode Active State */
    html[dir="ltr"] .sidebar-backdrop.active,
    html:not([dir="rtl"]) .sidebar-backdrop.active,
    body.ltr .sidebar-backdrop.active,
    body:not(.rtl) .sidebar-backdrop.active {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        height: 100% !important;
        z-index: 45 !important;
        opacity: 1 !important;

        /* CRITICAL: Override any RTL positioning that might be stuck */
        transform: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* RTL Mode: Keep original behavior (backdrop can be positioned differently) */
    html[dir="rtl"] .sidebar-backdrop,
    body.rtl .sidebar-backdrop {
        /* RTL positioning will be handled by RTL.css */
        position: fixed !important;
        top: 0 !important;
        bottom: 0 !important;
    }
}

/* LTR-specific backdrop positioning - Reset RTL overrides */
@media (max-width: 768px) {

    /* When NOT in RTL, ensure backdrop covers full viewport */
    .sidebar-backdrop:not(.rtl *),
    body:not(.rtl) .sidebar-backdrop,
    html:not(.rtl) .sidebar-backdrop {
        right: 0 !important;
        left: 0 !important;
        top: 0 !important;
    }

    /* Force override any RTL positioning when switching back to LTR */
    body.ltr .sidebar-backdrop,
    html.ltr .sidebar-backdrop,
    :not(.rtl) .sidebar-backdrop {
        right: 0 !important;
        left: 0 !important;
        top: 0 !important;
    }

    /* Additional specificity to override RTL.css rules */
    body:not(.rtl) .sidebar-backdrop.active,
    html:not(.rtl) .sidebar-backdrop.active {
        right: 0 !important;
        left: 0 !important;
        top: 0 !important;
    }

    /* Maximum specificity override for LTR mode - this should win over RTL.css */
    html:not([dir="rtl"]) .sidebar-backdrop,
    html[dir="ltr"] .sidebar-backdrop,
    html.ltr .sidebar-backdrop,
    body.ltr .sidebar-backdrop,
    html:not(.rtl) body .sidebar-backdrop {
        right: 0 !important;
        left: 0 !important;
        top: 0 !important;
        position: fixed !important;
        width: 100% !important;
        height: 100% !important;
    }
}

/* Prevent body scroll when mobile sidebar is open */
body.mobile-sidebar-open {
    overflow: hidden;
    position: fixed;
    width: 100%;
}

@media (max-width: 480px) {
    .topbar {
        padding: 0 var(--space-2);
        height: 3.5rem;
        /* Slightly smaller on very small screens */
    }

    .page-header h1 {
        font-size: var(--font-size-2xl);
    }

    .kpi-value {
        font-size: var(--font-size-2xl);
    }

    .sidebar {
        top: 3.5rem;
        height: calc(100vh - 3.5rem);
    }

    .main-content {
        padding-top: 3.5rem;
        min-height: calc(100vh - 3.5rem);
    }

    /* Mobile search adjustments for very small screens */
    .mobile-search-container {
        padding: var(--space-2);
    }

    .mobile-search-input {
        font-size: var(--font-size-sm);
        padding: var(--space-1) var(--space-2) var(--space-1) 2rem;
    }

    .mobile-search-wrapper .search-icon {
        left: var(--space-2);
        width: 0.875rem;
        height: 0.875rem;
    }

    /* RTL mobile search for small screens */
    .rtl .mobile-search-wrapper .search-icon {
        right: var(--space-2);
        left: auto;
    }

    .rtl .mobile-search-input {
        padding: var(--space-1) 2rem var(--space-1) var(--space-2);
    }

    /* RTL: Small screen fixes */
    .rtl .topbar {
        direction: rtl;
        background: var(--topbar) !important;
    }

    .rtl .topbar-left {
        order: 2;
        direction: rtl;
    }

    .rtl .topbar-right {
        order: 1;
        direction: rtl;
        flex-direction: row-reverse;
    }

    .rtl .brand-text {
        display: none !important;
    }
}

/* ===== PROFESSIONAL SALES DASHBOARD - EMBEDDED ===== */

/* Emergency SVG Icon Fix */
#sales-page svg,
#sales-page .kpi-icon,
#sales-page .btn-icon,
#sales-page .activity-icon,
#sales-page .action-icon {
    width: 16px !important;
    height: 16px !important;
    max-width: 16px !important;
    max-height: 16px !important;
    font-size: 16px !important;
}

/* Sales Page Base Styles */
#sales-page {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    line-height: 1.6;
    color: #333333;
    background-color: transparent;
    padding: 24px;
    max-width: 1400px;
    margin: 0 auto;
}

#sales-page * {
    box-sizing: border-box;
}

/* Sales Header */
#sales-page .sales-header {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 32px;
    margin-bottom: 24px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
}

#sales-page .sales-title {
    font-size: 28px;
    font-weight: 700;
    color: #1a202c;
    margin: 0 0 8px 0;
}

#sales-page .sales-subtitle {
    font-size: 16px;
    color: #64748b;
    margin: 0;
}

#sales-page .header-actions {
    display: flex;
    gap: 12px;
}

#sales-page .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    border: 1px solid;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    background: none;
}

#sales-page .btn-primary {
    background: #4f46e5;
    color: white;
    border-color: #4f46e5;
}

#sales-page .btn-primary:hover {
    background: #4338ca;
    border-color: #4338ca;
}

#sales-page .btn-secondary {
    background: #ffffff;
    color: #64748b;
    border-color: #e2e8f0;
}

#sales-page .btn-secondary:hover {
    background: #f8fafc;
    border-color: #cbd5e1;
}

/* Pipeline Summary Section */
#sales-page .pipeline-summary-section {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    margin-bottom: 24px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

#sales-page .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 32px;
    border-bottom: 1px solid #e2e8f0;
    background: #fafbfc;
}

#sales-page .header-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

#sales-page .header-icon {
    width: 44px;
    height: 44px;
    background: #4f46e5;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
}

#sales-page .header-icon svg {
    width: 20px !important;
    height: 20px !important;
}

#sales-page .section-title {
    font-size: 24px;
    font-weight: 700;
    color: #1a202c;
    margin: 0 0 4px 0;
}

#sales-page .section-subtitle {
    font-size: 15px;
    color: #64748b;
    margin: 0;
}

#sales-page .action-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 8px;
    border: 1px solid;
    cursor: pointer;
    transition: all 0.2s ease;
    background: none;
}

#sales-page .action-btn svg {
    width: 16px !important;
    height: 16px !important;
}

#sales-page .secondary-btn {
    background: #ffffff;
    color: #64748b;
    border-color: #e2e8f0;
}

#sales-page .secondary-btn:hover {
    background: #f8fafc;
    border-color: #cbd5e1;
}

#sales-page .primary-btn {
    background: #4f46e5;
    color: white;
    border-color: #4f46e5;
}

#sales-page .primary-btn:hover {
    background: #4338ca;
}

/* Pipeline Overview Stats */
#sales-page .pipeline-overview {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: #e2e8f0;
    margin: 0;
}

#sales-page .overview-stat {
    background: #ffffff;
    padding: 28px 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    transition: background-color 0.2s ease;
}

#sales-page .overview-stat:hover {
    background: #f8fafc;
}

#sales-page .stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

#sales-page .stat-icon svg {
    width: 20px !important;
    height: 20px !important;
}

#sales-page .blue-icon {
    background: #eff6ff;
    color: #2563eb;
}

#sales-page .green-icon {
    background: #f0fdf4;
    color: #16a34a;
}

#sales-page .orange-icon {
    background: #fff7ed;
    color: #ea580c;
}

#sales-page .purple-icon {
    background: #faf5ff;
    color: #9333ea;
}

#sales-page .stat-value {
    font-size: 28px;
    font-weight: 700;
    color: #1a202c;
    margin: 0 0 4px 0;
    line-height: 1;
}

#sales-page .stat-label {
    font-size: 14px;
    color: #64748b;
    margin: 0;
    font-weight: 500;
}

/* Pipeline Stages Grid */
#sales-page .pipeline-stages-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1px;
    background: #e2e8f0;
    margin: 0;
}

#sales-page .pipeline-stage {
    background: #ffffff;
    padding: 24px;
    transition: background-color 0.2s ease;
    min-height: 320px;
    display: flex;
    flex-direction: column;
}

#sales-page .pipeline-stage:hover {
    background: #f8fafc;
}

#sales-page .stage-header {
    margin-bottom: 20px;
}

#sales-page .stage-info {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 16px;
}

#sales-page .stage-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: white;
}

#sales-page .stage-icon svg {
    width: 16px !important;
    height: 16px !important;
}

#sales-page .prospects-stage .stage-icon {
    background: #3b82f6;
}

#sales-page .qualified-stage .stage-icon {
    background: #8b5cf6;
}

#sales-page .proposal-stage .stage-icon {
    background: #f59e0b;
}

#sales-page .negotiation-stage .stage-icon {
    background: #ef4444;
}

#sales-page .closing-stage .stage-icon {
    background: #10b981;
}

#sales-page .stage-name {
    font-size: 16px;
    font-weight: 600;
    color: #1a202c;
    margin: 0 0 4px 0;
}

#sales-page .stage-count {
    font-size: 13px;
    color: #64748b;
    margin: 0;
}

#sales-page .stage-value {
    font-size: 20px;
    font-weight: 700;
    color: #1a202c;
    margin-bottom: 16px;
}

#sales-page .stage-progress {
    margin-bottom: 20px;
}

#sales-page .progress-bar {
    width: 100%;
    height: 4px;
    background: #e2e8f0;
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 8px;
}

#sales-page .progress-fill {
    height: 100%;
    background: #4f46e5;
    border-radius: 2px;
    transition: width 0.3s ease;
}

#sales-page .progress-text {
    font-size: 12px;
    color: #64748b;
    font-weight: 500;
}

#sales-page .stage-opportunities {
    flex: 1;
}

#sales-page .opportunity-item {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 12px;
    transition: all 0.2s ease;
    cursor: pointer;
}

#sales-page .opportunity-item:hover {
    border-color: #cbd5e1;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

#sales-page .opportunity-item.hot-opportunity {
    background: #fef2f2;
    border-color: #fecaca;
}

#sales-page .opportunity-item.closing-opportunity {
    background: #f0fdf4;
    border-color: #bbf7d0;
}

#sales-page .opportunity-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 12px;
}

#sales-page .opportunity-title {
    font-size: 14px;
    font-weight: 600;
    color: #1a202c;
    line-height: 1.3;
}

#sales-page .opportunity-value {
    font-size: 14px;
    font-weight: 700;
    color: #16a34a;
}

#sales-page .opportunity-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

#sales-page .opportunity-company {
    font-size: 13px;
    color: #64748b;
    font-weight: 500;
}

#sales-page .opportunity-badges {
    display: flex;
    gap: 6px;
}

#sales-page .probability-badge {
    background: #eff6ff;
    color: #2563eb;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
}

#sales-page .date-badge {
    background: #f1f5f9;
    color: #64748b;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 500;
}

#sales-page .date-badge.urgent {
    background: #fef2f2;
    color: #dc2626;
}

/* Responsive Design */
@media (max-width: 1200px) {
    #sales-page .pipeline-overview {
        grid-template-columns: repeat(2, 1fr);
    }

    #sales-page .pipeline-stages-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    #sales-page {
        padding: 16px;
    }

    #sales-page .section-header {
        flex-direction: column;
        align-items: stretch;
        gap: 20px;
        padding: 20px;
    }

    #sales-page .pipeline-overview {
        grid-template-columns: 1fr;
    }

    #sales-page .pipeline-stages-grid {
        grid-template-columns: 1fr;
    }
}

/* === SALES PAGE FINAL OVERRIDES (appended for precedence) === */
#sales-page .kpi-card,
#sales-page .pipeline-summary-widget,
#sales-page .kanban-widget,
#sales-page .top-opportunities-widget,
#sales-page .leaderboard-widget,
#sales-page .orders-widget {
    animation: salesFadeIn .55s ease-out both;
}

#sales-page .kpi-card:nth-child(1) {
    animation-delay: .05s;
}

#sales-page .kpi-card:nth-child(2) {
    animation-delay: .1s;
}

#sales-page .kpi-card:nth-child(3) {
    animation-delay: .15s;
}

#sales-page .kpi-card:nth-child(4) {
    animation-delay: .2s;
}

@keyframes salesFadeIn {
    0% {
        opacity: 0;
        transform: translateY(14px) scale(.96);
    }

    60% {
        opacity: 1;
        transform: translateY(0) scale(1.01);
    }

    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Button gloss effect override */
#sales-page .btn {
    position: relative;
    overflow: hidden;
}

#sales-page .btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, .4), transparent 70%);
    opacity: 0;
    transition: opacity .4s;
}

#sales-page .btn:hover::after {
    opacity: .6;
}

/* Dark mode pass (prefers-color-scheme) */
@media (prefers-color-scheme: dark) {

    #sales-page .pipeline-summary-widget,
    #sales-page .top-opportunities-widget,
    #sales-page .kanban-widget,
    #sales-page .leaderboard-widget,
    #sales-page .orders-widget {
        background: var(--surface);
        border-color: var(--border);
        box-shadow: 0 2px 6px -1px rgba(0, 0, 0, .6);
    }

    #sales-page .stage-card,
    #sales-page .leaderboard-item,
    #sales-page .opportunity-item,
    #sales-page .stat-card,
    #sales-page .kanban-column {
        background: var(--surface-tertiary);
    }

    #sales-page .orders-table tr:hover {
        background: var(--surface-tertiary);
    }

    #sales-page .btn-secondary {
        background: var(--surface-tertiary);
    }

    #sales-page .stage-badge.stage-prospect {
        background: #334155;
        color: #e2e8f0;
    }

    #sales-page .stage-badge.stage-qualified {
        background: #1e3a8a;
        color: #bfdbfe;
    }

    #sales-page .stage-badge.stage-proposal {
        background: #78350f;
        color: #fde68a;
    }

    #sales-page .stage-badge.stage-negotiation {
        background: #4c1d95;
        color: #e9d5ff;
    }

    #sales-page .stage-badge.stage-won {
        background: #065f46;
        color: #d1fae5;
    }

    #sales-page .stage-badge.stage-lost {
        background: #7f1d1d;
        color: #fecaca;
    }
}

/* ============================================= */
/* CRITICAL MOBILE RTL INVENTORY FIXES         */
/* ============================================= */

/* Mobile Responsive Layout - Critical RTL Support */
@media (max-width: 768px) {
    .main-content {
        margin-left: 0 !important;
        margin-right: 0 !important;
        width: 100% !important;
        padding: 4rem 0.75rem 0.75rem 0.75rem !important;
        overflow-x: hidden !important;
    }

    .rtl .main-content {
        padding: 4rem 0.75rem 0.75rem 0.75rem !important;
        direction: rtl !important;
        text-align: right !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .page {
        padding: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    .rtl .page {
        direction: rtl !important;
        text-align: right !important;
    }

    .page-header {
        padding: 1rem 0 !important;
        text-align: left !important;
    }

    .rtl .page-header {
        text-align: right !important;
        direction: rtl !important;
    }

    .rtl .page-header h1 {
        text-align: right !important;
        direction: rtl !important;
    }

    .rtl .page-header p {
        text-align: right !important;
        direction: rtl !important;
    }

    /* Critical: Prevent horizontal scroll on mobile */
    body {
        overflow-x: hidden !important;
    }

    .rtl body {
        overflow-x: hidden !important;
        direction: rtl !important;
    }

    .dashboard-container {
        overflow-x: hidden !important;
        width: 100vw !important;
        max-width: 100vw !important;
    }

    .rtl .dashboard-container {
        overflow-x: hidden !important;
        direction: rtl !important;
    }

    /* Force sidebar behavior on mobile in RTL */
    .rtl .sidebar {
        position: fixed !important;
        top: 4rem !important;
        right: 0 !important;
        left: auto !important;
        height: calc(100vh - 4rem) !important;
        z-index: 999 !important;
        transform: translateX(100%) !important;
        transition: transform 0.3s ease !important;
    }

    .rtl .sidebar.mobile-open {
        transform: translateX(0) !important;
    }

    .rtl .sidebar+.main-content {
        margin-right: 0 !important;
        margin-left: 0 !important;
    }

    /* Mobile inventory-specific fixes */
    #inventory-page {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    .rtl #inventory-page {
        direction: rtl !important;
        text-align: right !important;
    }

    #inventory-content {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        padding: 0 0.75rem !important;
    }

    .rtl #inventory-content {
        direction: rtl !important;
        text-align: right !important;
    }
}

/* Fixed fallback classes (used by JS and as a safety net) */
header.topbar.topbar-fixed-fallback {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
}

.dashboard-container.topbar-padding-fix {
    padding-top: 4rem !important;
}