/*!
 * Dashcode-style admin theme (local)
 * Custom build — mimics the Dashcode admin template visual language
 */

:root {
    --dc-primary: #4669fa;
    --dc-primary-rgb: 70, 105, 250;
    --dc-primary-hover: #3b5ce0;
    --dc-primary-soft: #eef2ff;
    --dc-secondary: #a0aec0;
    --dc-success: #50c793;
    --dc-info: #0ce7fa;
    --dc-warning: #fa916b;
    --dc-danger: #f1595c;

    --dc-body-bg: #f1f5f9;
    --dc-card-bg: #ffffff;
    --dc-sidebar-bg: #1e293b;
    --dc-sidebar-bg-hover: #27364b;
    --dc-sidebar-text: #cbd5e1;
    --dc-sidebar-heading: #ffffff;
    --dc-sidebar-border: rgba(255, 255, 255, 0.06);
    --dc-border: #e2e8f0;

    --dc-text: #0f172a;
    --dc-text-muted: #64748b;
    --dc-heading: #1e293b;

    --dc-sidebar-width: 248px;
    --dc-sidebar-collapsed: 72px;
    --dc-header-height: 64px;

    --dc-radius: 10px;
    --dc-radius-sm: 6px;
    --dc-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
    --dc-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
    --dc-transition: 0.22s ease;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background-color: var(--dc-body-bg);
    color: var(--dc-text);
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 15.5px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--dc-primary); text-decoration: none; }
a:hover { color: var(--dc-primary-hover); }

h1, h2, h3, h4, h5, h6 {
    color: var(--dc-heading);
    font-weight: 600;
}

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

/* ==========================================================
   Layout wrapper
========================================================== */
.dc-app {
    display: flex;
    min-height: 100vh;
}

.dc-main {
    flex: 1;
    margin-left: var(--dc-sidebar-width);
    display: flex;
    flex-direction: column;
    min-width: 0;
    transition: margin-left var(--dc-transition);
}

.dc-content {
    padding: 1.75rem 1.75rem 2.5rem;
    flex: 1;
}

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

.dc-sidebar-brand {
    height: var(--dc-header-height);
    padding: 0 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    border-bottom: 1px solid var(--dc-sidebar-border);
    flex-shrink: 0;
}

.dc-sidebar-brand .brand-logo {
    width: 34px; height: 34px;
    background: linear-gradient(135deg, var(--dc-primary) 0%, #6d8dff 100%);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.dc-sidebar-brand .brand-name {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dc-sidebar-heading);
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.dc-sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 1rem 0.75rem 1.5rem;
}

.dc-sidebar-nav::-webkit-scrollbar { width: 4px; }
.dc-sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.15); border-radius: 4px; }

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

.dc-nav-section-title {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.55);
    padding: 1rem 0.85rem 0.45rem;
    margin: 0;
    white-space: nowrap;
}

.dc-nav-item { margin: 0 0; }

.dc-nav-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.45rem 0.9rem;
    color: var(--dc-sidebar-text);
    font-size: 0.98rem;
    font-weight: 500;
    border-radius: var(--dc-radius-sm);
    position: relative;
    white-space: nowrap;
    transition: background-color var(--dc-transition), color var(--dc-transition);
}

.dc-nav-link i {
    font-size: 1.15rem;
    width: 20px;
    color: rgba(255, 255, 255, 0.55);
    transition: color var(--dc-transition);
    flex-shrink: 0;
    text-align: center;
}

.dc-nav-link:hover {
    background-color: var(--dc-sidebar-bg-hover);
    color: #ffffff;
}

