/* ============================================================
   Haya Al Alfalah — scaffoldBB theme bridge
   Matches main site: assets/css/styles.css (tokens + buttons)
   Edit only this file for small tweaks after install.
   ============================================================ */

/* ── Design tokens (aligned with main site) ───────────────── */
:root {
	--green-50: #f0faf3;
	--green-100: #d6f3de;
	--green-200: #aae3bb;
	--green-400: #4caf72;
	--green-500: #1f7a3f;
	--green-600: #146334;
	--green-700: #0d4a26;
	--green-800: #072e17;

	--earth-50: #fdf8f3;
	--earth-100: #f5e9d8;
	--earth-200: #e8ccaa;
	--earth-400: #c4844a;
	--earth-500: #7a4a22;
	--earth-600: #4c2a14;
	--earth-700: #2e1809;

	--sand-50: #fdfcf9;
	--sand-100: #f7f3ec;
	--sand-200: #ede5d5;

	--gray-50: #f9fafb;
	--gray-100: #f3f4f6;
	--gray-200: #e5e7eb;
	--gray-400: #9ca3af;
	--gray-600: #4b5563;
	--gray-700: #374151;
	--gray-900: #111827;

	--brand: var(--green-500);
	--brand-dark: var(--green-600);
	--brand-deeper: var(--green-700);

	--bg-page: #f8f7f4;
	--bg-card: #ffffff;
	--bg-subtle: var(--sand-100);

	--text-primary: var(--gray-900);
	--text-secondary: var(--gray-600);
	--text-muted: var(--gray-400);
	--text-brand: var(--green-600);

	--border-light: #eae7e0;
	--border-mid: #d5d0c7;

	--r-sm: 0.5rem;
	--r-md: 0.875rem;
	--r-lg: 1.25rem;
	--r-xl: 1.75rem;

	--shadow-sm: 0 4px 12px rgba(15, 23, 18, 0.07);
	--shadow-md: 0 8px 28px rgba(15, 23, 18, 0.09);

	--font-display: "Playfair Display", Georgia, serif;
	--font-body: "DM Sans", system-ui, sans-serif;

	--ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--t-fast: 150ms var(--ease);

	/* Bootstrap 5 — map to Haya palette */
	--bs-body-font-family: var(--font-body);
	--bs-body-bg: var(--bg-page);
	--bs-body-color: var(--text-primary);
	--bs-secondary-color: var(--text-secondary);
	--bs-tertiary-bg: rgba(255, 255, 255, 0.94);
	--bs-tertiary-color: var(--text-secondary);

	--bs-primary: #1f7a3f;
	--bs-primary-rgb: 31, 122, 63;
	--bs-success: #1f7a3f;
	--bs-success-rgb: 31, 122, 63;

	--bs-link-color: #146334;
	--bs-link-hover-color: #0d4a26;

	--bs-border-color: var(--border-light);
	--bs-border-radius: var(--r-sm);
	--bs-border-radius-lg: var(--r-lg);
	--bs-border-radius-xl: var(--r-xl);

	--bs-focus-ring-color: rgba(31, 122, 63, 0.35);
}

/* Page shell — same warm background + soft vignette as main site */
body#phpbb {
	font-family: var(--font-body);
	background-color: var(--bg-page);
	color: var(--text-primary);
	-webkit-font-smoothing: antialiased;
}

body#phpbb::before {
	content: "";
	position: fixed;
	inset: 0;
	background-image:
		radial-gradient(ellipse 80% 50% at 10% -10%, rgba(31, 122, 63, 0.06) 0%, transparent 60%),
		radial-gradient(ellipse 60% 40% at 90% 110%, rgba(76, 42, 20, 0.05) 0%, transparent 60%);
	pointer-events: none;
	z-index: 0;
}

/* Page shell — matches main site .page-wrapper (sticky footer) */
body#phpbb .haya-page-wrapper {
	position: relative;
	z-index: 1;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

body#phpbb .haya-page-wrapper > .haya-forum-wrap.container-xxl.wrap {
	position: relative;
	z-index: 1;
	flex: 1 0 auto;
	background: var(--bg-card);
	border-color: var(--border-light) !important;
	box-shadow: var(--shadow-sm);
}

