.abilities-bridge-bubble-panel[hidden] {
	display: none !important;
}

#abilities-bridge-bubble-root {
	position: fixed;
	right: 24px;
	bottom: 24px;
	z-index: 999999;
	font-family: "Segoe UI", sans-serif;
}

.abilities-bridge-bubble-launcher {
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, #111827, #2563eb);
	color: #fff;
	padding: 14px 18px;
	font-size: 14px;
	font-weight: 600;
	box-shadow: 0 18px 40px rgba(15, 23, 42, 0.28);
	cursor: pointer;
}

.abilities-bridge-bubble-panel {
	position: absolute;
	right: 0;
	bottom: 72px;
	width: min(420px, calc(100vw - 24px));
	height: min(680px, calc(100vh - 120px));
	background: #ffffff;
	border: 1px solid rgba(148, 163, 184, 0.35);
	border-radius: 18px;
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.22);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.abilities-bridge-bubble-header {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding: 6px 10px 2px;
	background: #ffffff;
}

.abilities-bridge-bubble-header-compact {
	min-height: 0;
}

.abilities-bridge-bubble-close {
	border: 0;
	background: transparent;
	font-size: 18px;
	line-height: 1;
	padding: 2px 4px;
	color: #475569;
	cursor: pointer;
}

.abilities-bridge-bubble-controls,
.abilities-bridge-bubble-conversations,
.abilities-bridge-bubble-token-meter,
.abilities-bridge-bubble-form {
	padding-left: 18px;
	padding-right: 18px;
}

.abilities-bridge-bubble-controls {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	padding-top: 8px;
}

.abilities-bridge-bubble-model-guidance {
	padding: 8px 18px 0;
	font-size: 12px;
	line-height: 1.4;
	color: #475569;
}

.abilities-bridge-bubble-field-group,
.abilities-bridge-bubble-conversations {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.abilities-bridge-bubble-field-group label,
.abilities-bridge-bubble-conversations label {
	font-size: 12px;
	font-weight: 600;
	color: #334155;
}

.abilities-bridge-bubble-field-group select,
.abilities-bridge-bubble-conversation-row select,
#abilities-bridge-bubble-input {
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	padding: 10px 12px;
	font-size: 14px;
	background: #fff;
	width: 100%;
	box-sizing: border-box;
}

.abilities-bridge-bubble-conversation-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px;
}

.abilities-bridge-bubble-secondary,
.abilities-bridge-bubble-primary {
	border: 0;
	border-radius: 10px;
	padding: 10px 12px;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
}

.abilities-bridge-bubble-secondary {
	background: #e2e8f0;
	color: #0f172a;
}

.abilities-bridge-bubble-secondary:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.abilities-bridge-bubble-primary {
	background: #2563eb;
	color: #fff;
}

.abilities-bridge-bubble-token-meter {
	padding-top: 14px;
}

.abilities-bridge-bubble-token-bar {
	height: 8px;
	border-radius: 999px;
	background: #e2e8f0;
	overflow: hidden;
}

.abilities-bridge-bubble-token-fill {
	height: 100%;
	width: 0;
	background: #2563eb;
	transition: width 0.2s ease;
}

.abilities-bridge-bubble-token-meta {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	font-size: 12px;
	color: #475569;
	padding-top: 8px;
}

.abilities-bridge-bubble-messages {
	flex: 1;
	overflow-y: auto;
	padding: 16px 18px;
	background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.abilities-bridge-bubble-message {
	margin-bottom: 12px;
	padding: 12px 14px;
	border-radius: 14px;
	max-width: 92%;
	box-shadow: 0 8px 24px rgba(148, 163, 184, 0.12);
}

.abilities-bridge-bubble-message.user-message {
	margin-left: auto;
	background: #dbeafe;
}

.abilities-bridge-bubble-message.assistant-message {
	background: #ffffff;
}

.abilities-bridge-bubble-message.error-message,
.abilities-bridge-bubble-message.system-message {
	background: #fee2e2;
}

.abilities-bridge-bubble-role {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #475569;
	margin-bottom: 6px;
}

.abilities-bridge-bubble-content {
	font-size: 14px;
	line-height: 1.5;
	color: #0f172a;
	word-break: break-word;
}

.abilities-bridge-bubble-form {
	padding-top: 12px;
	padding-bottom: 18px;
	border-top: 1px solid rgba(148, 163, 184, 0.2);
	background: #fff;
}

#abilities-bridge-bubble-input {
	resize: vertical;
	min-height: 72px;
	max-height: 160px;
}

.abilities-bridge-bubble-form-actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-top: 10px;
}

.abilities-bridge-bubble-hint {
	font-size: 11px;
	color: #64748b;
}

@media (max-width: 782px) {
	#abilities-bridge-bubble-root {
		right: 12px;
		bottom: 12px;
	}

	.abilities-bridge-bubble-panel {
		position: fixed;
		right: 12px;
		left: 12px;
		bottom: 76px;
		width: auto;
		height: min(72vh, 640px);
	}

	.abilities-bridge-bubble-controls {
		grid-template-columns: 1fr;
	}

	.abilities-bridge-bubble-form-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.abilities-bridge-bubble-primary {
		width: 100%;
	}
}


.abilities-bridge-bubble-status {
	padding: 10px 18px 0;
	font-size: 12px;
	font-weight: 600;
	color: #475569;
}

.abilities-bridge-bubble-content p {
	margin: 0 0 10px;
}

.abilities-bridge-bubble-content p:last-child {
	margin-bottom: 0;
}

.abilities-bridge-bubble-content ul,
.abilities-bridge-bubble-content ol {
	margin: 0 0 10px 20px;
	padding: 0;
}

.abilities-bridge-bubble-content li {
	margin-bottom: 4px;
}

.abilities-bridge-bubble-content pre {
	margin: 10px 0;
	padding: 10px 12px;
	border-radius: 10px;
	background: #0f172a;
	color: #e2e8f0;
	overflow-x: auto;
}

.abilities-bridge-bubble-content code {
	font-family: Consolas, Monaco, monospace;
	font-size: 12px;
}

.abilities-bridge-bubble-content :not(pre) > code {
	padding: 1px 5px;
	border-radius: 6px;
	background: #e2e8f0;
	color: #0f172a;
}
