/* ============================================================
   Super Admin Panel Theme — YogaCRM brand
   Scoped to super-admin views only (loaded from
   resources/views/super-admin/partials/styles.blade.php).
   Do NOT load this on the business/tenant side.
   ============================================================ */

:root,
[data-bs-theme=light] {
    /* YogaCRM Super Admin — Modern Black palette */
    --sa-primary:        #111111;   /* Modern black */
    --sa-primary-dark:   #000000;
    --sa-primary-light:  #333333;
    --sa-secondary:      #1f1f1f;   /* Near-black charcoal */
    --sa-accent:         #2a2a2a;
    --sa-bg:             #fafafa;
    --sa-border:         #e5e5e5;

    /* Override Bootstrap primary so existing components pick it up */
    --bs-primary:        #111111;
    --bs-primary-rgb:    17, 17, 17;
    --sa-primary-rgb:    17, 17, 17;
    --bs-primary-color:  #111111;
    --bs-primary-bg-subtle: #f2f2f2;
    --bs-primary-text-emphasis: #000000;

    --bs-secondary:      #1f1f1f;
    --bs-secondary-rgb:  31, 31, 31;
    --bs-secondary-color:#1f1f1f;

    --bs-link-color:     #111111;
    --bs-link-hover-color:#000000;

    /* Layout sizing tokens */
    --sa-topbar-h: 60px;
    --sa-sidebar-w: 230px;
    --sa-sidebar-mini-w: 72px;
}

