/**
 * MX Screener — Stylesheet
 *
 * Aesthetic: Clean white SaaS, sharp ink-and-orange contrast.
 * Matches the stock page (`.mxx-*`) token set so the two pages feel
 * like one product, not two stitched together.
 *
 * All colors flow from CSS custom properties so a future dark mode is
 * a single :root override.
 */

.mxs {
	/* ── Brand ──────────────────────────────────────────────────────── */
	--mxs-orange:        #f59e0b;
	--mxs-orange-deep:   #d97706;
	--mxs-orange-soft:   #fef3c7;
	--mxs-orange-wash:   #fffbeb;
	--mxs-orange-border: rgba(245, 158, 11, .35);

	/* ── Surfaces ──────────────────────────────────────────────────── */
	--mxs-bg:        #ffffff;
	--mxs-surface:   #ffffff;
	--mxs-surface-2: #f8fafc;
	--mxs-surface-3: #f1f5f9;
	--mxs-line:      #e5e7eb;
	--mxs-line-soft: #f1f5f9;
	--mxs-line-strong:#cbd5e1;

	/* ── Text ──────────────────────────────────────────────────────── */
	--mxs-ink:    #0f172a;
	--mxs-ink-2:  #334155;
	--mxs-ink-3:  #64748b;
	--mxs-mute:   #94a3b8;

	/* ── Status ────────────────────────────────────────────────────── */
	--mxs-up:        #16a34a;
	--mxs-up-soft:   #f0fdf4;
	--mxs-down:      #dc2626;
	--mxs-down-soft: #fef2f2;

	/* ── Tokens ────────────────────────────────────────────────────── */
	--mxs-radius:    10px;
	--mxs-radius-sm: 7px;
	--mxs-radius-pill: 999px;
	--mxs-shadow-1: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .04);
	--mxs-shadow-2: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);
	--mxs-shadow-pop: 0 12px 32px rgba(15, 23, 42, .12);
	--mxs-ease: cubic-bezier(.4, 0, .2, 1);

	font-family: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", system-ui, sans-serif;
	color: var(--mxs-ink);
	font-size: 14px;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	background: var(--mxs-bg);
}

.mxs *, .mxs *::before, .mxs *::after {
	box-sizing: border-box;
}

.mxs button { font: inherit; cursor: pointer; }
.mxs input, .mxs select { font: inherit; color: var(--mxs-ink); }

/* ════════════════ GATED STATE ════════════════ */
.mxs-gate {
	text-align: center;
	padding: 80px 24px;
	background: var(--mxs-surface);
	border: 1px solid var(--mxs-line);
	border-radius: 16px;
	max-width: 560px;
	margin: 40px auto;
	box-shadow: var(--mxs-shadow-1);
}
.mxs-gate-icon {
	width: 56px; height: 56px;
	border-radius: 16px;
	background: var(--mxs-orange-wash);
	color: var(--mxs-orange-deep);
	display: inline-flex; align-items: center; justify-content: center;
	margin-bottom: 24px;
	border: 1px solid var(--mxs-orange-border);
}
.mxs-gate-icon svg { width: 24px; height: 24px; }
.mxs-gate-title {
	font-size: 22px; font-weight: 700;
	letter-spacing: -.01em;
	margin: 0 0 10px;
}
.mxs-gate-sub {
	font-size: 14px; color: var(--mxs-ink-3);
	max-width: 380px; margin: 0 auto 28px; line-height: 1.55;
}
.mxs-gate-actions {
	display: flex; gap: 10px; justify-content: center;
}

/* ════════════════ BUTTONS ════════════════ */
.mxs-btn {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px;
	border-radius: var(--mxs-radius-sm);
	border: 1px solid transparent;
	font-size: 13px; font-weight: 600;
	transition: background .12s var(--mxs-ease), border-color .12s var(--mxs-ease), color .12s var(--mxs-ease), transform .08s var(--mxs-ease);
	text-decoration: none;
	white-space: nowrap;
}
.mxs-btn svg { width: 14px; height: 14px; }
.mxs-btn:active { transform: translateY(1px); }

