/* ─────────────────────────────────────────────────────
   TAP APP — Executive Dashboard Theme
   Enterprise-grade visual polish for case management.
   Layered over Tailwind utility classes — no JS changes.
   ───────────────────────────────────────────────────── */

/* ── 1. Design Tokens ── */
:root {
  /* Primary palette — refined indigo pulled from branding */
  --tap-primary: var(--brand-primary, #4338ca);
  --tap-primary-light: #eef2ff;
  --tap-primary-muted: #818cf8;
  --tap-primary-deep: #312e81;

  /* Surfaces */
  --tap-bg: #f8f9fb;
  --tap-surface: #ffffff;
  --tap-surface-raised: #ffffff;
  --tap-surface-sunken: #f1f3f8;
  --tap-border: #e8ecf2;
  --tap-border-light: #f0f2f6;

  /* Text */
  --tap-text: #1a1d26;
  --tap-text-secondary: #5c6370;
  --tap-text-muted: #8e95a2;
  --tap-text-faint: #b4bac5;

  /* Semantic */
  --tap-success: #059669;
  --tap-success-bg: #ecfdf5;
  --tap-warning: #d97706;
  --tap-warning-bg: #fffbeb;
  --tap-danger: #dc2626;
  --tap-danger-bg: #fef2f2;
  --tap-info: #2563eb;
  --tap-info-bg: #eff6ff;

  /* Shadows */
  --tap-shadow-sm: 0 1px 2px rgba(0,0,0,0.04), 0 1px 3px rgba(0,0,0,0.02);
  --tap-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 4px 12px rgba(0,0,0,0.04);
  --tap-shadow-md: 0 2px 8px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.06);
  --tap-shadow-lg: 0 4px 12px rgba(0,0,0,0.06), 0 12px 40px rgba(0,0,0,0.08);
  --tap-shadow-glow: 0 0 0 3px rgba(67,56,202,0.12);

  /* Radii */
  --tap-radius-sm: 8px;
  --tap-radius: 12px;
  --tap-radius-lg: 16px;
  --tap-radius-xl: 20px;

  /* Transitions */
  --tap-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --tap-duration: 200ms;
  --tap-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── 2. Global Resets ── */
*, *::before, *::after {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  color: var(--tap-text);
  background: var(--tap-bg);
  letter-spacing: -0.01em;
  font-feature-settings: 'cv01', 'cv02', 'cv03', 'cv04', 'ss01';
}

/* ── 3. Typography Scale ── */
h1, .text-2xl {
  font-weight: 700 !important;
  letter-spacing: -0.025em;
  color: var(--tap-text) !important;
}

h2, .text-xl {
  font-weight: 600 !important;
  letter-spacing: -0.02em;
}

h3, .text-lg, .font-semibold {
  letter-spacing: -0.01em;
}

/* Monospace numbers in data displays */
.text-2xl.font-bold,
.text-xl.font-bold,
.text-3xl.font-bold,
.text-4xl.font-bold {
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum';
}

/* ── 4. Top Navigation Bar ── */
nav.bg-brand-900,
nav[class*="bg-brand-900"] {
  background: linear-gradient(135deg, var(--tap-primary-deep) 0%, #1e1b4b 100%) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

/* Search trigger in top bar */
nav button[title="Search (⌘K)"],
nav button[onclick="openCommandBar()"] {
  border-radius: var(--tap-radius-sm) !important;
  backdrop-filter: blur(8px);
  transition: all var(--tap-duration) var(--tap-ease);
}

nav button[title="Search (⌘K)"]:hover {
  background: rgba(255,255,255,0.12) !important;
  transform: translateY(-1px);
}

/* Notification bell */
nav button[title="Notifications"]:hover,
nav button[aria-label="Notifications"]:hover {
  background: rgba(255,255,255,0.1) !important;
  transform: scale(1.05);
  transition: all var(--tap-duration) var(--tap-ease);
}

/* Notification badge pulse */
#notif-badge:not(.hidden) {
  animation: tapPulse 2s infinite;
}

@keyframes tapPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.4); }
  50% { box-shadow: 0 0 0 4px rgba(239,68,68,0); }
}

