/* ============================================================
   Messenger Modern UI — Complete Redesign v4
   Loaded after dist/css/messenger.css — CSS-only, no JS changes.
   Primary accent: var(--lw-primary-color, #e10b2d)
   ============================================================ */

/* ── Design tokens ─────────────────────────────────────────── */
#messengerDialog {
	--lw-m-bg:           #f0f2f5;
	--lw-m-surface:      #ffffff;
	--lw-m-sidebar-bg:   #ffffff;
	--lw-m-header-bg:    #ffffff;
	--lw-m-border:       #e8eaed;
	--lw-m-text:         #1a1a2e;
	--lw-m-muted:        #8a8fa3;
	--lw-m-bubble-in:    #ffffff;
	--lw-m-bubble-in-t:  #1a1a2e;
	--lw-m-bubble-out:   var(--lw-primary-color, #e10b2d);
	--lw-m-bubble-out-t: #ffffff;
	--lw-m-input-bg:     #f0f2f5;
	--lw-m-header-h:     72px;
	--lw-m-ctrl-h:       44px;
	--lw-m-icon-btn:     40px;
	--lw-m-gap:          8px;
	--lw-m-radius:       20px;
}

/* ── Bootstrap modal-header theming ───────────────────────── */
#messengerDialog .modal-header {
	background: linear-gradient(135deg, var(--lw-primary-color, #e10b2d) 0%, #ff4d6d 100%) !important;
	border-bottom: none !important;
	padding: 12px 16px !important;
	align-items: center !important;
}
#messengerDialog .modal-header .modal-title {
	color: #ffffff !important;
	font-weight: 700 !important;
	font-size: 1.05rem !important;
	letter-spacing: 0.01em;
}
#messengerDialog .modal-header .close {
	color: #ffffff !important;
	opacity: 0.85 !important;
	text-shadow: none !important;
	font-size: 1.4rem !important;
	line-height: 1;
	margin: -4px -4px -4px auto !important;
	padding: 4px 8px !important;
	border-radius: 50%;
	transition: background 0.15s, opacity 0.15s;
}
#messengerDialog .modal-header .close:hover {
	opacity: 1 !important;
	background: rgba(255,255,255,0.18);
}
#messengerDialog .modal-header #lwChatSidebarToggle {
	color: #ffffff !important;
	background: rgba(255,255,255,0.18);
	border-radius: 50%;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	margin-right: 10px;
	flex-shrink: 0;
}
#messengerDialog .modal-header #lwChatSidebarToggle i {
	color: #ffffff;
}

/* ── Columns fill full height ──────────────────────────────── */
#messengerDialog .lw-messenger > .row {
	height: 100%;
}

/* ── Root messenger container ──────────────────────────────── */
#messengerDialog .lw-messenger {
	background-color: var(--lw-m-bg);
	color: var(--lw-m-text);
	text-shadow: none;
	position: relative;
	height: 100%;
	overflow: hidden;
}

/* ╔══════════════════════════════╗
   ║         SIDEBAR              ║
   ╚══════════════════════════════╝ */

#messengerDialog .lw-messenger .lw-messenger-sidebar {
	background-color: var(--lw-m-sidebar-bg);
	border-right: 1px solid var(--lw-m-border);
	height: 100%;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	padding-top: var(--lw-m-header-h);
}

#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list {
	margin-top: 0 !important;
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

/* Search bar */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-search {
	padding: 12px 14px 8px;
	flex: 0 0 auto;
}

