/* ============================================
   TABLES - Data Tables, Sorting, Mini Tables
   ============================================ */

/* Table Container */
.table-container {
  flex: 1;
  overflow: auto;
}

/* Base Table Styles */
table {
  width: 100%;
  border-collapse: collapse;
}

th, td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

/* Narrow category column in leads table */
.col-category {
  width: 90px;
  max-width: 90px;
  white-space: nowrap;
}

/* Fixed-width columns for owner/berater/assistant */
#leadsTable [data-col="owner"],
#leadsTable [data-col="berater"],
#leadsTable [data-col="assistant"] {
  width: 100px;
  max-width: 100px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Center only the category data cells, not the header */
#leadsTable tbody td.col-category {
  text-align: center;
}

th {
  background: var(--bg);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  color: var(--text-light);
  white-space: nowrap;
  position: sticky;
  top: 0;
}

th.sortable {
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
}

th.sortable:hover {
  background: var(--border);
}

th.sortable::after {
  content: '';
  display: inline-block;
  margin-left: 5px;
  width: 0;
  height: 0;
  vertical-align: middle;
}

th.sort-asc::after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 5px solid var(--primary);
}

th.sort-desc::after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--primary);
}

tbody tr {
  cursor: pointer;
  transition: background 0.1s;
}

tbody tr:hover {
  background: var(--bg);
}

tbody tr.selected {
  background: #dbeafe;
}

/* Mini Table */
.mini-table {
  font-size: 12px;
}

.mini-table th,
.mini-table td {
  padding: 6px 8px;
}

.text-light {
  color: var(--text-light);
  font-size: 11px;
}

/* Revenue Year-Month Grid Table */
.revenue-grid-table {
  width: 100%;
  font-size: 11px;
  border-collapse: collapse;
}

