/**
 * Invoicio – Professional SaaS Override
 * Loaded after style.css to override the base Kanakku template.
 * Targets: primary colour → professional blue, dark sidebar,
 *          Inter font, polished cards / tables / forms / modals.
 */

/* ─────────────────────────────────────────────────────────────
   0. Google Fonts – Inter
───────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ─────────────────────────────────────────────────────────────
   1. CSS Custom Properties – brand + layout tokens
───────────────────────────────────────────────────────────── */
:root {
    /* Brand */
    --inv-primary:          #2563eb;
    --inv-primary-dark:     #1d4ed8;
    --inv-primary-light:    #dbeafe;
    --inv-primary-rgb:      37, 99, 235;

    /* Sidebar – light */
    --inv-sidebar-bg:       #ffffff;
    --inv-sidebar-border:   #e2e8f0;
    --inv-sidebar-text:     #475569;
    --inv-sidebar-hover:    #f1f5f9;
    --inv-sidebar-active:   #dbeafe;
    --inv-sidebar-icon:     #94a3b8;

    /* Surface / layout */
    --inv-topbar-bg:        #ffffff;
    --inv-topbar-border:    #e2e8f0;
    --inv-body-bg:          #f8fafc;
    --inv-card-bg:          #ffffff;
    --inv-card-border:      #e2e8f0;
    --inv-card-shadow:      0 1px 3px 0 rgba(0,0,0,.07), 0 1px 2px -1px rgba(0,0,0,.07);
    --inv-card-shadow-hover:0 4px 12px 0 rgba(0,0,0,.10);

    /* Typography */
    --inv-font:             'Inter', system-ui, -apple-system, sans-serif;
    --inv-text-primary:     #0f172a;
    --inv-text-secondary:   #475569;
    --inv-text-muted:       #94a3b8;

    /* State colours */
    --inv-success:          #16a34a;
    --inv-warning:          #d97706;
    --inv-danger:           #dc2626;
    --inv-info:             #0891b2;

    /* Radius / spacing */
    --inv-radius-sm:        6px;
    --inv-radius:           10px;
    --inv-radius-lg:        14px;
    --inv-radius-xl:        20px;
}

/* ─────────────────────────────────────────────────────────────
   2. Global – font, body, scrollbar
───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--inv-font) !important;
    background-color: var(--inv-body-bg) !important;
    color: var(--inv-text-primary) !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    -webkit-font-smoothing: antialiased;
}

/* Thin custom scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* ─────────────────────────────────────────────────────────────
   3. Override purple CSS vars with blue
───────────────────────────────────────────────────────────── */
:root {
    --primary:              var(--inv-primary) !important;
    --primary-color:        var(--inv-primary) !important;
    --body-bg:              var(--inv-body-bg) !important;
}

/* ─────────────────────────────────────────────────────────────
   4. Two-column sidebar shell — width increase
   Base template: twocol-mini=60px + sidebar=216px = 276px total
   Invoicio:      twocol-mini=60px + sidebar=250px = 310px total
───────────────────────────────────────────────────────────── */

/* Total sidebar container */
.two-col-sidebar {
    width: 310px !important;
}

/* Text-menu panel */
.two-col-sidebar .sidebar,
#sidebar-two {
    width: 250px !important;
    left: 60px !important;
}

/* Logo strip inside the text panel — must match panel width */
.two-col-sidebar .sidebar .sidebar-logo,
#sidebar-two .sidebar-logo {
    width: 250px !important;
}

/* Push content area to clear the wider sidebar */
.page-wrapper {
    margin-left: 310px !important;
}
@media (max-width: 991.98px) {
    .two-col-sidebar { width: 0 !important; }
    .page-wrapper    { margin-left: 0 !important; }
}

/* Colour/border */
.two-col-sidebar,
.two-col-sidebar .sidebar,
#two-col-sidebar,
#sidebar-two {
    background-color: var(--inv-sidebar-bg) !important;
    border-right: 1px solid var(--inv-sidebar-border) !important;
}

.twocol-mini {
    background-color: #f8fafc !important;
    border-right: 1px solid #e2e8f0 !important;
}

