/* Matrix Fighter — UI layer.
   The game world renders on <canvas>; this styles the HTML overlay
   (auth, lobby, shop, HUD, touch controls). */

@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@500;700;900&display=swap');

:root {
	--mxf-bg: #000700;
	--mxf-green: #2bff88;
	--mxf-green-dim: rgba(43, 255, 136, 0.5);
	--mxf-green-soft: rgba(43, 255, 136, 0.65);
	--mxf-line: rgba(43, 255, 136, 0.25);
	--mxf-panel: rgba(0, 18, 8, 0.82);
	--mxf-amber: #ffcf4d;
	--mxf-red: #ff4d6d;
	--mxf-cyan: #5df2ff;
	--mxf-display: 'Orbitron', sans-serif;
	--mxf-mono: 'Share Tech Mono', monospace;
}

.mxf-root, .mxf-root * { box-sizing: border-box; }

.mxf-root {
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100vh;
	height: 100dvh;
	margin: 0;
	background: var(--mxf-bg);
	color: var(--mxf-green);
	font-family: var(--mxf-mono);
	overflow: hidden;
	touch-action: manipulation;
	user-select: none;
	-webkit-user-select: none;
	-webkit-tap-highlight-color: transparent;
	z-index: 2147483000;
}

#mxf-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
	touch-action: none;
	image-rendering: optimizeQuality;
}

#mxf-ui {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
#mxf-ui > * { pointer-events: auto; }

/* ---- Panels / screens ---- */
.mxf-screen {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	padding: 24px 16px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	touch-action: pan-y;
	animation: mxf-fade 0.4s ease both;
}
@keyframes mxf-fade { from { opacity: 0; } to { opacity: 1; } }

.mxf-panel {
	width: min(440px, 92vw);
	margin: auto 0;
	background: var(--mxf-panel);
	border: 1px solid var(--mxf-line);
	border-radius: 14px;
	padding: 28px 26px;
	backdrop-filter: blur(6px);
	box-shadow: 0 0 0 1px rgba(43,255,136,0.08), 0 24px 60px rgba(0,0,0,0.7),
		0 0 80px rgba(43,255,136,0.08) inset;
}
.mxf-panel.wide { width: min(720px, 94vw); }

.mxf-title {
	font-family: var(--mxf-display);
	font-weight: 900;
	letter-spacing: 4px;
	font-size: clamp(24px, 5vw, 40px);
	text-transform: uppercase;
	color: #eaffe9;
	text-shadow: 0 0 18px var(--mxf-green), 0 0 2px #fff;
	margin: 0 0 4px;
	text-align: center;
}
.mxf-sub {
	text-align: center;
	color: var(--mxf-green-soft);
	font-size: 12px;
	letter-spacing: 2px;
	margin: 0 0 22px;
	text-transform: uppercase;
}

.mxf-field { margin-bottom: 14px; }
.mxf-field label {
	display: block;
	font-size: 11px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--mxf-green-soft);
	margin-bottom: 6px;
}
.mxf-input {
	width: 100%;
	background: rgba(0,0,0,0.55);
	border: 1px solid var(--mxf-line);
	border-radius: 8px;
	padding: 12px 14px;
	color: var(--mxf-green);
	font-family: var(--mxf-mono);
	font-size: 16px; /* >=16px to stop iOS zoom */
	outline: none;
	transition: border-color .15s, box-shadow .15s;
}
.mxf-input:focus {
	border-color: var(--mxf-green);
	box-shadow: 0 0 0 3px rgba(43,255,136,0.15);
}

.mxf-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 13px 16px;
	margin-top: 8px;
	background: linear-gradient(180deg, rgba(43,255,136,0.18), rgba(43,255,136,0.06));
	border: 1px solid var(--mxf-green);
	border-radius: 8px;
	color: #eaffe9;
	font-family: var(--mxf-display);
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	font-size: 14px;
	cursor: pointer;
	transition: transform .08s, box-shadow .15s, background .15s;
}
.mxf-btn:hover { box-shadow: 0 0 22px rgba(43,255,136,0.4); }
.mxf-btn:active { transform: translateY(1px) scale(0.99); }
.mxf-btn.ghost {
	background: transparent;
	border-color: var(--mxf-line);
	color: var(--mxf-green-soft);
}
.mxf-btn.amber { border-color: var(--mxf-amber); color: #fff3d0; background: linear-gradient(180deg, rgba(255,207,77,0.18), rgba(255,207,77,0.05)); }
.mxf-btn.danger { border-color: var(--mxf-red); color: #ffd9e0; }
.mxf-btn:disabled { opacity: .45; cursor: not-allowed; }
.mxf-btn.small { width: auto; padding: 8px 14px; font-size: 12px; margin: 0; }

.mxf-row { display: flex; gap: 10px; }
.mxf-row .mxf-btn { margin-top: 0; }

.mxf-link {
	display: block;
	text-align: center;
	margin-top: 16px;
	color: var(--mxf-green-soft);
	font-size: 12px;
	letter-spacing: 1px;
	cursor: pointer;
	text-decoration: underline dotted;
}
.mxf-error {
	min-height: 16px;
	text-align: center;
	color: var(--mxf-red);
	font-size: 12px;
	letter-spacing: 1px;
	margin-bottom: 8px;
}

/* ---- Lobby ---- */
.mxf-lobby-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 18px; }
@media (max-width: 720px) { .mxf-lobby-grid { grid-template-columns: 1fr; } }

.mxf-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin: 14px 0 18px; }
.mxf-stat {
	background: rgba(0,0,0,0.4);
	border: 1px solid var(--mxf-line);
	border-radius: 8px;
	padding: 8px 6px;
	text-align: center;
}
.mxf-stat b { display: block; font-family: var(--mxf-display); font-size: 18px; color: #eaffe9; }
.mxf-stat span { font-size: 9px; letter-spacing: 1px; color: var(--mxf-green-soft); text-transform: uppercase; }

.mxf-list { list-style: none; margin: 0; padding: 0; }
.mxf-list li {
	display: flex; justify-content: space-between; align-items: center;
	padding: 7px 4px; border-bottom: 1px dashed var(--mxf-line); font-size: 13px;
}
.mxf-list li b { font-family: var(--mxf-display); }
.mxf-rank { color: var(--mxf-amber); width: 26px; }
.mxf-online {
	display: inline-flex; align-items: center; gap: 7px; font-size: 12px;
	letter-spacing: 1px; color: var(--mxf-green-soft);
}
.mxf-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--mxf-green); box-shadow: 0 0 10px var(--mxf-green); animation: mxf-pulse 1.6s infinite; }
@keyframes mxf-pulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }

