/* ─── Meet b. Assistent Widget ─── */
/* Scoped onder #meetb-assistent om Uncode-conflicts te voorkomen */

#meetb-assistent {
	--mb-warm: #C8956C;
	--mb-warm-dark: #92400e;
	--mb-warm-light: #F5E6D3;
	--mb-bg: #FDFAF6;
	--mb-card: #FFFFFF;
	--mb-text: #1a1a2e;
	--mb-text-muted: #6b7280;
	--mb-bubble-bot: #FFF8F0;
	--mb-accent: #2D5A3D;
	--mb-border: #E8DDD0;
	--mb-shadow: 0 8px 32px rgba(139, 90, 43, 0.15);

	position: fixed;
	z-index: 999990;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	font-size: 14px;
	line-height: 1.5;
	color: var(--mb-text);
	-webkit-font-smoothing: antialiased;
}

/* ─── Trigger Button (bubble) ─── */
#meetb-assistent .mb-trigger {
	position: fixed;
	bottom: 90px;
	right: 20px;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	border: none;
	background: linear-gradient(135deg, var(--mb-warm), var(--mb-warm-dark));
	color: #fff;
	cursor: pointer;
	box-shadow: var(--mb-shadow);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 999991;
	/* Needed for badge positioning */
	overflow: visible;
}

#meetb-assistent .mb-trigger-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	flex-shrink: 0;
}

.mb-trigger:hover {
	transform: scale(1.08);
	box-shadow: 0 8px 36px rgba(139, 90, 43, 0.25);
}

/* Mobiel: boven de bottom bar */
@media (max-width: 768px) {
	#meetb-assistent .mb-trigger {
		bottom: 100px;
		right: 14px;
		width: 50px;
		height: 50px;
	}
}

/* ─── Notification Badge ─── */
#meetb-assistent .mb-badge {
	position: absolute;
	top: -5px;
	right: -5px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	border-radius: 999px;
	background: #ef4444;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	line-height: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #fff;
	box-sizing: border-box;
	flex-shrink: 0;
	white-space: nowrap;
	animation: mbPulse 2s ease-in-out infinite;
}

@keyframes mbPulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.15); }
}

/* ─── Proactive Teaser ─── */
#meetb-assistent .mb-teaser {
	position: fixed;
	bottom: 160px;
	right: 20px;
	max-width: 260px;
	padding: 10px 16px;
	background: #fff;
	color: #1a1a2e;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.4;
	border-radius: 14px 14px 4px 14px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
	border: 1px solid var(--mb-border);
	cursor: pointer;
	animation: mbSlideIn 0.4s ease-out;
	z-index: 999991;
}

#meetb-assistent .mb-teaser:hover {
	background: #f9f6f2;
}

@media (max-width: 768px) {
	#meetb-assistent .mb-teaser {
		display: none !important;
	}
}

@keyframes mbSlideIn {
	from { opacity: 0; transform: translateY(8px) scale(0.95); }
	to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ─── Chat Window ─── */
#meetb-assistent .mb-window {
	position: fixed;
	bottom: 156px;
	right: 20px;
	width: 380px;
	max-height: 520px;
	background: var(--mb-card);
	border-radius: 16px;
	box-shadow: var(--mb-shadow);
	border: 1px solid var(--mb-border);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	opacity: 0;
	transform: translateY(12px) scale(0.96);
	pointer-events: none;
	transition: opacity 0.25s ease, transform 0.25s ease;
	z-index: 999992;
}

#meetb-assistent .mb-window.mb-open {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

/* Mobiel: altijd volledig beeldvullend — geen keyboard-detectie nodig */
@media (max-width: 768px) {
	#meetb-assistent .mb-window {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		width: 100%;
		/* dvh = dynamic viewport height: krimpt automatisch als iOS keyboard verschijnt */
		height: 100dvh;
		max-height: 100dvh;
		border-radius: 0;
		padding-bottom: env(safe-area-inset-bottom, 0px);
		z-index: 999995;
		/* Schuift van onder omhoog */
		transform: translateY(100%);
		transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
		opacity: 1;
	}

	#meetb-assistent .mb-window.mb-open {
		transform: translateY(0);
		opacity: 1;
	}

	/* Input area: altijd onderaan, los van keyboard */
	#meetb-assistent .mb-input-area {
		padding-bottom: max(env(safe-area-inset-bottom, 8px), 8px);
	}

	/* Messages: scrollbaar, vult de ruimte */
	#meetb-assistent .mb-messages {
		flex: 1;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}

	/* Trigger blijft zichtbaar als chat dicht is */
	#meetb-assistent .mb-trigger {
		bottom: 100px;
		right: 14px;
		width: 50px;
		height: 50px;
	}
}

