/*
 * Globals.css - Reorganized
 *
 * This stylesheet has been restructured for improved readability and maintainability.
 * The logical order is as follows:
 *
 * 0. IMPORTS
 * 1. THEME & VARIABLES
 * 2. RESET & BASE STYLES
 * 3. UTILITY CLASSES
 * 4. CORE LAYOUT & SHELL ARCHITECTURE
 * 5. PAGE HEADER & BREADCRUMBS
 * 6. FORMS & INPUTS
 * 7. GENERAL COMPONENTS (Buttons, Dropdowns, etc.)
 * 8. COMPLEX COMPONENTS
 *    8.1. Lookup, Filter & Dialog
 *    8.2. Two-Column Layout (TSF)
 *    8.3. Message Box
 * 9. THIRD-PARTY OVERRIDES
 *    9.1. Radzen General
 *    9.2. Radzen DataGrid
 *    9.3. Radzen Slim Theme
 *    9.4. Other ERP Overrides
 * 10. DYNAMIC STATES & ANIMATIONS
 * 11. RESPONSIVE MEDIA QUERIES
 *
 */

/* --- 0. IMPORTS --- */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600&display=swap');

/* --- 1. THEME & VARIABLES --- */

/* DEFAULT THEME: VS Cool Breeze Light */
:root {
    /* Backgrounds */
    --vs-bg-app-bar: #CDD6E0;
    --vs-bg-header: #DCE4EC;
    --vs-bg-main: #F5F7FA;
    --vs-bg-sidebar: #EAEFF4;
    --vs-bg-input: #FFFFFF;
    --vs-bg-hover: #E2E8F0;
    --vs-bg-selected: #BEE3F8;
    --vs-bg-overlay: rgba(51, 65, 85, 0.4);
    /* Borders */
    --vs-border-main: #CBD5E1;
    --vs-border-light: #E2E8F0;
    --vs-border-focus: #3B82F6;
    /* Text */
    --vs-text-default: #334155;
    --vs-text-bright: #1E293B;
    --vs-text-muted: #1E293B;  /*#64748B;*/
    --vs-text-info: #2563EB;
    /* Accents & Status */
    --vs-accent: #3B82F6;
    --vs-status-bg: #334155;
    --vs-status-accent: #3B82F6;
    /* Metrics */
    --vs-header-height: 40px;
    --vs-footer-height: 22px;
    --vs-sidebar-width: 280px;
    --vs-grid-cell-text-color: var(--vs-text-default); /* <-- ADD THIS LINE */
}

/* THEME OVERRIDE: Original VS Dark */
.theme-dark {
    --vs-bg-app-bar: #000000;
    --vs-bg-header: #1a1a1a;
    --vs-bg-main: #1e1e1e;
    --vs-bg-sidebar: #252526;
    --vs-bg-input: #333337;
    --vs-bg-hover: #37373d;
    --vs-bg-selected: #094771;
    --vs-bg-overlay: rgba(0, 0, 0, 0.6);
    --vs-border-main: #3e3e42;
    --vs-border-light: #454545;
    --vs-border-focus: #007acc;
    --vs-text-default: #cccccc;
    --vs-text-bright: #ffffff;
    --vs-text-muted: #888888;
    --vs-text-info: #569cd6;
    --vs-accent: #007acc;
    --vs-status-bg: #007acc;
    --vs-status-accent: #1f8ad2;
    --vs-grid-cell-text-color: var(--vs-text-bright); /* <-- ADD THIS LINE */
}

/* THEME OVERRIDE: Cool Slate (Dark) */
.theme-cool-slate {
    --vs-bg-app-bar: #1E293B;
    --vs-bg-header: #293548;
    --vs-bg-main: #334155;
    --vs-bg-sidebar: #243041;
    --vs-bg-input: #475569;
    --vs-bg-hover: #4F5E74;
    --vs-bg-selected: #475569;
    --vs-bg-overlay: rgba(15, 23, 42, 0.6);
    --vs-border-main: #475569;
    --vs-border-light: #404D61;
    --vs-border-focus: #60A5FA;
    --vs-text-default: #CBD5E1;
    --vs-text-bright: #F1F5F9;
    --vs-text-muted: #94A3B8;
    --vs-text-info: #60A5FA;
    --vs-accent: #3B82F6;
    --vs-status-bg: #3B82F6;
    --vs-status-accent: #60A5FA;
    --vs-grid-cell-text-color: var(--vs-text-bright); /* <-- ADD THIS LINE */
}

/* THEME OVERRIDE: Juicy Plum (Dark) */
.theme-juicy-plum {
    --vs-bg-app-bar: #21182B;
    --vs-bg-header: #352A48;
    --vs-bg-main: #2A2139;
    --vs-bg-sidebar: #2F2540;
    --vs-bg-input: #413A53;
    --vs-bg-hover: #4A4161;
    --vs-bg-selected: #6A4B9C;
    --vs-bg-overlay: rgba(42, 33, 57, 0.6);
    --vs-border-main: #4A3769;
    --vs-border-light: #3F3456;
    --vs-border-focus: #E93D82;
    --vs-text-default: #D9CFF0;
    --vs-text-bright: #F3E8FF;
    --vs-text-muted: #A295B7;
    --vs-text-info: #D67AE2;
    --vs-accent: #E93D82;
    --vs-status-bg: #4A3769;
    --vs-status-accent: #6D5494;
    --vs-grid-cell-text-color: var(--vs-text-bright); /* <-- ADD THIS LINE */
}

