/* FeatureMap Pro - Kanban styles. Colors come from per-instance CSS variables
   (--bg --card --text --border --hl) set inline by the theme settings. */
.fm-kanban { --muted: #8a93a3; max-width: 1100px; margin: 0 auto; color: var(--text); }
.fm-kanban-title { font-size: 22px; font-weight: 700; color: var(--text); margin: 0 0 16px; }
.fm-kanban-stage { position: relative; background: var(--bg); border-radius: 14px; padding: 14px; overflow-x: auto; scrollbar-width: thin; }
.fm-kanban-cols { display: grid; gap: 12px; align-items: start; }
.fm-kanban-col { display: flex; flex-direction: column; min-width: 0; }
.fm-kanban-head { display: flex; align-items: center; gap: 7px; padding: 2px 4px 11px; font-size: 13px; font-weight: 700; color: var(--text); }
.fm-kanban-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; }
.fm-kanban-count { margin-left: auto; font-size: 11px; color: var(--muted); background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: 1px 8px; }
.fm-kanban-list { display: flex; flex-direction: column; gap: 9px; min-height: 56px; padding: 6px; border-radius: 10px; border: 1.5px dashed transparent; transition: border-color .18s, background .18s; }
.fm-kanban-list.is-over { border-color: var(--hl); background: color-mix(in srgb, var(--hl) 9%, transparent); }
.fm-kanban-card { display: flex; align-items: flex-start; gap: 10px; background: var(--card); border: var(--fm-bw, 1px) solid var(--border); border-radius: 10px; padding: var(--fm-pad, 11px) var(--fm-pad, 12px); box-shadow: 0 1px 3px rgba(0,0,0,.09); transition: box-shadow .18s, border-color .18s, transform .22s cubic-bezier(.2,.7,.3,1); touch-action: none; will-change: transform; }
.fm-kanban[data-can-manage="1"] .fm-kanban-card { cursor: grab; }
.fm-kanban-card:hover { border-color: color-mix(in srgb, var(--hl) 45%, var(--border)); }
.fm-kanban-votes { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; min-width: 36px; padding: 4px 0; border: 0; border-radius: 8px; background: color-mix(in srgb, var(--hl) 12%, transparent); color: var(--hl); font-weight: 700; font-size: 13px; line-height: 1.1; cursor: pointer; font-family: inherit; }
.fm-kanban-votes:hover { background: color-mix(in srgb, var(--hl) 20%, transparent); }
.fm-kanban-votes.is-voted { background: var(--hl); color: #fff; }
.fm-kv-arrow { font-size: 11px; font-style: normal; }
.fm-kanban-card-title { font-size: 13px; color: var(--text); line-height: 1.4; padding-top: 1px; text-decoration: none; font-weight: 400; }
.fm-kanban-card-title:hover { color: var(--hl); }
.fm-kanban-ph { border: 1.5px dashed var(--hl); border-radius: 10px; background: color-mix(in srgb, var(--hl) 7%, transparent); box-shadow: none; }
.fm-kanban-drag { position: absolute; z-index: 50; pointer-events: none; box-shadow: 0 12px 28px rgba(0,0,0,.22); transform: rotate(1.2deg) scale(1.03); cursor: grabbing; margin: 0; }
@media (max-width: 640px) { .fm-kanban-cols { grid-template-columns: 1fr !important; } }

/* Admin-only "Edit" link shown under the board. */
.fm-admin-edit { margin-top: 12px; text-align: center; }
.fm-admin-edit-link {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 4px 12px; border-radius: 999px;
	font-size: 12px; font-weight: 600; line-height: 1.4;
	color: #555; background: rgba(0,0,0,.04);
	border: 1px solid rgba(0,0,0,.12); text-decoration: none;
	transition: background .12s, color .12s, border-color .12s;
}
.fm-admin-edit-link:hover { background: rgba(0,0,0,.07); color: #111; border-color: rgba(0,0,0,.2); }
.fm-admin-edit-link svg { flex: none; }
