/*
 * AurBoss Redesign Design System
 * Version: 1.0.0
 *
 * Layered on top of AdminLTE v2 + Bootstrap 3.
 * All component classes use the `ab-` prefix to avoid conflicts.
 * Mobile-first: base styles target small screens, min-width queries scale up.
 * RTL-compatible via logical properties and [dir="rtl"] overrides.
 */

/* ==========================================================================
   1. Design Tokens (CSS Custom Properties)
   ========================================================================== */

:root {
  /* --- Primary palette --- */
  --ab-primary-50:  #EEF4FF;
  --ab-primary-100: #DBEAFE;
  --ab-primary-200: #BFDBFE;
  --ab-primary-500: #3B82F6;
  --ab-primary-600: #2563EB;
  --ab-primary-700: #1D4ED8;
  --ab-primary-800: #1E40AF;
  --ab-primary-900: #1E3A5F;

  /* --- Surface --- */
  --ab-surface-bg:           #F8FAFC;
  --ab-surface-card:         #FFFFFF;
  --ab-surface-hover:        #F1F5F9;
  --ab-surface-border:       #E2E8F0;
  --ab-surface-border-light: #F1F5F9;

  /* --- Text --- */
  --ab-text-primary:   #0F172A;
  --ab-text-secondary: #475569;
  --ab-text-tertiary:  #94A3B8;
  --ab-text-inverse:   #FFFFFF;

  /* --- Status: Paid / Success --- */
  --ab-status-paid-bg:     #F0FDF4;
  --ab-status-paid-text:   #15803D;
  --ab-status-paid-border: #BBF7D0;
  --ab-status-paid-dot:    #22C55E;

  /* --- Status: Due / Warning --- */
  --ab-status-due-bg:     #FFF7ED;
  --ab-status-due-text:   #C2410C;
  --ab-status-due-border: #FED7AA;
  --ab-status-due-dot:    #F97316;

  /* --- Status: Partial / Info --- */
  --ab-status-partial-bg:     #EFF6FF;
  --ab-status-partial-text:   #1D4ED8;
  --ab-status-partial-border: #BFDBFE;
  --ab-status-partial-dot:    #3B82F6;

  /* --- Status: Overdue / Danger --- */
  --ab-status-overdue-bg:     #FEF2F2;
  --ab-status-overdue-text:   #DC2626;
  --ab-status-overdue-border: #FECACA;
  --ab-status-overdue-dot:    #EF4444;

  /* --- Status: Draft / Neutral --- */
  --ab-status-draft-bg:     #F8FAFC;
  --ab-status-draft-text:   #475569;
  --ab-status-draft-border: #E2E8F0;
  --ab-status-draft-dot:    #94A3B8;

  /* --- Spacing scale --- */
  --ab-space-xs:  4px;
  --ab-space-sm:  8px;
  --ab-space-md:  12px;
  --ab-space-lg:  16px;
  --ab-space-xl:  20px;
  --ab-space-2xl: 24px;
  --ab-space-3xl: 32px;

  /* --- Border radius --- */
  --ab-radius-sm:   6px;
  --ab-radius-md:   10px;
  --ab-radius-lg:   14px;
  --ab-radius-xl:   18px;
  --ab-radius-full: 9999px;

  /* --- Shadows --- */
  --ab-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --ab-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.07), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --ab-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.08), 0 4px 6px -4px rgba(0, 0, 0, 0.04);

  /* --- Font sizes --- */
  --ab-text-xs:   11.5px;
  --ab-text-sm:   12px;
  --ab-text-base: 13.5px;
  --ab-text-md:   14px;
  --ab-text-lg:   16px;
  --ab-text-xl:   20px;
  --ab-text-2xl:  24px;

  /* --- Transitions --- */
  --ab-transition: all 0.15s ease;
}


/* --------------------------------------------------------------------------
   Global: prevent horizontal overflow on mobile
   -------------------------------------------------------------------------- */

html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* Main layout flex container must not exceed viewport */
.tw-flex.tw-min-h-screen {
  max-width: 100vw;
  overflow-x: hidden;
}

/* ==========================================================================
   2. Components
   ========================================================================== */

/* --------------------------------------------------------------------------
   a) Card
   -------------------------------------------------------------------------- */

.ab-card {
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  padding: var(--ab-space-lg);
  transition: var(--ab-transition);
}

@media (min-width: 768px) {
  .ab-card {
    padding: var(--ab-space-xl);
  }
}

@media (min-width: 1024px) {
  .ab-card {
    padding: var(--ab-space-2xl);
  }
}


/* --------------------------------------------------------------------------
   b) Status Badge
   -------------------------------------------------------------------------- */

.ab-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: var(--ab-radius-full);
  font-size: var(--ab-text-xs);
  font-weight: 600;
  line-height: 1.4;
  white-space: nowrap;
  border: 1px solid transparent;
  transition: var(--ab-transition);
}

.ab-status-badge::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Paid / Success */
.ab-status-paid {
  background: var(--ab-status-paid-bg);
  color: var(--ab-status-paid-text);
  border-color: var(--ab-status-paid-border);
}
.ab-status-paid::before {
  background: var(--ab-status-paid-dot);
}

/* Due / Warning */
.ab-status-due {
  background: var(--ab-status-due-bg);
  color: var(--ab-status-due-text);
  border-color: var(--ab-status-due-border);
}
.ab-status-due::before {
  background: var(--ab-status-due-dot);
}

/* Partial / Info */
.ab-status-partial {
  background: var(--ab-status-partial-bg);
  color: var(--ab-status-partial-text);
  border-color: var(--ab-status-partial-border);
}
.ab-status-partial::before {
  background: var(--ab-status-partial-dot);
}

/* Overdue / Danger */
.ab-status-overdue {
  background: var(--ab-status-overdue-bg);
  color: var(--ab-status-overdue-text);
  border-color: var(--ab-status-overdue-border);
}
.ab-status-overdue::before {
  background: var(--ab-status-overdue-dot);
}

/* Draft / Neutral */
.ab-status-draft {
  background: var(--ab-status-draft-bg);
  color: var(--ab-status-draft-text);
  border-color: var(--ab-status-draft-border);
}
.ab-status-draft::before {
  background: var(--ab-status-draft-dot);
}

/* Final — alias for Paid styling */
.ab-status-final {
  background: var(--ab-status-paid-bg);
  color: var(--ab-status-paid-text);
  border-color: var(--ab-status-paid-border);
}
.ab-status-final::before {
  background: var(--ab-status-paid-dot);
}

/* Ordered — alias for Partial/Info styling */
.ab-status-ordered {
  background: var(--ab-status-partial-bg);
  color: var(--ab-status-partial-text);
  border-color: var(--ab-status-partial-border);
}
.ab-status-ordered::before {
  background: var(--ab-status-partial-dot);
}


/* --------------------------------------------------------------------------
   c) Filter Pill
   -------------------------------------------------------------------------- */

.ab-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--ab-radius-full);
  font-size: var(--ab-text-sm);
  font-weight: 500;
  color: var(--ab-text-secondary);
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border);
  cursor: pointer;
  white-space: nowrap;
  transition: var(--ab-transition);
  user-select: none;
}

.ab-filter-pill:hover {
  background: var(--ab-surface-hover);
  border-color: var(--ab-primary-200);
  color: var(--ab-text-primary);
}

.ab-filter-pill.active {
  background: var(--ab-primary-50);
  border-color: var(--ab-primary-200);
  color: var(--ab-primary-700);
  font-weight: 600;
}


/* --------------------------------------------------------------------------
   d) Search Input
   -------------------------------------------------------------------------- */

.ab-search-input {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 320px;
}

.ab-search-input .ab-search-icon {
  position: absolute;
  inset-inline-start: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ab-text-tertiary);
  font-size: var(--ab-text-md);
  pointer-events: none;
  line-height: 1;
}

.ab-search-input input {
  width: 100%;
  padding: 8px 12px;
  padding-inline-start: 36px;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-md);
  font-size: var(--ab-text-base);
  color: var(--ab-text-primary);
  background: var(--ab-surface-card);
  transition: var(--ab-transition);
  outline: none;
}

.ab-search-input input::placeholder {
  color: var(--ab-text-tertiary);
}

.ab-search-input input:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}


/* --------------------------------------------------------------------------
   e) Stat Card
   -------------------------------------------------------------------------- */

.ab-stat-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--ab-space-md);
  margin-bottom: var(--ab-space-lg);
}

@media (min-width: 1024px) {
  .ab-stat-cards {
    grid-template-columns: repeat(4, 1fr);
  }
}

.ab-stat-card {
  display: flex;
  align-items: center;
  gap: var(--ab-space-md);
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  padding: var(--ab-space-lg);
  transition: var(--ab-transition);
}

.ab-stat-card:hover {
  box-shadow: var(--ab-shadow-md);
}

.ab-stat-card .ab-stat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--ab-radius-md);
  flex-shrink: 0;
}

.ab-stat-card .ab-stat-icon svg {
  width: 22px;
  height: 22px;
}

.ab-stat-card .ab-stat-content {
  min-width: 0;
}

.ab-stat-card .ab-stat-label {
  font-size: var(--ab-text-xs);
  font-weight: 500;
  color: var(--ab-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 2px;
}

.ab-stat-card .ab-stat-value {
  font-size: var(--ab-text-xl);
  font-weight: 700;
  color: var(--ab-text-primary);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-feature-settings: "tnum";
}

/* Skeleton shimmer loading state */
.ab-stat-skeleton {
  display: inline-block;
  width: 80px;
  height: 22px;
  border-radius: 4px;
  background: linear-gradient(
    90deg,
    var(--ab-surface-border-light) 25%,
    var(--ab-surface-hover) 50%,
    var(--ab-surface-border-light) 75%
  );
  background-size: 200% 100%;
  animation: ab-shimmer 1.5s ease-in-out infinite;
}

@keyframes ab-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}


/* --------------------------------------------------------------------------
   f) Tab Bar
   -------------------------------------------------------------------------- */

.ab-tab-bar {
  display: flex;
  gap: 0;
  background: var(--ab-surface-card);
  border-bottom: 2px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-lg) var(--ab-radius-lg) 0 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  margin-bottom: var(--ab-space-lg);
}

.ab-tab-bar::-webkit-scrollbar {
  display: none;
}


/* --------------------------------------------------------------------------
   g) Tab
   -------------------------------------------------------------------------- */

.ab-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 20px;
  font-size: var(--ab-text-sm);
  font-weight: 500;
  color: var(--ab-text-tertiary);
  white-space: nowrap;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: var(--ab-transition);
  user-select: none;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
  text-decoration: none;
}

.ab-tab:hover {
  color: var(--ab-text-primary);
  background: var(--ab-surface-hover);
  text-decoration: none;
}

.ab-tab:focus {
  text-decoration: none;
  outline: none;
}

.ab-tab.active {
  color: var(--ab-primary-700);
  font-weight: 600;
  border-bottom-color: var(--ab-primary-600);
}

.ab-tab .ab-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: var(--ab-radius-full);
  font-size: 10.5px;
  font-weight: 600;
  line-height: 1;
  background: var(--ab-surface-hover);
  color: var(--ab-text-secondary);
}

.ab-tab.active .ab-tab-count {
  background: var(--ab-primary-50);
  color: var(--ab-primary-700);
}


/* --------------------------------------------------------------------------
   h) Table Container
   -------------------------------------------------------------------------- */

.ab-table-container {
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  overflow: visible;
}


/* --------------------------------------------------------------------------
   i) Table — Pure ab-table (for custom tables)
   -------------------------------------------------------------------------- */

.ab-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--ab-text-base);
  color: var(--ab-text-primary);
}

.ab-table thead {
  background: var(--ab-surface-bg);
  border-bottom: 1px solid var(--ab-surface-border);
}

