*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0c1220;--bg2:#0f1726;--card:#131f30;--card-h:#172438;--card-a:#1a2840;
  --border:#1e2e42;--border-s:#162030;--border-f:#2e5080;
  --text:#e8edf5;--text-d:#7a8fa8;--text-m:#3a4f66;
  --blue:#1e6af0;--blue-d:rgba(30,106,240,.12);
  --gold:#c9a84c;--gold-d:rgba(201,168,76,.12);
  --red:#d94f4f;--red-d:rgba(217,79,79,.10);
  --green:#2e9e6a;--green-d:rgba(46,158,106,.10);
  --yellow:#d4922a;--yellow-d:rgba(212,146,42,.10);
  --purple:#7c5cbf;--purple-d:rgba(124,92,191,.10);
  --sidebar:#08101e;--sw:224px;--th:52px;
  --radius:10px;--radius-s:6px;
}
body{font-family:"Inter",sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}

/* Layout */
#app{display:flex;min-height:100vh}

/* Sidebar */
#sidebar{width:var(--sw);background:var(--sidebar);border-right:1px solid var(--border-s);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .2s ease;overflow:hidden}
#sidebar.collapsed{width:52px}
#sidebar.collapsed .brand-text,#sidebar.collapsed .nav-label,#sidebar.collapsed .user-info{display:none}
#sidebar.collapsed .sidebar-brand{justify-content:center;padding:14px 0}
#sidebar.collapsed .nav-item{justify-content:center;padding:10px 0}
#sidebar.collapsed .user-avatar{margin:0 auto}

.sidebar-brand{display:flex;align-items:center;gap:10px;padding:18px 16px 14px;border-bottom:1px solid var(--border-s)}
.brand-monogram{width:30px;height:30px;background:#0c1a2e;border:1px solid var(--gold);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.05em;flex-shrink:0}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-name{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.01em}
.brand-sub{font-size:10px;font-weight:300;color:var(--text-d);letter-spacing:.08em;text-transform:uppercase}

.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:1px}
.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border-radius:var(--radius-s);border:none;background:none;color:var(--text-d);font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left;position:relative;white-space:nowrap}
.nav-item:hover{background:rgba(255,255,255,.04);color:var(--text)}
.nav-item.active{background:var(--blue-d);color:var(--text)}
.nav-item.active::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:2px;background:var(--gold);border-radius:0 2px 2px 0}
.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0;font-style:normal}

.sidebar-user{padding:12px 10px;border-top:1px solid var(--border-s);display:flex;align-items:center;gap:10px}
.user-avatar{width:28px;height:28px;background:linear-gradient(135deg,#1e3a5f,#0c2040);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--gold);flex-shrink:0}
.user-info{display:flex;flex-direction:column;line-height:1.3;min-width:0}
.user-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--text-d)}

/* Main */
#main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .2s ease}
#sidebar.collapsed~#main{margin-left:52px}

/* Topbar */
#topbar{height:var(--th);background:var(--sidebar);border-bottom:1px solid var(--border-s);display:flex;align-items:center;gap:12px;padding:0 20px;position:sticky;top:0;z-index:50}
#sidebar-toggle{background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-s);display:flex;flex-direction:column;gap:4px;width:28px}
#sidebar-toggle span{display:block;height:1.5px;background:var(--text-d);border-radius:1px;transition:all .15s}
#sidebar-toggle:hover span{background:var(--text)}

.topbar-search{flex:1;max-width:400px;margin:0 auto;position:relative}
.topbar-search input{width:100%;padding:7px 14px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:20px;color:var(--text);font:inherit;font-size:13px;outline:none;transition:all .15s}
.topbar-search input:focus{border-color:var(--border-f);background:rgba(255,255,255,.06)}
.topbar-search input::placeholder{color:var(--text-m)}

.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--card-a);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:200;max-height:300px;overflow-y:auto}
.search-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border-s);font-size:13px}
.search-item:hover{background:var(--card-h)}
.search-item:last-child{border-bottom:none}
.search-item .si-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);margin-bottom:2px}

