/* ── Live Status Board ───────────────────────────────────────
   Kanban board, project groups, columns, and person cards
   for the real-time status board view.
   ─────────────────────────────────────────────────────────── */

.kanban-board {
	margin-top: 24px;
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: 26px 28px;
	box-shadow: var(--shadow-md);
	animation: card-in 320ms ease-out;
}

.kanban-board__header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
}

.kanban-lock-button {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	border: 1px solid var(--blue-200);
	background: var(--blue-50);
	color: var(--blue-700);
	font-size: 13px;
	font-weight: 600;
	border-radius: var(--radius-pill);
	padding: 6px 14px;
	cursor: pointer;
	white-space: nowrap;
	flex-shrink: 0;
	transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
}

.kanban-lock-button:hover {
	background: var(--blue-100);
	border-color: var(--blue-400);
}

.kanban-lock-button[aria-pressed="true"] {
	background: var(--blue-600);
	border-color: var(--blue-700);
	color: #ffffff;
}

.kanban-lock-button[aria-pressed="true"]:hover {
	background: var(--blue-700);
}

.kanban-board__header h2 {
	margin: 8px 0 10px;
	font-size: 22px;
	color: var(--blue-900);
}

.kanban-board__controls {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
}

.kanban-grouping-selector {
	display: flex;
	align-items: center;
	gap: 6px;
}

.kanban-grouping-selector__label {
	font-size: 13px;
	font-weight: 600;
	color: var(--muted);
	white-space: nowrap;
	margin-right: 2px;
}

.kanban-grouping-pill {
	font-size: 13px;
	font-weight: 600;
	color: var(--blue-700);
	background: var(--blue-50);
	border: 1px solid var(--blue-200);
	border-radius: var(--radius-pill);
	padding: 5px 13px;
	text-decoration: none;
	white-space: nowrap;
	transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
}

.kanban-grouping-pill:hover {
	background: var(--blue-100);
	border-color: var(--blue-400);
}

.kanban-grouping-pill.is-active {
	background: var(--blue-600);
	border-color: var(--blue-700);
	color: #ffffff;
}

.kanban-board__header p {
	margin: 0;
	color: #334155;
}

.kanban-board__date {
	margin-top: 6px;
	font-size: 20px;
	font-weight: 700;
	color: var(--blue-900);
}

.kanban-stack {
	margin-top: 22px;
	display: grid;
	gap: 22px;
}

/* ── Project groups ── */

.kanban-project {
	border-radius: var(--radius-lg);
	border: 1px solid var(--scheme-border, var(--blue-100));
	background: var(--scheme-bg, #ffffff);
	padding: 18px;
	box-shadow: var(--shadow-sm);
}

.kanban-project__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 14px;
}

.kanban-project__header h3 {
	margin: 0;
	font-size: 18px;
	color: var(--scheme-accent, var(--blue-900));
}

.kanban-project__meta {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--scheme-accent, var(--blue-600));
}

/* ── Columns ── */

.kanban-columns {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: stretch;
}

.kanban-column {
	flex: 1 1 calc((100% - 60px) / 6);
	max-width: calc((100% - 60px) / 6);
	min-width: 140px;
	background: var(--blue-50);
	border: 1px solid var(--blue-200);
	border-radius: var(--radius-md);
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	transition: border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.kanban-column[draggable="true"] {
	cursor: grab;
}

.kanban-column.is-dragging {
	opacity: 0.75;
	border-color: var(--blue-500);
	box-shadow: 0 10px 24px rgba(37, 99, 235, 0.2);
	transform: scale(0.98);
	cursor: grabbing;
}

.kanban-column__handle {
	font-size: 16px;
	color: var(--blue-400);
}

.kanban-column__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-weight: 600;
	color: var(--blue-900);
}

.kanban-column__title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.kanban-column__count {
	min-width: 22px;
	padding: 2px 8px;
	border-radius: var(--radius-pill);
	background: #ffffff;
	border: 1px solid var(--blue-200);
	font-size: 12px;
	font-weight: 700;
	color: var(--blue-700);
	text-align: center;
}

