/* ── Reset & Variables ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:     #f0f2f5;
  --bg2:    #ffffff;
  --bg3:    #f7f8fa;
  --bg4:    #eef0f3;
  --bg5:    #e4e7ec;
  --border: rgba(0,0,0,0.08);
  --border2:rgba(0,0,0,0.14);
  --text:   #1a1d23;
  --text2:  #6b7280;
  --text3:  #9ca3af;
  --accent: #4f6ef7;
  --accent2:#3b5bf5;
  --abg:    rgba(79,110,247,0.08);
  --abg2:   rgba(79,110,247,0.16);
  --green:  #16a34a; --greenbg: rgba(22,163,74,0.08);
  --amber:  #d97706; --amberbg: rgba(217,119,6,0.08);
  --red:    #dc2626; --redbg:   rgba(220,38,38,0.08);
  --blue:   #2563eb; --bluebg:  rgba(37,99,235,0.08);
  --pink:   #db2777; --pinkbg:  rgba(219,39,119,0.08);
  --teal:   #0d9488; --tealbg:  rgba(13,148,136,0.08);
  --r:8px; --r2:12px;
  --sb:220px; --tb:54px;
  --font:'DM Sans',sans-serif;
  --mono:'DM Mono',monospace;
  --ease:0.17s cubic-bezier(.4,0,.2,1);
}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}

/* ── LOGIN SCREEN ────────────────────────────────────────────── */
#login-screen{
  position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--bg);z-index:999;
}
#login-screen.hidden{display:none}
.login-card{
  width:380px;background:var(--bg2);border:1px solid var(--border2);
  border-radius:20px;padding:40px;box-shadow:0 4px 24px rgba(0,0,0,0.08);
}
.login-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;margin-bottom:32px;letter-spacing:-0.3px}
.login-logo svg{color:var(--accent)}
.login-heading{font-size:24px;font-weight:600;letter-spacing:-0.5px;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--text2);margin-bottom:28px}
.form-field{margin-bottom:14px}
.form-label{display:block;font-size:11.5px;font-weight:600;letter-spacing:0.05em;color:var(--text3);text-transform:uppercase;margin-bottom:6px}
.form-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 13px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color var(--ease)}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--text3)}
/* Buttons — every variant inherits the base .btn sizing (height 36px, auto width).
   For the login form's full-width tall submit, add the .btn-block modifier. */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:8px;border:1px solid transparent;cursor:pointer;font-family:var(--font);font-size:13.5px;font-weight:500;line-height:1;transition:all var(--ease);white-space:nowrap;vertical-align:middle}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent2);border-color:var(--accent2)}
.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}
.btn-danger{background:var(--redbg);color:var(--red);border-color:var(--redbg)}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}
/* Active/toggled state — used by toggle buttons like Smart sort */
.btn.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.is-active:hover{background:var(--accent2);border-color:var(--accent2);color:#fff}
/* Block modifier — only used by the login submit button */
.btn-block{width:100%;height:42px;font-size:14px;margin-top:6px}
/* Small modifier — for compact inline actions (replaces ad-hoc inline font-size:12px) */
.btn-sm{height:30px;padding:0 11px;font-size:12.5px;border-radius:6px}
/* Extra-small — for buttons embedded in dense table rows */
.btn-xs{height:26px;padding:0 8px;font-size:11.5px;border-radius:5px}
/* Icon-only square button (e.g. the modal close ✕ — replaces inline width:28px;height:28px) */
.btn-icon{width:28px;height:28px;padding:0;border-radius:6px}
.login-error{background:var(--redbg);border:1px solid var(--red);color:var(--red);border-radius:8px;padding:10px 13px;font-size:13px;margin-top:12px;display:none}

/* ── APP LAYOUT ──────────────────────────────────────────────── */
#app{display:grid;grid-template-columns:var(--sb) 1fr;grid-template-rows:var(--tb) 1fr;height:100vh;overflow:hidden}
#app.hidden{display:none}

/* ── TOPBAR ──────────────────────────────────────────────────── */
.topbar{
  grid-column:1/-1;display:flex;align-items:center;gap:10px;
  padding:0 18px 0 0;border-bottom:1px solid var(--border);background:var(--bg2);z-index:50;box-shadow:0 1px 4px rgba(0,0,0,0.06);
}
.topbar-brand{
  width:var(--sb);display:flex;align-items:center;gap:8px;
  padding:0 16px;font-size:15px;font-weight:600;letter-spacing:-0.3px;flex-shrink:0;border-right:1px solid var(--border);
}
.topbar-brand svg{color:var(--accent)}
.topbar-search{
  flex:1;max-width:340px;display:flex;align-items:center;gap:8px;
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  padding:0 11px;height:33px;font-size:13px;color:var(--text2);
}
.topbar-search input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:13px;flex:1}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;cursor:pointer;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--pink))}

/* ── SIDEBAR ─────────────────────────────────────────────────── */
.sidebar{
  background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;box-shadow:1px 0 4px rgba(0,0,0,0.04);
}
.nav-section{padding:14px 12px 4px;font-size:10.5px;font-weight:600;letter-spacing:0.1em;color:var(--text3);text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:7px 12px;border-radius:8px;
  cursor:pointer;color:var(--text2);font-size:13.5px;transition:all var(--ease);
  margin:1px 8px;user-select:none;
}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:var(--abg);color:var(--accent);font-weight:600}
.nav-item svg{width:15px;height:15px;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--bg5);color:var(--text3);font-size:10.5px;padding:1px 6px;border-radius:9px}
.sidebar-footer{padding:10px;border-top:1px solid var(--border);margin-top:auto}

