/* =========================================================
   COLOR TOKEN NAMING RULES (DO NOT MODIFY LIGHTLY)
   =========================================================

   PURPOSE
   -------
   Enforce a consistent, scalable naming convention for all
   design tokens (CSS custom properties).

   These rules prevent drift, duplication, and ambiguity.

   ---------------------------------------------------------
   REQUIRED FORMAT
   ---------------------------------------------------------

   --color-{domain}-{component}-{variant?}-{state?}-{property}

   Examples:
   --color-nav-link-text
   --color-nav-current-bg
   --color-sales-btn-open-hover-bg
   --color-alert-error-border

   ---------------------------------------------------------
   SEGMENT DEFINITIONS
   ---------------------------------------------------------

   1. PREFIX (REQUIRED)
      Must always start with:
      --color-

   2. DOMAIN (REQUIRED)
      High-level system or feature area.

      Examples:
      nav, sales, alert, panel, table, layout,
      input, manifest, bootstrap, env

   3. COMPONENT (REQUIRED)
      UI element or concept.

      Examples:
      link, btn, status, doctype, surface,
      panel, row, overlay, header

   4. VARIANT (OPTIONAL)
      Specific type or subtype.

      Examples:
      open, closed, draft, success, error,
      estimate, sample, sales-order

   5. STATE (OPTIONAL)
      Interaction or UI state.

      Examples:
      hover, active, focus, disabled, current

   6. PROPERTY (REQUIRED - ALWAYS LAST)
      Preferred values:
      bg, text, border, shadow, ring

   ---------------------------------------------------------
   ORDER RULE (STRICT)
   ---------------------------------------------------------

   Tokens MUST follow this order:

   domain → component → variant → state → property

   ✔ --color-sales-btn-open-hover-bg
   ✘ --color-btn-sales-bg

   ---------------------------------------------------------
   NAMING RULES
   ---------------------------------------------------------

   ✔ lowercase kebab-case only
   ✔ use full words (no abbreviations)
   ✔ property MUST be the final segment
   ✔ tokens represent semantic meaning, not raw color

   ---------------------------------------------------------
   FORBIDDEN PATTERNS
   ---------------------------------------------------------

   ✘ missing domain
     --color-hover-bg

   ✘ missing component layer
     --color-nav-bg

   ✘ abbreviations
     --color-nav-txt

   ✘ mixed order
     --color-btn-sales-bg

   ---------------------------------------------------------
   ALLOWED EXCEPTIONS
   ---------------------------------------------------------

   These are allowed when they better describe intent:

   1. Layered ring tokens
      inner, outer
      --color-bootstrap-focus-ring-inner
      --color-bootstrap-focus-ring-outer

   2. Gradient stop tokens
      start, end
      --color-sales-estimate-gradient-start
      --color-sales-estimate-gradient-end

   3. Semantic text roles
      title, subtitle, help
      --color-manifest-title-text
      --color-manifest-subtitle-text
      --color-manifest-help-text

   4. Accent tokens
      accent
      --color-document-panel-accent-border

   5. Numeric semantic states
      zero, negative
      --color-table-numeric-zero
      --color-table-numeric-negative

   6. Environment tokens (no explicit component)
      --color-env-titlebar-prod-bg
      --color-env-titlebar-dev-bg

   ---------------------------------------------------------
   PREFERRED OVER LEGACY
   ---------------------------------------------------------

   Prefer:
   text  (instead of fg)

   ---------------------------------------------------------
   DUPLICATION RULE
   ---------------------------------------------------------

   Do NOT deduplicate tokens even if values match.
   Tokens represent meaning, not just color.

   ---------------------------------------------------------
   EXTENDING THE SYSTEM
   ---------------------------------------------------------

   When adding new tokens:
   1. Choose DOMAIN
   2. Add COMPONENT
   3. Add VARIANT if needed
   4. Add STATE if needed
   5. End with PROPERTY

   ---------------------------------------------------------
   END OF RULES
   ========================================================= */

