/* v2 surfaces — ported 1:1 from Noa's hyperfocus_v2_surfaces_mock.html.
   Sub-tasks reuse .sub (app.css); composer reuses app.css. Tokens from tokens.css. */

/* comments thread */
.thread { display: flex; flex-direction: column; gap: var(--space-4); }
.cmt { display: flex; gap: var(--space-3); }
.cmt .cbody { flex: 1; min-width: 0; }
.cmt-head { display: flex; align-items: baseline; gap: 8px; margin-bottom: 5px; }
.cmt-head b { font-size: 12.5px; font-weight: 600; color: var(--text-primary); }
.cmt-head .when { font-family: var(--font-mono); font-size: 10px; color: var(--text-tertiary); }
.bubble { font-size: 13px; line-height: 1.55; color: var(--text-primary); background: var(--bg-surface); border-radius: var(--radius-md); border-top-left-radius: 3px; padding: 9px var(--space-3); white-space: pre-wrap; word-break: break-word; }
.cmt-actions { display: flex; gap: 14px; margin-top: 6px; padding-left: 2px; }
.cmt-actions a { font-size: 11px; color: var(--text-tertiary); cursor: pointer; }
.cmt-actions a:hover { color: var(--text-secondary); }
.mention { color: var(--accent); background: var(--accent-tint); border-radius: var(--radius-sm); padding: 0 4px; font-weight: 500; white-space: nowrap; }
.replies { margin-top: var(--space-3); padding-left: 34px; display: flex; flex-direction: column; gap: var(--space-3); position: relative; }
.replies::before { content: ''; position: absolute; left: 10px; top: 2px; bottom: 8px; width: 1.5px; background: var(--border-subtle); border-radius: 2px; }
.reply-add { display: flex; align-items: center; gap: 7px; margin-top: 8px; padding-left: 34px; font-size: 11.5px; color: var(--text-tertiary); cursor: pointer; }
.reply-add:hover { color: var(--text-secondary); }

/* labels */
.label-chip { display: inline-flex; align-items: center; gap: 5px; height: 20px; padding: 0 8px; border-radius: var(--radius-sm); font-size: 11px; font-weight: 600; letter-spacing: 0.2px; line-height: 1; }
.label-chip .x { width: 13px; height: 13px; display: grid; place-items: center; border-radius: 3px; cursor: pointer; opacity: 0.55; }
.label-chip .x:hover { opacity: 1; background: rgba(0,0,0,0.25); }
.label-add { display: inline-flex; align-items: center; gap: 4px; height: 20px; padding: 0 8px; border-radius: var(--radius-sm); border: 1px dashed var(--border-strong); color: var(--text-tertiary); font-size: 11px; font-weight: 500; cursor: pointer; background: transparent; }
.label-add:hover { color: var(--text-secondary); border-color: var(--text-tertiary); }
.chip-set { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.manage-pop { position: absolute; z-index: 60; width: 280px; background: var(--bg-elevated); border: 1px solid var(--border-default); border-radius: var(--radius-md); box-shadow: var(--elev-3); padding: var(--space-3); }
.manage-pop .mp-title { font-size: 11px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase; color: var(--text-tertiary); margin-bottom: 10px; }
.lbl-create { display: flex; flex-direction: column; gap: 10px; padding-bottom: 12px; margin-bottom: 12px; border-bottom: 1px solid var(--border-subtle); }
.field-input { background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-md); height: 34px; padding: 0 10px; font-family: inherit; font-size: 13px; color: var(--text-primary); width: 100%; }
.field-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong); }
.swatch-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; }
.swatch { width: 24px; height: 24px; border-radius: var(--radius-sm); cursor: pointer; position: relative; transition: transform var(--dur-fast) var(--ease-out); }
.swatch:hover { transform: scale(1.12); }
.swatch.sel::after { content: ''; position: absolute; inset: -3px; border-radius: 6px; border: 2px solid var(--text-primary); }
.lbl-list-row { display: flex; align-items: center; gap: 9px; height: 32px; padding: 0 6px; margin: 0 -6px; border-radius: var(--radius-md); cursor: pointer; }
.lbl-list-row:hover { background: var(--bg-surface); }
.lbl-list-row .dot6 { width: 10px; height: 10px; border-radius: 3px; flex: none; }
.lbl-list-row .lname { font-size: 12.5px; color: var(--text-primary); flex: 1; }