/* ── MAIN CONTENT ────────────────────────────────────────────── */
.main{overflow:hidden;display:flex;flex-direction:column;min-height:0;height:100%}
.view{display:none;flex-direction:column;overflow:hidden;min-height:0;flex:1}
.view.active{display:flex;flex-direction:column;min-height:0;flex:1}
.view-header{padding:18px 22px 0;display:flex;align-items:flex-start;gap:10px;flex-shrink:0}
.view-title{font-size:20px;font-weight:600;letter-spacing:-0.5px}
.view-sub{font-size:12.5px;color:var(--text2);margin-top:2px}
.view-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}
.view-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 22px;display:flex;flex-direction:column;gap:14px;min-height:0}

/* ── CARDS ───────────────────────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.card-header{display:flex;align-items:center;margin-bottom:14px}
.card-title{font-size:13.5px;font-weight:600}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:all var(--ease);box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.stat-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(79,110,247,0.1)}
.stat-label{font-size:11.5px;color:var(--text3);font-weight:500;letter-spacing:0.03em;margin-bottom:6px}
.stat-value{font-size:26px;font-weight:600;letter-spacing:-0.8px;line-height:1}
.stat-change{font-size:11.5px;margin-top:4px;color:var(--text2)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}

/* ── TABLE ───────────────────────────────────────────────────── */
.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.tbl-head-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);gap:8px}
table{width:100%;border-collapse:collapse}
table th{padding:9px 13px;text-align:left;font-size:10.5px;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border)}
table td{padding:10px 13px;font-size:13.5px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
table tbody tr:last-child td{border-bottom:none}
table tbody tr{transition:background var(--ease);cursor:pointer}
table tbody tr:hover{background:var(--abg)}

/* ── TAGS/BADGES ─────────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:500;white-space:nowrap}
.tag-green{background:var(--greenbg);color:var(--green)}
.tag-amber{background:var(--amberbg);color:var(--amber)}
.tag-red{background:var(--redbg);color:var(--red)}
.tag-blue{background:var(--bluebg);color:var(--blue)}
.tag-teal{background:var(--tealbg);color:var(--teal)}
.tag-purple{background:var(--abg);color:var(--accent2)}
.tag-gray{background:var(--bg5);color:var(--text2)}
.tag-pink{background:var(--pinkbg);color:var(--pink)}

/* ── PROGRESS ────────────────────────────────────────────────── */
.prog{height:5px;background:var(--bg5);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width 0.5s}

/* ── TIMER BAR ───────────────────────────────────────────────── */
.timer-bar{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);
  padding:14px 18px;display:flex;align-items:center;gap:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);
}
.timer-display{font-family:var(--mono);font-size:26px;font-weight:500;letter-spacing:2px}
.timer-dot{width:9px;height:9px;border-radius:50%;background:var(--red);
  animation:pulse 1.3s ease-in-out infinite;display:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── KANBAN ──────────────────────────────────────────────────── */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;flex:1;overflow:hidden;min-height:0}
.k-col{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);display:flex;flex-direction:column;overflow:hidden}
.k-col-head{padding:11px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.k-col-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px}
.k-count{background:var(--bg5);color:var(--text3);font-size:10.5px;padding:1px 6px;border-radius:9px}
.k-cards{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:7px}
.k-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:11px;cursor:pointer;transition:all var(--ease);box-shadow:0 1px 3px rgba(0,0,0,0.05)}
.k-card:hover{border-color:var(--accent);background:var(--bg2);box-shadow:0 2px 8px rgba(79,110,247,0.1)}
/* ── Task action menu button (shared across all views) ─────── */
.task-menu-btn{
  background:none;border:none;cursor:pointer;
  font-size:15px;color:var(--text3);
  padding:0 4px;line-height:1;border-radius:4px;
  transition:all var(--ease);flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;
}
.task-menu-btn:hover{background:var(--bg5);color:var(--accent)}
/* keep old class names as aliases */
.k-card-menu-btn{background:none;border:none;cursor:pointer;font-size:15px;color:var(--text3);padding:0 4px;line-height:1;border-radius:4px;transition:all var(--ease);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;}
.k-card-menu-btn:hover{background:var(--bg5);color:var(--accent)}
.row-menu-btn{background:none;border:none;cursor:pointer;font-size:15px;color:var(--text3);padding:0 4px;line-height:1;border-radius:4px;transition:all var(--ease);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;}
.row-menu-btn:hover{background:var(--bg5);color:var(--accent)}
.k-card-title{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:8px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;word-break:break-word}
.k-card-foot{display:flex;align-items:center;justify-content:space-between;gap:6px}

