:root {
	--bg: #0b0b0c;
	--panel: #121317;
	--panel2: #161820;
	--text: #e8e8ea;
	--muted: #a7a7ad;
	--border: #23242a;
	--accent: #5aa7ff;
	--danger: #ff5a6b;
}
* {
	box-sizing: border-box;
}
html,
body {
	height: 100%;
}
body {
	margin: 0;
	background: var(--bg);
	color: var(--text);
	font-family: system-ui, Segoe UI, Roboto, Ubuntu, Arial;
}
.topbar {
	display: flex;
	gap: 10px;
	align-items: center;
	padding: 12px 16px;
	border-bottom: 1px solid var(--border);
	background: var(--panel);
}
.topbar .spacer {
	flex: 1;
}
button {
	padding: 8px 12px;
	border-radius: 10px;
	border: 1px solid var(--border);
	background: var(--panel2);
	color: var(--text);
	cursor: pointer;
}
button:hover {
	border-color: var(--accent);
}
button.primary {
	background: #1f6feb;
	border-color: #1f6feb;
}
button.danger {
	background: #351a1e;
	border-color: #522029;
	color: #ffb8c1;
}
.container {
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	max-width: 1200px;
	margin: 0 auto;
}

.plan {
	border: 1px solid var(--border);
	border-radius: 18px;
	background: var(--panel);
}
.plan-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	border-bottom: 1px solid var(--border);
}
.plan-title {
	margin: 0;
}
.collapse-btn {
	width: 36px;
	height: 36px;
}
.plan-body {
	padding: 12px;
	display: grid;
	gap: 12px;
}
/* Plan collapse */
.plan.collapsed .plan-body {
	display: none;
}
.plan .collapse-btn {
	transition: transform 0.2s ease;
}
.plan:not(.collapsed) .collapse-btn {
	transform: rotate(180deg);
} /* point up when expanded */

.card {
	border: 1px solid var(--border);
	border-radius: 16px;
	background: var(--panel2);
	overflow: hidden;
}
.card-head {
	display: grid;
	grid-template-columns: 1fr auto 42px;
	gap: 10px;
	align-items: center;
	padding: 10px 12px;
	border-bottom: 1px solid var(--border);
}
.card-title {
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.card-action {
	color: var(--muted);
	font-size: 14px;
}
.expand-btn {
	width: 36px;
	height: 36px;
}
.card.collapsed .card-body {
	display: none;
}
.card-body {
	padding: 12px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
/* Card collapse */
.card.collapsed .card-body {
	display: none;
}
.card .expand-btn {
	transition: transform 0.2s ease;
}
.card:not(.collapsed) .expand-btn {
	transform: rotate(180deg);
} /* point up when expanded */

.kv span {
	color: var(--muted);
	margin-right: 6px;
}
.meta {
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 12px;
	color: #cfcfd4;
	background: #0f1014;
	border: 1px dashed var(--border);
	padding: 8px;
	border-radius: 8px;
	white-space: pre-wrap;
}
.btnrow {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.editor {
	display: grid;
	gap: 10px;
	background: #0f1014;
	border: 1px solid var(--border);
	padding: 10px;
	border-radius: 10px;
}
.editor.hidden {
	display: none;
}
.field label {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.hidden {
	display: none !important;
}
.editor .field input:disabled {
	opacity: 0.6;
}
.remote {
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 12px;
	color: #cfcfd4;
	background: #0f1014;
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 10px;
	white-space: pre-wrap;
}
.muted {
	color: var(--muted);
}
.small {
	padding: 6px 10px;
	font-size: 12px;
}

.console {
	border: 1px solid var(--border);
	border-radius: 18px;
	background: var(--panel);
}
.console-head {
	display: flex;
	gap: 10px;
	align-items: center;
	padding: 10px 12px;
	border-bottom: 1px solid var(--border);
}
.console .spacer {
	flex: 1;
}
.logbox {
	margin: 0;
	padding: 12px;
	height: 28vh;
	overflow: auto;
	background: #0f1014;
	color: #eaeaea;
	border-radius: 0 0 18px 18px;
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 12.5px;
	white-space: pre-wrap;
}
.plan-header .plan-tools {
	margin-left: auto; /* push to the right if meta is short */
	display: flex;
	align-items: center;
	gap: 8px;
}
.plan-header .filter-action {
	background: var(--panel2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: 10px;
	padding: 6px 10px;
	font: inherit;
}
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}