.dc-nav-link:hover i { color: #ffffff; }

.dc-nav-link.active {
    background-color: transparent;
    color: #4fa3ff;
    box-shadow: none;
    font-weight: 600;
}

.dc-nav-link.active i { color: #4fa3ff; }

.dc-nav-link.has-caret .dc-caret {
    margin-left: auto;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.45);
    transition: transform var(--dc-transition);
}

.dc-nav-link.has-caret[aria-expanded="true"] .dc-caret {
    transform: rotate(180deg);
    color: #ffffff;
}

.dc-nav-link.has-caret[aria-expanded="true"]:not(.active) {
    background-color: var(--dc-sidebar-bg-hover);
    color: #ffffff;
}

.dc-nav-link.has-caret[aria-expanded="true"]:not(.active) i { color: #ffffff; }

.dc-submenu {
    list-style: none;
    padding: 0.15rem 0 0.25rem 0;
    margin: 0.1rem 0 0.25rem 1.35rem;
    border-left: none;
}

.dc-submenu .dc-nav-item { margin: 0.1rem 0; }

.dc-submenu .dc-nav-link {
    padding: 0.5rem 0.8rem;
    font-size: 0.98rem;
    font-weight: 500;
    gap: 0.65rem;
}

.dc-submenu .dc-nav-link i {
    font-size: 1.05rem;
    width: 18px;
}

.dc-submenu .dc-nav-link::before {
    display: none;
}

.dc-submenu .dc-nav-link.has-caret::before { display: none; }

.dc-submenu .dc-nav-link:hover::before,
.dc-submenu .dc-nav-link.active::before {
    background-color: currentColor;
    opacity: 1;
}

.dc-submenu .dc-nav-link.active {
    background-color: transparent;
    color: #4fa3ff;
    font-weight: 600;
    box-shadow: none;
}

.dc-submenu .dc-nav-link.active::before {
    background-color: #4fa3ff !important;
    opacity: 1;
}

.dc-submenu .dc-submenu {
    margin: 0.1rem 0 0.25rem 1.5rem;
    padding-left: 0;
}

/* ==========================================================
   Header
========================================================== */
.dc-header {
    height: var(--dc-header-height);
    background-color: #fff;
    border-bottom: 1px solid var(--dc-border);
    position: sticky;
    top: 0;
    z-index: 1020;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1.5rem;
    backdrop-filter: saturate(180%) blur(8px);
}

.dc-header-left, .dc-header-right {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.dc-header-action {
    display: flex;
    align-items: center;
}
.dc-header-action:empty {
    display: none;
}

.dc-sidebar-toggle {
    background: transparent;
    border: none;
    width: 38px;
    height: 38px;
    border-radius: var(--dc-radius-sm);
    color: var(--dc-text-muted);
    font-size: 1.25rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--dc-transition), color var(--dc-transition);
}

.dc-sidebar-toggle:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
}

.dc-header-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--dc-heading);
}

.dc-breadcrumb .breadcrumb {
    margin: 0;
    padding: 0;
    background: transparent;
    font-size: .92rem;
    line-height: 1.2;
}
.dc-breadcrumb .breadcrumb-item {
    color: #6b7280;
}
.dc-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    content: "›";
    color: #cbd5e1;
    padding: 0 .35rem;
}
.dc-breadcrumb .breadcrumb-item a {
    color: #6b7280;
    text-decoration: none;
    font-weight: 500;
    transition: color .15s ease;
}
.dc-breadcrumb .breadcrumb-item a:hover {
    color: var(--dc-primary);
}
.dc-breadcrumb .breadcrumb-item.active {
    color: var(--dc-heading);
    font-weight: 600;
}

.dc-search {
    position: relative;
    display: flex;
    align-items: center;
}

.dc-search i {
    position: absolute;
    left: 0.9rem;
    color: var(--dc-text-muted);
    font-size: 0.95rem;
}

.dc-search input {
    height: 38px;
    border: 1px solid var(--dc-border);
    background-color: var(--dc-body-bg);
    border-radius: var(--dc-radius-sm);
    padding: 0 0.9rem 0 2.35rem;
    min-width: 280px;
    font-size: 0.88rem;
    color: var(--dc-text);
    outline: none;
    transition: border-color var(--dc-transition), background-color var(--dc-transition), box-shadow var(--dc-transition);
}

.dc-search input:focus {
    border-color: var(--dc-primary);
    background-color: #fff;
    box-shadow: 0 0 0 3px rgba(var(--dc-primary-rgb), 0.15);
}

