/* ============================================
   Dashboard Page Specific Styles
   ============================================ */

/* KPI Grid */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
}

@media (max-width: 1400px) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Chart Grid */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
}

.charts-grid .chart-card.full-width {
  grid-column: 1 / -1;
}

@media (max-width: 1400px) {
  .charts-grid {
    grid-template-columns: 1fr;
  }
}

/* Activity Section */
.recent-activity {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.recent-activity .activity-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  border-bottom: 1px solid var(--border-subtle);
}

.recent-activity .activity-title {
  font-size: 0.92rem;
  font-weight: 600;
}

.recent-activity .activity-badge {
  font-size: 0.72rem;
  font-family: var(--font-mono);
  padding: 2px 8px;
  background: rgba(255,255,255,0.04);
  border-radius: var(--radius-sm);
  color: var(--text-tertiary);
}

/* --- Reports KPI trend pills --- */
.rpt-kpi-trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 500;
  margin-top: var(--space-sm);
  padding: 2px 8px;
  border-radius: var(--radius-full);
}

.rpt-kpi-trend.up {
  color: var(--color-success);
  background: var(--color-success-bg);
}

.rpt-kpi-trend.down {
  color: var(--color-danger);
  background: var(--color-danger-bg);
}

.rpt-kpi-trend.neutral {
  color: var(--text-tertiary);
  background: #F1F5F9;
}

/* --- Reports Page Extras --- */
.reports-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-lg);
  padding: var(--space-lg) var(--space-xl);
}

.reports-filter-bar .form-group {
  margin-bottom: 0;
}

.reports-filter-bar .filter-separator {
  width: 1px;
  height: 28px;
  background: var(--border-default);
}

/* Risk Trends */
.risk-trends {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

/* --- Feedback page --- */
.feedback-detail {
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
}

.feedback-prompt {
  background: var(--bg-input);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--text-secondary);
  margin: var(--space-lg) 0;
  line-height: 1.6;
}

.feedback-prompt .highlight {
  background: var(--color-warning-bg);
  color: var(--color-warning);
  padding: 1px 4px;
  border-radius: 3px;
  border: 1px solid var(--color-warning-border);
}

/* ─── Data Row (Categories + Chatbots side by side) ─── */
.data-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-xl);
}

@media (max-width: 1400px) {
  .data-row {
    grid-template-columns: 1fr;
  }
}

/* Category horizontal bars */
.cat-bar-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.cat-bar-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.cat-bar-label {
  width: 90px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-secondary);
  text-align: right;
  flex-shrink: 0;
}

.cat-bar-track {
  flex: 1;
  height: 24px;
  background: var(--bg-input);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.cat-bar-fill {
  height: 100%;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  padding-left: var(--space-md);
  transition: width 600ms cubic-bezier(0.16, 1, 0.3, 1);
}

.cat-bar-fill span {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 600;
  color: white;
  white-space: nowrap;
}

.cat-bar-value {
  width: 40px;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  font-weight: 500;
  text-align: right;
  flex-shrink: 0;
}

/* Chatbot ranked list */
.chatbot-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.chatbot-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.chatbot-row:hover {
  background: var(--bg-card-hover);
}

.chatbot-rank {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-input);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-tertiary);
  flex-shrink: 0;
}

.chatbot-row:first-child .chatbot-rank {
  background: rgba(var(--brand-primary-rgb), 0.08);
  color: var(--brand-primary);
}

.chatbot-name {
  flex: 1;
  font-size: 0.88rem;
  font-weight: 500;
}

.chatbot-bar-wrap {
  width: 120px;
  flex-shrink: 0;
}

.chatbot-bar-track {
  height: 6px;
  background: var(--bg-input);
  border-radius: 3px;
  overflow: hidden;
}

.chatbot-bar-fill {
  height: 100%;
  border-radius: 3px;
  background: var(--brand-primary);
}

.chatbot-pct {
  width: 36px;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text-secondary);
  text-align: right;
  flex-shrink: 0;
}

.chatbot-count {
  width: 48px;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--text-tertiary);
  text-align: right;
  flex-shrink: 0;
}

/* Activity table user/chatbot cells */
.user-cell {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.user-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-success);
  flex-shrink: 0;
}

.activity-chatbot {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--text-secondary);
}

/* --- Chatbots page (table-pro) --- */
.cb-toolbar { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.cb-search-box { position: relative; }
.cb-search-box input { width: 280px; padding: 8px 12px 8px 36px; border: 1px solid var(--border-card); border-radius: var(--radius-md); font-size: 0.88rem; font-family: var(--font-sans); background: var(--bg-card); color: var(--text-primary); outline: none; transition: border-color 150ms; }
.cb-search-box input:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px rgba(21,94,239,0.1); }
.cb-search-box input::placeholder { color: var(--text-tertiary); }
.cb-search-box svg { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--text-tertiary); }

.cb-filter-pills { display: flex; gap: 4px; }
.cb-filter-pill { padding: 6px 14px; border-radius: 999px; font-size: 0.82rem; font-weight: 500; border: 1px solid var(--border-card); background: var(--bg-card); color: var(--text-secondary); cursor: pointer; transition: all 150ms; font-family: var(--font-sans); }
.cb-filter-pill:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.cb-filter-pill.active { background: var(--brand-primary); color: white; border-color: var(--brand-primary); }

.cb-bulk-btn { margin-left: auto; padding: 8px 16px; border-radius: var(--radius-md); font-size: 0.85rem; font-weight: 500; border: 1px solid var(--border-card); background: var(--bg-card); color: var(--text-tertiary); cursor: not-allowed; font-family: var(--font-sans); transition: all 150ms; }
.cb-bulk-btn.enabled { color: var(--brand-primary); border-color: var(--brand-primary); cursor: pointer; background: rgba(21,94,239,0.05); }
.cb-bulk-btn.enabled:hover { background: var(--brand-primary); color: white; }