/* Logo area */
.two-col-sidebar .sidebar-logo,
.sidebar .sidebar-logo {
    background-color: var(--inv-sidebar-bg) !important;
    border-bottom: 1px solid var(--inv-sidebar-border) !important;
    padding: 16px 20px !important;
}

/* Toggle button */
.two-col-sidebar #toggle_btn i,
.sidebar #toggle_btn i {
    color: #94a3b8 !important;
}
.two-col-sidebar #toggle_btn:hover i,
.sidebar #toggle_btn:hover i {
    color: var(--inv-primary) !important;
}

/* Search */
.two-col-sidebar .sidebar-search,
.sidebar .sidebar-search {
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--inv-sidebar-border) !important;
}
.two-col-sidebar .sidebar-search .form-control,
.sidebar .sidebar-search .form-control {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
    color: #0f172a !important;
    border-radius: var(--inv-radius) !important;
    font-size: 13px !important;
    box-shadow: none !important;
}
.two-col-sidebar .sidebar-search .form-control::placeholder,
.sidebar .sidebar-search .form-control::placeholder { color: #94a3b8 !important; }
.two-col-sidebar .sidebar-search .input-icon-addon i,
.sidebar .sidebar-search .input-icon-addon i { color: #94a3b8 !important; }

/* ─────────────────────────────────────────────────────────────
   5. Sidebar nav items
   High-specificity rules to beat text-dark and base styles.
───────────────────────────────────────────────────────────── */

/* Container padding */
.two-col-sidebar .sidebar-menu,
.two-col-sidebar #sidebar-menu,
#sidebar-two .sidebar-menu,
#sidebar-two #sidebar-menu {
    padding: 12px 8px !important;
}

/* ── Section (menu-title) labels ── */
.two-col-sidebar .sidebar-menu .menu-title,
.two-col-sidebar .sidebar-menu .sub-title,
#sidebar-two .sidebar-menu .menu-title,
#sidebar-two .sidebar-menu .sub-title {
    color: #475569 !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: .09em !important;
    text-transform: uppercase !important;
    padding: 18px 14px 5px !important;
}
/* The <span> inside menu-title */
.two-col-sidebar .sidebar-menu .menu-title span,
#sidebar-two .sidebar-menu .menu-title span {
    color: #475569 !important;
}

/* ── All nav links – default state ── */
.two-col-sidebar .sidebar-menu ul li > a,
#sidebar-two .sidebar-menu ul li > a,
.two-col-sidebar #sidebar-menu ul li > a,
#sidebar-two #sidebar-menu ul li > a {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 9px 14px !important;
    border-radius: var(--inv-radius-sm) !important;
    color: #475569 !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: background 0.15s, color 0.15s !important;
    margin-bottom: 2px !important;
    background: transparent !important;
    white-space: nowrap !important;   /* never wrap onto a second line */
    overflow: hidden !important;
}

/* ── Icons – override text-dark and any inline colour ── */
.two-col-sidebar .sidebar-menu ul li > a i,
#sidebar-two .sidebar-menu ul li > a i,
.two-col-sidebar #sidebar-menu ul li > a i,
#sidebar-two #sidebar-menu ul li > a i,
.two-col-sidebar .sidebar-menu ul li > a i.text-dark,
#sidebar-two .sidebar-menu ul li > a i.text-dark,
.two-col-sidebar #sidebar-menu ul li > a i.text-dark,
#sidebar-two #sidebar-menu ul li > a i.text-dark {
    color: #94a3b8 !important;
    font-size: 18px !important;
    flex-shrink: 0;
    width: 20px;
    text-align: center;
    transition: color 0.15s !important;
}

/* ── Hover ── */
.two-col-sidebar .sidebar-menu ul li > a:hover,
#sidebar-two .sidebar-menu ul li > a:hover,
.two-col-sidebar #sidebar-menu ul li > a:hover,
#sidebar-two #sidebar-menu ul li > a:hover {
    background: #f1f5f9 !important;
    color: #0f172a !important;
}
.two-col-sidebar .sidebar-menu ul li > a:hover i,
#sidebar-two .sidebar-menu ul li > a:hover i,
.two-col-sidebar #sidebar-menu ul li > a:hover i,
#sidebar-two #sidebar-menu ul li > a:hover i,
.two-col-sidebar .sidebar-menu ul li > a:hover i.text-dark,
#sidebar-two .sidebar-menu ul li > a:hover i.text-dark,
.two-col-sidebar #sidebar-menu ul li > a:hover i.text-dark,
#sidebar-two #sidebar-menu ul li > a:hover i.text-dark {
    color: var(--inv-primary) !important;
}

