/* 
   AdminX Premium Theme - UI Kit Overrides
   Inspired by vibrant, modern "doit" Dashboard Kit.
*/

:root {
  /* Core Brand Colors */
  --adminx-primary: #3d5afe;
  --adminx-primary-rgb: 61, 90, 254;
  --adminx-primary-hover: #2a4aff;
  
  --adminx-success: #00d084;
  --adminx-success-rgb: 0, 208, 132;
  
  --adminx-warning: #ffab00;
  --adminx-warning-rgb: 255, 171, 0;
  
  --adminx-danger: #ff4d4d;
  --adminx-danger-rgb: 255, 77, 77;
  
  --adminx-info: #3d5afe;
  --adminx-info-rgb: 61, 90, 254;
  
  --adminx-secondary: #475569;
  --adminx-secondary-rgb: 71, 85, 105;
  --adminx-secondary-hover: #334155;
  
  /* Background & Surfaces */
  --adminx-bg: #f4f7fe;
  --adminx-card-bg: #ffffff;
  --adminx-border-color: #f2f2f2;
  
  /* Spacing & Radius */
  --adminx-radius-lg: 16px;
  --adminx-radius-md: 10px;
  --adminx-radius-sm: 8px;
  
  /* Shadows */
  --adminx-shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
  --adminx-shadow-md: 0 10px 25px -5px rgba(0, 0, 0, 0.05), 0 8px 10px -6px rgba(0, 0, 0, 0.05);
  --adminx-shadow-primary: 0 10px 15px -3px rgba(var(--adminx-primary-rgb), 0.2);
}

/* --- Global Overrides --- */
body {
    background-color: var(--adminx-bg) !important;
    font-family: 'Poppins', sans-serif !important;
    color: #334155 !important;
}

/* --- Text Color Overrides --- */
.text-info {
  color: var(--adminx-info) !important;
}

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

/* --- SweetAlert2 Font Size Standardization --- */
.swal2-container .swal2-popup {
  font-size: 0.875rem !important; /* 14px */
}

.swal2-container .swal2-popup .swal2-title {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    padding: 0 15px;
}

.swal2-container .swal2-popup .swal2-html-container {
  font-size: 0.875rem !important; /* 14px */
  font-weight: 400 !important;
  line-height: 1.5 !important;
  margin: 0.5em 1em !important;
}

/* --- Cards Styling --- */
.card {
    border: none !important;
    border-radius: var(--adminx-radius-lg) !important;
    /* box-shadow: var(--adminx-shadow-md) !important; */
    background-color: var(--adminx-card-bg) !important;
    /* overflow: hidden; */
    /* margin-bottom: 24px !important; */
}

.card-header {
    background-color: transparent !important;
    border-bottom: 1px solid var(--adminx-border-color) !important;
    padding: 20px 24px !important;
}

.card-header .card-title {
    font-weight: 700 !important;
    color: #1e293b !important;
    font-size: 1.1rem !important;
}

/* User Profile in Topbar */
.topbar-user {
    background-color: transparent !important;
    border: none !important;
    padding: 0 8px !important;
    height: 60px !important;
    display: flex !important;
    align-items: center !important;
}

#page-header-user-dropdown {
    padding: 6px 12px !important;
    border-radius: 12px !important;
    transition: all 0.2s ease !important;
}

#page-header-user-dropdown:hover {
    background-color: #f1f5f9 !important;
}

.header-profile-user {
    height: 38px !important;
    width: 38px !important;
    border: 2px solid #ffffff !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05) !important;
    object-fit: cover !important;
}

.user-name-text {
    font-weight: 700 !important;
    color: #334155 !important;
    font-size: 0.875rem !important;
    margin-left: 4px !important;
}

.card-body {
    padding: 25px;
}

