/* ============================================================
   Nalivayka CRM — Dark Indigo Theme (finCRM-compatible)
   ============================================================ */

:root {
    --bg-body: #0d0f1a;
    --bg-surface: #131525;
    --bg-surface-2: #1a1d30;
    --bg-surface-hover: #22253d;
    --bg-sidebar: #0b0d18;
    --sidebar-width: 220px;
    --sidebar-hover: #181b2e;
    --sidebar-active: #6c5ce7;
    --text-primary: #c8ccd8;
    --text-secondary: #7f849c;
    --text-muted: #4a4f65;
    --border-color: #1c1f33;
    --border-light: #262a40;
    --accent: #6c5ce7;
    --accent-hover: #5a4bd6;
    --accent-soft: rgba(108,92,231,.12);
    --topbar-height: 48px;
    --danger: #e74c3c;
    --success: #2ecc71;
    --warning: #f39c12;
    --info: #3498db;
}

/* ---- Reset ---- */
*, *::before, *::after { box-sizing: border-box; }
select, select option, select optgroup {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background: var(--bg-body);
    color: var(--text-primary);
    margin: 0;
    min-height: 100vh;
    font-size: 13px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: #8b7cf0; }

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: var(--sidebar-width);
    background: var(--bg-sidebar);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    z-index: 1040;
    overflow: hidden;
    transition: transform .2s ease;
}