/* ---------- Topbar (shrink + light theme) ---------- */
.topbar,
.topbar.bg-primary {
    min-height: var(--sa-topbar-h) !important;
    background-color: #ffffff !important;
    border-bottom: 1px solid var(--sa-border) !important;
}
.topbar .navbar .navbar-nav .nav-item .nav-link,
.topbar.bg-primary .navbar .navbar-nav .nav-item .nav-link {
    color: var(--sa-secondary) !important;
}
.topbar .nav-link iconify-icon {
    color: var(--sa-secondary);
}
.topbar .nav-link:hover iconify-icon,
.topbar .nav-link:focus iconify-icon {
    color: var(--sa-primary) !important;
}
.topbar .navbar .nav-icon-hover-bg:hover,
.topbar .navbar .nav-link:hover {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
  border-radius: 60px;
}
.topbar .navbar {
    min-height: var(--sa-topbar-h) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.topbar .navbar .navbar-nav .nav-item .nav-link {
    margin: 6px 0 !important;
    padding: 6px 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
}
.topbar .navbar-brand,
.topbar .logo-img {
    min-height: var(--sa-topbar-h);
    display: flex;
    align-items: center;
}
.topbar .logo-img img {
    height: 40px !important;
    max-height: 40px !important;
    width: auto;
}
.topbar .navbar .nav-icon-hover-bg {
    padding: 4px !important;
}
.topbar .nav-link iconify-icon {
    font-size: 1.5rem !important;
}
.topbar .navbar .badge-number,
.topbar .navbar .notification-count,
.topbar .navbar .supeNotification,
.topbar .navbar .badge-number-chat {
    inset: -4px auto auto 18px !important;
    top: 0 !important;
    left: 22px !important;
    font-size: 10px !important;
    padding: 2px 5px !important;
}

/* Push the sidebar back up under the smaller topbar */
[data-layout=vertical] .link-sidebar .left-sidebar {
    border-right: 1px solid var(--sa-border);
    top: var(--sa-topbar-h) !important;
}

/* ---------- Sidebar (shrink width) ---------- */
@media (min-width: 1100px) {
    [data-layout=vertical] .link-sidebar .left-sidebar {
        width: var(--sa-sidebar-w) !important;
    }
    [data-layout=vertical] .link-sidebar .page-wrapper {
        margin-left: var(--sa-sidebar-w) !important;
    }
    [data-layout=vertical] .link-sidebar .topbar {
        left: var(--sa-sidebar-w) !important;
        width: calc(100% - var(--sa-sidebar-w)) !important;
    }
    html[data-layout=vertical] [data-sidebartype=mini-sidebar].link-sidebar .left-sidebar {
        width: var(--sa-sidebar-mini-w) !important;
    }
    html[data-layout=vertical] [data-sidebartype=mini-sidebar].link-sidebar .page-wrapper {
        margin-left: var(--sa-sidebar-mini-w) !important;
    }
}

.sidebar-nav ul .sidebar-item .sidebar-link {
    font-size: 14px !important;
    font-weight: 500 !important;
    padding: 8px 12px !important;
    border-radius: 6px;
    color: var(--sa-secondary);
}
.sidebar-nav ul .sidebar-item .sidebar-link iconify-icon {
    font-size: 1.35rem !important;
}
@media (min-width: 1440px) {
    .sidebar-nav ul .sidebar-item .sidebar-link,
    .topbar .navbar .navbar-nav .nav-item .nav-link {
        font-size: 14px !important;
    }
}
.sidebar-nav ul .sidebar-item > .sidebar-link.active,
.sidebar-nav ul .sidebar-item.selected > .sidebar-link {
    color: var(--sa-primary) !important;
    background-color: var(--bs-primary-bg-subtle) !important;
    border-right: 3px solid var(--sa-primary) !important;
    font-weight: 600 !important;
}
.sidebar-nav ul .sidebar-item .sidebar-link:hover {
    background-color: var(--bs-primary-bg-subtle);
    color: var(--sa-primary-dark);
}
.nav-small-cap {
    font-size: 11px !important;
    padding: 10px 12px 4px !important;
    color: var(--sa-secondary);
    opacity: .7;
}

/* ---------- Sidebar collapsible groups ---------- */
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow {
    display: flex;
    align-items: center;
    position: relative;
}
/* Kill the template's built-in ::after chevron — we render our own iconify chevron */
.sidebar-nav .has-arrow::after,
.sidebar-nav li.active > .has-arrow::after,
.sidebar-nav li > .has-arrow.active::after,
.sidebar-nav .has-arrow[aria-expanded="true"]::after {
    content: none !important;
    display: none !important;
    border: 0 !important;
}

/* Chevron icon injected via JS — see main-menuSidebar.blade.php */
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow .sa-arrow {
    margin-left: auto;
    font-size: 1rem !important;
    color: #5e6b5e;
    transition: transform .25s ease, color .15s ease;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow[aria-expanded="true"] .sa-arrow {
    transform: rotate(180deg);
    color: var(--sa-primary);
}
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow:hover .sa-arrow {
    color: var(--sa-primary);
}
/* The parent icon should sit fixed-size so the chevron lands flush right */
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow > iconify-icon:first-child {
    margin-right: 8px;
}
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.active-parent {
    color: var(--sa-primary) !important;
    background-color: var(--bs-primary-bg-subtle);
    border-radius: 6px;
    font-weight: 600;
}
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.active-parent iconify-icon {
    color: var(--sa-primary) !important;
}

/* Group parent should NOT show the right-border active state (only leaf items do) */
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow.active,
.sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow {
    border-right: 0 !important;
}

/* Submenu list */
.sa-submenu {
    list-style: none;
    padding-left: 0 !important;
    margin: 4px 0 6px !important;
    position: relative;
}
.sa-submenu::before {
    content: "";
    position: absolute;
    left: 22px;
    top: 4px;
    bottom: 4px;
    width: 1px;
    background-color: var(--sa-border);
}
.sa-submenu .sidebar-item {
  margin: 1px 0 1px 50px;
}
.sa-submenu .sidebar-link {
    padding: 7px 12px 7px 38px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    border-radius: 6px;
    position: relative;
}
.sa-submenu .sidebar-link iconify-icon {
    display: none !important;
}
.sa-submenu .sidebar-link.active {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary) !important;
    border-right: 3px solid var(--sa-primary) !important;
    font-weight: 600 !important;
}
.sa-submenu .sidebar-link.active iconify-icon {
    color: var(--sa-primary) !important;
}
.sa-submenu .sidebar-link:hover {
    background-color: rgba(var(--sa-primary-rgb), .06);
    color: var(--sa-primary-dark);
}

/* Hide arrow and submenu in mini-sidebar (collapsed) mode */
[data-sidebartype=mini-sidebar].link-sidebar .sidebar-nav ul .sidebar-item.sa-group > .sidebar-link.has-arrow::after,
[data-sidebartype=mini-sidebar].link-sidebar .sa-submenu {
    display: none !important;
}

/* ---------- Buttons / accents ----------
   The template's bootstrap.min.css scopes button colors with high specificity
   like `[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-primary`.
   We mirror that specificity so our theme wins without resorting to !important. */
[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-primary,
[data-bs-theme=dark][data-color-theme=Blue_Theme]:root .btn-primary,
:root .btn-primary,
.btn-primary {
    --bs-btn-bg: var(--sa-primary);
    --bs-btn-border-color: var(--sa-primary);
    --bs-btn-color: #ffffff;
    --bs-btn-hover-bg: #3a3a3a;
    --bs-btn-hover-border-color: #3a3a3a;
    --bs-btn-hover-color: #ffffff;
    --bs-btn-active-bg: #000000;
    --bs-btn-active-border-color: #000000;
    --bs-btn-disabled-bg: var(--sa-primary);
    --bs-btn-disabled-border-color: var(--sa-primary);
    --bs-btn-focus-shadow-rgb: 17, 17, 17;
}
[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-outline-primary,
:root .btn-outline-primary,
.btn-outline-primary {
    --bs-btn-color: var(--sa-primary);
    --bs-btn-border-color: var(--sa-primary);
    --bs-btn-hover-bg: var(--sa-primary);
    --bs-btn-hover-border-color: var(--sa-primary);
    --bs-btn-hover-color: #ffffff;
    --bs-btn-active-bg: var(--sa-primary);
    --bs-btn-active-border-color: var(--sa-primary);
}
[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-secondary,
:root .btn-secondary,
.btn-secondary {
    --bs-btn-bg: var(--sa-secondary);
    --bs-btn-border-color: var(--sa-secondary);
    --bs-btn-color: #ffffff;
    --bs-btn-hover-bg: #1a1a1a;
    --bs-btn-hover-border-color: #1a1a1a;
}
[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-success,
:root .btn-success,
.btn-success {
    --bs-btn-bg: var(--sa-primary);
    --bs-btn-border-color: var(--sa-primary);
    --bs-btn-color: #ffffff;
    --bs-btn-hover-bg: var(--sa-primary-dark);
    --bs-btn-hover-border-color: var(--sa-primary-dark);
    --bs-btn-disabled-bg: var(--sa-primary);
    --bs-btn-disabled-border-color: var(--sa-primary);
    --bs-btn-active-color:  #ffffff;
    --bs-btn-active-bg: var(--sa-primary-dark);
    --bs-btn-active-border-color: var(--sa-primary-dark);
    --bs-btn-disabled-color: #fff;
}
[data-bs-theme=light][data-color-theme=Blue_Theme]:root .btn-info,
:root .btn-info,
.btn-info {
    --bs-btn-bg: var(--sa-accent);
    --bs-btn-border-color: var(--sa-accent);
    --bs-btn-color: #ffffff;
    --bs-btn-hover-bg: #3f7322;
    --bs-btn-hover-border-color: #3f7322;
}
.bg-primary { background-color: var(--sa-primary) !important; }
.text-primary { color: var(--sa-primary) !important; }
.bg-secondary { background-color: var(--sa-secondary) !important; }

/* Nav-link hover override (was hardcoded purple in styles.blade.php) */
.nav-link:hover {
    background: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
}

/* Body wrapper — clean white background, tighter side spacing */
.body-wrapper {
    background-color: #ffffff !important;
    padding: 16px 0 !important;
    margin-top: 59px;
    margin-left: 16px;
    margin-right: 16px;
}
.body-wrapper > .container-fluid,
.body-wrapper .container-fluid.mw-100 {
    padding: 0 !important;
    max-width: 100% !important;
}
@media (max-width: 768px) {
    .body-wrapper > .container-fluid,
    .body-wrapper .container-fluid.mw-100 {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
}

/* Cards — softer chrome, less padding */
.card {
    border-color: var(--sa-border) !important;
    box-shadow: none;
    border-radius: 8px;
    margin-bottom: 14px !important;
}
.card .card-body {
    padding: 16px !important;
}

/* ---------- Page header (redesigned) ----------
   Replaces the old card-wrapped header with a flat, Upwork-style block. */
.sa-page-header {
    padding: 6px 2px 14px;
    margin-bottom: 12px;
    border-bottom: 1px solid var(--sa-border);
}
.sa-page-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--sa-secondary);
    letter-spacing: -0.2px;
}
.sa-breadcrumb {
    font-size: 12.5px;
}
.sa-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    color: #9aa39a;
    content: "›";
    padding: 0 6px;
}
.sa-breadcrumb .breadcrumb-item.active {
    color: var(--sa-primary);
    font-weight: 600;
}

/* ---------- Tabs — Upwork-style underline tabs ---------- */
.nav-tabs, .panel-tabs {
    border-bottom: 1px solid var(--sa-border) !important;
    gap: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
}
.nav-tabs .nav-item {
    margin-bottom: -1px;
}
.nav-tabs .nav-link {
    border: 0 !important;
    border-bottom: 2px solid transparent !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #5e6b5e !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 10px 18px !important;
    margin: 0 !important;
    transition: color .15s ease, border-color .15s ease;
}
.nav-tabs .nav-link:hover, .panel-tabs .panel-tab:hover {
    color: var(--sa-primary-dark) !important;
    background: transparent !important;
    border-bottom-color: rgba(var(--sa-primary-rgb), .35) !important;
}
.nav-tabs .nav-link.active, .panel-tabs .panel-tab.active,
.nav-tabs .nav-item.show .nav-link {
    color: var(--sa-primary) !important;
    background: transparent !important;
    border-bottom: 2px solid var(--sa-primary) !important;
}
.nav-pills .nav-link.active, .nav-pills .show>.nav-link{
  background: var(--bs-primary-bg-subtle) !important;
  color: var(--sa-primary) !important;
}

.alert-info{
  background: var(--bs-primary-bg-subtle) !important;
  color: var(--sa-primary) !important;
  border: 1px solid var(--sa-primary) !important;
}
.panel-tab.active::after, .step-line.active{
  background: var(--sa-primary) !important;
}
.modal-header{
  background: var(--bs-primary-bg-subtle) !important;
}
.modal-title, .status-step.active .step-label{
  color: var(--sa-primary) !important;
}
.status-step.active .step-icon{
  background: var(--bs-primary-bg-subtle) !important;
  color: var(--sa-primary) !important;
  box-shadow: 0 0 0 4px rgba(232, 245, 228, 0.5) !important;
}
.modal-header .btn-close,
.modal .btn-close,
.offcanvas-header .btn-close {
  filter: none !important;
  opacity: .7 !important;
  background-color: transparent !important;
}
.modal-header .btn-close:hover,
.modal .btn-close:hover,
.offcanvas-header .btn-close:hover {
  opacity: 1 !important;
}
.daterangepicker td.active{
  background: var(--sa-primary) !important;
  color: #ffffff !important;
}
body .daterangepicker td.in-range{
  color: var(--sa-primary);
}
.btn-default{
  background: var(--sa-secondary) !important;
   color: #ffffff !important;
}
.tox .tox-edit-area::before{
  border: 2px solid var(--sa-primary) !important;
}


/* Tabs strip should not look like a card on its own.
   Any .card / .card-body whose first (or only) child is a .nav-tabs
   gets its card chrome stripped, so the tabs render as a flat strip
   without per-page Blade edits. */
.card:has(> .nav-tabs:only-child),
.card.card-body:has(> .nav-tabs:only-child),
.card:has(> ul.nav-tabs:first-child:last-child),
.card-body:has(> .nav-tabs:only-child) {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-bottom: 0 !important;
    border-radius: 0 !important;
}
.card > .nav-tabs:only-child,
.card-body > .nav-tabs:only-child {
    margin: 0 !important;
}

/* ---------- Form controls (inputs, selects, textareas) ---------- */
/* Idle border color — replaces the template's bluish default with theme neutral */
.form-control,
.form-select,
textarea.form-control,
input.form-control,
.input-group-text {
    border-color: var(--sa-border) !important;
    color: var(--sa-secondary);
}
.form-control:hover,
.form-select:hover {
    border-color: #cfd6cf !important;
}
.form-control::placeholder,
.form-select::placeholder {
    color: #9aa39a;
}

/* Select2 idle border */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border-color: var(--sa-border) !important;
}
.select2-container--default .select2-selection--single:hover,
.select2-container--default .select2-selection--multiple:hover {
    border-color: #cfd6cf !important;
}

/* Bootstrap tagsinput idle border */
.bootstrap-tagsinput {
    border-color: var(--sa-border) !important;
}

/* intl-tel-input idle border */
.iti--separate-dial-code .iti__selected-flag,
.iti__country-list {
    border-color: var(--sa-border) !important;
}

/* Quill editor idle border */
.ql-toolbar.ql-snow,
.ql-container.ql-snow {
    border-color: var(--sa-border) !important;
}

/* Generic input-group + table borders too — keep on-theme */
.input-group > .form-control,
.input-group > .form-select,
.input-group > .input-group-text,
.input-group > .btn {
    border-color: var(--sa-border) !important;
}
.table > :not(caption) > * > * {
    border-color: var(--sa-border);
}
.border, .rounded.border, .table-responsive.border {
    border-color: var(--sa-border) !important;
}

.form-control:focus,
.form-select:focus,
.form-check-input:focus,
textarea:focus,
input.form-control:focus {
    border-color: var(--sa-primary) !important;
    box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18) !important;
    outline: 0 !important;
}
.form-check-input:checked, .form-check-input[type=checkbox]:indeterminate {
    background-color: var(--sa-primary) !important;
    border-color: var(--sa-primary) !important;
}
.form-switch .form-check-input:focus {
    border-color: var(--sa-primary) !important;
}
.form-control:focus + .input-group-text,
.input-group:focus-within .input-group-text {
    border-color: var(--sa-primary) !important;
}

/* Select2 — focus / open / selection states */
.select2-container--default.select2-container--focus .select2-selection,
.select2-container--default.select2-container--open .select2-selection,
.select2-container--default .select2-selection--single:focus,
.select2-container--default .select2-selection--multiple:focus {
    border-color: var(--sa-primary) !important;
    box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18) !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background-color: var(--sa-primary) !important;
    color: #ffffff !important;
}
.select2-container--default .select2-results__option[aria-selected=true],
.select2-container--default .select2-results__option--selected {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: var(--bs-primary-bg-subtle) !important;
    border-color: var(--sa-primary) !important;
    color: var(--sa-primary-dark) !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    border-color: var(--sa-primary) !important;
    box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18) !important;
    outline: 0 !important;
}