.mxf-sectitle { font-family: var(--mxf-display); letter-spacing: 2px; font-size: 13px; text-transform: uppercase; color: var(--mxf-green-soft); margin: 0 0 8px; }

/* ---- Customizer rows ---- */
.mxf-choices { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.mxf-chip {
	padding: 7px 12px; border: 1px solid var(--mxf-line); border-radius: 999px;
	font-size: 12px; letter-spacing: 1px; cursor: pointer; color: var(--mxf-green-soft);
	background: rgba(0,0,0,0.3); transition: all .12s; text-transform: capitalize;
}
.mxf-chip.active { border-color: var(--mxf-green); color: #eaffe9; box-shadow: 0 0 14px rgba(43,255,136,0.3); }
.mxf-chip.locked { opacity: .5; }

/* ---- HUD (in-game) ---- */
.mxf-hud { position: absolute; inset: 0; pointer-events: none; }
.mxf-hud .bar-wrap { position: absolute; top: 14px; padding: 0 14px; width: 50%; max-width: 360px; }
.mxf-hud .bar-wrap.left { left: 0; }
.mxf-hud .bar-wrap.right { right: 0; text-align: right; }
.mxf-name { font-family: var(--mxf-display); font-size: 12px; letter-spacing: 2px; text-shadow: 0 0 6px #000; }
.mxf-hpbar { height: 14px; border: 1px solid var(--mxf-line); border-radius: 6px; background: rgba(0,0,0,0.6); overflow: hidden; margin-top: 4px; }
.mxf-hpfill { height: 100%; background: linear-gradient(90deg, #2bff88, #d6ff5d); transition: width .15s; }
.mxf-hpfill.foe { background: linear-gradient(90deg, #ff4d6d, #ff9a3d); }
.mxf-spbar { height: 6px; border: 1px solid rgba(93,242,255,.4); border-radius: 4px; margin-top: 4px; overflow: hidden; background: rgba(0,0,0,.5);}
.mxf-spfill { height: 100%; width: 0; background: linear-gradient(90deg,#5df2ff,#2bff88); }
.mxf-fcbar { height: 6px; border: 1px solid rgba(191,255,224,.5); border-radius: 4px; margin-top: 4px; overflow: hidden; background: rgba(0,0,0,.5); }
.mxf-fcfill { height: 100%; width: 100%; background: linear-gradient(90deg,#bfffe0,#5df2ff); transition: width .1s; }
.mxf-btlabel {
	position: absolute; left: 50%; top: 92px; transform: translateX(-50%);
	font-family: var(--mxf-display); letter-spacing: 4px; font-size: clamp(14px,2.4vw,22px);
	color: #d9fff0; text-shadow: 0 0 18px var(--mxf-cyan), 0 0 8px var(--mxf-green);
	opacity: 0; transition: opacity .15s; pointer-events: none;
}
.mxf-srv { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; letter-spacing: 1px; margin-left: 14px; }
.mxf-srv.up { color: var(--mxf-green); }
.mxf-srv.up .mxf-dot { background: var(--mxf-green); box-shadow: 0 0 10px var(--mxf-green); }
.mxf-srv.down { color: #ff6b6b; }
.mxf-srv.down .mxf-dot { background: #ff6b6b; box-shadow: 0 0 10px #ff6b6b; animation: none; }

.mxf-toast {
	position: absolute; left: 50%; top: 18%; transform: translateX(-50%);
	font-family: var(--mxf-display); letter-spacing: 3px; font-size: clamp(18px,4vw,34px);
	color: #eaffe9; text-shadow: 0 0 18px var(--mxf-green); text-transform: uppercase;
	pointer-events: none; opacity: 0;
}
.mxf-toast.show { animation: mxf-toast 1.4s ease both; }
@keyframes mxf-toast { 0%{opacity:0;transform:translateX(-50%) scale(.6);} 20%{opacity:1;transform:translateX(-50%) scale(1);} 80%{opacity:1;} 100%{opacity:0;transform:translateX(-50%) translateY(-20px);} }

.mxf-questbox {
	position: absolute; right: 12px; top: 64px; width: min(220px, 60vw);
	background: var(--mxf-panel); border: 1px solid var(--mxf-line); border-radius: 10px;
	padding: 10px 12px; font-size: 11px; pointer-events: none;
}
.mxf-questbox h4 { margin: 0 0 6px; font-family: var(--mxf-display); letter-spacing: 1px; font-size: 11px; color: var(--mxf-amber); }
.mxf-questbox .q { color: var(--mxf-green-soft); margin-bottom: 3px; }
.mxf-questbox .q.done { color: var(--mxf-green); text-decoration: line-through; opacity: .7; }

.mxf-topbtns { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; }
.mxf-onlinepill { position: absolute; bottom: 92px; left: 50%; transform: translateX(-50%);
	font-family: var(--mxf-display); letter-spacing: 1px; font-size: 12px; color: #bfffe0;
	background: rgba(0,18,8,.55); border: 1px solid var(--mxf-line); padding: 4px 14px;
	border-radius: 999px; pointer-events: none; text-shadow: 0 0 8px rgba(95,242,255,.4); }
.mxf-onlinepill:empty { display: none; }

/* ---- skill bar (1/2/3 select, right-click to use) ---- */
.mxf-skillbar { position: absolute; bottom: 56px; left: 50%; transform: translateX(-50%);
	display: flex; gap: 8px; align-items: center; pointer-events: auto; }
.mxf-slot { font-family: var(--mxf-display); font-size: 12px; letter-spacing: 1px; color: #cfeede;
	background: rgba(0,18,8,.6); border: 1px solid var(--mxf-line); border-radius: 8px; padding: 6px 12px; cursor: pointer; }
.mxf-slot.active { border-color: var(--mxf-green); color: #eaffe9; box-shadow: 0 0 14px rgba(43,255,136,.4); background: rgba(43,255,136,.14); }
.mxf-slothint { font-size: 10px; color: #7fae93; letter-spacing: 1px; margin-left: 4px; }

/* ---- chat ---- */
.mxf-chat { position: absolute; left: 14px; bottom: 150px; width: 300px; max-width: 42vw; pointer-events: auto; }
.mxf-chatlog { max-height: 132px; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end;
	font-size: 12px; line-height: 1.5; color: #cdeede; text-shadow: 0 1px 2px #000; margin-bottom: 4px; }
.mxf-chatlog > div { background: rgba(0,12,7,0.42); border-radius: 6px; padding: 1px 7px; margin-top: 2px; width: fit-content; max-width: 100%; }
.mxf-chatlog b { color: #5df2ff; }
#mxf-chatin { width: 100%; box-sizing: border-box; background: rgba(0,18,8,.7); border: 1px solid var(--mxf-line);
	color: #eaffe9; border-radius: 8px; padding: 6px 10px; font-family: monospace; font-size: 12px; outline: none; }
#mxf-chatin:focus { border-color: var(--mxf-green); box-shadow: 0 0 12px rgba(43,255,136,.3); }

/* ---- Touch controls ---- */
.mxf-touch { position: absolute; inset: 0; pointer-events: none; display: none; }
.mxf-touch.on { display: block; }
.mxf-touch.on ~ .mxf-skillbar { display: none; }
.mxf-stick {
	position: absolute; left: 18px; bottom: 22px; width: 120px; height: 120px;
	border-radius: 50%; border: 1px solid var(--mxf-line); background: rgba(0,18,8,0.45);
	pointer-events: auto; touch-action: none;
}
.mxf-stick .nub { position: absolute; left: 35px; top: 35px; width: 50px; height: 50px; border-radius: 50%; background: var(--mxf-green-dim); box-shadow: 0 0 16px rgba(43,255,136,.4); }
.mxf-actions { position: absolute; right: 12px; bottom: 20px; display: flex; flex-direction: column; gap: 12px; pointer-events: auto; }
.mxf-arow { display: flex; gap: 12px; justify-content: flex-end; }
.mxf-sidebtns { position: absolute; right: 96px; bottom: 168px; display: flex; flex-direction: column; gap: 10px; pointer-events: auto; }
.mxf-abtn {
	width: 60px; height: 60px; border-radius: 50%; border: 1px solid var(--mxf-green);
	background: rgba(43,255,136,0.12); color: #eaffe9; font-family: var(--mxf-display);
	font-size: 13px; letter-spacing: 1px; touch-action: none; display:flex;align-items:center;justify-content:center;
}
.mxf-sidebtns .mxf-abtn { width: 50px; height: 50px; font-size: 11px; }
.mxf-abtn.sp { border-color: var(--mxf-cyan); color: #d6f7ff; }
.mxf-abtn.shoot { border-color: #ff9bd0; color: #ffe1f1; box-shadow: 0 0 14px rgba(255,109,208,.35); }
.mxf-abtn.chat { border-color: #cfeede; color: #eaffe9; }
.mxf-abtn.blk { border-color: var(--mxf-amber); }
.mxf-abtn.kck { border-color: #a6ff5d; color: #eaffd6; }
.mxf-abtn.bt { border-color: #bfffe0; color: #d9fff0; box-shadow: 0 0 14px rgba(95,242,255,.35); }
.mxf-abtn.dash { border-color: #d6ff5d; color: #f1ffd6; }
.mxf-abtn.frz { border-color: #7fd8ff; color: #d9f6ff; box-shadow: 0 0 12px rgba(127,216,255,.3); }
.mxf-abtn.fly { border-color: #c77dff; color: #f0e1ff; box-shadow: 0 0 14px rgba(199,125,255,.4); }
.mxf-abtn:active { background: rgba(43,255,136,0.32); transform: scale(0.94); }

/* loader */
.mxf-loader { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:14px; }
.mxf-loader .lg { font-family: var(--mxf-display); letter-spacing:6px; font-size:22px; color:#eaffe9; text-shadow:0 0 18px var(--mxf-green); }
.mxf-loader .lp { font-size:11px; letter-spacing:2px; color: var(--mxf-green-soft); }

.mxf-custom { display: flex; gap: 18px; align-items: flex-start; flex-wrap: wrap; justify-content: center; margin-top: 10px; }
.mxf-preview { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; gap: 8px; }
#c-preview { border: 1px solid var(--mxf-line); border-radius: 12px; background: #02100a; box-shadow: inset 0 0 26px rgba(43,255,136,.14); }
.mxf-loadout { font-family: var(--mxf-display); font-size: 12px; letter-spacing: 1px; color: #bfffe0; text-align: center; }
.mxf-customopts { flex: 1 1 320px; min-width: 260px; text-align: left; max-height: 58vh; overflow-y: auto; padding-right: 6px; }

.mxf-shopgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(124px, 1fr)); gap: 12px; max-height: 58vh; overflow-y: auto; padding: 6px; margin-top: 8px; }
.mxf-card { display: flex; flex-direction: column; align-items: center; gap: 6px; border: 1px solid var(--mxf-line); border-radius: 10px; padding: 8px 6px; background: rgba(0,18,8,.4); }
.mxf-cardcv { background: #02100a; border: 1px solid rgba(43,255,136,.16); border-radius: 8px; }
.mxf-cardname { font-size: 11px; color: #bfffe0; text-align: center; min-height: 14px; letter-spacing: .5px; }
.mxf-owned { color: var(--mxf-green); font-family: var(--mxf-display); font-size: 12px; letter-spacing: 1px; }

.mxf-donate { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 10px; margin: 6px auto 14px; padding: 10px 16px; max-width: 560px;
	border: 1px solid #ffcf4d; border-radius: 10px; background: rgba(255,207,77,.08); box-shadow: 0 0 18px rgba(255,207,77,.12); }
.mxf-donate-msg { color: #ffe49a; font-size: 13px; }
.mxf-donate-btns { display: flex; gap: 8px; }
.mxf-btn.small.pp, .mxf-donate .mxf-btn.small { background: #ffcf4d; color: #1a1300; border-color: #ffcf4d; text-decoration: none; }
.mxf-btn.small.pp:hover, .mxf-donate .mxf-btn.small:hover { background: #ffd866; }

.mxf-hide { display: none !important; }

/* ---------- Map-change splash / loading ---------- */
.mxf-splash { position: fixed; inset: 0; z-index: 99999; background: #000; display: flex; align-items: center; justify-content: center; overflow: hidden; opacity: 1; transition: opacity .35s ease; }
.mxf-splash.mxf-splash-out { opacity: 0; }
.mxf-splash-rain { position: absolute; inset: 0; width: 100%; height: 100%; display: block; opacity: .55; }
.mxf-splash-scan { position: absolute; inset: 0; pointer-events: none; background: repeating-linear-gradient(to bottom, rgba(43,255,136,.05) 0 2px, transparent 2px 4px); animation: mxf-scan 6s linear infinite; }
@keyframes mxf-scan { from { background-position: 0 0; } to { background-position: 0 120px; } }
.mxf-splash-center { position: relative; text-align: center; color: #9fffc4; font-family: 'Orbitron', monospace; padding: 24px; }
.mxf-splash-sub { letter-spacing: .5em; font-size: 12px; color: #2bff88; opacity: .85; margin-bottom: 12px; text-transform: uppercase; }
.mxf-splash-title { font-size: clamp(28px, 6vw, 64px); font-weight: 800; letter-spacing: .06em; color: #eafff1; text-shadow: 0 0 18px rgba(43,255,136,.6); position: relative; display: inline-block; }
.mxf-splash-title.glitch::before, .mxf-splash-title.glitch::after { content: attr(data-text); position: absolute; left: 0; top: 0; width: 100%; }
.mxf-splash-title.glitch::before { color: #5df2ff; clip-path: inset(0 0 55% 0); animation: mxf-glitch 1.6s infinite linear alternate; }
.mxf-splash-title.glitch::after { color: #ff4d6d; clip-path: inset(55% 0 0 0); animation: mxf-glitch 1.2s infinite linear alternate-reverse; }
@keyframes mxf-glitch { 0% { transform: translate(-2px,0); } 25% { transform: translate(2px,-1px); } 50% { transform: translate(-1px,1px); } 75% { transform: translate(1px,0); } 100% { transform: translate(-2px,1px); } }
.mxf-splash-bar { margin: 22px auto 8px; width: min(420px, 70vw); height: 6px; border: 1px solid rgba(43,255,136,.4); border-radius: 6px; overflow: hidden; background: rgba(43,255,136,.08); }
.mxf-splash-bar > i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, #2bff88, #5df2ff); box-shadow: 0 0 12px #2bff88; transition: width .08s linear; }
.mxf-splash-tip { font-size: 12px; letter-spacing: .3em; color: #7fae93; }
.mxf-dots::after { content: ''; animation: mxf-dots 1s steps(4, end) infinite; }
@keyframes mxf-dots { 0% { content: ''; } 25% { content: '.'; } 50% { content: '..'; } 75% { content: '...'; } 100% { content: ''; } }

/* ---------- Shop category tabs ---------- */
.mxf-tabs { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin: 6px 0 14px; }
.mxf-tab { background: rgba(43,255,136,.06); border: 1px solid var(--mxf-line); color: #9fe8b0; padding: 7px 16px; border-radius: 20px; cursor: pointer; font-size: 12px; letter-spacing: 1px; text-transform: uppercase; transition: all .15s; }
.mxf-tab:hover { background: rgba(43,255,136,.14); }
.mxf-tab.active { background: #2bff88; color: #04140b; border-color: #2bff88; font-weight: 700; }

/* ---------- Map select ---------- */
.mxf-mapgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; max-height: 56vh; overflow-y: auto; padding: 4px; }
.mxf-mapcard { position: relative; overflow: hidden; border: 2px solid; border-radius: 12px; min-height: 110px; cursor: pointer; color: #eafff1; display: flex; flex-direction: column; justify-content: flex-end; align-items: flex-start; padding: 14px; text-align: left; transition: transform .12s, box-shadow .12s; }
.mxf-mapcard:hover { transform: translateY(-3px) scale(1.02); box-shadow: 0 8px 28px rgba(0,0,0,.5); }
.mxf-mapglow { position: absolute; right: -30px; top: -30px; width: 90px; height: 90px; border-radius: 50%; opacity: .35; filter: blur(14px); }
.mxf-mapname { position: relative; font-weight: 800; font-size: 15px; letter-spacing: .04em; text-shadow: 0 1px 6px rgba(0,0,0,.7); }
.mxf-mapdiff { position: relative; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; opacity: .85; margin-top: 4px; }

/* ---------- Phone booth travel ---------- */
.mxf-phone { position: fixed; inset: 0; z-index: 99998; background: rgba(0,6,3,.78); display: flex; align-items: center; justify-content: center; }
.mxf-phonebox { background: #04140b; border: 1px solid var(--mxf-line); border-radius: 14px; padding: 20px; max-width: 540px; width: 90%; box-shadow: 0 0 40px rgba(43,255,136,.25); }
.mxf-phonehdr { color: #2bff88; letter-spacing: .2em; font-size: 13px; text-transform: uppercase; margin-bottom: 14px; text-align: center; }
.mxf-phonelist { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; max-height: 50vh; overflow-y: auto; margin-bottom: 14px; }
.mxf-phbtn { background: rgba(43,255,136,.06); border: 1px solid var(--mxf-line); color: #cfffe2; padding: 10px; border-radius: 8px; cursor: pointer; font-size: 13px; text-align: left; }
.mxf-phbtn:hover { background: rgba(43,255,136,.16); }
.mxf-phbtn.here { opacity: .55; }
.mxf-phbtn small { color: #7fae93; }
.mxf-abtn.call { border-color: #2bff88; color: #9fffc4; }

/* ---------- Skills screen ---------- */
.mxf-skrow { display: flex; align-items: center; gap: 10px; margin: 8px 0; flex-wrap: wrap; }
.mxf-sklabel { min-width: 64px; color: #7fae93; font-size: 12px; letter-spacing: .1em; }
.mxf-skopts { display: flex; gap: 6px; flex-wrap: wrap; }
.mxf-skbtn { background: rgba(43,255,136,.06); border: 1px solid var(--mxf-line); color: #cfffe2; padding: 7px 12px; border-radius: 18px; cursor: pointer; font-size: 12px; }
.mxf-skbtn:hover { background: rgba(43,255,136,.16); }
.mxf-skbtn.active { background: #2bff88; color: #04140b; border-color: #2bff88; font-weight: 700; }
.mxf-skbtn.locked { opacity: .4; cursor: not-allowed; }
.mxf-skbtn small { color: #ffcf4d; }

/* ---------- Intro / story ---------- */
.mxf-introbox { max-width: 640px; }
.mxf-story { line-height: 1.65; color: #cfe9d8; font-size: 14px; margin: 6px 0 14px; text-align: left; }
.mxf-howlist { text-align: left; color: #bfe6cf; font-size: 13px; line-height: 1.7; margin: 6px 0 14px; padding-left: 18px; }

/* ---------- Language select ---------- */
.mxf-langbtns { display: flex; gap: 10px; justify-content: center; margin: 12px 0 4px; }
.mxf-langbtns .mxf-btn { flex: 1; max-width: 180px; }

/* ---------- Guild tag + mini buttons ---------- */
.mxf-gtag { color: var(--mxf-amber, #ffcf4d); font-weight: 700; }
.mxf-mini { background: rgba(43,255,136,0.12); border: 1px solid rgba(43,255,136,0.5); color: #bfffe0; border-radius: 8px; padding: 3px 10px; font-size: 12px; cursor: pointer; }
.mxf-mini:hover { background: rgba(43,255,136,0.22); }

/* ---------- Stat bars + minimap ---------- */
.mxf-statbar { display:flex; gap:3px; margin-top:6px; }
.mxf-statbar i { width:14px; height:8px; border-radius:2px; background:rgba(43,255,136,0.15); border:1px solid rgba(43,255,136,0.3); }
.mxf-statbar i.on { background:#2bff88; box-shadow:0 0 6px #2bff88; }
.mxf-minimap { position:absolute; right:12px; bottom:20px; width:150px; height:150px; border:1px solid rgba(43,255,136,0.5); border-radius:8px; background:rgba(0,10,6,0.55); z-index:5; pointer-events:none; }

/* ---------- Character select ---------- */
.mxf-chargrid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:12px; }
.mxf-charcard { background:rgba(10,26,18,0.6); border:1px solid rgba(43,255,136,0.3); border-radius:12px; padding:10px; text-align:center; }
.mxf-charcard:hover { border-color:rgba(95,242,255,0.6); box-shadow:0 0 16px rgba(43,255,136,0.2); }
.mxf-charcv { width:120px; height:150px; display:block; margin:0 auto; }
.mxf-charname { font-family:var(--mxf-display,monospace); font-weight:800; color:#bfffe0; margin-top:6px; }
.mxf-charsub { font-size:11px; color:rgba(191,255,224,0.6); margin-bottom:8px; }
@media (max-width:560px){ .mxf-chargrid { grid-template-columns:repeat(2,1fr); } }

/* ---------- Mobile / small-screen tuning ---------- */
@media (max-width: 820px), (pointer: coarse) {
	.mxf-panel { padding: 18px 16px; }
	.mxf-panel.wide { width: min(720px, 96vw); }
	.mxf-title { letter-spacing: 2px; }
	.mxf-hud .bar-wrap { width: 58%; max-width: 200px; }
	/* declutter during play on small screens */
	.mxf-questbox { display: none; }
	.mxf-skillbar { display: none; }
	.mxf-onlinepill { bottom: auto; top: 106px; font-size: 10px; padding: 3px 8px; max-width: 94vw; }
	.mxf-minimap { width: 84px; height: 84px; top: 62px; right: 8px; left: auto; bottom: auto; }
	.mxf-chat { left: 10px; bottom: 152px; width: 54vw; max-width: 230px; }
	.mxf-chatlog { max-height: 92px; }
	/* touch controls — two tidy clusters, clear of the top HUD */
	.mxf-stick { left: 12px; bottom: 14px; width: 100px; height: 100px; }
	.mxf-stick .nub { left: 28px; top: 28px; width: 44px; height: 44px; }
	.mxf-actions { right: 8px; bottom: 12px; gap: 8px; }
	.mxf-arow { gap: 8px; }
	.mxf-abtn { width: 46px; height: 46px; font-size: 11px; }
	.mxf-sidebtns { right: 8px; bottom: 168px; flex-direction: column; gap: 8px; }
	.mxf-sidebtns .mxf-abtn { width: 42px; height: 42px; font-size: 10px; }
}
@media (max-height: 480px) {
	.mxf-minimap { width: 72px; height: 72px; top: 58px; right: 8px; left: auto; bottom: auto; }
	.mxf-stick { width: 92px; height: 92px; bottom: 10px; }
	.mxf-actions { bottom: 10px; }
	.mxf-sidebtns { bottom: 120px; }
	.mxf-onlinepill { top: 92px; }
}

/* ---------- Credit ---------- */
.mxf-credit { text-align:center; margin-top:14px; font-size:12px; letter-spacing:0.5px; }
.mxf-credit a { color:rgba(95,242,255,0.7); text-decoration:none; transition:color .2s, text-shadow .2s; }
.mxf-credit a:hover { color:#5df2ff; text-shadow:0 0 8px rgba(95,242,255,0.6); }
.mxf-loader .mxf-credit { position:absolute; bottom:24px; left:0; right:0; }

/* ---------- Inventory ---------- */
.mxf-invlist { display:flex; flex-direction:column; gap:8px; max-height:56vh; overflow-y:auto; padding:4px; margin-top:8px; }
.mxf-invrow { display:flex; align-items:center; gap:12px; background:rgba(0,18,8,0.4); border:1px solid var(--mxf-line); border-radius:10px; padding:8px 12px; }
.mxf-invcv { width:48px; height:56px; flex:0 0 auto; }
.mxf-invmeta { flex:1; text-align:left; display:flex; flex-direction:column; }
.mxf-invmeta span { opacity:.6; font-size:11px; text-transform:uppercase; letter-spacing:1px; }

/* ---------- Admin chat highlight ---------- */
.mxf-adminmsg { color:#ffcf4d; text-shadow:0 0 8px rgba(255,207,77,0.5); }
.mxf-adminmsg b { color:#ffe08a; }

/* ---------- Server clock ---------- */
.mxf-srvclock { position:absolute; top:50px; left:50%; transform:translateX(-50%); font-family:var(--mxf-display, monospace); font-size:13px; letter-spacing:2px; color:#9fffc4; background:rgba(0,12,6,0.5); border:1px solid rgba(43,255,136,0.3); border-radius:8px; padding:3px 12px; pointer-events:none; text-shadow:0 0 6px rgba(43,255,136,0.4); }
@media (max-width: 820px), (pointer: coarse) { .mxf-srvclock { font-size:11px; padding:2px 8px; top:46px; } }

/* ---- landing content + social (auth screen) ---- */
.mxf-landing { margin: 6px 0 12px; padding: 10px 12px; border: 1px solid var(--mxf-line); border-radius: 8px; background: rgba(0,20,10,.35); color: #bfeedd; font-size: 13px; line-height: 1.5; max-height: 240px; overflow: auto; }
.mxf-landing img { max-width: 100%; height: auto; border-radius: 6px; display: block; margin: 6px 0; }
.mxf-landing a { color: var(--mxf-amber); }
.mxf-landing h1, .mxf-landing h2, .mxf-landing h3 { color: #d6ffe9; margin: 6px 0; }
.mxf-social { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin: 10px 0 4px; }
.mxf-social .mxf-btn.small { width: auto; padding: 6px 12px; }

/* ---- news / updates ---- */
.mxf-newslist { display: flex; flex-direction: column; gap: 10px; max-height: 60vh; overflow: auto; padding-right: 4px; }
.mxf-newsitem { border: 1px solid var(--mxf-line); border-radius: 8px; padding: 12px 14px; background: rgba(0,20,10,.35); text-align: left; }
.mxf-newshead { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.mxf-newstitle { color: #d6ffe9; font-weight: 700; letter-spacing: .5px; }
.mxf-newsdate { color: #6fae93; font-size: 11px; font-family: monospace; white-space: nowrap; }
.mxf-newsbody { color: #bfeedd; font-size: 13px; line-height: 1.55; }

/* ---- tabbed leaderboard ---- */
.mxf-boardtabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.mxf-btab { flex: 1 1 auto; padding: 6px 8px; font-size: 11px; letter-spacing: .5px; background: rgba(0,20,10,.4); color: #8fd9b3; border: 1px solid var(--mxf-line); border-radius: 7px; cursor: pointer; white-space: nowrap; }
.mxf-btab.active { background: rgba(43,255,136,.16); color: #d6ffe9; border-color: var(--mxf-acc); }
.mxf-board { max-height: 360px; overflow: auto; }
.mxf-brow { transition: background .2s; }
.mxf-badmin { color: var(--mxf-amber); font-weight: 700; font-size: 9px; letter-spacing: 1px; margin-left: 4px; }
/* prestige tiers */
.mxf-brow.r10 span { color: #d6ffe9; }
.mxf-brow.r3 { background: linear-gradient(90deg, rgba(255,207,77,.10), transparent); }
.mxf-brow.r3 span, .mxf-brow.r3 b { color: #ffe08a; }
.mxf-brow.r1 { background: linear-gradient(90deg, rgba(255,207,77,.22), rgba(255,207,77,.04)); border-radius: 8px; box-shadow: 0 0 14px rgba(255,207,77,.35); animation: mxf-auraGlow 2.4s ease-in-out infinite; }
.mxf-brow.r1 span, .mxf-brow.r1 b { color: #ffd64d; font-weight: 800; text-shadow: 0 0 8px rgba(255,207,77,.7); }
@keyframes mxf-auraGlow { 0%,100% { box-shadow: 0 0 12px rgba(255,207,77,.3); } 50% { box-shadow: 0 0 22px rgba(255,207,77,.6); } }
.mxf-boardnav { display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 8px; }
.mxf-boardnav .mxf-btn.small { width: auto; padding: 4px 12px; }
.mxf-bpage { font-size: 11px; color: #8fd9b3; font-family: monospace; letter-spacing: .5px; }

.mxf-brow.gm { background: linear-gradient(90deg, rgba(122,162,255,.14), transparent); border-radius: 8px; }
.mxf-brow.gm span, .mxf-brow.gm b { color: #bcd2ff; }
.mxf-brow.gm .mxf-badmin { color: var(--mxf-amber); }

/* ---- server status bar (auth screen) ---- */
.mxf-srvstat { margin: 12px 0 4px; }
.mxf-srvrow { display: flex; justify-content: space-between; align-items: baseline; font-size: 11px; color: #8fd9b3; font-family: monospace; letter-spacing: .5px; margin-bottom: 5px; }
.mxf-srvms { color: #bfeedd; }
.mxf-srvbar { height: 8px; border-radius: 6px; background: rgba(0,30,15,.6); border: 1px solid var(--mxf-line); overflow: hidden; }
.mxf-srvfill { height: 100%; width: 0%; background: #2bff88; border-radius: 6px; transition: width .6s ease, background .6s ease; }

/* ---- skill tree (REDPILL PATHS) ---- */
.mxf-treebox { max-width: 920px; }
.mxf-treehead { display: flex; align-items: center; justify-content: space-between; gap: 16px; border: 1px solid var(--mxf-line); border-radius: 10px; padding: 10px 14px; margin-bottom: 8px; background: rgba(2,20,12,.5); flex-wrap: wrap; }
.mxf-treexp { display: flex; align-items: center; gap: 10px; font: 700 11px monospace; color: #8fd9b3; letter-spacing: 1px; flex: 1; min-width: 220px; }
.mxf-xpbar { flex: 1; height: 8px; background: rgba(0,30,15,.7); border: 1px solid var(--mxf-line); border-radius: 6px; overflow: hidden; }
.mxf-xpbar i { display: block; height: 100%; background: #2bff88; box-shadow: 0 0 10px #2bff88; }
.mxf-treecr { font: 700 13px monospace; color: #ffcf4d; }
.mxf-treesub { text-align: center; color: #8fd9b3; font-size: 13px; margin-bottom: 12px; }
.mxf-treesub b { color: #a6ff5d; }
.mxf-treecols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 4px; }
.mxf-treecolh { text-align: center; color: #5df2ff; font: 700 13px monospace; letter-spacing: 2px; text-shadow: 0 0 8px rgba(95,242,255,.4); }
.mxf-treegrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px 10px; }
.mxf-tcell { position: relative; display: flex; justify-content: center; min-height: 64px; }
.mxf-tlink { position: absolute; top: -14px; left: 50%; width: 2px; height: 14px; background: rgba(95,242,255,.18); }
.mxf-tlink.on { background: #2bff88; box-shadow: 0 0 8px #2bff88; }
.mxf-tnode { position: relative; width: 100%; max-width: 200px; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 8px 6px; border: 1px solid var(--mxf-line); border-radius: 12px; background: rgba(2,20,12,.55); color: #9fd9b3; cursor: pointer; transition: all .15s; }
.mxf-tnode:hover { border-color: var(--mxf-acc); }
.mxf-tnode.has { border-color: #2bff88; box-shadow: 0 0 12px rgba(43,255,136,.3); color: #d6ffe9; background: rgba(43,255,136,.08); }
.mxf-tnode.maxed { border-color: #ffcf4d; box-shadow: 0 0 14px rgba(255,207,77,.4); }
.mxf-tnode.locked { opacity: .45; }
.mxf-tic { font-size: 18px; }
.mxf-tnm { font: 700 10px monospace; text-align: center; letter-spacing: .5px; line-height: 1.1; }
.mxf-tpips { display: flex; gap: 3px; margin-top: 2px; }
.mxf-tpips i { width: 7px; height: 7px; border-radius: 50%; background: rgba(95,242,255,.18); }
.mxf-tpips i.on { background: #2bff88; box-shadow: 0 0 6px #2bff88; }
.mxf-trk { font: 700 9px monospace; color: #7fae93; }
.mxf-ttip { margin-top: 14px; padding: 10px 14px; border: 1px solid var(--mxf-line); border-radius: 10px; background: rgba(0,0,0,.4); color: #bfeedd; font-size: 12px; line-height: 1.5; min-height: 20px; }
@media (max-width: 720px) { .mxf-tnm { font-size: 8px; } .mxf-tic { font-size: 14px; } .mxf-treegrid { gap: 12px 6px; } }

/* ---- in-game pause overlay (online never freezes) ---- */
.mxf-pausewrap { position: absolute; inset: 0; z-index: 60; display: flex; align-items: center; justify-content: center; background: rgba(0,8,4,.45); backdrop-filter: blur(2px); animation: mxfPauseIn .15s ease; }
@keyframes mxfPauseIn { from { opacity: 0; } to { opacity: 1; } }
.mxf-pausecard { position: relative; width: min(92vw, 420px); padding: 26px 22px 20px; border: 1px solid #2bff88; border-radius: 16px; background: linear-gradient(180deg, rgba(4,30,16,.96), rgba(0,12,6,.96)); box-shadow: 0 0 30px rgba(43,255,136,.35), inset 0 0 30px rgba(43,255,136,.06); text-align: center; }
.mxf-pausex { position: absolute; top: 10px; right: 12px; width: 30px; height: 30px; border: 1px solid var(--mxf-line); border-radius: 8px; background: rgba(0,0,0,.4); color: #9fd9b3; font-size: 14px; cursor: pointer; transition: all .15s; }
.mxf-pausex:hover { border-color: #ff5a5a; color: #ff8080; }
.mxf-pausetitle { font: 800 26px var(--mxf-display, monospace); letter-spacing: 4px; color: #2bff88; text-shadow: 0 0 14px rgba(43,255,136,.6); }
.mxf-pausesub { font-size: 11px; color: #7fae93; letter-spacing: 1px; margin: 6px 0 18px; }
.mxf-pausecard .mxf-btn { width: 100%; margin: 6px 0; }
.mxf-pausecard .mxf-btn.danger { border-color: #ff5a5a; color: #ffb3b3; }
.mxf-pausecard .mxf-btn.danger:hover { background: rgba(255,90,90,.14); }

/* ---- weapon merchant overlay ---- */
.mxf-shopwrap { position: absolute; inset: 0; z-index: 60; display: flex; align-items: center; justify-content: center; background: rgba(0,8,4,.5); backdrop-filter: blur(2px); animation: mxfPauseIn .15s ease; }
.mxf-shopcard { position: relative; width: min(94vw, 640px); max-height: 88vh; overflow: auto; padding: 24px 20px 18px; border: 1px solid #5df2ff; border-radius: 16px; background: linear-gradient(180deg, rgba(4,26,30,.97), rgba(0,10,12,.97)); box-shadow: 0 0 30px rgba(95,242,255,.3); text-align: center; }
.mxf-shopcredits { color: #ffcf4d; font: 800 18px monospace; margin: 4px 0 14px; }
.mxf-shopcols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.mxf-shopcol { border: 1px solid var(--mxf-line); border-radius: 10px; padding: 8px; background: rgba(0,0,0,.3); }
.mxf-shoph { font: 700 12px monospace; letter-spacing: 2px; color: #5df2ff; margin-bottom: 8px; }
.mxf-shoplist { display: flex; flex-direction: column; gap: 6px; }
.mxf-shoprow { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 6px 8px; border: 1px solid var(--mxf-line); border-radius: 8px; background: rgba(2,20,12,.4); }
.mxf-shopmeta { text-align: left; line-height: 1.15; }
.mxf-shopmeta b { color: #d6ffe9; font-size: 13px; }
.mxf-shopmeta span { display: block; font-size: 10px; color: #7fae93; }
.mxf-owned { color: #a6ff5d; font: 700 11px monospace; }
.mxf-shopcard .mxf-btn { margin-top: 14px; }
.mxf-btn.small.danger { border-color: #ff5a5a; color: #ff9b9b; padding: 4px 8px; }
@media (max-width: 560px) { .mxf-shopcols { grid-template-columns: 1fr; } }

/* ---- buy credits ---- */
.mxf-crgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 12px; }
.mxf-crpack { border: 1px solid var(--mxf-line); border-radius: 12px; padding: 16px 12px; text-align: center; background: rgba(2,20,12,.5); }
.mxf-crpack:hover { border-color: #ffcf4d; box-shadow: 0 0 14px rgba(255,207,77,.25); }
.mxf-crc { font: 800 26px var(--mxf-display, monospace); color: #ffcf4d; }
.mxf-crc small { font-size: 11px; color: #9fd9b3; letter-spacing: 1px; }
.mxf-crbonus { font: 700 11px monospace; color: #a6ff5d; margin: 2px 0 8px; }
.mxf-crpack .mxf-btn { width: 100%; margin-top: 8px; }

/* ---- pause menu extras ---- */
.mxf-pauseclock { font: 700 15px monospace; color: #9fffc4; letter-spacing: 2px; margin: 2px 0 4px; text-shadow: 0 0 8px rgba(43,255,136,.4); }
.mxf-pausegrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 6px 0; }
.mxf-pausegrid .mxf-btn { width: 100%; margin: 0; font-size: 12px; padding: 8px 4px; }
@media (max-width: 460px) { .mxf-pausegrid { grid-template-columns: 1fr; } }

/* ---- in-game wallet readout ---- */
.mxf-wallet { margin-top: 6px; font: 700 12px monospace; color: #ffcf4d; letter-spacing: .5px; text-shadow: 0 0 6px rgba(0,0,0,.6); }

/* ---- stats allocation (4 stats, 0–1000) ---- */
.mxf-statfill { position: relative; height: 16px; margin-top: 6px; border: 1px solid rgba(43,255,136,0.35); border-radius: 8px; background: rgba(0,20,10,0.6); overflow: hidden; }
.mxf-statfill > span { position: absolute; left: 0; top: 0; bottom: 0; background: linear-gradient(90deg,#2bff88,#a6ff5d); box-shadow: 0 0 10px rgba(43,255,136,0.6); transition: width .18s ease; }
.mxf-statfill > em { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font: 700 10px monospace; color: #eafff2; text-shadow: 0 0 4px #000; font-style: normal; }
.mxf-statbtns { display: flex; gap: 5px; align-items: center; }
.mxf-mini.amber { border-color: #ffcf4d; color: #ffcf4d; }

/* ============================================================
   LOBBY GLOW-UP (v1.43) — Matrix polish + mobile-friendly.
   Pure styling; the falling code rendered on the canvas shows
   through the translucent panel so the "numbers behind" stay.
   ============================================================ */
.mxf-panel {
	background:
		linear-gradient(180deg, rgba(0,26,12,0.72), rgba(0,10,5,0.86));
	border: 1px solid rgba(43,255,136,0.32);
	box-shadow:
		0 0 0 1px rgba(43,255,136,0.10),
		0 24px 70px rgba(0,0,0,0.78),
		0 0 90px rgba(43,255,136,0.10) inset,
		0 0 26px rgba(43,255,136,0.18);
	position: relative;
	max-height: 92dvh;
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: rgba(43,255,136,0.4) transparent;
}
.mxf-panel::-webkit-scrollbar { width: 8px; }
.mxf-panel::-webkit-scrollbar-thumb { background: rgba(43,255,136,0.3); border-radius: 8px; }
/* faint scanline texture over the panel */
.mxf-panel::before {
	content: ''; position: absolute; inset: 0; border-radius: 14px; pointer-events: none;
	background: repeating-linear-gradient(180deg, rgba(43,255,136,0.04) 0 1px, transparent 1px 4px);
	opacity: .5;
}
.mxf-panel.wide { width: min(760px, 95vw); }

.mxf-title { text-shadow: 0 0 22px var(--mxf-green), 0 0 6px rgba(43,255,136,0.8), 0 0 2px #fff; }

/* online / server status row */
.mxf-online, .mxf-srv { display: inline-flex; align-items: center; gap: 6px; margin: 0 8px; }
.mxf-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mxf-green); box-shadow: 0 0 8px var(--mxf-green); animation: mxfPulse 1.8s ease-in-out infinite; }
.mxf-srv.down .mxf-dot { background: var(--mxf-red); box-shadow: 0 0 8px var(--mxf-red); }
@keyframes mxfPulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

/* stat cards — auto-fit, gradient, neon top accent */
.mxf-stats { grid-template-columns: repeat(auto-fit, minmax(92px, 1fr)); gap: 10px; }
.mxf-stat {
	position: relative; overflow: hidden;
	background: linear-gradient(160deg, rgba(43,255,136,0.10), rgba(0,12,6,0.55));
	border: 1px solid rgba(43,255,136,0.28);
	border-radius: 10px; padding: 12px 8px;
	box-shadow: 0 0 18px rgba(43,255,136,0.06) inset;
	transition: transform .12s, box-shadow .15s, border-color .15s;
}
.mxf-stat::after { content: ''; position: absolute; top: 0; left: 12%; right: 12%; height: 2px; background: linear-gradient(90deg, transparent, var(--mxf-green), transparent); opacity: .8; }
.mxf-stat:hover { transform: translateY(-2px); border-color: rgba(43,255,136,0.55); box-shadow: 0 6px 20px rgba(0,0,0,0.5), 0 0 22px rgba(43,255,136,0.12) inset; }
.mxf-stat b { font-size: clamp(16px, 4.6vw, 22px); text-shadow: 0 0 12px rgba(43,255,136,0.5); }
.mxf-stat span { font-size: 9px; }

/* buttons — leading accent bar + smoother sheen */
.mxf-btn {
	position: relative; overflow: hidden;
	background: linear-gradient(180deg, rgba(43,255,136,0.20), rgba(43,255,136,0.05));
	border-color: rgba(43,255,136,0.55);
	transition: transform .08s, box-shadow .18s, background .18s, border-color .18s;
}
.mxf-btn::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--mxf-green); opacity: .55; box-shadow: 0 0 10px var(--mxf-green); }
.mxf-btn:hover { background: linear-gradient(180deg, rgba(43,255,136,0.30), rgba(43,255,136,0.08)); box-shadow: 0 0 24px rgba(43,255,136,0.35); border-color: var(--mxf-green); }
.mxf-btn.ghost { background: linear-gradient(180deg, rgba(43,255,136,0.05), rgba(0,0,0,0)); }
.mxf-btn.ghost::before { background: rgba(43,255,136,0.5); opacity: .35; }
.mxf-btn.ghost:hover { background: linear-gradient(180deg, rgba(43,255,136,0.14), rgba(43,255,136,0.03)); color: #eaffe9; }
.mxf-btn.amber::before { background: var(--mxf-amber); box-shadow: 0 0 10px var(--mxf-amber); }
.mxf-btn.amber:hover { box-shadow: 0 0 24px rgba(255,207,77,0.4); }
.mxf-btn.danger::before { background: var(--mxf-red); box-shadow: 0 0 10px var(--mxf-red); }

/* leaderboard tabs as pills */
.mxf-boardtabs .mxf-btab {
	background: rgba(0,0,0,0.35); border: 1px solid rgba(43,255,136,0.22);
	border-radius: 999px; padding: 6px 12px; font-size: 11px; color: var(--mxf-green-soft);
	cursor: pointer; transition: background .15s, border-color .15s, color .15s;
}
.mxf-boardtabs .mxf-btab.active { background: linear-gradient(180deg, rgba(43,255,136,0.25), rgba(43,255,136,0.06)); border-color: var(--mxf-green); color: #eaffe9; box-shadow: 0 0 14px rgba(43,255,136,0.25); }

/* donate banner glow */
.mxf-donate { border: 1px solid rgba(255,207,77,0.4); border-radius: 12px; background: linear-gradient(180deg, rgba(255,207,77,0.10), rgba(0,0,0,0.2)); box-shadow: 0 0 22px rgba(255,207,77,0.10) inset; }

/* ---- mobile tuning ---- */
@media (max-width: 720px) {
	.mxf-lobby-grid { gap: 14px; }
	.mxf-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px), (pointer: coarse) {
	.mxf-panel { padding: 20px 14px; border-radius: 12px; }
	.mxf-panel.wide { width: 96vw; }
	.mxf-stats { grid-template-columns: repeat(2, 1fr); }
	.mxf-btn { padding: 15px 14px; font-size: 13px; letter-spacing: 1.5px; }  /* bigger tap targets */
	.mxf-row { gap: 8px; }
	.mxf-boardtabs .mxf-btab { padding: 8px 12px; }
}

/* party chat — distinct purple channel */
.mxf-partymsg { color: #c9a6ff; }
.mxf-partymsg b { color: #b388ff; }

/* invite button inside the leaderboard rows */
.mxf-bright { display: inline-flex; align-items: center; gap: 8px; }
.mxf-invbtn { padding: 2px 8px; font-size: 12px; line-height: 1.3; border-radius: 6px; }