/* ── Active / current page ── */
.two-col-sidebar .sidebar-menu ul li.active > a,
#sidebar-two .sidebar-menu ul li.active > a,
.two-col-sidebar #sidebar-menu ul li.active > a,
#sidebar-two #sidebar-menu ul li.active > a {
    background: #dbeafe !important;
    color: var(--inv-primary) !important;
    font-weight: 600 !important;
}
.two-col-sidebar .sidebar-menu ul li.active > a i,
#sidebar-two .sidebar-menu ul li.active > a i,
.two-col-sidebar #sidebar-menu ul li.active > a i,
#sidebar-two #sidebar-menu ul li.active > a i,
.two-col-sidebar .sidebar-menu ul li.active > a i.text-dark,
#sidebar-two .sidebar-menu ul li.active > a i.text-dark,
.two-col-sidebar #sidebar-menu ul li.active > a i.text-dark,
#sidebar-two #sidebar-menu ul li.active > a i.text-dark {
    color: var(--inv-primary) !important;
}

/* ── Submenu links ── */
.two-col-sidebar .sidebar-menu ul li ul li > a,
#sidebar-two .sidebar-menu ul li ul li > a,
.two-col-sidebar #sidebar-menu ul li ul li > a,
#sidebar-two #sidebar-menu ul li ul li > a {
    padding: 7px 14px 7px 42px !important;
    font-size: 13px !important;
    color: #64748b !important;
}
.two-col-sidebar .sidebar-menu ul li ul li.active > a,
#sidebar-two .sidebar-menu ul li ul li.active > a,
.two-col-sidebar #sidebar-menu ul li ul li.active > a,
#sidebar-two #sidebar-menu ul li ul li.active > a {
    color: var(--inv-primary) !important;
    background: transparent !important;
    font-weight: 600 !important;
}

/* menu-arrow chevron */
.two-col-sidebar .sidebar-menu .menu-arrow,
#sidebar-two .sidebar-menu .menu-arrow {
    color: #cbd5e1 !important;
    margin-left: auto !important;
}

/* ── Sidebar footer quick-links ── */
.two-col-sidebar .sidebar-footer .menu-list li a,
#sidebar-two .sidebar-footer .menu-list li a {
    color: #94a3b8 !important;
    border-radius: var(--inv-radius-sm) !important;
    transition: background 0.15s, color 0.15s !important;
    padding: 8px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}
.two-col-sidebar .sidebar-footer .menu-list li a:hover,
#sidebar-two .sidebar-footer .menu-list li a:hover {
    background: #f1f5f9 !important;
    color: var(--inv-primary) !important;
}
.two-col-sidebar .sidebar-footer .menu-list li a i,
#sidebar-two .sidebar-footer .menu-list li a i {
    color: inherit !important;
}

/* ── Twocol-mini icon strip ── */
.twocol-mini {
    background-color: #f8fafc !important;
    border-right: 1px solid #e2e8f0 !important;
}
.twocol-mini .menu-list li a {
    color: #94a3b8 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px;
    height: 40px;
    border-radius: var(--inv-radius-sm) !important;
    margin: 4px auto !important;
    transition: background 0.15s, color 0.15s !important;
}
.twocol-mini .menu-list li a:hover {
    background: #e2e8f0 !important;
    color: var(--inv-primary) !important;
}
.twocol-mini .menu-list li a i,
.twocol-mini .menu-list li a i.text-dark {
    color: inherit !important;
    font-size: 18px !important;
}

