/* ====================================================
   COMMON STYLES — shared across all pages
   ==================================================== */
@import url('animations.css');

/* Base */
html { font-size: clamp(14px, 1rem + 0.2vw, 18px); overflow-y: scroll; }

/* Apply custom font to all form/UI elements.
   --custom-font is set per-page via an inline :root block. */
body { font-family: var(--custom-font); }
form, input, select, textarea, button, label { font-family: var(--custom-font) !important; }
.form-control, .form-select, .btn, .dropdown-menu,
.ts-control, .ts-dropdown, .tooltip, .popover, .badge,
.tg-btn-primary, .tg-btn-ghost, .modal-title {
    font-family: var(--custom-font) !important;
}

/* ── Navbar ── */
.navbar { background-color: var(--nav-bg, #1e293b); border-bottom: 1px solid var(--nav-border, rgba(255,255,255,0.1)); padding: 0.6rem 0; position: sticky; top: 0; z-index: 1030; }
.navbar-brand { font-size: 1.1rem; font-weight: 800; letter-spacing: -0.5px; color: var(--nav-brand-color, #ffffff) !important; }
.btn-nav-ghost { background-color: var(--nav-ghost-bg, rgba(255,255,255,0.07)) !important; border: 1px solid var(--nav-ghost-border, rgba(255,255,255,0.18)) !important; color: var(--nav-ghost-text, rgba(255,255,255,0.85)) !important; }
.btn-nav-ghost:hover { background-color: var(--nav-ghost-hover-bg, rgba(255,255,255,0.15)) !important; border-color: var(--nav-ghost-hover-border, rgba(255,255,255,0.35)) !important; color: var(--nav-ghost-hover-text, #ffffff) !important; }
.btn-nav-ghost::after { background-color: var(--nav-ghost-ripple, rgba(255,255,255,0.25)) !important; }
.navbar .btn-primary { background-color: var(--nav-primary-bg, #4f46e5) !important; color: var(--nav-primary-text, #ffffff) !important; border-color: var(--nav-primary-bg, #4f46e5) !important; }
.navbar .btn-primary:hover { background-color: var(--nav-primary-hover-bg, #4338ca) !important; }
.navbar .btn-primary::after { background-color: var(--nav-primary-ripple, #4f46e5) !important; }
.dropdown-toggle::after { display: none !important; }

/* ── Cards ── */
.card { border: none; border-radius: 1rem; box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); }

/* ── Buttons ── */
.btn { border-radius: 0.5rem; font-weight: 600; padding: 0.4rem 0.8rem; transition: all 0.2s; font-size: 0.85rem; }
.btn-sm { padding: 0.25rem 0.6rem; font-size: 0.8rem; }
.btn-primary { background-color: #4f46e5; border: none; }
.btn-primary:hover { background-color: #4338ca; transform: translateY(-1px); }

/* Global Button Ripple */
@keyframes btn-ripple-outline {
    0%   { transform: scaleX(1)   scaleY(1);   opacity: 0.4; }
    100% { transform: scaleX(1.4) scaleY(1.6); opacity: 0; }
}
.btn:not(.btn-link) { position: relative; overflow: visible; transition: all 0.2s; border-radius: 100px !important; }
.btn:not(.btn-link)::after {
    content: ""; display: inline-block; height: 100%; width: 100%;
    border: 0; border-radius: 100px; position: absolute; top: 0; left: 0;
    z-index: -1; transition: all 0.4s;
}
.btn-primary::after   { background-color: var(--ripple-primary,   #4f46e5); }
.btn-secondary::after { background-color: var(--ripple-secondary, #6c757d); }
.btn-success::after   { background-color: var(--ripple-success,   #198754); }
.btn-danger::after    { background-color: var(--ripple-danger,    #dc3545); }
.btn-warning::after   { background-color: #ffc107; }
.btn-info::after      { background-color: #0dcaf0; }
.btn-light::after     { background-color: #f8f9fa; }
.btn-dark::after      { background-color: #212529; }
.btn-nav-ghost::after { background-color: var(--ripple-ghost, #ffffff); }
.btn[class*="btn-outline-"]::after { background-color: var(--ripple-outline, #4f46e5); }
.btn[class*="btn-outline-"]::after { opacity: 0; transition: none; }
.btn:not([class*="btn-outline-"])::after { opacity: 0.4; }
.btn:not(.btn-link):hover { transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0,0,0,0.15); }
.btn[class*="btn-outline-"]:hover::after { animation: btn-ripple-outline 0.45s ease-out forwards; }
.btn:not(.btn-link):hover::after { transform: scaleX(1.4) scaleY(1.6); opacity: 0; }
.btn:not(.btn-link):active { transform: translateY(-1px); box-shadow: 0 5px 10px rgba(0,0,0,0.15); }

/* ── Form Controls ── */
.form-control, .form-select { border-radius: 0.5rem; border: 1px solid #cbd5e1; padding: 0.5rem 0.75rem; font-size: 0.9rem; }
.form-control:focus, .form-select:focus { border-color: #4f46e5; box-shadow: 0 0 0 4px rgba(79,70,229,0.1); outline: none; }

/* ── Modals ── */
.modal-content { border: none; border-radius: 1rem; box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25); }
.modal-header { border-bottom: 1px solid #f1f5f9; padding: 1.5rem; position: relative; }
.modal-header .btn-close { position: absolute; right: 1.5rem; top: 1.5rem; margin: 0; }
.modal-footer { border-top: 1px solid #f1f5f9; padding: 1.25rem; }

/* ── Assignee / next-action badge ── */
.b-assignee, .b-next { display: inline-flex; align-items: center; gap: 6px; padding: 3px 9px 3px 3px; border-radius: 6px; font-size: 11px; font-weight: 600; border: none; white-space: nowrap; }
.b-assignee .av, .b-next .av { width: 18px; height: 18px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 700; flex-shrink: 0; }

/* ── Status badge ── */
.b-status {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 9px; border-radius: 6px;
    font-size: 11px; font-weight: 600; letter-spacing: .01em; white-space: nowrap;
}
.b-status .dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; animation: dot-pulse 1.8s ease-in-out infinite; }
.b-status.status-is-closed .dot { display: none; }

/* ── Follow-up badge ── */
.b-fu {
    position: relative; overflow: hidden;
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 9px; border-radius: 6px;
    font-size: 11px; font-weight: 600; white-space: nowrap !important;
    flex-shrink: 0; font-variant-numeric: tabular-nums;
}
.countdown-text { white-space: nowrap !important; display: inline-block; }
.b-fu .dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.b-fu.fu-now  { background: var(--fu-now-bg, #dc2626); color: var(--fu-now-text, #fff); }
.b-fu.fu-now  .dot { background: var(--fu-now-dot, #fca5a5); animation: dot-pulse 1.4s ease-in-out infinite; }
.b-fu.fu-now::after  { content: ''; position: absolute; top: 0; left: -70%; width: 55%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent); animation: shimmer 2s ease-in-out infinite; }
.b-fu.fu-soon { background: var(--fu-soon-bg, #d97706); color: var(--fu-soon-text, #fff); }
.b-fu.fu-soon .dot { background: var(--fu-soon-dot, #fde68a); animation: dot-pulse 2s ease-in-out infinite; }
.b-fu.fu-soon::after { content: ''; position: absolute; top: 0; left: -70%; width: 55%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent); animation: shimmer 2.5s ease-in-out infinite; }
.b-fu.fu-closed { background: transparent; color: var(--fu-closed-bg, #16a34a); padding: 0; }
.b-fu.fu-closed .dot { display: none; }
.b-fu.fu-closed::after { display: none; }

/* ── Time-remaining badge ── */
.b-time {
    display: inline-flex; align-items: center; gap: 5px;
    background: var(--fu-waiting-bg, #eff6ff); color: var(--fu-waiting-text, #1d4ed8);
    border-radius: 6px; padding: 3px 9px;
    font-size: 11px; font-weight: 600; border: 1px solid var(--fu-waiting-ring, #bfdbfe);
    font-variant-numeric: tabular-nums;
}
.b-time .ring { width: 8px; height: 8px; border-radius: 50%; border: 2px solid var(--fu-waiting-ring, #bfdbfe); border-top-color: var(--fu-waiting-ring-top, #3b82f6); flex-shrink: 0; animation: spin 1.1s linear infinite; }

/* ── Follow-up label ── */
.fu-label { font-size: 9.5px; color: #9ca3af; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; min-width: 24px; display: inline-block; }

/* ── Animations — see animations.css ── */

/* ── Notifications ── */
.tt-toast-wrap { position: fixed; bottom: 20px; right: 20px; z-index: 9990; display: flex; flex-direction: column; gap: 10px; pointer-events: none; }
.tt-toast {
    pointer-events: all;
    background: #fff; border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.12), 0 1px 4px rgba(0,0,0,0.06);
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 14px 14px 16px; min-width: 280px; max-width: 360px;
    border-top: 3px solid #22c55e;
    opacity: 0; transform: translateY(8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}
.tt-toast.tt-show { opacity: 1; transform: translateY(0); }
.tt-toast.tt-hiding { opacity: 0; transform: translateY(8px); }
.tt-toast[data-type="success"] { border-top-color: #22c55e; }
.tt-toast[data-type="danger"]  { border-top-color: #ef4444; }
.tt-toast[data-type="warning"] { border-top-color: #f59e0b; }
.tt-toast[data-type="primary"] { border-top-color: #3b82f6; }
.tt-toast-icon { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 14px; }
.tt-toast[data-type="success"] .tt-toast-icon { background: #dcfce7; color: #16a34a; }
.tt-toast[data-type="danger"]  .tt-toast-icon { background: #fee2e2; color: #dc2626; }
.tt-toast[data-type="warning"] .tt-toast-icon { background: #fef3c7; color: #d97706; }
.tt-toast[data-type="primary"] .tt-toast-icon { background: #dbeafe; color: #1d4ed8; }
.tt-toast-body { flex: 1; min-width: 0; }
.tt-toast-title { font-size: 13px; font-weight: 600; color: #1e293b; line-height: 1.4; }
.tt-toast-sub { font-size: 12px; color: #64748b; margin-top: 2px; line-height: 1.4; }
.tt-toast-close { background: none; border: none; color: #9ca3af; cursor: pointer; font-size: 15px; padding: 0; line-height: 1; flex-shrink: 0; margin-top: 1px; transition: color 0.12s; }
.tt-toast-close:hover { color: #374151; }

/* ── Sidebar toggle button ── */
.sb-brand { display: flex; align-items: center; gap: 9px; padding: 0 10px 20px 12px; flex-shrink: 0; }
.sb-toggle-btn { flex-shrink: 0; margin-left: auto; width: 24px; height: 24px; border: 1px solid #e5e7eb; border-radius: 6px; background: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; color: #9ca3af; font-size: 11px; transition: background 0.12s, border-color 0.12s, color 0.12s; }
.sb-toggle-btn:hover { background: #f1f5f9; border-color: #d1d5db; color: #374151; }
/* Collapsed: center the icon, hide the toggle btn, click brand icon to expand */
.sidebar.collapsed .sb-brand { justify-content: center; padding-left: 4px; padding-right: 4px; cursor: pointer; }
.sidebar.collapsed .sb-toggle-btn { display: none; }
.sidebar.collapsed .sb-brand-icon { position: relative; }
.sidebar.collapsed .sb-brand:hover .sb-brand-icon::after { content: '›'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.32); border-radius: 8px; color: #fff; font-size: 18px; font-weight: 700; line-height: 1; }

/* ── Shared action buttons (used in modals across the app) ── */
.tg-btn-primary { display:inline-flex; align-items:center; gap:6px; background:#1654D1; color:#fff; border:1px solid #1654D1; border-radius:6px; padding:6px 16px; font-size:13px; font-weight:600; cursor:pointer; transition:opacity 0.12s; white-space:nowrap; }
.tg-btn-primary:hover { opacity:0.88; }
.tg-btn-ghost { display:inline-flex; align-items:center; gap:6px; background:#fff; color:#374151; border:1px solid #e5e7eb; border-radius:6px; padding:6px 14px; font-size:13px; font-weight:500; cursor:pointer; transition:background 0.12s; white-space:nowrap; }
.tg-btn-ghost:hover { background:#f9fafb; border-color:#d1d5db; }

/* ── Tom Select — global shape and behaviour ── */
.ts-wrapper { border-radius: 0.5rem !important; background-color: #fff !important; }
.ts-dropdown { border-radius: 0.5rem !important; }
.ts-control input { font-size: inherit !important; min-width: 0 !important; }
.ts-wrapper.single .ts-control { flex-wrap: nowrap !important; overflow: hidden; }
.ts-wrapper.single .ts-control .ts-item { background: transparent !important; color: inherit !important; border-radius: 0 !important; padding: 0 !important; margin: 0 !important; border: none !important; font-weight: inherit !important; font-size: inherit !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.ts-wrapper.single.has-items:not(.input-active) .ts-control input { position: absolute !important; opacity: 0 !important; pointer-events: none !important; }

/* ── Dark Mode ── */
body.dark-mode { background-color: #0f172a !important; color: #e2e8f0 !important; }
body.dark-mode .card { background-color: #1e293b !important; color: #e2e8f0 !important; }
body.dark-mode .card-header { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .card-footer { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .section-title { color: #e2e8f0 !important; }
body.dark-mode .modal-content { background-color: #1e293b !important; color: #e2e8f0 !important; }
body.dark-mode .modal-header { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .modal-footer { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .modal-body { background-color: #1e293b !important; }
body.dark-mode .form-control:not([type="color"]), body.dark-mode .form-select { background-color: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .form-control:focus, body.dark-mode .form-select:focus { border-color: #6366f1 !important; box-shadow: 0 0 0 3px rgba(99,102,241,0.15) !important; }
body.dark-mode .form-control::placeholder { color: #475569 !important; }
body.dark-mode .form-text { color: #64748b !important; }
body.dark-mode label.form-label { color: #94a3b8 !important; }
body.dark-mode .input-group-text { background-color: #1e293b !important; border-color: #334155 !important; color: #94a3b8 !important; }
body.dark-mode .dropdown-menu { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .dropdown-item { color: #e2e8f0 !important; }
body.dark-mode .dropdown-item:hover, body.dark-mode .dropdown-item:focus { background-color: #334155 !important; color: #f1f5f9 !important; }
body.dark-mode .dropdown-divider { border-color: #334155 !important; }
body.dark-mode .table { color: #e2e8f0 !important; --bs-table-bg: #1e293b; --bs-table-color: #e2e8f0; }
body.dark-mode .table td, body.dark-mode .table th { border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .table-hover tbody tr:hover td { background-color: rgba(51,65,85,0.5) !important; }
body.dark-mode .accordion-item { background-color: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .accordion-button { background-color: #1e293b !important; color: #e2e8f0 !important; box-shadow: none !important; }
body.dark-mode .accordion-button:not(.collapsed) { background-color: #0f172a !important; color: #e2e8f0 !important; }
body.dark-mode .accordion-button::after { filter: invert(1) brightness(2); }
body.dark-mode .accordion-collapse { border-color: #334155 !important; }
body.dark-mode .accordion-body { background-color: #1e293b !important; color: #e2e8f0 !important; }
body.dark-mode .list-group-item { background-color: #1e293b !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode hr { border-color: #334155 !important; }
body.dark-mode p, body.dark-mode span, body.dark-mode h1, body.dark-mode h2, body.dark-mode h3, body.dark-mode h4, body.dark-mode h5, body.dark-mode h6 { color: #e2e8f0; }
body.dark-mode small, body.dark-mode .text-muted { color: #64748b !important; }
body.dark-mode .text-secondary { color: #94a3b8 !important; }
/* Sidebar */
body.dark-mode .sidebar { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .sb-brand-name { color: #e2e8f0 !important; }
body.dark-mode .sb-label { color: #475569 !important; }
body.dark-mode .sb-item { color: #94a3b8 !important; }
body.dark-mode .sb-item:hover { background: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .sb-item.active { background: #1d4ed8 !important; color: #fff !important; }
body.dark-mode .sb-bottom { border-color: #334155 !important; }
body.dark-mode .sb-toggle-btn { background: #1e293b !important; border-color: #475569 !important; color: #94a3b8 !important; }
body.dark-mode .sb-toggle-btn:hover { background: #334155 !important; }
/* Topbar */
body.dark-mode .topbar { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .topbar-title { color: #e2e8f0 !important; }
body.dark-mode .topbar-user-btn { background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .topbar-user-btn:hover { background: #334155 !important; border-color: #475569 !important; }
body.dark-mode .topbar-username { color: #e2e8f0 !important; }
/* Toast */
body.dark-mode .tt-toast { background: #1e293b !important; box-shadow: 0 4px 20px rgba(0,0,0,0.4) !important; }
body.dark-mode .tt-toast-title { color: #e2e8f0 !important; }
body.dark-mode .tt-toast-sub { color: #94a3b8 !important; }
body.dark-mode .tt-toast-close { color: #64748b !important; }
body.dark-mode .tt-toast-close:hover { color: #e2e8f0 !important; }
/* Action buttons */
body.dark-mode .tg-btn-ghost { background: #334155 !important; border-color: #475569 !important; color: #e2e8f0 !important; }
body.dark-mode .tg-btn-ghost:hover { background: #475569 !important; }
/* Tom Select */
body.dark-mode .ts-wrapper { background-color: #0f172a !important; }
body.dark-mode .ts-control { background-color: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .ts-dropdown { background-color: #1e293b !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .ts-dropdown .option:hover, body.dark-mode .ts-dropdown .option.active { background: #334155 !important; }
body.dark-mode .ts-dropdown .option { color: #e2e8f0 !important; }
/* Settings page specifics */
body.dark-mode .settings-nav { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .settings-grp { color: #475569 !important; }
body.dark-mode .nav-pills .nav-link { color: #94a3b8 !important; }
body.dark-mode .nav-pills .nav-link.active { background-color: #1d4ed8 !important; color: #fff !important; }
body.dark-mode .nav-pills .nav-link:hover:not(.active) { background-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .settings-content { background: #0f172a !important; }
body.dark-mode .card-body h6 { color: #64748b !important; }
/* Bootstrap alert overrides */
body.dark-mode .alert-success { background-color: #064e3b !important; border-color: #065f46 !important; color: #a7f3d0 !important; }
body.dark-mode .alert-danger  { background-color: #450a0a !important; border-color: #7f1d1d !important; color: #fca5a5 !important; }
body.dark-mode .alert-warning { background-color: #451a03 !important; border-color: #78350f !important; color: #fcd34d !important; }
body.dark-mode .alert-info    { background-color: #0c1a4e !important; border-color: #1e3a8a !important; color: #93c5fd !important; }
/* Badge contrast */
body.dark-mode .badge.bg-light { background-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .badge.text-dark { color: #e2e8f0 !important; }
/* Borders and dividers */
body.dark-mode .border, body.dark-mode .border-bottom, body.dark-mode .border-top { border-color: #334155 !important; }
/* Dropdown inner content (overrides inline color styles) */
body.dark-mode .dropdown-menu > div > div[style*="font-size:10.5px"], body.dark-mode .dropdown-menu p[style*="color:#94a3b8"] { color: #475569 !important; }
body.dark-mode .dropdown-menu div[style*="color:#0f172a"], body.dark-mode .dropdown-menu div[style*="color: #0f172a"] { color: #e2e8f0 !important; }
body.dark-mode .dropdown-menu div[style*="color:#64748b"], body.dark-mode .dropdown-menu div[style*="color: #64748b"] { color: #64748b !important; }
body.dark-mode .dropdown-menu span[style*="background:#fff"] { background: #334155 !important; border-color: #475569 !important; color: #e2e8f0 !important; }
body.dark-mode .dropdown-menu [style*="border-top:1px solid #f1f5f9"], body.dark-mode .dropdown-menu [style*="border-top: 1px solid #f1f5f9"] { border-color: #334155 !important; }
body.dark-mode .hdr-dd-item { color: #e2e8f0 !important; }
body.dark-mode .hdr-dd-item:hover { background: #334155 !important; }
/* Table header in settings */
body.dark-mode .table thead th { background-color: #0f172a !important; color: #64748b !important; }
/* Anim section boxes */
body.dark-mode .anim-section { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .anim-preview-box { background: #0f172a !important; border-color: #334155 !important; }
/* Color field */
body.dark-mode .color-field { background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .clr-hex { color: #94a3b8 !important; }
/* Confirm dialog */
body.dark-mode #sharedConfirmModal > div { background: #1e293b !important; }
body.dark-mode #sharedConfirmTitle { color: #e2e8f0 !important; }
body.dark-mode #sharedConfirmMessage { color: #94a3b8 !important; }
body.dark-mode #sharedConfirmModal button[onclick*="_confirmReject"] { background: #0f172a !important; border-color: #334155 !important; color: #94a3b8 !important; }
/* Pagination buttons */
body.dark-mode .pg-btn-link { background: #1e293b !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .pg-btn-link:hover { background: #334155 !important; }
body.dark-mode .pg-btn-disabled { background: #0f172a !important; border-color: #334155 !important; color: #475569 !important; }
/* Banner clear buttons */
body.dark-mode .banner-clear-btn { background: #1e293b !important; color: #e2e8f0 !important; border-color: #475569 !important; }
/* Group filter banner bg */
body.dark-mode .banner-group-bg { background: #1e1b4b !important; border-color: #4338ca !important; }
body.dark-mode .banner-group-bg .text-muted { color: #6366f1 !important; }
/* Filter modal header */
body.dark-mode .filter-modal-content > div:first-child { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .filter-modal-content > div:first-child * { color: #e2e8f0 !important; }
/* Ticket groups modal */
body.dark-mode #ticketGroupsModal .tg-group-row { border-color: #334155 !important; }
body.dark-mode #ticketGroupsModal .tg-group-row:hover { background: #334155 !important; }
body.dark-mode #ticketGroupsModal .tg-input { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode #ticketGroupsModal .tg-select { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode #ticketGroupsModal .tg-section { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode #ticketGroupsModal .tg-btn-icon { background: #334155 !important; border-color: #475569 !important; color: #94a3b8 !important; }
body.dark-mode #ticketGroupsModal .tg-btn-danger-icon { background: #450a0a !important; border-color: #7f1d1d !important; color: #fca5a5 !important; }
body.dark-mode #ticketGroupsModal .tg-label { color: #94a3b8 !important; }
body.dark-mode #ticketGroupsModal .modal-content { border-color: #334155 !important; }
/* Ticket detail modal — inline-styled elements */
body.dark-mode .td-ts-card { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .td-ts-btns button { background: #1e293b !important; border-color: #334155 !important; color: #94a3b8 !important; }
body.dark-mode .td-url-row { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .td-update-card { background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .td-footer-btn-primary { background: #0f172a !important; }
body.dark-mode .td-footer-btn-danger  { background: #0f172a !important; border-color: #7f1d1d !important; }
body.dark-mode .td-modal-title-text { color: #e2e8f0 !important; }
body.dark-mode .td-ts-card .td-ts-val { color: #e2e8f0 !important; }
body.dark-mode #simpleTimeModal .modal-content > div,
body.dark-mode #closeReasonModal .modal-content > div { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode #simpleTimeModalLabel { color: #e2e8f0 !important; }
body.dark-mode #simple_time_input { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode #closeReasonModal span[style*="color:#0f172a"] { color: #e2e8f0 !important; }
body.dark-mode #closeReasonModal button[data-bs-dismiss="modal"] { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode #closeReasonOptions .form-check-label { color: #e2e8f0 !important; }
body.dark-mode .hist-log-search { color: #e2e8f0 !important; }
body.dark-mode .hist-log-wrap [style*="background:#f8fafc"] { background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .cal-day { color: #e2e8f0 !important; }
body.dark-mode #newUpdateText { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .td-upd-author, body.dark-mode .td-upd-body, body.dark-mode .td-hist-author, body.dark-mode .td-hist-body { color: #e2e8f0 !important; }
/* Ticket groups modal */
body.dark-mode #ticketGroupsModal .modal-content > div { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode #ticketGroupsModalLabel { color: #e2e8f0 !important; }
body.dark-mode .tg-section-label, body.dark-mode .tg-group-name, body.dark-mode .tg-ticket-title { color: #e2e8f0 !important; }
body.dark-mode #tgTicketSearch { color: #e2e8f0 !important; }
/* Activity log modal */
body.dark-mode .activity-page-link { color: #e2e8f0 !important; background: #1e293b !important; border-color: #334155 !important; }
/* Add / Edit ticket modals */
body.dark-mode #addTicketModalLabel, body.dark-mode #editTicketModal .modal-title { color: #e2e8f0 !important; }
/* Dashboard */
body.dark-mode .dash-card-header { color: #e2e8f0 !important; border-color: #334155 !important; }
body.dark-mode #filterDateFrom, body.dark-mode #filterDateTo { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .dash-apply-btn { color: #e2e8f0 !important; background: #1e293b !important; border-color: #334155 !important; }
/* EOD report toolbar */
body.dark-mode .toolbar strong { color: #e2e8f0 !important; }
body.dark-mode #dateInput { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .eod-reload-btn { color: #e2e8f0 !important; background: #1e293b !important; border-color: #334155 !important; }
/* Notes */
body.dark-mode .notes-topbar-title { color: #e2e8f0 !important; }
body.dark-mode .notes-topbar-search input { color: #e2e8f0 !important; background: #0f172a !important; border-color: #334155 !important; }
body.dark-mode .notes-tb-dd-btn { color: #e2e8f0 !important; background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .notes-tb-reset:hover { color: #e2e8f0 !important; }
/* Login page */
body.dark-mode .form-panel { background: #0f172a !important; }
body.dark-mode .gradient-panel { background: linear-gradient(145deg, #0c1a2e 0%, #0a1a2a 40%, #0c1a12 100%) !important; }
body.dark-mode .testimonial-card { background: #1e293b !important; }
body.dark-mode .testimonial-card p, body.dark-mode .greeting { color: #e2e8f0 !important; }
body.dark-mode .greeting-sub, body.dark-mode .form-check-label, body.dark-mode .back-link { color: #64748b !important; }
/* General bg-white / bg-light overrides inside dark UI */
body.dark-mode .bg-white { background-color: #1e293b !important; }
body.dark-mode .bg-light { background-color: #0f172a !important; }
body.dark-mode .bg-light.text-secondary { color: #94a3b8 !important; }
/* btn-close filter invert for dark backgrounds */
body.dark-mode .btn-close { filter: invert(1) brightness(2) !important; }
/* Layout areas */
body.dark-mode .main { background: #0f172a !important; }
body.dark-mode .main-body { background: #0f172a !important; }
body.dark-mode .toolbar { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .tt-footer { background: #1e293b !important; border-color: #334155 !important; color: #94a3b8 !important; }
body.dark-mode .eod-layout { background: #0f172a !important; }
/* Topbar search */
body.dark-mode .topbar-search input { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .topbar-search input::placeholder { color: #475569 !important; }
body.dark-mode .topbar-bell { background: #0f172a !important; border-color: #334155 !important; color: #94a3b8 !important; }
/* Toolbar buttons */
body.dark-mode .tb-dropdown-btn { background: #1e293b !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .tb-dropdown-btn i { color: #64748b !important; }
body.dark-mode .tb-btn-ghost { background: #1e293b !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .tb-btn-ghost:hover { background: #334155 !important; }
/* Sidebar danger items */
body.dark-mode .sb-item-danger:hover { background: #450a0a !important; color: #fca5a5 !important; }
body.dark-mode .hdr-dd-danger:hover { background: #450a0a !important; }
/* Dashboard */
body.dark-mode .kpi-cell { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .panel { background: #1e293b !important; border-color: #334155 !important; }
body.dark-mode .panel-head { border-color: #334155 !important; }
body.dark-mode .filter-seg { background: #334155 !important; }
body.dark-mode .filter-seg .fsb.active { background: #0f172a !important; color: #818cf8 !important; }
body.dark-mode .filter-seg .fsb { color: #94a3b8 !important; }
body.dark-mode .dash-list-item { border-color: #334155 !important; }
body.dark-mode .dash-list-item:hover { background: #1e293b !important; }
/* EOD report */
body.dark-mode .desc-input { background: #0f172a !important; border-color: #334155 !important; color: #e2e8f0 !important; }
body.dark-mode .desc-input:focus { background: #1e293b !important; }
/* Follow-up waiting badge CSS variable overrides */
body.dark-mode { --fu-waiting-bg: #0c1a3a; --fu-waiting-text: #93c5fd; --fu-waiting-ring: #1e3a8a; --fu-waiting-ring-top: #60a5fa; }
/* Table wrap scrollbar */
body.dark-mode .table-wrap::-webkit-scrollbar-track { background: #0f172a; }
body.dark-mode .table-wrap::-webkit-scrollbar-thumb { background: #334155; }
