/* ============================================================
   UltimatePOS — 2026 Ultra-Modern Theme
   Light Sidebar · Glassmorphism · Micro-animations · Premium UI
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;1,14..32,400&display=swap');

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --sb-bg:        #ffffff;
  --sb-text:      #4b5563;
  --sb-text-hover:#111827;
  --sb-text-active:#4f46e5;
  --sb-item-hover: #f5f3ff;
  --sb-item-active:#ede9fe;
  --sb-item-active-ring:rgba(99,102,241,0.25);
  --sb-divider:   #e5e7eb;
  --sb-accent:    #6366f1;

  --content-bg:   #f0f4f8;
  --card-bg:      #ffffff;
  --card-radius:  14px;
  --card-shadow:  0 1px 3px rgba(15,23,42,0.04), 0 6px 20px rgba(15,23,42,0.07);
  --card-shadow-h:0 8px 32px rgba(15,23,42,0.14);

  --btn-radius:   8px;
  --ease:         cubic-bezier(0.4,0,0.2,1);
  --ease-spring:  cubic-bezier(0.34,1.56,0.64,1);
  --dur:          180ms;
}

/* ─── GLOBAL RESETS ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif !important;
  background-color: var(--content-bg) !important;
  -webkit-font-smoothing: antialiased !important;
}

/* ─── SIDEBAR ────────────────────────────────────────────── */
.side-bar {
  background: #ffffff !important;
  border-right: 1px solid #e5e7eb !important;
  box-shadow: 2px 0 12px rgba(0,0,0,0.06) !important;
}

/* Sidebar brand bar */
.side-bar > a:first-child {
  position: relative !important;
  overflow: hidden !important;
}
.side-bar > a:first-child span.tw-inline-block {
  box-shadow: 0 0 8px 2px rgba(74,222,128,0.6) !important;
}

/* Scrollbar in sidebar */
#side-bar {
  border-right: none !important;
  background: transparent !important;
  scrollbar-width: thin;
  scrollbar-color: #d1d5db transparent;
}
#side-bar::-webkit-scrollbar       { width: 3px; }
#side-bar::-webkit-scrollbar-track { background: transparent; }
#side-bar::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 3px; }

/* Section headers */
#side-bar > div[class*="px-3"][class*="py-2"],
#side-bar > div > div[class*="text-xs"] {
  color: #9ca3af !important;
  font-size: 10px !important;
  letter-spacing: 0.10em !important;
  margin-top: 8px !important;
}

/* Top-level menu links */
#side-bar > a.tw-flex,
#side-bar > div > a.tw-flex:not(.drop_down) {
  color: var(--sb-text) !important;
  border-radius: 9px !important;
  transition: background var(--dur) var(--ease),
              color var(--dur) var(--ease) !important;
}
#side-bar > a.tw-flex:hover,
#side-bar > div > a.tw-flex:hover {
  background: var(--sb-item-hover) !important;
  color: var(--sb-text-hover) !important;
}

/* Active top-level link */
#side-bar > a.tw-bg-gray-200,
#side-bar a.tw-bg-gray-200 {
  background: var(--sb-item-active) !important;
  color: var(--sb-text-active) !important;
  box-shadow: inset 0 0 0 1px var(--sb-item-active-ring) !important;
}

/* SVG icons */
#side-bar svg:not(.svg) {
  color: inherit !important;
  opacity: 0.7;
  transition: opacity var(--dur) var(--ease) !important;
}
#side-bar a:hover svg:not(.svg),
#side-bar a.tw-bg-gray-200 svg:not(.svg) { opacity: 1; }

/* Dropdown toggle */
#side-bar .drop_down {
  color: var(--sb-text) !important;
  border-radius: 9px !important;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease) !important;
}
#side-bar .drop_down:hover {
  background: var(--sb-item-hover) !important;
  color: var(--sb-text-hover) !important;
}
#side-bar .tw-pb-1.tw-rounded-md.tw-bg-gray-200,
#side-bar .drop_down.tw-pb-1 {
  background: var(--sb-item-active) !important;
  color: var(--sb-text-active) !important;
}

/* Dropdown chevron */
#side-bar svg.svg { color: #9ca3af !important; transition: color var(--dur) var(--ease) !important; }
#side-bar a:hover svg.svg { color: #6b7280 !important; }