/* THEME OVERRIDE: Mango Paradise (Light) */
.theme-mango-paradise {
    --vs-bg-app-bar: #FFA500;
    --vs-bg-header: #FFDAB9;
    --vs-bg-main: #FFFBEB;
    --vs-bg-sidebar: #FFEBCD;
    --vs-bg-input: #FFFFFF;
    --vs-bg-hover: #FFF0D9;
    --vs-bg-selected: #FFD180;
    --vs-bg-overlay: rgba(124, 77, 25, 0.3);
    --vs-border-main: #FFCC80;
    --vs-border-light: #FFE0B2;
    --vs-border-focus: #F57C00;
    --vs-text-default: #5D4037;
    --vs-text-bright: #4E342E;
    --vs-text-muted: #8D6E63;
    --vs-text-info: #E65100;
    --vs-accent: #F57C00;
    --vs-status-bg: #F57C00;
    --vs-status-accent: #FB8C00;
    --vs-grid-cell-text-color: var(--vs-text-default); /* <-- ADD THIS LINE */
}


/* --- 2. RESET & BASE STYLES --- */
* {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    background-color: var(--vs-bg-main ) !important;
    color: var(--vs-text-default) !important;
    font-family: "Segoe UI Variable", "Segoe UI", "Roboto", sans-serif;
    font-size: 0.875rem; /* 14px */
    transition: background-color 0.2s ease;
}


/* --- 3. UTILITY CLASSES --- */
.d-flex { display: flex !important; }
.d-none { display: none !important; }
.d-md-block { @media (min-width: 768px) { display: block !important; } }
.flex-grow-1 { flex-grow: 1 !important; }
.flex-column { flex-direction: column !important; }
.justify-content-center { justify-content: center !important; }
.align-items-center { align-items: center !important; }
.align-items-end { align-items: flex-end !important; }
.text-center { text-align: center !important; }
.text-decoration-none { text-decoration: none !important; }
.w-100 { width: 100% !important; }
.h-100 { height: 100% !important; }
.me-1 { margin-right: 0.25rem !important; }
.me-2 { margin-right: 0.5rem !important; }
.me-3 { margin-right: 1rem !important; }
.ms-1 { margin-left: 0.25rem !important; }
.ms-2 { margin-left: 0.5rem !important; }
.mb-1 { margin-bottom: 0.25rem !important; }
.mb-2 { margin-bottom: 0.5rem !important; }
.mb-3 { margin-bottom: 1rem !important; }
.mx-2 { margin-left: 0.5rem !important; margin-right: 0.5rem !important; }
.px-2 { padding-left: 0.5rem !important; padding-right: 0.5rem !important; }
.py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.py-3 { padding-top: 1rem !important; padding-bottom: 1rem !important; }
.p-3 { padding: 1rem !important; }
.position-relative { position: relative !important; }
.fixed-top { position: fixed; top: 0; right: 0; left: 0; z-index: 1030; }
.fw-bold { font-weight: 700 !important; }
.fw-light { font-weight: 300 !important; }
.opacity-50 { opacity: 0.5 !important; }
.shadow-lg { box-shadow: 0 1rem 3rem rgba(0, 0, 0, .175) !important; }
.extra-small { font-size: 0.75rem; }
/* --- 3.1 FLEXBOX LAYOUT UTILITIES --- */

.tsf-form-row {
    display: flex;
    flex-wrap: wrap; /* This is key for the responsive behavior */
    align-items: flex-start; /* Aligns items to the top for better multi-line wrapping */
    margin-bottom: 1rem; /* Adds space between form rows */
}

/* --- MOBILE FIRST STYLES (Default) --- */
/* On small screens, both label and input take 100% width, stacking vertically. */
.tsf-form-col-label,
.tsf-form-col-input {
    flex-basis: 100%; /* Each item starts by taking up the full width */
}

.tsf-form-col-label {
    margin-bottom: 0.25rem; /* Adds a small space below the label when stacked */
}

/* --- Styling for the TsfButtonEdit component --- */

/* The main wrapper that allows absolute positioning of the button inside it. */
.tsf-button-edit-wrapper {
    position: relative;
    width: 100%;
}

    /* Add padding to the right of the textbox to prevent text from going under the button. */
    .tsf-button-edit-wrapper .rz-textbox {
        padding-right: 40px !important;
    }

/* The style for the absolutely positioned button on the right side of the input. */
.tsf-button-edit-btn {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    min-width: 32px;
    height: 32px;
    padding: 4px 8px;
    border: 1px solid var(--rz-border-color);
}
/* --- LARGE SCREEN STYLES (min-width: 768px) --- */
/* On screens 768px and wider, we switch to a side-by-side layout. */
@media (min-width: 768px) {
    .tsf-form-row {
        /* On large screens, align the label text with the center of the input field */
        align-items: center;
    }

    .tsf-form-col-label {
        flex: 1 0 33.3333%; /* Takes up 1/3 of the space */
        max-width: 33.3333%;
        margin-bottom: 0; /* Remove the margin used for stacking */
    }

    .tsf-form-col-input {
        flex: 1 0 66.6667%; /* Takes up 2/3 of the space */
        max-width: 66.6667%;
    }
}

/* --- 4. CORE LAYOUT & SHELL ARCHITECTURE --- */
.vs-root {
    display: flex;
    flex-direction: column;
    height: 100vh;
    width: 100vw;
    background-color: var(--vs-bg-main) !important;
}

