/* FlowTask UI. Mobile-first. */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  line-height: 1.5;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Buttons ─────────────────────────────────────── */
button, .ft-btn {
  appearance: none;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  padding: .5rem .9rem;
  border-radius: var(--radius);
  font: inherit;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--motion-fast), border-color var(--motion-fast),
              color var(--motion-fast), box-shadow var(--motion-fast), transform var(--motion-fast);
  white-space: nowrap;
  line-height: 1.2;
  user-select: none;
}
button:hover, .ft-btn:hover { background: var(--surface-hover); border-color: var(--border-strong); }
button:active, .ft-btn:active { transform: translateY(1px); }
button:focus-visible, .ft-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--focus-ring);
  border-color: var(--focus);
}
button:disabled, .ft-btn:disabled { opacity: .55; cursor: not-allowed; }

.ft-btn-primary { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.ft-btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.ft-btn-primary:active { background: var(--accent-active); }

.ft-btn-danger { background: var(--danger); color: #fff; border-color: var(--danger); }
.ft-btn-danger:hover { filter: brightness(.94); }

.ft-btn-ghost { background: transparent; border-color: transparent; color: var(--text-muted); }
.ft-btn-ghost:hover { background: var(--surface-2); color: var(--text); border-color: transparent; }

.ft-btn-sm { padding: .3rem .6rem; font-size: .85rem; border-radius: var(--radius-sm); }
.ft-btn-icon {
  padding: .35rem; width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-muted);
}
.ft-btn-icon:hover { background: var(--surface-2); color: var(--text); }

/* ── Inputs ──────────────────────────────────────── */
.ft-input,
.ft-form input, .ft-form select, .ft-form textarea {
  width: 100%;
  padding: .55rem .7rem;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: var(--radius);
  font: inherit;
  transition: border-color var(--motion-fast), box-shadow var(--motion-fast);
}
.ft-input:hover { border-color: var(--border-strong); }
.ft-input:focus,
.ft-form input:focus, .ft-form select:focus, .ft-form textarea:focus {
  outline: none;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}
.ft-input::placeholder { color: var(--text-subtle); }

/* ── Toasts ─────────────────────────────────────── */
.ft-toasts {
  position: fixed;
  bottom: var(--space-4);
  right: var(--space-4);
  display: flex;
  flex-direction: column-reverse;
  gap: var(--space-2);
  z-index: 1000;
  pointer-events: none;
  max-width: min(420px, calc(100vw - 2rem));
}
.ft-toast {
  pointer-events: auto;
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: .75rem .9rem;
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: .9rem;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--motion), transform var(--motion);
}
.ft-toast.is-open { opacity: 1; transform: none; }
.ft-toast-body  { flex: 1; min-width: 0; word-wrap: break-word; }
.ft-toast-actions { display: flex; gap: .35rem; align-items: center; }
.ft-toast-btn {
  padding: .25rem .6rem; font-size: .8rem;
  background: transparent; border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
}
.ft-toast-close {
  padding: 0; width: 22px; height: 22px; font-size: 1.1rem; line-height: 1;
  border: 0; background: transparent; color: var(--text-subtle); cursor: pointer;
}
.ft-toast-close:hover { color: var(--text); }
.ft-toast-success { border-left-color: var(--success); }
.ft-toast-warn    { border-left-color: var(--warn); }
.ft-toast-error   { border-left-color: var(--danger); }
.ft-toast-info    { border-left-color: var(--info); }

/* ── Confirm modal ──────────────────────────────── */
.ft-confirm-overlay {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, .55);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
  z-index: 1100;
  opacity: 0;
  transition: opacity var(--motion);
}
.ft-confirm-overlay.is-open { opacity: 1; }
.ft-confirm {
  width: min(420px, 100%);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 1.25rem 1.5rem 1rem;
  transform: translateY(8px) scale(.98);
  transition: transform var(--motion);
}
.ft-confirm-overlay.is-open .ft-confirm { transform: none; }
.ft-confirm-title { margin: 0 0 .35rem; font-size: 1.1rem; }
.ft-confirm-msg   { margin: 0 0 1.25rem; color: var(--text-muted); font-size: .95rem; }
.ft-confirm-actions { display: flex; justify-content: flex-end; gap: .5rem; }