#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-search .form-control {
	background-color: var(--lw-m-input-bg);
	border-radius: 999px;
	border: 1.5px solid transparent;
	padding: 8px 18px;
	font-size: 0.875rem;
	color: var(--lw-m-text);
	transition: border-color 0.2s;
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-search .form-control:focus {
	border-color: var(--lw-primary-color, #e10b2d);
	box-shadow: 0 0 0 3px rgba(225,11,45,0.1);
	outline: none;
}

/* Contact list */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group {
	padding: 6px 10px 80px;
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	height: auto;
	max-height: none;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: var(--lw-m-border) transparent;
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group::-webkit-scrollbar { width: 3px; }
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group::-webkit-scrollbar-thumb { background: var(--lw-m-border); border-radius: 99px; }

/* Contact row */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item.list-group-item-action {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	border: none;
	border-radius: 14px;
	margin-bottom: 2px;
	background-color: transparent;
	color: var(--lw-m-text);
	text-decoration: none;
	font-size: 0.9rem;
	font-weight: 500;
	transition: background 0.15s;
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item.list-group-item-action:not(.active):hover {
	background-color: var(--lw-m-bg);
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item.list-group-item-action.active {
	background: linear-gradient(135deg, var(--lw-primary-color, #e10b2d) 0%, #ff4d6d 100%);
	color: #fff;
}

/* Contact avatar */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list img.lw-profile-picture {
	width: 46px;
	height: 46px;
	min-width: 46px;
	border: 0;
	padding: 0;
	border-radius: 50%;
	object-fit: cover;
}

/* Online dot */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list span.lw-contact-status {
	left: 44px;
	top: 44px;
	width: 11px;
	height: 11px;
	border: 2px solid var(--lw-m-sidebar-bg);
	box-sizing: content-box;
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item.active span.lw-contact-status {
	border-color: var(--lw-primary-color, #e10b2d);
}

/* Unread badge */
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item .badge {
	margin-left: auto;
	min-width: 20px;
	height: 20px;
	border-radius: 99px;
	font-size: 0.7rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--lw-primary-color, #e10b2d) !important;
	color: #fff;
}
#messengerDialog .lw-messenger .lw-messenger-sidebar .lw-messenger-contact-list .list-group-item.active .badge {
	background-color: #fff !important;
	color: var(--lw-primary-color, #e10b2d);
}

/* ╔══════════════════════════════╗
   ║         HEADER               ║
   ╚══════════════════════════════╝ */

#messengerDialog .lw-messenger .lw-messenger-header {
	background: linear-gradient(135deg, var(--lw-primary-color, #e10b2d) 0%, #ff4d6d 100%) !important;
	color: #fff !important;
	border-bottom: none !important;
	height: var(--lw-m-header-h) !important;
	display: flex;
	align-items: center;
	padding: 0 16px !important;
	gap: 12px;
	box-shadow: 0 3px 16px rgba(225,11,45,0.28);
	position: relative !important;
	width: 100% !important;
	padding-top: calc(10px + env(safe-area-inset-top, 0px)) !important;
	margin-left: 0 !important;
}

#messengerDialog .lw-messenger .lw-messenger-header > .col-md-11 {
	display: flex;
	align-items: center;
	gap: 12px;
	max-width: 100%;
	flex: 1;
	padding: 0;
}

/* Header avatar */
#messengerDialog .lw-messenger .lw-messenger-header img.lw-profile-picture {
	width: 44px !important;
	height: 44px !important;
	min-width: 44px;
	border-radius: 50%;
	object-fit: cover;
	float: none !important;
	padding: 0 !important;
	border: 2.5px solid rgba(255,255,255,0.7) !important;
	margin-top: 0 !important;
	box-shadow: 0 0 0 2px rgba(255,255,255,0.25);
}

/* Header meta text */
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-header-meta {
	margin: 0 !important;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-header-meta > *:first-child {
	font-weight: 700;
	font-size: 0.97rem;
	line-height: 1.2;
	color: #fff !important;
}
#messengerDialog .lw-messenger .lw-messenger-header .text-muted {
	color: rgba(255,255,255,0.75) !important;
	font-size: 0.8rem !important;
}

/* Header actions */
#messengerDialog .lw-messenger .lw-messenger-header .float-right {
	float: none !important;
	display: flex;
	align-items: center;
	gap: 6px;
	margin-left: auto;
	padding: 0 !important;
}

#messengerDialog .lw-messenger .lw-messenger-header .btn.rounded-circle,
#messengerDialog .lw-messenger .lw-messenger-header .btn.rounded-circle.lw-button-width {
	background-color: rgba(255,255,255,0.18) !important;
	border: 1.5px solid rgba(255,255,255,0.35) !important;
	width: 38px !important;
	height: 38px !important;
	min-width: 38px;
	padding: 0 !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	transition: background 0.15s, border-color 0.15s;
}
#messengerDialog .lw-messenger .lw-messenger-header .btn.rounded-circle i {
	margin: 0 !important;
	color: #fff !important;
}
#messengerDialog .lw-messenger .lw-messenger-header .btn.rounded-circle:hover {
	background-color: rgba(255,255,255,0.32) !important;
	border-color: rgba(255,255,255,0.6) !important;
}
#messengerDialog .lw-messenger .lw-messenger-header .btn.rounded-circle:hover i {
	color: #fff !important;
}

/* Kebab menu */
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-user-menu {
	float: none;
	margin-left: 0;
}
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-user-menu .btn {
	background-color: rgba(255,255,255,0.18) !important;
	border: 1.5px solid rgba(255,255,255,0.35) !important;
	width: 38px;
	height: 38px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50% !important;
	transition: background 0.15s;
}
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-user-menu .btn:hover {
	background-color: rgba(255,255,255,0.32) !important;
}
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-user-menu .btn::after { display: none; }
#messengerDialog .lw-messenger .lw-messenger-header .lw-messenger-user-menu .btn i {
	color: #fff !important;
	margin: 0 !important;
}

/* Dropdown */
#messengerDialog .lw-messenger .lw-messenger-header .dropdown-menu {
	border-radius: 14px;
	border: 1px solid var(--lw-m-border);
	box-shadow: 0 8px 24px rgba(0,0,0,0.12);
	padding: 6px 0;
	min-width: 170px;
}
#messengerDialog .lw-messenger .lw-messenger-header .dropdown-menu .dropdown-item {
	padding: 9px 18px;
	font-size: 0.88rem;
	color: var(--lw-m-text);
	display: flex;
	align-items: center;
	gap: 8px;
}
#messengerDialog .lw-messenger .lw-messenger-header .dropdown-menu .dropdown-item:hover {
	background-color: var(--lw-m-bg);
}