body#phpbb .haya-page-wrapper .site-footer {
	margin-top: auto;
}

/* phpBB forum subnav: hide navbar notification dropdown (visual only; UCP notifications unchanged). */
#HeaderNavigation li.notifications-list,
#HeaderNavigation li:has(#notification_list_button) {
	display: none !important;
}

/*
 * Inline guest quick-login removed from index_body / viewforum_body templates.
 * Hide if Twig/phpBB cache still serves old markup (purge ACP cache after deploy).
 */
body#phpbb form.headerspace,
body#phpbb fieldset.quick-login {
	display: none !important;
}

/* ── Top site menu (same role as main site .site-navbar) ─── */
.haya-site-navbar {
	position: sticky;
	top: 0;
	z-index: 1040;
	background: rgba(255, 255, 255, 0.94) !important;
	backdrop-filter: blur(16px) saturate(180%);
	-webkit-backdrop-filter: blur(16px) saturate(180%);
	border-bottom: 1px solid var(--border-light);
	box-shadow: 0 1px 0 var(--border-light);
	padding: 0;
}

/* Match main site .navbar-inner — 64px header bar */
.haya-navbar-inner {
	display: flex;
	align-items: center;
	min-height: 64px;
	gap: 0.75rem;
}

/*
 * Bootstrap sets .navbar > .container { justify-content: space-between }, which
 * shrinks the collapse to content width and parks it on the RIGHT — menu + search
 * never span the bar. Override so: [brand][collapse grows to fill remaining width].
 */
.haya-site-navbar.navbar > .container.haya-navbar-inner {
	justify-content: flex-start !important;
	flex-wrap: nowrap;
	align-items: center;
}

/* Collapse must consume all space after the logo so the inner row can use full width */
.haya-site-navbar .navbar-collapse.haya-site-nav-collapse {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	width: auto !important;
	align-items: stretch;
}

@media (min-width: 992px) {
	.haya-site-navbar .navbar-collapse.haya-site-nav-collapse {
		display: flex !important;
		flex-direction: column;
		flex-basis: auto !important;
	}
}

/* One full-width row: primary links (left) | search + bell (right) */
.haya-site-navbar .haya-site-nav-row {
	width: 100%;
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.5rem;
}

@media (min-width: 992px) {
	.haya-site-navbar .haya-site-nav-row {
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: space-between;
	}
}

/* Primary links: stay left, do not grow to fill */
.haya-site-navbar .haya-site-nav {
	flex-direction: row !important;
	flex-wrap: wrap !important;
	justify-content: flex-start !important;
	align-items: center !important;
	flex: 0 1 auto !important;
	width: auto !important;
	max-width: 100%;
	margin: 0 !important;
}

/* Search + bell: stay on the right as a group (search first, then bell in HTML) */
.haya-site-navbar .haya-site-navbar-actions {
	flex: 0 0 auto;
	margin-left: auto;
}

@media (max-width: 991.98px) {
	.haya-site-navbar .haya-site-navbar-actions {
		margin-left: 0;
		width: 100%;
		justify-content: flex-start;
		padding-top: 0.35rem;
		border-top: 1px solid var(--border-light);
		margin-top: 0.25rem;
	}
}

.haya-brand-logo {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--green-100);
	box-shadow: 0 0 0 3px rgba(31, 122, 63, 0.08);
	transition: transform var(--t-fast);
}

.haya-brand-wrap:hover .haya-brand-logo {
	transform: rotate(-4deg) scale(1.06);
}

.haya-footer-logo {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--green-100);
	box-shadow: 0 0 0 3px rgba(31, 122, 63, 0.08);
}

.haya-brand {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.35rem 0;
}

.haya-brand-mark {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	flex-shrink: 0;
	background: linear-gradient(145deg, var(--green-100), var(--green-200));
	border: 2px solid var(--green-100);
	box-shadow: 0 0 0 3px rgba(31, 122, 63, 0.08);
}

.haya-brand-text {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1rem;
	color: var(--earth-600);
	line-height: 1.2;
	letter-spacing: -0.01em;
}