.sidebar-header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}
.sidebar-brand {
    color: #e0e0e0;
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
}
.sidebar-brand:hover { color: #fff; }
.sidebar-brand i { color: var(--accent); }

.sidebar-body {
    flex: 1;
    overflow-y: auto;
    padding: 6px 0;
    scrollbar-width: thin;
    scrollbar-color: #262a40 transparent;
}
.sidebar-body::-webkit-scrollbar { width: 3px; }
.sidebar-body::-webkit-scrollbar-thumb { background: #262a40; border-radius: 3px; }

.sidebar-section-label {
    padding: 14px 16px 4px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-muted);
    user-select: none;
}

.sidebar-nav { list-style: none; margin: 0; padding: 0; }

.sidebar-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 16px;
    font-size: 12.5px;
    color: var(--text-secondary);
    border-left: 2px solid transparent;
    transition: all .12s;
    border-radius: 0;
}
.sidebar-link i {
    font-size: 14px;
    width: 18px;
    text-align: center;
    flex-shrink: 0;
    opacity: .6;
}
.sidebar-link:hover {
    background: var(--sidebar-hover);
    color: var(--text-primary);
}
.sidebar-link:hover i { opacity: 1; }
.sidebar-link.active {
    background: var(--accent-soft);
    color: #a29bfe;
    border-left-color: var(--accent);
}
.sidebar-link.active i { opacity: 1; color: #a29bfe; }

.sidebar-footer {
    padding: 10px 14px;
    border-top: 1px solid var(--border-color);
    flex-shrink: 0;
}
.sidebar-user { display: flex; align-items: center; gap: 8px; }
.sidebar-user-avatar { font-size: 1.3rem; color: var(--text-muted); }
.sidebar-user-info { display: flex; flex-direction: column; overflow: hidden; }
.sidebar-user-name {
    color: var(--text-primary);
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sidebar-user-role { color: var(--text-muted); font-size: 10px; }

/* ============================================================
   MAIN CONTENT
   ============================================================ */
.main-content {
    margin-left: var(--sidebar-width);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.content-topbar {
    background: var(--bg-surface);
    border-bottom: 1px solid var(--border-color);
    padding: 10px 24px;
    position: sticky;
    top: 0;
    z-index: 1020;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.content-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}

.content-body { padding: 16px 24px; flex: 1; }

/* ============================================================
   MOBILE
   ============================================================ */
.mobile-topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: var(--topbar-height);
    background: var(--bg-sidebar);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 14px;
    z-index: 1050;
    border-bottom: 1px solid var(--border-color);
}
.mobile-topbar-brand { color: #fff; font-weight: 600; font-size: 13px; }

.sidebar-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 1035;
    opacity: 0; visibility: hidden;
    transition: .2s;
}
.sidebar-overlay.show { opacity: 1; visibility: visible; }

@media (max-width: 991.98px) {
    .sidebar { transform: translateX(-100%); }
    .sidebar.show { transform: translateX(0); }
    .main-content { margin-left: 0; padding-top: var(--topbar-height); }
    .content-topbar { position: static; }
    .content-body { padding: 12px; }
}
@media (min-width: 992px) {
    .mobile-topbar { display: none !important; }
}

/* ============================================================
   STATUS BADGES
   ============================================================ */
.badge-status {
    font-size: 10px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: .03em;
    white-space: nowrap;
}
.badge-pending   { background: rgba(243,156,18,.15); color: #f1c40f; }
.badge-sale      { background: rgba(46,204,113,.15); color: #2ecc71; }
.badge-ftd       { background: rgba(52,152,219,.15); color: #3498db; }
.badge-approved  { background: rgba(46,204,113,.15); color: #2ecc71; }
.badge-canceled  { background: rgba(231,76,60,.15); color: #e74c3c; }
.badge-failed    { background: rgba(231,76,60,.15); color: #e74c3c; }
.badge-lpending  { background: rgba(243,156,18,.1); color: #f39c12; }
.badge-check     { background: rgba(108,92,231,.15); color: #a29bfe; }
.badge-deleted   { background: rgba(127,132,156,.15); color: #7f849c; text-decoration: line-through; }

/* ============================================================
   TABLES
   ============================================================ */
.crm-table-wrapper {
    border: 1px solid var(--border-color);
    border-radius: 6px;
    overflow: hidden;
    background: var(--bg-surface);
}

.crm-table { margin-bottom: 0; color: var(--text-primary); }

.crm-table thead th {
    background: var(--bg-surface-2);
    border-bottom: 1px solid var(--border-light);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-muted);
    white-space: nowrap;
    padding: 8px 10px;
    position: sticky;
    top: 0;
}
.crm-table tbody td {
    font-size: 12px;
    padding: 6px 10px;
    border-color: var(--border-color);
    color: var(--text-secondary);
    vertical-align: middle;
}
.crm-table tbody tr { transition: background .1s; }
.crm-table tbody tr:hover { background: var(--bg-surface-hover); }
.crm-table tbody tr:hover td { color: var(--text-primary); }

/* Bootstrap table overrides */
.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text-primary);
    --bs-table-border-color: var(--border-color);
}
.table > thead { border-bottom: 1px solid var(--border-light); }
.table > tbody > tr { border-color: var(--border-color); }
.table th:last-child, .table td:last-child { padding-right: 16px; }
.table th:first-child, .table td:first-child { padding-left: 12px; }
.table-hover > tbody > tr:hover > * { --bs-table-bg-state: var(--bg-surface-hover); color: var(--text-primary); }
.table-striped > tbody > tr:nth-of-type(odd) > * { --bs-table-striped-bg: rgba(255,255,255,.015); }

/* thead/tfoot variants */
.table-dark > *,
.table thead.table-dark > tr > th {
    --bs-table-bg: var(--bg-surface-2);
    background: var(--bg-surface-2) !important;
    color: var(--text-muted) !important;
    border-color: var(--border-light) !important;
    font-weight: 600;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.table-light > *,
.table thead.table-light > tr > th,
.table tfoot.table-light > tr > td {
    --bs-table-bg: var(--bg-surface-2);
    background: var(--bg-surface-2) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-light) !important;
}

/* row variants */
.table-secondary > * {
    --bs-table-bg: var(--bg-surface-2);
    background: var(--bg-surface-2) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border-light) !important;
}
.table-danger > * {
    --bs-table-bg: rgba(231,76,60,.06);
    background: rgba(231,76,60,.06) !important;
    color: var(--text-primary) !important;
}
.table-success > * {
    --bs-table-bg: rgba(46,204,113,.06);
    background: rgba(46,204,113,.06) !important;
    color: var(--text-primary) !important;
}
.table-warning > * {
    --bs-table-bg: rgba(243,156,18,.06);
    background: rgba(243,156,18,.06) !important;
    color: var(--text-primary) !important;
}

/* ============================================================
   CARDS
   ============================================================ */
.card {
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    border-radius: 8px;
}
.card-header {
    background: var(--bg-surface-2);
    border-color: var(--border-color);
    padding: 10px 16px;
}
.card-footer {
    background: var(--bg-surface);
    border-color: var(--border-color);
}
.card.bg-primary.bg-opacity-10,
.card.bg-success.bg-opacity-10,
.card.bg-info.bg-opacity-10,
.card.bg-warning.bg-opacity-10 {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-light) !important;
}

.stat-card {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-surface);
    transition: transform .15s, border-color .15s;
}
.stat-card:hover {
    transform: translateY(-1px);
    border-color: var(--border-light);
}
.stat-card .stat-value { font-size: 1.4rem; font-weight: 700; color: var(--text-primary); }
.stat-card .stat-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .05em; }

/* ============================================================
   FILTER BAR
   ============================================================ */
.filter-card {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-surface);
}
.filter-card .form-label {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text-muted);
    margin-bottom: 3px;
}

/* ============================================================
   FORMS
   ============================================================ */
.form-control, .form-select {
    background: var(--bg-surface-2);
    border: 1px solid var(--border-light);
    color: var(--text-primary);
    font-size: 12px;
    padding: 6px 10px;
    border-radius: 6px;
}
.form-control::placeholder { color: var(--text-muted); }
.form-control:focus, .form-select:focus {
    background: var(--bg-surface-2);
    border-color: var(--accent);
    color: var(--text-primary);
    box-shadow: 0 0 0 2px rgba(108,92,231,.2);
}
.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%234a4f65' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 16px 12px;
}
.form-select option { background: var(--bg-surface); color: var(--text-primary); }

.form-check-input {
    background-color: var(--bg-surface-2);
    border-color: var(--border-light);
}
.form-check-input:checked {
    background-color: var(--accent);
    border-color: var(--accent);
}
.form-label { color: var(--text-secondary); font-size: 12px; }

.input-group-text {
    background: var(--bg-surface-2);
    border-color: var(--border-light);
    color: var(--text-muted);
    font-size: 12px;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn { font-size: 12px; padding: 6px 14px; border-radius: 6px; font-weight: 500; }
.btn-sm { font-size: 11px; padding: 4px 10px; }
.btn-primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.btn-outline-primary { color: var(--accent); border-color: var(--accent); }
.btn-outline-primary:hover { background: var(--accent); color: #fff; }
.btn-outline-secondary { color: var(--text-secondary); border-color: var(--border-light); }
.btn-outline-secondary:hover { background: var(--bg-surface-2); color: var(--text-primary); border-color: var(--text-muted); }
.btn-outline-danger { color: var(--danger); border-color: var(--danger); }
.btn-outline-danger:hover { background: var(--danger); color: #fff; }
.btn-outline-warning { color: var(--warning); border-color: var(--warning); }
.btn-outline-warning:hover { background: var(--warning); color: #000; }
.btn-outline-light { color: var(--text-secondary); border-color: var(--border-light); }
.btn-outline-light:hover { background: var(--bg-surface-2); color: var(--text-primary); }
.btn-success { background: var(--success); border-color: var(--success); }
.btn-danger { background: var(--danger); border-color: var(--danger); }

.btn-loading {
    position: relative; color: transparent !important; pointer-events: none;
}
.btn-loading::after {
    content: ""; position: absolute; inset: 0; margin: auto;
    width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,.3); border-top-color: #fff;
    border-radius: 50%; animation: btnSpin .5s linear infinite;
}
@keyframes btnSpin { to { transform: rotate(360deg); } }

/* ============================================================
   BADGES
   ============================================================ */
.badge.bg-light { background: var(--bg-surface-2) !important; color: var(--text-primary) !important; }
.badge.bg-secondary { background: rgba(127,132,156,.15) !important; color: var(--text-secondary) !important; }
.badge.bg-dark { background: var(--bg-surface-2) !important; color: var(--text-primary) !important; border: 1px solid var(--border-light) !important; }
.badge.bg-info { background: rgba(52,152,219,.15) !important; color: #3498db !important; }
.badge.bg-success { background: rgba(46,204,113,.15) !important; color: #2ecc71 !important; }
.badge.bg-danger { background: rgba(231,76,60,.15) !important; color: #e74c3c !important; }
.badge.bg-warning { background: rgba(243,156,18,.15) !important; color: #f39c12 !important; }
.badge.bg-primary { background: rgba(108,92,231,.15) !important; color: #a29bfe !important; }

/* ============================================================
   MODALS
   ============================================================ */
.modal-content {
    background: var(--bg-surface);
    border: 1px solid var(--border-light);
    color: var(--text-primary);
    border-radius: 10px;
}
.modal-header { border-color: var(--border-color); }
.modal-footer { border-color: var(--border-color); }
.btn-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* ============================================================
   ACCORDION
   ============================================================ */
.accordion-item { background: var(--bg-surface); border-color: var(--border-color); }
.accordion-button { background: var(--bg-surface-2); color: var(--text-primary); font-size: 13px; padding: 8px 14px; }
.accordion-button:not(.collapsed) { background: var(--bg-surface); color: var(--accent); box-shadow: none; }
.accordion-button::after { filter: invert(.6); }
.accordion-body { background: var(--bg-surface); padding: 12px 14px; }

/* ============================================================
   PAGINATION
   ============================================================ */
.page-link {
    background: var(--bg-surface);
    border-color: var(--border-color);
    color: var(--text-secondary);
    font-size: 12px;
    padding: 4px 10px;
}
.page-link:hover { background: var(--bg-surface-2); color: var(--text-primary); border-color: var(--border-light); }
.page-item.active .page-link { background: var(--accent); border-color: var(--accent); color: #fff; }
.page-item.disabled .page-link { background: var(--bg-surface); color: var(--text-muted); border-color: var(--border-color); }

/* ============================================================
   ALERTS
   ============================================================ */
.alert { font-size: 12px; border-radius: 6px; }
.alert-secondary { background: var(--bg-surface-2); border-color: var(--border-light); color: var(--text-primary); }
.alert-danger { background: rgba(231,76,60,.1); border-color: rgba(231,76,60,.2); color: #f5a5a0; }
.alert-success { background: rgba(46,204,113,.1); border-color: rgba(46,204,113,.2); color: #82e6ad; }
.alert-warning { background: rgba(243,156,18,.1); border-color: rgba(243,156,18,.2); color: #f7d794; }
.alert-info { background: rgba(52,152,219,.1); border-color: rgba(52,152,219,.2); color: #85c1e9; }

/* ============================================================
   PROGRESS BARS
   ============================================================ */
.progress { background: var(--bg-surface-2); border-radius: 4px; height: 6px; }

/* ============================================================
   DROPDOWNS
   ============================================================ */
.dropdown-menu { background: var(--bg-surface); border-color: var(--border-light); border-radius: 8px; }
.dropdown-item { color: var(--text-secondary); font-size: 12px; }
.dropdown-item:hover { background: var(--bg-surface-hover); color: var(--text-primary); }
.dropdown-divider { border-color: var(--border-color); }

/* ============================================================
   FLASH / TOASTS
   ============================================================ */
.flash-message { animation: flashSlideIn .3s ease; }
@keyframes flashSlideIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.flash-message.flash-fade-out { animation: flashFadeOut .3s ease forwards; }
@keyframes flashFadeOut { to { opacity: 0; transform: translateY(-6px); max-height: 0; margin: 0; padding: 0; overflow: hidden; } }

.toast-container { position: fixed; top: 12px; right: 12px; z-index: 1090; display: flex; flex-direction: column; gap: 6px; }
.crm-toast {
    min-width: 260px; padding: 10px 14px; border-radius: 8px;
    color: #fff; font-size: 12px; display: flex; align-items: center; gap: 6px;
    box-shadow: 0 4px 20px rgba(0,0,0,.5); animation: toastIn .25s ease;
}
.crm-toast.toast-success { background: #1a6b3c; }
.crm-toast.toast-danger { background: #8b2020; }
.crm-toast.toast-warning { background: #7a5b0e; color: #f7d794; }
.crm-toast.toast-info { background: #1a3a5c; color: #85c1e9; }
.crm-toast.toast-out { animation: toastOut .25s ease forwards; }
@keyframes toastIn { from { opacity: 0; transform: translateX(30px); } to { opacity: 1; transform: translateX(0); } }
@keyframes toastOut { to { opacity: 0; transform: translateX(30px); } }

/* ============================================================
   LOGIN PAGE
   ============================================================ */
.login-wrapper {
    min-height: 100vh; display: flex; align-items: center; justify-content: center;
    background: radial-gradient(ellipse at top, #181b30 0%, #0d0f1a 70%);
}
.login-card {
    width: 100%; max-width: 380px;
    border: 1px solid var(--border-light);
    border-radius: 12px;
    box-shadow: 0 8px 40px rgba(0,0,0,.5);
    background: var(--bg-surface);
}
.login-card .card-body { color: var(--text-primary); }
.login-logo {
    font-size: 1.4rem; font-weight: 700; color: var(--text-primary);
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.login-logo i { color: var(--accent); }

/* ============================================================
   UTILITY
   ============================================================ */
.text-truncate-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cursor-pointer { cursor: pointer; }
.lead-row.cursor-pointer:hover td { background: var(--bg-surface-hover); }
.quick-filter { color: inherit; text-decoration: none; cursor: pointer; }
.quick-filter:hover { text-decoration: underline; opacity: .8; }
.text-muted { color: var(--text-muted) !important; }
.border-bottom { border-color: var(--border-color) !important; }
hr { border-color: var(--border-color); opacity: .5; }
code { color: #a29bfe; }
pre { color: var(--text-primary); }

/* Scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #262a40; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: #363b55; }

/* Selection */
::selection { background: rgba(108,92,231,.3); }

/* Nav tabs dark */
.nav-tabs { border-color: var(--border-color); }
.nav-tabs .nav-link { color: var(--text-secondary); border: none; border-bottom: 2px solid transparent; font-size: 13px; }
.nav-tabs .nav-link:hover { color: var(--text-primary); border-color: transparent; }
.nav-tabs .nav-link.active { color: var(--accent); background: transparent; border-color: transparent; border-bottom-color: var(--accent); }
.card-header-tabs { margin-bottom: -1px; }

/* Form switch dark */
.form-switch .form-check-input { background-color: var(--bg-surface-2); border-color: var(--border-light); }
.form-switch .form-check-input:checked { background-color: var(--accent); border-color: var(--accent); }

/* ============================================================
   TOM SELECT — DARK
   ============================================================ */
.ts-wrapper .ts-control::after,
.ts-wrapper .ts-control > .dropdown-toggle,
.ts-wrapper.single .ts-control::after { display: none !important; }
.ts-wrapper select.ts-select { display: none !important; }
.ts-hidden-accessible { display: none !important; }
.ts-wrapper.multi .ts-control {
    background: var(--bg-surface-2);
    border-color: var(--border-light);
    color: var(--text-primary);
    min-height: 38px;
    border-radius: 6px;
}
.ts-wrapper.multi .ts-control > input { color: var(--text-primary); }
.ts-wrapper.multi .ts-control > input::placeholder { color: var(--text-muted); }
.ts-wrapper .ts-control { background: var(--bg-surface-2); border-color: var(--border-light); color: var(--text-primary); }
.ts-wrapper .ts-control:hover { border-color: var(--accent); }
.ts-wrapper.focus .ts-control { border-color: var(--accent); box-shadow: 0 0 0 .2rem rgba(108,92,231,.2); }
.ts-dropdown {
    background: var(--bg-surface);
    border-color: var(--border-light);
    color: var(--text-primary);
    border-radius: 6px;
}
.ts-dropdown .option { color: var(--text-primary); }
.ts-dropdown .option:hover, .ts-dropdown .active { background: var(--accent); color: #fff; }
.ts-dropdown .option.selected { background: var(--bg-surface-hover); }
.ts-wrapper .item {
    background: var(--accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 4px !important;
    padding: 2px 6px !important;
    font-size: 0.8125rem;
}
.ts-wrapper .item .remove { color: rgba(255,255,255,.6); border-left-color: rgba(255,255,255,.2); }
.ts-wrapper .item .remove:hover { color: #fff; }
select.tomselected,
select.ts-hidden-accessible { display: none !important; }
.ts-wrapper .dropdown-input { background: var(--bg-surface-2); color: var(--text-primary); border-color: var(--border-light); }
.ts-wrapper .ts-control .form-select { display: none; }

/* ============================================================
   DESIGN SYSTEM — shared primitives (opt-in)
   Use these classes in any template to get consistent look.
   ============================================================ */

/* ---- Page header row ---- */
.page-header {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px;
    padding: 12px 0 14px;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 16px;
}
.page-header h1, .page-header h2, .page-header .content-title {
    margin: 0; font-size: 18px; font-weight: 600; color: var(--text-primary);
}
.page-header .page-sub {
    color: var(--text-secondary); font-size: 12px; margin-top: 2px;
}

/* ---- Filter bar shared (used by stats, leads, offers, partners) ---- */
.filter-bar { padding: 10px 12px; }
.filter-bar .form-label-sm {
    font-size: 10.5px; letter-spacing: .03em;
    text-transform: uppercase; color: var(--text-secondary);
    margin-bottom: 2px;
}
.filter-bar .form-control-sm,
.filter-bar .form-select-sm { min-height: 30px; }

/* ---- Quick-range chips ---- */
.chip {
    border: 1px solid var(--border-light);
    background: transparent;
    color: var(--text-secondary);
    border-radius: 999px;
    padding: 3px 10px;
    font-size: 11.5px;
    cursor: pointer;
    transition: all .15s ease;
}
.chip:hover { background: var(--bg-surface-hover); color: var(--text-primary); }
.chip.chip-primary { border-color: var(--accent); color: var(--accent); }
.chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ---- KPI cards ---- */
.kpi-card {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px; border-radius: 10px;
    background: var(--bg-surface);
    border: 1px solid var(--border-color);
    height: 100%;
    transition: transform .15s ease, border-color .15s ease;
}
.kpi-card:hover { border-color: var(--border-light); transform: translateY(-1px); }
.kpi-icon { font-size: 22px; line-height: 1; opacity: .9; }
.kpi-label {
    font-size: 10.5px; text-transform: uppercase;
    letter-spacing: .05em; color: var(--text-secondary);
    margin-bottom: 2px;
}
.kpi-value { font-size: 22px; font-weight: 700; line-height: 1.1; color: var(--text-primary); }
.kpi-sub { font-size: 11px; margin-top: 2px; color: var(--text-secondary); }

/* ---- Unified data table ---- */
.data-table { font-size: 12.5px; margin-bottom: 0; }
.data-table thead th {
    background: var(--bg-surface);
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
    text-transform: uppercase;
    font-size: 10.5px;
    letter-spacing: .05em;
    font-weight: 600;
    position: sticky; top: 0; z-index: 2;
    padding: 10px 8px;
    white-space: nowrap;
}
.data-table tbody td { padding: 9px 8px; border-color: var(--border-color); vertical-align: middle; }
.data-table tbody tr { transition: background .1s ease; }
.data-table tbody tr:hover { background: var(--bg-surface-hover); }
.data-table tbody tr.is-highlight td { background: rgba(108,92,231,.08); }
.data-table tr.section-header td {
    background: linear-gradient(180deg, rgba(255,255,255,.025), transparent);
    font-weight: 600; font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
    color: var(--text-secondary); border-bottom: 1px solid var(--border-color);
    padding: 6px 10px;
}
.data-table tr.total-row td {
    background: rgba(108,92,231,.08);
    font-weight: 700;
    border-top: 1px solid var(--accent);
    border-bottom: 1px solid var(--accent);
}

/* ---- Sortable column header ---- */
.sortable { cursor: pointer; user-select: none; }
.sortable:hover { color: var(--text-primary); }
.sort-ind { opacity: .35; font-size: 9px; margin-left: 4px; }
.sort-ind.active { opacity: 1; color: var(--accent); }

/* ---- Pill / tag / bubble ---- */
.pill {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px; border-radius: 999px;
    font-size: 10.5px; font-weight: 600;
    background: var(--bg-surface-hover);
    color: var(--text-secondary);
    line-height: 1.4;
}
.pill-primary { background: rgba(108,92,231,.18); color: #c2bcf4; }
.pill-success { background: rgba(46,204,113,.15); color: #82e6ad; }
.pill-danger  { background: rgba(231,76,60,.15); color: #f5a5a0; }
.pill-warning { background: rgba(243,156,18,.15); color: #f7d794; }
.pill-info    { background: rgba(52,152,219,.15); color: #85c1e9; }

/* ---- Empty state ---- */
.empty-state {
    text-align: center; padding: 56px 20px;
    color: var(--text-secondary);
}
.empty-state .empty-icon {
    font-size: 36px; display: block; margin-bottom: 10px;
    color: var(--text-muted);
}
.empty-state .empty-title {
    font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px;
}
.empty-state .empty-hint { font-size: 12px; color: var(--text-secondary); }

/* ---- Loading inline ---- */
.loading-row td { padding: 24px !important; text-align: center; color: var(--text-secondary); }
.loading-row .spinner-border { margin-right: 8px; }

/* ---- Section navigator (pills) ---- */
.section-nav {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 8px;
}
.section-nav .nav-pills { flex-grow: 1; --bs-nav-pills-border-radius: 999px; }
.section-nav .nav-link { padding: 5px 12px; color: var(--text-secondary); font-size: 12px; border-radius: 999px; }
.section-nav .nav-link:hover { color: var(--text-primary); background: var(--bg-surface-hover); }
.section-nav .nav-link.active { background: var(--accent); color: #fff; }

/* ---- Clickable drill text ---- */
.drill-link { cursor: pointer; }
.drill-link:hover { text-decoration: underline; }

/* ---- Subtle muted helper text ---- */
.subtle { color: var(--text-muted); font-size: 11px; }

/* ---- Sticky toolbar under page header ---- */
.sticky-toolbar {
    position: sticky; top: 0; z-index: 10;
    background: var(--bg-body);
    padding-top: 8px; padding-bottom: 8px;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--border-color);
}

/* ---- Archived / inactive hint ---- */
.is-archived { opacity: .6; }
.is-archived td { text-decoration: line-through; }
.is-archived td:first-child { text-decoration: none; }

/* (Status badge classes are defined earlier in this file.) */

/* ---- Flatpickr date-range control (single input, one popup) ---- */
.date-range-fp {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--bg-surface-2);
    border: 1px solid var(--border-light);
    border-radius: 6px;
    padding: 4px 8px 4px 10px;
    min-height: 30px;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.date-range-fp:focus-within {
    border-color: var(--accent);
    box-shadow: 0 0 0 .15rem var(--accent-soft);
}
.date-range-fp > i {
    color: var(--text-secondary);
    font-size: 13px;
}
.date-range-fp input[type="text"] {
    background: transparent;
    border: none; outline: none;
    color: var(--text-primary);
    font-size: 12.5px;
    padding: 0;
    min-width: 220px;
    cursor: pointer;
}
.date-range-fp input[type="text"]::placeholder { color: var(--text-muted); }
.date-range-fp .fp-clear {
    background: transparent; border: none;
    color: var(--text-muted); padding: 0 4px;
    font-size: 14px; line-height: 1; cursor: pointer;
    border-radius: 4px;
}
.date-range-fp .fp-clear:hover { color: var(--danger); background: rgba(231,76,60,.12); }

/* ---- Flatpickr — polished dark calendar ---- */
.flatpickr-calendar {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-light) !important;
    border-radius: 12px !important;
    box-shadow: 0 18px 48px rgba(0,0,0,.55), 0 2px 8px rgba(0,0,0,.35) !important;
    padding: 10px 10px 12px;
    width: 340px !important;
    overflow: hidden;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}
.flatpickr-calendar.arrowTop:before  { border-bottom-color: var(--border-light) !important; }
.flatpickr-calendar.arrowTop:after   { border-bottom-color: var(--bg-surface) !important; }
.flatpickr-calendar.arrowBottom:before { border-top-color: var(--border-light) !important; }
.flatpickr-calendar.arrowBottom:after  { border-top-color: var(--bg-surface) !important; }

/* Header (month nav) */
.flatpickr-months {
    background: transparent;
    padding: 4px 4px 10px;
    margin-bottom: 4px;
    border-bottom: 1px solid var(--border-color);
}
.flatpickr-months .flatpickr-month {
    color: var(--text-primary);
    fill: var(--text-primary);
    height: 38px;
    line-height: 38px;
}
.flatpickr-current-month {
    font-size: 13px;
    font-weight: 600;
    padding: 6px 0 0;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: transparent;
    color: var(--text-primary);
    font-weight: 600;
    border-radius: 6px;
    padding: 2px 6px;
    transition: background .15s ease;
}
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
    background: var(--bg-surface-hover);
}
.flatpickr-current-month input.cur-year {
    color: var(--text-primary);
    font-weight: 600;
}
.flatpickr-monthDropdown-month {
    background: var(--bg-surface) !important;
    color: var(--text-primary) !important;
}

/* Prev / next arrows */
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    fill: var(--text-secondary);
    padding: 8px;
    border-radius: 8px;
    transition: background .15s ease, color .15s ease;
    top: 4px;
}
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
    background: var(--bg-surface-hover);
    fill: var(--accent);
    color: var(--accent);
}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
    fill: inherit;
    width: 14px; height: 14px;
}

/* Weekdays row */
.flatpickr-weekdays { background: transparent; height: 32px; margin-top: 4px; }
.flatpickr-weekdaycontainer { gap: 0; }
span.flatpickr-weekday {
    color: var(--text-muted) !important;
    background: transparent !important;
    font-size: 10.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* Day cells */
.dayContainer { padding: 2px 0; }
.flatpickr-day {
    color: var(--text-primary);
    background: transparent;
    border: none;
    border-radius: 8px;
    height: 38px; line-height: 38px;
    max-width: 42px; width: 42px;
    margin: 1px 0;
    font-size: 12.5px;
    font-weight: 500;
    transition: background .12s ease, color .12s ease;
}
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
    background: var(--bg-surface-hover);
    color: var(--text-primary);
}
.flatpickr-day.today {
    border: 1px solid var(--accent);
    color: var(--accent);
    font-weight: 600;
}
.flatpickr-day.today:hover { background: var(--bg-surface-hover); color: var(--accent); }

/* Range highlight */
.flatpickr-day.inRange {
    background: var(--accent-soft) !important;
    color: var(--text-primary) !important;
    border-radius: 0;
    box-shadow: none;
}
.flatpickr-day.startRange,
.flatpickr-day.selected.startRange { border-radius: 8px 0 0 8px !important; }
.flatpickr-day.endRange,
.flatpickr-day.selected.endRange { border-radius: 0 8px 8px 0 !important; }
.flatpickr-day.startRange.endRange { border-radius: 8px !important; }
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
    background: var(--accent) !important;
    color: #fff !important;
    font-weight: 600;
    box-shadow: 0 2px 10px rgba(108,92,231,.4) !important;
}

/* Grey out previous/next month days */
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: var(--text-muted);
    opacity: .55;
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover {
    color: var(--text-muted);
    opacity: .25;
    cursor: not-allowed;
    background: transparent !important;
}

/* ---- Service/endpoint icon tiles + status dots ---- */
.service-icon-wrap {
    width: 44px; height: 44px; border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0; font-size: 22px;
}
.status-dot {
    width: 8px; height: 8px; border-radius: 50%;
    display: inline-block;
}
.status-dot-success { background: var(--success); box-shadow: 0 0 6px rgba(46,204,113,.6); }
.status-dot-danger  { background: var(--danger);  box-shadow: 0 0 6px rgba(231,76,60,.6); }
.status-dot-warning { background: var(--warning); box-shadow: 0 0 6px rgba(243,156,18,.6); }
.status-dot-muted   { background: var(--text-muted); }