/* --- Button Styling --- */
.btn,
button.btn,
a.btn,
input.btn {
    border-radius: var(--adminx-radius-md) !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    min-height: 42px !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.btn-primary,
button.btn-primary,
a.btn-primary,
.btn-primary-custom {
    background-color: var(--adminx-primary) !important;
    border-color: var(--adminx-primary) !important;
    color: #ffffff !important;
    box-shadow: var(--adminx-shadow-primary) !important;
}

.btn-primary:hover,
button.btn-primary:hover,
a.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--adminx-primary-hover) !important;
    border-color: var(--adminx-primary-hover) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 20px rgba(var(--adminx-primary-rgb), 0.2) !important;
}

.btn-success,
button.btn-success,
a.btn-success {
    background-color: var(--adminx-success) !important;
    border-color: var(--adminx-success) !important;
    color: #ffffff !important;
}

.btn-success:hover,
.btn-success:focus,
.btn-success:active {
    background-color: #00bc77 !important;
    border-color: #00bc77 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

.btn-danger,
button.btn-danger,
a.btn-danger {
    background-color: var(--adminx-danger) !important;
    border-color: var(--adminx-danger) !important;
    color: #ffffff !important;
}

.btn-danger:hover,
.btn-danger:focus,
.btn-danger:active {
    background-color: #ff3333 !important;
    border-color: #ff3333 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

.btn-secondary,
button.btn-secondary,
a.btn-secondary {
    background-color: var(--adminx-secondary) !important;
    border-color: var(--adminx-secondary) !important;
    color: #ffffff !important;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active {
    background-color: var(--adminx-secondary-hover) !important;
    border-color: var(--adminx-secondary-hover) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

.btn-light,
.btn-soft-secondary,
button.btn-light {
    background-color: #f1f5f9 !important;
    border-color: transparent !important;
    color: #475569 !important;
}

.btn-light:hover,
.btn-soft-secondary:hover,
.btn-light:focus,
.btn-light:active {
    background-color: #e2e8f0 !important;
    border-color: transparent !important;
    color: var(--adminx-primary) !important;
    transform: translateY(-2px) !important;
}

/* Info Button */
.btn-info,
button.btn-info,
a.btn-info {
    background-color: var(--adminx-info) !important;
    border-color: var(--adminx-info) !important;
    color: #ffffff !important;
}

.btn-info:hover,
.btn-info:focus,
.btn-info:active {
    background-color: #2a4aff !important;
    border-color: #2a4aff !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

/* Warning Button */
.btn-warning,
button.btn-warning,
a.btn-warning {
    background-color: var(--adminx-warning) !important;
    border-color: var(--adminx-warning) !important;
    color: #ffffff !important;
}

.btn-warning:hover,
.btn-warning:focus,
.btn-warning:active {
    background-color: #ff9900 !important;
    border-color: #ff9900 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

/* Dark Button */
.btn-dark,
button.btn-dark,
a.btn-dark {
    background-color: #1e293b !important;
    border-color: #1e293b !important;
    color: #ffffff !important;
}

.btn-dark:hover,
.btn-dark:focus,
.btn-dark:active {
    background-color: #0f172a !important;
    border-color: #0f172a !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
}

/* Link Button */
.btn-link,
button.btn-link,
a.btn-link {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-primary) !important;
    text-decoration: none !important;
}

.btn-link:hover,
.btn-link:focus,
.btn-link:active {
    background-color: rgba(var(--adminx-primary-rgb), 0.1) !important;
    color: var(--adminx-primary-hover) !important;
    text-decoration: none !important;
}

/* Outline Buttons */
.btn-outline-primary {
    background-color: transparent !important;
    border-color: var(--adminx-primary) !important;
    color: var(--adminx-primary) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    background-color: var(--adminx-primary) !important;
    border-color: var(--adminx-primary) !important;
    color: #ffffff !important;
}

.btn-outline-secondary {
    background-color: transparent !important;
    border-color: var(--adminx-secondary) !important;
    color: var(--adminx-secondary) !important;
}

.btn-outline-secondary:hover {
    background-color: var(--adminx-secondary) !important;
    border-color: var(--adminx-secondary) !important;
    color: #ffffff !important;
}

.btn-outline-success {
    background-color: transparent !important;
    border-color: var(--adminx-success) !important;
    color: var(--adminx-success) !important;
}

.btn-outline-success:hover {
    background-color: var(--adminx-success) !important;
    border-color: var(--adminx-success) !important;
    color: #ffffff !important;
}

.btn-outline-info {
    background-color: transparent !important;
    border-color: var(--adminx-info) !important;
    color: var(--adminx-info) !important;
}

.btn-outline-info:hover {
    background-color: var(--adminx-info) !important;
    border-color: var(--adminx-info) !important;
    color: #ffffff !important;
}

.btn-outline-warning {
    background-color: transparent !important;
    border-color: var(--adminx-warning) !important;
    color: var(--adminx-warning) !important;
}

.btn-outline-warning:hover {
    background-color: var(--adminx-warning) !important;
    border-color: var(--adminx-warning) !important;
    color: #ffffff !important;
}

.btn-outline-danger {
    background-color: transparent !important;
    border-color: var(--adminx-danger) !important;
    color: var(--adminx-danger) !important;
}

.btn-outline-danger:hover {
    background-color: var(--adminx-danger) !important;
    border-color: var(--adminx-danger) !important;
    color: #ffffff !important;
}

.btn-outline-dark {
    background-color: transparent !important;
    border-color: #1e293b !important;
    color: #1e293b !important;
}

.btn-outline-dark:hover {
    background-color: #1e293b !important;
    border-color: #1e293b !important;
    color: #ffffff !important;
}

/* Soft Buttons */
.btn-soft-primary {
    background-color: rgba(var(--adminx-primary-rgb), 0.1) !important;
    border-color: transparent !important;
    color: var(--adminx-primary) !important;
}

.btn-soft-primary:hover {
    background-color: rgba(var(--adminx-primary-rgb), 0.2) !important;
    color: var(--adminx-primary) !important;
}

.btn-soft-success {
    background-color: rgba(var(--adminx-success-rgb), 0.1) !important;
    border-color: transparent !important;
    color: var(--adminx-success) !important;
}

.btn-soft-success:hover {
    background-color: rgba(var(--adminx-success-rgb), 0.2) !important;
    color: var(--adminx-success) !important;
}

.btn-soft-info {
    background-color: rgba(var(--adminx-info-rgb), 0.1) !important;
    border-color: transparent !important;
    color: var(--adminx-info) !important;
}

.btn-soft-info:hover {
    background-color: rgba(var(--adminx-info-rgb), 0.2) !important;
    color: var(--adminx-info) !important;
}

.btn-soft-warning {
    background-color: rgba(var(--adminx-warning-rgb), 0.1) !important;
    border-color: transparent !important;
    color: var(--adminx-warning) !important;
}

.btn-soft-warning:hover {
    background-color: rgba(var(--adminx-warning-rgb), 0.2) !important;
    color: var(--adminx-warning) !important;
}

.btn-soft-danger {
    background-color: rgba(var(--adminx-danger-rgb), 0.1) !important;
    border-color: transparent !important;
    color: var(--adminx-danger) !important;
}

.btn-soft-danger:hover {
    background-color: rgba(var(--adminx-danger-rgb), 0.2) !important;
    color: var(--adminx-danger) !important;
}

.btn-soft-dark {
    background-color: rgba(30, 41, 59, 0.1) !important;
    border-color: transparent !important;
    color: #1e293b !important;
}

.btn-soft-dark:hover {
    background-color: rgba(30, 41, 59, 0.2) !important;
    color: #1e293b !important;
}

/* Ghost Buttons */
.btn-ghost-primary {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-primary) !important;
}

.btn-ghost-primary:hover {
    background-color: rgba(var(--adminx-primary-rgb), 0.1) !important;
    color: var(--adminx-primary) !important;
}

.btn-ghost-secondary {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-secondary) !important;
}

.btn-ghost-secondary:hover {
    background-color: rgba(var(--adminx-secondary-rgb), 0.1) !important;
    color: var(--adminx-secondary) !important;
}

.btn-ghost-success {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-success) !important;
}

.btn-ghost-success:hover {
    background-color: rgba(var(--adminx-success-rgb), 0.1) !important;
    color: var(--adminx-success) !important;
}

.btn-ghost-info {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-info) !important;
}