.haya-brand-text small {
	display: block;
	font-family: var(--font-body);
	font-weight: 400;
	font-size: 0.65rem;
	color: var(--text-muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.haya-site-nav .nav-link {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.42rem 0.7rem !important;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--gray-700) !important;
	border-radius: var(--r-sm);
	transition: color var(--t-fast), background var(--t-fast);
	white-space: nowrap;
}

.haya-site-nav .nav-link:hover,
.haya-site-nav .nav-link:focus {
	color: var(--brand) !important;
	background: var(--green-50);
}

.haya-site-nav .nav-link.active {
	color: var(--brand) !important;
	background: var(--green-50);
	font-weight: 600;
}

.haya-site-nav .nav-link i.bi {
	font-size: 0.95rem;
	opacity: 0.65;
}

.haya-nav-toggler {
	border-color: var(--border-mid);
	padding: 0.35rem 0.6rem;
}

.haya-site-search-input {
	max-width: 220px;
	border-radius: var(--r-sm) 0 0 var(--r-sm) !important;
	border-color: var(--border-mid);
}

.haya-site-search-btn {
	border-radius: 0 var(--r-sm) var(--r-sm) 0 !important;
}

.haya-forum-body {
	padding-top: 0 !important;
}

/* Forum toolbar: Quick links, FAQ, account (under site menu) */
#HeaderNavigation.haya-forum-subnav {
	background: var(--sand-50) !important;
	border-bottom: 1px solid var(--border-light) !important;
}

#HeaderNavigation .navbar-nav .nav-link {
	font-weight: 500;
	font-size: 0.875rem;
	border-radius: var(--r-sm);
	transition: color var(--t-fast), background var(--t-fast);
}

#HeaderNavigation .navbar-nav .nav-link:hover,
#HeaderNavigation .navbar-nav .nav-link:focus {
	color: var(--brand) !important;
	background: rgba(255, 255, 255, 0.8);
}

.haya-forum-breadcrumbs {
	background: var(--bg-card) !important;
}

/* Forum category strips */
.forabg.bg-gradient.bg-primary {
	background: linear-gradient(135deg, var(--green-600) 0%, var(--green-500) 50%, var(--green-700) 100%) !important;
}

.topiclist.bg-body,
ul.bg-body.topiclist {
	background: var(--bg-card) !important;
	border: 1px solid var(--border-light);
	border-radius: var(--r-md);
}

/* Forum row icon circles */
.forum-row .rounded-circle.bg-primary {
	background-color: var(--green-500) !important;
}

.forum-row .rounded-circle.bg-danger {
	/* keep unread hot, slightly tuned */
	background-color: #c62828 !important;
}

/* Typography */
h1,
h2,
h3,
.display-1,
.display-2,
.display-3 {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--text-primary);
	letter-spacing: -0.01em;
}

h4,
h5,
h6 {
	font-family: var(--font-body);
	font-weight: 600;
}

main a:not(.btn):not(.badge):not(.forumtitle):not(.postlink) {
	color: var(--text-brand);
}

main a:not(.btn):hover {
	color: var(--brand-dark);
}

/* Buttons — match site .btn-success / primary */
.btn {
	font-family: var(--font-body);
	font-weight: 500;
	border-radius: var(--r-sm);
	letter-spacing: 0.01em;
}

.btn-primary {
	background-color: var(--brand);
	border-color: var(--brand);
	box-shadow: 0 1px 3px rgba(31, 122, 63, 0.3), 0 4px 12px rgba(31, 122, 63, 0.12);
}

.btn-primary:hover,
.btn-primary:focus {
	background-color: var(--brand-dark);
	border-color: var(--brand-dark);
	transform: translateY(-1px);
}

.btn-success {
	background-color: var(--brand);
	border-color: var(--brand);
	box-shadow: 0 1px 3px rgba(31, 122, 63, 0.3), 0 4px 12px rgba(31, 122, 63, 0.12);
}

.btn-success:hover,
.btn-success:focus {
	background-color: var(--brand-dark);
	border-color: var(--brand-dark);
}

.btn-outline-primary,
.btn-outline-success {
	color: var(--brand);
	border-color: var(--brand);
	border-width: 1.5px;
}