/* ─────────────────────────────────────────────────────────────
   5b. Neutralise .text-dark inside the sidebar – hardcoded on
       every icon in the blade files; would show near-black icons.
───────────────────────────────────────────────────────────── */
.two-col-sidebar .text-dark,
#two-col-sidebar .text-dark,
#sidebar-two .text-dark,
.sidebar .text-dark {
    color: #94a3b8 !important;   /* muted slate on white sidebar */
}
.two-col-sidebar a:hover .text-dark,
#sidebar-two a:hover .text-dark,
.sidebar a:hover .text-dark {
    color: var(--inv-primary) !important;
}
.two-col-sidebar li.active > a .text-dark,
#sidebar-two li.active > a .text-dark,
.sidebar li.active > a .text-dark {
    color: var(--inv-primary) !important;
}

/* ─────────────────────────────────────────────────────────────
   6. Header / Topbar
───────────────────────────────────────────────────────────── */
.header,
.top-bar,
[class*="header-"] {
    background: var(--inv-topbar-bg) !important;
    border-bottom: 1px solid var(--inv-topbar-border) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.04) !important;
}

.header .header-left,
.header .header-right {
    background: transparent !important;
}

/* Page title in header */
.page-title,
.breadcrumb-item.active,
h4.page-title { color: var(--inv-text-primary) !important; font-weight: 600 !important; }

/* Breadcrumb */
.breadcrumb-item a { color: var(--inv-primary) !important; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--inv-text-muted) !important; }

/* ─────────────────────────────────────────────────────────────
   7. Main content area
───────────────────────────────────────────────────────────── */
.page-wrapper,
.content,
.main-wrapper {
    background: var(--inv-body-bg) !important;
}

.content-page,
.page-content {
    padding: 24px !important;
}

/* ─────────────────────────────────────────────────────────────
   8. Cards
───────────────────────────────────────────────────────────── */
.card {
    background: var(--inv-card-bg) !important;
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius-lg) !important;
    box-shadow: var(--inv-card-shadow) !important;
    transition: box-shadow 0.2s !important;
}
.card:hover { box-shadow: var(--inv-card-shadow-hover) !important; }

.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--inv-card-border) !important;
    padding: 16px 20px !important;
    font-weight: 600 !important;
    color: var(--inv-text-primary) !important;
}

.card-body { padding: 20px !important; }

.card-footer {
    background: transparent !important;
    border-top: 1px solid var(--inv-card-border) !important;
    padding: 12px 20px !important;
}

/* KPI / stat cards */
.card.dash-widget,
.card.stat-card {
    border-radius: var(--inv-radius-lg) !important;
}

/* ─────────────────────────────────────────────────────────────
   9. Buttons
───────────────────────────────────────────────────────────── */
.btn {
    font-family: var(--inv-font) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    border-radius: var(--inv-radius-sm) !important;
    padding: 8px 18px !important;
    transition: all 0.18s !important;
    letter-spacing: 0.01em !important;
}

.btn-primary,
.btn-primary:focus {
    background-color: var(--inv-primary) !important;
    border-color: var(--inv-primary) !important;
    color: #fff !important;
    box-shadow: 0 1px 4px rgba(37,99,235,.3) !important;
}
.btn-primary:hover,
.btn-primary:active {
    background-color: var(--inv-primary-dark) !important;
    border-color: var(--inv-primary-dark) !important;
    box-shadow: 0 2px 8px rgba(37,99,235,.4) !important;
}

.btn-outline-primary {
    color: var(--inv-primary) !important;
    border-color: var(--inv-primary) !important;
}
.btn-outline-primary:hover {
    background-color: var(--inv-primary) !important;
    color: #fff !important;
}

.btn-light {
    background: #f1f5f9 !important;
    border-color: #e2e8f0 !important;
    color: var(--inv-text-primary) !important;
}
.btn-light:hover {
    background: #e2e8f0 !important;
}

.btn-sm {
    padding: 5px 12px !important;
    font-size: 12.5px !important;
}