.topbar-actions{margin-left:auto}
.btn-new{background:var(--gold);color:#0c1220;border:none;padding:7px 16px;border-radius:var(--radius-s);font:inherit;font-size:12px;font-weight:600;cursor:pointer;letter-spacing:.02em;transition:all .15s}
.btn-new:hover{background:#d4b060;transform:translateY(-1px)}

/* Content */
#content{padding:28px;flex:1}
.page-header{margin-bottom:24px}
.page-title{font-size:20px;font-weight:600;color:var(--text);letter-spacing:-.01em}
.page-sub{font-size:13px;color:var(--text-d);margin-top:4px}

/* Cards */
.card{background:linear-gradient(145deg,var(--card),#111a29);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .15s;cursor:default}
.card:hover{background:linear-gradient(145deg,var(--card-h),#141f30);border-color:rgba(255,255,255,.08);box-shadow:0 4px 16px rgba(0,0,0,.3);transform:translateY(-1px)}
.card-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:4px}
.card-meta{font-size:11px;color:var(--text-d);line-height:1.5}

/* Priority borders */
.pri-high{border-left:3px solid var(--red)}
.pri-medium{border-left:3px solid var(--gold)}
.pri-low{border-left:3px solid transparent}

/* Badges / Pills */
.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:10.5px;font-weight:500;letter-spacing:.02em}
.badge-blue{background:var(--blue-d);color:#6ea3ff}
.badge-gold{background:var(--gold-d);color:var(--gold)}
.badge-green{background:var(--green-d);color:#4cc990}
.badge-red{background:var(--red-d);color:#e87878}
.badge-purple{background:var(--purple-d);color:#a882e8}
.badge-gray{background:rgba(255,255,255,.06);color:var(--text-d)}

.days-pill{display:inline-flex;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:500}
.days-fresh{background:var(--green-d);color:#4cc990}
.days-warm{background:var(--yellow-d);color:#e8a855}
.days-cold{background:var(--red-d);color:#e87878}

/* Stats bar */
.stats-row{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.stat-card{background:linear-gradient(145deg,var(--card),#111a29);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;flex:1;min-width:120px}
.stat-card.accent-blue{border-top:2px solid var(--blue)}
.stat-card.accent-gold{border-top:2px solid var(--gold)}
.stat-card.accent-red{border-top:2px solid var(--red)}
.stat-card.accent-green{border-top:2px solid var(--green)}
.stat-val{font-size:32px;font-weight:700;color:var(--text);line-height:1;margin-bottom:6px}
.stat-lbl{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);font-weight:500}

/* Section headers */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;margin-top:28px}
.section-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);font-weight:600}
.section-action{font-size:12px;color:var(--blue);cursor:pointer;border:none;background:none;font:inherit}
.section-action:hover{color:#5090ff}

/* Board (Pipeline) */
.board{display:flex;gap:14px;overflow-x:auto;padding-bottom:16px;margin:0 -4px;padding:0 4px 16px}
.board-col{min-width:260px;flex:1}
.board-col-hdr{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);padding:8px 4px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.col-count{background:var(--border);color:var(--text-d);padding:2px 7px;border-radius:10px;font-size:10px;font-weight:500}
.board-col .cards{display:flex;flex-direction:column;gap:7px;min-height:100px}
.board-col.drop-target>.cards{border:2px dashed var(--blue);border-radius:var(--radius);background:var(--blue-d);padding:4px}
.firm-card{cursor:pointer;position:relative}
.firm-card.dragging{opacity:.4}
.firm-card .fc-name{font-size:13px;font-weight:500;margin-bottom:6px}
.firm-card .fc-notes{font-size:11px;color:var(--text-d);margin-bottom:8px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.firm-card .fc-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tasks-badge{background:var(--red-d);color:#e87878;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600}

/* Table */
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 14px;font-size:10.5px;font-weight:600;color:var(--text-d);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border)}
td{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--border-s);vertical-align:middle}
tr:hover td{background:rgba(255,255,255,.02)}
.avatar{width:28px;height:28px;background:linear-gradient(135deg,#1e3a5f,#0c2040);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--gold);flex-shrink:0}

/* Activity */
.activity-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-s)}
.act-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.act-icon.email{background:var(--blue-d)}
.act-icon.meeting{background:var(--green-d)}
.act-icon.call{background:var(--purple-d)}
.act-body{flex:1}
.act-title{font-size:13px;font-weight:500;margin-bottom:3px}
.act-meta{font-size:11px;color:var(--text-d);margin-bottom:5px}
.act-summary{font-size:12px;color:var(--text-d);line-height:1.5}
.act-takeaway{font-size:12px;color:var(--gold);margin-top:4px}
a.email-link{color:var(--blue);font-size:11px;text-decoration:none;margin-left:6px}
a.email-link:hover{text-decoration:underline}

/* Owed */
.owed-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.owed-col-hdr{font-size:15px;font-weight:600;padding:12px 0;border-bottom:2px solid;margin-bottom:14px}
.we-owe .owed-col-hdr{color:var(--red);border-color:var(--red)}
.they-owe .owed-col-hdr{color:var(--blue);border-color:var(--blue)}
.followup-card{cursor:pointer}
.followup-card.overdue{border-left:3px solid var(--red)}
.fu-task{font-size:13px;font-weight:500;margin-bottom:5px}
.fu-firm{font-size:11px;color:var(--gold);margin-bottom:4px}
.fu-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--text-d)}
.overdue-label{color:var(--red);font-weight:600}

/* Side panel */
#panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:290}
.side-panel{position:fixed;top:0;right:0;width:480px;height:100vh;background:#0e1828;border-left:1px solid var(--border);z-index:300;overflow-y:auto;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.side-panel.open{transform:translateX(0)}
.sp-header{padding:20px 20px 16px;border-bottom:1px solid var(--border-s);display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:#0e1828;z-index:10}
.sp-title{font-size:17px;font-weight:600;color:var(--text)}
.sp-close{background:none;border:none;color:var(--text-d);font-size:20px;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}
.sp-close:hover{color:var(--text);background:var(--border)}
.sp-tabs{display:flex;gap:0;padding:0 20px;border-bottom:1px solid var(--border-s);position:sticky;top:65px;background:#0e1828;z-index:9}
.sp-tab{padding:10px 14px;font-size:12px;font-weight:500;color:var(--text-d);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;font:inherit;transition:all .15s}
.sp-tab:hover{color:var(--text)}
.sp-tab.active{color:var(--text);border-bottom-color:var(--gold)}
.sp-body{padding:20px}
.sp-field{margin-bottom:14px}
.sp-field label{display:block;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);margin-bottom:5px}
.sp-field .val{font-size:13px;line-height:1.6;white-space:pre-wrap}
.sp-selectors{display:flex;gap:8px;padding:12px 20px;flex-wrap:wrap;border-bottom:1px solid var(--border-s)}
.sp-selectors select{padding:5px 10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-s);color:var(--text);font:inherit;font-size:12px;outline:none}

/* Task editor */
.task-editor{position:fixed;top:0;right:0;width:560px;height:100vh;background:#0e1828;border-left:1px solid var(--border);z-index:310;overflow-y:auto;transform:translateX(100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.task-editor.open{transform:translateX(0)}
.te-header{padding:20px;border-bottom:1px solid var(--border-s);display:flex;justify-content:space-between;align-items:center}
.te-close{background:none;border:none;color:var(--text-d);font-size:20px;cursor:pointer;border-radius:4px;padding:2px 6px}
.te-close:hover{color:var(--text);background:var(--border)}
.te-body{padding:24px}
.te-title-input{width:100%;background:none;border:none;font:inherit;font-size:20px;font-weight:600;color:var(--text);outline:none;margin-bottom:20px;padding:0}
.te-title-input::placeholder{color:var(--text-m)}
.te-field{margin-bottom:18px}
.te-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-d);margin-bottom:8px;display:block}
.pill-row{display:flex;gap:6px;flex-wrap:wrap}
.pill{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-d);font:inherit;font-size:12px;cursor:pointer;transition:all .15s}
.pill:hover{border-color:var(--blue);color:var(--text)}
.pill.active{background:var(--blue-d);border-color:var(--blue);color:var(--text)}
.pill.active-gold{background:var(--gold-d);border-color:var(--gold);color:var(--gold)}
.pill.active-red{background:var(--red-d);border-color:var(--red);color:#e87878}
.pill.active-green{background:var(--green-d);border-color:var(--green);color:#4cc990}
.te-input{width:100%;padding:8px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-s);color:var(--text);font:inherit;font-size:13px;outline:none}
.te-input:focus{border-color:var(--border-f)}
.te-textarea{width:100%;padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-s);color:var(--text);font:inherit;font-size:13px;resize:vertical;min-height:120px;outline:none;line-height:1.6}
.te-textarea:focus{border-color:var(--border-f)}
.te-actions{display:flex;gap:10px;padding:20px 24px;border-top:1px solid var(--border-s);position:sticky;bottom:0;background:#0e1828}

/* Buttons */
.btn{padding:8px 16px;border-radius:var(--radius-s);border:none;font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn-primary{background:var(--blue);color:#fff}
.btn-gold{background:var(--gold);color:#0c1220}
.btn-danger{background:none;border:1px solid var(--red);color:var(--red)}
.btn-danger:hover{background:var(--red-d)}
.btn-ghost{background:none;border:1px solid var(--border);color:var(--text-d)}
.btn-ghost:hover{border-color:var(--border-f);color:var(--text)}
.btn-success{background:var(--green);color:#fff}

/* Modal */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400}
#modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#0e1828;border:1px solid var(--border);border-radius:12px;padding:24px;z-index:401;width:90%;max-width:560px;max-height:80vh;overflow-y:auto}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-hdr h2{font-size:17px;font-weight:600}
.modal-close{background:none;border:none;color:var(--text-d);font-size:22px;cursor:pointer}

/* Insights */
.insight-section{margin-bottom:32px}
.insight-section-title{font-size:15px;font-weight:600;margin-bottom:14px;color:var(--text)}
.insight-card{padding:14px 16px;margin-bottom:8px}
.insight-pair{display:flex;align-items:center;gap:10px;font-size:13px;margin-bottom:6px;font-weight:500}
.insight-why{font-size:12px;color:var(--text-d);margin-bottom:8px;line-height:1.5}
.ai-loading{display:flex;align-items:center;gap:10px;padding:20px;color:var(--text-d);font-size:13px}
.ai-loading::before{content:"";width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* Data Sync */
.sync-section{margin-bottom:28px;padding:20px;background:linear-gradient(145deg,var(--card),#111a29);border:1px solid var(--border);border-radius:var(--radius)}
.sync-section-title{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--text)}
.sync-section-desc{font-size:12px;color:var(--text-d);margin-bottom:14px}
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;transition:all .2s}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--blue);background:var(--blue-d)}
.drop-zone-icon{font-size:28px;margin-bottom:8px;color:var(--text-d)}
.drop-zone-text{font-size:13px;color:var(--text-d)}
.db-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.db-card{padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.db-info .db-name{font-size:13px;font-weight:500}
.db-info .db-count{font-size:22px;font-weight:700;color:var(--text);margin-top:4px}
.db-link{font-size:11px;color:var(--blue);text-decoration:none}
.db-link:hover{text-decoration:underline}

/* Attention list */
.attention-item{padding:12px 14px;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.att-name{font-size:13px;font-weight:500}
.att-meta{font-size:11px;color:var(--text-d);margin-top:3px}
.att-btn{background:none;border:1px solid var(--border);color:var(--text-d);padding:4px 10px;border-radius:var(--radius-s);font:inherit;font-size:11px;cursor:pointer;white-space:nowrap}
.att-btn:hover{border-color:var(--blue);color:var(--blue)}

/* Inline form */
.inline-form{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-top:10px}
.inline-form input,.inline-form select,.inline-form textarea{width:100%;padding:7px 10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-s);color:var(--text);font:inherit;font-size:12px;outline:none;margin-bottom:8px}
.inline-form textarea{min-height:60px;resize:vertical}
.inline-form-actions{display:flex;gap:8px;margin-top:4px}

/* Filter bar */
.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.filter-bar input,.filter-bar select{padding:6px 12px;background:var(--card);border:1px solid var(--border);border-radius:20px;color:var(--text);font:inherit;font-size:12px;outline:none}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--border-f)}

/* Responsive */
@media(max-width:900px){
  #sidebar{width:52px}
  #sidebar .brand-text,#sidebar .nav-label,#sidebar .user-info{display:none}
  #sidebar .nav-item{justify-content:center}
  #sidebar .sidebar-brand{justify-content:center;padding:14px 0}
  #main{margin-left:52px}
  .side-panel,.task-editor{width:100%}
  .owed-grid{grid-template-columns:1fr}
  .board{flex-direction:column}
  .board-col{min-width:100%}
  .db-grid{grid-template-columns:1fr}
}

/* Global Follow-up Tray */
#fu-tray-btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 250;
  background: var(--gold);
  color: #0c1220;
  border: none;
  border-radius: 50%;
  width: 48px;
  height: 48px;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
  transition: all .2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
#fu-tray-btn:hover { transform: scale(1.08); background: #d4b060; }
#fu-tray-btn.drop-ready { background: var(--blue); transform: scale(1.15); box-shadow: 0 0 0 4px var(--blue-d); }

#fu-quick-tray {
  position: fixed;
  bottom: 84px;
  right: 20px;
  z-index: 250;
  width: 320px;
  background: #0e1828;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
  transform: translateY(20px) scale(.97);
  opacity: 0;
  pointer-events: none;
  transition: all .2s cubic-bezier(.4,0,.2,1);
}
#fu-quick-tray.open {
  transform: translateY(0) scale(1);
  opacity: 1;
  pointer-events: all;
}
.fu-tray-header {
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border-s);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.fu-tray-header span { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--text-d); }
.fu-tray-body { padding: 14px 16px; }
.fu-drop-zone {
  border: 2px dashed var(--border);
  border-radius: var(--radius-s);
  padding: 12px;
  text-align: center;
  font-size: 11px;
  color: var(--text-m);
  margin-bottom: 12px;
  transition: all .15s;
}
.fu-drop-zone.drag-over { border-color: var(--blue); background: var(--blue-d); color: var(--blue); }

/* Make all clickable cards obvious */
.card[onclick], .firm-card, .followup-card, .attention-item, .ws-contact, .ws-db-row td strong, .activity-item[onclick] {
  cursor: pointer;
}
.card[onclick]:hover, .firm-card:hover, .followup-card:hover, .attention-item:hover {
  background: linear-gradient(145deg, var(--card-h), #141f30);
  border-color: rgba(255,255,255,.1);
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
  transform: translateY(-1px);
}
.ws-db-row { cursor: pointer; }
.ws-db-row:hover td { background: rgba(255,255,255,.03); }
tr.ws-db-row:hover td { background: rgba(255,255,255,.03); cursor: pointer; }

/* Popup Card */
#popup-card {
  position: absolute;
  z-index: 500;
  width: 360px;
  background: #0e1828;
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,.6);
  opacity: 0;
  transform: translateY(6px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
  pointer-events: none;
}
#popup-card.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: all; }
.pc-header { padding: 16px 16px 12px; border-bottom: 1px solid var(--border-s); display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.pc-title { font-size: 15px; font-weight: 600; color: var(--text); line-height:1.3; }
.pc-close { background:none; border:none; color:var(--text-d); font-size:20px; cursor:pointer; padding:0 2px; line-height:1; flex-shrink:0; }
.pc-close:hover { color:var(--text); }
.pc-body { padding: 12px 16px; max-height: 320px; overflow-y: auto; }
.pc-footer { padding: 10px 16px 14px; border-top: 1px solid var(--border-s); display:flex; gap:8px; flex-wrap:wrap; }
.pc-row { display:flex; gap:8px; margin-bottom:10px; flex-wrap:wrap; }
.pc-select { padding:4px 8px; background:var(--card); border:1px solid var(--border); border-radius:5px; color:var(--text); font:inherit; font-size:11px; outline:none; }
.pc-notes { font-size:12px; color:var(--text-d); line-height:1.6; white-space:pre-wrap; margin-bottom:8px; }
.pc-section-label { font-size:10px; text-transform:uppercase; letter-spacing:.08em; color:var(--text-m); font-weight:600; margin:10px 0 5px; }
.pc-contact { display:flex; align-items:center; gap:8px; padding:5px 0; border-bottom:1px solid var(--border-s); }
.pc-tag { display:inline-flex; padding:3px 8px; border-radius:4px; font-size:11px; background:rgba(255,255,255,.05); color:var(--text-d); }
.pc-tag-red { background:var(--red-d); color:#e87878; }

/* ── Tile / Card refresh ── */
.card, .firm-card, .followup-card, .attention-item {
  background: #1b2535 !important;
  border-color: #223045 !important;
}
.card:hover, .firm-card:hover, .followup-card:hover, .attention-item:hover {
  background: #1f2c3d !important;
  border-color: #2e4060 !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.25) !important;
}
/* Lighter body background */
#content {
  background: #0e1825;
}
#main {
  background: #0e1825;
}
/* Dark topbar */
#topbar {
  background: #06101c !important;
  border-bottom-color: #131f30 !important;
}
/* Pipeline column headers — dark band */
.board-col-hdr {
  background: #06101c;
  padding: 8px 10px !important;
  border-radius: 6px;
  margin-bottom: 12px !important;
  font-size: 10px !important;
  letter-spacing: .1em !important;
  color: #5a7090 !important;
}
/* Cleaner card titles */
.firm-card .fc-name, .card-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: -.01em;
}
.firm-card .fc-notes {
  font-size: 11px !important;
  color: #5a7090 !important;
}
/* Popup card lighter */
#popup-card {
  background: #1b2535 !important;
  border-color: #223045 !important;
}

/* Channel taxonomy bar */
#channel-bar {
  display: flex;
  gap: 4px;
  align-items: center;
  margin-left: 12px;
}
.channel-btn {
  padding: 4px 10px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: none;
  color: var(--text-d);
  font: inherit;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.channel-btn:hover { border-color: var(--border-f); color: var(--text); }
.channel-btn.active { background: var(--blue-d); border-color: var(--blue); color: var(--text); }
.channel-btn[data-channel=clients].active { background: var(--green-d); border-color: var(--green); }
.channel-btn[data-channel=sourcing].active { background: var(--purple-d); border-color: var(--purple); }
.channel-btn[data-channel=vendor].active { background: var(--gold-d); border-color: var(--gold); }
.ch-badge {
  background: var(--red);
  color: white;
  border-radius: 8px;
  padding: 0 5px;
  font-size: 9px;
  font-weight: 700;
  margin-left: 4px;
  min-width: 14px;
  height: 14px;
  align-items: center;
  justify-content: center;
  line-height: 14px;
}

/* ── Light Mode ── */
body.light-mode {
  --bg: #f4f6f9;
  --bg2: #eef1f5;
  --card: #ffffff;
  --card-h: #f7f9fc;
  --card-a: #f0f3f8;
  --border: #dde3ed;
  --border-s: #e8ecf4;
  --border-f: #93a8c8;
  --text: #1a2438;
  --text-d: #5a6e8a;
  --text-m: #9aaec4;
  --sidebar: #1a2438;
  --sidebar-bg: #1a2438;
  --blue: #1a56d4;
  --blue-d: rgba(26,86,212,.10);
  --gold: #b08922;
  --gold-d: rgba(176,137,34,.10);
  --red: #c0392b;
  --red-d: rgba(192,57,43,.08);
  --green: #1a7a52;
  --green-d: rgba(26,122,82,.08);
  --yellow: #b07a10;
  --yellow-d: rgba(176,122,16,.08);
  --purple: #6040a8;
  --purple-d: rgba(96,64,168,.08);
}
body.light-mode #main, body.light-mode #content { background: var(--bg); }
body.light-mode #topbar { background: #ffffff; border-bottom-color: var(--border); }
body.light-mode .card, body.light-mode .firm-card { background: #ffffff !important; border-color: var(--border) !important; box-shadow: 0 1px 4px rgba(0,0,0,.06); }
body.light-mode .card:hover, body.light-mode .firm-card:hover { background: var(--card-h) !important; box-shadow: 0 4px 14px rgba(0,0,0,.10) !important; }
body.light-mode #topbar input { background: var(--bg2); border-color: var(--border); color: var(--text); }
body.light-mode select, body.light-mode input, body.light-mode textarea { background: var(--bg2) !important; border-color: var(--border) !important; color: var(--text) !important; }
body.light-mode .board-col-hdr { background: var(--bg2); color: var(--text-d); }
body.light-mode .stat-card { background: #ffffff !important; }
body.light-mode #firm-panel, body.light-mode .task-editor, body.light-mode #modal, body.light-mode #popup-card { background: #ffffff !important; border-color: var(--border) !important; }
body.light-mode .sp-tabs, body.light-mode .sp-header { background: #ffffff; }
body.light-mode .te-actions { background: #ffffff; }
body.light-mode .sync-section { background: #ffffff !important; }
body.light-mode .nav-item { color: rgba(255,255,255,.6); }
body.light-mode .nav-item:hover { background: rgba(255,255,255,.08); color: #fff; }
body.light-mode .nav-item.active { background: rgba(201,168,76,.15); color: #c9a84c; }
body.light-mode .sidebar-user .user-name { color: rgba(255,255,255,.9); }
body.light-mode .sidebar-user .user-role { color: rgba(255,255,255,.5); }
body.light-mode #channel-bar .channel-btn { background: var(--bg2); border-color: var(--border); color: var(--text-d); }
body.light-mode #channel-bar .channel-btn:hover { background: var(--card-h); color: var(--text); }
body.light-mode #fu-tray-body, body.light-mode #fu-quick-tray { background: #ffffff; border-color: var(--border); }

/* Theme toggle button */
#theme-toggle {
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-d);
  padding: 5px 8px;
  font-size: 13px;
  cursor: pointer;
  transition: all .15s;
  margin-right: 4px;
}
#theme-toggle:hover { border-color: var(--border-f); color: var(--text); }

/* Pipeline board refinement */
.board { background: #0b1520; border-radius: 10px; padding: 16px; }

/* Darker column headers */
.board-col-hdr {
  background: #060e18 !important;
  color: #4a6a8a !important;
  border: 1px solid #0d1a28 !important;
  padding: 7px 12px !important;
  border-radius: 6px !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
}

/* Lighter cards */
.firm-card {
  background: #1e2d40 !important;
  border-color: #263d54 !important;
}
.firm-card:hover {
  background: #243447 !important;
  border-color: #3a5470 !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.3) !important;
}
.firm-card .fc-name { color: #d8e4f0 !important; font-size: 13px !important; font-weight: 600 !important; }
.firm-card .fc-notes { color: #5a7a96 !important; }

/* Cards area subtle bg */
.board-col .cards {
  background: rgba(255,255,255,.015);
  border-radius: 6px;
  padding: 6px;
  min-height: 80px;
}

/* Light mode board */
body.light-mode .board { background: #eef2f7; }
body.light-mode .board-col-hdr { background: #1a2438 !important; color: #8aaac8 !important; border-color: #111d2e !important; }
body.light-mode .firm-card { background: #ffffff !important; border-color: #d8e4f0 !important; box-shadow: 0 1px 6px rgba(0,0,0,.07) !important; }
body.light-mode .firm-card:hover { background: #f5f8fc !important; box-shadow: 0 4px 14px rgba(0,0,0,.10) !important; }
body.light-mode .firm-card .fc-name { color: #1a2438 !important; }
body.light-mode .firm-card .fc-notes { color: #6a849a !important; }
body.light-mode .board-col .cards { background: rgba(0,0,0,.02); }