/* Child items */
#side-bar .chiled .tw-bg-gray-200.tw-w-px,
#side-bar .chiled [class*="w-px"] {
  background: #e5e7eb !important;
}
#side-bar .chiled a {
  color: #6b7280 !important;
  font-size: 13px !important;
  transition: color var(--dur) var(--ease) !important;
}
#side-bar .chiled a:hover { color: #111827 !important; }
#side-bar .chiled a.tw-text-primary-700 {
  color: var(--sb-text-active) !important;
  font-weight: 500 !important;
}

/* Divider */
#side-bar .tw-my-2 {
  border-top: 1px solid #f3f4f6 !important;
  margin-top: 8px !important;
  margin-bottom: 8px !important;
}

/* ─── HEADER — sticky + depth (all themes) ───────────────── */
.thetop > main > div:first-child:not(#app) {
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.15) !important;
}

/* Crystal override — only when blue or default (primary) is selected */
.thetop > main > div.tw-from-primary-800,
.thetop > main > div.tw-from-blue-800,
.thetop > main > div.tw-from-blue-light-800 {
  background-image: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 45%, #0284c7 100%) !important;
  box-shadow: 0 2px 16px rgba(14,165,233,0.35),
              0 1px 0 rgba(255,255,255,0.15) inset !important;
}

/* Sidebar brand bar — crystal when blue/primary */
.side-bar > a.tw-bg-primary-800,
.side-bar > a.tw-bg-blue-800,
.side-bar > a.tw-bg-blue-light-800 {
  background: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 45%, #0284c7 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,0.15) !important;
}

/* ─── CONTENT AREA ───────────────────────────────────────── */
#scrollable-container {
  background: var(--content-bg) !important;
}

/* ─── ADMINLTE BOX → MODERN CARD ────────────────────────── */
.box, .box-primary, .box-success, .box-warning, .box-danger, .box-info,
.box-default, .box-solid {
  background: var(--card-bg) !important;
  border: none !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease) !important;
  overflow: hidden !important;
}
.box:hover {
  box-shadow: var(--card-shadow-h) !important;
}
.box-header {
  background: transparent !important;
  border-bottom: 1px solid #f1f5f9 !important;
  padding: 16px 20px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: #1e293b !important;
  border-radius: var(--card-radius) var(--card-radius) 0 0 !important;
}
.box-header .box-title {
  font-weight: 600 !important;
  font-size: 15px !important;
  color: #1e293b !important;
  letter-spacing: -0.01em !important;
}
.box-header .box-tools { margin-top: 0 !important; }
.box-body {
  padding: 20px !important;
  border-radius: 0 0 var(--card-radius) var(--card-radius) !important;
}
.box-footer {
  background: #f8fafc !important;
  border-top: 1px solid #f1f5f9 !important;
  border-radius: 0 0 var(--card-radius) var(--card-radius) !important;
  padding: 12px 20px !important;
}

/* Info boxes */
.info-box {
  background: var(--card-bg) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  border: none !important;
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease) !important;
  overflow: hidden !important;
}
.info-box:hover {
  box-shadow: var(--card-shadow-h) !important;
  transform: translateY(-2px) !important;
}
.info-box-icon {
  border-radius: var(--card-radius) 0 0 var(--card-radius) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.info-box-content {
  padding: 10px 16px !important;
}
.info-box-text {
  font-weight: 500 !important;
  font-size: 12px !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  opacity: 0.7 !important;
}
.info-box-number {
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}

/* Small boxes */
.small-box {
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  border: none !important;
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease) !important;
  overflow: hidden !important;
}
.small-box:hover {
  box-shadow: var(--card-shadow-h) !important;
  transform: translateY(-3px) !important;
}
.small-box h3 {
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}
.small-box .small-box-footer {
  transition: background var(--dur) var(--ease) !important;
}