.vs-app-bar {
    display: flex;
    align-items: center;
    position: fixed;
    top: 0;
    width: 100%;
    height: var(--vs-header-height);
    background-color: var(--vs-bg-app-bar) !important;
    border-bottom: 1px solid var(--vs-border-main);
    z-index: 3000;
}

.vs-workspace {
    flex: 1;
    display: flex;
    position: relative;
    margin-top: var(--vs-header-height);
    margin-bottom: var(--vs-footer-height);
    overflow: hidden;
}

.vs-main-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 0;
    background-color: var(--vs-bg-main);
}

.vs-content-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 20px;
}
.vs-content-body0 {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 0px;
}

.vs-sidebar {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: var(--vs-sidebar-width);
    background-color: var(--vs-bg-sidebar);
    border-right: 1px solid var(--vs-border-main);
    z-index: 2500;
    transform: translateX(-100%);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.vs-sidebar.show {
    transform: translateX(0);
    box-shadow: 10px 0 25px var(--vs-bg-overlay);
}

.vs-sidebar-header {
    display: flex;
    justify-content: space-between;
    padding: 8px 12px;
    background-color: var(--vs-bg-header);
    font-size: 10px;
    font-weight: bold;
    color: var(--vs-text-muted);
    letter-spacing: 1px;
}

.vs-sidebar-overlay {
    position: absolute;
    inset: 0;
    background-color: var(--vs-bg-overlay);
    z-index: 2400;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease;
    backdrop-filter: blur(2px);
}

.vs-sidebar-overlay.visible {
    opacity: 1;
    visibility: visible;
}

.vs-status-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    bottom: 0;
    width: 100%;
    height: var(--vs-footer-height);
    background-color: var(--vs-status-bg);
    color: white;
    font-size: 11px;
    z-index: 3000;
}

.vs-status-item {
    display: inline-flex;
    align-items: center;
    height: 100%;
    padding: 0 10px;
}

.vs-status-item:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.vs-status-accent {
    background-color: var(--vs-status-accent);
}

.vs-status-item-separator {
    padding: 0 4px;
    color: rgba(255, 255, 255, 0.3);
}


/* --- 5. PAGE HEADER & BREADCRUMBS --- */
.vs-form-header {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    padding: 0px 20px 8px 20px;
    background-color: var(--vs-bg-header);
    border-bottom: 1px solid var(--vs-border-main);
}

.vs-title-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.vs-title-left {
    display: flex;
    align-items: center;
}

.vs-form-title {
    margin: 0;
    padding: 0;
    font-size: 1.25rem; /* 20px */
    font-weight: 600;
    color: var(--vs-text-bright);
}

.vs-data-actions-area {
    display: flex;
    align-items: center;
    gap: 8px;
}

.vs-breadcrumb-container {
    font-size: 0.75rem; /* 12px */
    margin-bottom: 6px;
}

.vs-breadcrumb-container a,
.vs-breadcrumb-link {
    color: var(--vs-text-muted);
    text-decoration: none;
}

.vs-breadcrumb-container a:hover,
.vs-breadcrumb-link:hover {
    color: var(--vs-text-bright);
    text-decoration: underline;
}

.vs-breadcrumb-separator {
    margin: 0 0.5rem;
    color: var(--vs-text-muted);
}

.vs-breadcrumb-current {
    color: var(--vs-text-default);
    font-weight: 500;
}


/* --- 6. FORMS & INPUTS --- */
.form-label {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--vs-text-muted);
}

input,
select,
textarea,
.form-control {
    padding: 0.25rem 0.5rem !important;
    background-color: var(--vs-bg-input) !important;
    border: 1px solid var(--vs-border-main) !important;
    color: var(--vs-text-bright) !important;
    font-size: 0.8125rem !important;
    border-radius: 2px;
}

input:focus,
select:focus,
textarea:focus,
.form-control:focus {
    outline: none !important;
    border-color: var(--vs-border-focus) !important;
}

.theme-dark input:focus,
.theme-dark textarea:focus {
    background-color: #333337 !important;
}

input:read-only,
textarea:read-only,
.form-control:read-only {
    background-color: var(--vs-bg-sidebar) !important;
    color: var(--vs-text-muted) !important;
    cursor: not-allowed;
}

input:read-only:hover,
textarea:read-only:hover,
.form-control:read-only:hover {
    border-color: var(--vs-border-main) !important;
}

.vs-search-placeholder {
    color: var(--vs-text-default);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0rem 0.5rem;
}


/* --- 7. GENERAL COMPONENTS (Buttons, Dropdowns, etc.) --- */
.vs-logo {
    width: 20px;
}

.vs-action-btn {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    background-color: var(--vs-bg-input);
    border: 1px solid var(--vs-border-main);
    color: var(--vs-text-default);
    font-size: 12px;
    border-radius: 2px;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
}

.vs-action-btn:hover {
    border-color: var(--vs-border-focus);
    color: var(--vs-text-bright);
}

.vs-action-btn.primary {
    background-color: var(--vs-accent);
    border-color: var(--vs-accent);
    color: white;
}

.vs-action-btn.primary:hover {
    filter: brightness(1.1);
}

.vs-mini-btn {
    background: none;
    border: none;
    color: var(--vs-text-muted);
    cursor: pointer;
}

.vs-mini-btn:hover {
    color: var(--vs-text-bright);
}