/* ── 5. Sidebar ── */
aside.border-r,
aside[class*="border-r"] {
  background: var(--tap-surface) !important;
  border-right: 1px solid var(--tap-border) !important;
  box-shadow: 1px 0 8px rgba(0,0,0,0.02);
}

/* Dashboard nav button — active state */
aside button[class*="bg-brand-600"] {
  background: var(--tap-primary) !important;
  box-shadow: var(--tap-shadow-sm), 0 0 0 1px rgba(67,56,202,0.2);
  border-radius: var(--tap-radius-sm) !important;
  transition: all var(--tap-duration) var(--tap-ease);
}

/* Sidebar group headers */
aside button[class*="uppercase"] {
  font-size: 0.65rem !important;
  letter-spacing: 0.08em;
  padding: 6px 12px !important;
  margin-top: 4px;
  color: var(--tap-text-muted) !important;
  transition: all var(--tap-duration) var(--tap-ease);
}
aside button[class*="uppercase"]:hover {
  color: var(--tap-text-secondary) !important;
  background: var(--tap-surface-sunken) !important;
}

/* Sidebar group color dots */
aside button[class*="uppercase"] span[class*="rounded-full"] {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.04);
}

/* Sidebar nav items */
aside button[class*="px-3"][class*="py-2"],
aside a[class*="px-3"][class*="py-2"] {
  border-radius: var(--tap-radius-sm) !important;
  transition: all 150ms var(--tap-ease);
  position: relative;
}

aside button[class*="px-3"][class*="py-2"]:hover,
aside a[class*="px-3"][class*="py-2"]:hover {
  transform: translateX(2px);
}

/* Sidebar active item — enhanced */
aside button[class*="bg-blue-50"],
aside button[class*="bg-amber-50"],
aside button[class*="bg-teal-50"],
aside button[class*="bg-indigo-50"],
aside button[class*="bg-emerald-50"],
aside button[class*="bg-violet-50"],
aside button[class*="bg-red-50"],
aside button[class*="bg-purple-50"],
aside button[class*="bg-slate-100"] {
  box-shadow: var(--tap-shadow-sm);
  font-weight: 600 !important;
}

/* Sidebar user footer */
aside .mt-auto {
  background: var(--tap-surface-sunken);
  border-top: 1px solid var(--tap-border) !important;
  padding: 16px !important;
}

/* Sidebar search shortcut */
aside button[class*="border-gray-200"][class*="bg-gray-50"] {
  border: 1px dashed var(--tap-border) !important;
  background: var(--tap-surface-sunken) !important;
  border-radius: var(--tap-radius-sm) !important;
}

/* Sidebar pending badges */
aside span[class*="bg-red-500"][class*="rounded-full"],
aside span[class*="bg-blue-500"][class*="rounded-full"],
aside span[class*="bg-amber-400"][class*="rounded-full"],
aside span[class*="bg-orange-500"][class*="rounded-full"] {
  font-size: 10px !important;
  min-width: 20px !important;
  height: 20px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

/* ── 6. Command Bar ── */
#cmd-overlay > div {
  border-radius: var(--tap-radius-lg) !important;
  box-shadow: var(--tap-shadow-lg), 0 0 0 1px rgba(0,0,0,0.05);
  border: none !important;
  animation: cmdSlideDown 200ms var(--tap-ease);
}

@keyframes cmdSlideDown {
  from { opacity: 0; transform: translateY(-12px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

#cmd-overlay input {
  font-size: 15px !important;
}

#cmd-list > div,
#cmd-list button {
  transition: all 100ms var(--tap-ease);
}

#cmd-list > div:hover,
#cmd-list button:hover {
  background: var(--tap-primary-light) !important;
}

/* ── 7. Cards & Surfaces ── */

/* All white cards → floating with shadows */
.bg-white.rounded-xl,
.bg-white[class*="rounded-xl"],
div[class*="bg-white"][class*="rounded-xl"] {
  border: 1px solid var(--tap-border) !important;
  border-radius: var(--tap-radius) !important;
  box-shadow: var(--tap-shadow-sm);
  transition: box-shadow var(--tap-duration) var(--tap-ease), transform var(--tap-duration) var(--tap-ease);
}

