/* ===== RESET & BASE ===== */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',sans-serif;background:#e8f4fd;color:#1a2332;min-height:100vh}
input,textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text}

/* ===== LOGIN SCREEN ===== */
.login-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a1628 0%,#1a3a5c 50%,#0d2847 100%);display:flex;align-items:center;justify-content:center;z-index:9999}
.login-overlay.hidden{display:none}
.login-card{background:#fff;border-radius:20px;padding:48px 40px;width:420px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,0.3);text-align:center}
.login-logo{width:80px;height:80px;margin:0 auto 20px;background:#f0f7fd;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(59,158,255,0.2)}
.login-logo svg{width:50px;height:50px}
.login-card h2{font-size:24px;font-weight:700;color:#1a2332;margin-bottom:4px}
.login-card h2 span{color:#3b9eff;font-weight:300}
.login-card .login-sub{font-size:13px;color:#7a9ab8;margin-bottom:28px}
.login-card form{display:flex;flex-direction:column;gap:12px}
.login-card input[type="email"],
.login-card input[type="password"]{width:100%;padding:14px 18px;border:2px solid #d0e3f2;border-radius:12px;font-size:15px;outline:none;transition:border-color 0.2s;font-family:'Inter',sans-serif}
.login-card input:focus{border-color:#3b9eff}
.login-card input.error{border-color:#e74c3c;animation:shake 0.4s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-8px)}50%{transform:translateX(8px)}75%{transform:translateX(-4px)}}
.login-btn{width:100%;padding:14px;border:none;background:linear-gradient(135deg,#3b9eff,#1a6dd4);color:#fff;font-size:15px;font-weight:600;border-radius:12px;cursor:pointer;margin-top:4px;transition:transform 0.1s,box-shadow 0.2s;box-shadow:0 4px 16px rgba(59,158,255,0.3)}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,158,255,0.4)}
.login-btn:active{transform:translateY(0)}
.login-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
.login-error{color:#e74c3c;font-size:12px;margin-top:12px;min-height:18px;font-weight:500}
.login-footer{font-size:11px;color:#b0c4d8;margin-top:24px}

/* ===== MAIN APP ===== */
.app-wrapper{display:none}
.app-wrapper.visible{display:block}

/* ===== HEADER ===== */
.header{background:linear-gradient(135deg,#0a1628 0%,#1a2d4a 100%);padding:14px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 12px rgba(0,0,0,0.15)}
.header-left{display:flex;align-items:center;gap:14px}
.logo-icon{width:40px;height:40px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.logo-icon svg{width:26px;height:26px}
.header-brand{font-size:20px;font-weight:700;color:#fff;letter-spacing:-0.5px}
.header-right{display:flex;align-items:center;gap:14px}
.user-email{color:#7eb8e8;font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logout-btn{padding:7px 18px;border:1.5px solid rgba(255,255,255,0.2);border-radius:8px;background:transparent;color:#e0effa;font-size:12px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
.logout-btn:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.4)}
.import-btn{padding:7px 14px;border:1.5px solid rgba(16,185,129,0.4);border-radius:8px;background:rgba(16,185,129,0.15);color:#6ee7b7;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
.import-btn:hover{background:rgba(16,185,129,0.3);border-color:rgba(16,185,129,0.6)}
.import-mode-tab{flex:1;padding:10px 16px;border:none;background:#f8fafc;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif}
.import-mode-tab:hover{background:#e2e8f0}
.import-mode-tab.active{background:#1a3a5c;color:#fff}
.email-parse-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px;position:relative}
.email-parse-card .epc-name{font-weight:700;font-size:14px;color:#1a2332}
.email-parse-card .epc-row{display:flex;gap:6px;align-items:center;margin-top:4px;font-size:12px;color:#475569}
.email-parse-card .epc-label{font-weight:600;color:#64748b;min-width:65px}
.email-parse-card .epc-val{color:#1a2332}
.email-parse-card .epc-notes{margin-top:8px;font-size:11px;color:#64748b;line-height:1.5;max-height:80px;overflow-y:auto;background:#fff;padding:8px;border-radius:6px;border:1px solid #e2e8f0}
.email-parse-card .epc-edit-btn{position:absolute;top:10px;right:10px;background:#f0f7fd;border:1px solid #bfdbfe;color:#3b82f6;font-size:11px;padding:4px 10px;border-radius:6px;cursor:pointer;font-weight:600}
.email-parse-card .epc-edit-btn:hover{background:#dbeafe}
.email-parse-card .epc-remove-btn{position:absolute;top:10px;right:70px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:11px;padding:4px 10px;border-radius:6px;cursor:pointer;font-weight:600}
.email-parse-card .epc-remove-btn:hover{background:#fee2e2}

/* ===== TABS ===== */
.tab-bar{display:flex;gap:0;background:#fff;border-bottom:2px solid #e0effa;padding:0 32px}
.tab{padding:14px 24px;border:none;background:none;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:#7a9ab8;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all 0.2s;display:flex;align-items:center;gap:8px}
.tab:hover{color:#1a2332}
.tab.active{color:#1a6dd4;border-bottom-color:#3b9eff;font-weight:600}
.tab-count{background:#e0effa;color:#3a6a94;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px}
.tab.active .tab-count{background:#3b9eff;color:#fff}

/* ===== SOURCE TAB PILLS ===== */
.source-pills{display:flex;flex-wrap:wrap;gap:8px;padding:12px 32px;background:#f5faff;border-bottom:1px solid #e0effa;min-height:20px}
.source-pills:empty{display:none}
.pill{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;border:1.5px solid #d0e3f2;background:#fff;color:#3a6a94;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:6px;font-family:'Inter',sans-serif}
.pill:hover{border-color:#3b9eff;background:#f0f7fd}
.pill.active{background:#3b9eff;color:#fff;border-color:#3b9eff}
.pill .pill-count{font-size:10px;font-weight:700;background:rgba(0,0,0,0.08);padding:1px 6px;border-radius:8px}
.pill.active .pill-count{background:rgba(255,255,255,0.3)}

/* ===== TOOLBAR ===== */
.toolbar{padding:12px 32px;display:flex;align-items:center;gap:16px;background:#f5faff;border-bottom:1px solid #e0effa}
.search-box{flex:1;max-width:500px;position:relative}
.search-box input{width:100%;padding:10px 16px 10px 40px;border:2px solid #d0e3f2;border-radius:10px;font-size:13px;background:#fff;outline:none;transition:border-color 0.2s;font-family:'Inter',sans-serif}
.search-box input:focus{border-color:#3b9eff}
.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#7a9ab8}
.result-count{margin-left:auto;font-size:13px;color:#7a9ab8;font-weight:500}

/* ===== LOADING ===== */
.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#7a9ab8}
.loading-state.hidden{display:none}
.spinner{width:40px;height:40px;border:4px solid #d0e3f2;border-top:4px solid #3b9eff;border-radius:50%;animation:spin 0.8s linear infinite;margin-bottom:16px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== TABLE ===== */
.table-container{padding:0 32px 20px;overflow-x:auto}
table{width:100%;border-collapse:separate;border-spacing:0;margin-top:12px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,60,120,0.06)}
thead th{background:linear-gradient(135deg,#1a2d4a,#2a4060);color:#fff;padding:11px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;position:sticky;top:0;z-index:10;text-align:left;white-space:nowrap}
tbody tr{transition:background 0.15s;cursor:pointer}
tbody tr:hover{background:#f0f7fd !important}
tbody td{padding:9px 14px;font-size:12px;border-bottom:1px solid #eef4fa;vertical-align:middle}
.even-row{background:#fafcff}
.odd-row{background:#fff}
a.linkedin-link{display:inline-flex;align-items:center;gap:4px;color:#0077b5;text-decoration:none;font-weight:500;font-size:12px}
a.linkedin-link:hover{text-decoration:underline}
a.linkedin-link svg{width:14px;height:14px;flex-shrink:0}
a.web-link{color:#3b9eff;text-decoration:none;font-size:12px}
a.web-link:hover{text-decoration:underline}
.notes-cell{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#7a9ab8;font-size:11px}

/* ===== PAGINATION ===== */
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:16px;flex-wrap:wrap}
.pagination button{padding:7px 12px;border:1.5px solid #d0e3f2;background:#fff;border-radius:8px;cursor:pointer;font-size:12px;color:#3a6a94;font-weight:500;transition:all 0.2s;font-family:'Inter',sans-serif}
.pagination button:hover{background:#e0effa;border-color:#3b9eff}
.pagination button.active{background:#3b9eff;color:#fff;border-color:#3b9eff}
.pagination button:disabled{opacity:0.4;cursor:default}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,22,40,0.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:9000}
.modal-overlay.open{display:flex}
.modal-card{background:#fff;border-radius:20px;padding:36px;width:560px;max-width:92vw;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.25);position:relative;animation:modalIn 0.25s ease-out}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:14px;right:18px;background:none;border:none;font-size:28px;color:#7a9ab8;cursor:pointer;line-height:1}
.modal-close:hover{color:#1a2332}
.modal-header{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid #e0effa}
.modal-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#3b9eff,#1a6dd4);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:700;flex-shrink:0}
.modal-header h3{font-size:18px;font-weight:700;color:#1a2332}
.modal-title{font-size:13px;color:#5a7a94;margin-top:2px}
.modal-body{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-field{display:flex;flex-direction:column;gap:3px}
.modal-field label{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;color:#7a9ab8;font-weight:600}
.modal-field span,.modal-field p{font-size:13px;color:#1a2332;word-break:break-word}
.modal-field a{color:#1a6dd4;text-decoration:none}
.modal-field a:hover{text-decoration:underline}
.modal-field-full{grid-column:1 / -1}
.modal-field-full p{background:#f5faff;padding:10px 14px;border-radius:10px;font-size:12px;line-height:1.6;color:#3a5a74;min-height:36px}

/* ===== PIPELINE TRACKER ===== */
.pipeline-section{display:none;background:#f0f5ff;min-height:60vh}
.pipeline-section.visible{display:block}
.pt-toolbar{background:#fff;border-bottom:1px solid #d1dcf5;padding:12px 24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.pt-select{padding:8px 12px;border:1.5px solid #d0e3f2;border-radius:8px;font-family:'Inter',sans-serif;font-size:12px;color:#1a2332;background:#f0f5ff;outline:none;cursor:pointer}
.pt-stats{margin-left:auto;display:flex;gap:18px}
.pt-stat{text-align:center}
.pt-stat span{display:block;font-size:18px;font-weight:600;color:#3b9eff;line-height:1}
.pt-stat small{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}
.pt-add-btn{padding:8px 16px;border-radius:8px;font-family:'Inter',sans-serif;font-size:12px;font-weight:500;cursor:pointer;border:none;background:linear-gradient(135deg,#2e63f0,#1b4fd8);color:#fff;box-shadow:0 2px 8px rgba(27,79,216,.35);transition:transform 0.1s}
.pt-add-btn:hover{transform:translateY(-1px)}
.pt-board-wrapper{overflow-x:auto;padding:20px 24px 32px}
.pt-board{display:flex;gap:14px;align-items:flex-start;min-width:max-content}
.pt-column{width:220px;background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,40,80,0.06);overflow:hidden;flex-shrink:0}
.pt-col-header{padding:12px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #e2e8f0}
.pt-col-header .pt-col-count{font-size:11px;font-weight:700;background:rgba(0,0,0,0.06);padding:2px 8px;border-radius:10px}
.pt-col-body{padding:8px;min-height:60px;display:flex;flex-direction:column;gap:8px}
.pt-card{background:#f8faff;border:1px solid #e2e8f0;border-radius:10px;padding:12px;cursor:pointer;transition:box-shadow 0.15s,transform 0.15s;position:relative}
.pt-card:hover{box-shadow:0 4px 12px rgba(0,40,80,0.1);transform:translateY(-1px)}
.pt-card-name{font-size:13px;font-weight:600;color:#1a2332;margin-bottom:4px}
.pt-card-title{font-size:11px;color:#64748b;margin-bottom:8px;line-height:1.3}
.pt-card-meta{display:flex;align-items:center;justify-content:space-between}
.pt-priority{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}
.pt-priority-high{background:#fee2e2;color:#dc2626}
.pt-priority-medium{background:#fef3c7;color:#d97706}
.pt-priority-low{background:#dcfce7;color:#16a34a}
.pt-card-date{font-size:10px;color:#94a3b8}
.pt-card-actions{position:absolute;top:8px;right:8px;display:none;gap:4px}
.pt-card:hover .pt-card-actions{display:flex}
.pt-card-action{width:24px;height:24px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:#64748b;transition:background 0.15s}
.pt-card-action:hover{background:#f0f5ff}
.pt-card-action.delete:hover{background:#fee2e2;color:#dc2626}
/* Stage colors */
.pt-stage-sourced .pt-col-header{color:#6366f1;border-bottom-color:#6366f1}
.pt-stage-screening .pt-col-header{color:#3b82f6;border-bottom-color:#3b82f6}
.pt-stage-pending .pt-col-header{color:#f59e0b;border-bottom-color:#f59e0b}
.pt-stage-interview .pt-col-header{color:#8b5cf6;border-bottom-color:#8b5cf6}
.pt-stage-offer .pt-col-header{color:#10b981;border-bottom-color:#10b981}
.pt-stage-placed .pt-col-header{color:#059669;border-bottom-color:#059669}
.pt-stage-rejected .pt-col-header{color:#ef4444;border-bottom-color:#ef4444}
/* Pipeline form elements */
.pt-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#64748b;margin-bottom:6px}
.pt-input{width:100%;padding:9px 13px;border:1.5px solid #d1dcf5;border-radius:8px;font-family:'Inter',sans-serif;font-size:13px;color:#1a2332;background:#f0f5ff;outline:none;resize:vertical}
.pt-input:focus{border-color:#3b9eff}
.pt-cancel-btn{background:transparent;border:1.5px solid #d1dcf5;color:#64748b;padding:10px 18px;border-radius:8px;font-family:'Inter',sans-serif;font-size:13px;cursor:pointer}
.pt-cancel-btn:hover{background:#f0f5ff}
.pt-save-btn{background:linear-gradient(135deg,#2e63f0,#1b4fd8);color:#fff;padding:10px 24px;border-radius:8px;font-family:'Inter',sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:none;box-shadow:0 2px 8px rgba(27,79,216,.35)}
.pt-save-btn:hover{transform:translateY(-1px)}
.pt-empty{text-align:center;padding:16px 8px;color:#94a3b8;font-size:11px}
.pt-book-interview-btn{display:block;width:100%;margin-top:8px;padding:6px 10px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none;border-radius:6px;font-family:'Inter',sans-serif;font-size:10px;font-weight:600;cursor:pointer;transition:transform 0.15s,box-shadow 0.15s;letter-spacing:0.3px}
.pt-book-interview-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(109,40,217,.35)}

/* ===== BULK ADD HOT CANDIDATES ===== */
.bulk-hc-row{display:grid;grid-template-columns:30px 1fr 1fr 1fr 1fr 1fr 1fr;gap:8px;align-items:start;padding:8px 10px;background:#f8faff;border:1px solid #e2e8f0;border-radius:10px}
.bulk-hc-row .bulk-num{font-size:12px;font-weight:700;color:#7a9ab8;padding-top:10px;text-align:center}
.bulk-hc-row input,.bulk-hc-row textarea{padding:8px 10px;border:1.5px solid #d1dcf5;border-radius:6px;font-family:'Inter',sans-serif;font-size:12px;color:#1a2332;background:#fff;outline:none;resize:vertical}
.bulk-hc-row input:focus,.bulk-hc-row textarea:focus{border-color:#3b9eff}
.bulk-hc-row input::placeholder,.bulk-hc-row textarea::placeholder{color:#94a3b8;font-size:11px}
.hc-add-btn{padding:8px 16px;border-radius:8px;font-family:'Inter',sans-serif;font-size:12px;font-weight:500;cursor:pointer;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px rgba(217,119,6,.25);transition:transform 0.1s}
.hc-add-btn:hover{transform:translateY(-1px)}

/* ===== CLIENT TRACKER ===== */
.client-tracker-section{display:none;background:#f0faf5;min-height:60vh}
.client-tracker-section.visible{display:block}
.ct-toolbar{background:#fff;border-bottom:1px solid #d1f5e3;padding:12px 24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ct-board-wrapper{overflow-x:auto;padding:20px 24px 32px}
.ct-board{display:flex;gap:14px;align-items:flex-start;min-width:max-content}
.ct-column{width:240px;background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,60,40,0.06);overflow:hidden;flex-shrink:0}
.ct-col-header{padding:12px 14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #e2e8f0}
.ct-col-header .ct-col-count{font-size:11px;font-weight:700;background:rgba(0,0,0,0.06);padding:2px 8px;border-radius:10px}
.ct-col-body{padding:8px;min-height:60px;display:flex;flex-direction:column;gap:8px}
.ct-card{background:#f8fdfb;border:1px solid #d1f5e3;border-radius:10px;padding:12px;cursor:pointer;transition:box-shadow 0.15s,transform 0.15s;position:relative}
.ct-card:hover{box-shadow:0 4px 12px rgba(0,60,40,0.1);transform:translateY(-1px)}
.ct-card-title{font-size:13px;font-weight:600;color:#1a2332;margin-bottom:4px}
.ct-card-desc{font-size:11px;color:#64748b;margin-bottom:8px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ct-card-meta{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}
.ct-card-category{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.04em;background:#dcfce7;color:#16a34a}
.ct-card-assignee{font-size:10px;color:#64748b;font-style:italic}
.ct-card-author{font-size:9px;color:#94a3b8;margin-top:6px}
.ct-card-actions{position:absolute;top:8px;right:8px;display:none;gap:4px}
.ct-card:hover .ct-card-actions{display:flex}
.ct-card-action{width:24px;height:24px;border-radius:6px;border:1px solid #d1f5e3;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:#64748b;transition:background 0.15s}
.ct-card-action:hover{background:#f0faf5}
.ct-card-action.delete:hover{background:#fee2e2;color:#dc2626}
.ct-empty{text-align:center;padding:16px 8px;color:#94a3b8;font-size:11px}
/* Client Tracker stage colors — now applied inline via JS from ct_stages.color */

/* ===== CANDIDATE SUMMARY TABLE ===== */
.summary-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:8px}
.summary-table th{background:#1a2d4a;color:#fff;padding:10px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.summary-table td{padding:9px 12px;border-bottom:1px solid #eef4fa;vertical-align:top;line-height:1.4}
.summary-table tr:nth-child(even){background:#f8faff}
.summary-table tr:nth-child(odd){background:#fff}
.summary-table .stage-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:uppercase;display:inline-block}
.pt-card-client{font-size:10px;color:#8b5cf6;font-weight:500;margin-top:2px}
.ct-summary-btn{font-size:10px;padding:3px 8px;border-radius:5px;border:1px solid #8b5cf6;background:#f5f3ff;color:#8b5cf6;cursor:pointer;font-family:'Inter',sans-serif;font-weight:500;transition:all 0.15s;margin-top:6px;display:inline-block}
.ct-summary-btn:hover{background:#8b5cf6;color:#fff}

/* ===== CLIENT PICKER (Pipeline Summary) ===== */
.pt-client-pick{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:#f8faff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all 0.15s;font-family:'Inter',sans-serif;text-align:left}
.pt-client-pick:hover{background:#ede9fe;border-color:#8b5cf6;transform:translateY(-1px);box-shadow:0 2px 8px rgba(139,92,246,0.15)}
.pt-client-pick-name{font-size:13px;font-weight:600;color:#1a2332}
.pt-client-pick-count{font-size:11px;color:#8b5cf6;font-weight:500;background:#f5f3ff;padding:2px 8px;border-radius:6px}

/* ===== CATEGORY MANAGEMENT ===== */
.ct-cat-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f8fdfb;border:1px solid #d1f5e3;border-radius:8px}
.ct-cat-name{flex:1;font-size:13px;font-weight:500;color:#1a2332}
.ct-cat-edit-input{font-size:13px}
.ct-cat-actions{display:flex;gap:4px}
.ct-cat-btn{width:28px;height:28px;border-radius:6px;border:1px solid #d1f5e3;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:#64748b;transition:all 0.15s}
.ct-cat-edit:hover{background:#f0f5ff;color:#3b82f6;border-color:#3b82f6}
.ct-cat-save:hover{background:#dcfce7;color:#16a34a;border-color:#16a34a}
.ct-cat-cancel:hover{background:#fef3c7;color:#d97706;border-color:#d97706}
.ct-cat-delete:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626}

/* ===== LOCATION FILTER DROPDOWN ===== */
.location-filter-bar{display:flex;align-items:center;padding:6px 32px;gap:8px;flex-wrap:nowrap}
.loc-dropdown-wrap{position:relative;flex:1;max-width:360px}
.loc-search-input{width:100%;padding:8px 12px;border:1.5px solid #d1dcf5;border-radius:8px;font-size:13px;font-family:'Inter',sans-serif;color:#1a2332;background:#fff;outline:none;transition:border-color 0.15s}
.loc-search-input:focus{border-color:#3b9eff;box-shadow:0 0 0 3px rgba(59,158,255,0.1)}
.loc-dropdown{position:absolute;top:100%;left:0;right:0;max-height:240px;overflow-y:auto;background:#fff;border:1.5px solid #d1dcf5;border-radius:0 0 10px 10px;box-shadow:0 8px 24px rgba(0,0,0,0.12);z-index:200;display:none}
.loc-dropdown.open{display:block}
.loc-opt{padding:8px 12px;font-size:12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background 0.1s;color:#1a2332}
.loc-opt:hover{background:#eef4fa}
.loc-opt.active{background:#ede9fe;color:#6d28d9;font-weight:600}
.loc-opt-count{font-size:10px;color:#94a3b8;font-weight:500;background:#f1f5f9;padding:1px 6px;border-radius:4px}
.loc-opt.active .loc-opt-count{background:#ddd6fe;color:#6d28d9}
.loc-clear-btn{font-size:11px;padding:6px 10px;border-radius:6px;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;font-family:'Inter',sans-serif;font-weight:500;transition:all 0.15s;white-space:nowrap}
.loc-clear-btn:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626}

/* ===== DRAG & DROP ===== */
.pt-card.dragging,.ct-card.dragging{opacity:0.4;transform:rotate(2deg)}
.pt-col-body.drag-over,.ct-col-body.drag-over{background:#e0effa;border-radius:8px;outline:2px dashed #3b9eff;outline-offset:-2px}
.ct-col-body.drag-over{background:#d1fae5;outline-color:#10b981}

/* ===== SCROLL TOP ===== */
.scroll-top{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:#3b9eff;color:#fff;border:none;cursor:pointer;box-shadow:0 4px 12px rgba(59,158,255,0.4);display:none;align-items:center;justify-content:center;font-size:20px;z-index:100;transition:opacity 0.2s}
.scroll-top.show{display:flex}

/* ===== DASHBOARD ===== */
.dash-section{padding:28px 32px;display:none}
.dash-section.visible{display:block}
.dash-welcome{margin-bottom:28px}
.dash-welcome h2{font-size:26px;font-weight:700;color:#1a2332;margin-bottom:4px}
.dash-welcome p{font-size:14px;color:#7a9ab8}
.dash-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:28px}
.dash-stat-card{background:#fff;border-radius:14px;padding:22px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border:1px solid #e8f0fe;transition:transform 0.15s,box-shadow 0.15s}
.dash-stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.1)}
.dash-stat-card.alert .dash-stat-number{color:#dc2626}
.dash-stat-card.alert{border-color:#fecaca}
.dash-stat-highlight{font-size:34px!important;font-weight:800!important}
.dash-stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-stat-number{font-size:28px;font-weight:700;color:#1a2332;line-height:1.1}
.dash-stat-label{font-size:12px;color:#7a9ab8;font-weight:500;margin-top:2px}
.dash-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.dash-col{background:#fff;border-radius:14px;padding:20px 22px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border:1px solid #e8f0fe}
.dash-col-header{font-size:14px;font-weight:600;color:#1a2332;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #e8f0fe}
.dash-breakdown-list{display:flex;flex-direction:column;gap:10px}
.dash-breakdown-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.dash-breakdown-label{font-size:13px;color:#475569;font-weight:500;display:flex;align-items:center;gap:8px}
.dash-breakdown-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dash-breakdown-bar-wrap{flex:1;margin:0 12px;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}
.dash-breakdown-bar{height:100%;border-radius:4px;transition:width 0.6s ease}
.dash-breakdown-count{font-size:13px;font-weight:600;color:#1a2332;min-width:24px;text-align:right}
.dash-activity-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto}
.dash-activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid #f1f5f9}
.dash-activity-item:last-child{border-bottom:none}
.dash-activity-dot{width:8px;height:8px;border-radius:50%;background:#3b82f6;flex-shrink:0;margin-top:5px}
.dash-activity-text{font-size:13px;color:#334155;line-height:1.4}
.dash-activity-text strong{font-weight:600;color:#1a2332}
.dash-activity-time{font-size:11px;color:#94a3b8;margin-top:2px}
.dash-empty{text-align:center;padding:30px 20px;color:#94a3b8;font-size:13px}

/* Dashboard — Push for Feedback / Stale Alerts */
/* ===== SMART MATCH ===== */
.dash-match-section{margin-top:24px;background:#fff;border-radius:14px;padding:20px 22px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border:1px solid #e0effa}
.dash-match-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.dash-match-bar{display:flex;gap:10px;align-items:center}
.dash-match-input{flex:1;padding:12px 16px;border:1.5px solid #d1e3f0;border-radius:10px;font-size:14px;font-family:'Inter',sans-serif;color:#1a2332;background:#f8fbff;transition:border-color 0.2s}
.dash-match-input:focus{outline:none;border-color:#3b9eff;background:#fff}
.dash-match-input::placeholder{color:#94a3b8}
.dash-match-btn{padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;white-space:nowrap;transition:opacity 0.2s}
.dash-match-btn:hover{opacity:0.9}
.dash-match-btn:disabled{opacity:0.5;cursor:not-allowed}
.dash-match-results{margin-top:16px}
.dash-match-card{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px;border-radius:10px;border:1px solid #e2e8f0;margin-bottom:8px;transition:border-color 0.2s;cursor:default}
.dash-match-card:hover{border-color:#3b9eff}
.dash-match-card-info{flex:1;min-width:0}
.dash-match-name{font-weight:600;font-size:14px;color:#1a2332}
.dash-match-detail{font-size:12px;color:#64748b;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-match-source{font-size:10px;font-weight:600;padding:3px 8px;border-radius:6px;white-space:nowrap}
.dash-match-source.hc{background:#fef3c7;color:#92400e}
.dash-match-source.ps{background:#e0effa;color:#1a6dd4}
.dash-match-score{display:flex;flex-direction:column;align-items:center;margin-left:14px;flex-shrink:0}
.dash-match-score-num{font-size:20px;font-weight:800;color:#3b82f6}
.dash-match-score-label{font-size:9px;color:#94a3b8;text-transform:uppercase;letter-spacing:0.5px}
.dash-match-empty{text-align:center;padding:24px;color:#94a3b8;font-size:13px}
.dash-match-add-btn{padding:3px 10px;font-size:10px;font-weight:600;border:1.5px solid #d1e3f0;border-radius:6px;background:#f8fbff;color:#3b82f6;cursor:pointer;font-family:'Inter',sans-serif;transition:all 0.2s;white-space:nowrap}
.dash-match-add-btn:hover{background:#3b82f6;color:#fff;border-color:#3b82f6}
.dash-match-add-btn:disabled{opacity:0.5;cursor:not-allowed;background:#f0fdf4;color:#16a34a;border-color:#bbf7d0}
.dash-match-count{font-size:12px;color:#7a9ab8;font-weight:500;margin-bottom:10px}

/* ===== ADMIN MODAL BUTTONS ===== */
.modal-admin-btn{padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;border:1.5px solid;transition:all 0.2s}
.modal-admin-btn.edit{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}
.modal-admin-btn.edit:hover{background:#2563eb;color:#fff}
.modal-admin-btn.delete{background:#fef2f2;color:#dc2626;border-color:#fecaca}
.modal-admin-btn.delete:hover{background:#dc2626;color:#fff}
.modal-edit-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.modal-edit-field label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:0.5px}
.modal-edit-field input,.modal-edit-field textarea{padding:8px 12px;border:1.5px solid #d1e3f0;border-radius:8px;font-size:13px;font-family:'Inter',sans-serif;color:#1a2332}
.modal-edit-field textarea{min-height:60px;resize:vertical}
.modal-edit-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}
.modal-save-btn{padding:8px 20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}
.modal-cancel-btn{padding:8px 20px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}

.dash-stale-section{margin-top:24px;background:#fff;border-radius:14px;padding:20px 22px;box-shadow:0 2px 12px rgba(0,0,0,0.06);border:1px solid #fecaca}
.dash-stale-header{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:#dc2626}
.dash-stale-icon{font-size:20px}
.dash-stale-count{background:#dc2626;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;margin-left:4px}
.dash-stale-sub{font-size:12px;color:#94a3b8;margin-top:4px;margin-bottom:16px}
.dash-stale-list{display:flex;flex-direction:column;gap:8px}
.dash-stale-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:10px;border:1px solid #e2e8f0;transition:transform 0.15s,box-shadow 0.15s}
.dash-stale-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.08)}
.dash-stale-item.warn{background:#fffbeb;border-color:#fde68a}
.dash-stale-item.urgent{background:#fef2f2;border-color:#fecaca}
.dash-stale-left{display:flex;flex-direction:column;gap:3px}
.dash-stale-name{font-size:14px;font-weight:600;color:#1a2332}
.dash-stale-client{font-size:12px;color:#64748b}
.dash-stale-right{display:flex;align-items:center;gap:12px}
.dash-stale-stage{font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;background:#f1f5f9;color:#475569}
.dash-stale-days{font-size:13px;font-weight:700;min-width:55px;text-align:right}
.dash-stale-days.warn{color:#d97706}
.dash-stale-days.urgent{color:#dc2626}
.dash-stale-action{font-size:11px;font-weight:600;padding:6px 12px;border-radius:6px;border:none;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;transition:transform 0.15s;white-space:nowrap}
.dash-stale-action:hover{transform:translateY(-1px)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .header{flex-direction:column;gap:10px;padding:12px 16px}
  .tab-bar{padding:0 16px;overflow-x:auto}
  .tab{padding:12px 16px;font-size:13px;white-space:nowrap}
  .source-pills,.toolbar,.table-container,.location-filter-bar,.dash-section{padding-left:16px;padding-right:16px}
  .login-card{padding:32px 24px}
  .modal-body{grid-template-columns:1fr}
  .user-email{display:none}
  .dash-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .dash-columns{grid-template-columns:1fr}
}