.dc-icon-btn {
    position: relative;
    background: transparent;
    border: none;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    color: var(--dc-text-muted);
    font-size: 1.1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--dc-transition), color var(--dc-transition);
}

.dc-icon-btn:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
}

.dc-icon-btn .dc-badge-dot {
    position: absolute;
    top: 8px;
    right: 9px;
    width: 8px;
    height: 8px;
    background-color: var(--dc-danger);
    border: 2px solid #fff;
    border-radius: 50%;
}

.dc-user {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.25rem 0.5rem 0.25rem 0.25rem;
    background: transparent;
    border: none;
    cursor: pointer;
    border-radius: 999px;
    transition: background-color var(--dc-transition);
}

.dc-user:hover { background-color: var(--dc-body-bg); }

.dc-user .user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--dc-primary) 0%, #8fa3ff 100%);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.9rem;
}

.dc-user .user-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.15;
}

.dc-user .user-name {
    font-size: 0.86rem;
    font-weight: 600;
    color: var(--dc-heading);
}

.dc-user .user-role {
    font-size: 0.72rem;
    color: var(--dc-text-muted);
}

.dropdown-menu {
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    box-shadow: var(--dc-shadow);
    padding: 0.35rem;
    font-size: 0.88rem;
}

.dropdown-item {
    border-radius: var(--dc-radius-sm);
    padding: 0.5rem 0.75rem;
}

.dropdown-item:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
}

/* ==========================================================
   Page header
========================================================== */
.dc-page-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.dc-page-title {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--dc-heading);
    letter-spacing: -0.015em;
}

.dc-breadcrumb {
    font-size: 0.82rem;
    color: var(--dc-text-muted);
    margin-top: 0.25rem;
}

.dc-breadcrumb a { color: var(--dc-text-muted); }
.dc-breadcrumb a:hover { color: var(--dc-primary); }
.dc-breadcrumb .sep { margin: 0 0.4rem; opacity: 0.6; }

/* ==========================================================
   Cards & stats
========================================================== */
.dc-card {
    background-color: var(--dc-card-bg);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    box-shadow: var(--dc-shadow-sm);
}

/* Reusable filter toolbar — used on index pages above the table card.
   Add class `dc-filter-toolbar` to the <form> wrapping your name/status/etc.
   filter inputs, and place it just before the .dc-card. */
.dc-filter-toolbar {
    background: var(--dc-card-bg);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    padding: .6rem .85rem;
    margin-top: 1rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--dc-shadow-sm);
}
.dc-filter-toolbar .form-label {
    font-size: .75rem;
    font-weight: 600;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .4px;
    margin-bottom: .2rem;
}
.dc-filter-toolbar .form-control,
.dc-filter-toolbar .form-select {
    font-size: .88rem;
    padding: .4rem .6rem;
    height: auto;
}
.dc-filter-toolbar .btn {
    font-size: .85rem;
    padding: .4rem .8rem;
    white-space: nowrap;
}

/* When a card uses our own filter toolbar, hide DataTables' built-in
   search box so we don't have two search inputs side-by-side. */
.dc-card.no-dt-search .dt-search { display: none !important; }

.dc-card-header {
    padding: 0.5rem 0.85rem;
    border-bottom: 1px solid var(--dc-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}


.dc-card-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--dc-heading);
}

.dc-card-body {
    padding: 1.25rem;
}

.dc-stat {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    background-color: var(--dc-card-bg);
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius);
    box-shadow: var(--dc-shadow-sm);
    transition: transform var(--dc-transition), box-shadow var(--dc-transition);
}

.dc-stat:hover {
    transform: translateY(-2px);
    box-shadow: var(--dc-shadow);
}

.dc-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}

.dc-stat-icon.primary { background-color: rgba(var(--dc-primary-rgb), 0.1); color: var(--dc-primary); }
.dc-stat-icon.success { background-color: rgba(80, 199, 147, 0.12); color: var(--dc-success); }
.dc-stat-icon.warning { background-color: rgba(250, 145, 107, 0.12); color: var(--dc-warning); }
.dc-stat-icon.info    { background-color: rgba(12, 231, 250, 0.12); color: #06b6d4; }

.dc-stat-label {
    font-size: 0.9rem;
    color: var(--dc-text-muted);
    margin-bottom: 0.15rem;
}

.dc-stat-value {
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--dc-heading);
    line-height: 1.1;
}

