/* KidsVerse Bot Directory – directory.css – v2.0 (fixed) */

.kvd-wrapper {
	--kvd-radius: 18px;
	--kvd-font: 'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	display: flex;
	gap: 22px;
	height: 640px;
	/* Fixed height — no grow */
	max-width: 1200px;
	margin: 0 auto;
	padding: 22px;
	font-family: var(--kvd-font);
	background:
		radial-gradient(circle at 15% 15%, rgba(124, 58, 237, .35), transparent 55%),
		radial-gradient(circle at 85% 85%, rgba(20, 184, 166, .30), transparent 55%),
		linear-gradient(135deg, #241a3d 0%, #34205a 40%, #1c2f44 100%);
	border-radius: 24px;
	color: #fff;
	box-sizing: border-box;
	overflow: hidden;
}

.kvd-wrapper * {
	box-sizing: border-box;
}

/* ── Sidebar ── */
.kvd-sidebar {
	width: 280px;
	flex-shrink: 0;
	background: rgba(255, 255, 255, .06);
	border: 1px solid rgba(255, 255, 255, .09);
	border-radius: var(--kvd-radius);
	padding: 18px;
	display: flex;
	flex-direction: column;
	backdrop-filter: blur(6px);
	height: 100%;
	overflow: hidden;
}

.kvd-sidebar-head {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	opacity: .55;
	margin-bottom: 14px;
	flex-shrink: 0;
}

.kvd-bot-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex: 1;
	overflow-y: auto;
	padding-right: 4px;
	margin-right: -4px;
	/* scroll when bots overflow */
}

.kvd-bot-list::-webkit-scrollbar {
	width: 5px;
}

.kvd-bot-list::-webkit-scrollbar-track {
	background: transparent;
}

.kvd-bot-list::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, .18);
	border-radius: 10px;
}

.kvd-bot-list::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, .3);
}

.kvd-bot-item {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	background: transparent;
	border: none;
	border-left: 3px solid transparent;
	border-radius: 12px;
	padding: 10px 12px;
	cursor: pointer;
	text-align: left;
	transition: background .15s ease, transform .15s ease, border-color .15s ease;
	font-family: inherit;
	flex-shrink: 0;
}

.kvd-bot-item:hover {
	background: rgba(255, 255, 255, .07);
	transform: translateX(2px);
}