.kanban-column__body {
	border-radius: var(--radius-md);
	border: 1px dashed var(--blue-200);
	background: #ffffff;
	padding: 10px;
	min-height: 70px;
	color: #475569;
	font-size: 13px;
	display: grid;
	gap: 8px;
	align-content: start;
	transition: border-color 150ms ease, box-shadow 150ms ease;
}

.kanban-column__body p {
	margin: 0;
}

.kanban-column__body.is-over {
	border-color: var(--blue-500);
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}

.kanban-column__empty {
	margin: 0;
	color: #94a3b8;
}

/* ── Person cards ── */

.kanban-card {
	border-radius: var(--radius-md);
	background: #ffffff;
	border: 1px solid var(--blue-200);
	padding: 10px 12px;
	box-shadow: var(--shadow-sm);
	cursor: grab;
	transition: transform 120ms ease, box-shadow 120ms ease;
	text-align: center;
}

.kanban-card:active {
	cursor: grabbing;
}

.kanban-card--locked {
	cursor: default;
	opacity: 0.85;
}

.kanban-card--mine {
	background: #eff6ff;
	border-color: #93c5fd;
	box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2), var(--shadow-sm);
}

.kanban-card--mine .kanban-card__name {
	color: #1d4ed8;
}

.kanban-card.is-dragging {
	opacity: 0.8;
	transform: scale(0.98);
	box-shadow: 0 12px 22px rgba(15, 23, 42, 0.16);
}

.kanban-card__name {
	margin: 0;
	font-weight: 600;
	color: var(--blue-900);
}

.kanban-card__role {
	margin: 4px 0 0;
	font-size: 12px;
	color: var(--blue-700);
}

.kanban-card__time {
	margin: 6px 0 0;
	font-size: 11px;
	color: #64748b;
}

.kanban-card__note {
	margin: 6px 0 0;
	font-size: 12px;
	color: #1e293b;
}

.kanban-card__note-button {
	margin-top: 8px;
	border: none;
	background: var(--blue-50);
	color: var(--blue-700);
	font-size: 12px;
	font-weight: 600;
	border-radius: var(--radius-pill);
	padding: 6px 10px;
	cursor: pointer;
	transition: background 150ms ease, color 150ms ease;
}

.kanban-card__note-button:hover {
	background: var(--blue-200);
	color: var(--blue-900);
}

.kanban-card.is-loading {
	opacity: 0.5;
	pointer-events: none;
}

.kanban-card__note-form {
	display: none;
	margin-top: 8px;
	text-align: left;
}

.kanban-card__note-form.is-visible {
	display: block;
}

.kanban-card__note-input {
	width: 100%;
	box-sizing: border-box;
	font-size: 12px;
	font-family: inherit;
	border: 1px solid var(--blue-200);
	border-radius: var(--radius-sm);
	padding: 6px 8px;
	resize: none;
	color: #1e293b;
}

.kanban-card__note-actions {
	display: flex;
	gap: 6px;
	margin-top: 6px;
	justify-content: flex-start;
}

.kanban-card__note-save {
	border: none;
	background: var(--blue-600);
	color: #ffffff;
	font-size: 12px;
	font-weight: 600;
	border-radius: var(--radius-pill);
	padding: 4px 12px;
	cursor: pointer;
	transition: background 150ms ease;
}

.kanban-card__note-save:hover {
	background: var(--blue-700);
}

.kanban-card__note-cancel {
	border: none;
	background: var(--blue-50);
	color: var(--blue-700);
	font-size: 12px;
	font-weight: 600;
	border-radius: var(--radius-pill);
	padding: 4px 12px;
	cursor: pointer;
	transition: background 150ms ease;
}

.kanban-card__note-cancel:hover {
	background: var(--blue-200);
}

/* ── Board-level empty states ── */

.kanban-empty {
	margin-top: 18px;
	padding: 14px 16px;
	border-radius: var(--radius-md);
	background: var(--surface);
	border: 1px solid #e8e5e0;
	color: var(--ink-soft);
	font-weight: 500;
}

/* ── Responsive ── */

@media (max-width: 640px) {
	.kanban-board {
		padding: 20px;
	}

	.kanban-project {
		padding: 14px;
	}

	.kanban-column {
		min-width: 200px;
	}
}