.dc-stat-delta {
    font-size: 0.75rem;
    font-weight: 600;
    margin-top: 0.2rem;
}

.dc-stat-delta.up { color: var(--dc-success); }
.dc-stat-delta.down { color: var(--dc-danger); }

/* ==========================================================
   Quick links list
========================================================== */
.dc-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dc-list li + li { margin-top: 0.25rem; }

.dc-list a {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 0.6rem;
    border-radius: var(--dc-radius-sm);
    color: var(--dc-text);
    font-size: 0.88rem;
    transition: background-color var(--dc-transition), color var(--dc-transition);
}

.dc-list a i { color: var(--dc-text-muted); width: 18px; }

.dc-list a:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
}

.dc-list a:hover i { color: var(--dc-primary); }

/* ==========================================================
   Buttons (dashcode primary)
========================================================== */
.btn-dc {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    height: 38px;
    padding: 0 1rem;
    font-size: 0.88rem;
    font-weight: 500;
    border-radius: var(--dc-radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background-color var(--dc-transition), border-color var(--dc-transition), color var(--dc-transition), box-shadow var(--dc-transition);
    text-decoration: none;
}

.btn-dc-primary {
    background-color: var(--dc-primary);
    color: #fff;
    box-shadow: 0 3px 8px rgba(var(--dc-primary-rgb), 0.25);
}

.btn-dc-primary:hover {
    background-color: var(--dc-primary-hover);
    color: #fff;
    box-shadow: 0 6px 14px rgba(var(--dc-primary-rgb), 0.35);
}

.btn-dc-outline {
    background-color: transparent;
    color: var(--dc-text);
    border-color: var(--dc-border);
}

.btn-dc-outline:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
    border-color: var(--dc-primary-soft);
}

/* ==========================================================
   Sidebar collapsed
========================================================== */
.dc-app.sidebar-collapsed .dc-sidebar {
    width: var(--dc-sidebar-collapsed);
}

.dc-app.sidebar-collapsed .dc-main {
    margin-left: var(--dc-sidebar-collapsed);
}

.dc-app.sidebar-collapsed .brand-name,
.dc-app.sidebar-collapsed .dc-nav-link span,
.dc-app.sidebar-collapsed .dc-nav-link .dc-caret,
.dc-app.sidebar-collapsed .dc-nav-section-title {
    display: none;
}

.dc-app.sidebar-collapsed .dc-nav-link { justify-content: center; padding: 0.65rem 0.6rem; }
.dc-app.sidebar-collapsed .dc-submenu { display: none !important; }

/* ==========================================================
   Tables
========================================================== */
.dc-table-wrap {
    overflow-x: auto;
}

.dc-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.98rem;
    border: 1px solid var(--dc-border);
    border-radius: 6px;
    overflow: hidden;
}

.dc-table thead th {
    background-color: #1e3a8a;
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.85rem 1rem;
    text-align: center;
    border-bottom: 1px solid var(--dc-border);
    border-right: 1px solid rgba(255,255,255,0.15);
    white-space: nowrap;
}

.dc-table thead th:last-child { border-right: none; }