.ab-table thead th {
  padding: 10px 16px;
  font-size: var(--ab-text-xs);
  font-weight: 600;
  color: var(--ab-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: start;
  white-space: nowrap;
}

.ab-table tbody tr {
  border-bottom: 1px solid var(--ab-surface-border-light);
  transition: var(--ab-transition);
}

.ab-table tbody tr:last-child {
  border-bottom: none;
}

.ab-table tbody tr:hover {
  background: var(--ab-surface-hover);
}

.ab-table tbody td {
  padding: 12px 16px;
  vertical-align: middle;
}

/* Mobile card layout for .ab-table (<640px) */
@media (max-width: 639px) {
  .ab-table thead {
    display: none;
  }

  .ab-table,
  .ab-table tbody {
    display: block;
  }

  .ab-table tbody tr {
    display: block;
    padding: var(--ab-space-md) var(--ab-space-lg);
    margin-bottom: var(--ab-space-sm);
    border: 1px solid var(--ab-surface-border-light);
    border-radius: var(--ab-radius-md);
    background: var(--ab-surface-card);
  }

  .ab-table tbody tr:last-child {
    margin-bottom: 0;
  }

  .ab-table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid var(--ab-surface-border-light);
  }

  .ab-table tbody td:last-child {
    border-bottom: none;
  }

  .ab-table tbody td::before {
    content: attr(data-label);
    font-size: var(--ab-text-xs);
    font-weight: 600;
    color: var(--ab-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    flex-shrink: 0;
    margin-inline-end: var(--ab-space-md);
  }
}


/* --------------------------------------------------------------------------
   i-2) DataTable Overrides (inside .ab-table-container)
   Scoped to .ab-table-container so existing tables elsewhere are unaffected.
   -------------------------------------------------------------------------- */

/* --- Base table reset --- */
.ab-table-container .table {
  font-size: var(--ab-text-base);
  color: var(--ab-text-primary);
  margin-bottom: 0;
}

.ab-table-container .table.table-bordered > thead > tr > th,
.ab-table-container .table.table-bordered > thead > tr > td,
.ab-table-container .table.table-bordered > tbody > tr > th,
.ab-table-container .table.table-bordered > tbody > tr > td,
.ab-table-container .table.table-bordered > tfoot > tr > th,
.ab-table-container .table.table-bordered > tfoot > tr > td {
  border: none;
}

.ab-table-container .table.table-bordered {
  border: none;
}

.ab-table-container .table.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: transparent;
}

/* --- Header --- */
.ab-table-container .table > thead > tr > th {
  background: var(--ab-surface-bg);
  font-size: var(--ab-text-xs);
  font-weight: 600;
  color: var(--ab-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 10px 14px;
  border-bottom: 2px solid var(--ab-surface-border) !important;
  white-space: nowrap;
  vertical-align: middle;
  line-height: 1.4;
}

.ab-table-container .table > thead > tr > th.sorting,
.ab-table-container .table > thead > tr > th.sorting_asc,
.ab-table-container .table > thead > tr > th.sorting_desc {
  cursor: pointer;
}

/* --- Body rows --- */
.ab-table-container .table > tbody > tr > td {
  padding: 11px 14px;
  vertical-align: middle;
  border-bottom: 1px solid var(--ab-surface-border-light);
  transition: var(--ab-transition);
  font-size: var(--ab-text-base);
  line-height: 1.5;
}

/* Truncate long text cells to 2 lines with expand/collapse */
.ab-table-container .table > tbody > tr > td .ab-cell-clamp {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-height: 3em;
  line-height: 1.5;
  word-break: break-word;
}

.ab-table-container .table > tbody > tr > td .ab-cell-clamp.ab-cell-expanded {
  -webkit-line-clamp: unset;
  max-height: none;
}

.ab-cell-toggle {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  color: var(--ab-primary-600);
  cursor: pointer;
  margin-top: 2px;
  border: none;
  background: none;
  padding: 0;
}

.ab-cell-toggle:hover {
  text-decoration: underline;
}

.ab-table-container .table > tbody > tr:hover > td {
  background: var(--ab-surface-hover);
}

.ab-table-container .table > tbody > tr:last-child > td {
  border-bottom: none;
}

/* --- Footer --- */
.ab-table-container .table > tfoot > tr > td {
  padding: 10px 14px;
  background: var(--ab-surface-bg);
  border-top: 2px solid var(--ab-surface-border) !important;
  font-size: var(--ab-text-sm);
  font-weight: 600;
  color: var(--ab-text-primary);
  font-feature-settings: "tnum";
}

.ab-table-container .table > tfoot > tr.bg-gray {
  background-color: var(--ab-surface-bg) !important;
  color: var(--ab-text-primary) !important;
}

.ab-table-container .table > tfoot > tr > td strong {
  color: var(--ab-text-secondary);
  font-weight: 700;
}

/* --- Status badge overrides (pills with dot) --- */
.ab-table-container .label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px !important;
  border-radius: var(--ab-radius-full) !important;
  font-size: var(--ab-text-xs) !important;
  font-weight: 600 !important;
  line-height: 1.4;
  border: 1px solid transparent;
  white-space: nowrap;
}

.ab-table-container .label::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Paid / bg-light-green */
.ab-table-container .label.bg-light-green {
  background-color: var(--ab-status-paid-bg) !important;
  color: var(--ab-status-paid-text) !important;
  border-color: var(--ab-status-paid-border);
}
.ab-table-container .label.bg-light-green::before {
  background: var(--ab-status-paid-dot);
}

/* Due / bg-yellow */
.ab-table-container .label.bg-yellow {
  background-color: var(--ab-status-due-bg) !important;
  color: var(--ab-status-due-text) !important;
  border-color: var(--ab-status-due-border);
}
.ab-table-container .label.bg-yellow::before {
  background: var(--ab-status-due-dot);
}

/* Partial / bg-aqua */
.ab-table-container .label.bg-aqua {
  background-color: var(--ab-status-partial-bg) !important;
  color: var(--ab-status-partial-text) !important;
  border-color: var(--ab-status-partial-border);
}
.ab-table-container .label.bg-aqua::before {
  background: var(--ab-status-partial-dot);
}

/* Overdue / bg-red */
.ab-table-container .label.bg-red {
  background-color: var(--ab-status-overdue-bg) !important;
  color: var(--ab-status-overdue-text) !important;
  border-color: var(--ab-status-overdue-border);
}
.ab-table-container .label.bg-red::before {
  background: var(--ab-status-overdue-dot);
}

/* Delivered, Completed SO / bg-green */
.ab-table-container .label.bg-green {
  background-color: var(--ab-status-paid-bg) !important;
  color: var(--ab-status-paid-text) !important;
  border-color: var(--ab-status-paid-border);
}
.ab-table-container .label.bg-green::before {
  background: var(--ab-status-paid-dot);
}

/* Default, Proforma / bg-gray */
.ab-table-container .label.bg-gray {
  background-color: var(--ab-status-draft-bg) !important;
  color: var(--ab-status-draft-text) !important;
  border-color: var(--ab-status-draft-border);
}
.ab-table-container .label.bg-gray::before {
  background: var(--ab-status-draft-dot);
}

/* Shipped / bg-navy */
.ab-table-container .label.bg-navy {
  background-color: #EEF2FF !important;
  color: #3730A3 !important;
  border-color: #C7D2FE;
}
.ab-table-container .label.bg-navy::before {
  background: #6366F1;
}

/* Packed, Subscription / bg-info */
.ab-table-container .label.bg-info {
  background-color: var(--ab-status-partial-bg) !important;
  color: var(--ab-status-partial-text) !important;
  border-color: var(--ab-status-partial-border);
}
.ab-table-container .label.bg-info::before {
  background: var(--ab-status-partial-dot);
}

/* ZATCA Pending / bg-primary */
.ab-table-container .label.bg-primary {
  background-color: var(--ab-primary-50) !important;
  color: var(--ab-primary-700) !important;
  border-color: var(--ab-primary-200);
}
.ab-table-container .label.bg-primary::before {
  background: var(--ab-primary-500);
}

/* Small label-round badges (return icon, recurring, etc.) */
.ab-table-container .label.label-round {
  padding: 2px 6px !important;
  font-size: 10px !important;
  gap: 0;
}
.ab-table-container .label.label-round::before {
  display: none;
}

/* --- Action dropdown restyle --- */
.ab-table-container .btn-group .dropdown-toggle {
  padding: 5px 10px;
  font-size: var(--ab-text-xs);
  font-weight: 500;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  background: var(--ab-surface-card);
  color: var(--ab-text-secondary);
  transition: var(--ab-transition);
  box-shadow: none;
  line-height: 1.4;
}

.ab-table-container .btn-group .dropdown-toggle:hover,
.ab-table-container .btn-group .dropdown-toggle:focus {
  background: var(--ab-surface-hover);
  border-color: var(--ab-primary-200);
  color: var(--ab-text-primary);
  box-shadow: none;
}

.ab-table-container .btn-group.open .dropdown-toggle {
  background: var(--ab-surface-hover);
  border-color: var(--ab-primary-300, var(--ab-primary-200));
  box-shadow: none;
}

.ab-table-container .btn-group .dropdown-menu {
  min-width: 190px;
  padding: var(--ab-space-xs) 0;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-md);
  box-shadow: var(--ab-shadow-lg);
  margin-top: 4px;
}

.ab-table-container .btn-group .dropdown-menu > li > a {
  padding: 7px 14px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-primary);
  transition: var(--ab-transition);
  display: flex;
  align-items: center;
  gap: 8px;
}

.ab-table-container .btn-group .dropdown-menu > li > a:hover,
.ab-table-container .btn-group .dropdown-menu > li > a:focus {
  background: var(--ab-surface-hover);
  color: var(--ab-primary-600);
}

.ab-table-container .btn-group .dropdown-menu > li > a > i {
  width: 16px;
  text-align: center;
  font-size: 13px;
  color: var(--ab-text-tertiary);
}

.ab-table-container .btn-group .dropdown-menu > li > a:hover > i {
  color: var(--ab-primary-600);
}

.ab-table-container .btn-group .dropdown-menu .divider {
  margin: var(--ab-space-xs) 0;
  background: var(--ab-surface-border-light);
}

/* --- DataTables UI wrapper elements --- */

/* Length selector (Show N entries) */
.ab-table-container .dataTables_length {
  padding: 8px 14px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
}

.ab-table-container .dataTables_length select {
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  padding: 4px 8px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-primary);
  background: var(--ab-surface-card);
  margin: 0 4px;
  outline: none;
}

.ab-table-container .dataTables_length select:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.12);
}

/* Search / filter input */
.ab-table-container .dataTables_filter {
  padding: 8px 14px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
}

.ab-table-container .dataTables_filter input {
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  padding: 5px 10px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-primary);
  margin-inline-start: 6px;
  outline: none;
  transition: var(--ab-transition);
}

.ab-table-container .dataTables_filter input:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

/* Info text (Showing X to Y of Z entries) */
.ab-table-container .dataTables_info {
  padding: 10px 14px;
  font-size: var(--ab-text-xs);
  color: var(--ab-text-tertiary);
}

/* Pagination */
.ab-table-container .dataTables_paginate {
  padding: 8px 14px;
}

.ab-table-container .dataTables_paginate .paginate_button {
  padding: 4px 10px !important;
  font-size: var(--ab-text-xs) !important;
  border: 1px solid var(--ab-surface-border) !important;
  border-radius: var(--ab-radius-sm) !important;
  margin-inline-start: 4px;
  color: var(--ab-text-secondary) !important;
  background: var(--ab-surface-card) !important;
  transition: var(--ab-transition);
}

.ab-table-container .dataTables_paginate .paginate_button:hover {
  background: var(--ab-surface-hover) !important;
  border-color: var(--ab-primary-200) !important;
  color: var(--ab-text-primary) !important;
}

.ab-table-container .dataTables_paginate .paginate_button.current {
  background: var(--ab-primary-600) !important;
  border-color: var(--ab-primary-600) !important;
  color: var(--ab-text-inverse) !important;
  font-weight: 600;
}