.kvd-bot-item.kvd-active {
	background: rgba(255, 255, 255, .13);
	border-left-color: var(--kvd-color, #7c3aed);
}

/* ── Avatar: always a perfect circle ── */
.kvd-avatar-wrap {
	position: relative;
	flex-shrink: 0;
	width: 44px;
	border-radius: 50%;
	height: 44px;
}

.kvd-avatar-img,
.kvd-avatar-letter {
	width: 44px;
	height: 44px !important;
	border-radius: 50% !important;
	/* ← circle */
	object-fit: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	color: #fff;
	font-size: 18px;
	flex-shrink: 0;
	overflow: hidden;
	/* ← clip image to circle */
}

.kvd-avatar-img {
	border: 2.5px solid var(--kvd-color, #7c3aed);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, .08);
}

.kvd-online-dot {
	position: absolute;
	bottom: 0px;
	right: 0px;
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background: #22c55e;
	border: 2px solid #2a1f48;
	box-shadow: 0 0 6px rgba(34, 197, 94, .5);
}

.kvd-bot-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.kvd-bot-info strong {
	font-size: 14px;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.kvd-bot-info small {
	font-size: 11.5px;
	opacity: .62;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.kvd-sidebar-footer {
	margin-top: 14px;
	font-size: 12px;
	opacity: .65;
	background: rgba(255, 255, 255, .05);
	border: 1px solid rgba(255, 255, 255, .06);
	border-radius: 10px;
	padding: 10px 12px;
	flex-shrink: 0;
}

/* ── Right panels ── */
.kvd-panels {
	flex: 1;
	position: relative;
	min-width: 0;
	height: 100%;
}

.kvd-panel {
	display: none;
	flex-direction: column;
	height: 100%;
	/* fill fixed parent */
	background: rgba(18, 14, 32, .5);
	border: 1px solid rgba(255, 255, 255, .09);
	border-radius: var(--kvd-radius);
	overflow: hidden;
	backdrop-filter: blur(6px);
	box-shadow: 0 18px 50px rgba(0, 0, 0, .25);
}

.kvd-panel.kvd-panel-active {
	display: flex;
	animation: kvd-fade-in .18s ease;
}

@keyframes kvd-fade-in {
	from {
		opacity: 0;
		transform: translateY(4px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ── Panel header ── */
.kvd-panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 18px;
	border-bottom: 1px solid rgba(255, 255, 255, .08);
	flex-shrink: 0;
	background: rgba(0, 0, 0, .15);
}

.kvd-panel-head-left {
	display: flex;
	align-items: center;
	gap: 12px;
}

/* Header avatar — round circle */
.kvd-panel-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	/* ← circle */
	object-fit: cover;
	flex-shrink: 0;
	overflow: hidden;
	/* ← clip */
	border: 2.5px solid var(--kvd-color, #7c3aed);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, .08), 0 4px 12px rgba(0, 0, 0, .3);
}

.kvd-panel-name {
	font-weight: 700;
	font-size: 16px;
}

.kvd-panel-status {
	font-size: 11.5px;
	opacity: .62;
	display: flex;
	align-items: center;
	gap: 5px;
	margin-top: 2px;
}

.kvd-dot-green {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #22c55e;
	display: inline-block;
	animation: kvd-blink 2.5s ease-in-out infinite;
}

@keyframes kvd-blink {

	0%,
	100% {
		opacity: 1
	}

	50% {
		opacity: .4
	}
}

.kvd-panel-badge {
	font-size: 12px;
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .12);
	padding: 5px 12px;
	border-radius: 20px;
	white-space: nowrap;
	display: flex;
	align-items: center;
	gap: 5px;
}

/* ── Messages area — scrollable, fixed height ── */
.kvd-panel-messages {
	flex: 1;
	/* fills remaining panel space */
	overflow-y: auto;
	/* scroll when chat grows */
	padding: 18px 18px 10px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	scroll-behavior: smooth;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, .18) transparent;
}

.kvd-panel-messages::-webkit-scrollbar {
	width: 5px;
}

.kvd-panel-messages::-webkit-scrollbar-track {
	background: transparent;
}

.kvd-panel-messages::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, .18);
	border-radius: 10px;
}

/* Message row */
.kvd-msg {
	display: flex;
	gap: 10px;
	max-width: 82%;
	align-items: flex-start;
	/* ← avatar stays at TOP of bubble, not bottom */
}

.kvd-msg-bot {
	align-self: flex-start;
}

.kvd-msg-user {
	align-self: flex-end;
	flex-direction: row-reverse;
	max-width: 75%;
}

/* Message avatar — always round circle, fixed size */
.kvd-msg-av {
	width: 32px;
	height: 32px !important;
	/* ← force fixed size */
	border-radius: 50% !important;
	/* ← circle */
	flex-shrink: 0;
	object-fit: cover;
	font-size: 13px;
	overflow: hidden;
	/* ← clip image */
	border: 2px solid var(--kvd-color, #7c3aed);
	background: var(--kvd-color, #7c3aed);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 700;
	margin-top: 2px;
	/* slight top nudge */
}

/* Bubbles */
.kvd-bubble {
	padding: 10px 14px;
	border-radius: 14px;
	border-top-left-radius: 4px;
	/* point toward avatar */
	font-size: 14px;
	line-height: 1.6;
	background: rgba(255, 255, 255, .1);
	color: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
	word-break: break-word;
	white-space: pre-wrap;
}

.kvd-msg-user .kvd-bubble {
	background: var(--kvd-color, #7c3aed);
	box-shadow: 0 2px 10px rgba(0, 0, 0, .25);
	border-radius: 14px;
	border-top-right-radius: 4px;
}

/* Typing indicator */
.kvd-typing .kvd-bubble {
	display: flex;
	gap: 4px;
	align-items: center;
	padding: 12px 16px;
}

.kvd-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #fff;
	opacity: .5;
	animation: kvd-bounce 1.2s infinite;
}

.kvd-dot:nth-child(2) {
	animation-delay: .2s;
}

.kvd-dot:nth-child(3) {
	animation-delay: .4s;
}

@keyframes kvd-bounce {

	0%,
	80%,
	100% {
		transform: translateY(0);
		opacity: .4;
	}

	40% {
		transform: translateY(-5px);
		opacity: 1;
	}
}

/* ── Quick prompts ── */
.kvd-prompts-wrap {
	padding: 0 18px 14px;
	flex-shrink: 0;
}

.kvd-prompts-label {
	font-size: 11.5px;
	opacity: .58;
	margin-bottom: 8px;
	font-weight: 600;
	letter-spacing: .04em;
}

.kvd-prompts-scroll {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.kvd-prompt-btn {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .14);
	color: #fff;
	border-radius: 12px;
	padding: 9px 12px;
	font-size: 12.5px;
	line-height: 1.35;
	text-align: left;
	cursor: pointer;
	transition: background .15s ease, transform .1s ease, border-color .15s ease;
	font-family: inherit;
	font-weight: 500;
}

.kvd-prompt-btn:hover {
	background: rgba(255, 255, 255, .17);
	border-color: rgba(255, 255, 255, .25);
	transform: translateY(-1px);
}

/* Prompt image — round circle */
.kvd-prompt-img {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	/* ← circle */
	object-fit: cover;
	flex-shrink: 0;
	overflow: hidden;
}

@media (max-width: 560px) {
	.kvd-prompts-scroll {
		grid-template-columns: 1fr;
	}
}

/* ── Input bar ── */
.kvd-input-bar {
	display: flex;
	gap: 10px;
	padding: 14px 18px;
	border-top: 1px solid rgba(255, 255, 255, .08);
	flex-shrink: 0;
	background: rgba(0, 0, 0, .1);
}

.kvd-input {
	flex: 1;
	background: rgba(255, 255, 255, .08);
	border: 1.5px solid rgba(255, 255, 255, .14);
	border-radius: 24px;
	padding: 10px 16px;
	color: #fff;
	font-size: 14px;
	font-family: inherit;
	outline: none;
	transition: border-color .15s, background .15s;
}

.kvd-input:focus {
	border-color: var(--kvd-color, #7c3aed);
	background: rgba(255, 255, 255, .12);
}

.kvd-input::placeholder {
	color: rgba(255, 255, 255, .4);
}

.kvd-send {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: none;
	background: var(--kvd-color, #7c3aed);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: transform .12s ease, box-shadow .12s ease, opacity .12s;
	box-shadow: 0 4px 14px rgba(0, 0, 0, .3);
}

.kvd-send:hover:not(:disabled) {
	transform: scale(1.08);
	box-shadow: 0 6px 18px rgba(0, 0, 0, .35);
}

.kvd-send:disabled {
	opacity: .4;
	cursor: default;
	transform: none;
}

/* ── Safety footer ── */
.kvd-safety {
	font-size: 11px;
	opacity: .5;
	text-align: center;
	padding: 6px 18px 12px;
	flex-shrink: 0;
}

.kvd-empty {
	padding: 60px;
	text-align: center;
	opacity: .6;
}

/* ── Mobile ── */
@media (max-width: 768px) {
	.kvd-wrapper {
		flex-direction: column;
		padding: 14px;
		gap: 14px;
		height: auto;
		min-height: 500px;
	}

	.kvd-sidebar {
		width: 100%;
		height: auto;
		max-height: 220px;
	}

	.kvd-panels {
		height: 520px;
	}
}