/* Bootstrap tagsinput */
.bootstrap-tagsinput.focus,
.bootstrap-tagsinput:focus-within {
    border-color: var(--sa-primary) !important;
    box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18) !important;
}

/* Quill editor focus */
.ql-container.ql-snow:focus-within,
.ql-toolbar.ql-snow + .ql-container.ql-snow:focus-within {
    border-color: var(--sa-primary) !important;
}

/* Floating labels / labels in focused state */
.form-floating > .form-control:focus ~ label,
.form-floating > .form-select:focus ~ label {
    color: var(--sa-primary) !important;
}

/* Generic ":focus-visible" rings (some custom buttons / wrappers) */
*:focus-visible {
    outline-color: var(--sa-primary) !important;
}

/* Override custom.css's hardcoded focus shadow that used --sa-primary-rgb
   but at a heavier weight — keep it green-tinted */
.form-control:focus,
.form-select:focus {
    --bs-border-color: var(--sa-primary);
}

/* intl-tel-input dropdown */
.iti__country.iti__highlight {
    background-color: var(--bs-primary-bg-subtle) !important;
}
.iti--separate-dial-code .iti__selected-flag:focus {
    background-color: var(--bs-primary-bg-subtle) !important;
}

/* ---------- Sidebar brand / logo area ---------- */
.sa-sidebar-brand {
    height: var(--sa-topbar-h);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    /*background-color: var(--sa-primary);*/
}
.sa-sidebar-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}
.sa-sidebar-logo img {
    max-height: 50px;
    width: auto;
    object-fit: contain;
}
[data-layout=vertical] .link-sidebar .left-sidebar {
    top: 0 !important;
}
[data-sidebartype=mini-sidebar].link-sidebar .sa-sidebar-logo img {
    max-height: 28px;
}