.ab-table-container .dataTables_paginate .paginate_button.current:hover {
  background: var(--ab-primary-700) !important;
  border-color: var(--ab-primary-700) !important;
  color: var(--ab-text-inverse) !important;
}

.ab-table-container .dataTables_paginate .paginate_button.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Export / column visibility buttons */
.ab-table-container .dt-buttons .dt-button {
  padding: 5px 12px !important;
  font-size: var(--ab-text-xs) !important;
  font-weight: 500;
  border: 1px solid var(--ab-surface-border) !important;
  border-radius: var(--ab-radius-sm) !important;
  background: var(--ab-surface-card) !important;
  color: var(--ab-text-secondary) !important;
  margin-inline-end: 4px;
  transition: var(--ab-transition);
}

.ab-table-container .dt-buttons .dt-button:hover {
  background: var(--ab-surface-hover) !important;
  border-color: var(--ab-primary-200) !important;
  color: var(--ab-text-primary) !important;
}

/* DataTables scroll wrapper */
.ab-table-container .dataTables_scrollHead {
  border-bottom: none !important;
}

.ab-table-container .dataTables_scrollBody {
  border-bottom: 1px solid var(--ab-surface-border-light);
  overflow-x: auto !important;
  overflow-y: auto !important;
}

/* Hide horizontal scroll when table is empty */
.ab-table-container .dataTables_scrollBody:has(.dataTables_empty) {
  overflow-x: hidden !important;
}

/* Processing indicator */
.ab-table-container .dataTables_processing {
  background: rgba(255, 255, 255, 0.85);
  border: none;
  box-shadow: var(--ab-shadow-md);
  border-radius: var(--ab-radius-md);
  padding: 12px 24px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
  z-index: 10;
}

/* Currency value cells — tabular numbers */
.ab-table-container .final-total,
.ab-table-container .total-paid,
.ab-table-container .payment_due,
.ab-table-container .sell_return_due,
.ab-table-container .total-tax,
.ab-table-container .total_before_tax,
.ab-table-container .total-discount,
.ab-table-container .display_currency {
  font-feature-settings: "tnum";
  white-space: nowrap;
}

/* clickable_td cursor */
.ab-table-container .clickable_td {
  cursor: pointer;
}

/* Responsive: stack DT controls on mobile */
@media (max-width: 639px) {
  .ab-table-container .dataTables_length,
  .ab-table-container .dataTables_filter {
    float: none !important;
    text-align: start !important;
    padding: 6px 10px;
  }

  .ab-table-container .dataTables_info,
  .ab-table-container .dataTables_paginate {
    float: none !important;
    text-align: center !important;
    padding: 8px 10px;
  }

  .ab-table-container .dt-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 6px 10px;
  }
}


/* --------------------------------------------------------------------------
   j) Action Dropdown
   -------------------------------------------------------------------------- */

.ab-action-dropdown {
  position: relative;
  display: inline-flex;
}

.ab-action-dropdown .ab-action-menu {
  position: absolute;
  top: 100%;
  inset-inline-end: 0;
  z-index: 50;
  min-width: 180px;
  margin-top: 4px;
  padding: var(--ab-space-xs) 0;
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-md);
  box-shadow: var(--ab-shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px) scale(0.97);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
}

.ab-action-dropdown.open .ab-action-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.ab-action-menu a,
.ab-action-menu button {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 14px;
  font-size: var(--ab-text-sm);
  color: var(--ab-text-primary);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  text-align: start;
  transition: var(--ab-transition);
}

.ab-action-menu a:hover,
.ab-action-menu button:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-primary-600);
}

.ab-action-menu .ab-action-divider {
  height: 1px;
  margin: var(--ab-space-xs) 0;
  background: var(--ab-surface-border-light);
}

.ab-action-menu .ab-action-danger {
  color: var(--ab-status-overdue-text);
}

.ab-action-menu .ab-action-danger:hover {
  background: var(--ab-status-overdue-bg);
  color: var(--ab-status-overdue-text);
}


/* --------------------------------------------------------------------------
   k) Summary Bar
   -------------------------------------------------------------------------- */

.ab-summary-bar {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ab-space-sm);
  padding: var(--ab-space-lg);
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
}

@media (min-width: 640px) {
  .ab-summary-bar {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .ab-summary-bar {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--ab-space-lg);
  }
}

.ab-summary-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--ab-space-sm);
}

.ab-summary-item .ab-summary-label {
  font-size: var(--ab-text-xs);
  font-weight: 500;
  color: var(--ab-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ab-summary-item .ab-summary-value {
  font-size: var(--ab-text-lg);
  font-weight: 700;
  color: var(--ab-text-primary);
}


/* --------------------------------------------------------------------------
   l) Page Header
   -------------------------------------------------------------------------- */

.ab-page-header {
  display: flex;
  flex-direction: column;
  gap: var(--ab-space-md);
  margin-bottom: var(--ab-space-lg);
}

@media (min-width: 640px) {
  .ab-page-header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

.ab-page-header .ab-page-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--ab-text-primary);
  line-height: 1.3;
  margin: 0;
}

.ab-page-header .ab-page-subtitle {
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
  margin-top: 2px;
}

.ab-page-header .ab-page-actions {
  display: flex;
  gap: var(--ab-space-sm);
  flex-shrink: 0;
}


/* --------------------------------------------------------------------------
   l-2) Filter Toolbar (sales-only compact horizontal bar)
   -------------------------------------------------------------------------- */

.ab-filter-toolbar {
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  padding: 10px 16px;
  margin-bottom: var(--ab-space-lg);
}

.ab-filter-toolbar .ab-toolbar-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-end;
}

/* Each filter field inside the toolbar */
.ab-filter-toolbar .ab-field-group {
  flex: 1 1 150px;
  min-width: 0;
  max-width: 220px;
}

.ab-filter-toolbar .ab-field-group--checkbox {
  flex: 0 0 auto;
  max-width: none;
  align-self: center;
}

/* Compact labels */
.ab-filter-toolbar .form-group {
  margin-bottom: 0;
}

.ab-filter-toolbar .form-group > label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  color: var(--ab-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 2px;
  line-height: 1.2;
}

/* Compact inputs */
.ab-filter-toolbar .form-control {
  height: 32px;
  padding: 4px 8px;
  font-size: 13px;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  box-shadow: none;
  transition: var(--ab-transition);
}

.ab-filter-toolbar .form-control:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
  outline: none;
}

/* Compact Select2 */
.ab-filter-toolbar .select2-container--default .select2-selection--single {
  height: 32px;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  background: var(--ab-surface-card);
  transition: var(--ab-transition);
}

.ab-filter-toolbar .select2-container--default .select2-selection--single:hover {
  border-color: var(--ab-primary-200);
}

.ab-filter-toolbar .select2-container--default.select2-container--open .select2-selection--single,
.ab-filter-toolbar .select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

.ab-filter-toolbar .select2-container--default .select2-selection--single .select2-selection__rendered {
  font-size: 13px;
  color: var(--ab-text-primary);
  line-height: 30px;
  padding-inline-start: 6px;
}

.ab-filter-toolbar .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: var(--ab-text-tertiary);
}

.ab-filter-toolbar .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 30px;
}

/* Neutralize Bootstrap col-* inside toolbar */
.ab-filter-toolbar [class*="col-"] {
  float: none;
  width: auto;
  padding-left: 0;
  padding-right: 0;
  position: static;
  min-height: auto;
}

.ab-filter-toolbar > form {
  display: contents;
}

/* Niche filters — hidden in essential row, visible in niche row */
.ab-toolbar-essential > .ab-filter-niche {
  display: none;
}

/* When inside the niche row, show them (row itself controls visibility) */
.ab-toolbar-niche > .ab-filter-niche {
  display: block;
}

/* "More" toggle button */
.ab-toolbar-more {
  flex: 0 0 auto;
  align-self: flex-end;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  height: 32px;
  font-size: 12px;
  font-weight: 500;
  color: var(--ab-text-tertiary);
  background: none;
  border: 1px dashed var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  cursor: pointer;
  transition: var(--ab-transition);
  white-space: nowrap;
}

.ab-toolbar-more:hover {
  color: var(--ab-primary-600);
  border-color: var(--ab-primary-200);
  background: var(--ab-primary-50);
}

.ab-toolbar-more.active {
  color: var(--ab-primary-600);
  border-style: solid;
  border-color: var(--ab-primary-200);
  background: var(--ab-primary-50);
}

.ab-toolbar-more svg {
  width: 14px;
  height: 14px;
}

/* Checkbox inside toolbar */
.ab-filter-toolbar .ab-field-group--checkbox .checkbox {
  margin: 0;
  padding-top: 0;
}

.ab-filter-toolbar .ab-field-group--checkbox .checkbox label {
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
  font-weight: 500;
}

/* Responsive: mobile stacks */
@media (max-width: 639px) {
  .ab-filter-toolbar .ab-toolbar-row {
    flex-direction: column;
  }

  .ab-filter-toolbar .ab-field-group {
    flex: 1 1 100%;
    max-width: none;
  }

  .ab-toolbar-more {
    width: 100%;
    justify-content: center;
  }
}


/* --------------------------------------------------------------------------
   l-3) Filter Toolbar — clear buttons & toolbar actions
   -------------------------------------------------------------------------- */

/*
 * No DOM manipulation on Select2 or daterangepicker elements.
 * All fields stay in-place inside .ab-toolbar-row. This CSS only adds:
 *  - Per-field clear (×) button positioning
 *  - Active-field highlight
 *  - Toolbar actions row (More toggle + Clear All)
 */

/* Toolbar actions row (More + Clear All) */
.ab-toolbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 4px;
}

/* Per-field clear button — absolutely positioned inside .form-group */
.ab-field-clear {
  position: absolute;
  top: 50%;
  inset-inline-end: 22px;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 50%;
  background: var(--ab-status-overdue-bg);
  color: var(--ab-status-overdue-text);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  z-index: 5;
  transition: background 0.15s ease;
}

/* Nudge clear button for date input (no Select2 arrow to avoid) */
.ab-filter-toolbar .ab-field-group input.form-control ~ .ab-field-clear {
  inset-inline-end: 6px;
}

.ab-field-clear:hover {
  background: var(--ab-status-overdue-border);
  color: #991B1B;
}

/* Highlight border on active filter */
.ab-filter-toolbar .ab-field-group.ab-field-active .select2-container--default .select2-selection--single {
  border-color: var(--ab-primary-300);
  background: var(--ab-primary-50) !important;
}

.ab-filter-toolbar .ab-field-group.ab-field-active .form-control {
  border-color: var(--ab-primary-300);
  background: var(--ab-primary-50);
}

/* Clear All button */
.ab-toolbar-clear-all {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--ab-radius-sm);
  background: none;
  color: var(--ab-text-tertiary);
  font-size: 12px;
  font-weight: 500;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: var(--ab-transition);
}

.ab-toolbar-clear-all:hover {
  background: var(--ab-primary-50);
  color: var(--ab-primary-600);
}

.ab-toolbar-clear-all svg {
  flex-shrink: 0;
}


/* --------------------------------------------------------------------------
   m) Bulk Actions
   -------------------------------------------------------------------------- */

.ab-bulk-actions {
  display: none;
  align-items: center;
  gap: var(--ab-space-md);
  padding: var(--ab-space-md) var(--ab-space-lg);
  background: var(--ab-primary-50);
  border: 1px solid var(--ab-primary-200);
  border-radius: var(--ab-radius-md);
}

.ab-bulk-actions.active {
  display: flex;
}

.ab-bulk-actions .ab-bulk-count {
  font-size: var(--ab-text-sm);
  font-weight: 600;
  color: var(--ab-primary-700);
  white-space: nowrap;
}

.ab-bulk-actions .ab-bulk-buttons {
  display: flex;
  gap: var(--ab-space-sm);
  flex-wrap: wrap;
}

.ab-bulk-actions .ab-bulk-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  font-size: var(--ab-text-xs);
  font-weight: 500;
  color: var(--ab-primary-700);
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-primary-200);
  border-radius: var(--ab-radius-sm);
  cursor: pointer;
  transition: var(--ab-transition);
}