/* ── TASK LIST VIEW ──────────────────────────────────────────── */
.task-list-table{table-layout:fixed}
.task-list-table th{padding:11px 14px;font-size:10.5px;color:var(--text3);border-bottom:1px solid var(--border)}
.task-list-table td{padding:14px;vertical-align:middle;border-bottom:1px solid var(--border)}
.task-list-table tbody tr:last-child td{border-bottom:none}
.task-list-table tbody tr{transition:background var(--ease)}
.task-list-table tbody tr:hover{background:var(--bg3)}
.task-list-table .tlt-task-cell{min-width:0}
.task-list-table .tlt-task-name{font-weight:500;font-size:13.5px;color:var(--text);line-height:1.4;
  overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}
.task-list-table .tlt-task-meta{display:flex;align-items:center;gap:8px;margin-top:5px;flex-wrap:wrap}
.task-list-table .tlt-task-cat{font-size:11px;color:var(--text3);font-style:italic}
.task-list-table .tlt-owner{display:flex;align-items:center;gap:7px;min-width:0}
.task-list-table .tlt-owner-name{font-size:12.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.task-list-table .tlt-num{font-size:13px;text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.task-list-table .tlt-due{font-size:12px;white-space:nowrap}
.task-list-table .tlt-checkbox{text-align:center;padding-left:8px;padding-right:0}
.task-list-table .row-menu-btn{opacity:0.35;transition:opacity var(--ease)}
.task-list-table tr:hover .row-menu-btn{opacity:1}
/* Project chip — small accent-tinted pill shown beneath the task name */
.proj-chip{display:inline-flex;align-items:center;gap:5px;background:var(--abg);color:var(--accent);
  font-size:10.5px;font-weight:500;padding:2px 8px;border-radius:10px;line-height:1.5;max-width:100%;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;transition:background var(--ease)}
.proj-chip:hover{background:var(--abg2)}
.proj-chip-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}
.proj-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Status / Priority pills at table-cell scale */
.task-list-table .tag{font-size:11px;padding:3px 9px}

/* ── PERSONAL NOTES (Keep-style) ─────────────────────────────── */
.notes-toolbar{display:flex;align-items:center;gap:10px;padding:0 22px 10px;flex-shrink:0;flex-wrap:wrap}
.notes-tabs{display:flex;gap:2px}
.notes-tab{padding:6px 12px;font-size:12.5px;font-weight:500;cursor:pointer;color:var(--text2);border-radius:6px;transition:all var(--ease);user-select:none;display:flex;align-items:center;gap:6px}
.notes-tab:hover:not(.active){background:var(--bg3);color:var(--text)}
.notes-tab.active{background:var(--abg);color:var(--accent);font-weight:600}
.notes-tab-badge{background:var(--bg5);color:var(--text3);font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:9px}
.notes-tab.active .notes-tab-badge{background:var(--abg2);color:var(--accent)}

/* Masonry-style grid using CSS columns */
.notes-grid{column-count:4;column-gap:12px;padding:0 22px 22px}
@media (max-width:1500px){.notes-grid{column-count:3}}
@media (max-width:1100px){.notes-grid{column-count:2}}
@media (max-width:700px){.notes-grid{column-count:1}}

.note-card{break-inside:avoid;margin:0 0 12px;border:1px solid var(--border);border-radius:var(--r2);
  padding:12px 14px;cursor:pointer;transition:all var(--ease);box-shadow:0 1px 3px rgba(0,0,0,0.04);
  position:relative;display:flex;flex-direction:column;gap:6px;overflow:hidden}
.note-card:hover{box-shadow:0 3px 12px rgba(0,0,0,0.08);border-color:var(--border2)}
.note-card.is-pinned::before{content:'📌';position:absolute;top:8px;right:10px;font-size:11px;opacity:0.6}
.note-title{font-size:13.5px;font-weight:600;color:var(--text);line-height:1.35;word-break:break-word;padding-right:18px}
.note-body{font-size:12.5px;color:var(--text);line-height:1.45;white-space:pre-wrap;word-break:break-word;
  display:-webkit-box;-webkit-line-clamp:14;-webkit-box-orient:vertical;overflow:hidden}
.note-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px;padding-top:6px;border-top:1px solid var(--border)}
.note-meta-time{font-size:10.5px;color:var(--text3)}
.note-reminder{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:500;
  padding:2px 7px;border-radius:10px;background:var(--bluebg);color:var(--blue)}
.note-reminder.due-soon{background:var(--amberbg);color:var(--amber)}
.note-reminder.past{background:var(--redbg);color:var(--red)}