.btn-outline-primary:hover,
.btn-outline-success:hover {
	background-color: var(--brand);
	border-color: var(--brand);
	color: #fff;
}

/* phpBB legacy submit buttons */
input.button1,
input.button2,
input.button3,
button.button1,
button.button2 {
	font-family: var(--font-body);
	border-radius: var(--r-sm);
}

input.button1,
button.button1 {
	background: var(--brand);
	border-color: var(--brand);
	color: #fff;
}

input.button1:hover,
button.button1:hover {
	background: var(--brand-dark);
	border-color: var(--brand-dark);
}

/* Forms */
.form-control,
.form-select,
.inputbox {
	border-color: var(--border-mid);
	border-radius: var(--r-sm);
}

.form-control:focus,
.form-select:focus,
.inputbox:focus {
	border-color: var(--green-400);
	box-shadow: 0 0 0 0.2rem rgba(31, 122, 63, 0.15);
}

/* Panels & stat blocks */
.stat-block {
	background: var(--bg-card);
	border: 1px solid var(--border-light);
	border-radius: var(--r-lg);
	padding: 1rem 1.25rem;
	margin-bottom: 1rem;
	box-shadow: var(--shadow-sm);
}

.stat-block h3.border-bottom {
	border-color: var(--border-light) !important;
	font-family: var(--font-display);
	font-size: 1.1rem;
}

/* Breadcrumbs */
header .breadcrumbs .crumb a {
	color: var(--text-brand);
	font-weight: 500;
}

/* Footer */
#page-footer,
.page-footer {
	border-top: 1px solid var(--border-light);
	background: transparent;
	color: var(--text-secondary);
}

#page-footer .footer-link-text {
	color: var(--text-secondary);
}

#page-footer a:hover {
	color: var(--brand);
}

/* Dropdowns */
.dropdown-menu {
	border-radius: var(--r-md);
	border-color: var(--border-light);
	box-shadow: var(--shadow-md);
}

.dropdown-item:hover,
.dropdown-item:focus {
	background: var(--green-50);
	color: var(--brand-dark);
}

/* Modals & alerts */
.modal-content {
	border-radius: var(--r-lg);
	border-color: var(--border-light);
}

.alert-primary {
	--bs-alert-bg: var(--green-50);
	--bs-alert-border-color: var(--green-200);
	--bs-alert-color: var(--green-800);
}

/* Pagination */
.pagination .page-link {
	color: var(--brand);
	border-color: var(--border-light);
}

.pagination .page-item.active .page-link {
	background-color: var(--brand);
	border-color: var(--brand);
}

/* UCP/MCP top tabs: force theme palette (avoid default Bootstrap blue) */
body#phpbb #tabs .nav.nav-pills {
	--bs-nav-pills-link-active-bg: var(--brand) !important;
	--bs-nav-pills-link-active-color: #fff !important;
}

#tabs .nav.nav-pills .nav-link {
	color: var(--gray-700);
	background-color: transparent;
	border: 1px solid transparent;
}

#tabs .nav.nav-pills .nav-link:hover,
#tabs .nav.nav-pills .nav-link:focus {
	color: var(--brand);
	background-color: var(--green-50);
	border-color: var(--green-100);
}

body#phpbb #tabs .nav.nav-pills .nav-link.active,
body#phpbb #tabs .nav.nav-pills .show > .nav-link,
body#phpbb #tabs .nav.nav-pills .activetab > .nav-link,
body#phpbb #tabs .nav-pills .nav-link.active {
	color: #fff !important;
	background-color: var(--brand) !important;
	border-color: var(--brand) !important;
	box-shadow: 0 1px 3px rgba(31, 122, 63, 0.24);
}

/* Checkboxes/radios: use Haya green instead of Bootstrap blue */
body#phpbb .form-check-input:checked {
	background-color: var(--brand) !important;
	border-color: var(--brand) !important;
}

body#phpbb .form-check-input:focus {
	border-color: var(--green-400) !important;
	box-shadow: 0 0 0 0.2rem rgba(31, 122, 63, 0.18) !important;
}