.dc-table thead th a { color: #ffffff !important; }
.dc-table thead th a:hover { color: #cbd5e1 !important; }

.dc-table thead th a {
    color: inherit;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.dc-table thead th a:hover { color: var(--dc-primary); }
.dc-table thead th.asc a::after  { content: "\2191"; opacity: 0.7; }
.dc-table thead th.desc a::after { content: "\2193"; opacity: 0.7; }

.dc-table tbody td {
    padding: 0.95rem 1rem;
    border-bottom: 1px solid var(--dc-border);
    border-right: 1px solid var(--dc-border);
    color: var(--dc-text);
    vertical-align: middle;
    text-align: center;
}

.dc-table tbody td:last-child { border-right: none; }
.dc-table tbody tr:last-child td { border-bottom: 1px solid var(--dc-border); }
.dc-table tbody tr:hover td { background-color: #f8fafc; }

.dc-table td.actions { white-space: nowrap; text-align: center; }

.dc-table .cell-muted { color: var(--dc-text-muted); }

/* Row action buttons */
.dc-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 6px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--dc-text-muted);
    font-size: 1rem;
    margin-left: 0.25rem;
    cursor: pointer;
    transition: background-color var(--dc-transition), color var(--dc-transition), border-color var(--dc-transition);
    text-decoration: none;
}

.dc-action:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
    border-color: var(--dc-primary-soft);
}

.dc-action.dc-action-danger:hover {
    background-color: rgba(241, 89, 92, 0.12);
    color: var(--dc-danger);
    border-color: rgba(241, 89, 92, 0.12);
}

.dc-action form { display: inline; }
.dc-action form button {
    background: transparent;
    border: none;
    padding: 0;
    color: inherit;
    font-size: inherit;
    cursor: pointer;
}

/* ==========================================================
   Status badges
========================================================== */
.dc-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.2;
}

.dc-badge::before {
    display: none;
}

.dc-badge.success { background-color: rgba(80, 199, 147, 0.15); color: #16a34a; }
.dc-badge.danger  { background-color: rgba(241, 89, 92, 0.15);  color: #dc2626; }
.dc-badge.warning { background-color: rgba(250, 145, 107, 0.15); color: #d97706; }
.dc-badge.info    { background-color: rgba(var(--dc-primary-rgb), 0.12); color: var(--dc-primary); }
.dc-badge.muted   { background-color: #eef2f6; color: var(--dc-text-muted); }

/* ==========================================================
   Table toolbar
========================================================== */
.dc-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--dc-border);
    flex-wrap: wrap;
}

.dc-toolbar .dc-toolbar-search {
    position: relative;
    flex: 1;
    max-width: 320px;
}

.dc-toolbar .dc-toolbar-search i {
    position: absolute;
    left: 0.85rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--dc-text-muted);
    font-size: 0.9rem;
}

.dc-toolbar .dc-toolbar-search input {
    height: 36px;
    width: 100%;
    border: 1px solid var(--dc-border);
    background-color: #fff;
    border-radius: var(--dc-radius-sm);
    padding: 0 0.85rem 0 2.2rem;
    font-size: 0.85rem;
    outline: none;
    transition: border-color var(--dc-transition), box-shadow var(--dc-transition);
}

.dc-toolbar .dc-toolbar-search input:focus {
    border-color: var(--dc-primary);
    box-shadow: 0 0 0 3px rgba(var(--dc-primary-rgb), 0.15);
}

.dc-toolbar .dc-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ==========================================================
   Pagination
========================================================== */
.dc-pagination-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem 1.25rem;
    border-top: 1px solid var(--dc-border);
    flex-wrap: wrap;
    gap: 0.75rem;
}

.dc-pagination-wrap .counter {
    color: var(--dc-text-muted);
    font-size: 0.82rem;
    margin: 0;
}

.dc-pagination {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    gap: 0.25rem;
    flex-wrap: wrap;
}

.dc-pagination li a,
.dc-pagination li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 0.6rem;
    border-radius: var(--dc-radius-sm);
    border: 1px solid var(--dc-border);
    color: var(--dc-text);
    font-size: 0.82rem;
    font-weight: 500;
    background-color: #fff;
    transition: background-color var(--dc-transition), color var(--dc-transition), border-color var(--dc-transition);
    text-decoration: none;
}

.dc-pagination li a:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
    border-color: var(--dc-primary-soft);
}

.dc-pagination li.active a,
.dc-pagination li.active span {
    background-color: var(--dc-primary);
    color: #fff;
    border-color: var(--dc-primary);
}

.dc-pagination li.disabled a,
.dc-pagination li.disabled span {
    color: var(--dc-text-muted);
    opacity: 0.55;
    pointer-events: none;
}

/* ==========================================================
   DataTables overrides (Bootstrap 5 integration)
========================================================== */
.dt-container {
    padding: 0.35rem 0.75rem 0.25rem;
}