/* ─── TABLES ─────────────────────────────────────────────── */
.table,
.dataTable,
table.table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}
.table > thead > tr > th,
.dataTable > thead > tr > th {
  background: #f8fafc !important;
  color: #64748b !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  padding: 10px 14px !important;
  border-bottom: 2px solid #e2e8f0 !important;
  border-top: none !important;
  white-space: nowrap !important;
}
.table > tbody > tr > td,
.dataTable > tbody > tr > td {
  padding: 11px 14px !important;
  border-top: 1px solid #f1f5f9 !important;
  color: #374151 !important;
  vertical-align: middle !important;
  font-size: 13.5px !important;
  transition: background var(--dur) var(--ease) !important;
}
.table-striped > tbody > tr:nth-of-type(odd) > td {
  background: #fafbff !important;
}
.table > tbody > tr:hover > td {
  background: #eff6ff !important;
}
.table-bordered { border: none !important; }
.table-bordered td, .table-bordered th { border-color: #f1f5f9 !important; }

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn {
  border-radius: var(--btn-radius) !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  letter-spacing: 0.01em !important;
  transition: all var(--dur) var(--ease) !important;
  border: none !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06) !important;
}
.btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}
.btn:active {
  transform: translateY(0) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.1) !important;
}
.btn-primary {
  background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
  color: #fff !important;
}
.btn-primary:hover { background: linear-gradient(135deg, #818cf8 0%, #6366f1 100%) !important; }
.btn-success {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
  color: #fff !important;
}
.btn-success:hover { background: linear-gradient(135deg, #34d399 0%, #10b981 100%) !important; }
.btn-danger {
  background: linear-gradient(135deg, #f43f5e 0%, #e11d48 100%) !important;
  color: #fff !important;
}
.btn-danger:hover { background: linear-gradient(135deg, #fb7185 0%, #f43f5e 100%) !important; }
.btn-warning {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%) !important;
  color: #fff !important;
}
.btn-warning:hover { background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%) !important; }
.btn-info {
  background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%) !important;
  color: #fff !important;
}
.btn-info:hover { background: linear-gradient(135deg, #22d3ee 0%, #06b6d4 100%) !important; }
.btn-default {
  background: #ffffff !important;
  color: #374151 !important;
  border: 1px solid #e5e7eb !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05) !important;
}
.btn-default:hover { background: #f9fafb !important; border-color: #d1d5db !important; }

/* Button sizes */
.btn-xs { font-size: 11px !important; padding: 3px 9px !important; border-radius: 6px !important; }
.btn-sm { font-size: 12px !important; padding: 5px 12px !important; }
.btn-lg { font-size: 15px !important; padding: 10px 24px !important; border-radius: 10px !important; }

/* ─── FORM CONTROLS ──────────────────────────────────────── */
.form-control,
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="tel"], input[type="search"],
select, textarea {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: var(--btn-radius) !important;
  font-size: 13.5px !important;
  color: #1e293b !important;
  background: #fff !important;
  transition: border-color var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03) !important;
}
.form-control:focus,
input[type="text"]:focus, input[type="email"]:focus,
input[type="password"]:focus, input[type="number"]:focus,
select:focus, textarea:focus {
  border-color: var(--sb-accent) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.15) !important;
  outline: none !important;
}

/* Select2 */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: var(--btn-radius) !important;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: var(--sb-accent) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.15) !important;
}

/* ─── DATEPICKER / FLATPICKR ─────────────────────────────── */
.flatpickr-calendar {
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.04) !important;
  border: none !important;
}

/* ─── LABELS / BADGES ────────────────────────────────────── */
.label {
  border-radius: 6px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.03em !important;
  padding: 3px 8px !important;
}
.badge {
  border-radius: 100px !important;
  font-weight: 600 !important;
  font-size: 10.5px !important;
  letter-spacing: 0.03em !important;
  padding: 3px 8px !important;
}

/* ─── ALERTS ─────────────────────────────────────────────── */
.alert {
  border-radius: 10px !important;
  border: none !important;
  font-size: 13.5px !important;
}
.alert-success { background: #ecfdf5 !important; color: #065f46 !important; box-shadow: inset 3px 0 0 #10b981 !important; }
.alert-danger   { background: #fff1f2 !important; color: #9f1239 !important; box-shadow: inset 3px 0 0 #f43f5e !important; }
.alert-warning  { background: #fffbeb !important; color: #92400e !important; box-shadow: inset 3px 0 0 #f59e0b !important; }
.alert-info     { background: #ecfeff !important; color: #155e75 !important; box-shadow: inset 3px 0 0 #06b6d4 !important; }

/* ─── MODALS ─────────────────────────────────────────────── */
.modal-content {
  border: none !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04) !important;
  overflow: hidden !important;
}
.modal-header {
  background: #f8fafc !important;
  border-bottom: 1px solid #f1f5f9 !important;
  padding: 18px 24px !important;
}
.modal-title {
  font-weight: 700 !important;
  font-size: 16px !important;
  color: #1e293b !important;
  letter-spacing: -0.01em !important;
}
.modal-body { padding: 24px !important; }
.modal-footer {
  background: #f8fafc !important;
  border-top: 1px solid #f1f5f9 !important;
  padding: 14px 24px !important;
}

/* ─── TABS ───────────────────────────────────────────────── */
.nav-tabs {
  border-bottom: 2px solid #e2e8f0 !important;
}
.nav-tabs > li > a {
  border: none !important;
  border-radius: 0 !important;
  color: #64748b !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  padding: 10px 18px !important;
  margin-bottom: -2px !important;
  transition: color var(--dur) var(--ease) !important;
}
.nav-tabs > li > a:hover { color: #1e293b !important; background: transparent !important; }
.nav-tabs > li.active > a,
.nav-tabs > li.active > a:focus,
.nav-tabs > li.active > a:hover {
  border: none !important;
  border-bottom: 2px solid var(--sb-accent) !important;
  color: var(--sb-accent) !important;
  font-weight: 600 !important;
  background: transparent !important;
}

/* ─── PAGINATION ─────────────────────────────────────────── */
.pagination > li > a,
.pagination > li > span {
  border-radius: var(--btn-radius) !important;
  border: 1px solid #e5e7eb !important;
  color: #374151 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  margin: 0 2px !important;
  transition: all var(--dur) var(--ease) !important;
}
.pagination > li > a:hover {
  background: #f0f4f8 !important;
  border-color: #d1d5db !important;
}
.pagination > .active > a,
.pagination > .active > span {
  background: var(--sb-accent) !important;
  border-color: var(--sb-accent) !important;
  color: #fff !important;
}

/* ─── SCROLLTOP BUTTON ───────────────────────────────────── */
.scrolltop {
  position: fixed !important;
  bottom: 28px !important;
  right: 28px !important;
  width: 40px !important;
  height: 40px !important;
  background: linear-gradient(135deg, #6366f1, #4f46e5) !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 16px rgba(99,102,241,0.4) !important;
  transition: all var(--dur) var(--ease) !important;
  z-index: 100 !important;
}
.scrolltop:hover {
  transform: translateY(-3px) scale(1.05) !important;
  box-shadow: 0 8px 24px rgba(99,102,241,0.5) !important;
}
.scrolltop .scroll.icon i { color: #fff !important; font-size: 16px !important; }

/* ─── FOOTER ─────────────────────────────────────────────── */
.tw-mt-auto {
  background: transparent !important;
}

/* ─── PAGE HEADER ────────────────────────────────────────── */
.content-header {
  background: transparent !important;
  padding: 18px 20px 8px !important;
}
.content-header h1 {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #1e293b !important;
  letter-spacing: -0.02em !important;
}
.breadcrumb {
  background: transparent !important;
  padding: 0 !important;
  font-size: 12px !important;
}
.breadcrumb > li { color: #64748b !important; }
.breadcrumb > li + li::before { color: #94a3b8 !important; }
.breadcrumb > .active { color: #1e293b !important; font-weight: 500 !important; }

/* ─── DATATABLE WRAPPER ──────────────────────────────────── */
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_info {
  font-size: 12.5px !important;
  color: #64748b !important;
}
.dataTables_wrapper .dataTables_filter input {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 8px !important;
  padding: 5px 12px !important;
  font-size: 13px !important;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease) !important;
}
.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--sb-accent) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
  outline: none !important;
}

/* ─── PROGRESS BARS ──────────────────────────────────────── */
.progress {
  border-radius: 100px !important;
  background: #f1f5f9 !important;
  box-shadow: none !important;
}
.progress-bar { border-radius: 100px !important; }

/* ─── DROPDOWNS ──────────────────────────────────────────── */
.dropdown-menu {
  border: 1px solid #f1f5f9 !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.10), 0 0 0 1px rgba(0,0,0,0.03) !important;
  padding: 6px !important;
}
.dropdown-menu > li > a {
  border-radius: 8px !important;
  font-size: 13px !important;
  color: #374151 !important;
  padding: 8px 12px !important;
  transition: background var(--dur) var(--ease) !important;
}
.dropdown-menu > li > a:hover {
  background: #f0f4f8 !important;
  color: #1e293b !important;
}
.dropdown-divider, .divider { border-color: #f1f5f9 !important; margin: 4px 0 !important; }

/* ─── TOOLTIPS ───────────────────────────────────────────── */
.tooltip-inner {
  border-radius: 7px !important;
  font-size: 12px !important;
  padding: 5px 10px !important;
  background: #1e293b !important;
}

/* ─── LOGIN PAGE ─────────────────────────────────────────── */
body.pace-done > .container-fluid,
body.hold-transition > .container-fluid {
  min-height: 100vh;
  background: linear-gradient(135deg, #0f172a 0%, #1a2540 40%, #0c1120 100%) !important;
  position: relative;
}
body.pace-done > .container-fluid::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 30%, rgba(99,102,241,0.15) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 80% 70%, rgba(16,185,129,0.08) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
body.pace-done .right-col {
  position: relative;
  z-index: 1;
}

/* Login card */
body.pace-done .login-box,
body.pace-done .register-box {
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 20px !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.05) !important;
  padding: 0 !important;
  overflow: hidden !important;
}
body.pace-done .login-box-body,
body.pace-done .register-box-body {
  background: rgba(255,255,255,0.04) !important;
  color: #e2e8f0 !important;
  padding: 32px !important;
  border-radius: 0 !important;
}
body.pace-done .login-box-body .form-control {
  background: rgba(255,255,255,0.06) !important;
  border: 1.5px solid rgba(255,255,255,0.12) !important;
  color: #f8fafc !important;
  border-radius: 10px !important;
}
body.pace-done .login-box-body .form-control:focus {
  border-color: #6366f1 !important;
  background: rgba(255,255,255,0.1) !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.2) !important;
}
body.pace-done .login-box-body .form-control::placeholder { color: rgba(255,255,255,0.35) !important; }
body.pace-done .login-logo,
body.pace-done .login-box-msg {
  color: #f1f5f9 !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  padding: 24px 24px 8px !important;
  background: rgba(0,0,0,0.2) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}
body.pace-done .login-logo a { color: #ffffff !important; }
body.pace-done .btn-primary {
  background: linear-gradient(135deg, #6366f1, #4f46e5) !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em !important;
  box-shadow: 0 4px 16px rgba(99,102,241,0.4) !important;
}
body.pace-done .btn-primary:hover {
  background: linear-gradient(135deg, #818cf8, #6366f1) !important;
  box-shadow: 0 6px 20px rgba(99,102,241,0.5) !important;
}

/* Login checkbox */
body.pace-done .checkbox label { color: #94a3b8 !important; }

/* ─── PRINT SAFETY ───────────────────────────────────────── */
@media print {
  .side-bar { display: none !important; }
  body { background: #fff !important; }
  .box, .box-primary { box-shadow: none !important; border: 1px solid #ddd !important; }
}

/* ─── PAGE TRANSITION ────────────────────────────────────── */
/* IMPORTANT: Do NOT add any animation here that targets
   `.tw-flex-1.tw-overflow-y-auto` (== #scrollable-container).
   - Animating `transform` leaves a residual identity matrix that
     traps `position: fixed` descendants (modal/backdrop confined to
     the scroll container, can't cover the viewport).
   - Animating `opacity` (or any stacking-context-creating property)
     promotes #scrollable-container to a compositor layer and creates
     a stacking context. The modal subtree is then submerged below
     the modal-backdrop at root level, even though the modal's
     z-index (1050) is higher than the backdrop's (1040). The modal
     renders correctly but every click lands on the backdrop, making
     the page feel frozen.
   The page-in fade was removed entirely; the marginal visual benefit
   isn't worth breaking modals. */

/* ─── CUSTOM SCROLLBAR (content area) ───────────────────── */
#scrollable-container {
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 transparent;
}
#scrollable-container::-webkit-scrollbar { width: 5px; }
#scrollable-container::-webkit-scrollbar-track { background: transparent; }
#scrollable-container::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 5px; }
#scrollable-container::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* ─── SIDEBAR GLOW PULSE (online indicator) ─────────────── */
@keyframes onlinePulse {
  0%, 100% { box-shadow: 0 0 5px 1px rgba(74,222,128,0.5); }
  50%       { box-shadow: 0 0 10px 3px rgba(74,222,128,0.8); }
}
.side-bar span.tw-bg-green-400 {
  animation: onlinePulse 2.5s ease-in-out infinite !important;
}

/* ─── SHIMMER LOADING SKELETON ───────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, #f0f4f8 25%, #e2e8f0 50%, #f0f4f8 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s ease-in-out infinite;
  border-radius: 6px;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
