/* Message badge */
.bm-menu-content { position: relative; display: inline-flex; align-items: center; gap: 6px; }
.bm-unread-badge { position: absolute; top: -6px; right: -14px; border-radius: 12px; min-width: 20px; padding: 0 6px; height: 20px; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; line-height: 1; background: #ef4444; color: #fff; border: 2px solid #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.12); }
.bm-unread-badge.bm-hidden { display: none; }

/* --- DESIGN TOKENS (BUDDYBOSS THEME) --- */
:root {
  --kln-primary: #FF703D;       /* BuddyBoss Orange */
  --kln-primary-hover: #e5633a; /* Darker orange */
  --kln-bg-unread: #fff7f5;     /* Soft orange tint */
  --kln-bg-hover: #faf9f7;      /* BuddyBoss bg */
  --kln-border-focus: #ffcdb8;  /* Light orange */
  --kln-text-main: #393E41;     /* BuddyBoss body text */
  --kln-text-muted: #AAAAAA;    /* BuddyBoss alternate text */
  --kln-border: #E0DFDB;        /* BuddyBoss border */
  --kln-link: #2563eb;          /* BuddyBoss link blue */
}

/* Notifications badge bubble (match Figma Make layout) */
li.kleo-toggle-menu .kln-toggle { position: relative !important; display: inline-flex !important; align-items: center !important; }
li.kleo-toggle-menu .kln-bubble { position: absolute !important; right: -12px !important; left: auto !important; inset-inline-end: -12px !important; inset-inline-start: auto !important; float: none !important; width: 20px !important; height: 20px !important; border-radius: 100% !important; border: 2px solid #fff !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; font-size: 10px !important; font-weight: 700 !important; line-height: 1 !important; background: var(--kln-primary) !important; color: #fff !important; box-shadow: 0 2px 6px rgba(255, 112, 61, 0.4) !important; }
li.kleo-toggle-menu .kln-bubble[hidden] { display: none !important; }
li.kleo-toggle-menu .kln-chevron { position: absolute !important; top: 50% !important; right: -18px !important; width: 14px !important; height: 14px !important; display: inline-block !important; opacity: 0.75 !important; transform: translateY(-50%) !important; pointer-events: none !important; }
li.kleo-toggle-menu > a.notify-contents[aria-expanded="true"] .kln-chevron { transform: translateY(-50%) rotate(180deg) !important; opacity: 1 !important; }
li.kleo-toggle-menu.open .kln-chevron { transform: translateY(-50%) rotate(180deg) !important; opacity: 1 !important; }

/* Notifications toggle tooltip (custom styled, instant, closed-only) */
li.kleo-toggle-menu > a.notify-contents[data-kln-tooltip] { position: relative !important; }
li.kleo-toggle-menu > a.notify-contents[data-kln-tooltip]::after {
  content: attr(data-kln-tooltip);
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  transform: translateX(-50%);
  background: rgba(17, 17, 17, 0.92);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  padding: 8px 12px;
  border-radius: 6px;
  white-space: nowrap;
  z-index: 20000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
li.kleo-toggle-menu > a.notify-contents[data-kln-tooltip]::before {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% + 4px);
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top: 0;
  border-bottom-color: rgba(17, 17, 17, 0.92);
  z-index: 20000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
li.kleo-toggle-menu > a.notify-contents[aria-expanded="false"][data-kln-tooltip]:hover::after,
li.kleo-toggle-menu > a.notify-contents[aria-expanded="false"][data-kln-tooltip]:focus-visible::after,
li.kleo-toggle-menu > a.notify-contents[aria-expanded="false"][data-kln-tooltip]:hover::before,
li.kleo-toggle-menu > a.notify-contents[aria-expanded="false"][data-kln-tooltip]:focus-visible::before {
  opacity: 1;
  visibility: visible;
}
li.kleo-toggle-menu > a.notify-contents.kln-tooltip-suppress::before,
li.kleo-toggle-menu > a.notify-contents.kln-tooltip-suppress::after {
  opacity: 0 !important;
  visibility: hidden !important;
}

/* Lift KLN notifications submenu above theme default (app.min.css sets z-index: 2) */
.kleo-toggle-menu .kleo-toggle-submenu.kln-submenu { z-index: 1700; top: 100%; margin-top: 14px; }

/* Lift Kleo messages submenu above theme default (same stacking issue as notifications) */
li.kleo-messages-nav.kleo-toggle-menu .kleo-toggle-submenu.dropdown-menu { z-index: 1700; top: 100%; margin-top: 14px; }

/* --- Better Messages dropdown (Kleo Live Messages replacement) --- */
.kleo-toggle-menu .kleo-toggle-submenu.kln-messages-submenu { z-index: 1700; top: 100%; margin-top: 14px; }

.kln-messages-panel .kln-header { border-bottom: 1px solid #f1f2f4; }
.kln-messages-list { margin: 0; padding: 0; list-style: none; max-height: 470px; overflow-y: auto; }

.kln-message-item { border-bottom: 1px solid #f1f2f4; display: flex; align-items: center; background: #fff; transition: background 0.15s ease; }
.kln-message-item:last-child { border-bottom: none; }
.kln-message-item:hover,
.kln-message-item:focus-within { background: var(--kln-bg-hover); }

.kln-message-link {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px 12px 14px;
	padding-right: 4px;
	text-decoration: none;
	color: inherit;
	background: transparent;
	flex: 1 1 auto;
	min-width: 0;
}

/* Actions container - holds expand + archive buttons */
.kln-message-actions {
	display: flex;
	align-items: center;
	gap: 4px;
	padding-right: 12px;
	flex-shrink: 0;
}

/* Expand button - chevron icon */
.kln-message-expand {
	appearance: none;
	border: 0;
	background: transparent;
	padding: 4px;
	cursor: pointer;
	display: none;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	border-radius: 4px;
	color: var(--kln-text-muted);
	transition: background 0.15s ease, color 0.15s ease;
	flex-shrink: 0;
	position: relative;
}

.kln-message-item.is-overflowing .kln-message-expand {
	display: inline-flex;
}

.kln-message-expand:hover {
	background: var(--kln-bg-hover);
	color: var(--kln-text-main);
}

.kln-message-expand:focus-visible {
	outline: 2px solid var(--kln-primary);
	outline-offset: 2px;
}

.kln-message-expand svg {
	width: 16px;
	height: 16px;
	transition: transform 0.2s ease;
}

.kln-message-item.is-expanded .kln-message-expand svg {
	transform: rotate(180deg);
}

/* Tooltip for expand button */
.kln-message-expand::before {
	content: attr(data-tooltip);
	position: absolute;
	right: calc(100% + 10px);
	top: 50%;
	transform: translateY(-50%) scale(0.98);
	background: rgba(15, 23, 42, 0.92);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	white-space: nowrap;
	padding: 6px 10px;
	border-radius: 10px;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.18s ease, transform 0.18s ease;
	z-index: 5;
}

.kln-message-expand:hover::before {
	opacity: 1;
	transform: translateY(-50%) scale(1);
}

.kln-message-avatar { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; flex-shrink: 0; position: relative; background: #f3f4f6; }
.kln-message-avatarImg { width: 100%; height: 100%; object-fit: cover; display: block; }

.kln-message-avatarStack { position: relative; display: block; width: 44px; height: 44px; }
.kln-message-avatarStack .kln-message-avatarImg { position: absolute; border-radius: 50%; border: 2px solid #fff; }
.kln-message-avatarStack .kln-message-avatarImg.is-front { width: 44px; height: 44px; left: 0; top: 0; z-index: 2; }
.kln-message-avatarStack .kln-message-avatarImg.is-back { width: 32px; height: 32px; left: 18px; top: 18px; z-index: 1; opacity: 0.95; }

.kln-message-content { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 2px; }
.kln-message-title { font-weight: 700; font-size: 15px; color: var(--kln-text-main); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kln-message-preview {
	color: var(--kln-text-muted);
	font-size: 13px;
	line-height: 1.25;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	max-height: 3.2em;
	transition: color 0.18s ease, max-height 0.22s ease, -webkit-line-clamp 0.22s ease;
	overflow-wrap: anywhere;
	word-break: break-word;
}


.kln-message-item.is-expanded .kln-message-preview {
	-webkit-line-clamp: unset;
	max-height: 420px;
	overflow: visible;
	white-space: normal;
}

.kln-message-unreadDot { width: 10px; height: 10px; border-radius: 50%; background: var(--kln-primary); flex-shrink: 0; margin-left: 10px; }

.kln-message-item.kln-loading,
.kln-message-item.kln-empty {
	padding: 16px 14px;
	color: var(--kln-text-muted);
	text-align: center;
	display: block;
}

/* Kleo theme dropdown styles can override anchors inside .dropdown-menu (e.g. `.top-menu .dropdown-menu a { display:block; padding:… }`).
   Force our inbox-row layout to stay intact. */
.kln-messages-submenu a.kln-message-link {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 12px 14px !important;
	line-height: normal !important;
	flex: 1 1 auto !important;
	min-width: 0 !important;
	width: auto !important;
}

/* Ensure the row itself is flex even under Kleo dropdown overrides */
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item {
	display: flex !important;
	align-items: center !important;
	flex-wrap: nowrap !important;
}

/* Theme override protection for actions container */
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item > .kln-message-actions {
	display: flex !important;
	align-items: center !important;
	gap: 4px !important;
	padding-right: 12px !important;
	flex-shrink: 0 !important;
}

li.kleo-toggle-menu .kln-messages-submenu .kln-message-item > .kln-message-actions .kln-message-expand {
	display: none !important;
}

li.kleo-toggle-menu .kln-messages-submenu .kln-message-item.is-overflowing > .kln-message-actions .kln-message-expand {
	display: inline-flex !important;
}
.kln-messages-submenu .kln-message-avatar {
	width: 44px !important;
	height: 44px !important;
	flex: 0 0 44px !important;
	overflow: hidden !important;
}
.kln-messages-submenu .kln-message-avatarImg {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
}

/* Remove theme dropdown-menu panel styling so only .kln-panel is visible */
li.kleo-toggle-menu .kleo-toggle-submenu.kln-submenu.dropdown-menu {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
li.kleo-toggle-menu .kleo-toggle-submenu.kln-messages-submenu.dropdown-menu {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}
li.kleo-toggle-menu .kleo-toggle-submenu.kln-submenu.dropdown-menu::before,
li.kleo-toggle-menu .kleo-toggle-submenu.kln-submenu.dropdown-menu::after {
  content: none !important;
}

/* Notifications panel styling */
.kln-panel { width: 380px; max-width: calc(100vw - 32px); background: #fff; border: 1px solid var(--kln-border); border-radius: 16px; box-shadow: 0 18px 38px -16px rgba(0,0,0,0.28), 0 10px 20px -14px rgba(0,0,0,0.18); overflow: hidden; }

.kln-header,
.kln-footer { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: #fff; }
.kln-header { border-bottom: 1px solid #f1f2f4; }

.kln-title { margin: 0; font-size: 17px; font-weight: 700; color: var(--kln-text-main); letter-spacing: -0.01em; }
.kln-count { font-size: 13px; color: var(--kln-text-muted); font-weight: 600; }

.kln-panel.kln-empty .kln-header-actions,
.kln-panel.kln-empty .kln-footer { display: none; }

.kln-header-actions { display: inline-flex; align-items: center; gap: 10px; }
.kln-mark-all { appearance: none; border: 0; background: transparent; color: var(--kln-primary); font-weight: 700; font-size: 13px; padding: 6px 10px; border-radius: 10px; cursor: pointer; transition: background 0.18s ease, color 0.18s ease, transform 0.1s ease; }
.kln-mark-all:hover { background: var(--kln-bg-unread); color: var(--kln-primary-hover); }
.kln-mark-all:active { transform: scale(0.98); }
.kln-mark-all:focus-visible { outline: 2px solid var(--kln-primary); outline-offset: 2px; }
.kln-mark-all[disabled] { opacity: 0.6; cursor: not-allowed; }

.kln-list { margin: 0; padding: 0; list-style: none; max-height: 470px; overflow-y: auto; }
.kln-list::-webkit-scrollbar { width: 8px; }
.kln-list::-webkit-scrollbar-track { background: #f5f6f8; border-radius: 10px; }
.kln-list::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 10px; }

.kln-item { display: flex; flex-wrap: nowrap; align-items: center; gap: 10px; padding: 10px 14px; border-bottom: 1px solid #f1f2f4; position: relative; background: #fff; transition: background 0.15s ease; }
.kln-item:last-child { border-bottom: none; }
.kln-item.unread { background: #fff; }
.kln-item:hover { background: var(--kln-bg-hover); }

.bm-unread-badge,
.kln-bubble,
.kln-badge { background: var(--kln-primary) !important; color: #fff !important; box-shadow: 0 2px 6px rgba(255, 112, 61, 0.4) !important; }

.kln-badge { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; line-height: 1; }

.kln-body { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; gap: 2px; }

.kln-text { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; color: var(--kln-text-main); font-size: 14px; font-weight: 600; text-decoration: none; margin: 0; }
.kln-text:hover { color: var(--kln-primary-hover); }
.kln-text:focus-visible { outline: 2px solid var(--kln-primary); outline-offset: 2px; border-radius: 6px; }

/* Theme override guard: menu dropdown link styles often add padding to <a> but not <span> */
li.kleo-toggle-menu .kln-body > a.kln-text { padding: 0 !important; }

.kln-time { display: block; font-size: 12px; line-height: 1.2; color: var(--kln-text-muted); margin-top: 0; }

/* --- DOT → EYE + TOOLTIP --- */
li.kleo-toggle-menu .kln-item { display: flex !important; flex-wrap: nowrap !important; align-items: center !important; }
li.kleo-toggle-menu .kln-panel button.kln-dot { appearance: none !important; -webkit-appearance: none !important; box-sizing: border-box !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; border: 0 !important; background: transparent !important; box-shadow: none !important; flex-shrink: 0 !important; margin: 0 0 0 auto !important; float: none !important; cursor: pointer !important; transition: none !important; position: relative !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; padding: 0 !important; line-height: 1 !important; font: inherit !important; text-transform: none !important; }
.kln-dot::after { content: ''; width: 10px; height: 10px; border-radius: 50%; background: var(--kln-primary); position: absolute; transition: opacity 0.12s ease; }
.kln-dot svg { width: 18px; height: 18px; color: var(--kln-text-muted); opacity: 0; transition: opacity 0.12s ease; pointer-events: none; }
.kln-item:hover .kln-dot::after { opacity: 0; }
.kln-item:hover .kln-dot svg { opacity: 1; }
.kln-dot:active { transform: none; }
.kln-dot:focus-visible { outline: 2px solid var(--kln-primary); outline-offset: 2px; }

.kln-dot::before { content: attr(data-tooltip); position: absolute; right: calc(100% + 10px); top: 50%; transform: translateY(-50%) scale(0.98); background: rgba(15, 23, 42, 0.92); color: #fff; font-size: 12px; font-weight: 700; white-space: nowrap; padding: 6px 10px; border-radius: 10px; opacity: 0; pointer-events: none; transition: opacity 0.18s ease, transform 0.18s ease; z-index: 5; }
.kln-dot:hover::before { opacity: 1; transform: translateY(-50%) scale(1); }

/* Messages dropdown: use same dot→eye affordance */
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item > .kln-message-actions > button.kln-message-seen { margin: 0 !important; }
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item > .kln-message-actions > button.kln-message-seen::after { opacity: 1; background: var(--kln-text-muted); }
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item > .kln-message-actions > button.kln-message-seen[data-unread="1"]::after { background: var(--kln-primary); }
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item:hover > .kln-message-actions > button.kln-message-seen::after { opacity: 0; }
li.kleo-toggle-menu .kln-messages-submenu .kln-message-item:hover > .kln-message-actions > button.kln-message-seen svg { opacity: 1; }

.kln-empty { justify-content: center; text-align: center; color: var(--kln-text-muted); }
.kln-footer { border-top: 1px solid #e7e7ea; justify-content: center; gap: 10px; }
.kln-view-all { font-size: 14px; font-weight: 700; color: var(--kln-primary); text-decoration: none; }
.kln-view-all:hover { color: var(--kln-primary-hover); }
.kln-view-all:focus-visible { outline: 2px solid var(--kln-primary); outline-offset: 2px; border-radius: 6px; }

.kleo-toggle-menu > a.notify-contents:focus-visible { outline: 2px solid var(--kln-primary); outline-offset: 4px; border-radius: 8px; }