.dt-container .dt-layout-row {
    margin: 0 -0.5rem 0.4rem;
}

/* Gap between the top action/search row (which contains the "+ New User"
   button — JS moves it into DataTables' topEnd slot) and the table headers
   that follow. */
.dt-container .dt-layout-row.dt-layout-start {
    margin-bottom: 1rem;
}

.dt-container .dt-layout-row.dt-layout-table {
    margin-bottom: 0;
}

/* Sit the table flush below whatever's above it (card header, search, etc.). */
div.dt-container div.dt-layout-table > div {
    display: block !important;
    margin-top: 0;
}

/* Collapse the empty top layout row that DataTables injects when the
   length-menu and built-in search are hidden — it was creating a gap. */
.dt-container .dt-layout-row.dt-layout-start:has(> .dt-layout-cell:empty) { display: none; }

.dt-container .dt-layout-cell { padding: 0 0.5rem; }

.dt-container .dt-length label,
.dt-container .dt-search label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.82rem;
    color: var(--dc-text-muted);
    margin: 0;
}

.dt-container .dt-length select {
    height: 34px;
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    padding: 0 2rem 0 0.75rem;
    background-color: #fff;
    font-size: 0.85rem;
    color: var(--dc-text);
    outline: none;
    min-width: 140px;
}

.dt-container .dt-length select:focus {
    border-color: var(--dc-primary);
    box-shadow: 0 0 0 3px rgba(var(--dc-primary-rgb), 0.15);
}

.dt-container .dt-search {
    text-align: right;
}

.dt-container .dt-search input {
    height: 40px;
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-sm);
    padding: 0 0.95rem 0 2.3rem;
    font-size: 0.95rem;
    min-width: 280px;
    outline: none;
    background-color: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2364748b'><path d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.868-3.834zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/></svg>") no-repeat 0.75rem center / 16px;
    margin-left: 0.5rem;
}

.dt-container .dt-search input:focus {
    border-color: var(--dc-primary);
    box-shadow: 0 0 0 3px rgba(var(--dc-primary-rgb), 0.15);
    background-color: #fff;
}

.dt-container .dt-info {
    color: var(--dc-text-muted);
    font-size: 0.9rem;
    padding-top: 0.25rem;
}

.dt-container table.dataTable {
    border-collapse: separate !important;
    border-spacing: 0;
    margin: 0 !important;
    width: 100% !important;
}

.dt-container table.dataTable.dc-table thead th,
table.dataTable.dc-table thead th {
    background-color: #1e3a8a !important;
    color: #ffffff !important;
    border-top: 1px solid var(--dc-border);
    text-align: center !important;
}

.dt-container table.dataTable.dc-table thead th a,
table.dataTable.dc-table thead th a { color: #ffffff !important; }

.dt-container table.dataTable.dc-table thead th .dt-column-header,
.dt-container table.dataTable.dc-table thead th .dt-column-title,
.dt-container table.dataTable.dc-table thead th > div {
    justify-content: center !important;
    text-align: center !important;
}

.dt-container .dt-paging {
    padding: 0.5rem 0 0.25rem;
}

.dt-container .dt-paging .pagination {
    margin: 0;
    display: inline-flex;
    gap: 0.25rem;
    flex-wrap: wrap;
}

.dt-container .dt-paging .page-item .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 0.6rem;
    border-radius: var(--dc-radius-sm);
    border: 1px solid var(--dc-border);
    background-color: #fff;
    color: var(--dc-text);
    font-size: 0.82rem;
    font-weight: 500;
    transition: background-color var(--dc-transition), color var(--dc-transition), border-color var(--dc-transition);
}

.dt-container .dt-paging .page-item .page-link:hover {
    background-color: var(--dc-primary-soft);
    color: var(--dc-primary);
    border-color: var(--dc-primary-soft);
}

.dt-container .dt-paging .page-item.active .page-link {
    background-color: var(--dc-primary);
    color: #fff;
    border-color: var(--dc-primary);
    box-shadow: 0 3px 8px rgba(var(--dc-primary-rgb), 0.25);
}