/* ─── Header ─── */
#meetb-assistent .mb-header {
	padding: 14px 16px;
	background: linear-gradient(135deg, var(--mb-warm), var(--mb-warm-dark));
	display: flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
}

#meetb-assistent .mb-header-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	flex-shrink: 0;
}

#meetb-assistent .mb-header-info {
	flex: 1;
}

#meetb-assistent .mb-header-title {
	color: #fff;
	font-weight: 600;
	font-size: 15px;
}

#meetb-assistent .mb-header-sub {
	color: rgba(255, 255, 255, 0.7);
	font-size: 12px;
}

#meetb-assistent .mb-header-close {
	background: rgba(255, 255, 255, 0.15);
	border: none;
	color: #fff;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	cursor: pointer;
	font-size: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s;
}

#meetb-assistent .mb-header-close:hover {
	background: rgba(255, 255, 255, 0.25);
}

/* ─── Messages ─── */
#meetb-assistent .mb-messages {
	flex: 1;
	overflow-y: auto;
	padding: 16px 14px 8px;
	background: var(--mb-bg);
	display: flex;
	flex-direction: column;
	gap: 10px;
}

#meetb-assistent .mb-msg {
	display: flex;
	gap: 8px;
	animation: mbFadeIn 0.3s ease-out;
}

#meetb-assistent .mb-msg-user {
	flex-direction: row-reverse;
}

#meetb-assistent .mb-msg-avatar {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--mb-warm), var(--mb-warm-dark));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	flex-shrink: 0;
	margin-top: 2px;
	box-shadow: 0 2px 6px rgba(200, 149, 108, 0.25);
}

#meetb-assistent .mb-bubble {
	max-width: 78%;
	padding: 10px 14px;
	font-size: 14px;
	line-height: 1.5;
	white-space: pre-wrap;
	word-break: break-word;
}

#meetb-assistent .mb-bubble-bot {
	background: var(--mb-bubble-bot);
	border: 1px solid var(--mb-border);
	border-radius: 2px 14px 14px 14px;
	color: var(--mb-text);
}

#meetb-assistent .mb-bubble-user {
	background: var(--mb-accent);
	border-radius: 14px 2px 14px 14px;
	color: #fff;
	box-shadow: 0 2px 8px rgba(45, 90, 61, 0.2);
}

/* ─── Quick Replies ─── */
#meetb-assistent .mb-quick-replies {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	padding: 0 0 4px 38px;
}

#meetb-assistent .mb-quick-btn {
	padding: 6px 14px;
	border-radius: 20px;
	border: 1.5px solid var(--mb-warm);
	background: transparent;
	color: var(--mb-warm-dark);
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s;
	font-family: inherit;
}

#meetb-assistent .mb-quick-btn:hover {
	background: var(--mb-warm-light);
	border-color: var(--mb-warm-dark);
}

/* ─── Typing Indicator ─── */
#meetb-assistent .mb-typing {
	display: flex;
	gap: 4px;
	padding: 8px 0;
	align-items: center;
}

#meetb-assistent .mb-typing-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--mb-warm);
	opacity: 0.4;
	animation: mbBounce 1.2s ease-in-out infinite;
}

#meetb-assistent .mb-typing-dot:nth-child(2) { animation-delay: 0.15s; }
#meetb-assistent .mb-typing-dot:nth-child(3) { animation-delay: 0.3s; }

/* ─── Input Area ─── */
#meetb-assistent .mb-input-area {
	padding: 12px 14px;
	border-top: 1px solid var(--mb-border);
	background: var(--mb-card);
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}