/* Checklist preview inside cards */
.note-checklist{display:flex;flex-direction:column;gap:3px}
.note-checklist-item{display:flex;align-items:center;gap:6px;font-size:12.5px;line-height:1.35}
.note-checklist-item .nci-box{flex-shrink:0;width:13px;height:13px;border:1.5px solid var(--text3);border-radius:3px;
  display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:#fff;background:transparent}
.note-checklist-item.done .nci-box{background:var(--accent);border-color:var(--accent)}
.note-checklist-item.done .nci-box::after{content:'✓'}
.note-checklist-item.done .nci-text{text-decoration:line-through;color:var(--text3)}
.note-checklist-more{font-size:11px;color:var(--text3);padding-left:19px;margin-top:2px}

/* Card hover action bar */
.note-actions{display:flex;align-items:center;gap:2px;margin-left:auto;opacity:0;transition:opacity var(--ease)}
.note-card:hover .note-actions{opacity:1}
.note-act-btn{background:none;border:none;cursor:pointer;width:24px;height:24px;border-radius:5px;color:var(--text3);
  display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:all var(--ease);padding:0}
.note-act-btn:hover{background:rgba(0,0,0,0.06);color:var(--text)}
.note-act-btn.danger:hover{background:var(--redbg);color:var(--red)}

/* Color palette (cards + swatch picker share these) */
.note-color-default{background:var(--bg2)}
.note-color-yellow {background:#fff8c5;border-color:#f0e3a0}
.note-color-green  {background:#dcfce7;border-color:#b8ecc7}
.note-color-blue   {background:#dbeafe;border-color:#b9d3f9}
.note-color-pink   {background:#fce7f3;border-color:#f3c8df}
.note-color-purple {background:#ede9fe;border-color:#d6cdf6}
.note-color-gray   {background:#f1f3f5;border-color:#dde0e4}

.color-picker{display:flex;gap:6px;flex-wrap:wrap}
.color-swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;
  transition:transform var(--ease), border-color var(--ease)}
.color-swatch:hover{transform:scale(1.1)}
.color-swatch.selected{border-color:var(--accent)}

/* Note editor modal — checklist editing */
.note-edit-checklist{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}
.note-edit-cli{display:flex;align-items:center;gap:7px;padding:4px 0}
.note-edit-cli input[type="checkbox"]{width:15px;height:15px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}
.note-edit-cli input[type="text"]{flex:1;background:transparent;border:none;outline:none;font-size:13.5px;
  color:var(--text);font-family:var(--font);padding:3px 0}
.note-edit-cli input[type="text"].done{text-decoration:line-through;color:var(--text3)}
.note-edit-cli .cli-remove{background:none;border:none;cursor:pointer;color:var(--text3);width:22px;height:22px;
  border-radius:4px;font-size:13px;flex-shrink:0;opacity:0;transition:all var(--ease)}
.note-edit-cli:hover .cli-remove{opacity:1}
.note-edit-cli .cli-remove:hover{background:var(--redbg);color:var(--red)}
.note-edit-cli-add{display:flex;align-items:center;gap:7px;padding:6px 0;color:var(--text3);cursor:text}
.note-edit-cli-add::before{content:'+';font-size:16px;width:15px;text-align:center}

/* Type toggle in editor */
.note-type-toggle{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}
.note-type-toggle button{background:var(--bg3);border:none;padding:5px 11px;font-size:12px;cursor:pointer;
  color:var(--text2);font-family:var(--font);transition:all var(--ease)}
.note-type-toggle button.active{background:var(--accent);color:#fff}

/* Empty state */
.notes-empty{text-align:center;padding:64px 22px;color:var(--text3)}
.notes-empty-icon{font-size:42px;margin-bottom:12px;opacity:0.5}
.notes-empty-title{font-size:15px;color:var(--text2);margin-bottom:4px;font-weight:500}
.notes-empty-sub{font-size:12.5px}

/* ── MODAL ───────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.72);display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;pointer-events:none;transition:opacity var(--ease)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r2);width:520px;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;transform:translateY(10px);transition:transform var(--ease);box-shadow:0 8px 40px rgba(0,0,0,0.14)}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-head{padding:15px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-title{font-size:15px;font-weight:600}
.modal-body{padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-group{display:flex;flex-direction:column;gap:5px}
select.form-input{appearance:none;cursor:pointer}
textarea.form-input{resize:vertical;min-height:72px}

/* ── ADMIN PANEL ─────────────────────────────────────────────── */
.admin-tabs{display:flex;gap:4px;padding:0 22px;border-bottom:1px solid var(--border);flex-shrink:0}
.admin-tab{padding:10px 14px;font-size:13px;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;transition:all var(--ease);margin-bottom:-1px}
.admin-tab.active{color:var(--accent2);border-bottom-color:var(--accent)}
.admin-tab:hover:not(.active){color:var(--text)}
.admin-pane{display:none;flex:1;overflow-y:auto;padding:18px 22px}
.admin-pane.active{display:block}

/* ── MISC ────────────────────────────────────────────────────── */
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.ml-auto{margin-left:auto}
.text-sm{font-size:12px}.text-muted{color:var(--text2)}.fw6{font-weight:600}
.divider{height:1px;background:var(--border);margin:6px 0}
.avatar-sm{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:#fff;flex-shrink:0}
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r);padding:11px 16px;font-size:13px;color:var(--text);z-index:9999;display:flex;align-items:center;gap:9px;transform:translateY(80px);opacity:0;transition:all 0.28s;max-width:290px;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,0.1)}
.toast.show{transform:translateY(0);opacity:1}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:2px}
/* tooltip handled by JS */
.role-superadmin{display:none}
.is-superadmin .role-superadmin{display:flex}
.is-superadmin .role-admin{display:flex}
.role-admin{display:none}
.is-admin .role-admin{display:flex}



/* ── NOTES ──────────────────────────────────────────────────── */
.note-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;position:relative}
.note-card:hover .note-del{opacity:1}
.note-del{position:absolute;top:8px;right:8px;opacity:0;transition:opacity var(--ease);background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:2px 6px}
.note-del:hover{color:var(--red)}
.note-meta{font-size:11px;color:var(--text3);margin-bottom:4px}
.note-body{font-size:13.5px;color:var(--text);white-space:pre-wrap;line-height:1.6}
.note-editor{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.note-editor textarea{width:100%;min-height:72px;resize:vertical}
.note-editor-actions{display:flex;justify-content:flex-end}

/* ── FILES DROPZONE ──────────────────────────────────────────── */
.drop-zone{border:2px dashed var(--border2);border-radius:var(--r2);padding:20px;text-align:center;cursor:pointer;transition:all var(--ease);color:var(--text2)}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--abg);color:var(--accent)}
.drop-zone input[type=file]{display:none}
.file-chip{display:flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:7px 10px;font-size:12.5px}
.file-chip-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-chip-size{color:var(--text3);font-size:11.5px;white-space:nowrap}

/* ── CUSTOMER DETAIL PANEL ────────────────────────────────────── */
.cust-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all var(--ease)}
.cust-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(79,110,247,0.1)}
.cust-card-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}
.cust-avatar{width:40px;height:40px;border-radius:var(--r);background:var(--abg);color:var(--accent);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.contact-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;position:relative}
.contact-primary{border-color:var(--accent);background:var(--abg)}
.contact-badge{background:var(--accent);color:#fff;font-size:10px;padding:1px 6px;border-radius:8px;margin-left:6px}


/* ── HTML TOOLTIP ───────────────────────────────────────────── */
.has-tip{position:relative}
.pf-tip{
  display:none;position:fixed;z-index:99999;
  background:#1a1d23;color:#eaeaf2;
  font-size:12.5px;line-height:1.6;
  padding:9px 14px;border-radius:8px;
  box-shadow:0 4px 24px rgba(0,0,0,0.4);
  max-width:340px;pointer-events:none;
  white-space:normal;word-break:break-word;
  border:1px solid rgba(255,255,255,0.10);
}
.pf-tip strong{color:#fff;display:block;margin-bottom:4px;font-size:13px;line-height:1.4}
.tip-meta{color:#9ca3af;font-size:11px;margin-top:5px;display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,0.08);padding-top:5px}
.tip-meta span{display:flex;align-items:center;gap:3px}


/* ── CARD CONTEXT MENU ───────────────────────────────────────── */
.ctx-menu{
  position:fixed;z-index:99998;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r);box-shadow:0 8px 28px rgba(0,0,0,0.18);
  min-width:230px;padding:4px 0;
  animation:ctxIn 0.1s ease;
}
@keyframes ctxIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.ctx-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;font-size:13px;cursor:pointer;
  color:var(--text);transition:background var(--ease);
  user-select:none;
}
.ctx-item:hover{background:var(--bg3)}
.ctx-item.danger{color:var(--red)}
.ctx-item.danger:hover{background:var(--redbg)}
.ctx-sep{height:1px;background:var(--border);margin:4px 0}
.ctx-label{padding:5px 14px 3px;font-size:10.5px;font-weight:700;
  letter-spacing:0.07em;text-transform:uppercase;color:var(--text3)}
/* Inline "Log time" mini-form inside the context menu */
.ctx-log-form{padding:4px 14px 8px;display:flex;flex-direction:column;gap:6px}
.ctx-log-row{display:flex;align-items:center;gap:6px}
.ctx-log-input{
  background:var(--bg3);border:1px solid var(--border);border-radius:6px;
  padding:6px 9px;font-family:var(--font);font-size:13px;color:var(--text);
  outline:none;transition:border-color var(--ease)
}
.ctx-log-input:focus{border-color:var(--accent)}
.ctx-log-hours-input{width:70px}
.ctx-log-note-input{width:100%}
.ctx-log-unit{font-size:11.5px;color:var(--text3)}
.ctx-log-actions{display:flex;align-items:center;gap:8px;margin-top:2px}
.ctx-log-check{
  display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text2);
  cursor:pointer;user-select:none;flex:1
}
.ctx-log-check input{width:13px;height:13px;cursor:pointer;accent-color:var(--accent);margin:0}