.revenue-grid-table th,
.revenue-grid-table td {
  padding: 6px 4px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.revenue-grid-table th {
  font-weight: 600;
  color: var(--text-light);
  background: var(--bg);
}

.revenue-grid-table .year-label {
  font-weight: 600;
  text-align: left;
  padding-left: 8px;
}

.revenue-grid-table .year-total {
  font-weight: 700;
  background: var(--bg);
  color: var(--primary);
}

.revenue-grid-table .has-value {
  color: var(--success);
  font-weight: 500;
}

.revenue-grid-table .zero-value {
  color: var(--text-light);
}

.revenue-grid-table tbody tr:hover {
  background: var(--bg);
}

.revenue-grid-table .type-label {
  font-weight: 500;
  text-align: left;
  padding-left: 8px;
  white-space: nowrap;
}

.revenue-grid-table .type-label.closed {
  color: var(--success);
}

.revenue-grid-table .type-label.cancelled {
  color: var(--danger);
}

.revenue-grid-table .type-label.net {
  color: var(--primary);
  font-weight: 700;
}

.revenue-grid-table .has-value.cancelled {
  color: var(--danger);
}

.revenue-grid-table .has-value.net {
  color: var(--primary);
  font-weight: 600;
}

.revenue-grid-table .has-value.net.negative {
  color: var(--danger);
}

.revenue-grid-table .year-total.closed {
  color: var(--success);
}

.revenue-grid-table .year-total.cancelled {
  color: var(--danger);
}

.revenue-grid-table .year-total.net {
  color: var(--primary);
  font-weight: 700;
  font-size: 12px;
}

.revenue-grid-table .net-row {
  border-bottom: 2px solid var(--border);
}

/* Enhanced Mini Table for Dashboard */
.dashboard-table {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}

.dashboard-table th {
  background: var(--bg);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 10px;
  color: var(--text-light);
  padding: 8px 6px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.dashboard-table td {
  padding: 8px 6px;
  border-bottom: 1px solid var(--border);
}

.dashboard-table tr:hover {
  background: var(--bg);
}

.dashboard-table .text-right {
  text-align: right;
}

.dashboard-table .text-center {
  text-align: center;
}

.dashboard-table .highlight-value {
  font-weight: 600;
  color: var(--primary);
}

.dashboard-table .positive {
  color: var(--success);
}

.dashboard-table .negative {
  color: var(--danger);
}

/* Analytics Table */
.analytics-table {
  width: 100%;
  font-size: 13px;
  border-collapse: collapse;
}

.analytics-table th {
  background: var(--bg);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 11px;
  color: var(--text-light);
  padding: 10px 8px;
  text-align: center;
  border-bottom: 2px solid var(--border);
}

.analytics-table th:first-child {
  text-align: left;
}

.analytics-table td {
  padding: 10px 8px;
  text-align: center;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}

.analytics-table td:first-child {
  text-align: left;
  font-weight: 600;
}

.analytics-table .pct {
  font-size: 11px;
  color: var(--text-light);
  font-weight: 400;
}

.analytics-table tbody tr:hover {
  background: var(--bg);
}

/* Drilldown cell crosshair hover — column highlight */
.analytics-table td.drilldown-cell {
  position: relative;
}

.analytics-table td.drilldown-cell:hover::after {
  content: '';
  position: absolute;
  top: -5000px;
  left: 0;
  right: 0;
  bottom: -5000px;
  background: rgba(37, 99, 235, 0.05);
  pointer-events: none;
  z-index: 0;
}

.analytics-table .total-row {
  background: var(--bg);
  font-weight: 700;
  font-size: 14px;
}

.analytics-table .total-row td {
  border-top: 2px solid var(--border);
  padding: 12px 8px;
}

.analytics-table .success {
  color: var(--success);
}

.analytics-table .danger {
  color: var(--danger);
}

.analytics-table .warning {
  color: var(--warning);
}

.analytics-table .primary {
  color: var(--primary);
  font-weight: 600;
}

/* Appointment Breakdown Table */
.appt-breakdown-table {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
  margin-bottom: 12px;
}

.appt-breakdown-table th {
  font-weight: 600;
  color: var(--text-light);
  text-align: center;
  padding: 8px 4px;
  font-size: 10px;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
}

.appt-breakdown-table th:first-child {
  text-align: left;
  width: 50px;
}

.appt-breakdown-table td {
  padding: 8px 4px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.appt-breakdown-table .label-cell {
  font-weight: 600;
  text-align: left;
  color: var(--primary);
}

.appt-breakdown-table .total-cell {
  font-weight: 600;
}

.appt-breakdown-table .attended-cell {
  color: var(--success);
}

.appt-breakdown-table .missed-cell {
  color: var(--danger);
}

.appt-breakdown-table .pct {
  font-size: 10px;
  color: var(--text-light);
}

.appt-breakdown-table .total-row {
  background: var(--bg);
  font-weight: 600;
}

.appt-breakdown-table .total-row .label-cell {
  color: var(--text);
}

.appt-breakdown-table tbody tr:hover {
  background: var(--bg);
}

/* Concepts Breakdown Table */
.concepts-breakdown-table {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}

.concepts-breakdown-table th {
  font-weight: 600;
  color: var(--text-light);
  text-align: center;
  padding: 6px 4px;
  font-size: 10px;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
}

.concepts-breakdown-table th:first-child {
  text-align: left;
  width: 80px;
}

.concepts-breakdown-table td {
  padding: 6px 4px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.concepts-breakdown-table .label-cell {
  font-weight: 600;
  text-align: left;
  color: var(--primary);
}

.concepts-breakdown-table .total-cell {
  font-weight: 600;
}

.concepts-breakdown-table .closed-cell {
  color: var(--success);
}

.concepts-breakdown-table .rejected-cell {
  color: var(--danger);
}

.concepts-breakdown-table .cancelled-cell {
  color: var(--warning);
}

.concepts-breakdown-table .eh-cell {
  font-weight: 600;
  color: var(--primary);
}

.concepts-breakdown-table .pct {
  font-size: 10px;
  color: var(--text-light);
}

.concepts-breakdown-table .total-row {
  background: var(--bg);
  font-weight: 600;
}

.concepts-breakdown-table .total-row .label-cell {
  color: var(--text);
}

.concepts-breakdown-table tbody tr:hover {
  background: var(--bg);
}

.concepts-breakdown-table .empty-state {
  text-align: center;
  color: var(--text-light);
  font-style: italic;
  padding: 12px;
}