.ab-bulk-actions .ab-bulk-btn:hover {
  background: var(--ab-primary-100);
}

.ab-bulk-actions .ab-bulk-cancel {
  margin-inline-start: auto;
  color: var(--ab-text-secondary);
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--ab-text-sm);
  padding: 4px 8px;
}


/* --------------------------------------------------------------------------
   n) Filter Card & Filter Bar
   -------------------------------------------------------------------------- */

/* Filter Card — card wrapper, no inner padding (header/body manage their own) */
.ab-filter-card {
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  margin-bottom: var(--ab-space-lg);
  overflow: hidden;
  transition: var(--ab-transition);
}

.ab-filter-card:hover {
  box-shadow: var(--ab-shadow-md);
}

/* Filter Header — collapsible toggle bar */
.ab-filter-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--ab-space-md) var(--ab-space-lg);
  cursor: pointer;
  user-select: none;
  text-decoration: none !important;
  color: inherit !important;
  border-bottom: 1px solid var(--ab-surface-border-light);
  transition: var(--ab-transition);
}

.ab-filter-header:hover,
.ab-filter-header:focus {
  background: var(--ab-surface-hover);
  text-decoration: none !important;
  color: inherit !important;
}

@media (min-width: 768px) {
  .ab-filter-header {
    padding: var(--ab-space-md) var(--ab-space-xl);
  }
}

@media (min-width: 1024px) {
  .ab-filter-header {
    padding: var(--ab-space-lg) var(--ab-space-2xl);
  }
}

/* Filter Title */
.ab-filter-title {
  display: flex;
  align-items: center;
  gap: var(--ab-space-sm);
  font-size: var(--ab-text-sm);
  font-weight: 600;
  color: var(--ab-text-secondary);
  margin: 0;
}

.ab-filter-title i {
  color: var(--ab-text-tertiary);
  font-size: var(--ab-text-md);
}

/* Filter Toggle — chevron icon that rotates when open */
.ab-filter-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--ab-text-tertiary);
  transition: transform 0.2s ease;
}

.ab-filter-header[aria-expanded="true"] .ab-filter-toggle {
  transform: rotate(180deg);
}

/* Filter Body — padded container inside the collapse */
.ab-filter-body {
  padding: var(--ab-space-lg);
}

@media (min-width: 768px) {
  .ab-filter-body {
    padding: var(--ab-space-xl);
  }
}

@media (min-width: 1024px) {
  .ab-filter-body {
    padding: var(--ab-space-2xl);
  }
}

/* Filter Grid — responsive layout for filter fields */
.ab-filter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ab-space-lg);
}

@media (min-width: 640px) {
  .ab-filter-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .ab-filter-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Allow <form> elements inside filter grid to participate in layout */
.ab-filter-grid > form {
  display: contents;
}

/* Neutralize Bootstrap col-* inside filter grid */
.ab-filter-grid > [class*="col-"],
.ab-filter-grid > form > [class*="col-"] {
  float: none;
  width: auto;
  padding-left: 0;
  padding-right: 0;
  position: static;
  min-height: auto;
}

/* Neutralize form-group margin inside filter grid */
.ab-filter-grid .form-group {
  margin-bottom: 0;
}

/* Field Group */
.ab-field-group {
  min-width: 0;
}

/* Label styling inside filter grid */
.ab-filter-grid .form-group > label,
.ab-field-group > label {
  display: block;
  font-size: var(--ab-text-xs);
  font-weight: 600;
  color: var(--ab-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--ab-space-xs);
  line-height: 1.3;
}

/* Input styling inside filter grid */
.ab-filter-grid .form-control {
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  font-size: var(--ab-text-base);
  color: var(--ab-text-primary);
  height: 36px;
  padding: 6px 12px;
  box-shadow: none;
  transition: var(--ab-transition);
}

.ab-filter-grid .form-control:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
  outline: none;
}

.ab-filter-grid .form-control::placeholder {
  color: var(--ab-text-tertiary);
}

/* Select2 v4 inside filter grid */
.ab-filter-grid .select2-container--default .select2-selection--single {
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  height: 36px;
  background: var(--ab-surface-card);
  transition: var(--ab-transition);
}

.ab-filter-grid .select2-container--default .select2-selection--single:hover {
  border-color: var(--ab-primary-200);
}

.ab-filter-grid .select2-container--default.select2-container--open .select2-selection--single,
.ab-filter-grid .select2-container--default.select2-container--focus .select2-selection--single {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

.ab-filter-grid .select2-container--default .select2-selection--single .select2-selection__rendered {
  font-size: var(--ab-text-base);
  color: var(--ab-text-primary);
  line-height: 34px;
  padding-inline-start: 8px;
}

.ab-filter-grid .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: var(--ab-text-tertiary);
}

.ab-filter-grid .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 34px;
}

/* Checkbox field alignment inside grid */
.ab-field-group--checkbox {
  align-self: end;
}

.ab-filter-grid .ab-field-group--checkbox .form-group {
  margin-bottom: 0;
}

.ab-filter-grid .ab-field-group--checkbox .checkbox {
  margin: 0;
  padding-top: 0;
}

.ab-filter-grid .ab-field-group--checkbox .checkbox label {
  font-size: var(--ab-text-sm);
  color: var(--ab-text-secondary);
  font-weight: 500;
}


/* ==========================================================================
   3. RTL Overrides
   ========================================================================== */

/*
 * Most components use logical properties (inset-inline-start, margin-inline-end,
 * text-align: start, etc.) and flip automatically. Below are overrides for cases
 * that need explicit RTL handling.
 */

[dir="rtl"] .ab-tab-bar {
  direction: rtl;
}

[dir="rtl"] .ab-table {
  direction: rtl;
}

[dir="rtl"] .ab-action-dropdown .ab-action-menu {
  /* inset-inline-end already handles this, but ensure text alignment */
  text-align: right;
}


/* ==========================================================================
   4. Print Styles
   ========================================================================== */

@media print {
  .ab-filter-pill,
  .ab-search-input,
  .ab-stat-cards,
  .ab-stat-card,
  .ab-bulk-actions,
  .ab-action-dropdown,
  .ab-tab-bar,
  .ab-page-actions,
  .ab-filter-card,
  .ab-filter-toolbar {
    display: none !important;
  }

  .ab-card,
  .ab-table-container {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
    break-inside: avoid;
  }

  .ab-table {
    font-size: 11px;
  }

  .ab-table thead {
    background: none !important;
  }

  .ab-table thead th {
    border-bottom: 2px solid #333 !important;
    color: #000 !important;
  }

  .ab-table tbody td {
    border-bottom: 1px solid #ddd !important;
    padding: 6px 10px;
  }

  .ab-table tbody tr:hover {
    background: none !important;
  }

  /* DataTable print overrides */
  .ab-table-container .label {
    background: none !important;
    border: none !important;
    color: #000 !important;
    padding: 0 !important;
    font-size: 10px !important;
  }
  .ab-table-container .label::before {
    display: none !important;
  }
  .ab-table-container .btn-group {
    display: none !important;
  }
  .ab-table-container .dataTables_length,
  .ab-table-container .dataTables_filter,
  .ab-table-container .dataTables_info,
  .ab-table-container .dataTables_paginate,
  .ab-table-container .dt-buttons {
    display: none !important;
  }
  .ab-table-container .table > thead > tr > th {
    background: none !important;
    border-bottom: 2px solid #333 !important;
    color: #000 !important;
    font-size: 9px !important;
  }
  .ab-table-container .table > tbody > tr > td {
    border-bottom: 1px solid #ddd !important;
    padding: 5px 8px !important;
    font-size: 10px !important;
  }
  .ab-table-container .table > tbody > tr:hover > td {
    background: none !important;
  }
  .ab-table-container .table > tfoot > tr > td {
    background: none !important;
    border-top: 2px solid #333 !important;
  }

  .ab-summary-bar {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
  }

  .ab-page-header {
    margin-bottom: 12px;
  }
}


/* ==========================================================================
   8. Global Select2 Dropdown Overrides
   ========================================================================== */

/*
 * Select2 appends .select2-dropdown to <body>, outside any component scope.
 * vendor.css has 5 competing .select2-dropdown rules (AdminLTE theme last:
 * border:1px solid #d2d6de; border-radius:0). Since redesign.css loads after
 * vendor.css (css.blade.php line 13 vs 3), identical selectors win by cascade.
 * No !important needed.
 */

.select2-dropdown {
  border: 1px solid var(--ab-surface-border);
  border-radius: 10px;
  background: var(--ab-surface-card);
  box-shadow: 0 12px 28px -4px rgba(0, 0, 0, 0.12), 0 4px 10px -2px rgba(0, 0, 0, 0.06);
  overflow: hidden;
  z-index: 10060;
}

/*
 * Select2 sets border-top/bottom: none and zeroes radii on --below/--above
 * to avoid a double border between the selection and dropdown. We keep the
 * gap behavior but preserve ALL corners — overflow:hidden on .select2-dropdown
 * clips content to the radius regardless.
 */
.select2-container--open .select2-dropdown--below {
  border-top-color: transparent;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  margin-top: 4px;
}
.select2-container--open .select2-dropdown--above {
  border-bottom-color: transparent;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  margin-bottom: 4px;
}