/* Clickable card hover lift */
div[class*="bg-white"][class*="rounded-xl"][class*="cursor-pointer"]:hover,
div[class*="bg-white"][class*="rounded-xl"][onclick]:hover {
  box-shadow: var(--tap-shadow-md);
  transform: translateY(-1px);
}

/* Metric stat cards — the 6 KPI cards on dashboard */
#dashboard-stats > div {
  border-radius: var(--tap-radius) !important;
  border: 1px solid var(--tap-border) !important;
  box-shadow: var(--tap-shadow-sm);
  padding: 16px !important;
  transition: all var(--tap-duration) var(--tap-ease);
  position: relative;
  overflow: hidden;
}

#dashboard-stats > div::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--tap-border);
  border-radius: var(--tap-radius) var(--tap-radius) 0 0;
  transition: background var(--tap-duration) var(--tap-ease);
}

#dashboard-stats > div:nth-child(1)::before { background: var(--tap-primary); }
#dashboard-stats > div:nth-child(2)::before { background: #f59e0b; }
#dashboard-stats > div:nth-child(3)::before { background: #3b82f6; }
#dashboard-stats > div:nth-child(4)::before { background: #8b5cf6; }
#dashboard-stats > div:nth-child(5)::before { background: #14b8a6; }
#dashboard-stats > div:nth-child(6)::before { background: #ef4444; }

#dashboard-stats > div:hover {
  box-shadow: var(--tap-shadow-md);
  transform: translateY(-2px);
}

/* Stat card big numbers */
#dashboard-stats .text-2xl {
  font-size: 1.75rem !important;
  font-weight: 800 !important;
  line-height: 1.2;
}

/* Stat card emoji icons */
#dashboard-stats .text-lg {
  font-size: 1.25rem;
  filter: saturate(0.85);
}

/* ── 8. Tables ── */
table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-variant-numeric: tabular-nums;
}

thead th {
  background: var(--tap-surface-sunken) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tap-text-muted) !important;
  padding: 10px 16px !important;
  border-bottom: 1px solid var(--tap-border);
  white-space: nowrap;
}

thead th:first-child {
  border-radius: var(--tap-radius-sm) 0 0 0;
}

thead th:last-child {
  border-radius: 0 var(--tap-radius-sm) 0 0;
}

tbody tr {
  transition: background 100ms var(--tap-ease);
}

tbody tr:hover {
  background: var(--tap-primary-light) !important;
}

tbody tr:nth-child(even) {
  background: rgba(248, 249, 251, 0.5);
}

tbody tr:nth-child(even):hover {
  background: var(--tap-primary-light) !important;
}

tbody td {
  padding: 10px 16px !important;
  font-size: 13px;
  color: var(--tap-text);
  border-bottom: 1px solid var(--tap-border-light);
}

/* ── 9. Buttons ── */

/* Primary CTA */
button[class*="bg-brand-600"],
.bg-brand-600 {
  background: var(--tap-primary) !important;
  border-radius: var(--tap-radius-sm) !important;
  font-weight: 600 !important;
  box-shadow: var(--tap-shadow-sm), 0 0 0 1px rgba(67,56,202,0.2);
  transition: all var(--tap-duration) var(--tap-ease);
}

button[class*="bg-brand-600"]:hover {
  background: #3730a3 !important;
  box-shadow: var(--tap-shadow), 0 0 0 1px rgba(67,56,202,0.3);
  transform: translateY(-1px);
}

button[class*="bg-brand-600"]:active {
  transform: translateY(0);
  box-shadow: var(--tap-shadow-sm);
}

/* Secondary / outline buttons */
button[class*="border-amber-200"],
button[class*="border-orange-200"],
button[class*="border-gray-200"] {
  border-radius: var(--tap-radius-sm) !important;
  transition: all var(--tap-duration) var(--tap-ease);
}

