/* ═══════════════════════════════════════════════════════════════
   TASKBOARD — Insurance kanban with drag-drop
   ═══════════════════════════════════════════════════════════════ */

.tb-filter-bar {
  display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-6);
  background: var(--bg-surface); border-bottom: 1px solid var(--border-subtle); flex-wrap: wrap;
}
.tb-search-wrap { position: relative; flex: 1; min-width: 180px; }
.tb-search-wrap::before { content: '🔍'; position: absolute; left: var(--space-3); top: 50%; transform: translateY(-50%); font-size: var(--text-xs); pointer-events: none; }
.tb-search { flex: 1; min-width: 180px; padding: var(--space-2) var(--space-3) var(--space-2) var(--space-8); font-size: var(--text-sm); }
.tb-filter-select { padding: var(--space-2) var(--space-3); font-size: var(--text-sm); cursor: pointer; }
.tb-refresh-btn { padding: var(--space-2) var(--space-4); background: var(--bg-elevated); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); color: var(--text-secondary); font-size: var(--text-sm); cursor: pointer; transition: all var(--duration-fast); }
.tb-refresh-btn:hover { background: var(--bg-hover); color: var(--text-primary); }

.tb-stats-strip { display: flex; gap: var(--space-4); padding: var(--space-3) var(--space-6); background: var(--bg-base);
  border-bottom: 1px solid var(--border-subtle); flex-wrap: wrap; }
.tb-stat { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--text-secondary); }
.tb-stat-val { font-weight: var(--weight-bold); font-size: var(--text-base); }

.tb-board-wrap { padding: var(--space-4) var(--space-6); overflow-x: auto; min-height: calc(100vh - 260px); }
.tb-board { display: flex; gap: var(--space-4); min-width: max-content; align-items: flex-start; }

.tb-column {
  width: 300px; min-width: 280px; max-width: 320px; background: var(--bg-surface);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
  display: flex; flex-direction: column; max-height: calc(100vh - 280px); flex-shrink: 0;
  transition: box-shadow var(--duration-normal), border-color var(--duration-normal);
}
.tb-column.drag-over { border-color: var(--accent); box-shadow: 0 0 16px var(--accent-muted); }

.tb-col-accent { height: 3px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.tb-col-accent-0 { background: var(--info); }     .tb-col-accent-1 { background: var(--warning); }
.tb-col-accent-2 { background: var(--success); }  .tb-col-accent-3 { background: var(--purple); }
.tb-col-accent-4 { background: var(--orange); }   .tb-col-accent-5 { background: var(--error); }
.tb-col-accent-6 { background: var(--info); }      .tb-col-accent-7 { background: var(--purple); }

.tb-col-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4) var(--space-2); }
.tb-col-name { font-size: var(--text-sm); font-weight: var(--weight-semibold); }
.tb-col-count { font-size: var(--text-xs); font-weight: var(--weight-semibold); padding: 2px var(--space-2);
  border-radius: var(--radius-full); background: var(--bg-elevated); color: var(--text-secondary); }

.tb-col-body { flex: 1; overflow-y: auto; padding: var(--space-1) var(--space-3) var(--space-3);
  display: flex; flex-direction: column; gap: var(--space-2); }
.tb-col-body::-webkit-scrollbar { width: 4px; }
.tb-col-body::-webkit-scrollbar-thumb { background: var(--border-default); border-radius: 4px; }