:root {
    /* =====================================================
       Bootstrap / Core Interaction
       ===================================================== */

    --color-bootstrap-focus-ring-inner: #fff;
    --color-bootstrap-focus-ring-outer: #258cfb;
    /* =====================================================
       Environment Title Bar
       ===================================================== */

    --color-env-titlebar-prod-bg: #1b5e20;
    --color-env-titlebar-staging-bg: #8b6f00;
    --color-env-titlebar-dev-bg: #7f1d1d;
    --color-env-titlebar-local-bg: #f00;
    /* =====================================================
       Layout
       ===================================================== */

    --color-layout-sidebar-bg: #f8fbf6;
    --color-layout-main-bg: #fff;
    /* =====================================================
       Navigation - Surface
       ===================================================== */

    --color-nav-surface-bg: #f8fbf6;
    --color-nav-surface-border: rgba(183, 215, 168, 0.45);
    --color-nav-surface-shadow: rgba(0, 0, 0, 0.12);
    /* =====================================================
       Navigation - Content
       ===================================================== */

    --color-nav-link-text: #1b5e20;
    --color-nav-link-hover-bg: rgba(27, 94, 32, 0.08);
    --color-nav-group-text: #1b5e20;
    --color-nav-current-bg: rgba(183, 215, 168, 0.18);
    --color-nav-current-text: #154a19;
    --color-nav-current-border: rgba(183, 215, 168, 0.45);
    --color-nav-disabled-text: rgba(27, 94, 32, 0.45);
    --color-nav-signout-text: #b91c1c;
    --color-nav-signout-hover-bg: rgba(185, 28, 28, 0.12);
    --color-nav-signout-current-bg: rgba(185, 28, 28, 0.16);
    --color-nav-signout-current-border: rgba(185, 28, 28, 0.4);
    --color-nav-group-divider-border: #e5e7eb;
    --color-nav-menu-toggle-border: rgba(255, 255, 255, 0.35);
    --color-nav-menu-toggle-hover-bg: rgba(255, 255, 255, 0.08);
    --color-nav-mobile-overlay-bg: rgba(0, 0, 0, 0.2);
    /* =====================================================
       Neutral Interaction Overlays
       ===================================================== */

    --color-sales-card-hover-border: rgba(0, 0, 0, 0.2);
    --color-sales-card-hover-shadow: rgba(0, 0, 0, 0.12);
    --color-picker-row-hover-bg: #f8f9fa;
    /* =====================================================
       Alerts
       ===================================================== */

    --color-alert-error-bg: #f00;
    --color-alert-error-text: #fff;
    --color-alert-error-border: #f00;
    --color-alert-error-ring: rgba(255, 0, 0, 0.25);
    --color-alert-success-bg: #198754;
    --color-alert-success-text: #fff;
    --color-alert-success-border: #198754;
    --color-alert-success-ring: rgba(25, 135, 84, 0.25);
    --color-alert-warning-bg: #ffc107;
    --color-alert-warning-text: #000;
    --color-alert-warning-border: #ffc107;
    --color-alert-warning-ring: rgba(255, 193, 7, 0.25);
    /* =====================================================
       Flash / Scan Feedback
       ===================================================== */

    --color-flash-success-bg: #b7d7a8;
    --color-flash-success-text: #000;
    --color-flash-error-bg: #f00;
    --color-flash-error-text: #fff;
    /* =====================================================
       Sales Document Types
       ===================================================== */

    --color-sales-doctype-text: #000;
    --color-sales-doctype-border: #000;
    --color-sales-doctype-estimate-bg: #f2cbf4;
    --color-sales-estimate-gradient-start: #f2cbf4;
    --color-sales-estimate-gradient-end: #a74be1;
    --color-sales-doctype-sample-bg: #fceabb;
    --color-sales-sample-gradient-start: #fceabb;
    --color-sales-sample-gradient-end: #f8b500;
    --color-sales-doctype-sales-order-bg: #c4e354;
    --color-sales-order-gradient-start: #c4e354;
    --color-sales-order-gradient-end: #1d8b1d;
    /* =====================================================
       Sales Document Status
       ===================================================== */

    --color-sales-status-draft-text: #fff;
    --color-sales-status-draft-bg: #ec8206;
    --color-sales-status-draft-border: #ffc107;
    --color-sales-status-open-text: #fff;
    --color-sales-status-open-bg: #0d6efd;
    --color-sales-status-open-border: #0d6efd;
    --color-sales-status-finalized-text: #fff;
    --color-sales-status-finalized-bg: #1e3a8a;
    --color-sales-status-finalized-border: #172f6b;
    --color-sales-status-partial-text: #fff;
    --color-sales-status-partial-bg: #79ba73;
    --color-sales-status-partial-border: #4caf7a;
    --color-sales-status-closed-text: #fff;
    --color-sales-status-closed-bg: #198754;
    --color-sales-status-closed-border: #198754;
    --color-sales-status-void-text: #fff;
    --color-sales-status-void-bg: #dc3545;
    --color-sales-status-void-border: #dc3545;
    /* =====================================================
       Sales Workflow Buttons
       ===================================================== */

    --color-sales-btn-disabled-text: #e9ecef;
    --color-sales-btn-disabled-bg: #b0b0b0;
    --color-sales-btn-disabled-border: #6c757d;
    --color-sales-btn-draft-text: #fff;
    --color-sales-btn-draft-bg: #ec8206;
    --color-sales-btn-draft-border: #ec8206;
    --color-sales-btn-draft-hover-bg: #d87705;
    --color-sales-btn-draft-hover-border: #cc7005;
    --color-sales-btn-draft-active-bg: #c96f05;
    --color-sales-btn-draft-active-border: #bc6804;
    --color-sales-btn-draft-focus-ring: rgba(236, 130, 6, 0.35);
    --color-sales-btn-open-text: #fff;
    --color-sales-btn-open-bg: #0d6efd;
    --color-sales-btn-open-border: #0d6efd;
    --color-sales-btn-open-hover-bg: #0b65e9;
    --color-sales-btn-open-hover-border: #0a5fdc;
    --color-sales-btn-open-active-bg: #0a5ed7;
    --color-sales-btn-open-active-border: #0957ca;
    --color-sales-btn-open-focus-ring: rgba(13, 110, 253, 0.35);
    --color-sales-btn-finalized-text: #fff;
    --color-sales-btn-finalized-bg: #1e3a8a;
    --color-sales-btn-finalized-border: #1e3a8a;
    --color-sales-btn-finalized-hover-bg: #1a3478;
    --color-sales-btn-finalized-hover-border: #162d66;
    --color-sales-btn-finalized-active-bg: #162d66;
    --color-sales-btn-finalized-active-border: #122552;
    --color-sales-btn-finalized-focus-ring: rgba(30, 58, 138, 0.35);
    --color-sales-btn-closed-text: #fff;
    --color-sales-btn-closed-bg: #198754;
    --color-sales-btn-closed-border: #198754;
    --color-sales-btn-closed-hover-bg: #177c4d;
    --color-sales-btn-closed-hover-border: #157247;
    --color-sales-btn-closed-active-bg: #157347;
    --color-sales-btn-closed-active-border: #146941;
    --color-sales-btn-closed-focus-ring: rgba(25, 135, 84, 0.35);
    --color-sales-btn-return-text: #fff;
    --color-sales-btn-return-bg: #8400ff;
    --color-sales-btn-return-border: #8400ff;
    --color-sales-btn-return-hover-bg: #7900e8;
    --color-sales-btn-return-hover-border: #7100d9;
    --color-sales-btn-return-active-bg: #7100d9;
    --color-sales-btn-return-active-border: #6900ca;
    --color-sales-btn-return-focus-ring: rgba(132, 0, 255, 0.35);
    --color-sales-btn-void-text: #fff;
    --color-sales-btn-void-bg: #dc3545;
    --color-sales-btn-void-border: #dc3545;
    --color-sales-btn-void-hover-bg: #ca313f;
    --color-sales-btn-void-hover-border: #be2e3b;
    --color-sales-btn-void-active-bg: #bd2d3b;
    --color-sales-btn-void-active-border: #b12a37;
    --color-sales-btn-void-focus-ring: rgba(220, 53, 69, 0.35);
    /* =====================================================
       Manifest Uploader
       ===================================================== */

    --color-manifest-overlay-border: #0d6efd;
    --color-manifest-overlay-bg: rgba(231, 241, 255, 0.96);
    --color-manifest-overlay-shadow: rgba(13, 110, 253, 0.12);
    --color-manifest-title-text: #0d6efd;
    --color-manifest-subtitle-text: #495057;
    --color-manifest-status-ok-text: #198754;
    --color-manifest-help-text: #6c757d;
    /* =====================================================
       Panel System
       ===================================================== */

    --color-panel-border: #e5e7eb;
    --color-panel-bg: #fff;
    --color-panel-shadow: rgba(0, 0, 0, 0.04);
    --color-form-panel-bg: #f8f9fa;
    --color-document-panel-bg: #fff;
    --color-document-panel-accent-border: #0d6efd;
    --color-lookup-panel-bg: #f8f9fa;
    --color-lookup-panel-accent-border: #6c757d;
    /* =====================================================
       Modal Confirm
       ===================================================== */

    --color-modal-confirm-header-bg: #b7d7a8;
    /* =====================================================
       Table System
       ===================================================== */
    --color-table-header-bg: #b7d7a8;
    --color-table-row-odd-bg: #f8fbf6;
    --color-table-row-even-bg: #fff;
    --color-table-footer-bg: #b7d7a8;
    --color-table-footer-border: #b7d7a8;
    --color-table-numeric-zero: #b7b7b7;
    --color-table-numeric-negative: #c00000;
    --color-table-numeric-positive: #1d8b1d;
    /* =====================================================
       Input / Validation
       ===================================================== */

    --color-input-invalid-border: #dc3545;
    --color-input-invalid-focus-ring: rgba(220, 53, 69, 0.25);
    /* =====================================================
       Document Picker
       ===================================================== */

    --color-document-picker-overlay-bg: rgba(0, 0, 0, 0.2);
    --color-document-picker-panel-bg: #fff;
    --color-document-picker-panel-border: #ccc;
    --color-document-picker-panel-shadow: rgba(0, 0, 0, 0.2);
    /* =====================================================
       Debug Console
       ===================================================== */

    --color-debug-toggle-border: #4a4a4a;
    --color-debug-toggle-bg: #111;
    --color-debug-toggle-text: #9cff9c;
    --color-debug-panel-bg: #000;
    --color-debug-panel-border: #2e2e2e;
    --color-debug-panel-shadow: rgba(0, 0, 0, 0.4);
    --color-debug-header-bg: #0b0b0b;
    --color-debug-header-border: #1e1e1e;
    --color-debug-title-text: #b8ffb8;
    --color-debug-button-bg: #111;
    --color-debug-button-hover-bg: #1a1a1a;
    --color-debug-button-border: #2e2e2e;
    --color-debug-button-text: #9cff9c;
    --color-debug-info-text: #9cff9c;
    --color-debug-warn-text: #ffe082;
    --color-debug-error-text: #ff8f8f;
    --color-debug-muted-text: #6eb56e;
    /* =====================================================
       Notes
       ===================================================== */

    --color-notes-meta-text: #6c757d;
    --color-notes-shell-bg: #f8fbf6;
    --color-notes-shell-border: #d9e7d5;
    --color-notes-shell-shadow: rgba(0, 0, 0, 0.06);
    --color-notes-shell-header-bg: #dcebd8;
    --color-notes-shell-header-border: #d1e3cc;
    --color-notes-shell-title-text: #2f4f2f;
    --color-notes-shell-tools-text: #4f6f4f;
    --color-notes-shell-status-text: #5f7f5f;
    --color-notes-shell-status-error-text: #a94442;
    --color-notes-card-bg: #f8fbf6;
    --color-notes-card-border: #d9e7d5;
    --color-notes-card-shadow: rgba(0, 0, 0, 0.06);
    --color-notes-card-header-bg: #dcebd8;
    --color-notes-card-header-text: #2f4f2f;
    --color-notes-card-time-text: #5f7f5f;
    --color-notes-card-deleted-header-bg: #f4dddd;
    --color-notes-card-deleted-header-text: #7a2f2f;
    --color-notes-card-deleted-time-text: #9a5a5a;
    --color-notes-text: #263226;
    --color-notes-deleted-badge-text: #7a2f2f;
    --color-notes-deleted-badge-bg: #f8eaea;
    --color-notes-deleted-badge-border: #e8bcbc;
    --color-notes-icon: #1b5e20;
    /* =====================================================
       Payments
       ===================================================== */
    --color-payment-detail-label-text: #6c757d;
    --color-payment-readonly-field-bg: #f8f9fa;
    --color-payment-readonly-field-border: #ced4da;
    --color-payment-status-unverified-text: #0d6efd;
    --color-payment-status-verified-match-text: #198754;
    --color-payment-status-verified-variance-text: #fd7e14;
    --color-payment-status-void-text: #dc3545;
    --color-payment-variance-zero-text: #198754;
    --color-payment-variance-nonzero-text: #dc3545;
    --color-payment-filter-control-border: #d9e7d5;
    --color-payment-filter-control-hover-border: #c8dcc2;
    --color-payment-filter-control-bg: #fff;
    --color-payment-filter-control-inset-shadow: rgba(255, 255, 255, 0.9);
    --color-payment-filter-control-shadow: rgba(0, 0, 0, 0.06);
    --color-payment-filter-control-focus-border: #79ba73;
    --color-payment-filter-control-focus-ring: rgba(121, 186, 115, 0.15);
    --color-payment-filter-dropdown-border: #d9e7d5;
    --color-payment-filter-dropdown-shadow: rgba(0, 0, 0, 0.12);
    --color-payment-filter-dropdown-active-bg: #f8fbf6;
    --color-payment-filter-status-all-text: #6c757d;
}