/* Topbar */
.ft-topbar {
  display: flex; align-items: center; gap: 1rem;
  padding: .5rem 1rem;
  background: var(--surface); border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 30;
  height: var(--topbar-h);
  backdrop-filter: saturate(180%) blur(8px);
}
.ft-brand { display: inline-flex; align-items: center; gap: .55rem; color: var(--text); font-weight: 700; letter-spacing: -.01em; }
.ft-logo {
  width: 26px; height: 26px;
  background: linear-gradient(135deg, var(--accent), #FF9B4A);
  border-radius: 7px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: .75rem;
  box-shadow: 0 2px 4px rgba(255, 107, 0, .3);
}
.ft-nav { margin-left: .75rem; display: flex; gap: .25rem; }
.ft-nav a {
  color: var(--text-muted); padding: .4rem .7rem; border-radius: var(--radius-sm);
  transition: background var(--motion-fast), color var(--motion-fast);
}
.ft-nav a:hover { color: var(--text); background: var(--surface-2); text-decoration: none; }
.ft-nav a.is-active { color: var(--accent); background: var(--accent-muted); }
.ft-tools { margin-left: auto; display: flex; align-items: center; gap: .4rem; }
.ft-user { color: var(--text-muted); font-size: .88rem; }

/* Layout */
.ft-main { padding: var(--space-5); max-width: 1600px; margin: 0 auto; }

/* Board */
.ft-board-head {
  position: sticky;
  top: var(--topbar-h);
  z-index: 20;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  backdrop-filter: saturate(180%) blur(6px);
  padding: var(--space-3) 0;
  margin-bottom: var(--space-2);
}
.ft-board-head h1 { margin: 0; font-size: 1.25rem; font-weight: 600; }
.ft-board-actions { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.ft-board-actions .ft-input { width: auto; min-width: 220px; }

.ft-columns {
  display: grid; grid-auto-flow: column; grid-auto-columns: minmax(280px, 1fr);
  gap: var(--space-3); overflow-x: auto; padding-bottom: var(--space-4);
  scrollbar-gutter: stable;
}
@media (max-width: 640px) {
  .ft-columns { grid-auto-flow: row; grid-auto-columns: unset; }
}
.ft-column {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column; min-height: 30vh;
  max-height: calc(100vh - 220px);
  overflow: hidden;
}
.ft-column-head {
  display: flex; align-items: center; gap: .5rem;
  padding: .75rem .9rem;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; background: var(--surface-2); z-index: 1;
}
.ft-column-head h2 { margin: 0; font-size: .82rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-muted); font-weight: 600; }
.ft-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--col-accent, var(--accent)); }
.ft-count {
  margin-left: auto; background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px; padding: 0 .55rem; font-size: .75rem; color: var(--text-muted);
  min-width: 22px; text-align: center;
}
.ft-wip {
  font-size: .72rem; color: var(--accent);
  background: var(--accent-muted); border: 1px solid var(--accent-weak);
  padding: 0 .4rem; border-radius: 999px;
}