.vs-menu-btn,
.vs-avatar-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: var(--vs-text-muted);
    border-radius: 6px;
    transition: all 0.2s ease-in-out;
}

.vs-menu-btn {
    width: 36px;
    height: 36px;
}

.vs-avatar-btn {
    height: 32px;
    padding: 0 12px;
    border-radius: 16px;
}

.vs-menu-btn i,
.vs-avatar-btn i {
    font-size: 1.1rem;
}

.vs-menu-btn:hover,
.vs-avatar-btn:hover {
    background-color: var(--vs-bg-hover);
    color: var(--vs-text-bright);
}

.vs-avatar-btn.active {
    background-color: var(--vs-accent);
    color: var(--vs-text-bright);
}

.vs-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 260px;
    background-color: var(--vs-bg-sidebar);
    border: 1px solid var(--vs-border-main);
    border-radius: 8px;
    overflow: hidden;
}

.vs-dropdown-header {
    padding: 12px 16px;
    background-color: var(--vs-bg-header);
}

.vs-dropdown-body {
    padding: 8px 16px;
}

.vs-info-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.8rem;
}

.vs-info-row span:first-child {
    color: var(--vs-text-muted);
}

.vs-dropdown-footer {
    padding: 8px;
    border-top: 1px solid var(--vs-border-main);
}

.vs-dropdown-footer button {
    color: var(--vs-text-default) !important;
}

.vs-dropdown-footer button:hover {
    background-color: var(--vs-bg-hover);
}



/* --- 7.1 CUSTOM FORM COMPONENTS (TsfTextEdit, IDLookup, etc.) --- */

/* A consistent label style for all custom TSF components */
.tsf-form-label {
    font-weight: 600;
    font-size: 0.85rem;
    display: block;
    opacity: 0.8;
}

/* This targets the RadzenTextBox specifically when it's inside our custom lookup wrapper */
.lookup-input-wrapper .rz-textbox {
    width: 100%;
    border: none !important;
    background: transparent !important;
}


/* --- 8. COMPLEX COMPONENTS --- */

/* 8.1. Lookup, Filter & Dialog */
.lookup-root {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 300px;
    background-color: var(--vs-bg-main);
    color: var(--vs-text-default);
}

.lookup-grid-container {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
}

.vs-lookup-group {
    display: flex;
    align-items: center;
}

.vs-lookup-group .form-control {
    flex: 1 1 auto;
    position: relative;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.vs-lookup-group .vs-action-btn {
    margin-left: -1px;
    height: 29px;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.lookup-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    background: var(--vs-bg-input);
    border: 1px solid var(--vs-border-main);
    border-radius: 6px;
}

.lookup-input-wrapper .rz-textbox {
    flex: 1 1 auto;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    color: inherit;
}

.lookup-input-wrapper .lookup-icon {
    position: absolute;
    right: 0.75rem;
    font-size: 0.95rem;
    color: var(--vs-text-muted);
    cursor: pointer;
    transition: color 0.15s ease;
}

.lookup-input-wrapper .lookup-icon:hover {
    color: var(--vs-text-bright);
}

.lookup-filter-bar {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: var(--vs-bg-header);
    border-bottom: 1px solid var(--vs-border-main);
    color: var(--vs-text-bright);
}

.filter-controls {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.filter-badge-container {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    flex-grow: 1;
}

.filter-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    background-color: var(--vs-bg-input);
    border: 1px solid var(--vs-border-main);
    color: var(--vs-text-default);
    border-radius: 12px;
    font-size: 0.75rem;
    white-space: nowrap;
}

.filter-badge-remove {
    margin-left: 8px;
    padding: 2px;
    font-size: 0.8em;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.2s;
}

.filter-badge-remove:hover {
    background-color: var(--vs-bg-hover);
    color: var(--vs-text-bright);
}

.filter-popup {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 44px;
    right: 8px; /* Default right */
    left: auto;   /* Default auto */
    min-width: 450px;
    padding: 12px;
    background: var(--vs-bg-sidebar);
    border: 1px solid var(--vs-border-main);
    box-shadow: 0 5px 15px var(--vs-bg-overlay);
    z-index: 1100;
}

.lookup-filter-bar > .filter-popup {
    left: 8px; /* Specific override for direct child */
    right: auto;
}

.filter-popup-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--vs-border-main);
}

.filter-popup-header h5 {
    margin: 0;
    font-size: 1rem;
    color: var(--vs-text-bright);
}

.filter-popup-content {
    flex: 1;
    overflow-y: auto;
    padding: 4px;
}

.filter-popup-footer {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--vs-border-main);
}

.filter-layout-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px 10px;
    align-items: center;
}

.filter-layout-grid > label {
    text-align: right;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--vs-text-muted);
}
    .filter-layout-grid.filter-grid-three-col {
        grid-template-columns: auto auto 1fr; /* Label | Operator | Input */
    }

/* --- Styling for the Quick Filter Bar --- */

.quick-filter-wrapper {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
}

/* Make the value input take up all available space */
.quick-filter-value-input {
    flex-grow: 1;
}
/* --- Styling for native Blazor <select> dropdowns in the Quick Filter --- */
.tsf-quick-filter-select {
    height: 29px; /* Matches Radzen input height */
    padding: 0 0.5rem;
    background-color: var(--vs-bg-input);
    border: 1px solid var(--vs-border-main);
    border-radius: 2px;
    color: var(--vs-text-default);
}

    .tsf-quick-filter-select:focus {
        border-color: var(--vs-border-focus);
        outline: none;
    }