/* =========================================================
   Base / Bootstrap Template Defaults
   ========================================================= */

html {
    font-size: 14px;
    position: relative;
    min-height: 100%;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 0.1rem var(--color-bootstrap-focus-ring-inner), 0 0 0 0.25rem var(--color-bootstrap-focus-ring-outer);
}


/* =========================================================
   Environment Title Bar
   ========================================================= */

.gl-env-prod {
    background-color: var(--color-env-titlebar-prod-bg);
}

.gl-env-staging {
    background-color: var(--color-env-titlebar-staging-bg);
}

.gl-env-dev {
    background-color: var(--color-env-titlebar-dev-bg);
}

.gl-env-local {
    background-color: var(--color-env-titlebar-local-bg);
}


/* =========================================================
   Footer Spacing
   ========================================================= */

.footer {
    height: 48px;
    line-height: 48px;
}

body {
    margin-bottom: 48px;
}


/* =========================================================
   Shell / Layout
   ========================================================= */

.gl-shell {
    display: flex;
}

.gl-main {
    flex-grow: 1;
    transition: margin-left 0.25s ease;
    background: var(--color-layout-main-bg);
    padding: 1.5rem 1.5rem 1.5rem 1.5rem;
}


/* =========================================================
   Sidebar
   ========================================================= */

.gl-sidebar {
    width: 260px;
    flex: 0 0 260px;
    max-width: 260px;
    min-height: calc(100vh - 56px);
    overflow-y: auto;
    background: var(--color-nav-surface-bg);
    border-right: 1px solid var(--color-nav-surface-border);
    box-shadow: 0 0.75rem 1.5rem var(--color-nav-surface-shadow);
    transform: translateX(0);
    transition: width 0.25s ease, flex-basis 0.25s ease, max-width 0.25s ease, transform 0.25s ease;
    position: sticky;
    top: 56px;
}

    .gl-sidebar .gl-nav {
        display: flex;
        flex-direction: column;
        min-height: calc(100vh - 80px);
    }

.gl-sidebar-toggle-icon {
    font-size: 16px;
}

.gl-sidebar-sticky {
    position: relative;
}


/* =========================================================
   Sidebar Collapsed State
   ========================================================= */

body.gl-sidebar-collapsed .gl-sidebar {
    width: 0;
    flex-basis: 0;
    max-width: 0;
    min-width: 0;
    overflow: hidden;
    border-right: 0;
    box-shadow: none;
    transform: translateX(-1rem);
}

    body.gl-sidebar-collapsed .gl-sidebar .gl-nav {
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.15s ease;
    }

body:not(.gl-sidebar-collapsed) .gl-sidebar .gl-nav {
    opacity: 1;
    transition: opacity 0.2s ease 0.05s;
}


/* =========================================================
   Icon Helpers
   ========================================================= */

.gl-icon {
    width: 20px;
    text-align: center;
    font-size: 16px;
}
    .gl-icon.sm {
        font-size: 16px;
    }

    .gl-icon.md {
        font-size: 20px;
    }

    .gl-icon.lg {
        font-size: 24px;
    }

    .gl-icon.xl {
        font-size: 32px;
    }

/* ================================
   NAV ICON (Material Symbols)
================================ */

.gl-navicon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px; /* nav-friendly size */
    line-height: 1;
    width: 24px; /* fixed width = perfect column alignment */
    min-width: 24px;
    margin-right: 0.5rem; /* spacing before text */
    vertical-align: middle;
    /* smoother rendering */
    -webkit-font-smoothing: antialiased;
}
    .gl-navicon.big {
        font-size: 26px
    }
/* Material Symbols specific tuning */
.material-symbol.gl-navicon {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;
}

/* Current page emphasis */
.gl-navlink.current-page .gl-navicon {
    font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 20;
}

/* Hover subtle bump */
.gl-navlink:hover .gl-navicon {
    transform: translateY(-1px);
}
.gl-navlink.current-page {
    font-weight: 600;
}
body.gl-sidebar-collapsed .gl-navicon {
    margin-right: 0;
}

.gl-toggleall-icon {
    font-size: 1rem;
    line-height: 1;
}


/* =========================================================
   Menu Buttons
   ========================================================= */

.gl-iconbtn {
    width: 32px;
    height: 32px;
    padding: 0.15rem 0.45rem;
    line-height: 1.1;
    border-radius: 0.6rem;
    color: var(--color-nav-link-text);
    background: transparent;
    border: none;
}

    .gl-iconbtn:hover {
        background: var(--color-nav-link-hover-bg);
        color: var(--color-nav-link-text);
    }

    .gl-iconbtn:focus,
    .gl-iconbtn:active:focus {
        outline: none;
        box-shadow: none;
    }

    .gl-iconbtn:focus-visible {
        outline: 2px solid var(--color-nav-current-border);
        outline-offset: 2px;
    }

.gl-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 1px solid var(--color-nav-menu-toggle-border);
    border-radius: 0.5rem;
    background: transparent;
    box-shadow: none;
}

    .gl-menu-toggle:hover {
        background: var(--color-nav-menu-toggle-hover-bg);
    }

    .gl-menu-toggle:focus,
    .gl-menu-toggle:active:focus {
        box-shadow: none;
    }

    .gl-menu-toggle:focus-visible {
        outline: 2px solid var(--color-nav-menu-toggle-border);
        outline-offset: 2px;
    }


/* =========================================================
   Header Layout - Left Alignment
   ========================================================= */

.navbar > .container-fluid {
    justify-content: flex-start;
}


/* =========================================================
   Navigation Styling
   ========================================================= */

.gl-nav {
    background: transparent;
}

    .gl-nav .nav-link {
        border-radius: 0.75rem;
    }