.ft-dropzone {
  list-style: none; margin: 0; padding: .6rem;
  display: flex; flex-direction: column; gap: .5rem;
  min-height: 8rem; overflow-y: auto; flex: 1;
}
.ft-dropzone.ft-dz-over {
  background: var(--accent-muted);
  outline: 2px dashed var(--accent); outline-offset: -6px;
}
.ft-dropzone:empty {
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  margin: .5rem;
  min-height: 6rem;
  display: flex; align-items: center; justify-content: center;
}
.ft-dropzone:empty::before {
  content: '✦  ' attr(data-empty);
  display: block; padding: .5rem 1rem; text-align: center;
  color: var(--text-subtle); font-size: .8rem; font-style: normal;
}
.ft-card {
  position: relative;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: .7rem .9rem .7rem 1rem;
  box-shadow: var(--shadow-xs);
  cursor: grab; user-select: none;
  transition: box-shadow var(--motion-fast), transform var(--motion-fast), border-color var(--motion-fast);
}
.ft-card:hover { box-shadow: var(--shadow-sm); border-color: var(--border-strong); transform: translateY(-1px); }
.ft-card:active { cursor: grabbing; }
.ft-card.ft-dragging { opacity: .45; transform: rotate(1.5deg); }
.ft-card:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--focus-ring); border-color: var(--focus); }
.ft-card-title { margin: 0 0 .25rem; font-size: .95rem; font-weight: 500; line-height: 1.35; }
.ft-card-due { color: var(--text-muted); font-size: .78rem; display: inline-flex; align-items: center; gap: .25rem; }
.ft-card-due::before { content: '📅'; font-size: .8rem; }
.ft-card-cf { list-style: none; margin: .4rem 0 0; padding: 0; font-size: .78rem; color: var(--text-muted); }
.ft-card-cf li { display: inline-block; margin-right: .5rem; }
.ft-card-cf li span { color: var(--text); font-weight: 600; }
.ft-priority-badge {
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  border-top-left-radius: var(--radius); border-bottom-left-radius: var(--radius);
}

/* Dialog (native <dialog>) */
.ft-dialog {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 0;
  background: var(--surface); color: var(--text);
  box-shadow: var(--shadow-lg);
  max-width: 540px; width: 90vw;
}
.ft-dialog::backdrop { background: rgba(15, 23, 42, .55); backdrop-filter: blur(2px); }
.ft-dialog[open] { animation: ft-dialog-in var(--motion) both; }
@keyframes ft-dialog-in {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to   { opacity: 1; transform: none; }
}
.ft-form { display: flex; flex-direction: column; gap: .85rem; padding: 1.25rem 1.5rem; }
.ft-form > header { padding-bottom: .5rem; border-bottom: 1px solid var(--border); margin-bottom: .25rem; }
.ft-form > header h3 { margin: 0; font-size: 1.05rem; }
.ft-form label {
  display: flex; flex-direction: column; gap: .3rem;
  font-size: .85rem; color: var(--text-muted); font-weight: 500;
}
.ft-form input, .ft-form select, .ft-form textarea { color: var(--text); }
.ft-form footer { display: flex; justify-content: flex-end; gap: .5rem; margin-top: .25rem; padding-top: .75rem; border-top: 1px solid var(--border); }

/* Team switcher */
.ft-team-switch { display: flex; align-items: center; gap: .5rem; }