.btn-icon {
    padding: 7px !important;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* bg-gradient override */
.btn.bg-gradient {
    background-image: none !important;
    background-color: var(--inv-primary) !important;
}

/* ─────────────────────────────────────────────────────────────
   10. Badges
───────────────────────────────────────────────────────────── */
.badge {
    font-family: var(--inv-font) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    border-radius: var(--inv-radius-sm) !important;
    padding: 3px 8px !important;
    letter-spacing: 0.02em !important;
}
.badge.bg-primary { background-color: var(--inv-primary) !important; }
.badge.bg-success { background-color: var(--inv-success) !important; }
.badge.bg-warning { background-color: var(--inv-warning) !important; }
.badge.bg-danger  { background-color: var(--inv-danger)  !important; }
.badge.bg-info    { background-color: var(--inv-info)    !important; }

/* Soft badges */
.badge-soft-primary { background: var(--inv-primary-light) !important; color: var(--inv-primary) !important; }
.badge-soft-success { background: #dcfce7 !important; color: #16a34a !important; }
.badge-soft-warning { background: #fef3c7 !important; color: #d97706 !important; }
.badge-soft-danger  { background: #fee2e2 !important; color: #dc2626 !important; }
.badge-soft-info    { background: #e0f2fe !important; color: #0891b2 !important; }

/* ─────────────────────────────────────────────────────────────
   11. Tables
───────────────────────────────────────────────────────────── */
.table {
    font-size: 13.5px !important;
    color: var(--inv-text-primary) !important;
    border-color: var(--inv-card-border) !important;
}

.table > thead > tr > th {
    background: #f8fafc !important;
    color: var(--inv-text-secondary) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
    border-bottom: 1px solid var(--inv-card-border) !important;
    padding: 12px 16px !important;
    white-space: nowrap;
}

.table > tbody > tr > td {
    padding: 12px 16px !important;
    vertical-align: middle !important;
    border-color: #f1f5f9 !important;
    color: var(--inv-text-primary) !important;
}

.table > tbody > tr:hover > td {
    background: #f8fafc !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > td {
    background: #fafbfc !important;
}

/* DataTables wrapper */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    border: 1px solid #e2e8f0 !important;
    border-radius: var(--inv-radius-sm) !important;
    padding: 6px 10px !important;
    font-size: 13px !important;
    color: var(--inv-text-primary) !important;
    background: #fff !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: var(--inv-primary) !important;
    color: #fff !important;
    border-color: var(--inv-primary) !important;
    border-radius: var(--inv-radius-sm) !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--inv-primary-light) !important;
    color: var(--inv-primary) !important;
    border-color: transparent !important;
    border-radius: var(--inv-radius-sm) !important;
}

/* ─────────────────────────────────────────────────────────────
   12. Forms
───────────────────────────────────────────────────────────── */
.form-control,
.form-select {
    font-family: var(--inv-font) !important;
    font-size: 13.5px !important;
    color: var(--inv-text-primary) !important;
    background: #ffffff !important;
    border: 1px solid #d1d5db !important;
    border-radius: var(--inv-radius-sm) !important;
    padding: 9px 14px !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
    box-shadow: none !important;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--inv-primary) !important;
    box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important;
    outline: none !important;
}

.form-control::placeholder { color: #9ca3af !important; }

.form-label {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--inv-text-secondary) !important;
    margin-bottom: 6px !important;
}

.input-group-text {
    background: #f8fafc !important;
    border-color: #d1d5db !important;
    color: var(--inv-text-secondary) !important;
    font-size: 13.5px !important;
}

/* Select2 */
.select2-container--default .select2-selection--single {
    border: 1px solid #d1d5db !important;
    border-radius: var(--inv-radius-sm) !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    font-size: 13.5px !important;
    color: var(--inv-text-primary) !important;
    padding-left: 14px !important;
    line-height: normal !important;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--inv-primary) !important;
    box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important;
}
.select2-dropdown {
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.12) !important;
    font-size: 13.5px !important;
}
.select2-container--default .select2-results__option--highlighted {
    background: var(--inv-primary) !important;
}

/* ─────────────────────────────────────────────────────────────
   13. Modals
───────────────────────────────────────────────────────────── */
.modal-content {
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius-lg) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,.18) !important;
    overflow: hidden;
}

.modal-header {
    background: #f8fafc !important;
    border-bottom: 1px solid var(--inv-card-border) !important;
    padding: 18px 24px !important;
}