.mxs-btn-primary {
	background: var(--mxs-ink);
	color: #fff;
	border-color: var(--mxs-ink);
}
.mxs-btn-primary:hover { background: #1e293b; border-color: #1e293b; }

.mxs-btn-ghost {
	background: var(--mxs-surface);
	color: var(--mxs-ink-2);
	border-color: var(--mxs-line);
}
.mxs-btn-ghost:hover {
	background: var(--mxs-surface-2);
	border-color: var(--mxs-line-strong);
	color: var(--mxs-ink);
}

.mxs-icon-btn {
	width: 34px; height: 34px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--mxs-radius-sm);
	border: 1px solid var(--mxs-line);
	background: var(--mxs-surface);
	color: var(--mxs-ink-2);
	transition: background .12s, color .12s, border-color .12s;
}
.mxs-icon-btn svg { width: 16px; height: 16px; }
.mxs-icon-btn:hover {
	background: var(--mxs-surface-2);
	color: var(--mxs-ink);
	border-color: var(--mxs-line-strong);
}
.mxs-icon-btn-danger:hover {
	background: var(--mxs-down-soft);
	color: var(--mxs-down);
	border-color: var(--mxs-down);
}

/* ════════════════ TOOLBAR ════════════════ */
.mxs-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px 0;
	flex-wrap: wrap;
}
.mxs-toolbar-left, .mxs-toolbar-right {
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Search */
.mxs-search {
	position: relative;
	min-width: 280px;
	flex: 0 0 auto;
}
.mxs-search-icon {
	position: absolute;
	left: 12px; top: 50%; transform: translateY(-50%);
	width: 16px; height: 16px;
	color: var(--mxs-mute);
	pointer-events: none;
}
.mxs-search-input {
	width: 100%;
	height: 36px;
	padding: 0 36px 0 38px;
	border: 1px solid var(--mxs-line);
	background: var(--mxs-surface);
	border-radius: var(--mxs-radius-sm);
	font-size: 14px;
	color: var(--mxs-ink);
	transition: border-color .12s, box-shadow .12s;
}
.mxs-search-input::placeholder { color: var(--mxs-mute); }
.mxs-search-input:focus {
	outline: 0;
	border-color: var(--mxs-orange);
	box-shadow: 0 0 0 3px rgba(245, 158, 11, .15);
}
.mxs-search-clear {
	position: absolute;
	right: 6px; top: 50%; transform: translateY(-50%);
	width: 24px; height: 24px;
	border-radius: 50%;
	border: 0; background: transparent;
	color: var(--mxs-mute);
	font-size: 18px; line-height: 1;
}
.mxs-search-clear:hover { background: var(--mxs-surface-2); color: var(--mxs-ink); }

/* Filter toggle button */
.mxs-filter-toggle .mxs-filter-count {
	display: inline-flex;
	align-items: center; justify-content: center;
	min-width: 18px; height: 18px;
	padding: 0 5px;
	border-radius: var(--mxs-radius-pill);
	background: var(--mxs-orange);
	color: #fff;
	font-size: 11px; font-weight: 700;
	margin-left: 2px;
}
.mxs-filter-toggle .mxs-filter-count[hidden] { display: none !important; }

/* Saved-screens select */
.mxs-select {
	height: 36px;
	padding: 0 30px 0 12px;
	border: 1px solid var(--mxs-line);
	background: var(--mxs-surface) url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 8px center / 14px;
	-webkit-appearance: none; appearance: none;
	border-radius: var(--mxs-radius-sm);
	font-size: 13px; color: var(--mxs-ink);
	min-width: 180px;
}
.mxs-select:focus {
	outline: 0;
	border-color: var(--mxs-orange);
	box-shadow: 0 0 0 3px rgba(245, 158, 11, .15);
}
.mxs-select-sm { height: 32px; min-width: 0; font-size: 12px; padding: 0 26px 0 10px; }

/* Save / delete buttons that appear when an editable screen is selected.
 * NOTE: any explicit `display` value on an element with the HTML [hidden]
 * attribute defeats the browser's UA `display:none` for [hidden]. Every
 * .mxs-* element that uses [hidden] for show/hide therefore needs a paired
 * `[hidden] { display: none }` rule. Forgetting one of these is the canonical
 * source of "the button is in the DOM but invisible / stuck visible" bugs in
 * this file — see also .mxs-chips and .mxs-filter-count below. */
.mxs-screen-actions { display: inline-flex; gap: 6px; }
.mxs-screen-actions[hidden] { display: none !important; }

/* ════════════════ ACTIVE FILTER CHIPS ════════════════ */
.mxs-chips {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding: 4px 0 12px;
}
.mxs-chips[hidden] { display: none !important; }
.mxs-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 5px 6px 5px 12px;
	background: var(--mxs-surface-2);
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius-pill);
	font-size: 12px;
	color: var(--mxs-ink);
	white-space: nowrap;
}
.mxs-chip strong {
	font-weight: 600;
	color: var(--mxs-ink-3);
	margin-right: 4px;
}
.mxs-chip-x {
	width: 18px; height: 18px;
	border-radius: 50%;
	border: 0;
	background: transparent;
	color: var(--mxs-ink-3);
	font-size: 16px; line-height: 1;
	display: inline-flex; align-items: center; justify-content: center;
}
.mxs-chip-x:hover { background: var(--mxs-line); color: var(--mxs-down); }