/* Drawer (HTMX-loaded task details) */
.ft-drawer {
  position: fixed; right: 0; top: var(--topbar-h);
  width: min(1060px, 100vw);
  height: calc(100vh - var(--topbar-h));
  overflow: hidden;
  z-index: 40;
  pointer-events: none;
}
.ft-drawer:empty { display: none; }
.ft-drawer::before {
  /* Subtle backdrop dim on desktop */
  content: ''; position: fixed; inset: 0;
  background: rgba(15, 23, 42, .15);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--motion);
}
.ft-drawer:not(:empty)::before { opacity: 1; pointer-events: auto; }
.ft-drawer-panel {
  pointer-events: auto;
  background: var(--surface);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  padding: 1rem 1.25rem 1.5rem;
  height: 100%;
  overflow-y: auto;
  position: relative; z-index: 1;
  animation: ft-drawer-in var(--motion) both;
}
@keyframes ft-drawer-in {
  from { transform: translateX(16px); opacity: 0; }
  to { transform: none; opacity: 1; }
}
.ft-drawer-head {
  display: flex; align-items: center; gap: .6rem;
  margin-bottom: .75rem;
  position: sticky; top: 0;
  background: var(--surface); padding: .5rem 0;
  z-index: 2;
}
.ft-drawer-head h2 { margin: 0; flex: 1; font-size: 1.1rem; font-weight: 600; line-height: 1.3; }
.ft-drawer-head .ft-priority-badge { position: static; width: 4px; height: 1.5rem; border-radius: 2px; }
.ft-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: .5rem .75rem; margin: 0 0 1rem;
  padding: .75rem; background: var(--surface-2); border-radius: var(--radius);
}
.ft-meta div { display: flex; flex-direction: column; gap: .2rem; }
.ft-meta dt { font-size: .7rem; color: var(--text-muted); margin: 0; text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
.ft-meta dd { margin: 0; font-size: .88rem; }
.ft-meta .ft-input { padding: .3rem .45rem; font-size: .85rem; }
.ft-drawer-section { margin-bottom: 1.25rem; }
.ft-drawer-section h3 { margin: 0 0 .6rem; font-size: .95rem; font-weight: 600; }
.ft-markdown { line-height: 1.55; }
.ft-markdown p { margin: .25rem 0 .75rem; }
.ft-markdown code { background: var(--surface-2); padding: 0 .3rem; border-radius: 3px; font-size: .85em; font-family: var(--font-mono); }
.ft-markdown pre { background: var(--surface-2); padding: .75rem; border-radius: var(--radius-sm); overflow-x: auto; }
.ft-markdown blockquote { border-left: 3px solid var(--accent); margin: .5rem 0; padding: .25rem .75rem; color: var(--text-muted); }
.ft-mention { color: var(--accent); font-weight: 600; }
.ft-comments { list-style: none; padding: 0; margin: 0 0 .75rem; display: flex; flex-direction: column; gap: .6rem; }
.ft-comment {
  background: var(--surface-2); border-radius: var(--radius);
  padding: .55rem .8rem; position: relative;
  border: 1px solid transparent;
  transition: border-color var(--motion-fast);
}
.ft-comment:hover { border-color: var(--border); }
.ft-comment header { display: flex; justify-content: space-between; font-size: .78rem; margin-bottom: .3rem; }
.ft-comment.ft-pending { opacity: .65; border: 1px dashed var(--border-strong); background: var(--accent-muted); }
.ft-checklist { list-style: none; padding: 0; margin: 0; }
.ft-checklist li {
  display: flex; align-items: center; gap: .5rem; padding: .3rem .25rem;
  border-radius: var(--radius-sm);
  transition: background var(--motion-fast);
}
.ft-checklist li:hover { background: var(--surface-2); }
.ft-checklist li.ft-done [data-role="label"] { text-decoration: line-through; color: var(--text-muted); }
.ft-checklist [data-role="label"] { flex: 1; }
.ft-cl-bar {
  height: 4px; background: var(--surface-2); border-radius: 2px; overflow: hidden;
  margin: .25rem 0 .5rem;
}
.ft-cl-bar > div { height: 100%; background: var(--accent); transition: width var(--motion); }
.ft-cl-add, .ft-dep-add { display: flex; gap: .35rem; margin-top: .5rem; position: relative; align-items: center; }
.ft-cl-add input, .ft-dep-add input, .ft-dep-add select {
  flex: 1; padding: .4rem .55rem; background: var(--surface); border: 1px solid var(--border);
  color: var(--text); border-radius: var(--radius-sm); font: inherit; font-size: .88rem;
}
.ft-cl-del, .ft-ci-del, .ft-dep-del {
  padding: .2rem .4rem; font-size: .85rem; color: var(--text-subtle); background: transparent; border: 0;
}
.ft-cl-del:hover, .ft-ci-del:hover, .ft-dep-del:hover { color: var(--danger); background: var(--danger-weak); }
.ft-checklist-group { border: 1px solid var(--border); border-radius: var(--radius); padding: .55rem .75rem; margin-bottom: .6rem; background: var(--surface); }
.ft-checklist-group summary {
  display: flex; align-items: center; gap: .5rem; cursor: pointer;
  padding: .2rem 0; list-style: none;
}
.ft-checklist-group summary::-webkit-details-marker { display: none; }
.ft-subtasks, .ft-deps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .2rem; }
.ft-subtasks li, .ft-deps li {
  display: flex; align-items: center; gap: .5rem;
  padding: .35rem .5rem; border-radius: var(--radius-sm);
  transition: background var(--motion-fast);
}
.ft-subtasks li:hover, .ft-deps li:hover { background: var(--surface-2); }
.ft-priority-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.ft-subtask-link { flex: 1; color: var(--text); text-decoration: none; }
.ft-subtask-link:hover { color: var(--accent); text-decoration: underline; }