/* ╔══════════════════════════════╗
   ║       CHAT CONTENT AREA      ║
   ╚══════════════════════════════╝ */

#messengerDialog .lw-messenger .lw-messenger-content {
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	padding: 0;
}

#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window {
	flex: 1 1 auto;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	background-color: var(--lw-m-bg);
	background-image: radial-gradient(circle, rgba(0,0,0,0.04) 1px, transparent 1px);
	background-size: 22px 22px;
	/* right padding = avatar (32px) + gap (8px) + buffer (12px) so the avatar never clips */
	padding: 16px 52px 24px 16px !important;
	scrollbar-width: thin;
	scrollbar-color: var(--lw-m-border) transparent;
	height: auto !important;
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window::-webkit-scrollbar { width: 3px; }
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window::-webkit-scrollbar-thumb { background: var(--lw-m-border); border-radius: 99px; }

/* ╔══════════════════════════════╗
   ║       MESSAGE BUBBLES        ║
   ╚══════════════════════════════╝ */

/* Neutralise Bootstrap .row (-15px margins) and .col-md-12 (15px padding)
   that live on .lw-messenger-chat-message and cause avatar clipping */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-message {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: flex-end !important;
	gap: 8px;
	margin: 0 0 6px !important;   /* kill Bootstrap .row -15px side margins */
	padding: 0 !important;        /* kill Bootstrap .col-md-12 15px side padding */
	width: 100% !important;
	overflow: visible !important; /* never clip avatars */
}

#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-sender {
	justify-content: flex-end !important;
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-recipient {
	justify-content: flex-start !important;
}