.mxs-chip-clear {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 5px 10px;
	border: 0;
	background: transparent;
	color: var(--mxs-ink-3);
	font-size: 12px;
	font-weight: 600;
	border-radius: var(--mxs-radius-sm);
}
.mxs-chip-clear:hover { color: var(--mxs-down); }
.mxs-chip-clear svg { width: 12px; height: 12px; }

/* ════════════════ COLUMN PRESET TABS ════════════════ */
.mxs-presets {
	display: flex;
	gap: 2px;
	margin-bottom: 16px;
	padding: 4px;
	background: var(--mxs-surface-2);
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.mxs-preset-tab {
	padding: 7px 14px;
	border: 0;
	background: transparent;
	font-size: 13px;
	font-weight: 600;
	color: var(--mxs-ink-3);
	border-radius: var(--mxs-radius-sm);
	white-space: nowrap;
	transition: background .12s, color .12s;
}
.mxs-preset-tab:hover { color: var(--mxs-ink); background: var(--mxs-surface); }
.mxs-preset-tab[aria-selected="true"] {
	background: var(--mxs-surface);
	color: var(--mxs-ink);
	box-shadow: var(--mxs-shadow-1);
}

/* ════════════════ LAYOUT (sidebar + main) ════════════════ */
.mxs-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 20px;
	align-items: start;
}
.mxs-main { min-width: 0; /* allow table to shrink within grid */ }

/* ════════════════ SIDEBAR ════════════════ */
.mxs-sidebar {
	background: var(--mxs-surface);
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius);
	overflow: hidden;
	position: sticky;
	top: 16px;
	height: calc(100vh - 32px);
	height: calc(100dvh - 32px);
	max-height: calc(100vh - 32px);
	max-height: calc(100dvh - 32px);
	display: flex;
	flex-direction: column;
}
.mxs-sidebar-header {
	display: flex; align-items: center; justify-content: space-between;
	padding: 14px 16px;
	border-bottom: 1px solid var(--mxs-line);
}
.mxs-sidebar-header h3 {
	margin: 0; font-size: 14px; font-weight: 700;
	letter-spacing: -.01em;
}
.mxs-sidebar-close {
	display: none;
	border: 0; background: transparent;
	width: 28px; height: 28px; border-radius: 50%;
	font-size: 22px; line-height: 1; color: var(--mxs-ink-3);
}
.mxs-sidebar-body {
	padding: 8px 0;
	overflow-y: auto;
	flex: 1 1 auto;
	min-height: 0;
	scrollbar-width: thin;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
}
.mxs-sidebar-body::-webkit-scrollbar { width: 6px; }
.mxs-sidebar-body::-webkit-scrollbar-thumb { background: var(--mxs-line-strong); border-radius: 3px; }
.mxs-sidebar-footer {
	display: none;
	gap: 8px;
	padding: 12px 16px;
	border-top: 1px solid var(--mxs-line);
	background: var(--mxs-surface-2);
}
.mxs-sidebar-footer .mxs-btn { flex: 1; justify-content: center; }