/* =========================================================================
 * Polish pass: sticky board head, refined empty state, chevron on selects,
 * truncated card-project chip, active-project chip affordance.
 * ========================================================================= */
.ft-board-head {
  position: sticky;
  top: var(--topbar-h);
  z-index: 20;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  backdrop-filter: saturate(180%) blur(6px);
  padding: var(--space-3) 0;
  margin-bottom: var(--space-2);
}

/* Custom chevron for native selects used as filters. */
.ft-select,
select.ft-input {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 2rem;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%2364748B' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right .7rem center;
  background-size: 12px 8px;
}

/* Empty column: friendlier, localisable copy + soft dashed frame. */
.ft-dropzone:empty {
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  margin: .5rem;
  min-height: 6rem;
  display: flex; align-items: center; justify-content: center;
}
.ft-dropzone:empty::before {
  content: '✦  ' attr(data-empty);
  display: block; padding: .5rem 1rem; text-align: center;
  color: var(--text-subtle); font-size: .8rem; font-style: normal;
}

/* Card project tag: truncate long keys gracefully. */
.ft-card-project {
  max-width: 7rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Active-project chip: interactive when filter is applied. */
a.ft-active-project-chip { cursor: pointer; transition: filter var(--motion-fast), transform var(--motion-fast); }
a.ft-active-project-chip:hover { filter: brightness(1.05); text-decoration: none; }
a.ft-active-project-chip:active { transform: translateY(1px); }
a.ft-active-project-chip:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--focus-ring); }
.ft-active-project-chip .ft-chip-x {
  margin-left: .35rem; opacity: .7; font-weight: 700; line-height: 1;
}
a.ft-active-project-chip:hover .ft-chip-x { opacity: 1; }

/* Autocomplete dropdown */
.ft-ac {
  position: absolute; top: 100%; left: 0; right: 0; background: var(--surface);
  border: 1px solid var(--border); border-radius: 6px; box-shadow: var(--shadow-md);
  max-height: 240px; overflow-y: auto; z-index: 30; margin-top: 2px;
}
.ft-ac > div { padding: .4rem .6rem; cursor: pointer; }
.ft-ac > div:hover, .ft-ac > div:focus { background: var(--surface-2); outline: none; }