.gl-navtext {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gl-navlink {
    white-space: nowrap;
    overflow: hidden;
    color: var(--color-nav-link-text);
}

    .gl-navlink:hover {
        color: var(--color-nav-link-text);
        background-color: var(--color-nav-link-hover-bg);
    }

.gl-nav .gl-navlink.disabled,
.gl-nav .gl-navlink:disabled {
    color: var(--color-nav-disabled-text);
    cursor: not-allowed;
    pointer-events: auto;
}

    .gl-nav .gl-navlink.disabled:hover,
    .gl-nav .gl-navlink:disabled:hover {
        color: var(--color-nav-disabled-text);
        background: none;
        cursor: not-allowed;
    }

.gl-nav .gl-navlink.current-page {
    color: var(--color-nav-current-text);
    background-color: var(--color-nav-current-bg);
    font-weight: 600;
    border: 1px solid var(--color-nav-current-border);
}

    .gl-nav .gl-navlink.current-page:hover {
        color: var(--color-nav-current-text);
        background-color: var(--color-nav-current-bg);
    }


/* =========================================================
   Group Headers
   ========================================================= */

.gl-groupbtn {
    width: 100%;
    display: flex;
    align-items: center;
    text-align: left;
    padding: 0.45rem 0.75rem;
    border: 1px solid transparent;
    border-radius: 0.75rem;
    background: transparent;
    color: var(--color-nav-group-text);
    font-weight: 700;
}

    .gl-groupbtn:hover {
        background: transparent;
        color: var(--color-nav-group-text);
    }

.gl-caret {
    flex: 0 0 auto;
    white-space: nowrap;
}

    .gl-caret::before {
        content: "▾";
        display: inline-block;
        transition: transform 150ms ease;
        opacity: 0.7;
    }

.gl-groupbtn[aria-expanded="false"] .gl-caret::before {
    transform: rotate(-90deg);
}


/* =========================================================
   Submenu Links
   ========================================================= */

.gl-group ul.nav {
    margin-top: 0.35rem;
    padding-left: 0.5rem;
    border-left: 2px solid var(--color-nav-group-divider-border);
}

.gl-group .gl-navlink {
    font-weight: 400;
    font-size: 0.95rem;
    border: 0;
    border-radius: 0.4rem;
    padding: 0.45rem 0.75rem;
    background: transparent;
    color: var(--color-nav-link-text);
}

    .gl-group .gl-navlink:hover {
        background: var(--color-nav-link-hover-bg);
        color: var(--color-nav-link-text);
    }

    .gl-group .gl-navlink.current-page {
        font-weight: 600;
        color: var(--color-nav-current-text);
        background-color: var(--color-nav-current-bg);
        border: 1px solid var(--color-nav-current-border);
    }


/* =========================================================
   Section Row (Home)
   ========================================================= */

.gl-navlink-section {
    padding: 0.25rem 0.35rem;
    margin-bottom: 0.25rem;
}

.gl-navlink-section-row {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 0.5rem;
}

.gl-navlink-section-link {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    font-weight: 600;
    border-radius: 0.5rem;
    padding: 0.55rem 0.75rem;
    color: var(--color-nav-link-text);
}

    .gl-navlink-section-link:hover {
        color: var(--color-nav-link-text);
        background: var(--color-nav-link-hover-bg);
    }

    .gl-navlink-section-link.current-page {
        background: var(--color-nav-current-bg);
        color: var(--color-nav-current-text);
        font-weight: 700;
        border: 1px solid var(--color-nav-current-border);
    }

.gl-navlink-section .gl-iconbtn {
    height: 30px;
    width: 30px;
}

.gl-home-toggleall-btn {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    padding: 0;
    margin-right: 10px;
    border: none;
    border-radius: 0.5rem;
    background: transparent;
    color: var(--color-nav-link-text);
}

    .gl-home-toggleall-btn:hover {
        background: var(--color-nav-link-hover-bg);
        color: var(--color-nav-link-text);
    }

    .gl-home-toggleall-btn:focus,
    .gl-home-toggleall-btn:active:focus {
        outline: none;
        box-shadow: none;
    }

    .gl-home-toggleall-btn:focus-visible {
        outline: 2px solid var(--color-nav-current-border);
        outline-offset: 1px;
    }

.gl-toggleall-icon {
    font-size: 20px;
    line-height: 1;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 20;
}

/* =========================================================
   Sign Out
   ========================================================= */

.gl-navlink-danger {
    white-space: nowrap;
    overflow: hidden;
    color: var(--color-nav-signout-text);
    font-weight: 600;
    border-radius: 0.75rem;
}

    .gl-navlink-danger:hover {
        color: var(--color-nav-signout-text);
        background-color: var(--color-nav-signout-hover-bg);
    }

.gl-nav .gl-navlink-danger.current-page {
    color: var(--color-nav-signout-text);
    background-color: var(--color-nav-signout-current-bg);
    border: 1px solid var(--color-nav-signout-current-border);
}


/* =========================================================
   Responsive Nav Behavior
   ========================================================= */

@media (min-width: 992px) {
    .gl-signout-item {
        margin-top: auto !important;
    }
}

@media (max-width: 991.98px) {
    /* -----------------------------------------------------
       Header stacking and alignment
       ----------------------------------------------------- */

    .navbar.sticky-top {
        z-index: 1060;
    }

    .navbar .navbar-collapse {
        flex-basis: auto !important;
        flex-grow: 0 !important;
    }

    /* -----------------------------------------------------
       Mobile dropdown shell
       ----------------------------------------------------- */

    #glMobileNav {
        position: fixed;
        top: 56px;
        left: 0;
        width: 100%;
        height: auto;
        max-height: calc(100vh - 56px);
        overflow-y: auto;
        overflow-x: hidden;
        background: transparent;
        border: 0;
        box-shadow: none;
        transform: translateY(-0.75rem);
        opacity: 0;
        visibility: hidden;
        transition: transform 0.2s ease, opacity 0.2s ease, visibility 0.2s ease;
        z-index: 1061;
        padding: 0.75rem;
        -webkit-overflow-scrolling: touch;
    }

        #glMobileNav.navbar-collapse {
            display: block !important;
            flex-basis: auto;
            flex-grow: 0;
        }

        #glMobileNav.show {
            transform: translateY(0);
            opacity: 1;
            visibility: visible;
        }

    /* -----------------------------------------------------
       Mobile menu card surface
       ----------------------------------------------------- */

    .gl-nav-shell {
        width: 100%;
        max-width: none;
        margin: 0;
        background: var(--color-nav-surface-bg);
        border: 1px solid var(--color-nav-surface-border);
        border-radius: 0.75rem;
        box-shadow: 0 0.75rem 1.5rem var(--color-nav-surface-shadow);
        padding: 0.5rem;
    }

    .gl-nav {
        background: transparent;
    }

    /* -----------------------------------------------------
       Mobile overlay
       ----------------------------------------------------- */

    body.gl-mobile-nav-open::before {
        content: "";
        position: fixed;
        inset: 0;
        background: var(--color-nav-mobile-overlay-bg);
        z-index: 1055;
    }
}


/* =========================================================
   Common Sizing Helpers
   ========================================================= */

.form-max-width {
    max-width: 800px;
    width: 100%;
}

.form-centered {
    margin-left: auto;
    margin-right: auto;
}


/* =========================================================
   Document Header
   ========================================================= */

.document-header {
    padding: 16px 20px;
    border-radius: 6px;
}

.document-header-inner {
    max-width: 800px;
}


/* =========================================================
   QR / Flash Scan Styling
   ========================================================= */

.qr-scan-success {
    animation: flashSuccess 1s ease-out;
}

.qr-scan-fail {
    animation: flashError 1s ease-out;
}

@keyframes flashSuccess {
    0% {
        background-color: var(--color-flash-success-bg);
        color: var(--color-flash-success-text);
    }

    20% {
        background-color: var(--color-flash-success-bg);
        color: var(--color-flash-success-text);
    }

    100% {
        background-color: transparent;
        color: inherit;
    }
}

@keyframes flashError {
    0% {
        background-color: var(--color-flash-error-bg);
        color: var(--color-flash-error-text);
    }

    20% {
        background-color: var(--color-flash-error-bg);
        color: var(--color-flash-error-text);
    }

    100% {
        background-color: transparent;
        color: inherit;
    }
}

.qr-reader-container {
    width: 100%;
}

    .qr-reader-container video {
        width: 100% !important;
        height: auto !important;
        display: block;
        object-fit: contain !important;
    }

    .qr-reader-container canvas {
        width: 100% !important;
        height: auto !important;
        display: block;
    }

.qr-scanner-component {
    margin-bottom: 0.5rem;
}

    .qr-scanner-component .form-control {
        padding: 0.35rem 0.5rem;
        font-size: 0.9rem;
    }

    .qr-scanner-component .btn {
        padding: 0.35rem 0.6rem;
        font-size: 0.85rem;
    }

    .qr-scanner-component .qr-reader {
        margin-top: 0.4rem;
    }


/* =========================================================
   Sales Tracker / Cards
   ========================================================= */

.sales-doc-card {
    cursor: pointer;
    border: 1px solid var(--bs-border-color);
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

    .sales-doc-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 0.5rem 1rem var(--color-sales-card-hover-shadow) !important;
        border-color: var(--color-sales-card-hover-border);
    }

    .sales-doc-card .card-title,
    .sales-doc-card .card-text {
        color: inherit;
    }


/* =========================================================
   Sales Badges
   ========================================================= */

.badge-sales {
    display: inline-block;
    min-width: 96px;
    padding: 0.2rem 0.5rem;
    text-align: center;
    white-space: nowrap;
    border-radius: 0.25rem;
    font-weight: 600;
}

    /* ---------------------------------------------------------
   Sales document type badges
   --------------------------------------------------------- */

    .badge-sales.doctype-estimate {
        color: var(--color-sales-doctype-text);
        background: var(--color-sales-doctype-estimate-bg);
        border-color: var(--color-sales-doctype-border);
    }

    .badge-sales.doctype-sample {
        color: var(--color-sales-doctype-text);
        background: var(--color-sales-doctype-sample-bg);
        border-color: var(--color-sales-doctype-border);
    }

    .badge-sales.doctype-sales-order {
        color: var(--color-sales-doctype-text);
        background: var(--color-sales-doctype-sales-order-bg);
        border-color: var(--color-sales-doctype-border);
    }

    /* ---------------------------------------------------------
   Sales document status badges
   --------------------------------------------------------- */

    .badge-sales.status-draft {
        color: var(--color-sales-status-draft-text);
        background-color: var(--color-sales-status-draft-bg);
        border-color: var(--color-sales-status-draft-border);
    }

    .badge-sales.status-open {
        color: var(--color-sales-status-open-text);
        background-color: var(--color-sales-status-open-bg);
        border-color: var(--color-sales-status-open-border);
    }

    .badge-sales.status-finalized {
        color: var(--color-sales-status-finalized-text);
        background-color: var(--color-sales-status-finalized-bg);
        border-color: var(--color-sales-status-finalized-border);
    }

    .badge-sales.status-partial {
        color: var(--color-sales-status-partial-text);
        background-color: var(--color-sales-status-partial-bg);
        border-color: var(--color-sales-status-partial-border);
    }

    .badge-sales.status-closed {
        color: var(--color-sales-status-closed-text);
        background-color: var(--color-sales-status-closed-bg);
        border-color: var(--color-sales-status-closed-border);
    }

    .badge-sales.status-void {
        color: var(--color-sales-status-void-text);
        background-color: var(--color-sales-status-void-bg);
        border-color: var(--color-sales-status-void-border);
    }