button[class*="border-amber-200"]:hover,
button[class*="border-orange-200"]:hover {
  transform: translateY(-1px);
  box-shadow: var(--tap-shadow-sm);
}

/* Ghost buttons */
button[class*="hover:bg-gray-50"],
button[class*="hover:bg-gray-100"] {
  border-radius: var(--tap-radius-sm) !important;
  transition: all 150ms var(--tap-ease);
}

/* ── 10. Form Inputs ── */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
input[type="search"],
input[type="tel"],
input[type="url"],
textarea,
select {
  border: 1px solid var(--tap-border) !important;
  border-radius: var(--tap-radius-sm) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  color: var(--tap-text);
  background: var(--tap-surface) !important;
  transition: all var(--tap-duration) var(--tap-ease);
  box-shadow: 0 1px 2px rgba(0,0,0,0.02);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--tap-primary) !important;
  box-shadow: var(--tap-shadow-glow), 0 1px 2px rgba(0,0,0,0.04) !important;
  outline: none !important;
}

input::placeholder,
textarea::placeholder {
  color: var(--tap-text-faint);
}

/* Labels */
label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--tap-text-secondary);
  letter-spacing: 0;
}

/* ── 11. Badges & Pills ── */
span[class*="rounded-full"][class*="text-xs"][class*="font-medium"],
.category-badge {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em;
  padding: 3px 10px !important;
  border-radius: 100px !important;
}

/* ── 12. Notification Panel ── */
#notif-panel {
  border-radius: var(--tap-radius) !important;
  box-shadow: var(--tap-shadow-lg) !important;
  border: 1px solid var(--tap-border) !important;
  animation: notifSlideDown 200ms var(--tap-ease);
}

@keyframes notifSlideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

#notif-panel .bg-gray-50 {
  background: var(--tap-surface-sunken) !important;
}

/* ── 13. Breadcrumbs ── */
nav[aria-label="Breadcrumb"] {
  padding: 6px 0;
  font-size: 12px;
}

nav[aria-label="Breadcrumb"] button:hover {
  color: var(--tap-primary) !important;
}

/* ── 14. Page Transitions ── */
.fade-in {
  animation: tapFadeIn 250ms var(--tap-ease) !important;
}

@keyframes tapFadeIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── 15. Main Content Area ── */
main {
  max-width: 1400px;
}

/* Section headers — page titles */
main h1.text-2xl {
  font-size: 1.625rem !important;
  font-weight: 700 !important;
  color: var(--tap-text) !important;
}

/* Subtitle text under page titles */
main p.text-gray-500.text-sm {
  color: var(--tap-text-muted) !important;
  font-size: 13px !important;
}

/* ── 16. Alert Panels ── */
#overdue-alerts-panel {
  border-radius: var(--tap-radius) !important;
  box-shadow: var(--tap-shadow-sm);
}

#pending-applications-panel {
  border-radius: var(--tap-radius) !important;
  box-shadow: var(--tap-shadow-sm);
}

/* ── 17. Progress Bars ── */
div[class*="bg-gray-100"][class*="rounded-full"][class*="overflow-hidden"] {
  background: var(--tap-surface-sunken) !important;
  height: 6px !important;
  border-radius: 100px !important;
}

div[class*="bg-brand-500"][class*="rounded-full"] {
  background: var(--tap-primary) !important;
  border-radius: 100px !important;
  transition: width 600ms var(--tap-ease);
}

/* ── 18. Scrollbar ── */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

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

::-webkit-scrollbar-thumb {
  background: var(--tap-border);
  border-radius: 100px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--tap-text-faint);
}

aside::-webkit-scrollbar {
  width: 4px;
}

/* ── 19. Loading Skeletons ── */
@keyframes tapShimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.tap-skeleton {
  background: linear-gradient(90deg, var(--tap-surface-sunken) 25%, #e8ecf2 50%, var(--tap-surface-sunken) 75%);
  background-size: 200% 100%;
  animation: tapShimmer 1.5s infinite;
  border-radius: var(--tap-radius-sm);
}

/* Loading placeholders → skeleton effect */
.text-gray-500:only-child {
  transition: opacity 300ms var(--tap-ease);
}

/* ── 20. Mobile Sidebar ── */
#mobile-menu {
  border-radius: 0 var(--tap-radius-xl) var(--tap-radius-xl) 0 !important;
  box-shadow: var(--tap-shadow-lg) !important;
  animation: mobileSlideIn 250ms var(--tap-ease);
}