.lookup-dialog-overlay {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background-color: var(--vs-bg-overlay);
    z-index: 4000;
}

.lookup-dialog {
    display: flex;
    flex-direction: column;
    width: min(960px, 95vw);
    max-height: 85vh;
    background-color: var(--vs-bg-main);
    border: 1px solid var(--vs-border-main);
    border-radius: 8px;
    box-shadow: 0 20px 40px var(--vs-bg-overlay);
}

.lookup-dialog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background-color: var(--vs-bg-header);
    border-bottom: 1px solid var(--vs-border-main);
}

.lookup-dialog-title {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: var(--vs-text-bright);
}

.lookup-dialog-close {
    padding: 0.25rem;
    background: transparent;
    border: none;
    color: var(--vs-text-muted);
    font-size: 1rem;
    cursor: pointer;
}

.lookup-dialog-close:hover {
    color: var(--vs-text-bright);
}

.lookup-dialog-body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    padding: 0;
}

.lookup-dialog-footer {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding: 0.75rem 1rem;
    background-color: var(--vs-bg-header);
    border-top: 1px solid var(--vs-border-main);
}

/* 8.2. Two-Column Layout (TSF) */
.tsf-two-column {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    position: relative;
    height: 100%;
    min-height: 0;
}

.tsf-two-column .left-pane {
    position: sticky;
    top: 0;
    width: 300px;
    flex-shrink: 0;
    padding: 1rem;
    background: var(--vs-bg-sidebar);
    color: var(--vs-text-default);
    font-size: 0.8125rem;
    max-height: 100%;
    overflow-y: auto;
    z-index: 1;
}

.tsf-two-column .right-pane {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow-y: auto;
    margin-left: 0;
}

.theme-dark .tsf-two-column .left-pane {
    background: #2b2b2b;
    color: #fff;
}

.tsf-two-column .left-pane .action-nav {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.tsf-two-column .left-pane .action-link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    background: transparent;
    color: var(--vs-text-default);
    text-decoration: none;
    border-radius: 4px;
    font-size: 0.8125rem;
}

.theme-dark .tsf-two-column .left-pane .action-link {
    color: #fff;
}

.tsf-two-column .left-pane .action-link:hover {
    background: var(--vs-bg-hover);
}

.tsf-two-column .left-pane .action-link.disabled {
    opacity: 0.45;
    pointer-events: none;
}

.tsf-two-column .left-pane .action-title {
    font-weight: 600;
}

.tsf-two-column .left-pane .action-hint {
    margin-left: 24px;
    font-size: 0.75rem;
    color: var(--vs-text-muted);
}

/* 8.3. Message Box */
.messagebox-overlay {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--vs-bg-overlay);
    z-index: 4500;
}

.messagebox-window {
    width: min(420px, 90vw);
    background-color: var(--vs-bg-main);
    border: 1px solid var(--vs-border-main);
    border-radius: 8px;
    box-shadow: 0 20px 40px var(--vs-bg-overlay);
    color: var(--vs-text-default);
    overflow: hidden;
}

.messagebox-window .title-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.75rem;
    background-color: var(--vs-bg-header);
    border-bottom: 1px solid var(--vs-border-main);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.85rem;
}

.messagebox-window .close-btn {
    background: transparent;
    border: none;
    color: var(--vs-text-muted);
    font-size: 1rem;
    cursor: pointer;
}

.messagebox-window .close-btn:hover {
    color: var(--vs-text-bright);
}

.messagebox-window .content {
    display: flex;
    padding: 1rem;
    gap: 0.75rem;
}

.messagebox-window .icon-area {
    flex-shrink: 0;
}

.messagebox-window .icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    font-size: 1.25rem;
    font-weight: bold;
    color: #fff;
}