/* =========================================================
   Sales Document Type Gradients
   ========================================================= */

.sales-doc-estimate {
    color: var(--color-sales-doctype-text);
    background: linear-gradient(to right, var(--color-sales-estimate-gradient-start), var(--color-sales-estimate-gradient-end));
    border-color: var(--color-sales-doctype-border);
}

.sales-doc-sample {
    color: var(--color-sales-doctype-text);
    background: linear-gradient(to right, var(--color-sales-sample-gradient-start), var(--color-sales-sample-gradient-end));
    border-color: var(--color-sales-doctype-border);
}

.sales-doc-sales-order {
    color: var(--color-sales-doctype-text);
    background: linear-gradient(to right, var(--color-sales-order-gradient-start), var(--color-sales-order-gradient-end));
    border-color: var(--color-sales-doctype-border);
}


/* =========================================================
   Sales Workflow Buttons
   ========================================================= */

/* ---------------------------------------------------------
   Draft
   --------------------------------------------------------- */

.btn-sales-doc-draft {
    color: var(--color-sales-btn-draft-text);
    background-color: var(--color-sales-btn-draft-bg);
    border-color: var(--color-sales-btn-draft-border);
}

    .btn-sales-doc-draft:hover {
        color: var(--color-sales-btn-draft-text);
        background-color: var(--color-sales-btn-draft-hover-bg);
        border-color: var(--color-sales-btn-draft-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-draft,
    .btn-sales-doc-draft:focus {
        color: var(--color-sales-btn-draft-text);
        background-color: var(--color-sales-btn-draft-hover-bg);
        border-color: var(--color-sales-btn-draft-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-draft-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-draft,
    .btn-check:active + .btn-sales-doc-draft,
    .btn-sales-doc-draft:active,
    .btn-sales-doc-draft.active,
    .show > .btn-sales-doc-draft.dropdown-toggle {
        color: var(--color-sales-btn-draft-text);
        background-color: var(--color-sales-btn-draft-active-bg);
        border-color: var(--color-sales-btn-draft-active-border);
    }

        .btn-check:checked + .btn-sales-doc-draft:focus,
        .btn-check:active + .btn-sales-doc-draft:focus,
        .btn-sales-doc-draft:active:focus,
        .btn-sales-doc-draft.active:focus,
        .show > .btn-sales-doc-draft.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-draft-focus-ring);
        }

    .btn-sales-doc-draft:disabled,
    .btn-sales-doc-draft.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }

/* ---------------------------------------------------------
   Open
   --------------------------------------------------------- */

.btn-sales-doc-open {
    color: var(--color-sales-btn-open-text);
    background-color: var(--color-sales-btn-open-bg);
    border-color: var(--color-sales-btn-open-border);
}

    .btn-sales-doc-open:hover {
        color: var(--color-sales-btn-open-text);
        background-color: var(--color-sales-btn-open-hover-bg);
        border-color: var(--color-sales-btn-open-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-open,
    .btn-sales-doc-open:focus {
        color: var(--color-sales-btn-open-text);
        background-color: var(--color-sales-btn-open-hover-bg);
        border-color: var(--color-sales-btn-open-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-open-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-open,
    .btn-check:active + .btn-sales-doc-open,
    .btn-sales-doc-open:active,
    .btn-sales-doc-open.active,
    .show > .btn-sales-doc-open.dropdown-toggle {
        color: var(--color-sales-btn-open-text);
        background-color: var(--color-sales-btn-open-active-bg);
        border-color: var(--color-sales-btn-open-active-border);
    }

        .btn-check:checked + .btn-sales-doc-open:focus,
        .btn-check:active + .btn-sales-doc-open:focus,
        .btn-sales-doc-open:active:focus,
        .btn-sales-doc-open.active:focus,
        .show > .btn-sales-doc-open.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-open-focus-ring);
        }

    .btn-sales-doc-open:disabled,
    .btn-sales-doc-open.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }

/* ---------------------------------------------------------
   Finalized
   --------------------------------------------------------- */

.btn-sales-doc-finalized {
    color: var(--color-sales-btn-finalized-text);
    background-color: var(--color-sales-btn-finalized-bg);
    border-color: var(--color-sales-btn-finalized-border);
}

    .btn-sales-doc-finalized:hover {
        color: var(--color-sales-btn-finalized-text);
        background-color: var(--color-sales-btn-finalized-hover-bg);
        border-color: var(--color-sales-btn-finalized-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-finalized,
    .btn-sales-doc-finalized:focus {
        color: var(--color-sales-btn-finalized-text);
        background-color: var(--color-sales-btn-finalized-hover-bg);
        border-color: var(--color-sales-btn-finalized-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-finalized-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-finalized,
    .btn-check:active + .btn-sales-doc-finalized,
    .btn-sales-doc-finalized:active,
    .btn-sales-doc-finalized.active,
    .show > .btn-sales-doc-finalized.dropdown-toggle {
        color: var(--color-sales-btn-finalized-text);
        background-color: var(--color-sales-btn-finalized-active-bg);
        border-color: var(--color-sales-btn-finalized-active-border);
    }

        .btn-check:checked + .btn-sales-doc-finalized:focus,
        .btn-check:active + .btn-sales-doc-finalized:focus,
        .btn-sales-doc-finalized:active:focus,
        .btn-sales-doc-finalized.active:focus,
        .show > .btn-sales-doc-finalized.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-finalized-focus-ring);
        }

    .btn-sales-doc-finalized:disabled,
    .btn-sales-doc-finalized.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }

/* ---------------------------------------------------------
   Return
   --------------------------------------------------------- */

.btn-sales-doc-return {
    color: var(--color-sales-btn-return-text);
    background-color: var(--color-sales-btn-return-bg);
    border-color: var(--color-sales-btn-return-border);
}

    .btn-sales-doc-return:hover {
        color: var(--color-sales-btn-return-text);
        background-color: var(--color-sales-btn-return-hover-bg);
        border-color: var(--color-sales-btn-return-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-return,
    .btn-sales-doc-return:focus {
        color: var(--color-sales-btn-return-text);
        background-color: var(--color-sales-btn-return-hover-bg);
        border-color: var(--color-sales-btn-return-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-return-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-return,
    .btn-check:active + .btn-sales-doc-return,
    .btn-sales-doc-return:active,
    .btn-sales-doc-return.active,
    .show > .btn-sales-doc-return.dropdown-toggle {
        color: var(--color-sales-btn-return-text);
        background-color: var(--color-sales-btn-return-active-bg);
        border-color: var(--color-sales-btn-return-active-border);
    }

        .btn-check:checked + .btn-sales-doc-return:focus,
        .btn-check:active + .btn-sales-doc-return:focus,
        .btn-sales-doc-return:active:focus,
        .btn-sales-doc-return.active:focus,
        .show > .btn-sales-doc-return.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-return-focus-ring);
        }

    .btn-sales-doc-return:disabled,
    .btn-sales-doc-return.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }

/* ---------------------------------------------------------
   Closed
   --------------------------------------------------------- */

.btn-sales-doc-closed {
    color: var(--color-sales-btn-closed-text);
    background-color: var(--color-sales-btn-closed-bg);
    border-color: var(--color-sales-btn-closed-border);
}

    .btn-sales-doc-closed:hover {
        color: var(--color-sales-btn-closed-text);
        background-color: var(--color-sales-btn-closed-hover-bg);
        border-color: var(--color-sales-btn-closed-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-closed,
    .btn-sales-doc-closed:focus {
        color: var(--color-sales-btn-closed-text);
        background-color: var(--color-sales-btn-closed-hover-bg);
        border-color: var(--color-sales-btn-closed-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-closed-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-closed,
    .btn-check:active + .btn-sales-doc-closed,
    .btn-sales-doc-closed:active,
    .btn-sales-doc-closed.active,
    .show > .btn-sales-doc-closed.dropdown-toggle {
        color: var(--color-sales-btn-closed-text);
        background-color: var(--color-sales-btn-closed-active-bg);
        border-color: var(--color-sales-btn-closed-active-border);
    }

        .btn-check:checked + .btn-sales-doc-closed:focus,
        .btn-check:active + .btn-sales-doc-closed:focus,
        .btn-sales-doc-closed:active:focus,
        .btn-sales-doc-closed.active:focus,
        .show > .btn-sales-doc-closed.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-closed-focus-ring);
        }

    .btn-sales-doc-closed:disabled,
    .btn-sales-doc-closed.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }

/* ---------------------------------------------------------
   Void
   --------------------------------------------------------- */

.btn-sales-doc-void {
    color: var(--color-sales-btn-void-text);
    background-color: var(--color-sales-btn-void-bg);
    border-color: var(--color-sales-btn-void-border);
}

    .btn-sales-doc-void:hover {
        color: var(--color-sales-btn-void-text);
        background-color: var(--color-sales-btn-void-hover-bg);
        border-color: var(--color-sales-btn-void-hover-border);
    }

    .btn-check:focus + .btn-sales-doc-void,
    .btn-sales-doc-void:focus {
        color: var(--color-sales-btn-void-text);
        background-color: var(--color-sales-btn-void-hover-bg);
        border-color: var(--color-sales-btn-void-hover-border);
        box-shadow: 0 0 0 0.25rem var(--color-sales-btn-void-focus-ring);
    }

    .btn-check:checked + .btn-sales-doc-void,
    .btn-check:active + .btn-sales-doc-void,
    .btn-sales-doc-void:active,
    .btn-sales-doc-void.active,
    .show > .btn-sales-doc-void.dropdown-toggle {
        color: var(--color-sales-btn-void-text);
        background-color: var(--color-sales-btn-void-active-bg);
        border-color: var(--color-sales-btn-void-active-border);
    }

        .btn-check:checked + .btn-sales-doc-void:focus,
        .btn-check:active + .btn-sales-doc-void:focus,
        .btn-sales-doc-void:active:focus,
        .btn-sales-doc-void.active:focus,
        .show > .btn-sales-doc-void.dropdown-toggle:focus {
            box-shadow: 0 0 0 0.25rem var(--color-sales-btn-void-focus-ring);
        }

    .btn-sales-doc-void:disabled,
    .btn-sales-doc-void.disabled {
        color: var(--color-sales-btn-disabled-text);
        background-color: var(--color-sales-btn-disabled-bg);
        border-color: var(--color-sales-btn-disabled-border);
        opacity: 1;
        cursor: not-allowed;
    }


/* =========================================================
   Manifest Upload / Analyze
   ========================================================= */

.manifest-file-shell {
    position: relative;
}

.manifest-drag-overlay {
    position: absolute;
    inset: 0;
    z-index: 20;
    display: none;
    align-items: center;
    justify-content: center;
    border: 2px dashed var(--color-manifest-overlay-border);
    border-radius: 0.75rem;
    background: var(--color-manifest-overlay-bg);
    box-shadow: 0 0 0 0.2rem var(--color-manifest-overlay-shadow);
    transition: opacity 0.15s ease-in-out;
    pointer-events: none;
}

    .manifest-drag-overlay.active {
        display: flex;
        pointer-events: auto;
    }

.manifest-drag-overlay-content {
    text-align: center;
    padding: 1.5rem;
}

.manifest-drag-overlay-title {
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--color-manifest-title-text);
}

.manifest-drag-overlay-subtitle {
    margin-top: 0.35rem;
    color: var(--color-manifest-subtitle-text);
}

.manifest-spinner {
    width: 1rem;
    height: 1rem;
    border: 0.15em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    display: inline-block;
    animation: manifest-spin 0.75s linear infinite;
    vertical-align: -0.125em;
    margin-right: 0.5rem;
}

@keyframes manifest-spin {
    to {
        transform: rotate(360deg);
    }
}

.manifest-status-ok {
    color: var(--color-manifest-status-ok-text);
    font-weight: 600;
}

    .manifest-status-ok .check {
        margin-right: 0.35rem;
    }

.manifest-file-help {
    color: var(--color-manifest-help-text);
    font-size: 0.95rem;
    margin-top: 0.35rem;
}

.manifest-page-dragging #fileInputContainer {
    opacity: 0.35;
}


/* =========================================================
   Panel System
   ========================================================= */

.panel {
    border-radius: 0.5rem;
    padding: 1.5rem;
    border: 1px solid var(--color-panel-border);
    background-color: var(--color-panel-bg);
    box-shadow: 0 1px 2px var(--color-panel-shadow);
}

.form-panel {
    background-color: var(--color-form-panel-bg);
}

.document-panel {
    background-color: var(--color-document-panel-bg);
    border-left: 4px solid var(--color-document-panel-accent-border);
}

.lookup-panel {
    background-color: var(--color-lookup-panel-bg);
    border-left: 4px solid var(--color-lookup-panel-accent-border);
}


/* =========================================================
   Busy Cursor
   ========================================================= */

body.gl-busy,
body.gl-busy * {
    cursor: wait !important;
}

.gl-busy button,
.gl-busy input[type="submit"] {
    pointer-events: none;
}

/* =========================================================
   Detail Label / Value Table
   ========================================================= */

.gl-detail-table {
    width: auto;
    max-width: 100%;
    border-collapse: collapse;
}

    .gl-detail-table th,
    .gl-detail-table td {
        padding: 0.2rem 1rem 0.2rem 0;
        vertical-align: top;
        white-space: nowrap;
    }

    .gl-detail-table th {
        font-weight: 600;
    }

    .gl-detail-table td:last-child {
        padding-right: 0;
    }

/* =========================================================
   GL Table
   ========================================================= */

.gl-table {
    width: 100%;
    table-layout: auto;
}

    .gl-table th,
    .gl-table td {
        vertical-align: top;
        padding: 3px 10px 3px 10px;
        white-space: nowrap;
    }

    .gl-table thead th {
        white-space: nowrap;
        background-color: var(--color-table-header-bg);
    }

    .gl-table tbody tr:nth-child(odd) {
        background-color: var(--color-table-row-odd-bg);
    }

    .gl-table tbody tr:nth-child(even) {
        background-color: var(--color-table-row-even-bg);
    }

    .gl-table tfoot tr {
        background-color: var(--color-table-footer-bg);
    }

    .gl-table tfoot td {
        border-top: 2px solid var(--color-table-footer-border);
    }

    .gl-table tfoot.total td {
        font-weight: 700;
    }

    .gl-table .numeric {
        text-align: right;
        font-variant-numeric: tabular-nums;
    }

        .gl-table .numeric.zero {
            color: var(--color-table-numeric-zero);
        }

        .gl-table .numeric.negative {
            color: var(--color-table-numeric-negative);
        }

        .gl-table .numeric.positive {
            color: var(--color-table-numeric-positive);
        }

.gl-table-wrap {
    overflow: auto;
}

.gl-table.gl-table-sticky thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    white-space: nowrap;
    background: var(--color-table-header-bg);
    color: var(--color-table-header-text);
    box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.08);
}

.numeric {
    text-align: right;
}

    .numeric.zero {
        color: var(--color-table-numeric-zero);
    }

    .numeric.negative {
        color: var(--color-table-numeric-negative);
    }

    .numeric.positive {
        color: var(--color-table-numeric-positive);
    }


/* =========================================================
   Document Lines
   ========================================================= */

.document-lines .col-line {
    width: 60px;
}

.document-lines .col-product {
    width: 100px;
}

.document-lines .col-type {
    width: 100px;
}

.document-lines .col-grade {
    width: 60px;
}

.document-lines .text-naked {
    padding-top: 13px;
}

.document-lines .col-product,
.document-lines .col-type,
.document-lines .col-grade {
    white-space: nowrap;
}

.document-lines .col-qty {
    width: 125px;
}

.document-lines .col-money {
    width: 125px;
}

.document-lines .col-total {
    width: 120px;
}

.document-lines .col-action {
    white-space: nowrap;
    text-align: left;
}


/* =========================================================
   Document Line Helpers
   ========================================================= */

.line-input-stack {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.line-input-helper {
    min-height: 1.25rem;
    line-height: 1.1;
    text-align: right;
}

    .line-input-helper .js-max-available {
        display: inline-block;
        white-space: nowrap;
    }

.field-validation {
    display: block;
    font-size: 0.875rem;
}

.input-invalid-client {
    border-color: var(--color-input-invalid-border);
}

    .input-invalid-client:focus {
        border-color: var(--color-input-invalid-border);
        box-shadow: 0 0 0 0.2rem var(--color-input-invalid-focus-ring);
    }

.line-remove-btn {
    min-width: 2.25rem;
    text-align: center;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}


/* =========================================================
   Document Picker
   ========================================================= */

.document-picker-overlay {
    position: fixed;
    inset: 0;
    background: var(--color-document-picker-overlay-bg);
    z-index: 1040;
}

.document-picker-panel {
    position: fixed;
    top: 6rem;
    left: 50%;
    transform: translateX(-50%);
    width: min(1200px, 96vw);
    max-height: 75vh;
    overflow: auto;
    background: var(--color-document-picker-panel-bg);
    border: 1px solid var(--color-document-picker-panel-border);
    border-radius: 0.5rem;
    box-shadow: 0 1rem 2rem var(--color-document-picker-panel-shadow);
    padding: 1rem;
    z-index: 1050;
}

.document-picker-row {
    cursor: pointer;
}

    .document-picker-row:hover {
        background-color: var(--color-picker-row-hover-bg);
    }


/* =========================================================
   Alert System
   ========================================================= */

.alert-error,
.alert-success,
.alert-warning {
    font-weight: 600;
    border-width: 1px;
    border-style: solid;
}

/* ---------------------------------------------------------
   Error
   --------------------------------------------------------- */

.alert-error {
    width: 100%;
    background-color: var(--color-alert-error-bg);
    color: var(--color-alert-error-text);
    border-color: var(--color-alert-error-border);
    box-shadow: 0 0 0 2px var(--color-alert-error-ring);
}

    .alert-error::before {
        content: "⚠ ";
        font-weight: 700;
    }

/* ---------------------------------------------------------
   Success
   --------------------------------------------------------- */

.alert-success {
    width: 100%;
    background-color: var(--color-alert-success-bg);
    color: var(--color-alert-success-text);
    border-color: var(--color-alert-success-border);
    box-shadow: 0 0 0 2px var(--color-alert-success-ring);
}

    .alert-success::before {
        content: "✅ ";
        font-weight: 700;
    }

/* ---------------------------------------------------------
   Warning
   --------------------------------------------------------- */

.alert-warning {
    width: 100%;
    background-color: var(--color-alert-warning-bg);
    color: var(--color-alert-warning-text);
    border-color: var(--color-alert-warning-border);
    box-shadow: 0 0 0 2px var(--color-alert-warning-ring);
}

    .alert-warning::before {
        content: "‼️ ";
        font-weight: 700;
    }

    /* ---------------------------------------------------------
   Shared inner content behavior
   --------------------------------------------------------- */

    .alert-error ul,
    .alert-success ul,
    .alert-warning ul {
        margin-bottom: 0;
        padding-left: 1.25rem;
    }

    .alert-error li,
    .alert-success li,
    .alert-warning li {
        color: inherit;
    }

    .alert-error a,
    .alert-success a,
    .alert-warning a {
        color: inherit;
        text-decoration: underline;
    }


/* =========================================================
   Alert Behavior
   ========================================================= */

.alert-fade {
    transition: opacity 0.18s ease-in-out, transform 0.18s ease-in-out;
}

    .alert-fade.fade-out {
        opacity: 0;
        transform: translateY(-4px);
    }

/* ---------------------------------------------------------
   Persistent alerts
   --------------------------------------------------------- */

.alert-persistent {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

    .alert-persistent .alert-content {
        flex: 1 1 auto;
        min-width: 0;
    }

    .alert-persistent .alert-close {
        flex: 0 0 auto;
        margin-left: auto;
    }

/* ---------------------------------------------------------
   Temporary alerts
   --------------------------------------------------------- */

.alert-temporary {
    display: block;
}

/* ---------------------------------------------------------
   Close button contrast
   --------------------------------------------------------- */

.alert-error .alert-close,
.alert-success .alert-close {
    opacity: 1;
    filter: invert(1) grayscale(100%) brightness(200%);
}

.alert-warning .alert-close,
.alert-secondary .alert-close {
    opacity: 1;
    filter: none;
}


/* =========================================================
   Status / Busy Indicators
   ========================================================= */

.status-busy {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    opacity: 1;
    transition: opacity 0.15s ease-in-out;
}

.status-content {
    flex: 1 1 auto;
    min-width: 0;
}

/* ---------------------------------------------------------
   Reusable busy spinner
   --------------------------------------------------------- */

.spinner-busy {
    width: 1rem;
    height: 1rem;
    border: 0.15em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    display: inline-block;
    animation: manifest-spin 0.75s linear infinite;
    vertical-align: -0.125em;
    flex: 0 0 auto;
}

/* =========================================================
   ModalConfirm
   ========================================================= */
.gl-confirm-header {
    background-color: var(--color-modal-confirm-header-bg);
}

baby momma.gl-confirm-body {
    white-space: pre-line;
}

.gl-confirm-btn {
    min-width: 110px;
}

/* =========================================================
   Debug Console
   ========================================================= */

#gl-debug-toggle {
    position: fixed;
    right: 6px;
    bottom: 6px;
    z-index: 2000;
    width: 18px;
    height: 18px;
    padding: 0;
    border: 1px solid var(--color-debug-toggle-border);
    border-radius: 50%;
    background: var(--color-debug-toggle-bg);
    color: var(--color-debug-toggle-text);
    font-size: 10px;
    line-height: 16px;
    text-align: center;
    cursor: pointer;
    opacity: 0.65;
}

    #gl-debug-toggle:hover {
        opacity: 1;
    }

#gl-debug-panel {
    position: fixed;
    right: 6px;
    bottom: 28px;
    z-index: 1999;
    width: min(680px, calc(100vw - 12px));
    height: min(320px, 45vh);
    display: none;
    flex-direction: column;
    background: var(--color-debug-panel-bg);
    color: var(--color-debug-toggle-text);
    border: 1px solid var(--color-debug-panel-border);
    border-radius: 8px;
    box-shadow: 0 8px 24px var(--color-debug-panel-shadow);
    font-family: Consolas, Menlo, Monaco, monospace;
    font-size: 12px;
}

    #gl-debug-panel.gl-open {
        display: flex;
    }