/* phpBB pages include legacy checkbox/radio markup too */
body#phpbb input[type="checkbox"]:checked,
body#phpbb input[type="radio"]:checked {
	accent-color: var(--brand);
}

/* Post body readability */
.postbody .content {
	line-height: 1.65;
	color: var(--text-primary);
}

blockquote {
	border-left: 4px solid var(--green-200);
	background: var(--sand-50);
	border-radius: 0 var(--r-sm) var(--r-sm) 0;
}

/* Search box in header */
.search-box .button-search,
.search-box .button-search-end {
	border-color: var(--border-mid) !important;
}

/* Skip link focus */
.visually-hidden-focusable:focus {
	outline: 2px solid var(--brand);
	outline-offset: 2px;
}

/* ── Full site footer (site_footer.html) — mirrors main site includes/footer.php ─ */
.site-footer {
	background: white;
	border-top: 1px solid var(--border-light);
}

.site-footer .footer-main {
	padding: 2.5rem 0 2rem;
}

.site-footer .footer-brand-name {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--earth-600);
}

.site-footer .footer-tagline {
	font-size: 0.8rem;
	color: var(--text-muted);
	margin-top: 0.2rem;
}

.site-footer .footer-heading {
	font-weight: 600;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	color: var(--text-secondary);
	margin-bottom: 0.85rem;
}

.site-footer .footer-link {
	display: block;
	font-size: 0.84rem;
	color: var(--text-secondary) !important;
	text-decoration: none;
	padding: 0.22rem 0;
	transition: color var(--t-fast);
}

.site-footer .footer-link:hover {
	color: var(--brand) !important;
}

.site-footer .footer-bottom {
	border-top: 1px solid var(--border-light);
	padding: 1.15rem 0 1.35rem;
}

.site-footer .footer-bottom-inner {
	max-width: 48rem;
	margin: 0 auto;
}

.site-footer .footer-bottom .footer-bottom-meta {
	font-size: 0.68rem !important;
	color: #6b7280 !important;
	line-height: 1.5;
}

.site-footer .footer-bottom-meta__sep {
	margin: 0 0.45rem;
	opacity: 0.55;
	font-weight: 300;
	color: var(--gray-400) !important;
	vertical-align: middle;
}

.site-footer .footer-bottom a.footer-bottom-meta__brand {
	font-weight: 600;
	color: #4b5563 !important;
	text-decoration: none !important;
}

.site-footer .footer-bottom a.footer-bottom-meta__brand:hover {
	color: #374151 !important;
}

.site-footer .footer-bottom .footer-legal-nav {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.35rem 0.45rem;
	margin-top: 0.65rem;
}

.site-footer .footer-bottom a.footer-legal-link {
	display: inline-block;
	font-size: 0.64rem !important;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #4b5563 !important;
	text-decoration: none !important;
	padding: 0.3rem 0.75rem;
	border-radius: 999px;
	border: 1px solid #e5e7eb !important;
	background: #f3f4f6 !important;
	transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}

.site-footer .footer-bottom a.footer-legal-link:hover {
	color: #111827 !important;
	border-color: #d1d5db !important;
	background: #e5e7eb !important;
}

.site-footer .footer-bottom .footer-legal-sep {
	color: #9ca3af !important;
	opacity: 0.9;
	font-weight: 600;
	font-size: 0.68rem;
}

.haya-value-badge {
	background: var(--green-50) !important;
	color: var(--green-700) !important;
	border: 1px solid var(--green-100) !important;
	font-size: 0.68rem;
	font-weight: 500;
}

.site-footer .btn-icon {
	width: 34px;
	height: 34px;
	border-radius: var(--r-sm);
	font-size: 0.9rem;
	border: 1px solid var(--border-light);
	background: transparent;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--gray-600);
	text-decoration: none;
	transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}

.site-footer .btn-icon:hover {
	background: var(--green-50);
	color: var(--brand);
	border-color: var(--green-200);
}

@media (max-width: 575.98px) {
	.site-footer .footer-bottom .footer-bottom-meta__line {
		display: block !important;
		margin-bottom: 0.35rem;
	}
	.site-footer .footer-bottom .footer-bottom-meta__line:last-of-type {
		margin-bottom: 0;
	}
}