.messagebox-window .icon.info { background-color: #2563eb; }
.messagebox-window .icon.warning { background-color: #d97706; }
.messagebox-window .icon.error { background-color: #b91c1c; }
.messagebox-window .icon.question { background-color: #059669; }
.messagebox-window .message-text {
    flex: 1;
    line-height: 1.4;
}

.messagebox-window .button-bar {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background-color: var(--vs-bg-header);
    border-top: 1px solid var(--vs-border-main);
}

.messagebox-window .win-btn {
    min-width: 80px;
    padding: 0.4rem 0.9rem;
    border-radius: 4px;
    border: 1px solid var(--vs-border-main);
    background-color: var(--vs-bg-sidebar);
    color: var(--vs-text-default);
    font-size: 0.85rem;
    cursor: pointer;
}

.messagebox-window .win-btn:hover {
    background-color: var(--vs-bg-hover);
}

.messagebox-window .win-btn.default {
    border-color: var(--vs-border-focus);
    color: var(--vs-text-bright);
}

/* --- 8.1. Lookup, Filter & Dialog --- */

.lookup-input-wrapper .lookup-icon {
    position: absolute;
    right: 0.75rem;
    font-size: 0.95rem;
    /* FIX: Force icon to match the default text color variable */
    color: var(--vs-text-default) !important;
    cursor: pointer;
    transition: color 0.15s ease;
    z-index: 2;
}

/* FIX: Prevent the icon from turning white when the row or input is focused/selected */
.rz-state-selected .lookup-icon,
.rz-state-highlight .lookup-icon,
.lookup-input-wrapper:focus-within .lookup-icon {
    color: var(--vs-text-default) !important;
}

.lookup-input-wrapper .lookup-icon:hover {
    color: var(--vs-accent) !important;
}
/* --- 9. THIRD-PARTY OVERRIDES --- */

/* 9.1. Radzen General */
.rz-p-1 {
    padding: 0px;
}

.rz-form-field-content {
    background-color: var(--vs-bg-input) !important;
}

.lookup-filter-bar .rz-button,
.filter-popup .rz-button {
    background-color: var(--vs-bg-input);
    border: 1px solid var(--vs-border-main);
    color: var(--vs-text-default);
}

.lookup-filter-bar .rz-button:hover,
.filter-popup .rz-button:hover {
    border-color: var(--vs-border-focus);
}

.filter-popup .rz-button.rz-primary {
    background-color: var(--vs-accent);
    color: white;
}

/* --- 9.2. Radzen DataGrid --- */

/* General container styles */
.rz-data-grid,
.rz-grid-table {
    background-color: var(--vs-bg-main);
    color: var(--vs-text-default); /* Default text for the component */
}

    /* Header styles */
    .rz-grid-header,
    .rz-grid-table thead th,
    .rz-grid-table thead th.rz-sortable-column:not(.rz-state-active):hover {
        background-color: var(--vs-bg-sidebar) !important;
        /* This gradient adds the "3D" lighting effect */
        background-image: linear-gradient(to bottom, rgba(255,255,255,0.1), rgba(0,0,0,0.05)) !important;
        border-top: 1px solid rgba(255, 255, 255, 0.2); /* Creates the top light "edge" */
        border-bottom: 2px solid var(--vs-border-main) !important;
    }

.rz-grid-header-cell {
    background-color: var(--vs-bg-sidebar) !important;
    color: var(--vs-text-muted) !important;
    font-size: 11px !important;
    text-transform: uppercase;
    border-bottom: none !important;
}

.rz-column-title {
    color: var(--vs-text-muted);
}

.rz-sortable-column .rz-column-title,
.rz-grid-table thead th .rz-column-title-content,
.rz-grid-table thead th .rz-sort-icon,
.rz-grid-table thead th .rz-column-filter-button {
    color: var(--vs-text-default) !important;
}

.rz-grid-header-cell .rz-sort-indicator,
.rz-grid-filter-icon {
    color: var(--vs-text-default) !important;
}

.rz-sortable-column:hover {
    background-color: var(--vs-bg-hover) !important;
}

/* Vertical Grid Lines */
.rz-grid-table th,
.rz-grid-table td {
    border-right: 1px solid var(--vs-border-light);
}

    .rz-grid-table th:last-child,
    .rz-grid-table td:last-child {
        border-right: none;
    }



/* --- 9.2. Radzen DataGrid - Static Style (No Hover/Selection Effects) --- */

/* 1. Force all rows to maintain the main background color */
.rz-grid-table .rz-data-row td,
.rz-grid-table .rz-data-row:hover td,
.rz-grid-table .rz-data-row.rz-state-hover td,
.rz-grid-table .rz-data-row.rz-state-selected td,
.rz-grid-table .rz-data-row.rz-state-highlight td {
    background-color: var(--vs-bg-main) !important;
    border-bottom: 1px solid var(--vs-border-light) !important;
}

/* 2. Prevent text color from changing (avoids turning white on selection) */
.rz-grid-table .rz-data-row,
.rz-grid-table .rz-data-row td,
.rz-grid-table .rz-data-row span,
.rz-grid-table .rz-data-row.rz-state-highlight td,
.rz-grid-table .rz-data-row.rz-state-selected td {
    color: var(--vs-text-default) !important;
}

/* 3. Keep vertical grid lines consistent */
.rz-grid-table th,
.rz-grid-table td {
    border-right: 1px solid var(--vs-border-light) !important;
}

/*
 * ===================================================================
 *  DEFINITIVE GRID TEXT COLOR OVERRIDE
 * ===================================================================
 * This rule targets the grid within its .lookup-root parent to create
 * a high-specificity selector that defeats Radzen's default styles
 * applied during the Blazor re-render cycle.
*/
.lookup-root .rz-grid-row,
.lookup-root .rz-datatable-emptymessage {
    color: var(--vs-grid-cell-text-color) !important;
}
/*
 * ===================================================================
 *  DEFINITIVE FIX FOR ROW & CELL TEXT
 * ===================================================================
*/

/* Set the default background for all data rows */
.lookup-root .rz-grid-table .rz-data-row td {
    background-color: var(--vs-bg-main) !important;
    border-bottom: 1px solid var(--vs-border-light);
    padding: 4px 8px !important;
}
/* Set the TEXT COLOR for rows and the empty message using your variable */
.rz-grid-row,
.rz-datatable-emptymessage {
    color: var(--vs-grid-cell-text-color) !important;
}

    /* Handle the ROW HOVER state */
    .rz-grid-row:hover,
    .rz-grid-row.rz-state-hover,
    .rz-grid-table .rz-data-row:not(.rz-state-highlight):hover td,
    .rz-grid-table .rz-data-row:not(.rz-state-selected):hover td {
        background-color: var(--vs-bg-hover) !important;
    }

    /* Handle the ROW SELECTED state */
    .rz-grid-row.rz-state-selected,
    .rz-grid-table .rz-data-row.rz-state-highlight td,
    .rz-grid-table .rz-data-row.rz-state-selected td,
    .rz-data-row.rz-state-highlight,
    .rz-datatable-tbody > .rz-data-row.rz-state-highlight > td {
        background-color: var(--vs-bg-selected) !important;
        color: var(--vs-text-bright) !important; /* Use brightest text for selection */
    }

/* Pager styles */
.rz-grid-pager {
    background-color: var(--vs-bg-sidebar);
    border-top: 1px solid var(--vs-border-main);
    color: var(--vs-text-muted);
}

.rz-pager-link,
.rz-pager-nav {
    color: var(--vs-text-default) !important;
}

    .rz-pager-link.rz-state-active {
        background-color: var(--vs-accent) !important;
        color: white !important;
    }

/* 9.3. Radzen Slim Theme */
.radzen-slim {
    /* General Inputs */
    --rz-input-font-size: 0.8125rem;
    --rz-input-height: 28px;
    --rz-input-padding: 0.25rem 0.5rem;
    /* FormField */
    --rz-form-field-margin-bottom: 0.8rem;
    --rz-form-field-font-size: 0.75rem;
    /* Button */
    --rz-button-font-size: 0.8125rem;
    --rz-button-padding: 0.25rem 0.75rem;
    --rz-button-icon-margin: 0 0.25rem 0 0;
    /* DataGrid */
    --rz-grid-header-cell-padding: 0.35rem 0.5rem;
    --rz-grid-cell-padding: 0.25rem 0.5rem;
    --rz-grid-header-font-size: 0.75rem;
    --rz-grid-font-size: 0.8125rem;
    --rz-grid-filter-button-width: 24px;
    --rz-grid-filter-button-height: 24px;
    /* DropDown */
    --rz-dropdown-item-padding: 0.25rem 0.6rem;
    --rz-dropdown-item-font-size: 0.8125rem;
    /* DatePicker */
    --rz-datepicker-calendar-header-padding: 0.2rem;
    --rz-datepicker-calendar-header-font-size: 0.8rem;
    --rz-datepicker-calendar-cell-padding: 0.2rem;
    --rz-datepicker-calendar-cell-font-size: 0.75rem;
    /* CheckBox & RadioButton */
    --rz-chkbox-size: 16px;
    --rz-radio-size: 16px;
    /* Pager */
    --rz-pager-padding: 0.2rem;
    --rz-pager-item-width: 28px;
    --rz-pager-item-height: 28px;
    --rz-pager-item-margin: 0 2px;
}

.radzen-slim .rz-grid-filter-case-sensitive-button { margin-left: 2px !important; }
.radzen-slim .rz-column-filter-operator { margin-bottom: 4px !important; }
.radzen-slim .rz-grid-filter-buttons { margin-top: 4px !important; }
.radzen-slim .rz-datepicker .rz-inputtext-icon-right { padding-right: 1.5rem !important; }
.radzen-slim .rz-button.rz-button-icon-only { width: 28px; height: 28px; }


/* 9.4. Other ERP Overrides */
.card.bg-light {
    background-color: var(--vs-bg-sidebar) !important;
    border: 1px solid var(--vs-border-main) !important;
    color: var(--vs-text-default) !important;
}

.table {
    margin-bottom: 0;
    color: var(--vs-text-default);
}

.table thead th {
    background-color: var(--vs-bg-sidebar);
    color: var(--vs-text-muted);
    border-bottom: 2px solid var(--vs-border-main);
    font-size: 11px;
    text-transform: uppercase;
}

.table td {
    border-bottom: 1px solid var(--vs-border-light);
    vertical-align: middle;
}

.win-div-header {
    height: 20px;
    background-color: var(--vs-bg-header) !important;
    border-bottom: 1px solid var(--vs-border-main) !important;
    color: var(--vs-text-bright) !important;
}

.win-div-content {
    background-color: var(--vs-bg-main) !important;
    margin-top: 1rem;
    margin-left: 0.5rem;
    margin-right: 0.5rem;
    color: var(--vs-text-default) !important;
}


/* --- 10. DYNAMIC STATES & ANIMATIONS --- */
.vs-app-bar.navbar-bg-alert {
    background-color: #a12626 !important;
    transition: background-color 0.3s ease-in-out;
}

.vs-app-bar.navbar-bg-success {
    background-color: #1a7e3a !important;
    transition: background-color 0.3s ease-in-out;
}

.vs-app-bar.navbar-bg-warning {
    background-color: #b95a00 !important;
    transition: background-color 0.3s ease-in-out;
}

.animate-fade-in {
    animation: vsFadeIn 0.2s ease-out;
}

@keyframes vsFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}


/* --- 11. RESPONSIVE MEDIA QUERIES --- */
@media (max-width: 768px) {
    .form-grid {
        grid-template-columns: 1fr;
    }

    .vs-content-body {
        padding: 1px !important;
    }

    .tsf-two-column {
        flex-direction: column;
        gap: 0;
    }

    .tsf-two-column .right-pane {
        order: 1;
        width: 100%;
        margin-left: 0;
        overflow-y: visible;
    }

    .tsf-two-column .right-pane .vs-content-body {
        padding: 1px;
    }

    .tsf-two-column .left-pane {
        order: 2;
        position: sticky;
        top: auto;
        bottom: var(--vs-footer-height);
        width: 100%;
        padding: 0;
        background: var(--vs-bg-header);
        border-top: 1px solid var(--vs-border-main);
        max-height: none;
        overflow-y: hidden;
        z-index: 2000;
    }

    .tsf-two-column .left-pane .action-nav {
        flex-direction: row;
        justify-content: space-around;
        width: 100%;
    }

    .tsf-two-column .left-pane .action-link {
        flex: 1;
        justify-content: center;
        padding: 12px 8px;
        color: var(--vs-text-muted);
    }

    .tsf-two-column .left-pane .action-link:hover {
        color: var(--vs-text-bright);
    }

    .tsf-two-column .left-pane .action-title {
        display: none;
    }

    .tsf-two-column .left-pane .action-link i {
        margin-right: 0;
        font-size: 1.2rem;
    }
}




/* --- TsfTabs Custom Component Styles --- */
.tsf-tabs-wrapper {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.tsf-tabs-nav {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
    background-color: var(--vs-bg-sidebar);
    border-bottom: 1px solid var(--vs-border-main);
    height: 30px; /* Ultra-compact IDE height */
    align-items: flex-end;
}

.tsf-tab-item {
    display: flex;
    align-items: center;
    padding: 0 15px;
    height: 29px;
    cursor: pointer;
    font-size: 0.75rem; /* Exactly 12px */
    color: var(--vs-text-muted);
    border-right: 1px solid var(--vs-border-light);
    transition: all 0.1s ease;
    user-select: none;
    border-top: 2px solid transparent; /* Placeholder for active state */
}

    .tsf-tab-item i {
        font-size: 0.8rem;
        margin-right: 6px;
        opacity: 0.8;
    }

    .tsf-tab-item:hover:not(.disabled):not(.active) {
        background-color: var(--vs-bg-hover);
        color: var(--vs-text-bright);
    }

    /* Active State: The "Eclipse/VS" look */
    .tsf-tab-item.active {
        background-color: var(--vs-bg-main);
        color: var(--vs-text-bright);
        font-weight: 500;
        border-top: 2px solid var(--vs-accent); /* Blue bar at the top */
        border-bottom: 1px solid var(--vs-bg-main); /* Blends into panel */
        margin-bottom: -1px;
        z-index: 5;
    }

    .tsf-tab-item.disabled {
        opacity: 0.4;
        cursor: not-allowed;
    }

.tsf-tabs-content {
    flex-grow: 1;
    background-color: var(--vs-bg-main);
    padding: 12px 0;
}

.tsf-sub-toolbar {
    height: 30px;
    align-content: center;
    margin-top: 5px;
    background-color: var(--vs-bg-header) !important;
    border-bottom: 1px solid var(--vs-border-main) !important;
    color: var(--vs-text-bright) !important;
}
    .tsf-sub-toolbar .action-link {
        gap: 10px;
        padding: 8px 10px;
        background: transparent;
        color: var(--vs-text-default);
        text-decoration: none;
        font-size: 0.8125rem;
    }


/* --- Zoho-Style Responsive Timesheet --- */
.ts-container {
    width: 100%;
    overflow-x: auto;
}

@media (max-width: 768px) {
    .ts-table thead {
        display: none;
    }
    /* Hide headers on mobile */
    .ts-table, .ts-table tbody, .ts-table tr, .ts-table td {
        display: block;
        width: 100% !important;
    }

        .ts-table tr {
            margin-bottom: 15px;
            border: 1px solid var(--vs-border-main);
            border-radius: 8px;
            background: #fff;
            padding: 10px;
        }

        .ts-table td {
            border: none !important;
            padding: 5px 0 !important;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
            /* Add labels on mobile */
            .ts-table td:before {
                content: attr(data-label);
                font-weight: bold;
                font-size: 11px;
                color: var(--vs-text-muted);
                text-transform: uppercase;
            }

    .day-cell {
        width: 100% !important;
        border-top: 1px solid #eee !important;
        margin-top: 5px;
    }

    /* Add inside your @media (max-width: 768px) block */

    .ts-table thead {
        display: none; /* Hide table headers on small screens */
    }

    .ts-table, .ts-table tbody, .ts-table tr.ts-table-row, .ts-table td.ts-table-cell {
        display: block;
        width: 100% !important;
    }

        .ts-table tr.ts-table-row {
            margin-bottom: 1rem;
            border: 1px solid var(--vs-border-main);
            border-radius: 4px;
            background: var(--vs-bg-sidebar);
            padding: 0.75rem;
        }

        .ts-table td.ts-table-cell {
            border: none !important;
            padding: 0.5rem 0 !important;
            display: flex;
            flex-direction: column; /* Stack label on top of input */
            align-items: flex-start;
        }

            /* Create pseudo-labels from the data-label attribute */
            .ts-table td.ts-table-cell:before {
                content: attr(data-label);
                font-weight: bold;
                font-size: 0.7rem; /* 11px */
                color: var(--vs-text-muted);
                text-transform: uppercase;
                margin-bottom: 0.25rem;
            }
}


.vs-loader-active {
    cursor: wait !important;
}

    .vs-loader-active input {
        pointer-events: none; /* Prevent typing while loading */
        background-color: var(--vs-bg-hover) !important;
    }

/* QuickGrid Striping Integration */
.lookup-grid-container table.table-striped tbody tr:nth-of-type(odd) {
    background-color: var(--vs-bg-main) !important;
}

.lookup-grid-container table.table-striped tbody tr:nth-of-type(even) {
    background-color: var(--vs-bg-sidebar) !important; /* Slightly darker than main */
    opacity: 0.8;
}

.lookup-grid-container table tbody tr:hover {
    background-color: var(--vs-bg-hover) !important;
}