/* Chat-window avatar — clean circle, never clipped */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window img.lw-profile-picture {
	width: 32px !important;
	height: 32px !important;
	min-width: 32px !important;
	max-width: 32px !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	border: 2px solid var(--lw-m-border) !important;
	margin: 0 !important;
	padding: 0 !important;
	align-self: flex-end !important;
	flex-shrink: 0 !important;
	display: block !important;  /* always show; ensure lazy-img doesn't hide it */
	overflow: hidden !important;
	box-sizing: border-box !important;
	float: none !important;
}
/* Sender avatar: smaller, right-side tint */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-sender img.lw-profile-picture {
	border-color: var(--lw-primary-color, #e10b2d) !important;
	opacity: 1;
}

/* Bubble base */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item {
	position: relative;
	width: auto !important;
	max-width: 72%;
	min-height: auto !important;
	padding: 10px 14px 7px;
	font-weight: 400;
	font-size: 0.9rem;
	line-height: 1.45;
	word-break: break-word;
	box-shadow: 0 2px 6px rgba(0,0,0,0.07);
	border-radius: var(--lw-m-radius) !important;
	margin: 0 !important;
}

/* Remove old speech-tail arrows */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item::after,
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item::before {
	display: none !important;
}

/* Images in bubbles */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item img:not(.emojioneemoji) {
	border-radius: 14px;
	max-height: 200px;
	width: 100%;
	object-fit: cover;
}

/* Received bubble */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-recipient .lw-messenger-chat-item {
	background-color: var(--lw-m-bubble-in) !important;
	color: var(--lw-m-bubble-in-t) !important;
	margin-left: 0 !important;
	border-bottom-left-radius: 4px !important;
}

/* Sent bubble */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-sender .lw-messenger-chat-item {
	background: var(--lw-primary-color, #e10b2d) !important;
	color: #fff !important;
	margin-right: 0 !important;
	border-bottom-right-radius: 4px !important;
}

/* Timestamp */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item .lw-messenger-chat-meta {
	display: block;
	font-size: 0.72rem;
	margin-top: 4px;
	padding: 0;
	border-top: none !important;
	font-style: normal;
	opacity: 0.7;
	white-space: nowrap;
	line-height: 1;
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-recipient .lw-messenger-chat-item .lw-messenger-chat-meta {
	color: var(--lw-m-muted);
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-sender .lw-messenger-chat-item .lw-messenger-chat-meta {
	color: rgba(255,255,255,0.8) !important;
}

/* Delete × icon — reveal on hover */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item .lw-single-message-delete {
	opacity: 0;
	transition: opacity 0.15s;
	right: 4px;
	top: 2px;
	font-size: 0.85rem;
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item:hover .lw-single-message-delete {
	opacity: 0.7;
}
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item .lw-single-message-delete:hover {
	opacity: 1;
}

/* New message pop animation */
#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item.lw-messenger-new-message {
	animation: lwMsgPop 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes lwMsgPop {
	from { opacity: 0; transform: translateY(12px) scale(0.94); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ╔══════════════════════════════╗
   ║          FOOTER              ║
   ╚══════════════════════════════╝ */

#messengerDialog .lw-messenger .lw-messenger-footer {
	flex: 0 0 auto;
	position: relative !important;
	width: 100% !important;
	bottom: auto !important;
	background-color: var(--lw-m-surface) !important;
	border-top: 1px solid var(--lw-m-border);
	padding: 10px 14px !important;
	padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px)) !important;
}

/* Input pill wrapper */
#messengerDialog .lw-messenger .lw-messenger-footer .input-group {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: var(--lw-m-gap);
	width: 100%;
	background: var(--lw-m-input-bg);
	border-radius: 999px;
	padding: 4px 4px 4px 14px;
	border: 1.5px solid var(--lw-m-border);
	transition: border-color 0.2s, box-shadow 0.2s;
}
#messengerDialog .lw-messenger .lw-messenger-footer .input-group:focus-within {
	border-color: var(--lw-primary-color, #e10b2d);
	box-shadow: 0 0 0 3px rgba(225,11,45,0.1);
}

/* Text field */
#messengerDialog .lw-messenger .lw-messenger-footer .form-control {
	height: auto !important;
	min-height: var(--lw-m-ctrl-h);
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
	color: var(--lw-m-text);
	padding: 6px 4px;
	font-size: 0.92rem;
	min-width: 0;
	flex: 1;
	border-radius: 0 !important;
}
#messengerDialog .lw-messenger .lw-messenger-footer .form-control::placeholder {
	color: var(--lw-m-muted);
}
#messengerDialog .lw-messenger .lw-messenger-footer .form-control:focus {
	background-color: transparent !important;
	border-color: transparent !important;
	box-shadow: none !important;
}