@keyframes mobileSlideIn {
  from { transform: translateX(-100%); }
  to { transform: translateX(0); }
}

#mobile-menu-overlay {
  backdrop-filter: blur(4px);
  background: rgba(0,0,0,0.4) !important;
  animation: tapFadeOverlay 200ms var(--tap-ease);
}

@keyframes tapFadeOverlay {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* ── 21. Login & Register Pages ── */
.bg-gradient-to-br[class*="from-brand-900"] {
  background: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #1e1b4b 100%) !important;
}

/* Login card */
.bg-white.rounded-2xl.shadow-xl {
  border-radius: var(--tap-radius-xl) !important;
  box-shadow: var(--tap-shadow-lg) !important;
  border: 1px solid rgba(0,0,0,0.04);
}

/* Login icon container */
.bg-white\/10.backdrop-blur.rounded-2xl {
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.1);
}

/* ── 22. Chart & Data Viz Enhancement ── */
canvas {
  border-radius: var(--tap-radius-sm);
}

/* ── 23. Compliance Metric Cards ── */
div[class*="rounded-xl"][class*="p-4"] .text-2xl.font-bold,
div[class*="rounded-xl"][class*="p-4"] .text-3xl.font-bold {
  font-variant-numeric: tabular-nums;
}

/* Toggle buttons (date range filters) */
div[class*="bg-gray-100"][class*="rounded-lg"][class*="p-1"] {
  background: var(--tap-surface-sunken) !important;
  border-radius: var(--tap-radius-sm) !important;
  padding: 3px !important;
  border: 1px solid var(--tap-border);
}

div[class*="bg-gray-100"][class*="rounded-lg"][class*="p-1"] button {
  border-radius: 6px !important;
  transition: all 150ms var(--tap-ease);
}

div[class*="bg-gray-100"][class*="rounded-lg"][class*="p-1"] button[class*="bg-white"] {
  box-shadow: var(--tap-shadow-sm) !important;
  background: var(--tap-surface) !important;
  color: var(--tap-primary) !important;
  font-weight: 600 !important;
}

/* ── 24. Section Headers Inside Cards ── */
div[class*="bg-gray-50"][class*="border-b"] {
  background: var(--tap-surface-sunken) !important;
  border-bottom: 1px solid var(--tap-border-light) !important;
}

/* ── 25. Quick Access Links ── */
.space-y-1 button[class*="hover:bg-gray-50"],
.space-y-1 a[class*="hover:bg-gray-50"] {
  border-radius: var(--tap-radius-sm) !important;
}

.space-y-1 button[class*="hover:bg-gray-50"]:hover,
.space-y-1 a[class*="hover:bg-gray-50"]:hover {
  background: var(--tap-primary-light) !important;
  color: var(--tap-primary) !important;
  transform: translateX(2px);
  transition: all 150ms var(--tap-ease);
}

/* ── 26. Service Stats Grid ── */
#dashboard-service-stats > div {
  padding: 12px !important;
  border-radius: var(--tap-radius-sm);
  background: var(--tap-surface-sunken);
  transition: all var(--tap-duration) var(--tap-ease);
}

#dashboard-service-stats > div:hover {
  background: var(--tap-primary-light);
}

/* ── 27. Welcome Header Polish ── */
.fade-in > .mb-6:first-child h1 {
  font-size: 1.625rem !important;
}

/* Quick action buttons row */
.fade-in > .mb-6:first-child .flex.items-center.gap-2 button {
  font-size: 13px !important;
  padding: 8px 14px !important;
}

/* ── 28. Tooltip / Hover Cards ── */
[title]:not(button):not(a) {
  cursor: help;
}