/* Hide the duplicated logo inside the topbar (now lives in the sidebar) */
.topbar .navbar-brand,
.topbar .logo-img {
    display: none !important;
}

/* Page title slot inside the topbar (left side) */
.sa-topbar-title-wrap {
    min-width: 0;
}
.sa-topbar-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--sa-secondary);
    letter-spacing: -0.2px;
    line-height: 1.2;
    margin: 0;
    padding: 0 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
@media (max-width: 575px) {
    .sa-topbar-title { font-size: 14px; }
}

/* Sidebar scroll area starts right under the brand */
.left-sidebar .scroll-sidebar {
    margin-top: 8px !important;
}
@media (min-width: 1100px) {
    [data-layout=vertical] .link-sidebar .left-sidebar .sidebar-nav {
        margin-top: 0 !important;
    }
}

/* ---------- Sidebar icon hover/active colors (Upwork green) ---------- */
.sidebar-nav ul .sidebar-item .sidebar-link iconify-icon {
    color: #5e6b5e;
    transition: color .15s ease;
}
.sidebar-nav ul .sidebar-item .sidebar-link:hover iconify-icon,
.sidebar-nav ul .sidebar-item .sidebar-link:focus iconify-icon {
    color: var(--sa-primary) !important;
}
.sidebar-nav ul .sidebar-item > .sidebar-link.active iconify-icon,
.sidebar-nav ul .sidebar-item.selected > .sidebar-link iconify-icon,
.sidebar-nav ul .sidebar-item.selected .sidebar-link.active iconify-icon {
    color: var(--sa-primary) !important;
}
[data-sidebartype=mini-sidebar].link-sidebar .sidebar-nav ul .sidebar-item > .sidebar-link.active iconify-icon {
    color: #ffffff !important;
}