/* Append icon buttons */
#messengerDialog .lw-messenger .lw-messenger-footer .input-group-append {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-left: 0 !important;
	flex: 0 0 auto;
}

#messengerDialog .lw-messenger .lw-messenger-footer .input-group-append .btn,
#messengerDialog .lw-messenger .lw-messenger-footer .input-group-append .input-group-text {
	width: var(--lw-m-icon-btn);
	height: var(--lw-m-icon-btn);
	min-width: var(--lw-m-icon-btn);
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50% !important;
	border: none;
	background: transparent;
	color: var(--lw-m-muted);
	font-size: 1rem;
	transition: background 0.15s, color 0.15s;
}
#messengerDialog .lw-messenger .lw-messenger-footer .input-group-append .btn:hover,
#messengerDialog .lw-messenger .lw-messenger-footer .input-group-append .input-group-text:hover {
	background: var(--lw-m-bg);
	color: var(--lw-primary-color, #e10b2d);
}

#messengerDialog .lw-messenger .lw-messenger-footer .btn.btn-outline-secondary {
	background: transparent !important;
	border: none !important;
	color: var(--lw-m-muted);
}
#messengerDialog .lw-messenger .lw-messenger-footer .btn.btn-outline-secondary:hover,
#messengerDialog .lw-messenger .lw-messenger-footer .btn.btn-outline-secondary:focus {
	background-color: var(--lw-m-bg) !important;
	color: var(--lw-primary-color, #e10b2d) !important;
}

/* Send button */
#messengerDialog .lw-messenger .lw-messenger-footer #lwSendMessageButton {
	background: linear-gradient(135deg, var(--lw-primary-color, #e10b2d) 0%, #ff4d6d 100%) !important;
	border: none !important;
	border-radius: 50% !important;
	width: var(--lw-m-ctrl-h);
	height: var(--lw-m-ctrl-h);
	min-width: var(--lw-m-ctrl-h);
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	box-shadow: 0 3px 10px rgba(225,11,45,0.35);
	transition: transform 0.15s, box-shadow 0.15s;
}
#messengerDialog .lw-messenger .lw-messenger-footer #lwSendMessageButton:hover {
	transform: scale(1.08);
	box-shadow: 0 5px 14px rgba(225,11,45,0.45);
}
#messengerDialog .lw-messenger .lw-messenger-footer #lwSendMessageButton i {
	margin: 0 !important;
	font-size: 1rem;
}

/* Loader */
#messengerDialog .lw-messenger .lw-messenger-footer #lwUploadingLoader {
	background: transparent !important;
	border: none !important;
	color: var(--lw-m-muted) !important;
}

/* FilePond upload */
#messengerDialog .lw-messenger .lw-messenger-footer .lw-messenger-file-upload {
	margin-left: 0 !important;
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
#messengerDialog .lw-messenger .lw-messenger-footer .lw-messenger-file-upload .filepond--drop-label {
	width: 100% !important;
	height: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
}
#messengerDialog .lw-messenger .lw-messenger-footer .lw-messenger-file-upload .filepond--drop-label label { margin: 0; }
#messengerDialog .lw-messenger .lw-messenger-footer .lw-messenger-file-upload label i { margin: 0 !important; }
#messengerDialog .lw-messenger .lw-messenger-footer .lw-open-gif-action i { margin-top: 0 !important; }

/* Hide sticker button */
#messengerDialog .lw-messenger .lw-messenger-footer .lw-open-stickers-action { display: none !important; }