/* Filter groups (accordion) */
.mxs-group {
	border-bottom: 1px solid var(--mxs-line-soft);
}
.mxs-group:last-child { border-bottom: 0; }
.mxs-group-header {
	width: 100%;
	display: flex; align-items: center; justify-content: space-between;
	padding: 12px 16px;
	border: 0; background: transparent;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--mxs-ink-2);
	cursor: pointer;
}
.mxs-group-header:hover { color: var(--mxs-ink); background: var(--mxs-surface-2); }
.mxs-group-chev {
	width: 14px; height: 14px;
	transition: transform .15s var(--mxs-ease);
	color: var(--mxs-mute);
}
.mxs-group[aria-expanded="true"] .mxs-group-chev { transform: rotate(90deg); }
.mxs-group-body {
	padding: 0 16px 12px;
	display: none;
}
.mxs-group[aria-expanded="true"] .mxs-group-body { display: block; }

.mxs-filter-row {
	display: grid;
	grid-template-columns: 16px minmax(0, 1fr);
	align-items: center;
	padding: 6px 0;
	gap: 8px;
}
.mxs-filter-row input[type="checkbox"] {
	width: 16px; height: 16px;
	accent-color: var(--mxs-orange);
	flex: 0 0 auto;
	margin: 0;
}
.mxs-filter-row label {
	font-size: 13px;
	color: var(--mxs-ink-2);
	flex: 1;
	cursor: pointer;
	user-select: none;
	line-height: 1.35;
}

/* Active filter inline form (range/select/etc.) */
.mxs-filter-form {
	grid-column: 2;
	margin-top: 2px;
	display: none;
	gap: 6px;
	flex-direction: column;
	min-width: 0;
}
.mxs-filter-row[data-active="true"] .mxs-filter-form { display: flex; }
.mxs-filter-row[data-active="true"] label { color: var(--mxs-ink); font-weight: 600; }

.mxs-filter-input {
	width: 100%;
	height: 32px;
	padding: 0 10px;
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius-sm);
	background: var(--mxs-surface);
	font-size: 13px;
	color: var(--mxs-ink);
}
.mxs-filter-input:focus {
	outline: 0;
	border-color: var(--mxs-orange);
	box-shadow: 0 0 0 3px rgba(245, 158, 11, .12);
}
.mxs-filter-op-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px;
}
.mxs-filter-op-row.three { grid-template-columns: 1fr 1fr 1fr; }
.mxs-threshold-note {
	font-size: 11px;
	color: var(--mxs-ink-3);
	margin-top: 2px;
	display: flex;
	align-items: center;
	gap: 4px;
}
.mxs-threshold-note::before {
	content: "ℹ";
	color: var(--mxs-orange);
	font-size: 11px;
}

/* ════════════════ RESULT BAR ════════════════ */
.mxs-result-bar {
	display: flex; align-items: center; justify-content: space-between;
	margin-bottom: 10px;
	padding: 0 2px;
}
.mxs-result-count {
	font-size: 13px;
	color: var(--mxs-ink-3);
}
.mxs-result-count strong { color: var(--mxs-ink); font-weight: 700; }
.mxs-page-size { display: inline-flex; align-items: center; gap: 8px; }
.mxs-page-size label { font-size: 12px; color: var(--mxs-ink-3); }

/* ════════════════ TABLE ════════════════ */
.mxs-table-wrap {
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius);
	background: var(--mxs-surface);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	box-shadow: var(--mxs-shadow-1);
	scrollbar-width: thin;
}
.mxs-table-wrap::-webkit-scrollbar { height: 8px; }
.mxs-table-wrap::-webkit-scrollbar-thumb { background: var(--mxs-line-strong); border-radius: 4px; }

.mxs-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 13px;
	font-variant-numeric: tabular-nums;
}