.btn-ghost-info:hover {
    background-color: rgba(var(--adminx-info-rgb), 0.1) !important;
    color: var(--adminx-info) !important;
}

.btn-ghost-warning {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-warning) !important;
}

.btn-ghost-warning:hover {
    background-color: rgba(var(--adminx-warning-rgb), 0.1) !important;
    color: var(--adminx-warning) !important;
}

.btn-ghost-danger {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--adminx-danger) !important;
}

.btn-ghost-danger:hover {
    background-color: rgba(var(--adminx-danger-rgb), 0.1) !important;
    color: var(--adminx-danger) !important;
}

.btn-ghost-dark {
    background-color: transparent !important;
    border-color: transparent !important;
    color: #1e293b !important;
}

.btn-ghost-dark:hover {
    background-color: rgba(30, 41, 59, 0.1) !important;
    color: #1e293b !important;
}

/* Rounded Pills */
.btn.rounded-pill {
    border-radius: 50rem !important;
}

/* --- Badge & Status Styling --- */
.badge {
    padding: 6px 12px !important;
    border-radius: var( --adminx-radius-sm);
    font-weight: 600 !important;
    text-transform: capitalize !important;
}

.badge-gradient-success {
    background: rgba(var(--adminx-success-rgb), 0.1) !important;
    color: var(--adminx-success) !important;
}