/* EmojiOneArea inside footer */
#messengerDialog .lw-messenger .lw-messenger-footer .emojionearea.emojionearea-inline {
	flex: 1;
	border: none !important;
	background: transparent !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	height: var(--lw-m-ctrl-h);
}
#messengerDialog .lw-messenger .lw-messenger-footer .emojionearea .emojionearea-editor {
	padding: 10px 40px 10px 4px !important;
	color: var(--lw-m-text) !important;
	font-size: 0.92rem !important;
}

/* ╔══════════════════════════════╗
   ║     GIF / STICKER SHEET      ║
   ╚══════════════════════════════╝ */

#messengerDialog .lw-messenger .lw-messenger-bottom-sheet.lw-open {
	border-radius: 24px 24px 0 0;
	box-shadow: 0 -4px 24px rgba(0,0,0,0.12);
	overflow: hidden;
}
#messengerDialog .lw-messenger .lw-messenger-bottom-sheet .lw-heading {
	background: var(--lw-m-surface);
	border-bottom: 1px solid var(--lw-m-border);
}

/* ╔══════════════════════════════╗
   ║        SAFE AREA / PWA       ║
   ╚══════════════════════════════╝ */

/* Fill real viewport — 100dvh with 100vh + svh fallbacks */
#messengerDialog.modal {
	height: 100vh !important;
	height: 100svh !important;
	height: 100dvh !important;
	max-height: 100vh !important;
	max-height: 100dvh !important;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
}
#messengerDialog .modal-dialog {
	/* zero out Bootstrap's centering margin so dialog fills the whole screen */
	margin: 0 !important;
	padding: 0 !important;
	width: 100% !important;
	max-width: 100% !important;
	height: 100%;
	/* push content down / up for notch + home bar */
	padding-top: env(safe-area-inset-top, 0px) !important;
	padding-bottom: env(safe-area-inset-bottom, 0px) !important;
	padding-left: env(safe-area-inset-left, 0px) !important;
	padding-right: env(safe-area-inset-right, 0px) !important;
	box-sizing: border-box !important;
}
#messengerDialog .modal-dialog .modal-content {
	height: 100%;
	border-radius: 0;
	overflow: hidden;
	border: none;
}
#messengerDialog .modal-dialog .modal-content .lw-messenger {
	height: 100% !important;
	max-height: none !important;
	min-height: 0;
}
/* On landscape mobile: cap the dialog width so it looks intentional */
@media (max-width: 767.98px) and (orientation: landscape) {
	#messengerDialog .modal-dialog {
		max-width: 100% !important;
	}
}

/* ╔══════════════════════════════╗
   ║         RESPONSIVE           ║
   ╚══════════════════════════════╝ */

@media (max-width: 767.98px) {
	#messengerDialog {
		--lw-m-header-h: 68px;
	}
	#messengerDialog .lw-messenger .lw-messenger-sidebar {
		border-right: 0;
		top: 0;
		bottom: 0;
		height: auto;
		max-height: 100%;
		box-shadow: 4px 0 20px rgba(0,0,0,0.1);
		border-radius: 0 20px 20px 0;
	}
	#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window {
		padding-left: 10px !important;
		padding-right: 10px !important;
	}
	#messengerDialog .lw-messenger .lw-messenger-content .lw-messenger-chat-window .lw-messenger-chat-item {
		max-width: 86%;
	}
}

@media (max-width: 420px) {
	#messengerDialog {
		--lw-m-ctrl-h:   40px;
		--lw-m-icon-btn: 36px;
		--lw-m-gap:       4px;
	}
}

/* ╔══════════════════════════════╗
   ║      EMOJI PICKER            ║
   ╚══════════════════════════════╝ */