.mxs-table thead th {
	position: sticky;
	top: 0;
	z-index: 2;
	background: var(--mxs-surface);
	padding: 10px 12px;
	text-align: right;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--mxs-ink-3);
	border-bottom: 1px solid var(--mxs-line);
	white-space: nowrap;
	cursor: pointer;
	user-select: none;
}
.mxs-table thead th:first-child,
.mxs-table thead th[data-text="true"] { text-align: left; }
.mxs-table thead th:hover { color: var(--mxs-ink); background: var(--mxs-surface-2); }
.mxs-table thead th[aria-sort] .mxs-sort-ind {
	display: inline-block;
	width: 0; height: 0;
	margin-left: 4px;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	opacity: .3;
}
.mxs-table thead th[aria-sort="asc"]  .mxs-sort-ind { border-bottom: 5px solid var(--mxs-orange); opacity: 1; }
.mxs-table thead th[aria-sort="desc"] .mxs-sort-ind { border-top: 5px solid var(--mxs-orange); opacity: 1; }

.mxs-table tbody td {
	padding: 11px 12px;
	border-bottom: 1px solid var(--mxs-line-soft);
	text-align: right;
	color: var(--mxs-ink);
	white-space: nowrap;
}
.mxs-table tbody td:first-child,
.mxs-table tbody td[data-text="true"] { text-align: left; }
.mxs-table tbody tr { transition: background .08s; }
.mxs-table tbody tr:hover { background: var(--mxs-orange-wash); }
.mxs-table tbody tr:last-child td { border-bottom: 0; }

/* Sticky first column (ticker) */
.mxs-table thead th[data-sticky="true"],
.mxs-table tbody td[data-sticky="true"] {
	position: sticky;
	left: 0;
	z-index: 3;
	background: var(--mxs-surface);
	box-shadow: 4px 0 6px -4px rgba(15, 23, 42, .08);
}
.mxs-table thead th[data-sticky="true"] { z-index: 4; }
.mxs-table tbody tr:hover td[data-sticky="true"] { background: var(--mxs-orange-wash); }

/* Ticker cell */
.mxs-cell-ticker {
	display: inline-flex; align-items: center; gap: 8px;
	font-weight: 700;
}
.mxs-cell-ticker a {
	color: var(--mxs-ink);
	text-decoration: none;
	transition: color .12s;
}
.mxs-cell-ticker a:hover { color: var(--mxs-orange-deep); }
.mxs-cell-ticker .mxs-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	flex: 0 0 auto;
}
.mxs-cell-ticker .mxs-dot-pass { background: var(--mxs-up); }
.mxs-cell-ticker .mxs-dot-fail { background: var(--mxs-down); }
.mxs-cell-ticker .mxs-dot-warn { background: var(--mxs-orange); }

/* Compliance badges (Pass/Fail/N/A per standard) */
.mxs-badge {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 2px 8px;
	border-radius: var(--mxs-radius-pill);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .02em;
}
.mxs-badge-pass { background: var(--mxs-up-soft); color: var(--mxs-up); }
.mxs-badge-fail { background: var(--mxs-down-soft); color: var(--mxs-down); }
.mxs-badge-warn { background: var(--mxs-orange-wash); color: var(--mxs-orange-deep); }
.mxs-badge-na   { background: var(--mxs-surface-3); color: var(--mxs-ink-3); }

/* Change %: green-up, red-down inline coloring */
.mxs-up-text   { color: var(--mxs-up);   font-weight: 600; }
.mxs-down-text { color: var(--mxs-down); font-weight: 600; }
.mxs-zero-text { color: var(--mxs-ink-3); }

/* Stars (NoofStandards) */
.mxs-stars { color: var(--mxs-orange); letter-spacing: 1px; font-size: 12px; }
.mxs-stars-empty { color: var(--mxs-line-strong); }