.badge-gradient-info {
    background: rgba(var(--adminx-primary-rgb), 0.1) !important;
    color: var(--adminx-primary) !important;
}

.badge-gradient-warning {
    background: rgba(var(--adminx-warning-rgb), 0.1) !important;
    color: var(--adminx-warning) !important;
}

.badge-gradient-danger {
    background: rgba(var(--adminx-danger-rgb), 0.1) !important;
    color: var(--adminx-danger) !important;
}

/* --- Form Elements --- */
.form-control, .form-select {
    border-radius: var(--adminx-radius-md) !important;
    border: 1px solid #e2e8f0 !important;
    padding: 10px 15px !important;
    background-color: #ffffff !important;
    min-height: 42px !important;
    transition: all 0.2s ease !important;
}

.form-control:focus, .form-select:focus {
    border-color: var(--adminx-primary) !important;
    box-shadow: 0 0 0 4px rgba(var(--adminx-primary-rgb), 0.1) !important;
}

.search-box .form-control {
    padding-left: 45px !important;
    background-color: #fff !important;
}

.search-box .search-icon {
    left: 16px !important;
    color: #94a3b8 !important;
    font-size: 18px !important;
}

/* Modern Search Box */
.search-box-custom {
    position: relative;
    width: 100%;
}

.search-box-custom .form-control {
    padding-left: 45px !important;
    background-color: #fff !important;
    border-radius: var(--adminx-radius-md) !important;
}

.search-box-custom .search-icon {
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: #94a3b8 !important;
    font-size: 18px !important;
    pointer-events: none !important;
}

/* Choices.js Global Overrides */
.choices {
    margin-bottom: 0 !important;
    border-radius: var(--adminx-radius-md) !important;
}

.choices__inner {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: var(--adminx-radius-md) !important;
    min-height: 42px !important;
    padding: 0 12px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    transition: all 0.2s ease !important;
    font-size: 14px !important;
}

.choices[is-focused] .choices__inner {
    border-color: var(--adminx-primary) !important;
    box-shadow: 0 0 0 4px rgba(var(--adminx-primary-rgb), 0.1) !important;
}

.choices__list--single {
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    /* min-height: 40px !important; */
}