/* Attachments */
.ft-attachments { list-style: none; padding: 0; margin: 0 0 .5rem; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .5rem; }
.ft-attachments li {
  display: flex; align-items: center; gap: .5rem; padding: .3rem .4rem;
  background: var(--surface-2); border-radius: 6px; position: relative;
}
.ft-att-link { display: flex; align-items: center; gap: .5rem; color: var(--text); text-decoration: none; flex: 1; overflow: hidden; }
.ft-att-link img { width: 36px; height: 36px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.ft-att-icon { font-size: 1.4rem; width: 36px; text-align: center; flex-shrink: 0; }
.ft-att-meta { display: flex; flex-direction: column; min-width: 0; }
.ft-att-meta strong { font-size: .85rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ft-att-meta small { color: var(--text-muted); font-size: .7rem; }
.ft-att-del { opacity: 0; transition: opacity .15s; }
.ft-attachments li:hover .ft-att-del { opacity: 1; }
.ft-att-pick { cursor: pointer; display: inline-flex; align-items: center; gap: .35rem; }
.ft-att-add { display: flex; gap: .5rem; align-items: center; margin-top: .5rem; }

/* Delivery table */
.ft-deliveries { width: 100%; border-collapse: collapse; font-size: .85rem; }
.ft-deliveries th, .ft-deliveries td { text-align: left; padding: .35rem .5rem; border-bottom: 1px solid var(--border); }
.ft-deliveries td pre { white-space: pre-wrap; word-break: break-word; max-height: 300px; overflow: auto;
  background: var(--surface-2); padding: .5rem; border-radius: 4px; font-size: .75rem; }
.ft-filters { display: flex; gap: .5rem; margin-bottom: .5rem; align-items: center; }
.ft-badge-ok   { background: rgba(16,185,129,.15); color: var(--success); border-color: transparent; }
.ft-badge-warn { background: rgba(245,158,11,.15); color: #D97706; border-color: transparent; }
.ft-badge-bad  { background: rgba(239,68,68,.15);  color: var(--danger);  border-color: transparent; }

/* Reactions */
.ft-reactions { display: flex; flex-wrap: wrap; gap: .25rem; margin-top: .35rem; align-items: center; }
.ft-reaction {
  font: inherit; font-size: .8rem; padding: .1rem .4rem; border-radius: 999px;
  border: 1px solid var(--border); background: var(--surface); color: var(--text);
  cursor: pointer; line-height: 1.4;
}
.ft-reaction:hover { background: var(--surface-2); }
.ft-reaction.ft-mine { background: rgba(255,107,0,.15); border-color: var(--accent-weak); color: var(--accent); }
.ft-reaction-pick { position: relative; display: inline-flex; width: 1.5rem; height: 1.3rem;
  align-items: center; justify-content: center; cursor: pointer; color: var(--text-muted);
  border: 1px dashed var(--border); border-radius: 999px; font-size: .75rem; }
.ft-reaction-pick:hover, .ft-reaction-pick:focus { color: var(--accent); border-color: var(--accent); }
.ft-pick-menu { position: absolute; bottom: 100%; left: 0; display: none;
  background: var(--surface); border: 1px solid var(--border); border-radius: 8px;
  padding: .25rem; box-shadow: var(--shadow-md); z-index: 40; margin-bottom: 2px; gap: .15rem;
}
.ft-reaction-pick:hover .ft-pick-menu,
.ft-reaction-pick:focus-within .ft-pick-menu { display: inline-flex; }
.ft-pick-menu button { background: none; border: 0; cursor: pointer; padding: .25rem; font-size: 1.1rem; border-radius: 4px; }
.ft-pick-menu button:hover { background: var(--surface-2); }

/* Billing / plan page */
.ft-plan-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
  padding: 1rem 1.25rem; margin-bottom: 1rem; }
.ft-plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.ft-plan-tier { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 1rem;
  display: flex; flex-direction: column; }
.ft-plan-tier.ft-current { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-weak); }
.ft-plan-tier h3 { margin: 0 0 .5rem; }
.ft-plan-tier button, .ft-plan-tier form { margin-top: auto; }
.ft-feature-list { list-style: none; padding: 0; margin: 0 0 1rem; display: flex; flex-direction: column; gap: .25rem; font-size: .85rem; }
.ft-feature-list li.ft-off { color: var(--text-muted); }
.ft-badge-free { background: var(--surface-2); color: var(--text-muted); }
.ft-badge-pro  { background: rgba(255,107,0,.15); color: var(--accent); border-color: var(--accent-weak); }
.ft-badge-enterprise { background: rgba(37,99,235,.15); color: #2563EB; }
.ft-saved { display: inline-block; font-size: .8rem; color: var(--success); padding: .1rem .5rem;
  border-radius: 999px; background: rgba(16,185,129,.12); margin: .25rem 0; }
[data-field][contenteditable="plaintext-only"] { outline: none; border-bottom: 1px dashed transparent; }
[data-field][contenteditable="plaintext-only"]:focus { border-bottom-color: var(--accent); }

/* Role badges */
.ft-badge { display: inline-block; padding: 0 .5rem; border-radius: 999px; font-size: .75rem; border: 1px solid var(--border); }
.ft-badge-owner  { background: rgba(255,107,0,.15); color: var(--accent); border-color: var(--accent-weak); }
.ft-badge-admin  { background: rgba(37,99,235,.15); color: #2563EB; }
.ft-badge-member { background: var(--surface-2); color: var(--text-muted); }
.ft-badge-viewer { background: var(--surface-2); color: var(--text-muted); opacity: .7; }

/* Settings — status + field editor */
.ft-status-list { list-style: none; padding: 0; margin: 0 0 1rem; display: flex; flex-direction: column; gap: .4rem; }
.ft-status-list li {
  display: flex; align-items: center; gap: .5rem;
  padding: .4rem .6rem; background: var(--surface); border: 1px solid var(--border);
  border-left: 4px solid var(--c, var(--border)); border-radius: 8px;
}
.ft-status-list li input[type="text"] { flex: 1; border: 0; background: transparent; padding: .25rem; color: var(--text); }
.ft-status-list li input[type="text"]:focus { outline: 1px solid var(--focus); }
.ft-drag-handle { cursor: grab; color: var(--text-muted); user-select: none; }
.ft-inline-label { display: inline-flex; align-items: center; gap: .3rem; font-size: .8rem; color: var(--text-muted); }

/* Offline indicator */
.ft-offline-banner {
  position: fixed; bottom: var(--space-4); left: 50%; transform: translateX(-50%);
  background: var(--danger); color: #fff;
  padding: .55rem 1rem; border-radius: 999px;
  box-shadow: var(--shadow-md); font-size: .85rem; z-index: 60;
  display: none;
  animation: ft-slide-up var(--motion) both;
}
@keyframes ft-slide-up {
  from { transform: translate(-50%, 16px); opacity: 0; }
  to   { transform: translate(-50%, 0);    opacity: 1; }
}
body.ft-offline .ft-offline-banner { display: inline-flex; align-items: center; gap: .5rem; }
body.ft-offline .ft-offline-banner::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 0 0 rgba(255, 255, 255, .7);
  animation: ft-pulse 1.5s infinite;
}
@keyframes ft-pulse {
  0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, .7); }
  70% { box-shadow: 0 0 0 8px rgba(255, 255, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); }
}