/* ── SORTABLE COLUMN HEADERS ─────────────────────────────────── */
.proj-col-head .sortable{cursor:pointer;user-select:none;display:flex;align-items:center;gap:4px}
.proj-col-head .sortable:hover{color:var(--text2)}
.proj-col-head .sortable.asc::after{content:'↑';opacity:0.8}
.proj-col-head .sortable.desc::after{content:'↓';opacity:0.8}
.proj-col-head .sortable:not(.asc):not(.desc)::after{content:'↕';opacity:0.3}

/* ── PROJECT TABS ────────────────────────────────────────────── */
.proj-tabs{display:flex;align-items:center;gap:2px;padding:0 22px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg2);overflow-x:auto}
.proj-tab{padding:10px 14px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;white-space:nowrap;transition:all var(--ease);margin-bottom:-1px;display:flex;align-items:center;gap:5px}
.proj-tab:hover:not(.active){color:var(--text);background:var(--bg3)}
.proj-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.proj-tab-badge{background:var(--redbg);color:var(--red);font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:9px;display:none}
.proj-tab-badge.has-items{display:inline-block}
.proj-tab[data-tab="overdue"] .proj-tab-badge{background:var(--redbg);color:var(--red)}
.proj-tab[data-tab="thisweek"] .proj-tab-badge{background:var(--amberbg);color:var(--amber)}
.proj-tab[data-tab="nextweek"] .proj-tab-badge{background:var(--bluebg);color:var(--blue)}
.proj-tab[data-tab="months3"] .proj-tab-badge,.proj-tab[data-tab="future"] .proj-tab-badge,.proj-tab[data-tab="nodate"] .proj-tab-badge{background:var(--bg5);color:var(--text2)}
/* Right-aligned toggle inside the tabs row (e.g. "Include completed & cancelled") */
.proj-tabs-toggle{
  display:flex;align-items:center;gap:7px;
  margin-left:auto;             /* push to the far right */
  padding:0 4px 0 14px;
  font-size:12.5px;color:var(--text2);
  cursor:pointer;user-select:none;white-space:nowrap;
  transition:color var(--ease);
}
.proj-tabs-toggle:hover{color:var(--text)}
.proj-tabs-toggle input{width:14px;height:14px;cursor:pointer;accent-color:var(--accent);margin:0}