/* Search input inside dropdown */
.select2-container--default .select2-search--dropdown .select2-search__field {
  border: 1.5px solid var(--ab-surface-border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--ab-text-primary);
  background: var(--ab-surface-bg);
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.select2-container--default .select2-search--dropdown .select2-search__field:focus {
  border-color: var(--ab-primary-500);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

/* Search container */
.select2-container--default .select2-search--dropdown {
  padding: 8px 8px 4px;
}

/* Results list */
.select2-container--default .select2-results > .select2-results__options {
  max-height: 260px;
  padding: 4px;
}

/* Individual option */
.select2-container--default .select2-results__option {
  padding: 8px 12px;
  font-size: 13px;
  color: var(--ab-text-primary);
  border-radius: 6px;
  margin: 1px 4px;
  transition: background 0.1s ease, color 0.1s ease;
}

/* Hover / keyboard-highlighted */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background: var(--ab-primary-50);
  color: var(--ab-primary-700);
}

/* Selected (already chosen) */
.select2-container--default .select2-results__option[aria-selected="true"] {
  background: var(--ab-primary-50);
  color: var(--ab-primary-700);
  font-weight: 600;
}

/* Hover on already-selected */
.select2-container--default .select2-results__option[aria-selected="true"]:hover {
  background: var(--ab-primary-100);
}

/* No results / loading message */
.select2-container--default .select2-results__message {
  padding: 10px 12px;
  font-size: 13px;
  color: var(--ab-text-tertiary);
}


/* ==========================================================================
   9. Global Daterangepicker Overrides
   ========================================================================== */

/*
 * daterangepicker is appended to <body>. vendor.css sets border-radius:4px,
 * border:1px solid #ddd, z-index:3001, font-family:arial — no !important.
 * Our rules win by cascade order.
 */

.daterangepicker {
  border-radius: 12px;
  border: 1px solid var(--ab-surface-border);
  background: var(--ab-surface-card);
  box-shadow: 0 12px 28px -4px rgba(0, 0, 0, 0.12), 0 4px 10px -2px rgba(0, 0, 0, 0.06);
  font-family: inherit;
  z-index: 10060;
}

/* Remove the arrow notch */
.daterangepicker::before,
.daterangepicker::after {
  display: none;
}

/* Predefined ranges list */
.daterangepicker .ranges ul {
  padding: 8px;
  width: auto;
}
.daterangepicker .ranges li {
  padding: 8px 14px;
  font-size: 13px;
  color: var(--ab-text-primary);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.1s ease;
  margin-bottom: 2px;
}
.daterangepicker .ranges li:hover {
  background: var(--ab-surface-hover);
}
.daterangepicker .ranges li.active {
  background: var(--ab-primary-600);
  color: #fff;
  border-radius: 6px;
}

/* Calendar header (month/year nav) */
.daterangepicker .calendar-table th {
  font-size: 12px;
  font-weight: 600;
  color: var(--ab-text-secondary);
  padding: 6px;
}
.daterangepicker th.month {
  font-size: 13px;
  font-weight: 700;
  color: var(--ab-text-primary);
}
.daterangepicker th.prev,
.daterangepicker th.next {
  border-radius: 6px;
  transition: background 0.1s ease;
}
.daterangepicker th.prev:hover,
.daterangepicker th.next:hover {
  background: var(--ab-surface-hover);
}

/* Calendar day cells */
.daterangepicker td {
  font-size: 12px;
  border-radius: 6px;
  transition: background 0.1s ease;
}
.daterangepicker td.available:hover {
  background: var(--ab-surface-hover);
}
.daterangepicker td.in-range {
  background: var(--ab-primary-50);
  color: var(--ab-primary-700);
  border-radius: 0;
}
.daterangepicker td.active,
.daterangepicker td.active:hover {
  background: var(--ab-primary-600);
  color: #fff;
}
.daterangepicker td.start-date {
  border-radius: 6px 0 0 6px;
}
.daterangepicker td.end-date {
  border-radius: 0 6px 6px 0;
}
.daterangepicker td.start-date.end-date {
  border-radius: 6px;
}
.daterangepicker td.off,
.daterangepicker td.off.in-range {
  color: var(--ab-text-tertiary);
  background: transparent;
}

/* Month/year dropdowns inside calendar */
.daterangepicker .calendar-table select {
  font-size: 12px;
  border: 1px solid var(--ab-surface-border);
  border-radius: 6px;
  padding: 2px 4px;
  background: var(--ab-surface-card);
  color: var(--ab-text-primary);
}

/* Calendar table container */
.daterangepicker .calendar-table {
  border-radius: 8px;
  background: var(--ab-surface-card);
}

/* Apply / Cancel buttons */
.daterangepicker .drp-buttons {
  border-top: 1px solid var(--ab-surface-border);
  padding: 10px 12px;
}
.daterangepicker .drp-buttons .btn {
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  padding: 6px 16px;
  transition: var(--ab-transition);
}
.daterangepicker .drp-buttons .btn-primary,
.daterangepicker .drp-buttons .applyBtn {
  background: var(--ab-primary-600);
  border-color: var(--ab-primary-600);
  color: #fff;
}
.daterangepicker .drp-buttons .btn-primary:hover,
.daterangepicker .drp-buttons .applyBtn:hover {
  background: var(--ab-primary-700);
  border-color: var(--ab-primary-700);
}
.daterangepicker .drp-buttons .btn-default,
.daterangepicker .drp-buttons .cancelBtn {
  background: var(--ab-surface-bg);
  border: 1px solid var(--ab-surface-border);
  color: var(--ab-text-secondary);
}
.daterangepicker .drp-buttons .btn-default:hover,
.daterangepicker .drp-buttons .cancelBtn:hover {
  background: var(--ab-surface-hover);
}

/* Selected range display text */
.daterangepicker .drp-selected {
  font-size: 12px;
  color: var(--ab-text-secondary);
}

/* RTL adjustments for daterangepicker */
[dir="rtl"] .daterangepicker td.start-date {
  border-radius: 0 6px 6px 0;
}
[dir="rtl"] .daterangepicker td.end-date {
  border-radius: 6px 0 0 6px;
}
[dir="rtl"] .daterangepicker td.start-date.end-date {
  border-radius: 6px;
}


/* ==========================================================================
   5. Dashboard Page
   ========================================================================== */

/* --------------------------------------------------------------------------
   a) Dashboard wrapper
   -------------------------------------------------------------------------- */

.ab-dashboard {
  padding: var(--ab-space-xl);
  max-width: 1440px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .ab-dashboard {
    padding: var(--ab-space-2xl);
  }
}

/* --------------------------------------------------------------------------
   b) Dashboard header — welcome + controls row
   -------------------------------------------------------------------------- */

.ab-dashboard__header {
  display: flex;
  flex-direction: column;
  gap: var(--ab-space-lg);
  margin-bottom: var(--ab-space-xl);
}

@media (min-width: 768px) {
  .ab-dashboard__header {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--ab-space-2xl);
  }
}

.ab-dashboard__welcome {
  min-width: 0;
}

.ab-dashboard__title {
  font-size: var(--ab-text-xl);
  font-weight: 700;
  color: var(--ab-text-primary);
  margin: 0;
  line-height: 1.3;
}

@media (min-width: 768px) {
  .ab-dashboard__title {
    font-size: var(--ab-text-2xl);
  }
}

.ab-dashboard__subtitle {
  font-size: var(--ab-text-sm);
  color: var(--ab-text-tertiary);
  margin: 4px 0 0;
}

.ab-dashboard__controls {
  display: flex;
  align-items: center;
  gap: var(--ab-space-sm);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.ab-dashboard__location-wrap {
  min-width: 180px;
  max-width: 240px;
}

/* --------------------------------------------------------------------------
   c) Period selector — segmented button group
   -------------------------------------------------------------------------- */

.ab-period-selector {
  display: inline-flex;
  border-radius: var(--ab-radius-md);
  border: 1.5px solid var(--ab-surface-border);
  overflow: hidden;
  background: var(--ab-surface-card);
}

.ab-period-btn {
  padding: 7px 14px;
  border: none;
  border-inline-end: 1px solid var(--ab-surface-border);
  font-size: var(--ab-text-sm);
  font-weight: 400;
  font-family: inherit;
  color: var(--ab-text-secondary);
  background: var(--ab-surface-card);
  cursor: pointer;
  white-space: nowrap;
  transition: var(--ab-transition);
  line-height: 1.4;
}

.ab-period-btn:last-child {
  border-inline-end: none;
}

.ab-period-btn:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
}

.ab-period-btn.active {
  background: var(--ab-primary-600);
  color: var(--ab-text-inverse);
  font-weight: 600;
}

.ab-period-btn--custom {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ab-period-btn--custom svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   d) Stat card — compact variant for purchase row
   -------------------------------------------------------------------------- */

.ab-stat-cards--compact {
  margin-bottom: var(--ab-space-xl);
}

.ab-stat-cards--compact .ab-stat-card {
  padding: var(--ab-space-md) var(--ab-space-lg);
}

.ab-stat-cards--compact .ab-stat-icon {
  width: 36px;
  height: 36px;
}

.ab-stat-cards--compact .ab-stat-icon svg {
  width: 18px;
  height: 18px;
}

.ab-stat-cards--compact .ab-stat-value {
  font-size: var(--ab-text-lg);
}

/* Icon color tints for stat cards */
.ab-stat-icon--blue  { background: rgba(59, 130, 246, 0.08); color: #2563EB; }
.ab-stat-icon--green { background: rgba(34, 197, 94, 0.08);  color: #16A34A; }
.ab-stat-icon--amber { background: rgba(245, 158, 11, 0.08); color: #D97706; }
.ab-stat-icon--red   { background: rgba(239, 68, 68, 0.08);  color: #DC2626; }
.ab-stat-icon--purple{ background: rgba(168, 85, 247, 0.08); color: #9333EA; }

/* --------------------------------------------------------------------------
   e) Dashboard grid — 2-column layout for charts & tables
   -------------------------------------------------------------------------- */

.ab-dashboard__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--ab-space-md);
  margin-bottom: var(--ab-space-xl);
}

@media (min-width: 1024px) {
  .ab-dashboard__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* --------------------------------------------------------------------------
   f) Section card — wraps charts and data tables
   -------------------------------------------------------------------------- */

.ab-section-card {
  display: flex;
  flex-direction: column;
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
  overflow: hidden;
  transition: box-shadow 0.2s ease;
}

.ab-section-card__body {
  flex: 1;
}

.ab-section-card:hover {
  box-shadow: var(--ab-shadow-md);
}

/* Full-width variant spans both columns */
.ab-section-card--full {
  grid-column: 1 / -1;
}

.ab-section-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ab-space-sm);
  padding: 14px 18px;
  border-bottom: 1px solid var(--ab-surface-border-light);
}

.ab-section-card__header-start {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.ab-section-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--ab-radius-sm);
  flex-shrink: 0;
}

.ab-section-card__icon svg {
  width: 16px;
  height: 16px;
}

/* Section icon color modifiers */
.ab-section-card__icon--blue   { background: rgba(59, 130, 246, 0.08); color: #2563EB; }
.ab-section-card__icon--green  { background: rgba(34, 197, 94, 0.08);  color: #16A34A; }
.ab-section-card__icon--amber  { background: rgba(245, 158, 11, 0.08); color: #D97706; }
.ab-section-card__icon--red    { background: rgba(239, 68, 68, 0.08);  color: #DC2626; }
.ab-section-card__icon--purple { background: rgba(168, 85, 247, 0.08); color: #9333EA; }

.ab-section-card__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ab-text-primary);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ab-section-card__header-end {
  display: flex;
  align-items: center;
  gap: var(--ab-space-sm);
  flex-shrink: 0;
}

.ab-section-card__header-end .form-control,
.ab-section-card__header-end .select2-container {
  min-width: 160px;
}

.ab-section-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ab-text-xs);
  color: var(--ab-text-tertiary);
}

.ab-section-card__body {
  padding: 0;
}

.ab-section-card__body--padded {
  padding: 16px 18px;
}

/* Chart container inside section card — Tremor aesthetic */
.ab-section-card__chart {
  min-height: 300px;
  position: relative;
}

.ab-section-card__chart > div {
  min-height: 300px;
}

/* Highcharts overrides scoped to dashboard charts */
.ab-section-card__chart .highcharts-container {
  overflow: visible !important;
}

.ab-section-card__chart .highcharts-background {
  fill: transparent;
}

.ab-section-card__chart .highcharts-grid-line {
  stroke: var(--ab-surface-border-light);
  stroke-dasharray: 4 4;
}

.ab-section-card__chart .highcharts-axis-line {
  stroke: var(--ab-surface-border);
}

.ab-section-card__chart .highcharts-tick {
  stroke: var(--ab-surface-border);
}

/* Tooltip — clean rounded, subtle shadow */
.ab-section-card__chart .highcharts-tooltip > span {
  padding: 10px 14px !important;
}

.ab-section-card__chart .highcharts-tooltip-box {
  fill: var(--ab-surface-card);
  stroke: none;
  rx: 10;
  ry: 10;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.08));
}

/* Legend — horizontal pill style at bottom */
.ab-section-card__chart .highcharts-legend-item text {
  font-size: 12px !important;
  font-weight: 500 !important;
  fill: var(--ab-text-secondary) !important;
}

.ab-section-card__chart .highcharts-legend-item:hover text {
  fill: var(--ab-text-primary) !important;
}

/* Crosshair — subtle */
.ab-section-card__chart .highcharts-crosshair {
  stroke: var(--ab-surface-border);
  stroke-width: 1;
  stroke-dasharray: 4 3;
}

/* Chart entry animation */
.ab-section-card__chart .highcharts-series path {
  transition: opacity 0.3s ease;
}

/* Smooth hover state on data points */
.ab-section-card__chart .highcharts-point {
  transition: r 0.15s ease;
}

/* Make DataTables inside section cards seamless */
.ab-section-card .ab-table-container {
  border: none;
  border-radius: 0;
  box-shadow: none;
}

/* --------------------------------------------------------------------------
   g) Dashboard mini-tables — hide DT chrome, compact rows
   -------------------------------------------------------------------------- */

/* Hide all DataTable UI controls inside dashboard table cards */
.ab-dashboard-table .dataTables_length,
.ab-dashboard-table .dataTables_filter,
.ab-dashboard-table .dt-buttons,
.ab-dashboard-table .dataTables_paginate,
.ab-dashboard-table .dataTables_info {
  display: none !important;
}

/* Cap table body height — shrink-to-fit, scroll only when >~5 rows.
   DataTables sets inline height from scrollY:"75vh". We override to auto
   so the container collapses to content, with max-height as the cap. */