#meetb-assistent .mb-input {
	flex: 1;
	padding: 10px 14px;
	border-radius: 24px;
	border: 1.5px solid var(--mb-border);
	outline: none;
	font-size: 14px;
	font-family: inherit;
	color: var(--mb-text);
	background: var(--mb-bg);
	transition: border-color 0.2s;
}

#meetb-assistent .mb-input:focus {
	border-color: var(--mb-warm);
}

#meetb-assistent .mb-input::placeholder {
	color: var(--mb-text-muted);
}

#meetb-assistent .mb-send {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: none;
	background: var(--mb-border);
	color: var(--mb-text-muted);
	font-size: 18px;
	cursor: default;
	transition: background 0.2s, color 0.2s;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

#meetb-assistent .mb-send.mb-active {
	background: linear-gradient(135deg, var(--mb-accent), #1a3d28);
	color: #fff;
	cursor: pointer;
}

/* ─── Company Cards ─── */
#meetb-assistent .mb-company-card {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 12px;
	margin: 6px 0;
	background: #f5f0eb;
	border-radius: 10px;
	border: 1px solid var(--mb-border);
	text-decoration: none;
	color: var(--mb-text);
	transition: background 0.2s;
}

#meetb-assistent .mb-company-card:hover {
	background: #ede7df;
}

/* ─── Rating Buttons ─── */
#meetb-assistent .mb-rating {
	display: flex;
	gap: 4px;
	margin-top: 8px;
	padding-top: 6px;
	border-top: 1px solid var(--mb-border);
}

#meetb-assistent .mb-rate-btn {
	background: transparent;
	border: 1px solid var(--mb-border);
	border-radius: 14px;
	padding: 2px 10px;
	font-size: 13px;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s;
	font-family: inherit;
	line-height: 1.6;
}

#meetb-assistent .mb-rate-btn:hover {
	background: var(--mb-warm-light);
	border-color: var(--mb-warm);
}

#meetb-assistent .mb-rated {
	font-size: 12px;
	color: var(--mb-text-muted);
	padding-top: 2px;
}

/* ─── Animations ─── */
@keyframes mbFadeIn {
	from { opacity: 0; transform: translateY(6px); }
	to { opacity: 1; transform: translateY(0); }
}

@keyframes mbBounce {
	0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
	30% { transform: translateY(-5px); opacity: 1; }
}

/* ─── PWA install banner aanwezig: widget omhoog (alleen desktop) ─── */
body.meetb-pwa-banner-visible #meetb-assistent .mb-trigger,
body.meetb-pwa-banner-visible #meetb-assistent .mb-teaser {
	bottom: 180px;
	transition: bottom 0.3s ease;
}
body.meetb-pwa-banner-visible #meetb-assistent .mb-window {
	bottom: 240px;
	transition: bottom 0.3s ease;
}
@media (max-width: 768px) {
	/* Mobiel: widget blijft op vaste positie, PWA banner schuift los ervan */
	body.meetb-pwa-banner-visible #meetb-assistent .mb-trigger,
	body.meetb-pwa-banner-visible #meetb-assistent .mb-teaser {
		bottom: 100px;
	}
	body.meetb-pwa-banner-visible #meetb-assistent .mb-window {
		bottom: 0;
	}
}

/* Markdown rendering in bot berichten */
#meetb-assistent .mb-bubble-bot p { margin: 0 0 6px; line-height: 1.5; }
#meetb-assistent .mb-bubble-bot p:last-child { margin-bottom: 0; }
#meetb-assistent .mb-bubble-bot strong { font-weight: 700; }
#meetb-assistent .mb-bubble-bot em { font-style: italic; }
#meetb-assistent .mb-bubble-bot code { background: #f0ebe4; border-radius: 3px; padding: 1px 5px; font-family: monospace; font-size: 12px; }
#meetb-assistent .mb-bubble-bot ul.mb-md-list { margin: 4px 0 6px 16px; padding: 0; list-style: disc; }
#meetb-assistent .mb-bubble-bot ul.mb-md-list li { margin-bottom: 3px; line-height: 1.5; }
#meetb-assistent .mb-bubble-bot br { display: block; content: ''; margin-top: 4px; }

/* Verberg assistent FAB als messaging sidebar open is */
body.meetb-msg-active #meetb-assistent {
	display: none !important;
}