/* ── 29. Status Indicators ── */
span[class*="bg-green-100"],
span[class*="bg-green-50"] {
  border: 1px solid rgba(5,150,105,0.15);
}

span[class*="bg-red-100"],
span[class*="bg-red-50"] {
  border: 1px solid rgba(220,38,38,0.15);
}

span[class*="bg-yellow-100"],
span[class*="bg-amber-100"],
span[class*="bg-amber-50"] {
  border: 1px solid rgba(217,119,6,0.15);
}

/* ── 30. Dividers ── */
.divide-y > *:not(:first-child),
.divide-y-gray-100 > *:not(:first-child) {
  border-color: var(--tap-border-light) !important;
}

/* ── 31. Selection Style ── */
::selection {
  background: rgba(67,56,202,0.15);
  color: var(--tap-text);
}

/* ── 32. Focus Ring ── */
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: none;
  box-shadow: var(--tap-shadow-glow);
}

/* ── 33. Print Stylesheet ── */
@media print {
  nav, aside, #mobile-menu, #mobile-menu-overlay, #cmd-overlay, #notif-panel,
  button[onclick*="navigate"], button[onclick*="openCommandBar"],
  .no-print {
    display: none !important;
  }

  body {
    background: white !important;
    font-size: 11pt !important;
    color: #000 !important;
  }

  main {
    padding: 0 !important;
    max-width: 100% !important;
  }

  .bg-white, [class*="bg-white"] {
    box-shadow: none !important;
    border: 1px solid #ddd !important;
  }

  table {
    page-break-inside: auto;
  }

  tr {
    page-break-inside: avoid;
  }

  h1, h2, h3 {
    page-break-after: avoid;
  }

  @page {
    margin: 0.75in;
  }
}

/* ── 34. Responsive Tweaks ── */
@media (max-width: 640px) {
  main {
    padding: 12px !important;
  }

  #dashboard-stats > div {
    padding: 12px !important;
  }

  #dashboard-stats .text-2xl {
    font-size: 1.375rem !important;
  }

  /* Touch-friendly tap targets */
  button, a {
    min-height: 44px;
    min-height: max(44px, auto);
  }

  aside button, aside a,
  #mobile-menu button, #mobile-menu a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
}

/* Wide screens — constrain content width */
@media (min-width: 1600px) {
  main {
    max-width: 1400px;
    margin: 0 auto;
  }
}

/* ── 35. Skeleton Screen Utility ── */
.tap-loading-line {
  height: 12px;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--tap-surface-sunken) 25%, #e8ecf2 50%, var(--tap-surface-sunken) 75%);
  background-size: 200% 100%;
  animation: tapShimmer 1.5s infinite;
  margin-bottom: 8px;
}

.tap-loading-line:nth-child(2) { width: 75%; }
.tap-loading-line:nth-child(3) { width: 50%; }

/* ── 36. Smooth Sidebar Collapse ── */
aside div[id^="sg-"] {
  transition: all 200ms var(--tap-ease);
  overflow: hidden;
}

aside div[id^="sg-"].hidden {
  max-height: 0;
  opacity: 0;
  margin: 0;
  padding: 0;
}

aside div[id^="sg-"]:not(.hidden) {
  max-height: 500px;
  opacity: 1;
}

aside svg[id^="sg-arrow-"] {
  transition: transform 200ms var(--tap-ease) !important;
}

/* ── 37. Card Section Borders ── */
div[class*="border-b"][class*="border-gray-100"] {
  border-color: var(--tap-border-light) !important;
}

div[class*="border-b"][class*="border-gray-200"] {
  border-color: var(--tap-border) !important;
}

/* ── 38. Hover States for List Items ── */
.divide-y > div:hover,
.divide-y > a:hover {
  background: rgba(67,56,202,0.03);
}

/* ── 39. Compact Mobile Nav Hamburger ── */
@media (max-width: 640px) {
  nav .px-4.py-3 {
    padding: 10px 16px !important;
  }
}

/* ── 40. Empty State Polish ── */
.text-center.text-gray-400 {
  color: var(--tap-text-muted) !important;
}