.choices__list--dropdown {
    border-radius: var(--adminx-radius-md) !important;
    box-shadow: var(--adminx-shadow-md) !important;
    border: 1px solid #e2e8f0 !important;
    margin-top: 8px !important;
    overflow: hidden !important;
    z-index: 1001 !important;
}

.choices__list--single .choices__item {
    padding: 0 !important;
    font-size: 14px !important;
}

.choices__item--selectable {
    padding: 6px 16px !important;
    font-size: 14px !important;
}

.choices__item--selectable.is-highlighted {
    background-color: #f1f5f9 !important;
    color: var(--adminx-primary) !important;
}

/* Fix Choices.js search input */
.choices__input {
    background-color: #fff !important;
    padding: 8px 12px !important;
    margin-bottom: 0 !important;
    font-size: 14px !important;
    border: 1px solid #dee2e6 !important;
    border-radius: 6px !important;
}

.choices[data-type*='select-one'] .choices__input {
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
}

.choices__list--dropdown .choices__input {
    background-color: #fff !important;
    border: 1px solid #dee2e6 !important;
    padding: 8px 12px !important;
    margin: 8px 8px 4px 8px !important;
    border-radius: 6px !important;
}

/* Choices.js Multi-select Items */
.choices .choices__inner .choices__list--multiple .choices__item {
    background-color: rgba(var(--adminx-primary-rgb), 0.1) !important;
    border: 1px solid rgba(var(--adminx-primary-rgb), 0.1) !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 2px 8px !important;
    margin: 3px 6px 3px 0 !important;
    color: var(--adminx-primary) !important;
    display: inline-flex !important;
    align-items: center !important;
}

.choices .choices__inner .choices__list--multiple .choices__item[data-deletable] {
    padding-right: 5px !important;
}

.choices .choices__inner .choices__list--multiple .choices__item .choices__button {
    border-left: 1px solid rgba(var(--adminx-primary-rgb), 0.2) !important;
    margin-left: 8px !important;
    padding-left: 8px !important;
    opacity: 0.6 !important;
    filter: none !important;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233d5afe' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") !important;
    background-size: 10px !important;
    background-position: center !important;
}

.choices__list--multiple .choices__item .choices__button:hover {
    opacity: 1 !important;
}

.choices__input {
    background-color: transparent !important;
    padding: 0 !important;
    margin: 3px 0 !important;
    font-size: 14px !important;
    color: #1e293b !important;
    min-width: 120px !important;
    border: none !important;
}

.choices__list--multiple .choices__input {
    margin: 3px 0 !important;
    padding: 2px 0 !important;
}

.choices__input::placeholder {
    color: #94a3b8 !important;
    opacity: 0.8 !important;
}

.choices__list--multiple {
    display: inline-flex !important;
    flex-wrap: wrap !important;
    padding: 0 !important;
}

/* Checkboxes & Radios (Premium style) */
.form-check {
    display: flex !important;
    align-items: center !important;
    padding-left: 0 !important;
    gap: 8px !important;
    min-height: 24px !important;
}

.form-check-input {
    width: 20px !important;
    height: 20px !important;
    border-radius: 6px !important;
    border: 2px solid #cbd5e1 !important;
    margin: 0 !important;
    cursor: pointer !important;
    position: relative;
    flex-shrink: 0 !important;
}

.form-check-input[type="radio"] {
    border-radius: 50% !important; /* Circular for radio */
}

.form-check-input:checked {
    background-color: var(--adminx-primary) !important;
    border-color: var(--adminx-primary) !important;
}

.form-check-input:checked[type="radio"]::after {
    content: "" !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 8px !important;
    height: 8px !important;
    background-color: white !important;
    border-radius: 50% !important;
}

.form-check-label {
    cursor: pointer !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    margin: 0 !important;
    color: #334155 !important;
}

/* --- Table Styling --- */
.table-responsive {
    border: none !important;
    /* padding: 4px !important; */
}