/* Skeleton rows */
.mxs-row-skeleton td { padding: 14px 12px; }
.mxs-sk-bar {
	height: 12px;
	background: linear-gradient(90deg, var(--mxs-surface-2) 0%, var(--mxs-surface-3) 50%, var(--mxs-surface-2) 100%);
	background-size: 200% 100%;
	border-radius: 4px;
	animation: mxs-sk-shimmer 1.4s ease-in-out infinite;
}
@keyframes mxs-sk-shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* Empty state */
.mxs-empty {
	padding: 60px 24px;
	text-align: center;
	color: var(--mxs-ink-3);
}
.mxs-empty-icon {
	width: 48px; height: 48px;
	border-radius: 50%;
	background: var(--mxs-surface-2);
	color: var(--mxs-ink-3);
	display: inline-flex; align-items: center; justify-content: center;
	margin-bottom: 16px;
}
.mxs-empty-title { font-size: 15px; font-weight: 700; color: var(--mxs-ink); margin-bottom: 4px; }

/* ════════════════ PAGINATION ════════════════ */
.mxs-pagination {
	display: flex; align-items: center; justify-content: center; gap: 12px;
	padding: 14px 0 4px;
}
.mxs-page-btn {
	width: 32px; height: 32px;
	display: inline-flex; align-items: center; justify-content: center;
	border: 1px solid var(--mxs-line);
	background: var(--mxs-surface);
	border-radius: var(--mxs-radius-sm);
	color: var(--mxs-ink-2);
	transition: background .12s, border-color .12s, color .12s, opacity .12s;
}
.mxs-page-btn svg { width: 14px; height: 14px; }
.mxs-page-btn:hover:not(:disabled) {
	background: var(--mxs-surface-2);
	border-color: var(--mxs-line-strong);
	color: var(--mxs-ink);
}
.mxs-page-btn:disabled { opacity: .35; cursor: not-allowed; }
.mxs-page-info {
	font-size: 13px;
	color: var(--mxs-ink-2);
	min-width: 80px;
	text-align: center;
}
.mxs-page-info strong { font-weight: 700; color: var(--mxs-ink); }

/* ════════════════ TOASTS ════════════════ */
.mxs-toast {
	position: fixed;
	bottom: 24px; right: 24px;
	background: var(--mxs-ink);
	color: #fff;
	padding: 12px 16px;
	border-radius: var(--mxs-radius);
	font-size: 13px;
	box-shadow: var(--mxs-shadow-pop);
	z-index: 9999;
	animation: mxs-toast-in .25s var(--mxs-ease);
}
.mxs-toast-error { background: var(--mxs-down); }
.mxs-toast-ok    { background: var(--mxs-up); }
@keyframes mxs-toast-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ════════════════ BACKDROP (mobile filter drawer) ════════════════ */
.mxs-backdrop {
	position: fixed; inset: 0;
	background: rgba(15, 23, 42, .45);
	z-index: 999;
}

/* ════════════════ RESPONSIVE ════════════════ */
@media (max-width: 1024px) {
	.mxs-layout { grid-template-columns: 1fr; }

	/* Sidebar becomes a slide-in drawer on mobile */
	.mxs-sidebar {
		position: fixed;
		left: 0; top: 0; bottom: 0;
		width: 88vw;
		max-width: 360px;
		height: 100vh;
		height: 100dvh;
		max-height: 100%;
		z-index: 1000;
		transform: translateX(-100%);
		transition: transform .25s var(--mxs-ease);
		border-radius: 0;
		border: 0;
		border-right: 1px solid var(--mxs-line);
	}
	.mxs[data-mxs-filters-open="true"] .mxs-sidebar { transform: translateX(0); }
	.mxs-sidebar-close { display: inline-flex; }
	.mxs-sidebar-footer { display: flex; }
}
@media (min-width: 1025px) {
	.mxs-filter-toggle { display: none; } /* desktop: sidebar always visible */
	.mxs-backdrop { display: none !important; }
}