/* Auth */
.ft-auth {
  max-width: 420px; margin: 3rem auto;
  background: var(--surface); padding: 2rem 2.25rem;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  position: relative;
}
.ft-auth::before {
  content: ''; position: absolute; top: -3px; left: 24px; right: 24px; height: 3px;
  background: linear-gradient(90deg, var(--accent), #FF9B4A);
  border-radius: 3px 3px 0 0;
}
.ft-auth h1 {
  margin: 0 0 1.25rem;
  font-size: 1.6rem; font-weight: 700; letter-spacing: -.02em;
}
.ft-auth .form-group {
  display: flex; gap: .5rem; align-items: center;
  margin-top: 1.25rem; flex-wrap: wrap;
}
.ft-auth .field-rememberme { margin-top: .5rem; }
.ft-auth p { color: var(--text-muted); font-size: .9rem; }

/* A11y helpers */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* =========================================================================
 * Workspace (team) switcher — Jira-style dropdown in the topbar
 * ========================================================================= */
.ft-workspace { position: relative; margin-left: .25rem; }
.ft-workspace-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  background: transparent; border: 1px solid transparent;
  color: var(--text); padding: .35rem .55rem; border-radius: 8px;
  cursor: pointer; font: inherit; max-width: 260px;
}
.ft-workspace-btn:hover,
.ft-workspace-btn[aria-expanded="true"] { background: var(--surface-2); border-color: var(--border); }
.ft-ws-avatar {
  flex: none; width: 26px; height: 26px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--accent), #7c3aed);
  color: #fff; font-weight: 700; font-size: .8rem;
}
.ft-ws-name  { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-ws-caret { color: var(--text-muted); font-size: .8rem; }

.ft-workspace-menu {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 40;
  min-width: 280px; padding: .35rem; border-radius: 10px;
  background: var(--surface); border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
}
.ft-ws-head {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted); padding: .5rem .6rem .35rem;
}
.ft-ws-item {
  display: flex; align-items: center; gap: .55rem;
  padding: .45rem .6rem; border-radius: 8px;
  color: var(--text); text-decoration: none; cursor: pointer;
}
.ft-ws-item:hover { background: var(--surface-2); }
.ft-ws-item.is-active { background: color-mix(in oklab, var(--accent) 14%, transparent); }
.ft-ws-item-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ft-ws-check { color: var(--accent); font-weight: 700; }
.ft-ws-sep   { height: 1px; background: var(--border); margin: .35rem 0; }
.ft-ws-link  { color: var(--text-muted); font-size: .9rem; }
.ft-ws-link:hover { color: var(--text); }