/* ---------- Dropdown menus (profile + others) ---------- */
.dropdown-menu {
    --bs-dropdown-link-color: var(--sa-secondary);
    --bs-dropdown-link-hover-color: var(--sa-primary-dark);
    --bs-dropdown-link-hover-bg: var(--bs-primary-bg-subtle);
    --bs-dropdown-link-active-color: #ffffff;
    --bs-dropdown-link-active-bg: var(--sa-primary);
    --bs-dropdown-border-color: var(--sa-border);
    border-radius: 8px;
    box-shadow: 0 6px 24px rgba(43, 43, 43, .08);
}
.dropdown-menu .dropdown-item {
    color: var(--sa-secondary);
    font-weight: 500;
    border-radius: 6px;
    padding: 8px 12px;
    transition: background-color .12s ease, color .12s ease;
}
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
}
.dropdown-menu .dropdown-item.active,
.dropdown-menu .dropdown-item:active {
    background-color: var(--sa-primary) !important;
    color: #ffffff !important;
}
/* Generic anchor-as-link inside dropdowns (some templates use <a class="d-flex"> instead of .dropdown-item) */
.dropdown-menu a:not(.btn):hover,
.dropdown-menu a:not(.btn):focus {
    color: var(--sa-primary-dark) !important;
    background-color: var(--bs-primary-bg-subtle) !important;
}

/* Topbar badge contrast on the new light background */
.topbar .navbar .notification-count,
.topbar .navbar .supeNotification,
.topbar .navbar .badge-number,
.topbar .navbar .badge-number-chat {
    background-color: var(--sa-primary) !important;
    color: #ffffff !important;
}

/* ---------- Settings: vertical tab list, content sits to the right ----------
   Use flexbox on the wrapping card so the tab rail and card-body sit
   side-by-side regardless of which Blade page hosts them. */
.card:has(> .sa-settings-tabs) {
    display: grid !important;
    grid-template-columns: 240px minmax(0, 1fr) !important;
    grid-auto-rows: min-content;
    align-items: stretch !important;
    overflow: hidden;
}
.card:has(> .sa-settings-tabs) > .sa-settings-tabs {
    grid-column: 1;
    grid-row: 1 / -1;
    align-self: stretch;
}
.card:has(> .sa-settings-tabs) > *:not(.sa-settings-tabs) {
    grid-column: 2;
    min-width: 0;
}
.sa-settings-tabs {
    width: 240px;
    padding: 12px 8px !important;
    border-right: 1px solid var(--sa-border);
    background-color: #fafcfa;
    gap: 2px;
    align-self: stretch;
}
.sa-settings-tabs .nav-item {
    width: 100%;
}
.sa-settings-tabs .nav-link {
    display: flex !important;
    align-items: center;
    width: 100%;
    padding: 9px 12px !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--sa-secondary) !important;
    background: transparent !important;
    border: 0 !important;
    text-align: left;
    transition: background-color .12s ease, color .12s ease;
}
.sa-settings-tabs .nav-link iconify-icon {
    font-size: 1rem !important;
    margin-right: 8px;
    flex-shrink: 0;
}
.sa-settings-tabs .nav-link:hover {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
}
.sa-settings-tabs .nav-link.active {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary) !important;
    font-weight: 600 !important;
    border-right: 3px solid var(--sa-primary) !important;
    border-radius: 6px 0 0 6px !important;
    margin-right: -1px;
}