#gl-debug-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-bottom: 1px solid var(--color-debug-header-border);
    background: var(--color-debug-header-bg);
}

#gl-debug-title {
    font-weight: 600;
    color: var(--color-debug-title-text);
}

#gl-debug-actions {
    display: flex;
    gap: 6px;
}

.gl-debug-btn {
    border: 1px solid var(--color-debug-button-border);
    background: var(--color-debug-button-bg);
    color: var(--color-debug-button-text);
    border-radius: 4px;
    padding: 2px 6px;
    cursor: pointer;
    font-size: 11px;
}

    .gl-debug-btn:hover {
        background: var(--color-debug-button-hover-bg);
    }

#gl-debug-body {
    flex: 1;
    overflow: auto;
    padding: 8px;
    white-space: pre-wrap;
    word-break: break-word;
}

.gl-debug-line {
    margin-bottom: 4px;
}

.gl-debug-info {
    color: var(--color-debug-info-text);
}

.gl-debug-warn {
    color: var(--color-debug-warn-text);
}

.gl-debug-error {
    color: var(--color-debug-error-text);
}

.gl-debug-muted {
    color: var(--color-debug-muted-text);
}


/* =========================================================
   Notes
   ========================================================= */

.note-deleted {
    opacity: 0.5;
    text-decoration: line-through;
}