/* ── PROJECT GROUPS ──────────────────────────────────────────── */
.proj-group{margin-bottom:6px}
.proj-group-header{display:flex;align-items:center;gap:10px;padding:8px 0 6px;cursor:pointer;user-select:none}
.proj-group-label{font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--text3)}
.proj-group-count{background:var(--bg5);color:var(--text3);font-size:11px;padding:1px 7px;border-radius:10px}
.proj-group-line{flex:1;height:1px;background:var(--border)}
.proj-group-body{display:flex;flex-direction:column;gap:4px;padding-bottom:4px}
/* expand btn + 8 data cols */
/* Shared column template for project rows + their column header + the
   expanded task-tree rows beneath each project. Three things must stay
   identical for vertical alignment, hence the variable. Pixel widths
   are sized for the actual content (pill heights, "Xh" hours strings,
   a 22px avatar, a "Wed, 6 May" date). Project / Customer / Progress
   are flexible and absorb whatever space is left. */
:root {
  --proj-grid:
    32px               /* col 1  — expand toggle / indent */
    minmax(0, 2.4fr)   /* col 2  — Project / Task name (widest) */
    minmax(0, 1.4fr)   /* col 3  — Customer / Category */
    100px              /* col 4  — Status pill */
    100px              /* col 5  — Priority pill */
    minmax(0, 1.1fr)   /* col 6  — Progress bar + % */
    70px               /* col 7  — Tasks count "0 / 7" (empty for task rows) */
    60px               /* col 8  — Est hours */
    75px               /* col 9  — Act hours (decimals like 96.0h) */
    50px               /* col 10 — Owner avatar (avatar-only) */
    105px;             /* col 11 — Due date "Wed, 6 May" */
}
.proj-row{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:0;display:grid;grid-template-columns:var(--proj-grid);align-items:center;gap:0;cursor:pointer;transition:all var(--ease);font-size:13px;overflow:hidden}
.proj-row:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(79,110,247,0.08)}
.proj-row-overdue{border-left:3px solid var(--red)}
.proj-row-thisweek{border-left:3px solid var(--amber)}
.proj-row-nextweek{border-left:3px solid var(--blue)}
.proj-row-future{border-left:3px solid var(--border2)}
.proj-col-head{
  display:grid;grid-template-columns:var(--proj-grid);gap:0;
  padding:8px 0;font-size:10.5px;font-weight:600;letter-spacing:0.07em;
  text-transform:uppercase;color:var(--text3);
  /* Stick to the top of the scrolling .view-body so column labels stay
     visible while the project rows scroll underneath. */
  position:sticky;top:-16px;       /* offset cancels view-body padding-top */
  z-index:5;background:var(--bg);
  margin:-16px -22px 4px;          /* extend across the .view-body padding */
  padding-left:22px;padding-right:22px;
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 var(--border);
}
.proj-col-head > div{padding:0 10px}
.proj-cell{padding:10px 10px;display:flex;align-items:center}
/* expand toggle */
.proj-expand{display:flex;align-items:center;justify-content:center;height:100%;cursor:pointer;color:var(--text3);font-size:12px;transition:all var(--ease);border-right:1px solid var(--border);padding:0 8px;flex-shrink:0;user-select:none}
.proj-expand:hover{background:var(--bg3);color:var(--text)}
.proj-expand.open{color:var(--accent)}
/* task tree rows */
.proj-tree{display:none;flex-direction:column;gap:0;border-top:1px solid var(--border);background:var(--bg3)}
.proj-tree.open{display:flex}
.task-tree-row{display:grid;grid-template-columns:var(--proj-grid);align-items:center;font-size:12.5px;border-bottom:1px solid var(--border);transition:background var(--ease);cursor:pointer}
.task-tree-row:last-child{border-bottom:none}
.task-tree-row:hover{background:var(--bg4)}
.task-tree-indent{padding:8px 10px;display:flex;align-items:center;border-right:1px solid var(--border);justify-content:center}
.task-tree-cell{padding:8px 10px;display:flex;align-items:center;overflow:hidden}
.task-tree-loading{padding:10px 44px;font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px}

/* ── KANBAN DRAG DROP ────────────────────────────────────────── */
.k-card{cursor:grab}
.k-card.dragging{opacity:0.4;cursor:grabbing}
.k-col.drag-over .k-cards{background:var(--abg);border-radius:var(--r)}
.k-card-status-label{font-size:10.5px;color:var(--text2)}