/* Stack vertically on small screens */
@media (max-width: 768px) {
    .card:has(> .sa-settings-tabs) {
        grid-template-columns: minmax(0, 1fr) !important;
    }
    .card:has(> .sa-settings-tabs) > .sa-settings-tabs {
        grid-column: 1;
        grid-row: auto;
    }
    .card:has(> .sa-settings-tabs) > *:not(.sa-settings-tabs) {
        grid-column: 1;
    }
    .sa-settings-tabs {
        width: 100%;
        border-right: 0;
        border-bottom: 1px solid var(--sa-border);
    }
    .sa-settings-tabs .nav-link.active {
        border-right: 0 !important;
        border-left: 3px solid var(--sa-primary) !important;
        border-radius: 0 6px 6px 0 !important;
    }
}

/* ---------- Pagination (Upwork green) ---------- */
.pagination {
    --bs-pagination-color: var(--sa-secondary);
    --bs-pagination-bg: #ffffff;
    --bs-pagination-border-color: var(--sa-border);
    --bs-pagination-hover-color: var(--sa-primary);
    --bs-pagination-hover-bg: var(--bs-primary-bg-subtle);
    --bs-pagination-hover-border-color: var(--sa-primary);
    --bs-pagination-focus-color: var(--sa-primary);
    --bs-pagination-focus-bg: var(--bs-primary-bg-subtle);
    --bs-pagination-focus-box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18);
    --bs-pagination-active-color: #ffffff;
    --bs-pagination-active-bg: var(--sa-primary);
    --bs-pagination-active-border-color: var(--sa-primary);
    --bs-pagination-disabled-color: #9aa39a;
    --bs-pagination-disabled-bg: #f5f7f5;
    --bs-pagination-disabled-border-color: var(--sa-border);
    gap: 4px;
}
.pagination .page-link {
    border-radius: 6px !important;
    font-weight: 600;
    min-width: 32px;
    text-align: center;
    color: var(--sa-primary);
}
.pagination .page-item.active .page-link,
.pagination .page-link.active {
    background-color: var(--sa-primary) !important;
    border-color: var(--sa-primary) !important;
    color: #ffffff !important;
    box-shadow: 0 1px 2px rgba(var(--sa-primary-rgb), .2);
}
.pagination .page-item.disabled .page-link {
    color: #9aa39a !important;
}

/* simple-datatables pagination (vendor CSS hardcodes blue — override here) */
.datatable-pagination {
    --bs-pagination-color: var(--sa-primary) !important;
    --bs-pagination-bg: #ffffff !important;
    --bs-pagination-border-color: var(--sa-border) !important;
    --bs-pagination-hover-color: #ffffff !important;
    --bs-pagination-hover-bg: var(--sa-primary) !important;
    --bs-pagination-hover-border-color: var(--sa-primary) !important;
    --bs-pagination-focus-color: var(--sa-primary-dark) !important;
    --bs-pagination-focus-bg: var(--bs-primary-bg-subtle) !important;
    --bs-pagination-focus-box-shadow: 0 0 0 .18rem rgba(var(--sa-primary-rgb), .18) !important;
    --bs-pagination-active-color: #ffffff !important;
    --bs-pagination-active-bg: var(--sa-primary) !important;
    --bs-pagination-active-border-color: var(--sa-primary) !important;
    --bs-pagination-disabled-color: #9aa39a !important;
    --bs-pagination-disabled-bg: #f5f7f5 !important;
    --bs-pagination-disabled-border-color: var(--sa-border) !important;
}
.datatable-pagination ul {
    gap: 4px;
}
.datatable-pagination a,
.datatable-pagination button {
    color: var(--sa-primary) !important;
    border-color: var(--sa-border) !important;
    border-radius: 6px !important;
    font-weight: 600;
    min-width: 32px;
    text-align: center;
}
.datatable-pagination a:hover,
.datatable-pagination button:hover {
    background-color: var(--sa-primary) !important;
    border-color: var(--sa-primary) !important;
    color: #ffffff !important;
}
.datatable-pagination .datatable-active a,
.datatable-pagination .datatable-active a:focus,
.datatable-pagination .datatable-active a:hover,
.datatable-pagination .datatable-active button,
.datatable-pagination .datatable-active button:focus,
.datatable-pagination .datatable-active button:hover {
    background-color: var(--sa-primary) !important;
    border-color: var(--sa-primary) !important;
    color: #ffffff !important;
    box-shadow: 0 1px 2px rgba(var(--sa-primary-rgb), .2);
}
.datatable-pagination .datatable-disabled a,
.datatable-pagination .datatable-disabled button {
    color: #9aa39a !important;
    background-color: #f5f7f5 !important;
}

/* DataTables pagination (if used) */
.dataTables_paginate .paginate_button,
.dataTables_paginate .paginate_button.previous,
.dataTables_paginate .paginate_button.next {
    color: var(--sa-primary) !important;
    border-color: var(--sa-border) !important;
}
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
    background: var(--sa-primary) !important;
    border-color: var(--sa-primary) !important;
    color: #ffffff !important;
}
.dataTables_paginate .paginate_button:hover {
    background: var(--bs-primary-bg-subtle) !important;
    color: var(--sa-primary-dark) !important;
    border-color: var(--sa-primary) !important;
}