.note-meta {
    font-size: 0.8rem;
    color: var(--color-notes-meta-text);
}

.notes-shell {
    position: relative;
    background: var(--color-notes-shell-bg);
    border: 1px solid var(--color-notes-shell-border);
    border-radius: 1rem;
    box-shadow: 0 4px 10px var(--color-notes-shell-shadow);
    padding: 0.75rem;
}

    .notes-shell.is-busy {
        opacity: 0.72;
        pointer-events: none;
    }

.notes-shell-header {
    background: var(--color-notes-shell-header-bg);
    border: 1px solid var(--color-notes-shell-header-border);
    border-radius: 0.75rem;
    padding: 0.55rem 0.8rem;
    margin-bottom: 0.75rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.notes-shell-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-notes-shell-title-text);
}

.notes-shell-tools {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--color-notes-shell-tools-text);
}

.notes-shell-inputrow {
    display: flex;
    align-items: stretch;
    gap: 0;
}

    .notes-shell-inputrow .notes-input {
        min-height: 5rem;
        resize: vertical;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .notes-shell-inputrow .notes-add {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
        min-width: 3.75rem;
        font-size: 1.9rem;
        line-height: 1;
    }

.notes-shell-status {
    min-height: 1.1rem;
    margin-top: 0.5rem;
    font-size: 0.78rem;
    color: var(--color-notes-shell-status-text);
}

    .notes-shell-status.is-error {
        color: var(--color-notes-shell-status-error-text);
    }

.notes-container.is-busy {
    opacity: 0.6;
}

.notes-container .note-card {
    background: var(--color-notes-card-bg);
    border: 1px solid var(--color-notes-card-border);
    border-radius: 1rem;
    box-shadow: 0 4px 10px var(--color-notes-card-shadow);
    margin-bottom: 0.75rem;
    overflow: hidden;
}

    .notes-container .note-card.deleted {
        opacity: 0.6;
    }

.notes-container .note-card-header {
    background: var(--color-notes-card-header-bg);
    color: var(--color-notes-card-header-text);
    padding: 0.55rem 0.8rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    line-height: 1.2;
}

.notes-container .note-card.deleted .note-card-header {
    background: var(--color-notes-card-deleted-header-bg);
    color: var(--color-notes-card-deleted-header-text);
}

.notes-container .note-card-header-left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.notes-container .note-card-user {
    font-size: 0.85rem;
    font-weight: 600;
}

.notes-container .note-card-time {
    font-size: 0.82rem;
    font-weight: 400;
    color: var(--color-notes-card-time-text);
    white-space: nowrap;
}

.notes-container .note-card.deleted .note-card-time {
    color: var(--color-notes-card-deleted-time-text);
}

.notes-container .note-card-header span:last-child {
    color: var(--color-notes-card-time-text);
    font-weight: 400;
}

.notes-container .note-card-body {
    padding: 0.9rem 0.95rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}

.notes-container .note-text {
    font-size: 0.95rem;
    color: var(--color-notes-text);
    white-space: pre-wrap;
    word-break: break-word;
    flex: 1 1 auto;
}

.notes-container .note-actions {
    flex: 0 0 auto;
    margin-left: 0.5rem;
}

.notes-container .note-deleted-badge {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--color-notes-deleted-badge-text);
    background: var(--color-notes-deleted-badge-bg);
    border: 1px solid var(--color-notes-deleted-badge-border);
    border-radius: 999px;
    padding: 0.15rem 0.45rem;
    line-height: 1;
}
.gl-notes-icon {
    color: var(--color-notes-icon);
    cursor: help;
}