.ab-dashboard-table .dataTables_scrollBody {
  height: auto !important;
  max-height: 260px !important;
}

/* Hide empty DataTables scroll footer wrapper (generated even without <tfoot>) */
.ab-dashboard-table .dataTables_scrollFoot {
  display: none;
}

/* For tables without DT scroll wrapper (fallback) */
.ab-dashboard-table .ab-table-container {
  max-height: none;
  overflow-y: auto;
  overflow-x: auto;
}

/* Compact table rows for dashboard */
.ab-dashboard-table .table > tbody > tr > td {
  padding: 8px 12px !important;
  font-size: var(--ab-text-sm);
  border-bottom: 1px solid var(--ab-surface-border-light) !important;
}

.ab-dashboard-table .table > tbody > tr:last-child > td {
  border-bottom: none !important;
}

.ab-dashboard-table .table > thead > tr > th {
  padding: 8px 12px !important;
  font-size: 10.5px;
}

/* --------------------------------------------------------------------------
   h) Section card footer — "view all" link
   -------------------------------------------------------------------------- */

.ab-section-card__footer {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-top: 1px solid var(--ab-surface-border-light);
  background: var(--ab-surface-bg);
  border-radius: 0 0 var(--ab-radius-lg) var(--ab-radius-lg);
}

.ab-section-card__footer a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ab-text-sm);
  font-weight: 600;
  color: var(--ab-primary-600);
  text-decoration: none;
  transition: var(--ab-transition);
}

.ab-section-card__footer a:hover {
  color: var(--ab-primary-700);
  text-decoration: none;
  gap: 6px;
}

.ab-section-card__footer a svg {
  width: 14px;
  height: 14px;
  transition: transform 0.15s ease;
}

[dir="rtl"] .ab-section-card__footer a svg {
  transform: scaleX(-1);
}

.ab-section-card__footer a:hover svg {
  transform: translateX(2px);
}

[dir="rtl"] .ab-section-card__footer a:hover svg {
  transform: scaleX(-1) translateX(2px);
}

/* --------------------------------------------------------------------------
   i) Compact location filter in section card header
   -------------------------------------------------------------------------- */

.ab-section-card__header-end .select2-container {
  min-width: 140px !important;
  max-width: 180px !important;
}

.ab-section-card__header-end .select2-container--default .select2-selection--single {
  height: 30px;
  border: 1px solid var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  background: var(--ab-surface-card);
  font-size: 12px;
}

.ab-section-card__header-end .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 28px;
  padding-inline-start: 8px;
  font-size: 12px;
  color: var(--ab-text-secondary);
}

.ab-section-card__header-end .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 28px;
}

.ab-section-card__header-end .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: var(--ab-text-tertiary);
  font-size: 12px;
}

/* --------------------------------------------------------------------------
   j) Responsive and print
   -------------------------------------------------------------------------- */

@media (max-width: 639px) {
  .ab-dashboard__controls {
    width: 100%;
  }
  .ab-dashboard__location-wrap {
    min-width: 0;
    flex: 1;
  }
  .ab-period-selector {
    width: 100%;
  }
  .ab-period-btn {
    flex: 1;
    text-align: center;
    padding: 7px 8px;
    font-size: 11px;
  }
  /* Stack section card header on very small screens */
  .ab-section-card__header {
    flex-wrap: wrap;
    gap: 8px;
  }
  .ab-section-card__header-end {
    width: 100%;
  }
  .ab-section-card__header-end .select2-container {
    min-width: 100% !important;
    max-width: 100% !important;
  }
  /* Prevent horizontal overflow on mobile */
  .ab-dashboard {
    padding: var(--ab-space-md);
    overflow-x: hidden;
  }
  .ab-dashboard__title {
    font-size: var(--ab-text-lg);
    word-break: break-word;
  }
  .ab-stat-cards {
    grid-template-columns: 1fr;
  }
  .ab-section-card__chart {
    min-height: 200px;
  }
  .ab-section-card__chart > div {
    min-height: 200px;
  }
}

/* --------------------------------------------------------------------------
   k) Dashboard scrollbars — thin, neutral, rounded
   -------------------------------------------------------------------------- */

/* Thin scrollbar for all dashboard scroll areas */
.ab-dashboard ::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.ab-dashboard ::-webkit-scrollbar-track {
  background: transparent;
}

.ab-dashboard ::-webkit-scrollbar-thumb {
  background: var(--ab-surface-border);
  border-radius: 3px;
}

.ab-dashboard ::-webkit-scrollbar-thumb:hover {
  background: var(--ab-text-tertiary);
}

/* Firefox */
.ab-dashboard * {
  scrollbar-width: thin;
  scrollbar-color: var(--ab-surface-border) transparent;
}

/* DataTable scroll containers — override any vendor colored scrollbars */
.ab-dashboard .dataTables_scrollBody::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

.ab-dashboard .dataTables_scrollBody::-webkit-scrollbar-track {
  background: transparent;
}

.ab-dashboard .dataTables_scrollBody::-webkit-scrollbar-thumb {
  background: var(--ab-surface-border);
  border-radius: 3px;
}

.ab-dashboard .dataTables_scrollBody::-webkit-scrollbar-thumb:hover {
  background: var(--ab-text-tertiary);
}

.ab-dashboard .dataTables_scrollBody {
  scrollbar-width: thin;
  scrollbar-color: var(--ab-surface-border) transparent;
}

/* --------------------------------------------------------------------------
   l) Hide Highcharts export menu on dashboard charts
   -------------------------------------------------------------------------- */

.ab-section-card__chart .highcharts-exporting-group,
.ab-section-card__chart .highcharts-button {
  display: none !important;
}

/* --------------------------------------------------------------------------
   m) Dashboard action button overrides (payment buttons from server)
   -------------------------------------------------------------------------- */

.ab-dashboard-table .tw-dw-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px !important;
  font-size: var(--ab-text-xs) !important;
  font-weight: 600 !important;
  border-radius: var(--ab-radius-sm) !important;
  border: 1px solid var(--ab-primary-200) !important;
  background: var(--ab-primary-50) !important;
  color: var(--ab-primary-700) !important;
  text-decoration: none !important;
  white-space: nowrap;
  transition: var(--ab-transition);
  line-height: 1.4;
}

.ab-dashboard-table .tw-dw-btn:hover {
  background: var(--ab-primary-100) !important;
  border-color: var(--ab-primary-500) !important;
  color: var(--ab-primary-800) !important;
  text-decoration: none !important;
}

.ab-dashboard-table .tw-dw-btn i {
  font-size: 11px;
}

/* --------------------------------------------------------------------------
   n) KPI row spacing fix — consistent gap between Row 1 and Row 2
   -------------------------------------------------------------------------- */

.ab-stat-cards {
  margin-bottom: var(--ab-space-md);
}

.ab-stat-cards--compact {
  margin-bottom: var(--ab-space-xl);
}

/* Ensure compact row has same internal gap as Row 1 */
.ab-stat-cards--compact {
  gap: var(--ab-space-md);
}

/* --------------------------------------------------------------------------
   o) Print
   -------------------------------------------------------------------------- */

@media print {
  .ab-dashboard__controls,
  .ab-period-selector,
  .ab-section-card__footer {
    display: none !important;
  }
  .ab-section-card {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ddd;
  }
  .ab-dashboard-table .dataTables_scrollBody {
    max-height: none !important;
  }
}


/* ==========================================================================
   6. Sidebar
   N5: CSS methodology — ab- prefixed classes handle structural layout
   (width, transitions, collapsed state, tooltip). Tailwind tw- utilities
   handle visual details (colors, padding, font sizes, spacing).
   N8: Print styles for sidebar are here. Other print rules are inline
   in app.blade.php — consolidation planned for Phase 2.
   ========================================================================== */

/* --------------------------------------------------------------------------
   a) Sidebar base — hidden on mobile, flex-column on desktop
   The sidebar is hidden by default. It becomes visible at the lg
   breakpoint (1024px) via the media query below. On mobile, the
   .small-view-side-active class (toggled by hamburger JS) shows it
   as an overlay — that class uses !important so it wins.
   -------------------------------------------------------------------------- */

.ab-sidebar {
  width: 256px;
  background: var(--ab-surface-card);
  border-inline-end: 1px solid var(--ab-surface-border);
  display: none;              /* F11-A fix: hidden by default (mobile) */
  flex-direction: column;
  height: 100%;
  position: relative;
  flex-shrink: 0;
  /* L3: width transition triggers layout recalculation on each frame.
     transform: translateX() would be more performant but requires different
     layout approach. The 0.25s duration is short enough to be acceptable. */
  transition: width 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  /* L4: overflow:hidden clips content during collapse animation. If a future
     feature needs elements to protrude (badges, flyouts), use position:fixed
     on those elements instead, like the tooltip does. */
  overflow: hidden;
  z-index: 40;
}

/* Show sidebar at desktop breakpoint (1024px = Tailwind lg) */
@media (min-width: 1024px) {
  .ab-sidebar {
    display: flex;
  }
}

/* F4-A: Flash prevention — synchronous class on <html> from early <script>.
   Applied before the sidebar renders, prevents expanded→collapsed flash. */
.ab-html-sidebar-collapsed .ab-sidebar {
  width: 68px;
}
.ab-html-sidebar-collapsed .ab-sidebar .ab-sidebar-label,
.ab-html-sidebar-collapsed .ab-sidebar .ab-sidebar-chevron,
.ab-html-sidebar-collapsed .ab-sidebar .ab-sidebar__logo-text,
.ab-html-sidebar-collapsed .ab-sidebar [role="heading"],
.ab-html-sidebar-collapsed .ab-sidebar .tw-border-t {
  display: none;
}
.ab-html-sidebar-collapsed .ab-sidebar .chiled {
  display: none !important;
}

/* --------------------------------------------------------------------------
   b) Sidebar logo area
   -------------------------------------------------------------------------- */

.ab-sidebar__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 14px;
  border-bottom: 1px solid var(--ab-surface-border-light);
  flex-shrink: 0;
  text-decoration: none;
  overflow: hidden;
  min-height: 60px;
  transition: padding 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.ab-sidebar__logo:hover {
  text-decoration: none;
}

/* Logo image (uploaded business logo) */
.ab-sidebar__logo-img {
  width: 36px;
  height: 36px;
  border-radius: var(--ab-radius-md);
  object-fit: contain;
  flex-shrink: 0;
  background: var(--ab-surface-bg);
}

/* Logo initials fallback (no uploaded logo) */
.ab-sidebar__logo-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--ab-radius-md);
  background: linear-gradient(135deg, var(--ab-primary-600), var(--ab-primary-800));
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 13px;
  flex-shrink: 0;
  letter-spacing: -0.5px;
}

.ab-sidebar__logo-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
  opacity: 1;
  transition: opacity 0.2s ease 0.05s, width 0.2s ease;
}

.ab-sidebar__logo-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--ab-text-primary);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ab-sidebar__logo-sub {
  font-size: var(--ab-text-xs);
  color: var(--ab-text-tertiary);
  white-space: nowrap;
}

/* --------------------------------------------------------------------------
   c) Sidebar menu area — scrollable
   -------------------------------------------------------------------------- */

.ab-sidebar__menu {
  flex: 1;
  padding: 8px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--ab-surface-border) transparent;
}

.ab-sidebar__menu::-webkit-scrollbar {
  width: 4px;
}
.ab-sidebar__menu::-webkit-scrollbar-track {
  background: transparent;
}
.ab-sidebar__menu::-webkit-scrollbar-thumb {
  background: var(--ab-surface-border);
  border-radius: 2px;
}

/* --------------------------------------------------------------------------
   d) Menu item styling
   -------------------------------------------------------------------------- */

/* Labels — transition for collapse animation */
.ab-sidebar .ab-sidebar-label {
  opacity: 1;
  width: auto;
  transition: opacity 0.15s ease 0.08s, width 0.15s ease;
  white-space: nowrap;
  overflow: hidden;
}