.table {
    border-collapse: separate !important;
    border-spacing: 0 8px !important;
    width: 100% !important;
}

.table thead th {
    background-color: #f8fafc !important;
    border: none !important;
    padding: 12px 20px !important;
    color: #64748b !important;
    font-weight: 800 !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    vertical-align: middle !important;
}

.table thead th:first-child {
    border-top-left-radius: var(--adminx-radius-md) !important;
    border-bottom-left-radius: var(--adminx-radius-md) !important;
}

.table thead th:last-child {
    border-top-right-radius: var(--adminx-radius-md) !important;
    border-bottom-right-radius: var(--adminx-radius-md) !important;
}

.table tbody tr {
    transition: all 0.2s ease;
}

.table tbody td {
    background-color: #ffffff !important;
    padding: 10px !important;
    border-top: 1px solid var(--adminx-border-color) !important;
    border-bottom: 1px solid var(--adminx-border-color) !important;
}

.dt-container .dt-info {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dt-container .row.p-2:has(.dt-info) > .col-sm-6.col-md-3:first-child {
    padding-left: 0;    
}


/* Empty State / No Results */
.no-results {
    padding: 3rem 1rem !important;
}

.no-results img {
    margin-bottom: 1.5rem;
    filter: grayscale(0.2) opacity(0.8);
}

.no-results p {
    color: #64748b;
    font-weight: 500;
}

.table tbody td:first-child {
    border-left: 1px solid var(--adminx-border-color) !important;
    border-top-left-radius: var(--adminx-radius-md);
    border-bottom-left-radius: var(--adminx-radius-md);
}

.table tbody td:last-child {
    border-right: 1px solid var(--adminx-border-color) !important;
    border-top-right-radius: var(--adminx-radius-md);
    border-bottom-right-radius: var(--adminx-radius-md);
}

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

/* --- Modern Nav Style (Standardized) --- */
.nav-tabs-modern {
    background: #f1f5f9 !important;
    padding: 6px !important;
    border-radius: var(--adminx-radius-md) !important;
    display: inline-flex !important;
    /* border: 1px solid #e2e8f0 !important; */
    /* margin-bottom: 0px !important; */
}

.nav-tabs-modern .nav-link {
    color: #64748b !important;
    font-weight: 600 !important;
    padding: 6px 16px !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--adminx-radius-sm) !important;
    transition: all 0.2s !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 34px !important;
}

.nav-tabs-modern .nav-link:hover {
    color: var(--adminx-primary) !important;
}

.nav-tabs-modern .nav-link.active {
    color: var(--adminx-primary) !important;
    background: #ffffff !important;
    box-shadow: var(--adminx-shadow-sm) !important;
    font-weight: 700 !important;
}

/* --- Pagination & DataTables Controls --- */
.dataTables_wrapper .dataTables_paginate {
    margin-top: 15px !important;
    padding-top: 10px !important;
}

.pagination {
    gap: 6px !important;
    margin: 0 !important;
}

.page-item .page-link {
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    color: #64748b !important;
    transition: all 0.2s ease !important;
    background-color: #ffffff !important;
    min-width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}

.page-item.active .page-link {
    background-color: var(--adminx-primary) !important;
    border-color: var(--adminx-primary) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 10px rgba(var(--adminx-primary-rgb), 0.2) !important;
}

.page-item.disabled .page-link {
    background-color: #f8fafc !important;
    color: #cbd5e1 !important;
    border-color: #e2e8f0 !important;
}

.page-item:not(.active):not(.disabled) .page-link:hover {
    background-color: #f1f5f9 !important;
    color: var(--adminx-primary) !important;
    border-color: #cbd5e1 !important;
}

/* Entries per page (Length Menu) */
.dataTables_length {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 0.875rem !important;
    color: #64748b !important;
    font-weight: 500;
}

.dataTables_length select,
select[name*="_length"],
select.form-select.search_module,
select.form-control.search_module {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding-left: 14px !important;
    padding-right: 38px !important;
    height: 40px !important;
    line-height: normal !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: #334155 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 14px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    outline: none !important;
    text-align: left !important;
    box-sizing: border-box !important;
}