/* =========================================================
   Payments / Status Filter
   ========================================================= */

.payments-filter {
    margin-bottom: 0.75rem;
}

.payment-detail-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-payment-detail-label-text);
    letter-spacing: 0.04em;
    margin-bottom: 0.2rem;
    text-transform: uppercase;
}

.payment-detail-value {
    font-size: 1rem;
}

    .payment-detail-value.bold {
        font-weight: 800;
    }

.payment-section-spacer {
    margin-top: 1.5rem;
}

.payment-money-input {
    text-align: right;
}

.payment-readonly-locator {
    font-weight: 600;
    letter-spacing: 0.12em;
}

.payment-verify-form .form-label {
    margin-bottom: 0.45rem;
}

.payment-readonly-field {
    background: var(--color-payment-readonly-field-bg);
    border: 1px solid var(--color-payment-readonly-field-border);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    min-height: calc(1.5em + 0.75rem + 2px);
}

.payment-card-actions {
    padding-top: 1rem;
}

.payment-status-icon {
    font-size: 1.15rem;
    line-height: 1;
    width: 1rem;
    text-align: center;
}

.payment-status-unverified {
    color: var(--color-payment-status-unverified-text);
}

.payment-status-verified-match {
    color: var(--color-payment-status-verified-match-text);
}

.payment-status-verified-variance {
    color: var(--color-payment-status-verified-variance-text);
}

.payment-status-void {
    color: var(--color-payment-status-void-text);
}

.payment-locator-display {
    font-weight: 600;
    letter-spacing: 0.12em;
    white-space: nowrap;
}

.payment-variance-zero {
    color: var(--color-payment-variance-zero-text);
}

.payment-variance-nonzero {
    color: var(--color-payment-variance-nonzero-text);
    font-weight: 600;
}

.payment-filter-row {
    display: flex;
    align-items: end;
    gap: 1rem;
    flex-wrap: nowrap;
}

.payment-actions {
    white-space: nowrap;
}

.payments-filter-row .ts-wrapper {
    min-width: 13rem;
}

.payments-filter-row .ts-control,
.payments-filter-row .ts-control input {
    font-size: 0.875rem;
}

.payments-filter-row .ts-control {
    min-height: 38px;
    border: 1px solid var(--color-payment-filter-control-border);
    border-radius: 0.75rem;
    background: var(--color-payment-filter-control-bg);
    box-shadow: 0 1px 0 var(--color-payment-filter-control-inset-shadow) inset, 0 4px 10px var(--color-payment-filter-control-shadow);
    padding: 0.35rem 0.65rem;
}

    .payments-filter-row .ts-control:hover {
        border-color: var(--color-payment-filter-control-hover-border);
    }

.payments-filter-row .ts-wrapper.focus .ts-control {
    border-color: var(--color-payment-filter-control-focus-border);
    box-shadow: 0 0 0 0.2rem var(--color-payment-filter-control-focus-ring), 0 1px 0 var(--color-payment-filter-control-inset-shadow) inset, 0 4px 10px var(--color-payment-filter-control-shadow);
}

.payments-filter-row .ts-dropdown {
    border: 1px solid var(--color-payment-filter-dropdown-border);
    border-radius: 0.75rem;
    box-shadow: 0 10px 24px var(--color-payment-filter-dropdown-shadow);
    overflow: hidden;
    margin-top: 0.35rem;
}

    .payments-filter-row .ts-dropdown .option {
        padding: 0.55rem 0.7rem;
    }

    .payments-filter-row .ts-dropdown .active {
        background: var(--color-payment-filter-dropdown-active-bg);
    }


.payment-detail-grid {
    display: grid;
    grid-template-columns: 220px minmax(0, 320px);
    row-gap: 0.75rem;
    column-gap: 1rem;
    align-items: center;
}

    .payment-detail-grid .payment-detail-value.numeric {
        text-align: right;
        font-variant-numeric: tabular-nums;
    }

    .payment-detail-grid .form-control {
        max-width: 320px;
    }





/* =========================================================
   Unorganized styles
   ========================================================= */
.gl-status-option,
.gl-status-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    line-height: 1.2;
}

.ts-dropdown .gl-status-option {
    padding: 0.25rem 0;
}

.ts-control .gl-status-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.ts-control .item {
    display: flex;
    align-items: center;
}

.gl-status-option-icon {
    width: 1rem;
    text-align: center;
}

.status-unverified {
    color: var(--color-payment-status-unverified-text);
}

.status-verified {
    color: var(--color-payment-status-verified-match-text);
}

.status-void {
    color: var(--color-payment-status-void-text);
}

.status-all {
    color: var(--color-payment-filter-status-all-text);
}

.ts-wrapper.single .ts-control {
    cursor: pointer;
}

    .ts-wrapper.single .ts-control .item {
        cursor: pointer;
    }

    .ts-wrapper.single .ts-control .ts-dropdown-indicator,
    .ts-wrapper.single .ts-control .dropdown-active,
    .ts-wrapper.single .ts-control::after {
        pointer-events: none;
    }



.material-symbols-outlined {
    visibility: hidden;
}

.material-icons-loaded .material-symbols-outlined {
    visibility: visible;
}






.receive-scan-row {
    display: flex;
    align-items: start;
    gap: 0.5rem;
    width: 100%;
}

    .receive-scan-row .receive-scan-input {
        flex: 1 1 auto;
        min-width: 0;
    }

        .receive-scan-row .receive-scan-input .qr-scanner-component,
        .receive-scan-row .receive-scan-input .qr-scanner-root,
        .receive-scan-row .receive-scan-input .form-group,
        .receive-scan-row .receive-scan-input .mb-3 {
            width: 100%;
        }

        .receive-scan-row .receive-scan-input input.form-control {
            width: 100%;
        }

    .receive-scan-row .receive-scan-btn {
        flex: 0 0 auto;
        white-space: nowrap;
    }

.receive-scan-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    height: 2.5rem;
    padding: 0 0.75rem;
}

.qty-mismatch {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.15) !important;
    background-color: #fff5f5;
}

tr.qty-mismatch-row > th,
tr.qty-mismatch-row > td {
    background-color: #fff8e1;
}




/* =========================================================
   Help / Training Manual
   ========================================================= */

.gl-help-card {
    border: 1px solid rgba(0, 0, 0, 0.08);
}

    .gl-help-card .card-title {
        font-weight: 700;
    }

    .gl-help-card .card-text {
        min-height: 3rem;
    }

.gl-help-page {
    max-width: 1100px;
}

.gl-help-section {
    scroll-margin-top: 90px;
    margin-bottom: 2rem;
}

    .gl-help-section h2 {
        border-bottom: 1px solid rgba(0, 0, 0, 0.12);
        padding-bottom: 0.35rem;
        margin-bottom: 1rem;
    }

.gl-help-step-list {
    padding-left: 1.25rem;
}

    .gl-help-step-list li {
        margin-bottom: 0.5rem;
    }

.gl-help-note {
    border-left: 4px solid var(--bs-primary);
    background: rgba(13, 110, 253, 0.06);
    padding: 0.75rem 1rem;
    margin: 1rem 0;
}