/* Chevrons — pushed to end via margin-inline-start auto (F8-A fix) */
.ab-sidebar .ab-sidebar-chevron {
  opacity: 1;
  margin-inline-start: auto;
  transition: opacity 0.15s ease 0.08s, width 0.15s ease;
  flex-shrink: 0;
}

/* Icon container — consistent size and alignment for all icons (SVG + FA) */
.ab-sidebar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.ab-sidebar-icon svg {
  width: 20px;
  height: 20px;
}

.ab-sidebar-icon i {
  font-size: 16px;
  width: 20px;
  text-align: center;
  line-height: 20px;
}

/* Active item: primary-50 bg + 3px inline-start border */
.ab-sidebar .ab-sidebar-item--active {
  background: var(--ab-primary-50) !important;
  color: var(--ab-primary-700) !important;
  border-inline-start: 3px solid var(--ab-primary-600);
  padding-inline-start: 11px; /* 14px - 3px border */
}

.ab-sidebar .ab-sidebar-item--active svg,
.ab-sidebar .ab-sidebar-item--active i {
  color: var(--ab-primary-600);
}

/* M1: Active child item — CSS fallback for Tailwind tw-text-primary-700 */
.ab-sidebar .ab-sidebar-child--active {
  color: var(--ab-primary-700) !important;
  font-weight: 600;
}

/* M9: Dropdown chevron flips in RTL */
[dir="rtl"] .ab-sidebar .ab-sidebar-chevron {
  transform: scaleX(-1);
}

/* Ensure all menu item links have a generous click target */
.ab-sidebar .ab-sidebar-item {
  min-height: 40px;
}

/* --------------------------------------------------------------------------
   e) Toggle button at sidebar bottom
   -------------------------------------------------------------------------- */

.ab-sidebar__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  border-top: 1px solid var(--ab-surface-border-light);
  flex-shrink: 0;
  background: var(--ab-surface-card);
}

.ab-sidebar__toggle-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--ab-radius-sm);
  border: 1px solid var(--ab-surface-border);
  background: var(--ab-surface-card);
  color: var(--ab-text-tertiary);
  cursor: pointer;
  transition: var(--ab-transition);
}

.ab-sidebar__toggle-btn:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
  border-color: var(--ab-primary-200);
}

.ab-sidebar__toggle-btn svg {
  width: 16px;
  height: 16px;
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Flip chevron in RTL */
[dir="rtl"] .ab-sidebar__toggle-btn svg {
  transform: scaleX(-1);
}

/* --------------------------------------------------------------------------
   f) Collapsed state (68px)
   -------------------------------------------------------------------------- */

.ab-sidebar.ab-sidebar--collapsed {
  width: 68px;
}

/* Hide labels, chevrons — fully removed from layout (display:none) */
.ab-sidebar--collapsed .ab-sidebar-label,
.ab-sidebar--collapsed .ab-sidebar-chevron {
  display: none;
}

/* Hide logo text */
.ab-sidebar--collapsed .ab-sidebar__logo-text {
  display: none;
}

/* Hide section headers and dividers in collapsed mode */
.ab-sidebar--collapsed [role="heading"],
.ab-sidebar--collapsed .tw-border-t {
  display: none;
}

/* Center menu items — zero gap, uniform padding, generous click target */
.ab-sidebar--collapsed .ab-sidebar__menu a.ab-sidebar-item {
  justify-content: center;
  gap: 0;
  padding: 10px;
  min-height: 44px;
  min-width: 44px;
  border-inline-start: none !important;
  padding-inline-start: 10px !important;
  padding-inline-end: 10px !important;
  border-radius: var(--ab-radius-md);
}

/* Icons slightly larger when collapsed for easier clicking */
.ab-sidebar--collapsed .ab-sidebar-icon {
  width: 24px;
  height: 24px;
}

.ab-sidebar--collapsed .ab-sidebar-icon svg {
  width: 22px;
  height: 22px;
}

.ab-sidebar--collapsed .ab-sidebar-icon i {
  font-size: 20px;
  width: 24px;
}

/* Hide sub-menus entirely when collapsed */
.ab-sidebar--collapsed .chiled {
  display: none !important;
}

/* No-transition helper — applied on page load, removed after first frame
   to prevent the 256→68px animation on navigation */
.ab-sidebar--no-transition,
.ab-sidebar--no-transition * {
  transition: none !important;
}

/* Flip toggle chevron direction when collapsed */
.ab-sidebar--collapsed .ab-sidebar__toggle-btn svg {
  transform: rotate(180deg);
}

[dir="rtl"] .ab-sidebar--collapsed .ab-sidebar__toggle-btn svg {
  transform: scaleX(-1) rotate(180deg);
}

/* Logo area: center the icon */
.ab-sidebar--collapsed .ab-sidebar__logo {
  justify-content: center;
  padding: 16px 8px;
}

/* --------------------------------------------------------------------------
   g) Tooltip — dark pill on hover when collapsed
   -------------------------------------------------------------------------- */

.ab-sidebar-tooltip {
  position: fixed;
  padding: 6px 12px;
  background: var(--ab-text-primary);
  color: #fff;
  font-size: var(--ab-text-sm);
  font-weight: 500;
  border-radius: var(--ab-radius-sm);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
  z-index: 9999;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.ab-sidebar-tooltip.ab-sidebar-tooltip--visible {
  opacity: 1;
}

/* Tooltip arrow — points toward sidebar */
.ab-sidebar-tooltip::before {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  inset-inline-start: -10px;
  border-inline-end-color: var(--ab-text-primary);
}

/* --------------------------------------------------------------------------
   h) Responsive — mobile uses overlay mechanism
   -------------------------------------------------------------------------- */

@media (max-width: 1023px) {
  /* Sidebar hidden by default (display:none in base rule).
     .small-view-side-active shows it as overlay via !important.
     Force full width and hide the desktop toggle button. */
  .ab-sidebar {
    width: 256px !important;
  }
  .ab-sidebar__toggle {
    display: none;
  }
}

/* Print: hide sidebar */
@media print {
  .ab-sidebar {
    display: none !important;
  }
}


/* ==========================================================================
   7. Navbar — clean slim white bar
   ========================================================================== */

.ab-navbar {
  height: 52px;
  background: var(--ab-surface-card);
  border-bottom: 1px solid var(--ab-surface-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  flex-shrink: 0;
  z-index: 20;
}

.ab-navbar__start,
.ab-navbar__end {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Ghost button — icon-only, no background */
.ab-navbar__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--ab-radius-sm);
  border: none;
  background: transparent;
  color: var(--ab-text-secondary);
  cursor: pointer;
  transition: var(--ab-transition);
  flex-shrink: 0;
  position: relative;
}

.ab-navbar__btn:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
}

.ab-navbar__btn svg {
  width: 20px;
  height: 20px;
}

/* Notification badge — red dot */
.ab-navbar__badge {
  position: absolute;
  top: 6px;
  inset-inline-end: 6px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 8px;
  background: var(--ab-status-overdue-dot);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
}

.ab-navbar__badge:empty {
  width: 8px;
  height: 8px;
  min-width: 8px;
  padding: 0;
  top: 8px;
  inset-inline-end: 8px;
}

/* Vertical divider between button groups */
.ab-navbar__divider {
  width: 1px;
  height: 24px;
  background: var(--ab-surface-border);
  flex-shrink: 0;
  margin: 0 2px;
}

/* POS button — primary accent */
.ab-navbar__pos {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--ab-radius-sm);
  background: var(--ab-primary-600);
  color: #fff;
  font-size: var(--ab-text-sm);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  transition: var(--ab-transition);
}

.ab-navbar__pos:hover {
  background: var(--ab-primary-700);
  color: #fff;
  text-decoration: none;
}

.ab-navbar__pos svg {
  width: 18px;
  height: 18px;
}

/* Date display */
.ab-navbar__date {
  font-size: var(--ab-text-sm);
  font-weight: 500;
  color: var(--ab-text-tertiary);
  font-feature-settings: "tnum";
  white-space: nowrap;
  padding: 0 4px;
}

/* User avatar */
.ab-navbar__user {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px 4px 4px;
  border-radius: var(--ab-radius-sm);
  cursor: pointer;
  transition: var(--ab-transition);
  border: none;
  background: transparent;
  list-style: none;
}

.ab-navbar__user:hover {
  background: var(--ab-surface-hover);
}

.ab-navbar__user::-webkit-details-marker {
  display: none;
}

.ab-navbar__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--ab-primary-600), var(--ab-primary-800));
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: -0.5px;
}

.ab-navbar__username {
  font-size: var(--ab-text-sm);
  font-weight: 500;
  color: var(--ab-text-primary);
  white-space: nowrap;
}

.ab-navbar__chevron {
  width: 14px;
  height: 14px;
  color: var(--ab-text-tertiary);
  flex-shrink: 0;
}

/* Dropdown card — clean white */
.ab-navbar__dropdown {
  position: absolute;
  inset-inline-end: 0;
  z-index: 50;
  margin-top: 4px;
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-lg);
  padding: var(--ab-space-sm);
  min-width: 200px;
}

.ab-navbar__dropdown-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: var(--ab-radius-sm);
  font-size: var(--ab-text-sm);
  font-weight: 500;
  color: var(--ab-text-secondary);
  text-decoration: none;
  transition: var(--ab-transition);
  cursor: pointer;
  border: none;
  background: none;
  width: 100%;
  text-align: start;
}

.ab-navbar__dropdown-item:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
  text-decoration: none;
}

.ab-navbar__dropdown-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: var(--ab-text-tertiary);
}

.ab-navbar__dropdown-item:hover svg {
  color: var(--ab-text-secondary);
}

.ab-navbar__dropdown-header {
  padding: 8px 12px 4px;
  font-size: var(--ab-text-xs);
  color: var(--ab-text-tertiary);
}

.ab-navbar__dropdown-name {
  font-size: var(--ab-text-sm);
  font-weight: 600;
  color: var(--ab-text-primary);
  margin-top: 2px;
}

.ab-navbar__dropdown-sep {
  height: 1px;
  background: var(--ab-surface-border-light);
  margin: var(--ab-space-xs) 0;
}

/* Superadmin switch-back badge */
.ab-navbar__switch-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: var(--ab-radius-full);
  background: var(--ab-status-overdue-bg);
  color: var(--ab-status-overdue-text);
  font-size: var(--ab-text-xs);
  font-weight: 600;
  text-decoration: none;
  transition: var(--ab-transition);
}

.ab-navbar__switch-back:hover {
  background: var(--ab-status-overdue-border);
  text-decoration: none;
  color: var(--ab-status-overdue-text);
}

.ab-navbar__switch-back svg {
  width: 14px;
  height: 14px;
}

/* Notifications — restyle toggle as ghost button inside navbar */
.ab-navbar .notifications-menu {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ab-navbar .notifications-menu .dropdown-toggle {
  /* C3/H3: targeted overrides instead of all:unset — keeps display and click target */
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--ab-radius-sm);
  border: none !important;
  background: transparent !important;
  color: var(--ab-text-secondary) !important;
  padding: 0 !important;
  cursor: pointer;
  transition: var(--ab-transition);
  position: relative;
  box-shadow: none !important;
  /* Override old Tailwind theme-color classes */
  --tw-ring-opacity: 0 !important;
}

.ab-navbar .notifications-menu .dropdown-toggle:hover {
  background: var(--ab-surface-hover) !important;
  color: var(--ab-text-primary) !important;
}

.ab-navbar .notifications-menu .dropdown-toggle svg {
  width: 20px;
  height: 20px;
}

/* C2: Override Bootstrap .label.label-warning badge to match design system */
.ab-navbar .notifications-menu .label.label-warning {
  position: absolute !important;
  top: 4px;
  inset-inline-end: 4px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px !important;
  border-radius: 8px !important;
  background: var(--ab-status-overdue-dot) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 16px;
  text-align: center;
  display: inline-block;
  border: 2px solid var(--ab-surface-card);
}