/* Specific layout for DataTables length select only */
.dataTables_length select,
select[name*="_length"] {
    min-width: 85px !important;
    width: 85px !important;
    display: inline-block !important;
    vertical-align: middle !important;
}

.dataTables_length select:focus {
    border-color: var(--adminx-primary) !important;
    box-shadow: 0 0 0 4px rgba(var(--adminx-primary-rgb), 0.1) !important;
    outline: none !important;
}

.dataTables_info {
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    color: #64748b !important;
    margin-top: 15px !important;
}

/* Row alignment for DataTables footer */
.dataTables_wrapper .row:last-child {
    margin-top: 15px !important;
    align-items: center !important;
}

/* Fallback for raw DataTables buttons if not using Bootstrap */
.dataTables_paginate .paginate_button {
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
    margin-left: 5px !important;
    cursor: pointer !important;
    font-weight: 600 !important;
    color: #64748b !important;
    background: #fff !important;
    transition: all 0.2s ease !important;
}

.dataTables_paginate .paginate_button.current {
    background: var(--adminx-primary) !important;
    color: #fff !important;
    border-color: var(--adminx-primary) !important;
}

.dataTables_paginate .paginate_button:hover:not(.current) {
    background: #f1f5f9 !important;
    color: var(--adminx-primary) !important;
}

/* --- Sidebar Styling --- */
.navbar-menu {
    border-right: 1px solid var(--adminx-border-color) !important;
    background-color: #ffffff !important;
    transition: all 0.3s ease !important;
}

.navbar-brand-box {
    padding: 16px 24px !important;
    height: 70px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    transition: all 0.3s ease !important;
}

.navbar-nav {
    padding: 0 !important;
    margin-bottom: 10px !important;
}

.navbar-nav .nav-item {
    padding: 0 16px !important;
}

.navbar-nav .nav-link {
    margin: 4px 0 !important;
    height: 48px !important;
    border-radius: var(--adminx-radius-md) !important;
    padding: 0 16px !important;
    font-weight: 500 !important;
    color: #64748b !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    transition: all 0.2s ease !important;
    overflow: hidden !important;
    white-space: nowrap !important;
}

.navbar-nav .nav-link i {
    font-size: 1.25rem !important;
    min-width: 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-right: 0 !important;
    flex-shrink: 0 !important;
}

.navbar-nav .nav-link span {
    transition: opacity 0.2s ease !important;
}

.navbar-nav .nav-link.active {
    background-color: var(--adminx-primary) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 16px rgba(var(--adminx-primary-rgb), 0.2) !important;
}

.navbar-nav .nav-link.active i {
    color: #ffffff !important;
}

.navbar-nav .nav-link:hover:not(.active) {
    background-color: #f1f5f9 !important;
    color: var(--adminx-primary) !important;
}

.navbar-nav .nav-link:hover:not(.active) i {
    color: var(--adminx-primary) !important;
}

.navbar-menu .navbar-nav .nav-link{
    font-family: 'Poppins', sans-serif !important;
}

/* Sidebar menu title */
.menu-title {
    font-size: 0.7rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    font-weight: 800 !important;
    color: #94a3b8 !important;
    background: transparent !important;
    transition: all 0.3s ease !important;
}

/* --- Responsive Sidebar (Small Mode) --- */
html[data-sidebar-size="sm"] .navbar-menu {
    width: 70px !important;
}

html[data-sidebar-size="sm"] .navbar-brand-box {
    padding: 10px !important;
    justify-content: center !important;
}

html[data-sidebar-size="sm"] .navbar-brand-box .logo-lg {
    display: none !important;
}

html[data-sidebar-size="sm"] .navbar-brand-box .logo-sm {
    display: block !important;
}

html[data-sidebar-size="sm"] .navbar-nav .nav-item {
    padding: 0 8px !important;
}