/* Notification bell (Font Awesome — same family as search icon; dedicated class avoids Bootstrap .btn-icon clashes) */
.haya-site-navbar a.haya-site-notif-btn {
	width: 38px;
	height: 38px;
	min-width: 38px;
	border-radius: 50%;
	border: 1px solid var(--border-light);
	background: transparent;
	color: var(--gray-600);
	font-size: 1rem;
	line-height: 1;
	transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.haya-site-navbar a.haya-site-notif-btn:hover {
	background: var(--green-50);
	color: var(--brand);
	border-color: var(--green-200);
}
.haya-site-navbar a.haya-site-notif-btn .fa {
	opacity: 1;
}
.haya-site-navbar .haya-notif-dot {
	position: absolute;
	top: 6px;
	right: 6px;
	width: 7px;
	height: 7px;
	background: #ef4444;
	border-radius: 50%;
	border: 2px solid #fff;
}

/* ── Find member popup (memberlist.php?mode=searchuser&form=…&field=…) ─────────
   In popup mode, memberlist_search.html is output directly under #page-body.
   On the full memberlist page the same form lives inside #memberlist_search,
   so only the popup matches #page-body > form#search_memberlist. */

/* Hide main site menu: only when simple_header adds .memberlist-find-popup (S_IN_SEARCH_POPUP). */
body#phpbb.memberlist-find-popup #hayaSiteNavbar.haya-site-navbar {
	display: none !important;
}

body#phpbb.memberlist-find-popup .haya-forum-wrap.container-xxl.wrap {
	border-radius: var(--r-md);
	padding-top: 0.75rem;
}

body#phpbb.memberlist-find-popup #page-body.page-body {
	padding-top: 0.75rem;
	padding-bottom: 1rem;
}

body#phpbb.memberlist-find-popup #page-body > h2.solo {
	margin-bottom: 0.5rem;
	font-size: 1.15rem;
}

#page-body > form#search_memberlist.search_memberlist {
	max-width: 38rem;
	margin-inline: auto;
	padding-inline: 0.5rem;
}

#page-body > form#search_memberlist.search_memberlist > .bg-opacity-25 {
	border-radius: var(--r-md);
}

#page-body > form#search_memberlist.search_memberlist .inner {
	padding-top: 0.15rem;
	padding-bottom: 0.15rem;
}

#page-body > form#search_memberlist.search_memberlist fieldset.fields1 {
	padding: 0.5rem !important;
}

/* Two fieldsets side-by-side: top-align columns (avoid stretched equal-height blocks) */
#page-body > form#search_memberlist.search_memberlist > .bg-opacity-25 > .inner > .row.gx-0 {
	align-items: flex-start;
}

#page-body > form#search_memberlist.search_memberlist dl.row {
	align-items: center;
	margin-bottom: 0.35rem;
}

#page-body > form#search_memberlist.search_memberlist dl.row dt {
	padding-top: 0;
	padding-bottom: 0;
	margin-bottom: 0;
}

#page-body > form#search_memberlist.search_memberlist dl.row dd {
	margin-bottom: 0.35rem;
}

/* Username / email / IP: single-line controls only (no accidental tall blocks) */
#page-body > form#search_memberlist.search_memberlist input.form-control:not([type="number"]),
#page-body > form#search_memberlist.search_memberlist input.inputbox:not([type="number"]) {
	min-height: 0;
	height: auto;
	max-height: 2.75rem;
	line-height: 1.35;
}

#page-body > form#search_memberlist.search_memberlist textarea.inputbox,
#page-body > form#search_memberlist.search_memberlist textarea.form-control {
	min-height: 4rem;
	max-height: 8rem;
}

#page-body > form#search_memberlist.search_memberlist .submit-buttons {
	margin-top: 0.35rem;
	padding-top: 0.35rem !important;
}

/* Results table + actions below the search form (same popup page) */
body#phpbb.memberlist-find-popup #page-body .table-responsive {
	margin-top: 0.5rem;
}

body#phpbb.memberlist-find-popup #page-body .action-bar.bar-bottom {
	margin-top: 0.75rem !important;
}