/* dependencies */
.dep-group + .dep-group { margin-top: var(--space-4); }
.dep-glabel { font-size: 11px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; display: flex; align-items: center; gap: 7px; }
.dep-row { display: flex; align-items: center; gap: var(--space-3); min-height: 36px; padding: var(--space-1) var(--space-2); margin: 0 calc(-1 * var(--space-2)); border-radius: var(--radius-md); cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.dep-row:hover { background: var(--bg-surface); }
.dep-row:hover .dep-unlink { opacity: 1; }
.dep-row .sdot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.dep-row .dtext { font-size: 13px; color: var(--text-primary); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dep-row .dstatus { font-family: var(--font-mono); font-size: 10px; padding: 2px 7px; border-radius: var(--radius-sm); flex: none; }
.dep-row .dep-unlink { opacity: 0; color: var(--text-tertiary); transition: opacity var(--dur-fast); display: flex; background: none; border: none; cursor: pointer; }
.dep-add { display: flex; align-items: center; gap: var(--space-2); min-height: 34px; color: var(--text-tertiary); font-size: 12.5px; cursor: pointer; }
.dep-add:hover { color: var(--text-secondary); }
.sdot.done { background: var(--success); } .sdot.doing { background: var(--accent); } .sdot.todo { background: var(--text-tertiary); }
.dstatus.done { background: var(--success-tint); color: var(--success); } .dstatus.doing { background: var(--accent-tint); color: var(--accent); } .dstatus.todo { background: var(--bg-pressed); color: var(--text-tertiary); }

/* card blocked badge + label chips on card */
.blocked-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: var(--radius-sm); background: var(--danger-tint); color: var(--danger); }
.blocked-badge svg { width: 11px; height: 11px; }
.card .chip-set { margin-top: 2px; }

/* custom fields manage */
.type-chip { font-family: var(--font-mono); font-size: 10px; padding: 2px 6px; border-radius: var(--radius-sm); background: var(--bg-pressed); color: var(--text-tertiary); }
.cf-mrow { display: flex; align-items: center; gap: var(--space-3); height: 42px; padding: 0 var(--space-2); margin: 0 calc(-1 * var(--space-2)); border-radius: var(--radius-md); }
.cf-mrow:hover { background: var(--bg-surface); }
.cf-mrow .cf-name { font-size: 13px; color: var(--text-primary); flex: 1; }
.cf-mrow .cf-rm { color: var(--text-tertiary); cursor: pointer; background: none; border: none; }
.cf-addform { margin-top: 14px; padding-top: 16px; border-top: 1px solid var(--border-subtle); display: flex; flex-direction: column; gap: 10px; }
.cf-formrow { display: flex; gap: 8px; }

/* attachments */
.dropzone { border: 1.5px dashed var(--border-strong); border-radius: var(--radius-md); min-height: 70px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; color: var(--text-tertiary); cursor: pointer; transition: border-color var(--dur-fast), background var(--dur-fast); }
.dropzone:hover { border-color: var(--accent); background: var(--accent-tint); color: var(--accent); }
.dropzone svg { width: 22px; height: 22px; }
.dropzone .dz-main { font-size: 12.5px; font-weight: 500; }
.file-row { display: flex; align-items: center; gap: var(--space-3); height: 48px; padding: 0 var(--space-2); margin: 0 calc(-1 * var(--space-2)); border-radius: var(--radius-md); }
.file-row:hover { background: var(--bg-surface); }
.file-row:hover .file-rm { opacity: 1; }
.file-ico { width: 36px; height: 36px; border-radius: var(--radius-md); display: grid; place-items: center; flex: none; background: var(--accent-tint); color: var(--accent); }
.file-ico svg { width: 17px; height: 17px; }
.file-meta { flex: 1; min-width: 0; }
.file-name { font-size: 13px; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-sub { font-family: var(--font-mono); font-size: 10px; color: var(--text-tertiary); margin-top: 1px; }
.file-rm { opacity: 0; color: var(--text-tertiary); cursor: pointer; background: none; border: none; }
.file-rm:hover { color: var(--danger); }

/* rule engine */
.rule-card { background: var(--bg-surface); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: 14px 16px; display: flex; align-items: flex-start; gap: 12px; }
.rule-card + .rule-card { margin-top: 10px; }
.toggle { width: 34px; height: 20px; border-radius: var(--radius-full); background: var(--bg-pressed); position: relative; cursor: pointer; flex: none; margin-top: 2px; transition: background var(--dur-normal) var(--ease-out); }
.toggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--text-secondary); transition: transform var(--dur-normal) var(--ease-out), background var(--dur-normal); }
.toggle.on { background: var(--accent); }
.toggle.on::after { transform: translateX(14px); background: #fff; }
.rule-body { flex: 1; min-width: 0; }
.rule-summary { font-size: 13px; line-height: 1.6; color: var(--text-secondary); }
.rule-summary .kw { font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: 0.5px; color: var(--text-tertiary); }
.rule-summary .val { color: var(--text-primary); font-weight: 500; }
.builder { background: var(--bg-base); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 16px; margin-top: 14px; }
.builder-line { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.builder-line + .builder-line { margin-top: 12px; }
.bkw { font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: 0.5px; color: var(--text-tertiary); width: 50px; flex: none; }
.bconn { font-size: 12.5px; color: var(--text-tertiary); }

/* command palette */
.cmdk-scrim { position: fixed; inset: 0; background: var(--bg-overlay); z-index: 80; }
.palette { position: fixed; top: 96px; left: 50%; transform: translateX(-50%); width: 640px; max-width: calc(100vw - 48px); background: var(--bg-elevated); border: 1px solid var(--border-default); border-radius: var(--radius-lg); box-shadow: var(--elev-3); overflow: hidden; z-index: 81; animation: palpop var(--dur-normal) var(--ease-out); }
@keyframes palpop { from { transform: translateX(-50%) scale(0.97); opacity: 0; } to { transform: translateX(-50%) scale(1); opacity: 1; } }
.pal-search { display: flex; align-items: center; gap: 12px; height: 52px; padding: 0 18px; border-bottom: 1px solid var(--border-subtle); }
.pal-search > svg { width: 18px; height: 18px; color: var(--text-tertiary); flex: none; }
.pal-search input { flex: 1; background: transparent; border: none; color: var(--text-primary); font-family: inherit; font-size: 15px; }
.pal-search input:focus { outline: none; }
.pal-results { max-height: 360px; overflow-y: auto; padding: 6px; }
.pal-group { font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text-tertiary); height: 28px; display: flex; align-items: center; padding: 0 12px; }
.pal-row { display: flex; align-items: center; gap: 12px; height: 44px; padding: 0 12px; border-radius: var(--radius-md); cursor: pointer; border-left: 2px solid transparent; }
.pal-row:hover, .pal-row.sel { background: var(--accent-tint); border-left-color: var(--accent); }
.pal-ico { width: 18px; height: 18px; color: var(--text-secondary); flex: none; display: grid; place-items: center; }
.pal-label { font-size: 13px; color: var(--text-primary); flex: none; }
.pal-ctx { font-size: 12px; color: var(--text-tertiary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* share / permissions */
.share-add { display: flex; gap: 8px; margin-bottom: 18px; }
.share-add .field-input { flex: 1; }
.member-row { display: flex; align-items: center; gap: 12px; height: 52px; }
.member-row .m-meta { flex: 1; min-width: 0; }
.member-row .m-name { font-size: 13px; color: var(--text-primary); }
.member-row .m-mail { font-family: var(--font-mono); font-size: 10px; color: var(--text-tertiary); margin-top: 1px; }
.access-locked { font-size: 12px; color: var(--text-tertiary); padding: 0 10px; flex: none; }

/* =====================================================================
   PROJECT-ROW MENU + ADD-LIST / COLUMN-HEADER MENU  (Noa spec)
   ===================================================================== */
/* shared popover menu DNA */
.popover { background: var(--bg-elevated); border: 1px solid var(--border-default); border-radius: var(--radius-md); box-shadow: var(--elev-3); padding: 4px; min-width: 180px; }
.pop-fixed { position: fixed; z-index: 60; animation: popIn var(--dur-fast) var(--ease-out); }
.pop-item { display: flex; align-items: center; gap: 10px; height: 34px; padding: 0 10px; border-radius: var(--radius-sm); font-size: 12px; color: var(--text-secondary); cursor: pointer; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.pop-item:hover { background: var(--bg-surface); color: var(--text-primary); }
.pop-item svg { width: 15px; height: 15px; flex: none; color: var(--text-tertiary); }
.pop-item:hover svg { color: var(--text-secondary); }
.pop-item.danger { color: var(--danger); }
.pop-item.danger svg { color: var(--danger); opacity: 0.85; }
.pop-item.danger:hover { background: var(--danger-tint); color: var(--danger); }
.pop-item.danger:hover svg { opacity: 1; }
.pop-divider { height: 1px; background: var(--border-subtle); margin: 4px 0; }
.pop-scrim { position: fixed; inset: 0; z-index: 59; background: transparent; }
@keyframes popIn { from { opacity: 0; transform: translateY(-4px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

/* sidebar project row: ⋯ trigger + inline rename + inline archive confirm */
.nav-item .pname { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-more { flex: none; width: 24px; height: 24px; margin-right: -4px; border: none; background: transparent; color: var(--text-tertiary); border-radius: var(--radius-sm); display: grid; place-items: center; cursor: pointer; opacity: 0; transition: opacity var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.nav-more svg { width: 16px; height: 16px; }
.nav-item:hover .nav-more, .nav-item.menu-open .nav-more { opacity: 1; }
.nav-item:hover .count.has-more { opacity: 0; width: 0; margin: 0; overflow: hidden; }
.nav-more:hover { background: var(--bg-pressed); color: var(--text-primary); }
.nav-item.menu-open { background: var(--bg-surface); color: var(--text-primary); }
.nav-item.menu-open .nav-more { background: var(--bg-pressed); color: var(--text-primary); }
.nav-rename { flex: 1; min-width: 0; height: 24px; background: var(--bg-input); border: 1px solid var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong); border-radius: var(--radius-sm); padding: 0 6px; font-family: inherit; font-size: 13px; font-weight: 500; color: var(--text-primary); outline: none; }
.nav-item.renaming, .nav-item.confirming { background: var(--bg-surface); }
.nav-confirm { flex: 1; display: flex; align-items: center; gap: var(--space-2); min-width: 0; }
.nav-confirm .q { flex: 1; min-width: 0; font-size: 12px; color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cbtn { flex: none; height: 24px; padding: 0 10px; border-radius: var(--radius-sm); font-family: inherit; font-size: 11px; font-weight: 600; cursor: pointer; border: 1px solid var(--border-default); background: transparent; color: var(--text-secondary); transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.cbtn.confirm { background: var(--danger-tint); border-color: transparent; color: var(--danger); }
.cbtn.confirm:hover { background: var(--danger); color: #fff; }
.cbtn.cancel:hover { background: var(--bg-elevated); color: var(--text-primary); border-color: var(--border-strong); }

/* column-head: ⋯ trigger + inline rename + WIP count */
.col-more { flex: none; width: 24px; height: 24px; margin-left: 2px; border: none; background: transparent; color: var(--text-tertiary); border-radius: var(--radius-sm); display: grid; place-items: center; cursor: pointer; opacity: 0; transition: opacity var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.col-more svg { width: 16px; height: 16px; }
.column-head:hover .col-more, .column-head.menu-open .col-more { opacity: 1; }
.col-more:hover { background: var(--bg-pressed); color: var(--text-primary); }
.column-head.menu-open .col-more { background: var(--bg-pressed); color: var(--text-primary); }
.column-head .count .lim { color: var(--text-tertiary); }
.column-head .count.over { color: var(--warning); }
.col-rename { flex: 1; min-width: 0; height: 26px; background: var(--bg-input); border: 1px solid var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong); border-radius: var(--radius-sm); padding: 0 7px; font-family: inherit; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-primary); outline: none; }

/* add-list affordance */
.add-list-rest { width: 280px; flex: none; min-height: 44px; align-self: flex-start; border: 1px dashed var(--border-default); border-radius: var(--radius-lg); background: transparent; color: var(--text-tertiary); display: flex; align-items: center; gap: var(--space-2); padding: 0 var(--space-4); font-size: 13px; cursor: pointer; transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out); }
.add-list-rest svg { width: 15px; height: 15px; }
.add-list-rest:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-tint); }
.add-list-active { width: 280px; flex: none; align-self: flex-start; background: var(--bg-base); border: 1px solid var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong), var(--elev-2); border-radius: var(--radius-lg); padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-3); }
.add-list-active .nameinput { width: 100%; height: 36px; background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 0 var(--space-3); font-family: inherit; font-size: 13px; color: var(--text-primary); outline: none; transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out); }
.add-list-active .nameinput::placeholder { color: var(--text-tertiary); }
.add-list-active .nameinput:focus { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong); }
.kind-pick { display: flex; gap: var(--space-1); }
.kind-opt { flex: 1; height: 32px; border-radius: var(--radius-md); border: 1px solid var(--border-default); background: transparent; display: flex; align-items: center; justify-content: center; gap: 6px; font-family: inherit; font-size: 11px; font-weight: 500; color: var(--text-secondary); cursor: pointer; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.kind-opt .kd { width: 6px; height: 6px; border-radius: var(--radius-full); flex: none; }
.kind-opt .kd.todo { background: var(--text-tertiary); }
.kind-opt .kd.doing { background: var(--accent); }
.kind-opt .kd.done { background: var(--success); }
.kind-opt:hover { background: var(--bg-surface); color: var(--text-primary); }
.kind-opt.sel { background: var(--accent-tint); border-color: var(--accent); color: var(--text-primary); }
.add-list-actions { display: flex; align-items: center; gap: var(--space-2); }

/* WIP-limit stepper (no native spinner) */
.wip-pop { min-width: 232px; padding: var(--space-3); }
.wip-pop .wl { font-size: 11px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase; color: var(--text-tertiary); margin-bottom: 10px; }
.stepper { display: flex; align-items: center; gap: var(--space-2); }
.stepper .sbtn { width: 32px; height: 32px; flex: none; border-radius: var(--radius-md); border: 1px solid var(--border-default); background: var(--bg-input); color: var(--text-secondary); display: grid; place-items: center; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.stepper .sbtn svg { width: 14px; height: 14px; }
.stepper .sbtn:hover { background: var(--bg-elevated); color: var(--text-primary); border-color: var(--border-strong); }
.stepper .sbtn:disabled { opacity: 0.35; cursor: not-allowed; }
.stepper .sval { flex: 1; height: 32px; background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 13px; color: var(--text-primary); }
.stepper .sval.off { color: var(--text-tertiary); }
.wip-pop .wnote { font-size: 11px; color: var(--text-tertiary); margin-top: 10px; line-height: 1.5; }
.wip-pop .wactions { display: flex; gap: var(--space-2); margin-top: 12px; }
.wip-pop .wactions .btn { flex: 1; justify-content: center; }

/* =====================================================================
   CUSTOM DROPDOWN / SELECT  (Noa spec — replaces native <select>)
   ===================================================================== */
.dd { position: relative; display: inline-flex; max-width: 100%; }
.dd.full { display: flex; width: 100%; }
.dd-trigger { display: inline-flex; align-items: center; gap: var(--space-2); height: 28px; padding: 0 8px; border-radius: var(--radius-md); background: transparent; border: 1px solid transparent; cursor: pointer; font-family: inherit; font-size: 13px; color: var(--text-primary); max-width: 100%; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out); }
.dd-trigger:hover { background: var(--bg-surface); border-color: var(--border-subtle); }
.dd-trigger:focus-visible { outline: none; background: var(--bg-surface); box-shadow: 0 0 0 2px var(--accent); }
.dd-trigger .chev { width: 14px; height: 14px; color: var(--text-tertiary); flex-shrink: 0; margin-left: 2px; transition: transform var(--dur-fast) var(--ease-out); }
.dd.open > .dd-trigger { background: var(--bg-elevated); border-color: var(--border-strong); }
.dd.open > .dd-trigger .chev { transform: rotate(180deg); }
.dd-trigger.boxed { height: 34px; width: 100%; justify-content: space-between; background: var(--bg-input); border-color: var(--border-default); padding: 0 var(--space-3); }
.dd-trigger.boxed:hover { background: var(--bg-input); border-color: var(--border-strong); }
.dd-trigger.boxed .chev { margin-left: 0; }
.dd-trigger .tlabel { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dd-trigger .val-empty { color: var(--text-tertiary); }

/* the shared floating menu (fixed-positioned by JS so it never clips) */
.dd-menu { position: fixed; z-index: 62; min-width: 200px; max-width: 320px; background: var(--bg-elevated); border: 1px solid var(--border-default); border-radius: var(--radius-md); box-shadow: var(--elev-3); padding: 4px; transform-origin: top left; animation: popIn var(--dur-fast) var(--ease-out); }
.dd-search { display: flex; align-items: center; gap: var(--space-2); height: 32px; margin: 2px; padding: 0 var(--space-2); background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-sm); }
.dd-search svg { width: 14px; height: 14px; color: var(--text-tertiary); flex-shrink: 0; }
.dd-search input { flex: 1; background: transparent; border: none; outline: none; font-family: inherit; font-size: 12.5px; color: var(--text-primary); }
.dd-search input::placeholder { color: var(--text-tertiary); }
.dd-scroll { max-height: 280px; overflow-y: auto; overscroll-behavior: contain; }
.dd-scroll::-webkit-scrollbar { width: 8px; }
.dd-scroll::-webkit-scrollbar-thumb { background: var(--bg-pressed); border-radius: 4px; border: 2px solid var(--bg-elevated); }
.opt { display: flex; align-items: center; gap: var(--space-2); height: 32px; padding: 0 var(--space-2); border-radius: var(--radius-sm); cursor: pointer; color: var(--text-secondary); font-size: 13px; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); position: relative; }
.opt:hover, .opt.cursor { background: var(--bg-surface); color: var(--text-primary); }
.opt.cursor::before { content: ''; position: absolute; left: 0; top: 4px; bottom: 4px; width: 2px; border-radius: 2px; background: var(--accent); }
.opt.selected { color: var(--text-primary); }
.opt .opt-check { margin-left: auto; width: 15px; height: 15px; color: var(--accent); flex-shrink: 0; opacity: 0; }
.opt.selected .opt-check { opacity: 1; }
.opt .dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.opt .nm { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dd-noresult { padding: 14px var(--space-2); text-align: center; font-size: 12px; color: var(--text-tertiary); }
/* option leading pill/tag reuse app's pri/cat colors via .pri-*/.cat-* on these */
.opt .opt-pill { display: inline-flex; align-items: center; height: 20px; padding: 0 9px; border-radius: var(--radius-full); font-size: 11.5px; font-weight: 500; }
.opt .opt-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 600; letter-spacing: 0.3px; padding: 2px 7px; border-radius: var(--radius-sm); }
.dd-scrim { position: fixed; inset: 0; z-index: 61; background: transparent; }

/* =====================================================================
   QUICK TIMER  ·  global top-bar widget + card start/pause  (Noa spec)
   ===================================================================== */
.tw { display: inline-flex; align-items: center; gap: var(--space-2); height: 32px; padding: 0 6px 0 10px; border-radius: var(--radius-full); background: var(--success-tint); border: 1px solid transparent; cursor: pointer; max-width: 248px; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.tw:hover { background: rgba(46,190,126,0.18); }
.tw.open { background: rgba(46,190,126,0.18); border-color: rgba(46,190,126,0.30); }
.tw .pulse { width: 7px; height: 7px; border-radius: var(--radius-full); background: var(--timer-running); box-shadow: 0 0 0 0 rgba(46,190,126,0.5); animation: pulse 1600ms var(--ease-out) infinite; flex: none; }
.tw .tw-time { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--timer-running); flex: none; letter-spacing: 0.2px; }
.tw .tw-sep { width: 1px; height: 14px; background: rgba(46,190,126,0.28); flex: none; }
.tw .tw-title { font-size: 12px; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.tw .tw-pause { width: 26px; height: 26px; flex: none; border: none; background: transparent; color: var(--timer-running); border-radius: var(--radius-full); display: grid; place-items: center; cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.tw .tw-pause:hover { background: rgba(46,190,126,0.22); }
.tw .tw-pause svg { width: 13px; height: 13px; }
.tw.warn { background: var(--warning-tint); }
.tw.warn .pulse { background: var(--timer-warn); box-shadow: 0 0 0 0 rgba(240,180,41,0.5); }
.tw.warn .tw-time, .tw.warn .tw-pause { color: var(--timer-warn); }
.tw.warn .tw-sep { background: rgba(240,180,41,0.28); }
.tw.over { background: var(--danger-tint); }
.tw.over .pulse { background: var(--timer-over); box-shadow: 0 0 0 0 rgba(224,85,107,0.5); }
.tw.over .tw-time, .tw.over .tw-pause { color: var(--timer-over); }
.tw.over .tw-sep { background: rgba(224,85,107,0.28); }
/* pull-down popover (reuses .popover + .pop-fixed) */
.tw-pop { min-width: 300px; padding: var(--space-3); }
.tw-pop .tp-kicker { display: flex; align-items: center; gap: 7px; font-size: 10px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase; color: var(--timer-running); margin-bottom: 10px; }
.tw-pop .tp-kicker .pulse { width: 6px; height: 6px; border-radius: var(--radius-full); background: var(--timer-running); box-shadow: 0 0 0 0 rgba(46,190,126,0.5); animation: pulse 1600ms var(--ease-out) infinite; }
.tw-pop .tp-title { font-size: 13px; font-weight: 500; color: var(--text-primary); line-height: 1.4; margin-bottom: 2px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tw-pop .tp-crumb { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-tertiary); margin-bottom: 14px; }
.tw-pop .tp-crumb .cdot { width: 6px; height: 6px; border-radius: var(--radius-full); flex: none; }
.tw-pop .tp-time { font-family: var(--font-mono); font-size: 30px; font-weight: 500; letter-spacing: -0.5px; color: var(--timer-running); line-height: 1; margin-bottom: 4px; }
.tw-pop.warn .tp-time, .tw-pop.warn .tp-kicker { color: var(--timer-warn); }
.tw-pop.over .tp-time, .tw-pop.over .tp-kicker { color: var(--timer-over); }
.tp-budget { height: 6px; border-radius: 3px; background: var(--bg-pressed); overflow: hidden; margin-bottom: 6px; }
.tp-budget > i { display: block; height: 100%; border-radius: 3px; background: var(--timer-running); }
.tp-budget > i.warn { background: var(--timer-warn); }
.tp-budget > i.over { background: var(--timer-over); }
.tp-budget-meta { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; color: var(--text-tertiary); margin: 0 0 14px; }
.tp-actions { display: flex; gap: var(--space-2); }
.tp-btn { flex: 1; height: 36px; border-radius: var(--radius-md); border: 1px solid var(--border-default); background: transparent; color: var(--text-primary); font-family: inherit; font-size: 12px; font-weight: 500; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 7px; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.tp-btn svg { width: 14px; height: 14px; }
.tp-btn.pause { background: var(--success-tint); border-color: transparent; color: var(--timer-running); }
.tp-btn.pause:hover { background: rgba(46,190,126,0.20); }
.tp-open { display: flex; align-items: center; justify-content: center; gap: 6px; height: 32px; margin-top: 10px; border-radius: var(--radius-md); color: var(--text-tertiary); font-size: 11px; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.tp-open:hover { background: var(--bg-surface); color: var(--text-secondary); }
.tp-open svg { width: 13px; height: 13px; }

/* card quick start/pause button */
.qt { width: 26px; height: 26px; flex: none; border-radius: var(--radius-full); border: 1px solid var(--border-default); background: transparent; color: var(--text-secondary); display: grid; place-items: center; cursor: pointer; opacity: 0; margin-left: auto; transition: opacity var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.qt svg { width: 12px; height: 12px; }
.card:hover .qt { opacity: 1; }
.qt:hover { border-color: var(--accent); color: var(--text-primary); background: var(--accent-tint); }
.card.running .qt { opacity: 1; margin-left: auto; background: var(--success-tint); border-color: transparent; color: var(--timer-running); }
.card.running .qt:hover { background: rgba(46,190,126,0.20); }
/* qt is the last child + sole margin-left:auto → the whole right cluster aligns cleanly */
.card-foot:has(.qt) .timer, .card-foot:has(.qt) .budget { margin-left: var(--space-2); }

/* inline card expansion — checklist / subtask preview (click the count chip) */
.metachip.ce-toggle { cursor: pointer; }
.metachip.ce-toggle:hover { color: var(--text-secondary); }
.ce-chev { width: 11px; height: 11px; margin-left: 1px; transition: transform var(--dur-fast) var(--ease-out); }
.ce-chev.open { transform: rotate(180deg); }
.card-expand { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border-subtle); display: flex; flex-direction: column; gap: 2px; }
.ce-group-label { font-size: 10px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-tertiary); margin: 4px 0 2px; }
.ce-row { display: flex; align-items: center; gap: 8px; padding: 4px; margin: 0 -4px; border-radius: var(--radius-sm); cursor: pointer; font-size: 12.5px; color: var(--text-secondary); transition: background var(--dur-fast) var(--ease-out); }
.ce-row:hover { background: var(--bg-elevated); }
.ce-box { width: 15px; height: 15px; flex: none; border: 1.5px solid var(--border-strong); border-radius: 4px; display: grid; place-items: center; color: transparent; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.ce-row.done .ce-box { background: var(--accent); border-color: var(--accent); color: #fff; }
.ce-box svg { width: 11px; height: 11px; }
.ce-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.ce-row.done .ce-text { text-decoration: line-through; color: var(--text-tertiary); }
.ce-row .ce-arrow { margin-left: auto; width: 13px; height: 13px; color: var(--text-tertiary); flex: none; }

/* =====================================================================
   INVITE A TEAMMATE  (Noa spec) — modal (owner) + accept screen (invitee)
   ===================================================================== */
/* role picker — 2-option segmented */
.role-seg { display: flex; gap: 6px; background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 4px; }
.role-opt { flex: 1; display: flex; flex-direction: column; align-items: flex-start; gap: 2px; height: 44px; justify-content: center; padding: 0 12px; border-radius: var(--radius-sm); cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.role-opt:hover { background: var(--bg-surface); }
.role-opt .ro-name { font-size: 12.5px; font-weight: 500; color: var(--text-secondary); }
.role-opt .ro-desc { font-size: 10px; color: var(--text-tertiary); }
.role-opt.sel { background: var(--accent-tint); }
.role-opt.sel .ro-name { color: var(--accent); }
.role-opt.sel .ro-desc { color: var(--accent); opacity: 0.8; }
/* created state */
.invite-created-banner { display: flex; align-items: center; gap: var(--space-2); background: var(--success-tint); border: 1px solid rgba(46,190,126,0.28); border-radius: var(--radius-md); padding: 9px var(--space-3); font-size: 12px; color: var(--success); margin-bottom: var(--space-4); }
.invite-created-banner svg { width: 15px; height: 15px; flex-shrink: 0; }
.link-field { position: relative; display: flex; align-items: center; }
.link-field input { width: 100%; height: 40px; background: var(--bg-input); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 0 84px 0 12px; font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); text-overflow: ellipsis; }
.link-field input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-tint-strong); }
.copy-btn { position: absolute; right: 5px; height: 30px; padding: 0 11px; display: inline-flex; align-items: center; gap: 6px; border-radius: var(--radius-sm); border: none; background: transparent; color: var(--accent); font-family: inherit; font-size: 12px; font-weight: 500; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.copy-btn::before { content: ''; position: absolute; left: 0; top: 6px; bottom: 6px; width: 1px; background: var(--border-subtle); }
.copy-btn:hover { background: var(--accent-tint); }
.copy-btn svg { width: 14px; height: 14px; }
.copy-btn.copied { color: var(--success); }
.copy-btn.copied:hover { background: var(--success-tint); }
.expiry-hint { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-tertiary); margin-top: 8px; }
.expiry-hint svg { width: 13px; height: 13px; flex-shrink: 0; }
.role-recap { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-secondary); }
.role-recap .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.created-actions { display: flex; align-items: center; gap: var(--space-2); margin-top: var(--space-6); }
.created-actions .spacer { flex: 1; }
/* pending invites */
.pending-section { margin-top: var(--space-6); padding-top: var(--space-6); border-top: 1px solid var(--border-subtle); }
.pending-label { font-size: 10px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-2); display: flex; align-items: center; gap: 8px; }
.pending-label .cnt { font-family: var(--font-mono); font-size: 10px; color: var(--text-tertiary); letter-spacing: 0; }
.member-row:hover .revoke { opacity: 1; }
.member-row .m-name { display: flex; align-items: center; gap: 7px; }
.role-tag { font-family: var(--font-mono); font-size: 9px; font-weight: 500; letter-spacing: 0.4px; text-transform: uppercase; color: var(--text-tertiary); background: var(--bg-pressed); padding: 1px 6px; border-radius: var(--radius-sm); }
.m-status { font-size: 11px; color: var(--text-tertiary); flex-shrink: 0; display: flex; align-items: center; gap: 5px; }
.m-status.copied { color: var(--success); }
.m-status svg { width: 12px; height: 12px; }
.revoke { width: 28px; height: 28px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; border: none; background: transparent; color: var(--text-tertiary); cursor: pointer; opacity: 0; transition: opacity var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out); flex-shrink: 0; }
.revoke:hover { color: var(--danger); background: var(--danger-tint); }
.revoke svg { width: 15px; height: 15px; }
.pending-empty { padding: 20px 8px; text-align: center; font-size: 12px; color: var(--text-tertiary); }
.av.pending { background: var(--bg-pressed); color: var(--text-tertiary); }
/* accept-invite screen */
.invite-kicker { text-align: center; margin-bottom: var(--space-6); }
.invite-kicker .kick { font-size: 11px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.invite-kicker .org { font-size: 17px; font-weight: 600; letter-spacing: -0.2px; color: var(--text-primary); }
.invite-kicker .org-line { display: inline-flex; align-items: center; gap: 8px; justify-content: center; margin-bottom: 6px; }
.invite-kicker .as { font-size: 12px; color: var(--text-tertiary); margin-bottom: var(--space-4); }
.invite-kicker .as b { color: var(--text-secondary); font-weight: 600; }
.invited-email { display: inline-flex; align-items: center; gap: 8px; height: 32px; padding: 0 12px; border-radius: var(--radius-full); background: var(--bg-input); border: 1px solid var(--border-subtle); font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); }
.invited-email svg { width: 14px; height: 14px; color: var(--text-tertiary); flex-shrink: 0; }
.org-mark { width: 28px; height: 28px; border-radius: var(--radius-md); background: var(--accent-tint); border: 1px solid var(--accent-tint-strong); display: inline-flex; align-items: center; justify-content: center; }
.org-mark svg { width: 16px; height: 16px; }
.invite-error { text-align: center; }
.invite-error .err-tile { width: 52px; height: 52px; border-radius: var(--radius-lg); background: var(--danger-tint); border: 1px solid rgba(224,85,107,0.28); display: inline-flex; align-items: center; justify-content: center; color: var(--danger); margin-bottom: var(--space-4); }
.invite-error .err-tile svg { width: 24px; height: 24px; }
.invite-error h2 { font-size: 17px; font-weight: 600; letter-spacing: -0.2px; color: var(--text-primary); margin-bottom: 6px; }
.invite-error p { font-size: 12.5px; color: var(--text-secondary); line-height: 1.55; margin-bottom: var(--space-6); }
.invite-error .btn { width: 100%; }