/* Language switcher (topbar) — reuses workspace menu styles. */
.ft-lang { position: relative; }
.ft-lang-menu {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 40;
  min-width: 180px; padding: .35rem; border-radius: 10px;
  background: var(--surface); border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
}
.ft-lang .ft-lang-code { font-weight: 600; font-size: .8rem; letter-spacing: .04em; }

/* Install-PWA button — surfaced by app.js on beforeinstallprompt */
.ft-install-btn {
  display: inline-flex; align-items: center; gap: .25rem;
  font-weight: 600; color: var(--accent); border-color: var(--accent-weak);
  background: var(--accent-muted);
}
.ft-install-btn:hover { background: var(--accent-weak); color: var(--accent); }
@media (max-width: 640px) {
  /* Hide email/install text on tiny screens to keep the topbar usable. */
  .ft-user { display: none; }
  .ft-install-btn { padding: .35rem .5rem; }
  .ft-install-btn::after { content: ''; }
}

/* Active-project breadcrumb on the board */
.ft-board-context { display: flex; align-items: center; gap: .6rem; min-width: 0; }
.ft-active-project { display: inline-flex; align-items: center; gap: .5rem; }
.ft-active-project-chip {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .2rem .55rem; border-radius: 999px;
  border: 1px solid currentColor; font-size: .8rem; font-weight: 600;
  white-space: nowrap;
}
.ft-crumb-sep { color: var(--text-muted); }
.ft-board-title { margin: 0; font-size: 1.1rem; }

/* Cards: Jira-style key + project tag */
.ft-card { cursor: pointer; }
.ft-card:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.ft-card-top { display: flex; align-items: center; gap: .4rem; margin-bottom: .15rem; }
.ft-card-key { font: 600 .72rem ui-monospace, Menlo, monospace; color: var(--text-muted); letter-spacing: .02em; }
.ft-card-project {
  display: inline-flex; align-items: center; padding: 0 .4rem; border-radius: 4px;
  font: 700 .7rem ui-monospace, Menlo, monospace; letter-spacing: .03em;
  max-width: 7rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Drawer: project badge + task key in header */
.ft-drawer-project {
  display: inline-flex; align-items: center;
  padding: .1rem .45rem; border-radius: 4px; border: 1px solid transparent;
  font: 700 .72rem ui-monospace, Menlo, monospace; text-decoration: none;
}
.ft-drawer-project:hover { filter: brightness(1.05); }
.ft-task-key { font: 600 .78rem ui-monospace, Menlo, monospace; color: var(--text-muted); }
.ft-drawer-close { margin-left: auto; }

/* Drawer tabs */
.ft-drawer-tabs {
  display: flex; gap: .25rem; border-bottom: 1px solid var(--border);
  margin: .25rem 0 .75rem; overflow-x: auto;
}
.ft-drawer-tab {
  background: transparent; border: 0; border-bottom: 2px solid transparent;
  padding: .5rem .75rem; color: var(--text-muted); cursor: pointer;
  font: inherit; white-space: nowrap;
}
.ft-drawer-tab:hover { color: var(--text); }
.ft-drawer-tab.is-active { color: var(--text); border-bottom-color: var(--accent); font-weight: 600; }
.ft-drawer-pane { display: none; }
.ft-drawer-pane.is-active { display: block; }