/* ---------- Shared overrides for invite-analytics.css (Jobs, Demo Requests, KPI) ---------- */
.stats-card,
.stats-card-1, .stats-card-2, .stats-card-3, .stats-card-4 {
    border: 1px solid var(--sa-border) !important;
    border-radius: 10px !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(43, 43, 43, .04) !important;
    transition: box-shadow .15s ease, transform .15s ease;
}
.stats-card:hover {
    box-shadow: 0 6px 16px rgba(43, 43, 43, .06) !important;
}
.stats-card .card-body { padding: 18px !important; }
.stats-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
}
.icon-blue   { background: var(--bs-primary-bg-subtle) !important; color: var(--sa-primary) !important; }
.icon-green  { background: var(--bs-primary-bg-subtle) !important; color: var(--sa-primary) !important; }
.icon-purple { background: #eef0ee !important;                     color: #5e6b5e !important; }
.icon-orange { background: rgba(255, 152, 0, .15) !important;      color: #ff9800 !important; }
.icon-red    { background: rgba(244, 67, 54, .15) !important;      color: #f44336 !important; }
.icon-teal   { background: rgba(0, 150, 136, .15) !important;      color: #009688 !important; }
.counter-label {
    font-size: .8rem !important;
    color: #6b756b !important;
    font-weight: 600 !important;
    letter-spacing: .02em;
}
.counter-number {
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    color: var(--sa-secondary) !important;
    line-height: 1.1 !important;
}

/* Flatten the glassmorphism wrapper */
.card.glassmorphism {
    background: #fff !important;
    border: 1px solid var(--sa-border) !important;
    box-shadow: 0 1px 2px rgba(43, 43, 43, .04) !important;
    backdrop-filter: none !important;
    border-radius: 8px !important;
}

/* Modern filter inputs / buttons */
.modern-input {
    display: block;
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    color: var(--sa-secondary);
    background-color: #fff;
    border: 1px solid var(--sa-border);
    border-radius: 6px;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.modern-input:focus {
    border-color: var(--sa-primary) !important;
    box-shadow: 0 0 0 4px rgba(232, 245, 228, 0.5) !important;
    outline: 0;
}
.btn-modern {
    font-weight: 600;
    border-radius: 6px;
}
.btn-gradient {
    background: var(--sa-primary) !important;
    background-image: linear-gradient(135deg, var(--sa-primary) 0%, var(--sa-primary-dark) 100%) !important;
    color: #fff !important;
    border: 0 !important;
    font-weight: 600;
}
.btn-gradient:hover,
.btn-gradient:focus {
    background: #3a3a3a !important;
    background-image: linear-gradient(135deg, #3a3a3a 0%, #1a1a1a 100%) !important;
    color: #fff !important;
}

/* Status badges used across these pages */
.status-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase;
}

/* ---------- Cancel button — neutral light style (was danger pink) ---------- */
.btn.bg-danger-subtle.text-danger {
    background-color: #f5f7f5 !important;
    color: var(--sa-secondary) !important;
    border: 1px solid var(--sa-border) !important;
    font-weight: 600;
}
.btn.bg-danger-subtle.text-danger:hover,
.btn.bg-danger-subtle.text-danger:focus {
    background-color: #e9ece9 !important;
    color: var(--sa-secondary) !important;
    border-color: #cfd6cf !important;
}

/* ---------- Status / priority badges (feature requests etc.) ----------
   Soft "subtle background + emphasis text" pills that sit on-theme with the
   YogaCRM palette instead of raw Bootstrap text-* colors. */
.sa-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: .01em;
    border: 1px solid transparent;
    white-space: nowrap;
}
/* New — brand green */
.sa-badge-new {
     background-color: var(--bs-primary-bg-subtle);
    color: var(--sa-primary-dark);
     border-color: rgba(var(--sa-primary-rgb), .25);
}
/* Under Review — amber */
.sa-badge-review {
     background-color: #fff4e0;
    color: #b9770b;
     border-color: #f5dca8;
}
/* Planned — neutral charcoal */
.sa-badge-planned {
     background-color: #eef0ee;
    color: var(--sa-secondary);
     border-color: #dfe4df;
}
/* In Progress / Low priority — teal-blue accent */
.sa-badge-progress {
     background-color: #e4f1f5;
    color: #1f7d92;
     border-color: #bfe0e8;
}
/* Released / Resolved — success green */
.sa-badge-success {
     background-color: #e6f4dd;
    color: var(--sa-primary-dark);
     border-color: #c7e6b3;
}
/* Closed — muted grey */
.sa-badge-closed {
     background-color: #f1f2f1;
    color: #6b756b;
     border-color: #e0e3e0;
}
/* Rejected / High priority — danger red */
.sa-badge-danger {
     background-color: #fde7e7;
    color: #c0392b;
     border-color: #f5c6c2;
}
/* Medium priority — warning amber (alias of review tone) */
.sa-badge-warning {
     background-color: #fff4e0;
    color: #b9770b;
     border-color: #f5dca8;
}

/* ---------- Seed Data / utility outline button ---------- */
.btn-sa-outline {
    --bs-btn-color: var(--sa-secondary);
    --bs-btn-bg: #ffffff;
    --bs-btn-border-color: var(--sa-border);
    --bs-btn-hover-color: var(--sa-primary);
    --bs-btn-hover-bg: var(--bs-primary-bg-subtle);
    --bs-btn-hover-border-color: var(--sa-primary);
    --bs-btn-active-color: #ffffff;
    --bs-btn-active-bg: var(--sa-primary);
    --bs-btn-active-border-color: var(--sa-primary);
    font-weight: 600;
    border-width: 1px;
}

/* ---------- Badge text — force black across Super Admin tables/pages ----------
   Applies to Bootstrap .badge, subtle variants and the custom .sa-badge / .status-badge.
   Topbar notification badges are excluded so the count stays readable on dark dot. */
.badge,
.badge.bg-primary, .badge.bg-secondary, .badge.bg-success,
.badge.bg-info, .badge.bg-warning, .badge.bg-danger,
.badge.bg-light, .badge.bg-dark,
.badge.bg-primary-subtle, .badge.bg-secondary-subtle,
.badge.bg-success-subtle, .badge.bg-info-subtle,
.badge.bg-warning-subtle, .badge.bg-danger-subtle,
.badge.bg-light-subtle, .badge.bg-dark-subtle,
.status-badge,
.sa-badge, .sa-badge-new, .sa-badge-review, .sa-badge-planned,
.sa-badge-progress, .sa-badge-success, .sa-badge-closed,
.sa-badge-danger, .sa-badge-warning {
    color: #000000 !important;
}
.topbar .navbar .badge-number,
.topbar .navbar .notification-count,
.topbar .navbar .supeNotification,
.topbar .navbar .badge-number-chat {
    color: #ffffff !important;
}

/* ---------- .popup-card — clean white success modal (overrides custom.css gradient) ---------- */
.popup-container {
    background: rgba(17, 17, 17, .45) !important;
    backdrop-filter: blur(2px) !important;
}
.popup-card {
    background: #ffffff !important;
    background-image: none !important;
    border: 1px solid var(--sa-border) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, .12) !important;
    padding: 28px 24px !important;
    max-width: 440px !important;
    width: 100% !important;
}
.popup-card::before { display: none !important; }
.popup-card h2 {
    color: var(--sa-secondary) !important;
    font-size: 20px !important;
    font-weight: 600 !important;
}
.popup-card p {
    color: #555 !important;
    font-size: 14px !important;
    font-weight: 400 !important;
}
.popup-icon {
    width: 56px !important;
    height: 56px !important;
    background: #e6f4ea !important;
    background-image: none !important;
    box-shadow: none !important;
    margin: 0 auto 14px !important;
}
.popup-icon svg {
    width: 28px !important;
    height: 28px !important;
    color: #1f9d55 !important;
}
.btn-custom {
    background: var(--sa-primary) !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 1px solid var(--sa-primary) !important;
    border-radius: 8px !important;
    padding: 8px 22px !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}
.btn-custom:hover,
.btn-custom:focus {
    background: #3a3a3a !important;
    background-image: none !important;
    border-color: #3a3a3a !important;
    color: #ffffff !important;
    box-shadow: none !important;
}

/* ---------- SweetAlert2 — clean, professional white card ---------- */
.swal2-popup {
    background: #ffffff !important;
    background-image: none !important;
    color: var(--sa-secondary) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, .12) !important;
    padding: 28px 24px !important;
}
.swal2-title {
    color: var(--sa-secondary) !important;
    font-size: 20px !important;
    font-weight: 600 !important;
}
.swal2-html-container,
.swal2-content {
    color: #555 !important;
    font-size: 14px !important;
}
.swal2-icon { border-color: var(--sa-border) !important; }
.swal2-icon.swal2-success {
    border-color: #1f9d55 !important;
    color: #1f9d55 !important;
}
.swal2-icon.swal2-success [class^="swal2-success-line"] {
    background-color: #1f9d55 !important;
}
.swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(31, 157, 85, .25) !important;
}
.swal2-icon.swal2-error    { border-color: #d9534f !important; color: #d9534f !important; }
.swal2-icon.swal2-error [class^="swal2-x-mark-line"] { background-color: #d9534f !important; }
.swal2-icon.swal2-warning  { border-color: #d4a017 !important; color: #d4a017 !important; }
.swal2-icon.swal2-info     { border-color: #2c7fb8 !important; color: #2c7fb8 !important; }
.swal2-icon.swal2-question { border-color: #6b7280 !important; color: #6b7280 !important; }

.swal2-actions { gap: 8px !important; margin-top: 18px !important; }
.swal2-styled.swal2-confirm {
    background: var(--sa-primary) !important;
    background-image: none !important;
    color: #ffffff !important;
    border: 1px solid var(--sa-primary) !important;
    border-radius: 8px !important;
    padding: 8px 20px !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}
.swal2-styled.swal2-confirm:hover,
.swal2-styled.swal2-confirm:focus {
    background: var(--sa-primary-dark) !important;
    border-color: var(--sa-primary-dark) !important;
    box-shadow: none !important;
}
.swal2-styled.swal2-cancel,
.swal2-styled.swal2-deny {
    background: #ffffff !important;
    color: var(--sa-secondary) !important;
    border: 1px solid var(--sa-border) !important;
    border-radius: 8px !important;
    padding: 8px 20px !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}
.swal2-styled.swal2-cancel:hover,
.swal2-styled.swal2-deny:hover {
    background: #f5f5f5 !important;
}
.swal2-container.swal2-backdrop-show {
    background: rgba(17, 17, 17, .45) !important;
}