html[data-sidebar-size="sm"] .navbar-nav .nav-link {
    padding: 0 !important;
    justify-content: center !important;
    width: 48px !important;
    margin: 4px auto !important;
}

html[data-sidebar-size="sm"] .navbar-nav .nav-link span,
html[data-sidebar-size="sm"] .navbar-nav .menu-title span {
    display: none !important;
}

html[data-sidebar-size="sm"] .menu-title {
    /* padding: 24px 0 10px !important; */
    text-align: center !important;
}

html[data-sidebar-size="sm"] .menu-title i {
    display: block !important;
}

/* --- Header / Topbar --- */
#page-topbar {
    background-color: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid rgba(0,0,0,0.05) !important;
    box-shadow: none !important;
    transition: all 0.3s ease;
    z-index: 1002 !important;
    height: 60px !important; /* Slightly thinner header */
}

.navbar-header {
    height: 60px !important;
    padding: 0 20px !important;
}

/* Hamburger Icon Tweak - Simplify to restore default Velzon behavior */
.hamburger-icon span {
    background-color: #64748b !important;
}

.topnav-hamburger {
    color: #64748b !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    transition: all 0.2s ease !important;
    background: transparent !important;
    border: none !important;
    /* margin-left: 8px !important; */
}

.topnav-hamburger:hover {
    background-color: #f1f5f9 !important;
    color: var(--adminx-primary) !important;
}

/* --- Breadcrumb Styling --- */
.page-title-box {
    background-color: transparent !important;
    padding: 12px 0 !important;
    margin: 0 !important;
    border-bottom: none !important; /* Remove the ugly line */
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.page-title-box h4 {
    font-weight: 700 !important;
    font-size: 1.25rem !important;
    color: #1a1d21 !important;
    text-transform: none !important; /* Not all caps */
    letter-spacing: -0.02em !important;
    margin: 0 !important;
}

/* Permission Group Choices Customization */
.choices__list--dropdown .choices__item--choice:hover,
.choices__list--dropdown .choices__item--choice.is-highlighted {
    background-color: #e8f0fe !important;
    color: #165b9a !important;
    cursor: pointer;
}
.choices__list--dropdown .choices__item--choice {
    transition: background-color 0.1s ease;
}

/* User Status Badge */
.breadcrumb {
    background-color: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

.breadcrumb-item {
    font-size: 0.85rem !important;
    display: flex !important;
    align-items: center !important;
}

.breadcrumb-item a {
    color: #878a99 !important;
    font-weight: 500 !important;
    transition: all 0.2s ease;
    text-decoration: none !important;
}

.breadcrumb-item a:hover {
    color: var(--adminx-primary) !important;
}

.breadcrumb-item.active,
.breadcrumb-item a.active {
    color: var(--adminx-primary) !important;
    font-weight: 600 !important;
}

/* Fix the separator - use a simple clean bullet or chevron */
.breadcrumb-item + .breadcrumb-item::before {
    content: "\f0142" !important; /* Material Design Chevron mini */
    font-family: "Material Design Icons" !important;
    font-size: 16px !important;
    line-height: 1 !important;
    color: #cbd5e1 !important;
    padding: 0 8px !important;
    float: none !important;
    vertical-align: middle !important;
}

#page-topbar {
    height: 70px !important;
    background-color: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid rgba(0,0,0,0.05) !important;
    box-shadow: none !important; /* Clean look */
}

.navbar-header {
    height: 70px !important;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}


.page-title-box{
    box-shadow: none;
    margin-bottom: 6px !important;
}

/* Avatar control */
.avatar-title.image-control{
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #e7f3ff !important;
    color: #0c63e4 !important;
    border-radius: 50% !important;
    border: 3px solid white !important;
    box-shadow: none !important;
 }

/* Choices js */
.choices__list--dropdown, .choices__list[aria-expanded] {
    word-break: break-word;
    width: max-content;
}

.choices__inner {
    padding: 0 35px 0 12px !important;
}