.cb-table-container { background: var(--bg-card); border: 1px solid var(--border-card); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
.cb-table-container table { width: 100%; border-collapse: collapse; }
.cb-table-container thead th { position: sticky; top: 0; background: #F8FAFC; padding: 12px 16px; font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-secondary); text-align: left; border-bottom: 1px solid var(--border-card); white-space: nowrap; user-select: none; z-index: 1; }
.cb-table-container thead th.cb-sortable { cursor: pointer; }
.cb-table-container thead th.cb-sortable:hover { color: var(--text-primary); }
.cb-table-container thead th .cb-sort-icon { display: inline-block; margin-left: 4px; opacity: 0.3; font-size: 0.7rem; }
.cb-table-container thead th.cb-sorted .cb-sort-icon { opacity: 1; color: var(--brand-primary); }

.cb-table-container tbody tr { border-bottom: 1px solid var(--border-subtle); transition: background 150ms; }
.cb-table-container tbody tr:last-child { border-bottom: none; }
.cb-table-container tbody tr:hover { background: #F8FAFC; }
.cb-table-container tbody tr.cb-selected { background: rgba(21,94,239,0.04); }
.cb-table-container tbody td { padding: 12px 16px; vertical-align: middle; }

.cb-col-cb { width: 40px; text-align: center; }
.cb-col-cb input[type="checkbox"],
.cb-table-container .cb-row-cb { width: 16px; height: 16px; accent-color: var(--brand-primary); cursor: pointer; }

.cb-cell { display: flex; align-items: center; gap: 12px; }
.cb-cell .cb-info .cb-name { font-weight: 600; font-size: 0.92rem; }
.cb-cell .cb-info .cb-url { font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-tertiary); margin-top: 1px; }

.cb-status-select { padding: 5px 28px 5px 10px; border-radius: 999px; font-size: 0.78rem; font-weight: 600; border: none; cursor: pointer; font-family: var(--font-sans); appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 8px center; outline: none; }
.cb-status-select.approved { background-color: var(--color-success-bg); color: var(--color-success); }
.cb-status-select.warning { background-color: var(--color-warning-bg); color: var(--color-warning); }
.cb-status-select.blocked { background-color: var(--color-danger-bg); color: var(--color-danger); }

.cb-users-cell { display: flex; align-items: center; gap: 6px; color: var(--text-secondary); font-size: 0.88rem; }
.cb-users-cell svg { width: 14px; height: 14px; opacity: 0.5; }
.cb-users-cell .cb-count-zero { color: var(--text-tertiary); }

.cb-last-active { font-size: 0.85rem; color: var(--text-secondary); }
.cb-last-active.cb-inactive { color: var(--text-tertiary); }

.cb-recommended-badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font-size: 0.7rem; font-weight: 600; background: #EFF6FF; color: #155EEF; border: 1px solid #BFDBFE; vertical-align: middle; margin-left: 6px; }
.cb-recommended-badge svg { width: 12px; height: 12px; flex-shrink: 0; }
.cb-recommend-btn { color: var(--text-tertiary) !important; }
.cb-recommend-btn:hover { color: #F59E0B !important; border-color: #F59E0B !important; background: rgba(245,158,11,0.05) !important; }
.cb-recommend-btn--active { color: #F59E0B !important; position: relative; }
.cb-recommend-btn--active::after { content: none; }

.cb-action-btn { width: 32px; height: 32px; border: 1px solid var(--border-card); border-radius: var(--radius-md); background: var(--bg-card); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 150ms; color: var(--text-secondary); }
.cb-action-btn:hover { border-color: var(--brand-primary); color: var(--brand-primary); background: rgba(21,94,239,0.05); }
.cb-action-btn svg { width: 14px; height: 14px; }

/* Category filter dropdown */
.cb-category-select { padding: 7px 32px 7px 12px; border: 1px solid var(--border-card); border-radius: var(--radius-md); font-size: 0.85rem; font-family: var(--font-sans); background: var(--bg-card); color: var(--text-primary); cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; outline: none; transition: border-color 150ms; }
.cb-category-select:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px rgba(21,94,239,0.1); }

/* Group header rows */
.cb-group-header td { background: #F8FAFC; padding: 10px 16px !important; border-bottom: 1px solid var(--border-card); border-top: 2px solid var(--border-card); }
.cb-group-header:first-child td { border-top: none; }
.cb-group-header:hover td { background: #F8FAFC !important; }
.cb-group-cb-cell { width: 40px; text-align: center; }
.cb-group-cb-cell input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--brand-primary); cursor: pointer; }
.cb-group-title { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; }
.cb-group-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.cb-group-name { font-weight: 600; color: var(--text-primary); text-transform: uppercase; letter-spacing: 0.04em; }
.cb-group-count { font-weight: 400; color: var(--text-tertiary); font-size: 0.78rem; }
.cb-group-summary { font-weight: 400; color: var(--text-tertiary); font-size: 0.78rem; margin-left: 4px; }
.cb-group-summary::before { content: '\2014'; margin-right: 8px; }
.cb-group-actions { margin-left: auto; display: flex; gap: 6px; }
.cb-group-action { padding: 3px 10px; border-radius: var(--radius-sm); font-size: 0.72rem; font-weight: 500; border: 1px solid var(--border-card); background: var(--bg-card); cursor: pointer; font-family: var(--font-sans); transition: all 150ms; color: var(--text-secondary); }
.cb-group-action:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.cb-group-action-block:hover { border-color: var(--color-danger); color: var(--color-danger); }
.cb-group-action-approve:hover { border-color: var(--color-success); color: var(--color-success); }
