/* Custom CSS for PulseExtract */

/* ================================================================
   DESIGN TOKENS
   Dark (default): near-black page, dark-gray cards, refined text
   Light:          soft-gray page, white cards, subtle shadows
   Both:           rounded cards (0.75rem), clean border colors
   ================================================================ */

/* --- Dark mode token overrides (default theme) --- */
html[data-bs-theme="dark"] {
    --bs-body-bg:       #121418;
    --bs-body-color:    #e1e4e8;
    --bs-secondary-bg:  #1a1d23;
    --bs-tertiary-bg:   #1e2228;
    --bs-border-color:  #2d3239;
    --bs-secondary-color: #8b949e;
}

/* --- Light mode token overrides --- */
html[data-bs-theme="light"] {
    --bs-body-bg:         #f8fafc;
    --bs-body-color:      #0f172a;
    --bs-secondary-bg:    #ffffff;
    --bs-tertiary-bg:     #f1f5f9;
    --bs-border-color:    #e2e8f0;
    --bs-secondary-color: #475569;
    /* Indigo brand primary */
    --bs-primary:         #4F46E5;
    --bs-primary-rgb:     79, 70, 229;
    --bs-link-color:      #4F46E5;
    --bs-link-hover-color:#4338CA;
    --bs-link-color-rgb:  79, 70, 229;
}

/* Primary buttons — indigo in light mode */
html[data-bs-theme="light"] .btn-primary {
    --bs-btn-bg:               #4F46E5;
    --bs-btn-border-color:     #4F46E5;
    --bs-btn-hover-bg:         #4338CA;
    --bs-btn-hover-border-color:#4338CA;
    --bs-btn-active-bg:        #3730A3;
    --bs-btn-active-border-color:#3730A3;
    --bs-btn-disabled-bg:      #a5b4fc;
    --bs-btn-disabled-border-color:#a5b4fc;
    --bs-btn-color:            #fff;
    --bs-btn-hover-color:      #fff;
    --bs-btn-active-color:     #fff;
}
html[data-bs-theme="light"] .btn-outline-primary {
    --bs-btn-color:            #4F46E5;
    --bs-btn-border-color:     #4F46E5;
    --bs-btn-hover-bg:         #4F46E5;
    --bs-btn-hover-border-color:#4F46E5;
    --bs-btn-active-bg:        #4338CA;
    --bs-btn-active-border-color:#4338CA;
}
/* Badges */
html[data-bs-theme="light"] .badge.bg-primary,
html[data-bs-theme="light"] .badge.text-bg-primary {
    background-color: #4F46E5 !important;
    color: #fff !important;
}
/* Spinner / progress bar primary */
html[data-bs-theme="light"] .spinner-border.text-primary,
html[data-bs-theme="light"] .text-primary {
    color: #4F46E5 !important;
}

/* --- Global: rounded cards matching the design system (0.75rem) --- */
.card,
.modal-content,
.offcanvas,
.batch-card {
    border-radius: 0.75rem !important;
}
.card-header:first-child {
    border-radius: calc(0.75rem - 1px) calc(0.75rem - 1px) 0 0 !important;
}
.card-footer:last-child {
    border-radius: 0 0 calc(0.75rem - 1px) calc(0.75rem - 1px) !important;
}

/* --- Card shadows — stronger lift so cards float off the page --- */
.card {
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
}
html[data-bs-theme="dark"] {
    --bs-card-bg: #1a1d23;
}
html[data-bs-theme="dark"] .card {
    background-color: #1a1d23 !important;
    border: 1px solid #3a4155 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.55) !important;
}
html[data-bs-theme="light"] .card {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.05) !important;
    border: 1px solid #e2e8f0 !important;
    background-color: #ffffff !important;
}

/* --- Light mode: card header separator line defines section top --- */
html[data-bs-theme="light"] .card-header {
    border-bottom: 1px solid #e2e8f0 !important;
    background-color: #f8fafc !important;
}

/* --- Light mode: card heading typography — semi-bold, darker anchor --- */
html[data-bs-theme="light"] .card-title,
html[data-bs-theme="light"] .card-header h1,
html[data-bs-theme="light"] .card-header h2,
html[data-bs-theme="light"] .card-header h3,
html[data-bs-theme="light"] .card-header h4,
html[data-bs-theme="light"] .card-header h5,
html[data-bs-theme="light"] .card-header h6,
html[data-bs-theme="light"] .card-header .fw-bold,
html[data-bs-theme="light"] .card-header .fw-semibold {
    color: #1a1d23 !important;
    font-weight: 600 !important;
}