@media (max-width: 640px) {
	.mxs-toolbar { gap: 8px; }
	.mxs-toolbar-left, .mxs-toolbar-right { flex: 1 1 100%; flex-wrap: wrap; }
	.mxs-search { min-width: 0; flex: 1; }
	.mxs-select { min-width: 140px; flex: 1; }
	.mxs-btn span { display: inline; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	.mxs *, .mxs *::before, .mxs *::after {
		animation-duration: .001ms !important;
		transition-duration: .001ms !important;
	}
}

/* ════════════════ CUSTOM COLUMNS ════════════════ */
.mxs-column-panel {
	margin: -6px 0 16px;
	padding: 14px;
	background: var(--mxs-surface);
	border: 1px solid var(--mxs-line);
	border-radius: var(--mxs-radius);
	box-shadow: var(--mxs-shadow-1);
}
.mxs-column-panel[hidden] { display: none !important; }
.mxs-column-panel-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}
.mxs-column-panel-head strong {
	display: block;
	font-size: 14px;
	font-weight: 700;
	color: var(--mxs-ink);
}
.mxs-column-panel-head span {
	display: block;
	font-size: 12px;
	color: var(--mxs-ink-3);
	margin-top: 2px;
}
.mxs-column-panel-actions {
	display: inline-flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.mxs-column-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}
.mxs-column-section {
	padding: 10px;
	border: 1px solid var(--mxs-line-soft);
	border-radius: var(--mxs-radius-sm);
	background: var(--mxs-surface-2);
}
.mxs-column-section-title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--mxs-ink-3);
	margin-bottom: 8px;
}
.mxs-column-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 6px 10px;
}
.mxs-column-option {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 12px;
	color: var(--mxs-ink-2);
	line-height: 1.25;
}
.mxs-column-option input {
	width: 15px;
	height: 15px;
	accent-color: var(--mxs-orange);
	margin: 0;
	flex: 0 0 auto;
}
.mxs-column-option input:disabled + span {
	font-weight: 700;
	color: var(--mxs-ink);
}

/* Make the export icon robust against theme SVG/button overrides. */
.mxs .mxs-export-btn {
	color: var(--mxs-ink-2) !important;
	background: var(--mxs-surface) !important;
	border: 1px solid var(--mxs-line) !important;
	min-width: 34px;
	padding: 0;
}
.mxs .mxs-export-btn svg {
	display: block !important;
	width: 17px !important;
	height: 17px !important;
	stroke: currentColor !important;
	fill: none !important;
	visibility: visible !important;
	opacity: 1 !important;
}
.mxs .mxs-export-btn:hover {
	color: var(--mxs-ink) !important;
	background: var(--mxs-surface-2) !important;
	border-color: var(--mxs-line-strong) !important;
}

@media (max-width: 900px) {
	.mxs-column-list,
	.mxs-column-grid { grid-template-columns: 1fr; }
	.mxs-column-panel-head { flex-direction: column; }
	.mxs-column-panel-actions { justify-content: flex-start; }
}

/* Robust save/delete/export toolbar icons against Elementor/theme SVG overrides. */
.mxs .mxs-icon-btn {
	position: relative;
	min-width: 34px;
	padding: 0 !important;
	color: var(--mxs-ink-2) !important;
	background: var(--mxs-surface) !important;
	border: 1px solid var(--mxs-line) !important;
	line-height: 1 !important;
}
.mxs .mxs-icon-btn svg {
	display: block !important;
	width: 17px !important;
	height: 17px !important;
	stroke: currentColor !important;
	fill: none !important;
	visibility: visible !important;
	opacity: 1 !important;
	pointer-events: none !important;
}
.mxs .mxs-icon-btn svg path,
.mxs .mxs-icon-btn svg polyline,
.mxs .mxs-icon-btn svg line,
.mxs .mxs-icon-btn svg rect,
.mxs .mxs-icon-btn svg circle {
	stroke: currentColor !important;
	fill: none !important;
	visibility: visible !important;
	opacity: 1 !important;
}
.mxs .mxs-icon-btn:hover {
	color: var(--mxs-ink) !important;
	background: var(--mxs-surface-2) !important;
	border-color: var(--mxs-line-strong) !important;
}
.mxs .mxs-icon-btn-danger:hover {
	color: var(--mxs-down) !important;
	background: var(--mxs-down-soft) !important;
	border-color: var(--mxs-down) !important;
}
