body { background: #f4f6fa; }
.card { border: none; box-shadow: 0 1px 3px rgba(0,0,0,.08); }
.report-table input[type=time], .report-table input[type=text] { padding: .25rem .5rem; }
.select2-container--bootstrap-5 .select2-selection { min-height: 38px; }

/* Mobile: stack report rows as cards */
@media (max-width: 768px) {
  .report-table thead { display: none; }
  .report-table tbody tr { display: block; border: 1px solid #dee2e6; border-radius: .5rem; padding: .75rem; margin-bottom: .75rem; background: #fff; }
  .report-table tbody td { display: flex; justify-content: space-between; align-items: center; padding: .35rem 0; border: none; }
  .report-table tbody td::before { content: attr(data-label); font-weight: 600; color: #6c757d; flex: 0 0 40%; }
  .report-table tbody td > * { flex: 1; }
}

.stat-card { padding: 1rem 1.25rem; border-radius: .75rem; color: #fff; }
.stat-card .lbl { opacity: .85; font-size: .85rem; }
.stat-card .val { font-size: 1.75rem; font-weight: 700; line-height: 1; }
.bg-grad-1 { background: linear-gradient(135deg,#0d6efd,#0aa1dd); }
.bg-grad-2 { background: linear-gradient(135deg,#20c997,#0d6efd); }
.bg-grad-3 { background: linear-gradient(135deg,#fd7e14,#dc3545); }
.bg-grad-4 { background: linear-gradient(135deg,#6f42c1,#d63384); }