/* --- Light mode: batch cards get a left-accent border for definition --- */
html[data-bs-theme="light"] .batch-card {
    border-left: 3px solid #0d6efd !important;
}

/* Batch cards — theme-aware via Bootstrap CSS variables */
.batch-card {
    background-color: var(--bs-tertiary-bg, #1e2228);
    border-color: var(--bs-border-color, #2d3239) !important;
    /* `overflow: visible` so the Export/etc. dropdown menus can escape the
       card's vertical bounds when the batch is collapsed. Previously this
       was `hidden`, which clipped the menu to whatever fit inside the card
       (often only the first item — CSV Format). */
    overflow: visible;
}

/* =============================================================
   LIGHT MODE OVERRIDES
   Resets all hardcoded Bootstrap dark utility classes so every
   page renders correctly when the light theme is active.
   ============================================================= */

/* btn-outline-light is invisible on light backgrounds — remap to secondary */
html[data-bs-theme="light"] .btn-outline-light {
    color: #495057 !important;
    border-color: #6c757d !important;
}
html[data-bs-theme="light"] .btn-outline-light:hover,
html[data-bs-theme="light"] .btn-outline-light:focus {
    color: #212529 !important;
    background-color: #f8f9fa !important;
    border-color: #495057 !important;
}

/* table-dark + table-hover: override Bootstrap's internal CSS custom properties
   so the hover resolves to a subtle light gray instead of the dark #323539 */
html[data-bs-theme="light"] .table-dark {
    --bs-table-hover-bg: rgba(0, 0, 0, 0.04);
    --bs-table-hover-color: var(--bs-body-color);
}
html[data-bs-theme="light"] .table-dark.table-hover > tbody > tr:hover > td,
html[data-bs-theme="light"] .table-dark.table-hover > tbody > tr:hover > th {
    background-color: rgba(0, 0, 0, 0.04) !important;
    color: var(--bs-body-color) !important;
}

/* Matters list — give the injected table-responsive a card-like rounded container */
#projects-container .table-responsive {
    border-radius: 0.75rem;
    overflow: hidden;
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    background-color: var(--bs-secondary-bg);
}

/* Batch document table — fixed layout so columns never shift when Show More loads */
.batch-doc-table {
    table-layout: fixed;
    width: 100%;
}
.batch-doc-table td {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* List group hover in light mode */
html[data-bs-theme="light"] .list-group-item-action:hover,
html[data-bs-theme="light"] .list-group-item-action:focus {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
}

/* Reset bg-dark backgrounds to theme-aware equivalents */
html[data-bs-theme="light"] .bg-dark {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
}

/* Card and card-header specific reset — use white, not page-bg */
html[data-bs-theme="light"] .card.bg-dark,
html[data-bs-theme="light"] .card-header.bg-dark {
    background-color: var(--bs-secondary-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}

/* Form inputs with bg-dark — white background, not page-bg */
html[data-bs-theme="light"] .form-control.bg-dark,
html[data-bs-theme="light"] .form-select.bg-dark,
html[data-bs-theme="light"] .input-group-text.bg-dark {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

/* Table rows / cells with bg-dark */
html[data-bs-theme="light"] table.bg-dark,
html[data-bs-theme="light"] thead.bg-dark,
html[data-bs-theme="light"] tbody.bg-dark,
html[data-bs-theme="light"] tr.bg-dark,
html[data-bs-theme="light"] th.bg-dark,
html[data-bs-theme="light"] td.bg-dark {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
}

/* White/light text overrides — make readable on light backgrounds */
html[data-bs-theme="light"] .text-white {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .text-light {
    color: var(--bs-secondary-color) !important;
}
/* text-muted in light mode — darken from #6c757d to #495057 for readability */
html[data-bs-theme="light"] .text-muted,
html[data-bs-theme="light"] small.text-muted,
html[data-bs-theme="light"] span.text-muted,
html[data-bs-theme="light"] p.text-muted {
    color: #495057 !important;
}

/* border-secondary on dark cards becomes standard border in light mode */
html[data-bs-theme="light"] .card.bg-dark.border-secondary,
html[data-bs-theme="light"] .card-header.bg-dark.border-secondary {
    border-color: var(--bs-border-color) !important;
}

/* Inline-dark special elements: override by ID */
html[data-bs-theme="light"] #massDeleteBar {
    background: var(--bs-danger) !important;
    border-color: var(--bs-danger) !important;
    color: #fff !important;
}
html[data-bs-theme="light"] #categorizationAlert {
    background: linear-gradient(135deg, #1e1b4b 0%, #312e81 100%) !important;
    border-color: #4c1d95 !important;
    color: #e0e7ff !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25) !important;
}
html[data-bs-theme="light"] #categorizationAlert.stalled {
    background: linear-gradient(135deg, #451a03 0%, #78350f 100%) !important;
    border-color: #d97706 !important;
}
html[data-bs-theme="light"] #categorizationTitle  { color: #c4b5fd !important; }
html[data-bs-theme="light"] #categorizationStatus { color: #ddd6fe !important; }
html[data-bs-theme="light"] #categorizationTimer  { color: #c4b5fd !important; background: rgba(139,92,246,0.25) !important; }
html[data-bs-theme="light"] #categorizationDetail { color: #c7d2fe !important; }
html[data-bs-theme="light"] #categorizationPercent{ color: #f5f3ff !important; }
html[data-bs-theme="light"] #phaseImport,
html[data-bs-theme="light"] #phaseCategorize { font-weight: 600 !important; }
html[data-bs-theme="light"] #categorizationSpinner {
    border-color: rgba(167,139,250,0.3) !important;
    border-top-color: #a78bfa !important;
}

/* batch-card text contrast in light mode */
html[data-bs-theme="light"] .batch-card {
    background-color: var(--bs-secondary-bg) !important;
}

/* batch-header hover fix */
html[data-bs-theme="light"] .batch-header:hover {
    background-color: var(--bs-tertiary-bg) !important;
}

/* ---------------------------------------------------------------
   NAMED CSS CLASSES — matter_dashboard embedded style block
   These classes are defined inside individual templates with dark-
   only values. The overrides below make them theme-aware.
--------------------------------------------------------------- */

.track-card-ready { border: 1px solid rgba(16, 185, 129, 0.45) !important; }
.track-card-warning { border: 1px solid rgba(245, 158, 11, 0.4) !important; }
.track-card-neutral { border: 1px solid rgba(255, 255, 255, 0.1) !important; }

html[data-bs-theme="light"] .track-card-neutral {
    border-color: var(--bs-border-color) !important;
}

/* Income-analysis CSS classes */
html[data-bs-theme="light"] .ia-text {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .ia-muted,
html[data-bs-theme="light"] .ia-label,
html[data-bs-theme="light"] .ia-neutral {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .ia-card-inner {
    background-color: var(--bs-tertiary-bg) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .ia-score-bar {
    background: var(--bs-secondary-bg) !important;
}
html[data-bs-theme="light"] .ia-section-toggle:hover {
    background-color: var(--bs-tertiary-bg) !important;
}
/* text-light headings inside bg-dark cards become readable in light mode */
html[data-bs-theme="light"] .card.bg-dark .text-light {
    color: var(--bs-body-color) !important;
}
/* YTD warning line inside income risk card — keep accent but darken slightly */
html[data-bs-theme="light"] .card.bg-dark .text-warning {
    color: #b45309 !important;
}

/* ---------------------------------------------------------------
   ADMIN FEEDBACK DETAIL — named CSS classes
--------------------------------------------------------------- */
html[data-bs-theme="light"] .admin-response {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .admin-response h5,
html[data-bs-theme="light"] .admin-response p,
html[data-bs-theme="light"] .admin-response small {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .admin-form-card,
html[data-bs-theme="light"] .admin-form-card .card-body {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .admin-form-card .card-header {
    background-color: var(--bs-tertiary-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .admin-form-card .form-label {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .admin-form-card .form-control,
html[data-bs-theme="light"] .admin-form-card .form-select {
    background-color: var(--bs-secondary-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .user-info,
html[data-bs-theme="light"] .technical-info,
html[data-bs-theme="light"] .status-history {
    background-color: var(--bs-tertiary-bg) !important;
    color: var(--bs-body-color) !important;
}

/* ---------------------------------------------------------------
   THEME HELPER UTILITY CLASSES
   Used to replace inline rgba(255,255,255,...) values across
   templates. Dark values are defaults; light overrides follow.
--------------------------------------------------------------- */

/* Progress bar / score bar track */
.theme-track-bg { background: rgba(255, 255, 255, 0.1); }
html[data-bs-theme="light"] .theme-track-bg {
    background: var(--bs-secondary-bg) !important;
}

/* Subtle surface inside a dark card */
.theme-surface { background-color: rgba(255, 255, 255, 0.03); }
html[data-bs-theme="light"] .theme-surface {
    background-color: var(--bs-tertiary-bg) !important;
}

/* Divider borders */
.theme-border-top  { border-top:    1px solid rgba(255, 255, 255, 0.08); }
.theme-border-bottom { border-bottom: 1px solid rgba(255, 255, 255, 0.06); }
html[data-bs-theme="light"] .theme-border-top {
    border-top-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .theme-border-bottom {
    border-bottom-color: var(--bs-border-color) !important;
}

/* Muted descriptive text */
.theme-muted-text { color: #6b7280; }
html[data-bs-theme="light"] .theme-muted-text {
    color: var(--bs-secondary-color) !important;
}

/* ---------------------------------------------------------------
   AFFIDAVIT SNAPSHOT INFO BOX — calculations/calculator_form.html
--------------------------------------------------------------- */
.affidavit-snapshot-box {
    background: #1e3a5f;
    border: 1px solid #3b82f6;
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
}
html[data-bs-theme="light"] .affidavit-snapshot-box {
    background: var(--bs-primary-bg-subtle) !important;
    border-color: var(--bs-primary) !important;
}
html[data-bs-theme="light"] .affidavit-snapshot-box span,
html[data-bs-theme="light"] .affidavit-snapshot-box strong {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .affidavit-snapshot-box .snapshot-icon {
    color: var(--bs-primary) !important;
}

/* ---------------------------------------------------------------
   COMPARISON TABLE — expandable inner table rows
   partials/comparison_row_fragment.html + comparison_table.html
--------------------------------------------------------------- */
.comparison-inner-expand-cell {
    background-color: var(--bs-body-bg);
    padding: 20px;
    border-left: 4px solid #0d6efd;
}
.comparison-inner-header th {
    background-color: var(--bs-tertiary-bg) !important;
    color: var(--bs-body-color) !important;
}
.comparison-inner-row td {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
}

/* ---------------------------------------------------------------
   CHECKLIST STATUS ITEMS — matter_dashboard Jinja conditional
--------------------------------------------------------------- */
.checklist-status-complete {
    background: rgba(16, 185, 129, 0.07);
    border: 1px solid rgba(16, 185, 129, 0.2);
}
.checklist-status-incomplete {
    background: rgba(245, 158, 11, 0.07);
    border: 1px solid rgba(245, 158, 11, 0.2);
}
.checklist-status-pending {
    background: rgba(0, 0, 0, 0.02);
    border: 1px solid var(--bs-border-color);
}
html[data-bs-theme="light"] .checklist-status-pending {
    background: var(--bs-tertiary-bg) !important;
}

/* ---------------------------------------------------------------
   PROCESSING STATUS LOG ENTRIES
--------------------------------------------------------------- */
.theme-log-entry {
    background-color: var(--bs-tertiary-bg) !important;
    border: 1px solid var(--bs-border-color) !important;
    border-radius: 6px;
    margin-bottom: 12px;
    padding: 10px;
}

/* ---------------------------------------------------------------
   UPLOAD PAGE — custom dark-themed upload UI classes
   Dark values are defined inside the template <style> block.
   Light overrides are here.
--------------------------------------------------------------- */
html[data-bs-theme="light"] .upload-modern {
    background: linear-gradient(135deg, #f8f9ff 0%, #eef2ff 100%) !important;
}
html[data-bs-theme="light"] .upload-modern-header h3,
html[data-bs-theme="light"] .upload-zone h4,
html[data-bs-theme="light"] .files-header h6,
html[data-bs-theme="light"] .options-header h6 {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .upload-modern-header p,
html[data-bs-theme="light"] .upload-zone p,
html[data-bs-theme="light"] .file-limits span,
html[data-bs-theme="light"] .files-header button,
html[data-bs-theme="light"] .option-label,
html[data-bs-theme="light"] .toggle-label,
html[data-bs-theme="light"] .toggle-label small,
html[data-bs-theme="light"] .auto-project-info p {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .upload-zone {
    background: var(--bs-body-bg) !important;
}
html[data-bs-theme="light"] .file-item {
    background: var(--bs-tertiary-bg) !important;
}
html[data-bs-theme="light"] .file-item-name {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .file-item-size,
html[data-bs-theme="light"] .file-item-remove {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .options-panel {
    background: var(--bs-tertiary-bg) !important;
}
html[data-bs-theme="light"] .option-select {
    background-color: var(--bs-body-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .option-select option {
    background: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .project-input {
    background: var(--bs-body-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .project-input::placeholder {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .toggle-switch {
    background: var(--bs-secondary-bg) !important;
}
html[data-bs-theme="light"] .toggle-switch::after {
    background: var(--bs-body-color) !important;
}

/* ---------------------------------------------------------------
   AFFIDAVIT DETAIL — question/answer boxes
   Light-hardcoded box colors are fine in light mode but dark text
   becomes invisible in dark mode.
--------------------------------------------------------------- */
html[data-bs-theme="dark"] .question-box {
    background-color: rgba(33, 150, 243, 0.1) !important;
}
html[data-bs-theme="dark"] .answer-box {
    background-color: rgba(76, 175, 80, 0.1) !important;
}

/* ---------------------------------------------------------------
   PORTAL GROUP CARDS (dashboard) — #ffffff30 border fix
--------------------------------------------------------------- */
html[data-bs-theme="light"] .portal-group-card {
    border-color: var(--bs-border-color) !important;
}

/* ---------------------------------------------------------------
   ROUTE OVERRIDES ADMIN — light-hardcoded CSS classes
--------------------------------------------------------------- */
html[data-bs-theme="dark"] .override-item {
    background-color: var(--bs-tertiary-bg) !important;
}
html[data-bs-theme="dark"] .override-item strong {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="dark"] .override-item .small {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="dark"] .global-config-summary {
    background-color: rgba(33, 150, 243, 0.1) !important;
}
html[data-bs-theme="dark"] .global-config-summary strong {
    color: var(--bs-info) !important;
}

/* ---------------------------------------------------------------
   COURT FORMS ADMIN — rgba white dividers and surfaces
--------------------------------------------------------------- */
html[data-bs-theme="light"] [class*="court-form"] .card,
html[data-bs-theme="light"] .court-form-surface {
    background-color: var(--bs-body-bg) !important;
    border-color: var(--bs-border-color) !important;
}

/* ---------------------------------------------------------------
   TABLE DARK — table-dark overrides in light mode
   (used in reference docs table and other places)
--------------------------------------------------------------- */
html[data-bs-theme="light"] .table-dark {
    --bs-table-bg: var(--bs-secondary-bg);
    --bs-table-color: var(--bs-body-color);
    --bs-table-border-color: var(--bs-border-color);
}

:root {
    --upload-area-bg: hsl(210 11% 98%);
    --upload-area-border: hsl(210 11% 85%);
    --upload-area-hover: hsl(210 20% 95%);
    --upload-area-active: hsl(210 30% 92%);
}

/* Contract Details Table Styling */
.contract-table td {
    vertical-align: top;
    word-wrap: break-word;
}

.contract-description-cell {
    max-width: 400px;
    min-width: 200px;
    white-space: normal;
    line-height: 1.4;
}

.contract-table .table-responsive {
    overflow-x: auto;
}

/* Upload Area Styling */
.upload-area {
    transition: all 0.3s ease;
    cursor: pointer;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.upload-area:hover {
    background-color: var(--upload-area-hover);
    border-color: var(--bs-primary) !important;
}

.upload-area.drag-over {
    background-color: var(--upload-area-active);
    border-color: var(--bs-primary) !important;
    border-style: solid !important;
}

/* File list styling */
#fileList {
    position: relative !important;
    z-index: 20 !important;
    background: var(--bs-body-bg) !important;
    border: 2px solid var(--bs-border-color) !important;
    border-radius: 0.5rem !important;
    padding: 1rem !important;
    margin: 1rem 0 !important;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

#fileList h6 {
    color: var(--bs-body-color) !important;
    margin-bottom: 0.75rem !important;
    font-weight: 600 !important;
}

.file-item {
    background-color: var(--bs-gray-100) !important;
    border: 1px solid var(--bs-border-color) !important;
    border-radius: 0.375rem;
    padding: 0.75rem;
    margin-bottom: 0.5rem;
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    min-height: 60px;
    width: 100%;
}

.file-item .file-info {
    flex-grow: 1;
    display: block !important;
}

.file-item .file-name {
    font-weight: 500 !important;
    margin-bottom: 0.25rem;
    color: var(--bs-dark) !important;
    display: block !important;
}

.file-item .file-size {
    font-size: 0.875rem !important;
    color: var(--bs-secondary) !important;
    display: block !important;
}

.file-item .remove-file {
    color: var(--bs-danger);
    cursor: pointer;
    padding: 0.25rem;
}

.file-item .remove-file:hover {
    background-color: var(--bs-danger);
    color: white;
    border-radius: 50%;
}

/* Progress bar enhancements */
.progress {
    background-color: var(--bs-gray-200);
}

.progress-bar {
    transition: width 0.6s ease;
}

/* Status badges */
.badge {
    font-size: 0.75em;
}

/* Table improvements */
.table th {
    border-bottom: 2px solid var(--bs-border-color);
    font-weight: 600;
}

.table-hover tbody tr:hover {
    background-color: var(--bs-gray-50);
}

/* Card enhancements */
.card {
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.card-header {
    background-color: var(--bs-gray-50);
    border-bottom: 1px solid var(--bs-border-color);
}

/* Statistics cards */
.stats-card {
    text-align: center;
    padding: 1.5rem;
}

.stats-card .icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.stats-card .number {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
}

.stats-card .label {
    color: var(--bs-secondary);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Invoice detail styling */
.invoice-header {
    background: linear-gradient(135deg, var(--bs-primary), var(--bs-info));
    color: white;
    padding: 2rem;
    border-radius: 0.375rem;
    margin-bottom: 1.5rem;
}

.invoice-amount {
    font-size: 2.5rem;
    font-weight: bold;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Line items table */
.line-items-table {
    font-size: 0.9rem;
}

.line-items-table th {
    background-color: var(--bs-gray-100);
    color: var(--bs-gray-800);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
}

.line-items-table td {
    vertical-align: middle;
}

.line-items-table .description {
    max-width: 300px;
    word-wrap: break-word;
}

/* Batch document table — responsive filename and entity columns */
.filename-cell {
    width: 35%;
    max-width: 0;       /* prevents the cell from growing past its allocated share */
    overflow: hidden;
}

.filename-cell a {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    max-width: 100%;
}

.entity-cell {
    width: 18%;
    max-width: 0;
    overflow: hidden;
}

.entity-cell span {
    max-width: 100%;
}

/* Processing status */
.processing-status {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.status-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

.status-pending { background-color: var(--bs-secondary); }
.status-processing { 
    background-color: var(--bs-warning);
    animation: pulse 1.5s infinite;
}
.status-completed { background-color: var(--bs-success); }
.status-failed { background-color: var(--bs-danger); }

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .upload-area {
        min-height: 150px;
        padding: 1rem;
    }
    
    .invoice-amount {
        font-size: 2rem;
    }
    
    .stats-card .number {
        font-size: 1.5rem;
    }
    
    .table-responsive {
        font-size: 0.875rem;
    }
}

/* Dark theme adjustments */
[data-bs-theme="dark"] {
    --upload-area-bg: hsl(210 11% 15%);
    --upload-area-border: hsl(210 11% 25%);
    --upload-area-hover: hsl(210 20% 20%);
    --upload-area-active: hsl(210 30% 25%);
}

[data-bs-theme="dark"] .upload-area {
    background-color: var(--upload-area-bg);
    border-color: var(--upload-area-border);
}

[data-bs-theme="dark"] .file-item {
    background-color: var(--bs-gray-800) !important;
    border-color: var(--bs-gray-700) !important;
}

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

[data-bs-theme="dark"] .file-item .file-size {
    color: var(--bs-gray-400) !important;
}

[data-bs-theme="dark"] #fileList {
    background: var(--bs-gray-800) !important;
    border-color: var(--bs-gray-600) !important;
}

[data-bs-theme="dark"] #fileList h6 {
    color: var(--bs-light) !important;
}



[data-bs-theme="dark"] .table-hover tbody tr:hover {
    background-color: var(--bs-gray-800);
}

/* Loading states */
.loading {
    position: relative;
    pointer-events: none;
}

.loading::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: inherit;
}

[data-bs-theme="dark"] .loading::after {
    background-color: rgba(0, 0, 0, 0.8);
}

/* Utility classes */
.text-truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.border-dashed {
    border-style: dashed !important;
}

.cursor-pointer {
    cursor: pointer;
}

/* Animation for new elements */
.fade-in {
    animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Custom scrollbar for webkit browsers */
.custom-scrollbar::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

.custom-scrollbar::-webkit-scrollbar-track {
    background: var(--bs-gray-100);
    border-radius: 4px;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
    background: var(--bs-gray-400);
    border-radius: 4px;
}

.custom-scrollbar::-webkit-scrollbar-thumb:hover {
    background: var(--bs-gray-500);
}

[data-bs-theme="dark"] .custom-scrollbar::-webkit-scrollbar-track {
    background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .custom-scrollbar::-webkit-scrollbar-thumb {
    background: var(--bs-gray-600);
}

[data-bs-theme="dark"] .custom-scrollbar::-webkit-scrollbar-thumb:hover {
    background: var(--bs-gray-500);
}

.client-contacts-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 9999;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0 0 6px 6px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    max-height: 220px;
    overflow-y: auto;
}

.client-contacts-dropdown .contact-item {
    padding: 9px 13px;
    cursor: pointer;
    color: var(--bs-body-color);
    font-size: 0.9rem;
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.client-contacts-dropdown .contact-item:hover {
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
}

.client-contacts-dropdown .contact-item:last-child {
    border-bottom: none;
}

.form-control {
    background-color: #fafbff;
}

/* ================================================================
   LIGHT MODE — EXTENDED OVERRIDES
   Covers dark Bootstrap utility classes used throughout templates
   so everything renders correctly when data-bs-theme="light".
   ================================================================ */

/* dropdown-menu-dark in light mode → normal dropdown */
html[data-bs-theme="light"] .dropdown-menu-dark {
    background-color: #ffffff !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item:hover,
html[data-bs-theme="light"] .dropdown-menu-dark .dropdown-item:focus {
    background-color: var(--bs-tertiary-bg) !important;
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .dropdown-menu-dark .dropdown-header {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .dropdown-menu-dark .dropdown-divider {
    border-color: var(--bs-border-color) !important;
}

/* border-secondary standalone (inside cards that aren't .card.bg-dark) */
html[data-bs-theme="light"] .border-secondary {
    border-color: var(--bs-border-color) !important;
}

/* table-dark → standard light table */
html[data-bs-theme="light"] .table-dark {
    --bs-table-color: var(--bs-body-color);
    --bs-table-bg: var(--bs-secondary-bg);
    --bs-table-border-color: var(--bs-border-color);
    --bs-table-striped-bg: var(--bs-tertiary-bg);
    --bs-table-hover-bg: var(--bs-tertiary-bg);
    color: var(--bs-body-color) !important;
    background-color: var(--bs-secondary-bg) !important;
}
html[data-bs-theme="light"] .table-dark > thead > tr > th {
    background-color: var(--bs-tertiary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .table-dark > tbody > tr > td,
html[data-bs-theme="light"] .table-dark > tbody > tr > th {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .table-dark.table-hover > tbody > tr:hover > td {
    background-color: var(--bs-tertiary-bg) !important;
}

/* Modals with bg-dark content in light mode */
html[data-bs-theme="light"] .modal-content.bg-dark {
    background-color: #ffffff !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .modal-header.border-secondary,
html[data-bs-theme="light"] .modal-footer.border-secondary {
    border-color: var(--bs-border-color) !important;
}
html[data-bs-theme="light"] .form-select.bg-dark.text-light,
html[data-bs-theme="light"] .form-control.bg-dark.text-light {
    background-color: #ffffff !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

/* Upload page — override dark gradient container */
html[data-bs-theme="light"] .upload-modern {
    background: #ffffff !important;
    border: 1px solid var(--bs-border-color) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07) !important;
}
html[data-bs-theme="light"] .upload-modern-header h3 {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .upload-modern-header p {
    color: var(--bs-secondary-color) !important;
}
html[data-bs-theme="light"] .upload-zone {
    background: var(--bs-tertiary-bg) !important;
    border-color: #4F46E5 !important;
}
html[data-bs-theme="light"] .upload-zone h4 {
    color: var(--bs-body-color) !important;
}

/* Navbar — white background with subtle shadow in light mode */
html[data-bs-theme="light"] #main-navbar {
    background-color: #ffffff !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.08) !important;
    border-bottom: 1px solid var(--bs-border-color) !important;
}

/* Navbar accent — indigo brand in light mode */
html[data-bs-theme="light"] .navbar-brand {
    color: #4F46E5 !important;
}
html[data-bs-theme="light"] .navbar-brand:hover {
    color: #4338CA !important;
}

/* Navbar links in light mode */
html[data-bs-theme="light"] #main-navbar .nav-link {
    color: #374151 !important;
}
html[data-bs-theme="light"] #main-navbar .nav-link:hover,
html[data-bs-theme="light"] #main-navbar .nav-link.active {
    color: #4F46E5 !important;
}

/* Matters list — mass-delete bar in light mode */
html[data-bs-theme="light"] #massDeleteBar {
    background: #ef4444 !important;
    border-color: #dc2626 !important;
}

/* Badge .bg-dark in light mode */
html[data-bs-theme="light"] .badge.bg-dark {
    background-color: var(--bs-secondary-color) !important;
    color: #fff !important;
}

/* bg-transparent inside dark cards keeps clean look in light */
html[data-bs-theme="light"] .card-header.bg-transparent {
    background-color: var(--bs-tertiary-bg) !important;
    border-bottom: 1px solid var(--bs-border-color) !important;
}

/* text-light and text-white inside dark-context elements should use body color in light mode */
html[data-bs-theme="light"] .card.bg-dark .text-light,
html[data-bs-theme="light"] .card.bg-dark .text-white,
html[data-bs-theme="light"] .modal-content.bg-dark .text-light,
html[data-bs-theme="light"] .modal-content.bg-dark .text-white {
    color: var(--bs-body-color) !important;
}

/* Standalone text-light / text-white that aren't inside intentionally dark containers */
html[data-bs-theme="light"] .card .text-light {
    color: var(--bs-secondary-color) !important;
}

/* btn-close-white in light mode should be the standard dark close button */
html[data-bs-theme="light"] .btn-close-white {
    filter: none !important;
}

/* nav-link text-light inside cards */
html[data-bs-theme="light"] .card .nav-link.text-light,
html[data-bs-theme="light"] .card .nav-link.text-white {
    color: var(--bs-body-color) !important;
}
html[data-bs-theme="light"] .card .nav-link.text-light:hover,
html[data-bs-theme="light"] .card .nav-link.text-white:hover {
    color: #4F46E5 !important;
}

/* form-select bg-dark in light mode */
html[data-bs-theme="light"] select.bg-dark,
html[data-bs-theme="light"] input.bg-dark,
html[data-bs-theme="light"] textarea.bg-dark {
    background-color: #ffffff !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

/* small text-muted inside bg-dark cards should be visible */
html[data-bs-theme="light"] .card.bg-dark .text-muted {
    color: var(--bs-secondary-color) !important;
}

/* h5, h6 inside bg-dark cards */
html[data-bs-theme="light"] .card.bg-dark h1,
html[data-bs-theme="light"] .card.bg-dark h2,
html[data-bs-theme="light"] .card.bg-dark h3,
html[data-bs-theme="light"] .card.bg-dark h4,
html[data-bs-theme="light"] .card.bg-dark h5,
html[data-bs-theme="light"] .card.bg-dark h6,
html[data-bs-theme="light"] .card.bg-dark p {
    color: var(--bs-body-color) !important;
}

/* PDF Viewer Modal */
#pdfViewerModal .modal-content {
    border-radius: 8px;
    overflow: hidden;
}
#pdfViewerModal .modal-body {
    min-height: 0;
}
#pdfViewerIframe {
    display: block;
}