.tb-card {
  background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-md);
  padding: var(--space-3); cursor: grab; transition: transform var(--duration-fast), box-shadow var(--duration-fast), border-color var(--duration-fast);
}
.tb-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--border-default); }
.tb-card:active { cursor: grabbing; }
.tb-card.dragging { opacity: 0.4; transform: scale(0.96); }
.tb-card-name { font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--accent-text); cursor: pointer; margin-bottom: var(--space-1); display: inline-block; }
.tb-card-name:hover { text-decoration: underline; }
.tb-card-desc { font-size: var(--text-xs); color: var(--text-secondary); margin-bottom: var(--space-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 260px; }
.tb-card-tags { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-bottom: var(--space-2); }
.tb-tag { font-size: 0.65rem; font-weight: var(--weight-semibold); padding: 1px 7px; border-radius: var(--radius-full); text-transform: uppercase; letter-spacing: 0.03em; }
.tb-tag-pending { background: var(--warning-muted); color: var(--warning); }
.tb-tag-inprog { background: var(--info-muted); color: var(--info); }
.tb-tag-done { background: var(--success-muted); color: var(--success); }
.tb-tag-blocked { background: var(--error-muted); color: var(--error); }
.tb-tag-cancelled { background: var(--bg-elevated); color: var(--text-tertiary); }
.tb-lob-auto { background: var(--info-muted); color: var(--info); }
.tb-lob-home { background: var(--success-muted); color: var(--success); }
.tb-lob-condo { background: var(--purple-muted); color: var(--purple); }
.tb-lob-renters { background: rgba(39,190,186,0.12); color: #27beba; }
.tb-lob-bop, .tb-lob-commercial { background: var(--orange-muted); color: var(--orange); }
.tb-lob-wc { background: var(--error-muted); color: var(--error); }
.tb-lob-life { background: rgba(220,120,180,0.12); color: #dc78b4; }
.tb-lob-default { background: var(--bg-elevated); color: var(--text-secondary); }
.tb-tag-nb { background: var(--success-muted); color: var(--success); }
.tb-tag-rn { background: var(--info-muted); color: var(--info); }
.tb-tag-rw { background: var(--orange-muted); color: var(--orange); }

.tb-card-meta { display: flex; align-items: center; justify-content: space-between; font-size: var(--text-xs); color: var(--text-muted); margin-top: var(--space-1); }
.tb-card-producer { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-secondary); }
.tb-card-premium { font-weight: var(--weight-semibold); color: var(--success); }
.tb-card-time { color: var(--text-muted); }
.tb-drop-placeholder { border: 2px dashed var(--accent); border-radius: var(--radius-md); min-height: 60px; background: var(--accent-muted); transition: all var(--duration-normal); }
.tb-col-empty { text-align: center; padding: var(--space-5) var(--space-3); color: var(--text-muted); font-size: var(--text-sm); }
.tb-loading { display: flex; flex-direction: column; align-items: center; padding: var(--space-16); color: var(--text-secondary); }
.tb-spinner { width: 32px; height: 32px; border: 3px solid var(--border-default); border-top-color: var(--accent);
  border-radius: 50%; animation: spin 0.8s linear infinite; margin-bottom: var(--space-3); }

/* Detail */
.tb-detail-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 900; opacity: 0; pointer-events: none; transition: opacity var(--duration-normal); }
.tb-detail-overlay.open { opacity: 1; pointer-events: auto; }
.tb-detail-panel { position: fixed; top: 0; right: -480px; width: 460px; max-width: 90vw; height: 100vh;
  background: var(--bg-surface); border-left: 1px solid var(--border-default); z-index: 901;
  display: flex; flex-direction: column; transition: right var(--duration-slow); box-shadow: var(--shadow-xl); }
.tb-detail-panel.open { right: 0; }
.tb-detail-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--border-subtle); }
.tb-detail-header h2 { font-size: var(--text-md); font-weight: var(--weight-semibold); }
.tb-detail-close { background: none; border: none; color: var(--text-tertiary); font-size: 1.5rem; cursor: pointer; padding: var(--space-1); line-height: 1; }
.tb-detail-close:hover { color: var(--text-primary); }
.tb-detail-body { flex: 1; overflow-y: auto; padding: var(--space-5); }
.tb-detail-section { margin-bottom: var(--space-5); }
.tb-detail-section-title { font-size: var(--text-xs); font-weight: var(--weight-semibold); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); margin-bottom: var(--space-2); }
.tb-detail-row { display: flex; justify-content: space-between; align-items: center; padding: var(--space-1) 0; font-size: var(--text-sm); border-bottom: 1px solid var(--border-subtle); }
.tb-detail-row:last-child { border-bottom: none; }
.tb-detail-label { color: var(--text-secondary); }
.tb-detail-val { color: var(--text-primary); font-weight: var(--weight-medium); text-align: right; }
.tb-detail-notes { background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: var(--space-3); font-size: var(--text-sm); color: var(--text-secondary); white-space: pre-wrap; }
.tb-detail-status-select { padding: var(--space-1) var(--space-3); font-size: var(--text-sm); cursor: pointer; }
.tb-detail-customer-link { color: var(--accent-text); cursor: pointer; font-weight: var(--weight-semibold); }
.tb-detail-customer-link:hover { text-decoration: underline; }
.tb-detail-input { padding: var(--space-1) var(--space-3); font-size: var(--text-sm); width: 130px; text-align: right; }
.tb-outcome-select { min-width: 130px; }
.tb-save-outcome-btn { padding: var(--space-2) var(--space-5); background: var(--accent); color: #fff; border: none; border-radius: var(--radius-md);
  font-size: var(--text-sm); font-weight: var(--weight-semibold); cursor: pointer; transition: background var(--duration-fast); }
.tb-save-outcome-btn:hover { background: var(--accent-hover); }
.tb-outcome-badge { font-size: 0.65rem; font-weight: var(--weight-bold); padding: 2px var(--space-2); border-radius: var(--radius-full); text-transform: uppercase; }
.tb-outcome-bound { background: var(--success-muted); color: var(--success); }
.tb-outcome-lost { background: var(--error-muted); color: var(--error); }
.tb-outcome-quoted { background: var(--info-muted); color: var(--info); }
.tb-outcome-cancelled { background: var(--bg-elevated); color: var(--text-secondary); }
.tb-outcome-abandoned { background: var(--bg-elevated); color: var(--text-muted); }

@media (max-width: 768px) { .tb-board-wrap { padding: var(--space-3); } .tb-column { width: 260px; min-width: 240px; }
  .tb-filter-bar { padding: var(--space-3); } .tb-detail-panel { width: 100vw; max-width: 100vw; } }