.emojionearea {
	border: none !important;
	background: transparent !important;
	box-shadow: none !important;
}
.emojionearea.focused {
	border-color: transparent !important;
	box-shadow: none !important;
}
.emojionearea .emojionearea-button {
	right: 10px !important;
	bottom: 8px !important;
	opacity: 0.55 !important;
	width: 26px !important;
	height: 26px !important;
	transition: opacity 0.15s, transform 0.15s !important;
}
.emojionearea .emojionearea-button:hover {
	opacity: 1 !important;
	transform: scale(1.15) rotateZ(8deg) !important;
}
.emojionearea .emojionearea-dropdown {
	width: 330px !important;
	border: none !important;
	border-radius: 20px !important;
	box-shadow: 0 0 0 1px rgba(0,0,0,0.06), 0 8px 30px -4px rgba(0,0,0,0.16) !important;
	background: #fff !important;
	overflow: hidden !important;
	padding: 0 !important;
	animation: lwEmojiPop 0.22s cubic-bezier(0.34,1.4,0.64,1) both !important;
}
@keyframes lwEmojiPop {
	from { opacity: 0; transform: translateY(12px) scale(0.93); }
	to   { opacity: 1; transform: none; }
}
.emojionearea .emojionearea-dropdown::before {
	content: '' !important;
	display: block !important;
	height: 3px !important;
	background: linear-gradient(90deg, var(--lw-primary-color, #e10b2d) 0%, #ff6b6b 50%, #ffd93d 100%) !important;
}
.emojionearea .emojionearea-search { display: none !important; }
.emojionearea .emojionearea-filter {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 6px 8px 0 !important;
	background: #fff !important;
	border-bottom: 2px solid #f3f4f6 !important;
	overflow-x: auto !important;
	scrollbar-width: none !important;
}
.emojionearea .emojionearea-filter::-webkit-scrollbar { display: none !important; }
.emojionearea .emojionearea-filter .emojionearea-filter-item {
	flex: 1 1 0 !important;
	height: 36px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 18px !important;
	opacity: 0.4 !important;
	border-bottom: 2px solid transparent !important;
	margin-bottom: -2px !important;
	transition: opacity 0.15s, border-color 0.15s !important;
	cursor: pointer !important;
}
.emojionearea .emojionearea-filter .emojionearea-filter-item:hover { opacity: 0.75 !important; }
.emojionearea .emojionearea-filter .emojionearea-filter-item.active {
	opacity: 1 !important;
	border-bottom-color: var(--lw-primary-color, #e10b2d) !important;
}
.emojionearea .emojionearea-scroll-area {
	height: 252px !important;
	overflow-y: auto !important;
	padding: 4px 6px 8px !important;
	scrollbar-width: thin !important;
	scrollbar-color: #e5e7eb transparent !important;
}
.emojionearea .emojionearea-scroll-area::-webkit-scrollbar { width: 3px !important; }
.emojionearea .emojionearea-scroll-area::-webkit-scrollbar-thumb { background: #dde1e7 !important; border-radius: 99px !important; }
.emojionearea .emojionearea-category-title {
	font-size: 0.62rem !important;
	font-weight: 800 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.8px !important;
	color: #c4c9d4 !important;
	padding: 10px 6px 2px !important;
	margin: 0 !important;
	display: block !important;
}
.emojionearea .emojionearea-scroll-area .emojibtn {
	width: 38px !important;
	height: 38px !important;
	border-radius: 12px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: background 0.12s, transform 0.12s !important;
	cursor: pointer !important;
}
.emojionearea .emojionearea-scroll-area .emojibtn:hover {
	background: #f5f6fa !important;
	transform: scale(1.28) translateY(-2px) !important;
}
.emojionearea .emojionearea-scroll-area .emojibtn:active { transform: scale(0.92) !important; }
.emojionearea .emojionearea-picker.emojionearea-picker-position-top {
	bottom: calc(100% + 10px) !important;
	top: auto !important;
}
.emojionearea .emojionearea-picker-position-top { right: 0; left: 0; }
@media (max-width: 420px) {
	.emojionearea .emojionearea-dropdown { width: calc(100vw - 20px) !important; border-radius: 18px !important; }
	.emojionearea .emojionearea-scroll-area { height: 216px !important; }
	.emojionearea .emojionearea-filter .emojionearea-filter-item { font-size: 15px !important; height: 30px !important; }
}