.modal-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--inv-text-primary) !important;
}

.modal-body { padding: 24px !important; }

.modal-footer {
    background: #f8fafc !important;
    border-top: 1px solid var(--inv-card-border) !important;
    padding: 14px 24px !important;
}

/* ─────────────────────────────────────────────────────────────
   14. Dropdown menus
───────────────────────────────────────────────────────────── */
.dropdown-menu {
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
    padding: 6px !important;
    min-width: 180px;
}

.dropdown-item {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--inv-text-secondary) !important;
    border-radius: var(--inv-radius-sm) !important;
    padding: 8px 12px !important;
    transition: background 0.12s, color 0.12s !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: var(--inv-primary-light) !important;
    color: var(--inv-primary) !important;
}

.dropdown-item.text-danger:hover { background: #fee2e2 !important; color: var(--inv-danger) !important; }

.dropdown-divider { border-color: var(--inv-card-border) !important; margin: 4px 0 !important; }

/* ─────────────────────────────────────────────────────────────
   15. Alerts
───────────────────────────────────────────────────────────── */
.alert {
    border-radius: var(--inv-radius) !important;
    border: none !important;
    font-size: 13.5px !important;
    padding: 14px 18px !important;
}
.alert-primary  { background: var(--inv-primary-light) !important; color: var(--inv-primary-dark) !important; }
.alert-success  { background: #dcfce7 !important; color: #15803d !important; }
.alert-warning  { background: #fef3c7 !important; color: #b45309 !important; }
.alert-danger   { background: #fee2e2 !important; color: #b91c1c !important; }
.alert-info     { background: #e0f2fe !important; color: #0369a1 !important; }

/* ─────────────────────────────────────────────────────────────
   16. Nav tabs / pills
───────────────────────────────────────────────────────────── */
.nav-tabs {
    border-bottom: 2px solid var(--inv-card-border) !important;
    gap: 4px;
}
.nav-tabs .nav-link {
    border: none !important;
    border-radius: var(--inv-radius-sm) var(--inv-radius-sm) 0 0 !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: var(--inv-text-secondary) !important;
    padding: 10px 16px !important;
    transition: color 0.15s, background 0.15s !important;
}
.nav-tabs .nav-link:hover {
    color: var(--inv-primary) !important;
    background: var(--inv-primary-light) !important;
}
.nav-tabs .nav-link.active {
    color: var(--inv-primary) !important;
    border-bottom: 2px solid var(--inv-primary) !important;
    background: transparent !important;
    font-weight: 600 !important;
}

.nav-pills .nav-link {
    border-radius: var(--inv-radius-sm) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: var(--inv-text-secondary) !important;
    padding: 8px 16px !important;
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: var(--inv-primary) !important;
    color: #fff !important;
}

/* ─────────────────────────────────────────────────────────────
   17. Pagination
───────────────────────────────────────────────────────────── */
.pagination { gap: 3px; }
.page-link {
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius-sm) !important;
    color: var(--inv-text-secondary) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 6px 12px !important;
    transition: all 0.15s !important;
}
.page-link:hover {
    background: var(--inv-primary-light) !important;
    color: var(--inv-primary) !important;
    border-color: var(--inv-primary-light) !important;
}
.page-item.active .page-link {
    background: var(--inv-primary) !important;
    border-color: var(--inv-primary) !important;
    color: #fff !important;
}

/* ─────────────────────────────────────────────────────────────
   18. Headings & typography
───────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--inv-font) !important;
    font-weight: 700 !important;
    color: var(--inv-text-primary) !important;
}

.text-primary { color: var(--inv-primary) !important; }
.text-muted   { color: var(--inv-text-muted) !important; }

a { color: var(--inv-primary) !important; }
a:hover { color: var(--inv-primary-dark) !important; }

/* ─────────────────────────────────────────────────────────────
   19. Status / priority badge helpers
───────────────────────────────────────────────────────────── */
.badge-status-paid,
.badge-paid    { background: #dcfce7 !important; color: #16a34a !important; }
.badge-status-unpaid,
.badge-unpaid  { background: #fee2e2 !important; color: #dc2626 !important; }
.badge-status-partial,
.badge-partial { background: #fef3c7 !important; color: #d97706 !important; }
.badge-status-draft,
.badge-draft   { background: #f1f5f9 !important; color: #475569 !important; }
.badge-status-overdue,
.badge-overdue { background: #fff7ed !important; color: #ea580c !important; }

/* ─────────────────────────────────────────────────────────────
   20. Dashboard KPI cards
───────────────────────────────────────────────────────────── */
.kpi-card {
    border-radius: var(--inv-radius-lg) !important;
    padding: 20px !important;
}

.kpi-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--inv-radius) !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}

.kpi-icon.blue   { background: var(--inv-primary-light); color: var(--inv-primary); }
.kpi-icon.green  { background: #dcfce7; color: #16a34a; }
.kpi-icon.yellow { background: #fef3c7; color: #d97706; }
.kpi-icon.red    { background: #fee2e2; color: #dc2626; }
.kpi-icon.cyan   { background: #e0f2fe; color: #0891b2; }
.kpi-icon.purple { background: #ede9fe; color: #7c3aed; }

.kpi-label {
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--inv-text-muted) !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
}

.kpi-value {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--inv-text-primary) !important;
    line-height: 1.2 !important;
}

/* ─────────────────────────────────────────────────────────────
   21. Page header / title row
───────────────────────────────────────────────────────────── */
.page-header {
    margin-bottom: 20px !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

.page-header h4,
.page-header h3,
.page-header .page-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--inv-text-primary) !important;
    margin: 0 !important;
}

/* ─────────────────────────────────────────────────────────────
   22. Notification bell & header icons
───────────────────────────────────────────────────────────── */

/* ── Bell trigger button ── */
.inv-bell-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: var(--inv-radius-sm);
    background: transparent;
    border: none;
    color: #475569;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    cursor: pointer;
}
.inv-bell-btn:hover,
.inv-bell-btn:focus,
.inv-bell-btn[aria-expanded="true"] {
    background: #f1f5f9;
    color: var(--inv-primary);
    outline: none;
    text-decoration: none;
}
.inv-bell-btn i {
    color: inherit;
    line-height: 1;
}

/* ── Unread count badge ── */
.inv-bell-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: #dc2626;
    color: #ffffff;
    font-family: var(--inv-font);
    font-size: 10px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    border-radius: 99px;
    border: 2px solid #ffffff;
    box-shadow: 0 1px 4px rgba(220,38,38,.4);
    pointer-events: none;
}

/* ── Dropdown panel ── */
.inv-notif-panel {
    width: 360px !important;
    border: 1px solid var(--inv-card-border) !important;
    border-radius: var(--inv-radius-lg) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,.12) !important;
    overflow: hidden;
    padding: 0 !important;
}

/* ── Notification list items (rendered by JS) ── */
.inv-notif-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 12px 16px;
    border-bottom: 1px solid #f1f5f9;
    transition: background 0.12s;
    cursor: pointer;
    text-decoration: none;
}
.inv-notif-item:hover { background: #f8fafc; }
.inv-notif-item.unread { background: #eff6ff; }
.inv-notif-item:last-child { border-bottom: none; }

.inv-notif-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--inv-primary-light);
    color: var(--inv-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.inv-notif-title {
    font-size: 13px;
    font-weight: 600;
    color: #0f172a;
    margin: 0 0 2px;
}
.inv-notif-body {
    font-size: 12.5px;
    color: #475569;
    margin: 0 0 4px;
    line-height: 1.4;
}
.inv-notif-time {
    font-size: 11px;
    color: #94a3b8;
}

/* keep old notification-item styling functional */
.header .notification-icon,
.header .header-icon {
    color: var(--inv-text-secondary) !important;
    background: transparent !important;
    border-radius: var(--inv-radius-sm) !important;
    transition: background 0.15s !important;
}
.header .notification-icon:hover,
.header .header-icon:hover {
    background: var(--inv-primary-light) !important;
    color: var(--inv-primary) !important;
}

/* ─────────────────────────────────────────────────────────────
   23. Impersonation banner
───────────────────────────────────────────────────────────── */
#impersonation-banner {
    background: linear-gradient(90deg, #b45309, #d97706) !important;
    color: #fff !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    letter-spacing: .01em !important;
}

/* ─────────────────────────────────────────────────────────────
   24. Support ticket thread
───────────────────────────────────────────────────────────── */
.message-bubble {
    border-radius: var(--inv-radius-lg) !important;
    padding: 14px 18px !important;
    max-width: 75%;
}
.message-bubble.admin {
    background: var(--inv-primary-light) !important;
    border: 1px solid #bfdbfe !important;
}
.message-bubble.user {
    background: #f8fafc !important;
    border: 1px solid var(--inv-card-border) !important;
}

/* ─────────────────────────────────────────────────────────────
   25. Progress bars
───────────────────────────────────────────────────────────── */
.progress {
    height: 6px !important;
    border-radius: 99px !important;
    background: #e2e8f0 !important;
    overflow: hidden;
}
.progress-bar {
    border-radius: 99px !important;
    background: var(--inv-primary) !important;
}
.progress-bar.bg-success { background: var(--inv-success) !important; }
.progress-bar.bg-warning { background: var(--inv-warning) !important; }
.progress-bar.bg-danger  { background: var(--inv-danger) !important; }

/* ─────────────────────────────────────────────────────────────
   26. Avatars / user icons
───────────────────────────────────────────────────────────── */
.avatar,
.user-img {
    border-radius: 50% !important;
    object-fit: cover;
}

.avatar-sm { width: 32px; height: 32px; font-size: 13px; }
.avatar-md { width: 40px; height: 40px; font-size: 15px; }
.avatar-lg { width: 56px; height: 56px; font-size: 20px; }

/* Initials avatar */
.avatar-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-weight: 700;
    background: var(--inv-primary-light);
    color: var(--inv-primary);
}

/* ─────────────────────────────────────────────────────────────
   27. Invoice / quote detail layout
───────────────────────────────────────────────────────────── */
.invoice-box {
    background: #fff;
    border: 1px solid var(--inv-card-border);
    border-radius: var(--inv-radius-lg);
    padding: 32px;
    box-shadow: var(--inv-card-shadow);
}

/* ─────────────────────────────────────────────────────────────
   28. Auth pages (login / register)
───────────────────────────────────────────────────────────── */
.login-wrapper,
.register-wrapper,
.auth-wrapper {
    background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 100%) !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-content,
.auth-card {
    background: #fff !important;
    border-radius: var(--inv-radius-xl) !important;
    box-shadow: 0 24px 64px rgba(0,0,0,.22) !important;
    padding: 40px !important;
}

/* ─────────────────────────────────────────────────────────────
   29. Utility / misc
───────────────────────────────────────────────────────────── */
.border { border-color: var(--inv-card-border) !important; }
.border-top    { border-top-color:    var(--inv-card-border) !important; }
.border-bottom { border-bottom-color: var(--inv-card-border) !important; }
.border-start  { border-left-color:   var(--inv-card-border) !important; }
.border-end    { border-right-color:  var(--inv-card-border) !important; }

hr { border-color: var(--inv-card-border) !important; opacity: 1 !important; }

.rounded    { border-radius: var(--inv-radius) !important; }
.rounded-lg { border-radius: var(--inv-radius-lg) !important; }
.rounded-xl { border-radius: var(--inv-radius-xl) !important; }

/* SweetAlert2 override to use Inter */
.swal2-popup {
    font-family: var(--inv-font) !important;
    border-radius: var(--inv-radius-lg) !important;
}
.swal2-confirm {
    background-color: var(--inv-primary) !important;
    border-radius: var(--inv-radius-sm) !important;
}
.swal2-confirm:hover { background-color: var(--inv-primary-dark) !important; }

/* ─────────────────────────────────────────────────────────────
   30. Responsive tweaks
───────────────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
    .content-page,
    .page-content { padding: 16px !important; }

    .kpi-value { font-size: 20px !important; }
}

@media (max-width: 575.98px) {
    .card-body { padding: 14px !important; }
    .modal-body { padding: 16px !important; }
    .btn { padding: 7px 14px !important; }
}