.ab-navbar .notifications-menu .label.label-warning:empty {
  width: 8px;
  height: 8px;
  min-width: 8px;
  padding: 0 !important;
  top: 6px;
  inset-inline-end: 6px;
  border: none;
}

/* Notifications dropdown card */
.ab-navbar .notifications-menu .dropdown-menu {
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-lg);
  padding: var(--ab-space-sm);
  max-height: 80vh;
  overflow-y: auto;
}

/* M6: Hide <details> marker in all browsers */
.ab-navbar details > summary {
  list-style: none;
}
.ab-navbar details > summary::-webkit-details-marker {
  display: none;
}
.ab-navbar details > summary::marker {
  display: none;
  content: '';
}

/* Responsive */
@media (max-width: 767px) {
  .ab-navbar {
    padding: 0 8px;
    max-width: 100vw;
    overflow-x: hidden;
  }
  .ab-navbar__end {
    gap: 4px;
    overflow: hidden;
  }
  .ab-navbar__date,
  .ab-navbar__username,
  .ab-navbar__divider,
  .ab-navbar__chevron {
    display: none;
  }
  .ab-navbar__pos {
    padding: 6px 10px;
    font-size: 11px;
  }
  .ab-navbar__pos svg {
    display: none;
  }
}

@media print {
  .ab-navbar {
    display: none !important;
  }
}


/* ==========================================================================
   14. Sales List Pages — Unified Visual Improvements
   ========================================================================== */

/* --------------------------------------------------------------------------
   a) Primary action button
   -------------------------------------------------------------------------- */

.ab-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  text-decoration: none;
  white-space: nowrap;
  transition: var(--ab-transition);
  cursor: pointer;
  line-height: 1.4;
}

.ab-btn:hover,
.ab-btn:focus {
  text-decoration: none;
  outline: none;
}

.ab-btn svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.ab-btn-primary {
  color: var(--ab-text-inverse);
  background: var(--ab-primary-600);
}

.ab-btn-primary:hover,
.ab-btn-primary:focus {
  background: var(--ab-primary-700);
  color: var(--ab-text-inverse);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.25);
}


/* --------------------------------------------------------------------------
   b) Unified list card — filter + table in one container
   -------------------------------------------------------------------------- */

.ab-list-card {
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-lg);
  box-shadow: var(--ab-shadow-sm);
}

/* Strip individual container styling from children */
.ab-list-card .ab-filter-toolbar {
  border: none;
  border-radius: 0;
  box-shadow: none;
  margin-bottom: 0;
  border-bottom: 1px solid var(--ab-surface-border-light);
}

/* Action buttons row — between filter bar and table */
.ab-list-actions {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--ab-space-sm);
  padding: 2px var(--ab-space-lg) 0;
}

.ab-actions-divider {
  width: 1px;
  height: 20px;
  background: var(--ab-surface-border);
  flex-shrink: 0;
}

.ab-list-card .ab-table-container {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
}

/* Strip widget internal padding inside list card */
.ab-list-card .ab-table-container > div {
  padding: 0 !important;
}

.ab-list-card .ab-table-container .tw-py-2 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.ab-list-card .ab-table-container .margin-bottom-10 {
  margin-bottom: 0;
}

/* Override Tailwind utility classes on widget inside list card */
.ab-list-card > [class*="tw-ring"] {
  --tw-ring-shadow: 0 0 #0000 !important;
  --tw-ring-offset-shadow: 0 0 #0000 !important;
}

.ab-list-card > [class*="tw-shadow"] {
  --tw-shadow: 0 0 #0000 !important;
  --tw-shadow-colored: 0 0 #0000 !important;
}

.ab-list-card > [class*="tw-rounded"] {
  border-radius: 0 !important;
}

.ab-list-card > [class*="tw-mb-"] {
  margin-bottom: 0 !important;
}


/* --------------------------------------------------------------------------
   c) Hide DataTable search & length — filter toolbar provides this
   -------------------------------------------------------------------------- */

.ab-list-card .dataTables_length {
  display: none !important;
}

.ab-list-card .dataTables_filter {
  display: none !important;
}


/* --------------------------------------------------------------------------
   d) DataTable export buttons — hidden, proxied by ab-export-dropdown
   -------------------------------------------------------------------------- */

.ab-list-card .dt-buttons {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}


/* --------------------------------------------------------------------------
   d-2) Export dropdown — page header export menu
   -------------------------------------------------------------------------- */

.ab-btn-outline {
  color: var(--ab-text-secondary);
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border);
}

.ab-btn-outline:hover,
.ab-btn-outline:focus {
  color: var(--ab-text-primary);
  background: var(--ab-surface-hover);
  border-color: var(--ab-surface-border);
}

.ab-export-dropdown {
  position: relative;
}

.ab-export-chevron {
  width: 12px !important;
  height: 12px !important;
  opacity: 0.5;
  transition: transform 0.15s ease;
}

.ab-export-dropdown.open .ab-export-chevron {
  transform: rotate(180deg);
}

.ab-export-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  inset-inline-end: 0;
  min-width: 180px;
  background: var(--ab-surface-card);
  border: 1px solid var(--ab-surface-border-light);
  border-radius: var(--ab-radius-md);
  box-shadow: var(--ab-shadow-lg);
  padding: 4px;
  z-index: 50;
}

.ab-export-dropdown.open .ab-export-menu {
  display: block;
}

.ab-export-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ab-text-secondary);
  background: none;
  border: none;
  border-radius: var(--ab-radius-sm);
  cursor: pointer;
  transition: var(--ab-transition);
  text-align: start;
  white-space: nowrap;
}

.ab-export-item:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
}

.ab-export-item svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  opacity: 0.6;
}

.ab-export-item:hover svg {
  opacity: 1;
}

.ab-export-divider {
  height: 1px;
  background: var(--ab-surface-border-light);
  margin: 4px 6px;
}

@media print {
  .ab-export-dropdown {
    display: none !important;
  }
}


/* --------------------------------------------------------------------------
   d-3) Column Visibility Side Panel
   -------------------------------------------------------------------------- */

.ab-colvis-panel {
  position: fixed;
  inset: 0;
  z-index: 70;
  pointer-events: none;
  visibility: hidden;
}

.ab-colvis-panel.open {
  pointer-events: auto;
  visibility: visible;
}

/* Overlay */
.ab-colvis-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.35);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.ab-colvis-panel.open .ab-colvis-overlay {
  opacity: 1;
}

/* Panel body — slides from inline-start (right in RTL, left in LTR) */
.ab-colvis-body {
  position: absolute;
  top: 0;
  bottom: 0;
  inset-inline-start: 0;
  width: 280px;
  background: var(--ab-surface-card);
  box-shadow: var(--ab-shadow-lg);
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform 0.25s ease;
}

[dir="rtl"] .ab-colvis-body {
  transform: translateX(100%);
}

.ab-colvis-panel.open .ab-colvis-body {
  transform: translateX(0);
}

/* Header */
.ab-colvis-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--ab-surface-border-light);
  flex-shrink: 0;
}

.ab-colvis-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ab-text-primary);
}

.ab-colvis-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: none;
  border-radius: var(--ab-radius-sm);
  color: var(--ab-text-tertiary);
  cursor: pointer;
  transition: var(--ab-transition);
}

.ab-colvis-close:hover {
  background: var(--ab-surface-hover);
  color: var(--ab-text-primary);
}

/* Column list — scrollable */
.ab-colvis-list {
  flex: 1;
  overflow-y: auto;
  padding: 6px 8px;
  scrollbar-width: thin;
  scrollbar-color: var(--ab-surface-border) transparent;
}

.ab-colvis-list::-webkit-scrollbar {
  width: 4px;
}

.ab-colvis-list::-webkit-scrollbar-track {
  background: transparent;
}

.ab-colvis-list::-webkit-scrollbar-thumb {
  background: var(--ab-surface-border);
  border-radius: 3px;
}

.ab-colvis-list::-webkit-scrollbar-thumb:hover {
  background: var(--ab-text-tertiary);
}

.ab-colvis-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 7px 8px;
  border-radius: var(--ab-radius-sm);
  transition: background 0.1s ease;
}

.ab-colvis-item:hover {
  background: var(--ab-surface-hover);
}

.ab-colvis-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--ab-text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  flex: 1;
}

/* Toggle switch */
.ab-colvis-toggle {
  position: relative;
  width: 36px;
  height: 20px;
  border-radius: 10px;
  border: none;
  background: var(--ab-surface-border);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  transition: background 0.15s ease;
}

.ab-colvis-toggle.on {
  background: #22C55E;
}

.ab-colvis-knob {
  position: absolute;
  top: 2px;
  inset-inline-start: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  transition: inset-inline-start 0.15s ease, transform 0.15s ease;
}

.ab-colvis-toggle.on .ab-colvis-knob {
  inset-inline-start: 18px;
}

/* Footer */
.ab-colvis-footer {
  flex-shrink: 0;
  border-top: 1px solid var(--ab-surface-border-light);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ab-colvis-reset {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ab-text-tertiary);
  background: none;
  border: 1px dashed var(--ab-surface-border);
  border-radius: var(--ab-radius-sm);
  cursor: pointer;
  transition: var(--ab-transition);
}

.ab-colvis-reset:hover {
  color: var(--ab-primary-600);
  border-color: var(--ab-primary-200);
  background: var(--ab-primary-50);
}

.ab-colvis-reset svg {
  width: 14px;
  height: 14px;
}

/* Permanent save toggle */
.ab-colvis-perm {
  padding: 0 2px;
}

.ab-colvis-perm-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
  margin: 0;
  font-weight: normal;
}

.ab-colvis-perm-check {
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--ab-primary-600);
}

.ab-colvis-perm-text {
  display: flex;
  flex-direction: column;
}

.ab-colvis-perm-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ab-text-secondary);
  line-height: 1.3;
}

.ab-colvis-perm-desc {
  font-size: 10.5px;
  color: var(--ab-text-tertiary);
  line-height: 1.3;
}

/* Responsive */
@media (max-width: 639px) {
  .ab-colvis-body {
    width: 100%;
  }
}

@media print {
  .ab-colvis-panel {
    display: none !important;
  }
}


/* --------------------------------------------------------------------------
   e) Sort indicators — clean arrows replacing default DataTable icons
   -------------------------------------------------------------------------- */

.ab-table-container .table > thead > tr > th.sorting,
.ab-table-container .table > thead > tr > th.sorting_asc,
.ab-table-container .table > thead > tr > th.sorting_desc {
  background-image: none !important;
  position: relative;
  padding-inline-end: 22px !important;
}

.ab-table-container .table > thead > tr > th.sorting::after {
  content: "⇅";
  position: absolute;
  inset-inline-end: 6px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 10px;
  opacity: 0.25;
  color: var(--ab-text-tertiary);
}

.ab-table-container .table > thead > tr > th.sorting_asc::after {
  content: "↑";
  position: absolute;
  inset-inline-end: 6px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  font-weight: 700;
  opacity: 0.7;
  color: var(--ab-primary-600);
}

.ab-table-container .table > thead > tr > th.sorting_desc::after {
  content: "↓";
  position: absolute;
  inset-inline-end: 6px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  font-weight: 700;
  opacity: 0.7;
  color: var(--ab-primary-600);
}


/* --------------------------------------------------------------------------
   f) Print override for ab-list-card
   -------------------------------------------------------------------------- */

@media print {
  .ab-list-card {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }
}

/* ==========================================================================
   Stock Report — alert rows & summary table
   ========================================================================== */

/* Low stock alert row highlight */
tr.ab-row-alert > td {
  background: rgba(239, 68, 68, 0.08) !important;
}
tr.ab-row-alert:hover > td {
  background: rgba(239, 68, 68, 0.12) !important;
}

/* Accounting-style summary table colors */
.bg-subtotal {
  background-color: #dff0d8 !important;
}
.bg-grand-total {
  background-color: #d1f9ff !important;
}
.font-weight-bold {
  font-weight: 700 !important;
}