/* ── DUPLICATE-PROJECT WARNING (new-project modal) ─────────────── */
.np-dupes{
  border:1px solid var(--border);border-radius:8px;
  background:var(--bg3);padding:10px 12px;
  animation:dupeIn 0.15s ease-out;
}
@keyframes dupeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.np-dupes-high{border-color:#ef4444;background:rgba(239,68,68,0.06)}
.np-dupes-med {border-color:#f59e0b;background:rgba(245,158,11,0.07)}
.np-dupes-low {border-color:var(--border2)}
.np-dupes-head{
  font-size:12px;font-weight:700;letter-spacing:0.03em;
  color:var(--text);margin-bottom:6px;display:flex;align-items:center;gap:6px;
}
.np-dupes-high .np-dupes-head{color:#ef4444}
.np-dupes-med  .np-dupes-head{color:#b45309}
.np-dupes-list{display:flex;flex-direction:column;gap:4px}
.np-dupe-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 9px;border-radius:6px;
  background:var(--bg2);border:1px solid transparent;
  cursor:pointer;transition:all var(--ease);
}
.np-dupe-item:hover{border-color:var(--border2);background:var(--bg4)}
.np-dupe-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.np-dupe-body{flex:1;min-width:0}
.np-dupe-name{
  font-size:13px;font-weight:500;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.np-dupe-meta{font-size:11.5px;color:var(--text3);margin-top:1px}
.np-dupe-score{
  font-family:var(--mono);font-size:11px;font-weight:600;
  color:var(--text3);padding:2px 6px;border-radius:4px;
  background:var(--bg3);flex-shrink:0;
}
.np-dupes-hint{
  font-size:11px;color:var(--text3);margin-top:7px;padding-top:7px;
  border-top:1px dashed var(--border);
}

/* ── Rich-text note editor ──────────────────────────────────────
   Used in the project / task detail modal and the New Project
   modal Notes tab. Built on contenteditable + execCommand with
   paste-handling for screenshots (inlined as base64 data URLs). */
.rich-editor{border:1px solid var(--border2);border-radius:var(--r);background:var(--bg2);display:flex;flex-direction:column;overflow:hidden;transition:border-color var(--ease)}
.rich-editor:focus-within{border-color:var(--accent)}
.rich-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:5px 6px;border-bottom:1px solid var(--border);background:var(--bg3)}
.rich-btn{background:none;border:1px solid transparent;border-radius:4px;padding:0 7px;font-size:12.5px;color:var(--text2);cursor:pointer;min-width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-family:inherit}
.rich-btn:hover{background:var(--bg2);color:var(--text);border-color:var(--border)}
.rich-btn:active,.rich-btn.active{background:var(--abg);color:var(--accent);border-color:var(--abg)}
.rich-btn b{font-weight:700}
.rich-btn i{font-style:italic}
.rich-btn u{text-decoration:underline}
.rich-sep{width:1px;height:18px;background:var(--border);margin:0 3px;flex-shrink:0}
.rich-select{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:0 6px;font-size:12px;color:var(--text2);cursor:pointer;height:26px;font-family:inherit}
.rich-content{min-height:90px;max-height:280px;overflow-y:auto;padding:9px 11px;font-size:13.5px;line-height:1.5;color:var(--text);outline:none;position:relative}
.rich-content.is-empty::before{content:attr(data-placeholder);color:var(--text3);pointer-events:none;position:absolute;top:9px;left:11px}
.rich-content img{max-width:100%;height:auto;display:inline-block;margin:4px 0;border-radius:4px;border:1px solid var(--border)}
.rich-content p{margin:0 0 6px}
.rich-content ul,.rich-content ol{margin:4px 0 6px;padding-left:22px}
.rich-content h2{font-size:16px;margin:6px 0;font-weight:600}
.rich-content h3{font-size:14px;margin:6px 0;font-weight:600}
.rich-content blockquote{border-left:3px solid var(--border2);margin:4px 0;padding:2px 10px;color:var(--text2)}
.rich-content a{color:var(--accent);text-decoration:underline}
/* When rendered inside a note card (read-only display), images
   should also be constrained so a pasted screenshot doesn't blow
   up the card width. */
.note-body img{max-width:100%;height:auto;display:inline-block;border-radius:4px;border:1px solid var(--border);margin:4px 0}
.note-body p{margin:0 0 6px}
.note-body ul,.note-body ol{margin:4px 0 6px;padding-left:22px}
.note-body blockquote{border-left:3px solid var(--border2);margin:4px 0;padding:2px 10px;color:var(--text2)}

/* Constrain images inside the My Notes card grid so a pasted
   screenshot doesn't blow up a card preview. The full image is
   visible when the user opens the note for editing. */
#notes-grid .note-body img{max-height:140px;width:auto;object-fit:contain;display:block}

/* ── Image popover (resize / remove) ─────────────────────────
   Shown when the user clicks an image inside any rich-text
   editor; lets them resize the image to a fraction of the
   container width or remove it from the note. */
.rich-content img{cursor:pointer}
.rich-img-selected{outline:2px solid var(--accent);outline-offset:2px}
.rich-img-pop{position:absolute;z-index:9000;background:var(--bg2);border:1px solid var(--border2);border-radius:6px;box-shadow:0 4px 18px rgba(0,0,0,0.18);padding:4px;display:flex;align-items:center;gap:2px;font-size:12px;font-family:inherit}
.rich-img-pop button{background:none;border:1px solid transparent;color:var(--text2);padding:0 9px;border-radius:4px;cursor:pointer;font-size:12px;font-family:inherit;line-height:1;height:26px}
.rich-img-pop button:hover{background:var(--bg3);color:var(--text);border-color:var(--border)}
.rich-img-pop .rich-img-pop-del{color:var(--red)}
.rich-img-pop .rich-img-pop-del:hover{background:var(--redbg);color:var(--red);border-color:var(--redbg)}
.rich-img-pop-sep{width:1px;height:18px;background:var(--border);margin:0 3px}

/* ── Project notes: edit button + active-edit highlight ──────
   Edit pencil sits left of the existing ✕ delete button on each
   note card; both fade in on hover. The card being edited gets
   a persistent accent outline so it's obvious which one is loaded
   in the editor at the top. */
.note-card:hover .note-edit{opacity:1}
.note-edit{position:absolute;top:7px;right:30px;opacity:0;transition:opacity var(--ease),color var(--ease),background var(--ease);background:none;border:none;color:var(--text3);cursor:pointer;padding:4px 6px;line-height:0;display:inline-flex;align-items:center;justify-content:center;border-radius:3px}
.note-edit:hover{color:var(--accent);background:var(--bg2)}
.note-edit svg{display:block}
.note-card.is-editing{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.note-card.is-editing .note-edit{opacity:1;color:var(--accent)}

/* ── Gantt horizontal scrollbars ─────────────────────────────
   Override the thin (4px) global scrollbar for the Gantt view
   only: the top mirror strip and the main body's horizontal
   scrollbar both get a 12px track with a prominent thumb so
   users can see and grab them easily on a wide timeline. */
#gantt-top-scroll::-webkit-scrollbar,
#resource-top-scroll::-webkit-scrollbar{height:14px;width:14px}
#gantt-top-scroll::-webkit-scrollbar-track,
#resource-top-scroll::-webkit-scrollbar-track{background:var(--bg3);border-radius:7px}
#gantt-top-scroll::-webkit-scrollbar-thumb,
#resource-top-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:7px;border:2px solid var(--bg3)}
#gantt-top-scroll::-webkit-scrollbar-thumb:hover,
#resource-top-scroll::-webkit-scrollbar-thumb:hover{background:var(--text3)}
#gantt-top-scroll,
#resource-top-scroll{scrollbar-color:var(--border2) var(--bg3);scrollbar-width:auto}

#gantt-scroll-wrap::-webkit-scrollbar,
#resource-scroll-wrap::-webkit-scrollbar{height:12px;width:10px}
#gantt-scroll-wrap::-webkit-scrollbar-track,
#resource-scroll-wrap::-webkit-scrollbar-track{background:var(--bg3)}
#gantt-scroll-wrap::-webkit-scrollbar-thumb,
#resource-scroll-wrap::-webkit-scrollbar-thumb{background:var(--border2);border-radius:6px;border:2px solid var(--bg3)}
#gantt-scroll-wrap::-webkit-scrollbar-thumb:hover,
#resource-scroll-wrap::-webkit-scrollbar-thumb:hover{background:var(--text3)}
#gantt-scroll-wrap,
#resource-scroll-wrap{scrollbar-color:var(--border2) var(--bg3);scrollbar-width:thin}

/* ── Gantt inline task-add button ───────────────────────────
   The "+" button on each project row lives next to the task
   count. Hover-only so it doesn't clutter the UI while idle. */
.g-proj-row .g-proj-add{opacity:0;transition:opacity var(--ease),color var(--ease),background var(--ease);background:none;border:1px solid transparent;color:var(--text3);cursor:pointer;font-size:16px;font-weight:600;padding:0;width:20px;height:20px;line-height:1;border-radius:4px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}
.g-proj-row:hover .g-proj-add{opacity:1}
.g-proj-add:hover{color:var(--accent);background:var(--bg2);border-color:var(--border)}

/* Task label hover highlight — subtle cue that the row is clickable */
.g-task-label:hover{background:var(--bg3)!important;color:var(--text)!important}

/* ── Resource planner drop-target highlight ───────────────────
   When dragging a task bar on the Resource view, the owner row
   under the cursor receives .g-dropping so the user can see
   where the bar will land on release. */
.g-dropping{background:var(--abg)!important;box-shadow:inset 0 0 0 2px var(--accent);position:relative}
.g-dropping::after{content:'⇩ reassign';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:var(--accent);letter-spacing:0.04em;pointer-events:none;background:var(--bg2);padding:2px 8px;border-radius:10px;border:1px solid var(--accent)}

/* ── Tasks list: sortable + sticky column headers ──────────────
   Keeps the header row visible while scrolling long task lists
   and gives every header a click-affordance + arrow indicator. */
.task-list-table thead th{position:sticky;top:0;z-index:5;background:var(--bg2);box-shadow:inset 0 -1px 0 var(--border)}
.task-list-table th.tlt-sortable{cursor:pointer;user-select:none;transition:color var(--ease)}
.task-list-table th.tlt-sortable:hover{color:var(--text)}
.task-list-table .tlt-sort-arrow{font-size:9px;color:var(--accent);margin-left:2px;display:inline-block;min-width:10px}