.dt-container .dt-paging .page-item.disabled .page-link {
    color: var(--dc-text-muted);
    opacity: 0.55;
    background-color: #fff;
}

/* Sort indicators */
table.dataTable thead .dt-orderable-asc,
table.dataTable thead .dt-orderable-desc {
    cursor: pointer;
}

table.dataTable thead .dt-ordering-asc span.dt-column-order::before,
table.dataTable thead .dt-ordering-desc span.dt-column-order::after {
    color: var(--dc-primary) !important;
    opacity: 1 !important;
}

table.dataTable thead .dt-column-order::before,
table.dataTable thead .dt-column-order::after {
    opacity: 0.4;
}

/* Hide DataTables sort indicator (dot/arrow) before column titles */
table.dataTable thead .dt-column-order { display: none !important; }

/* ==========================================================
   Cell truncation — long values (names, emails, addresses, etc.)
   are clipped with an ellipsis. Hover shows full value via title.
   Opt out per cell with class="no-truncate", or per column by
   not applying width constraints. The .actions column is excluded.
========================================================== */
.dc-table tbody td:not(.actions):not(.no-truncate) {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dc-table tbody td.actions { white-space: nowrap; }

@media (max-width: 1199.98px) {
    .dc-table tbody td:not(.actions):not(.no-truncate) { max-width: 170px; }
}
@media (max-width: 991.98px) {
    .dc-table tbody td:not(.actions):not(.no-truncate) { max-width: 130px; }
}

/* Helper class — apply manually to a span/strong/element inside a cell when
   you want truncation on inline content (e.g. wrapped in <strong>). */
.dc-truncate {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

/* Remove stock DataTables borders so .dc-table styling wins */
table.dataTable.dc-table > tbody > tr > td,
table.dataTable.dc-table > thead > tr > th {
    border-top: none;
}

/* ==========================================================
   Empty state
========================================================== */
.dc-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--dc-text-muted);
}

.dc-empty i {
    font-size: 2.4rem;
    opacity: 0.55;
    margin-bottom: 0.5rem;
}

/* ==========================================================
   Index page filters (per-page logic, shared visuals)
========================================================== */
.dc-filters {
    background: #f8fafc;
    padding: 0.85rem 1.1rem;
    border-bottom: 1px solid #e5e7eb;
}
.dc-filters .form-label {
    font-size: .72rem;
    font-weight: 600;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: .4px;
    margin-bottom: .25rem;
}
.dc-filters .form-control-sm,
.dc-filters .form-select-sm {
    font-size: .85rem;
    padding: .4rem .65rem;
    border-color: #e2e8f0;
    background-color: #fff;
}
.dc-filters .form-control-sm:focus,
.dc-filters .form-select-sm:focus {
    border-color: #1e3a8a;
    box-shadow: 0 0 0 .15rem rgba(30,58,138,.12);
}
.dc-filters .btn-sm {
    font-size: .8rem;
    padding: .4rem .85rem;
}
.dc-filters .dc-filter-actions {
    display: flex;
    gap: .35rem;
    justify-content: flex-end;
}
.dc-filters .select2-container--bootstrap-5 .select2-selection {
    min-height: calc(1.5em + .8rem + 2px);
    padding: .25rem .65rem;
    font-size: .85rem;
    border-color: #e2e8f0;
}

/* ==========================================================
   Responsive
========================================================== */
@media (max-width: 991.98px) {
    .dc-sidebar {
        transform: translateX(-100%);
    }

    .dc-main { margin-left: 0; }

    .dc-app.sidebar-mobile-open .dc-sidebar {
        transform: translateX(0);
        box-shadow: var(--dc-shadow);
    }

    .dc-app.sidebar-mobile-open::after {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.4);
        z-index: 1025;
    }

    .dc-search { display: none; }
    .dc-user .user-meta { display: none; }
}

/* ==========================================================
   Hide DebugKit floating toolbar (the cake logo at bottom)
========================================================== */
#debug-kit,
#debug-kit-toolbar,
iframe#debug-kit-toolbar,
html > #debug-kit { display: none !important; }

