:root {
	--bg: #050508;
	--bg2: #0a0a12;
	--surface: #141420;
	--surface2: #1a1a2a;
	--surface3: #222235;
	--border: #2a2a3a;
	--border-hi: #3a3a50;
	--text: #eee;
	--text2: #999;
	--text3: #555;
	--pri: #ff2d78;
	--pri-rgb: 255, 45, 120;
	--sec: #00f0ff;
	--sec-rgb: 0, 240, 255;
	--grn: #00e676;
	--grn-rgb: 0, 230, 118;
	--gold: #ffb300;
	--gold-rgb: 255, 179, 0;
	--purp: #b388ff;
	--purp-rgb: 179, 136, 255;
	--pink: #ff80ab;
	--pink-rgb: 255, 128, 171;
	--rad: 20px;
	--rad-sm: 12px;
	--rad-xs: 8px;
	--ease: cubic-bezier(0.16, 1, 0.3, 1);
	--spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
	font-family: 'Courier New', Courier, monospace;
	color: var(--text);
	background: var(--bg);
	overflow-x: hidden;
	line-height: 1.5;
	touch-action: manipulation;
	-webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-hi); }

#bgCanvas { position: fixed; inset: 0; z-index: 0; pointer-events: none; }

.aurora { display: none; }

.comboVignette {
	position: fixed; inset: 0; z-index: 45;
	pointer-events: none; opacity: 0; transition: opacity 0.3s;
}
.comboVignette.active { opacity: 1; animation: vigPulse 0.8s ease-in-out infinite alternate; }
@keyframes vigPulse { from { opacity: 0.7; } to { opacity: 1; } }

header {
	position: sticky; top: 0; z-index: 50;
	background: var(--bg2);
	border-bottom: 2px solid var(--border);
}
.nav {
	max-width: 1120px; margin: 0 auto;
	padding: 12px 20px;
	display: flex; justify-content: space-between; align-items: center;
}
.brand { display: flex; align-items: center; gap: 10px; }
.brand .dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: var(--pri);
	box-shadow: 0 0 12px rgba(var(--pri-rgb), 0.8);
	animation: dotP 2s ease-in-out infinite;
}
@keyframes dotP {
	0%, 100% { box-shadow: 0 0 8px rgba(var(--pri-rgb), 0.6); }
	50% { box-shadow: 0 0 16px rgba(var(--pri-rgb), 1); }
}
.brand .title { font-weight: 800; font-size: 14px; letter-spacing: 1px; text-transform: uppercase; }
.navRight { display: flex; align-items: center; gap: 12px; }
.nav a { color: var(--text3); text-decoration: none; font-weight: 600; font-size: 12px; transition: color 0.2s; }
.nav a:hover { color: var(--text2); }
.muteBtn {
	appearance: none; border: none; background: none; cursor: pointer;
	color: var(--text2); font-size: 16px; padding: 4px;
	transition: color 0.2s, transform 0.15s;
}
.muteBtn:hover { color: var(--text); transform: scale(1.2); }

.wrap {
	position: relative; z-index: 1;
	margin: 0; padding: 12px;
}
.grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}

.card {
	position: relative;
	background: var(--surface);
	border: 2px solid var(--border);
	border-radius: 12px;
	overflow: hidden;
}
.playCard {
	min-height: calc(100vh - 80px);
}
.playCard > .cardBody {
	display: flex; flex-direction: column; justify-content: center;
	min-height: calc(100vh - 140px);
}
.shopCard {
	border-color: var(--border);
}
.cardHead {
	padding: 16px 20px;
	border-bottom: 1px solid var(--border);
	display: flex; justify-content: space-between; align-items: center;
	position: relative; z-index: 1;
}
.cardTitle {
	font-size: 10px; font-weight: 800; text-transform: uppercase;
	letter-spacing: 2px; color: var(--text3);
}
.cardBody { padding: 28px 28px; position: relative; z-index: 1; }

.counterWrap { text-align: center; padding: 24px 0 28px; position: relative; }
.counterLarge {
	font-size: clamp(64px, 14vw, 110px);
	font-weight: 700;
	letter-spacing: -2px;
	line-height: 1;
	color: #fff;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
	transition: transform 0.12s var(--spring);
	transform-origin: center;
}
.counterLarge.counter-bump { animation: cBump 0.18s var(--spring); }
@keyframes cBump { 0% { transform: scale(1); } 40% { transform: scale(1.06); } 100% { transform: scale(1); } }

.comboDisplay { text-align: center; min-height: 24px; margin-top: 4px; }
.comboCounter {
	display: inline-block;
	font-weight: 800; font-size: 13px;
	padding: 3px 14px;
	border-radius: 20px;
	background: rgba(var(--sec-rgb), 0.08);
	color: var(--sec);
	border: 1px solid rgba(var(--sec-rgb), 0.15);
	animation: cPop 0.12s var(--spring);
}
@keyframes cPop { from { transform: scale(1.3); } to { transform: scale(1); } }
.comboCounter.c-high {
	font-size: 16px;
	background: rgba(var(--purp-rgb), 0.1);
	color: var(--purp);
	border-color: rgba(var(--purp-rgb), 0.2);
}
.comboCounter.c-mega {
	font-size: 20px;
	background: rgba(var(--pri-rgb), 0.08);
	color: var(--pink);
	border-color: rgba(var(--pri-rgb), 0.2);
	text-shadow: 0 0 10px rgba(var(--pri-rgb), 0.3);
}
.comboCounter.c-ultra {
	font-size: 24px;
	background: rgba(var(--gold-rgb), 0.08);
	color: var(--gold);
	border-color: rgba(var(--gold-rgb), 0.2);
	text-shadow: 0 0 14px rgba(var(--gold-rgb), 0.4);
	animation: cPop 0.12s var(--spring), uPulse 0.5s ease-in-out infinite alternate;
}
@keyframes uPulse {
	from { text-shadow: 0 0 14px rgba(var(--gold-rgb), 0.4); }
	to { text-shadow: 0 0 24px rgba(var(--gold-rgb), 0.7), 0 0 48px rgba(var(--gold-rgb), 0.2); }
}

.effectsBar {
	display: flex; gap: 6px; flex-wrap: wrap;
	justify-content: center;
	min-height: 4px; margin-top: 8px;
}
.effectPill {
	display: flex; align-items: center; gap: 5px;
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 11px; font-weight: 700;
	color: #fff;
	position: relative; overflow: hidden;
	animation: pillIn 0.3s var(--spring);
	border: 1px solid rgba(255,255,255,0.06);
}
@keyframes pillIn { from { opacity: 0; transform: scale(0.7) translateY(-6px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.effectPill .pillBg { position: absolute; inset: 0; opacity: 0.12; border-radius: 20px; }
.effectPill .pillTimer {
	position: absolute; bottom: 0; left: 0; height: 2px;
	border-radius: 0 0 20px 20px; opacity: 0.5;
	transition: width 0.12s linear;
}
.effectPill .pillText { position: relative; z-index: 1; }

.stats {
	display: flex; gap: 10px; margin-top: 20px; flex-wrap: wrap; justify-content: center;
}
.stat {
	flex: 1; min-width: 90px;
	background: var(--surface);
	border: 2px solid var(--border);
	border-radius: 8px;
	padding: 14px 16px;
	text-align: center;
	position: relative;
}
.stat .lab {
	font-size: 9px; color: var(--text3);
	text-transform: uppercase; letter-spacing: 1px;
	font-weight: 700;
}
.stat .val {
	font-size: 22px; font-weight: 900; margin-top: 2px;
	letter-spacing: -0.5px; transition: color 0.3s;
}
.stat .val.val-flash { color: var(--grn); }

.spaceWrap { margin-top: 20px; display: grid; gap: 12px; }
.spaceKey {
	user-select: none; position: relative; touch-action: manipulation;
	border-radius: 15px;
	padding: 40px 48px;
	text-align: center;
	font-weight: 900; letter-spacing: 12px; font-size: 26px;
	color: #fff;
	background: linear-gradient(180deg, var(--surface3), var(--surface));
	border: 3px solid var(--border-hi);
	border-bottom: 8px solid var(--border-hi);
	cursor: pointer;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
	transition: all 0.08s ease;
	outline: none;
}
.spaceKey::before {
	content: '';
	position: absolute; inset: 0; border-radius: 12px;
	background: linear-gradient(180deg, rgba(255,255,255,0.06) 0%, transparent 50%);
	pointer-events: none;
}
.spaceKey:hover {
	background: linear-gradient(180deg, var(--surface3), var(--surface2));
	border-color: #4a4a60;
}
.spaceKey.pressed {
	border-bottom-width: 3px;
	transform: translateY(5px);
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
	background: linear-gradient(180deg, var(--surface), var(--bg2));
}
.spaceKey:focus-visible { outline: 2px solid var(--sec); outline-offset: 4px; }


.actions { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 16px; }
.btn {
	appearance: none;
	border: 2px solid var(--border);
	border-bottom: 3px solid var(--border);
	background: var(--surface);
	color: var(--text2);
	padding: 8px 14px;
	border-radius: 6px;
	cursor: pointer; font-family: inherit;
	font-weight: 700; font-size: 12px;
	transition: all 0.1s;
}
.btn:hover { background: var(--surface2); color: var(--text); border-color: var(--border-hi); }
.btn.danger { border-color: #5a2020; color: #f87171; background: #2a1010; }
.btn.danger:hover { background: #3a1515; border-color: #7a3030; }
.btn.prestige {
	border-color: #3a2a5a;
	color: var(--purp); font-weight: 800;
	background: #1a1030;
}
.btn.prestige:hover {
	background: #251545;
	border-color: #5a3a7a;
}
.prestige-info { font-size: 11px; color: var(--text3); text-align: center; margin-top: 8px; }
.bulk-toggle {
	font-weight: 800; min-width: 48px; text-align: center;
	font-size: 12px; font-variant-numeric: tabular-nums;
}

.tabs {
	display: flex; gap: 4px; padding: 10px 16px;
	border-bottom: 1px solid var(--border);
}
.tab {
	appearance: none; border: 2px solid transparent;
	background: transparent; color: var(--text3);
	padding: 7px 14px; border-radius: 6px;
	cursor: pointer; font-weight: 700; font-size: 11px;
	font-family: inherit;
	white-space: nowrap; transition: all 0.15s;
	text-transform: uppercase; letter-spacing: 0.5px;
}
.tab:hover { color: var(--text2); background: var(--surface2); }
.tab.active {
	color: var(--sec);
	background: var(--surface);
	border-color: var(--border-hi);
}

.shopBody {
	padding: 14px; max-height: 70vh;
	overflow-y: auto; overflow-x: hidden;
}

.shopGrid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.shopTile {
	background: var(--surface2);
	border: 2px solid var(--border);
	border-radius: 8px;
	padding: 14px;
	transition: all 0.15s ease;
	position: relative; overflow: hidden;
	cursor: default;
	opacity: 0; transform: translateY(10px);
	animation: tileIn 0.25s var(--ease) forwards;
	animation-delay: var(--d, 0ms);
}
@keyframes tileIn { to { opacity: 1; transform: translateY(0); } }
.shopTile:hover {
	background: var(--surface3);
	border-color: var(--border-hi);
}
.shopTile.can-afford {
	border-color: rgba(var(--grn-rgb), 0.15);
}
.shopTile.can-afford:hover {
	border-color: rgba(var(--grn-rgb), 0.3);
	box-shadow: 0 0 20px rgba(var(--grn-rgb), 0.06);
}
.shopTile.buy-flash { animation: tFlash 0.35s ease-out; opacity: 1; transform: none; }
@keyframes tFlash {
	0% { background: rgba(var(--grn-rgb), 0.12); box-shadow: inset 0 0 30px rgba(var(--grn-rgb), 0.08); }
	100% { background: var(--surface); box-shadow: none; }
}
.shopTile .tileIcon {
	font-size: 24px; margin-bottom: 8px;
}
.shopTile .tileName {
	font-weight: 800; font-size: 13px;
	display: flex; align-items: center; gap: 6px;
	margin-bottom: 2px;
}
.shopTile .tileOwned {
	font-size: 10px; font-weight: 800;
	background: rgba(var(--sec-rgb), 0.08);
	color: var(--sec);
	padding: 0 5px; border-radius: 4px;
}
.shopTile .tileDesc {
	font-size: 10px; color: var(--text3);
	margin-bottom: 4px; line-height: 1.3;
}
.shopTile .tileCost {
	font-size: 11px; color: var(--text3);
	margin-bottom: 8px;
}
.shopTile .tileBar {
	height: 3px; border-radius: 2px;
	background: var(--bg2); overflow: hidden;
	margin-bottom: 8px;
}
.shopTile .tileBarFill {
	height: 100%; border-radius: 2px;
	background: var(--sec);
	transition: width 0.4s var(--ease);
}
.shopTile .tileBuy {
	appearance: none; width: 100%;
	border: 2px solid var(--border);
	border-bottom: 3px solid var(--border);
	background: var(--surface);
	color: var(--text2);
	padding: 6px; border-radius: 6px;
	font-weight: 700; font-size: 11px;
	font-family: inherit;
	cursor: pointer; transition: all 0.1s;
}
.shopTile .tileBuy.can-buy {
	background: #0a2a15;
	border-color: #1a5a30;
	color: var(--grn);
}
.shopTile .tileBuy.can-buy:hover {
	background: #0f3a1e;
	border-color: #2a7a40;
}
.shopTile .tileBuy[disabled] { opacity: 0.25; cursor: not-allowed; }

.purchaseLabel {
	position: fixed; z-index: 85; pointer-events: none;
	font-weight: 800; font-size: 13px;
	color: var(--grn); white-space: nowrap;
	text-shadow: 0 1px 6px rgba(0,0,0,0.7);
	animation: pFloat 0.8s var(--ease) forwards;
}
@keyframes pFloat {
	0% { opacity: 0; transform: translateY(0) scale(0.8); }
	15% { opacity: 1; transform: translateY(-10px) scale(1); }
	70% { opacity: 1; }
	100% { opacity: 0; transform: translateY(-50px); }
}

.prestige-header {
	text-align: center; padding: 14px 0 18px;
	border-bottom: 1px solid var(--border); margin-bottom: 12px;
}
.prestige-stardust {
	font-size: 24px; font-weight: 900; color: var(--gold);
	text-shadow: 0 0 20px rgba(var(--gold-rgb), 0.3);
}
.prestige-count { font-size: 11px; color: var(--text3); margin-top: 3px; }
.prestige-explain {
	font-size: 11px; color: var(--text2); line-height: 1.5;
	margin-top: 10px; padding: 10px 14px;
	background: var(--surface2); border-radius: var(--rad-xs);
	border: 1px solid var(--border);
	text-align: left;
}
.prestige-ascend-hint {
	font-size: 12px; color: var(--gold); font-weight: 700;
	margin-top: 8px;
}
.prestige-item { border-color: rgba(var(--purp-rgb), 0.1); }
.prestige-item:hover { border-color: rgba(var(--purp-rgb), 0.2); }
.prestige-item .tileIcon { color: var(--purp); }
.prestige-buy {
	background: rgba(var(--purp-rgb), 0.08) !important;
	border-color: rgba(var(--purp-rgb), 0.2) !important;
	color: var(--purp) !important;
}
.prestige-buy:hover {
	background: rgba(var(--purp-rgb), 0.15) !important;
	box-shadow: 0 0 12px rgba(var(--purp-rgb), 0.12) !important;
}
.prestige-buy[disabled] { opacity: 0.2 !important; }
.prestige-level {
	font-size: 10px; font-weight: 800;
	background: rgba(var(--purp-rgb), 0.08);
	color: var(--purp);
	padding: 0 5px; border-radius: 4px;
}

.achieve-header {
	text-align: center; padding: 12px 0 16px;
	border-bottom: 1px solid var(--border); margin-bottom: 14px;
}
.achieve-header .achieveCount { font-size: 18px; font-weight: 900; }
.achieve-header .achieveBonus { font-size: 11px; color: var(--grn); font-weight: 600; margin-top: 2px; }
.achieve-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.achieve-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--rad-sm);
	padding: 14px 10px;
	text-align: center;
	transition: all 0.3s; position: relative; overflow: hidden;
	opacity: 0; transform: scale(0.9);
	animation: acIn 0.3s var(--spring) forwards;
	animation-delay: var(--d, 0ms);
}
@keyframes acIn { to { opacity: 1; transform: scale(1); } }
.achieve-card.unlocked {
	border-color: rgba(var(--gold-rgb), 0.15);
	background: rgba(var(--gold-rgb), 0.02);
}
.achieve-card.unlocked::before {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient(105deg, transparent 40%, rgba(var(--gold-rgb), 0.06) 50%, transparent 60%);
	animation: acShim 3s ease-in-out infinite;
	pointer-events: none;
}
@keyframes acShim { 0% { transform: translateX(-100%); } 100% { transform: translateX(200%); } }
.achieve-card.locked { opacity: 0.3; }
.achieve-card.locked .achieve-progress {
	height: 2px; margin-top: 6px; border-radius: 2px;
	background: rgba(255,255,255,0.04); overflow: hidden;
}
.achieve-card.locked .achieve-progress-fill {
	height: 100%; border-radius: 2px;
	background: rgba(var(--gold-rgb), 0.3);
	transition: width 0.5s var(--ease);
}
.achieve-icon { font-size: 22px; margin-bottom: 4px; position: relative; z-index: 1; }
.achieve-name { font-size: 11px; font-weight: 700; margin-bottom: 2px; line-height: 1.2; position: relative; z-index: 1; }
.achieve-desc { font-size: 9px; color: var(--text3); margin-bottom: 4px; line-height: 1.3; position: relative; z-index: 1; }
.achieve-bonus { font-size: 10px; color: var(--grn); font-weight: 700; position: relative; z-index: 1; }

.synergy-header {
	text-align: center; padding: 12px 0 16px;
	border-bottom: 1px solid var(--border); margin-bottom: 14px;
}
.synergy-header .synCount { font-size: 18px; font-weight: 900; }
.synergy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.synergy-tile {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--rad-sm);
	padding: 14px;
	transition: all 0.2s; position: relative;
	opacity: 0; transform: translateY(8px);
	animation: tileIn 0.25s var(--ease) forwards;
	animation-delay: var(--d, 0ms);
}
.synergy-tile.active {
	border-color: rgba(var(--grn-rgb), 0.15);
	background: rgba(var(--grn-rgb), 0.02);
}
.synergy-tile .synIcon { font-size: 20px; margin-bottom: 6px; }
.synergy-tile .synName { font-weight: 700; font-size: 12px; margin-bottom: 2px; }
.synergy-tile .synDesc { font-size: 10px; color: var(--text3); line-height: 1.3; margin-bottom: 6px; }
.synergy-tile .synStatus {
	font-size: 10px; font-weight: 800;
	padding: 2px 8px; border-radius: 4px;
	display: inline-block;
}
.synergy-tile.active .synStatus { background: rgba(var(--grn-rgb), 0.08); color: var(--grn); }
.synergy-tile:not(.active) .synStatus { background: rgba(255,255,255,0.03); color: var(--text3); }

.sb-glow-1 {
	box-shadow: 0 0 30px rgba(var(--pri-rgb), 0.15), 0 0 60px rgba(var(--pri-rgb), 0.05);
}
.sb-glow-2 {
	box-shadow: 0 0 35px rgba(96,165,250,0.2), 0 0 70px rgba(96,165,250,0.07);
}
.sb-glow-3 {
	border-color: rgba(var(--purp-rgb), 0.3);
	box-shadow: 0 0 40px rgba(var(--purp-rgb), 0.25), 0 0 80px rgba(var(--purp-rgb), 0.08);
}
.sb-glow-4 {
	border-color: rgba(var(--pink-rgb), 0.35);
	box-shadow: 0 0 45px rgba(var(--pink-rgb), 0.25), 0 0 90px rgba(var(--pink-rgb), 0.1);
	animation: kShim 2s ease-in-out infinite alternate;
}
.sb-glow-5 {
	border-color: rgba(var(--gold-rgb), 0.4);
	box-shadow: 0 0 50px rgba(var(--gold-rgb), 0.3), 0 0 100px rgba(var(--gold-rgb), 0.12);
	animation: kShim 1.5s ease-in-out infinite alternate;
}
.sb-glow-4.pressed, .sb-glow-5.pressed { animation: none; }
@keyframes kShim { from { filter: brightness(1); } to { filter: brightness(1.1); } }

.counter-t1 { text-shadow: 0 0 30px rgba(var(--sec-rgb), 0.3), 0 0 60px rgba(var(--sec-rgb), 0.1); }
.counter-t2 { text-shadow: 0 0 35px rgba(96,165,250,0.35), 0 0 70px rgba(96,165,250,0.12); }
.counter-t3 {
	background: linear-gradient(135deg, #b388ff, #e040fb, #b388ff) !important;
	background-size: 200% 200% !important;
	-webkit-background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	background-clip: text !important;
	filter: drop-shadow(0 0 25px rgba(var(--purp-rgb), 0.35));
	animation: gradShift 6s ease infinite;
}
.counter-t4 {
	background: linear-gradient(135deg, #ff80ab, #ff4081, #ff80ab) !important;
	background-size: 200% 200% !important;
	-webkit-background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	background-clip: text !important;
	filter: drop-shadow(0 0 28px rgba(var(--pri-rgb), 0.35));
	animation: gradShift 6s ease infinite;
}
.counter-t5 {
	background: linear-gradient(135deg, #ffb300, #ff6f00, #ffb300, #ffe082) !important;
	background-size: 200% 200% !important;
	-webkit-background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	background-clip: text !important;
	filter: drop-shadow(0 0 30px rgba(var(--gold-rgb), 0.4));
	animation: gradShift 6s ease infinite;
}
@keyframes gradShift {
	0%, 100% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
}

.tierFlash {
	position: fixed; inset: 0; z-index: 450; pointer-events: none;
	animation: tFlashAnim 0.5s ease-out forwards;
}
@keyframes tFlashAnim { 0% { opacity: 0.6; } 100% { opacity: 0; } }

.goldenOrb {
	position: fixed;
	width: 64px; height: 64px;
	display: flex; align-items: center; justify-content: center;
	font-size: 26px;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 35%, #fff3e0, #ffb300 45%, #e65100 90%);
	box-shadow:
		0 0 24px rgba(var(--gold-rgb), 0.5),
		0 0 60px rgba(var(--gold-rgb), 0.2);
	cursor: pointer; z-index: 100;
	animation: gFloat 2.5s ease-in-out infinite alternate, gGlow 1.2s ease-in-out infinite;
	pointer-events: auto;
}
.goldenOrb::before {
	content: ''; position: absolute; inset: -6px;
	border-radius: 50%;
	border: 2px solid rgba(var(--gold-rgb), 0.25);
	animation: gRing 3s linear infinite;
}
.goldenOrb:hover { transform: scale(1.12); }
.goldenOrb:active { transform: scale(0.92); }
@keyframes gFloat { from { transform: translateY(-10px); } to { transform: translateY(10px); } }
@keyframes gGlow {
	0%, 100% { box-shadow: 0 0 24px rgba(var(--gold-rgb), 0.5), 0 0 60px rgba(var(--gold-rgb), 0.2); }
	50% { box-shadow: 0 0 36px rgba(var(--gold-rgb), 0.7), 0 0 80px rgba(var(--gold-rgb), 0.3); }
}
@keyframes gRing { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.goldenOrb.collected {
	animation: gCollect 0.4s ease-out forwards;
	pointer-events: none;
}
@keyframes gCollect {
	0% { transform: scale(1); opacity: 1; }
	40% { transform: scale(1.6); opacity: 0.7; }
	100% { transform: scale(0); opacity: 0; }
}

.resetModal {
	position: fixed; inset: 0; z-index: 400;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0, 0, 0, 0);
	transition: background 0.4s;
	padding: 20px;
	opacity: 0; pointer-events: none;
}
.resetModal.show { background: rgba(0, 0, 0, 0.9); opacity: 1; pointer-events: auto; }
.rmPanel {
	background: var(--bg2);
	border: 1px solid rgba(var(--pri-rgb), 0.15);
	border-radius: var(--rad);
	padding: 36px 32px;
	text-align: center;
	max-width: 380px; width: 100%;
	transform: scale(0.85) translateY(24px);
	opacity: 0;
	transition: all 0.4s var(--spring);
	box-shadow: 0 30px 80px rgba(var(--pri-rgb), 0.1);
}
.resetModal.show .rmPanel { transform: scale(1) translateY(0); opacity: 1; }
.rmIcon { font-size: 48px; margin-bottom: 12px; }
.rmTitle {
	font-size: 22px; font-weight: 900; color: #f87171;
	margin-bottom: 10px;
}
.rmDesc {
	font-size: 12px; color: var(--text2);
	margin-bottom: 24px; line-height: 1.6;
}
.rmBtns { display: flex; gap: 8px; justify-content: center; }
.rmConfirm {
	background: #2a1010;
	border: 1px solid #5a2020;
	color: #f87171;
	padding: 10px 28px; font-size: 14px; font-weight: 800;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s; font-family: inherit;
}
.rmConfirm:hover {
	background: #3a1515;
	box-shadow: 0 0 20px rgba(248, 113, 113, 0.15);
}
.rmCancel {
	background: var(--surface);
	border: 1px solid var(--border);
	color: var(--text3);
	padding: 10px 28px; font-size: 14px; font-weight: 600;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s; font-family: inherit;
}
.rmCancel:hover { background: var(--surface2); color: var(--text2); }

.prestigeModal {
	position: fixed; inset: 0; z-index: 400;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0, 0, 0, 0);
	transition: background 0.4s;
	padding: 20px;
	opacity: 0; pointer-events: none;
}
.prestigeModal.show { background: rgba(0, 0, 0, 0.9); opacity: 1; pointer-events: auto; }
.pmPanel {
	background: var(--bg2);
	border: 1px solid rgba(var(--purp-rgb), 0.15);
	border-radius: var(--rad);
	padding: 36px 32px;
	text-align: center;
	max-width: 380px; width: 100%;
	transform: scale(0.85) translateY(24px);
	opacity: 0;
	transition: all 0.4s var(--spring);
	box-shadow: 0 30px 80px rgba(var(--purp-rgb), 0.1);
	position: relative; overflow: hidden;
}
.prestigeModal.show .pmPanel { transform: scale(1) translateY(0); opacity: 1; }
.pmStarburst {
	position: absolute; inset: -60%;
	background: conic-gradient(from 0deg, transparent, rgba(var(--purp-rgb), 0.03) 8%, transparent 16%);
	animation: sbSpin 10s linear infinite;
	pointer-events: none;
}
@keyframes sbSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.pmTitle {
	font-size: 22px; font-weight: 900; color: var(--purp);
	margin-bottom: 10px; position: relative; z-index: 1;
}
.pmEarned {
	font-size: 34px; font-weight: 900; color: var(--gold);
	margin-bottom: 6px; position: relative; z-index: 1;
	text-shadow: 0 0 24px rgba(var(--gold-rgb), 0.3);
}
.pmDesc {
	font-size: 12px; color: var(--text3);
	margin-bottom: 24px; position: relative; z-index: 1;
	line-height: 1.6;
}
.pmBtns { display: flex; gap: 8px; justify-content: center; position: relative; z-index: 1; }
.pmConfirm {
	background: rgba(var(--purp-rgb), 0.1);
	border: 1px solid rgba(var(--purp-rgb), 0.25);
	color: var(--purp);
	padding: 10px 28px; font-size: 14px; font-weight: 800;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s;
}
.pmConfirm:hover {
	background: rgba(var(--purp-rgb), 0.2);
	box-shadow: 0 0 20px rgba(var(--purp-rgb), 0.15);
}
.pmCancel {
	background: var(--surface);
	border: 1px solid var(--border);
	color: var(--text3);
	padding: 10px 28px; font-size: 14px; font-weight: 600;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s;
}
.pmCancel:hover { background: var(--surface2); color: var(--text2); }

.acModal {
	position: fixed; inset: 0; z-index: 450;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0, 0, 0, 0);
	transition: background 0.4s;
	padding: 20px;
	opacity: 0; pointer-events: none;
}
.acModal.show { background: rgba(0, 0, 0, 0.92); opacity: 1; pointer-events: auto; }
.acPanel {
	background: var(--bg2);
	border: 1px solid rgba(var(--pri-rgb), 0.2);
	border-radius: var(--rad);
	padding: 36px 32px;
	text-align: center;
	max-width: 380px; width: 100%;
	transform: scale(0.85) translateY(24px);
	opacity: 0;
	transition: all 0.4s var(--spring);
	box-shadow: 0 30px 80px rgba(var(--pri-rgb), 0.15);
}
.acModal.show .acPanel { transform: scale(1) translateY(0); opacity: 1; }
.acIcon { font-size: 48px; margin-bottom: 12px; }
.acTitle {
	font-size: 20px; font-weight: 900; color: var(--pri);
	margin-bottom: 10px;
}
.acDesc {
	font-size: 13px; color: var(--text2);
	margin-bottom: 24px; line-height: 1.6;
}
.acDismiss {
	background: rgba(var(--pri-rgb), 0.1);
	border: 1px solid rgba(var(--pri-rgb), 0.25);
	color: var(--pri);
	padding: 10px 28px; font-size: 14px; font-weight: 800;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s;
}
.acDismiss:hover {
	background: rgba(var(--pri-rgb), 0.2);
	box-shadow: 0 0 20px rgba(var(--pri-rgb), 0.15);
}

.prestigeFlash {
	position: fixed; inset: 0; z-index: 500;
	background: radial-gradient(circle at center, rgba(var(--purp-rgb), 0.5) 0%, transparent 65%);
	pointer-events: none;
	animation: pFlash 0.6s ease-out forwards;
}
@keyframes pFlash {
	0% { opacity: 1; transform: scale(0.4); }
	50% { opacity: 0.7; transform: scale(1.3); }
	100% { opacity: 0; transform: scale(2.2); }
}

.ascendOverlay {
	position: fixed; inset: 0; z-index: 500;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0, 0, 0, 0);
	transition: background 0.4s;
	padding: 20px;
	opacity: 0; pointer-events: none;
}
.ascendOverlay.show { background: rgba(0, 0, 0, 0.92); opacity: 1; pointer-events: auto; }
.ascendPanel {
	background: var(--bg2);
	border: 1px solid rgba(var(--purp-rgb), 0.2);
	border-radius: var(--rad);
	padding: 40px 36px;
	text-align: center;
	max-width: 380px; width: 100%;
	transform: scale(0.8) translateY(30px);
	opacity: 0;
	transition: all 0.5s var(--spring);
	box-shadow: 0 30px 80px rgba(var(--purp-rgb), 0.15);
	position: relative; overflow: hidden;
}
.ascendOverlay.show .ascendPanel { transform: scale(1) translateY(0); opacity: 1; }
.ascendStarburst {
	position: absolute; inset: -60%;
	background: conic-gradient(from 0deg, transparent, rgba(var(--gold-rgb), 0.04) 8%, transparent 16%);
	animation: sbSpin 8s linear infinite;
	pointer-events: none;
}
.ascendIcon { font-size: 48px; margin-bottom: 12px; position: relative; z-index: 1; }
.ascendTitle {
	font-size: 26px; font-weight: 900; color: var(--purp);
	margin-bottom: 8px; position: relative; z-index: 1;
	text-shadow: 0 0 24px rgba(var(--purp-rgb), 0.3);
}
.ascendEarned {
	font-size: 36px; font-weight: 900; color: var(--gold);
	margin-bottom: 14px; position: relative; z-index: 1;
	text-shadow: 0 0 24px rgba(var(--gold-rgb), 0.3);
}
.ascendDesc {
	font-size: 13px; color: var(--text2);
	margin-bottom: 28px; position: relative; z-index: 1;
	line-height: 1.6;
}
.ascendBtn {
	appearance: none;
	background: rgba(var(--purp-rgb), 0.1);
	border: 1px solid rgba(var(--purp-rgb), 0.25);
	color: var(--purp);
	padding: 12px 36px; font-size: 15px; font-weight: 800;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s;
	position: relative; z-index: 1;
	font-family: inherit;
}
.ascendBtn:hover {
	background: rgba(var(--purp-rgb), 0.2);
	box-shadow: 0 0 20px rgba(var(--purp-rgb), 0.15);
}

.tooltip {
	position: fixed; z-index: 250;
	background: rgba(10, 10, 18, 0.96);
	border: 1px solid var(--border-hi);
	border-radius: var(--rad-sm);
	padding: 12px 14px;
	min-width: 200px; max-width: 260px;
	box-shadow: 0 12px 40px rgba(0,0,0,0.6);
	pointer-events: none; font-size: 11px;
	opacity: 0; transform: translateY(4px) scale(0.97);
	transition: opacity 0.15s, transform 0.15s var(--ease);
	backdrop-filter: blur(16px);
}
.tooltip.show { opacity: 1; transform: translateY(0) scale(1); }
.tooltip .ttTitle { font-weight: 800; font-size: 13px; margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.tooltip .ttRow { display: flex; justify-content: space-between; gap: 10px; padding: 2px 0; }
.tooltip .ttLabel { color: var(--text3); }
.tooltip .ttValue { font-weight: 700; color: var(--text); }
.tooltip .ttDivider { border: none; border-top: 1px solid var(--border); margin: 5px 0; }
.tooltip .ttTotal { color: var(--grn); font-weight: 800; }
.tooltip .ttEfficiency { color: var(--sec); }
.tooltip .ttBar {
	height: 3px; border-radius: 3px; margin-top: 6px;
	background: rgba(255,255,255,0.04); overflow: hidden;
}
.tooltip .ttBarFill {
	height: 100%; border-radius: 3px;
	background: linear-gradient(90deg, var(--sec), var(--grn));
}

.particleLayer {
	position: fixed; inset: 0; z-index: 80;
	pointer-events: none; overflow: hidden;
}
.particle {
	position: absolute; width: 4px; height: 4px;
	border-radius: 50%; pointer-events: none;
	animation: pBurst var(--pdur, 0.5s) ease-out forwards;
}
@keyframes pBurst {
	0% { transform: translate(0, 0) scale(1); opacity: 1; }
	100% { transform: translate(var(--px, 0), var(--py, 0)) scale(0); opacity: 0; }
}
.confetti {
	position: absolute; width: 8px; height: 8px;
	pointer-events: none;
	animation: cFall var(--cdur, 1.5s) ease-in forwards;
}
@keyframes cFall {
	0% { transform: translate(0, 0) rotate(0deg) scale(1); opacity: 1; }
	100% { transform: translate(var(--cx, 0), var(--cy, 400px)) rotate(var(--cr, 720deg)) scale(0.2); opacity: 0; }
}

.toasts {
	position: fixed; right: 14px; top: 14px;
	z-index: 200; display: grid; gap: 6px; max-width: 300px;
}
.toast {
	background: rgba(10, 10, 18, 0.95);
	color: var(--text);
	border: 1px solid var(--border-hi);
	border-radius: var(--rad-sm);
	padding: 10px 16px 12px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.5);
	backdrop-filter: blur(16px);
	font-size: 12px; font-weight: 600;
	animation: tIn 0.3s var(--spring);
	position: relative; overflow: hidden;
}
.toast .toastBar {
	position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
	background: rgba(var(--sec-rgb), 0.3);
	animation: tBarShrink var(--toast-dur, 2.5s) linear forwards;
}
@keyframes tBarShrink { from { transform: scaleX(1); transform-origin: left; } to { transform: scaleX(0); transform-origin: left; } }
@keyframes tIn { from { opacity: 0; transform: translateX(20px) scale(0.92); } to { opacity: 1; transform: translateX(0) scale(1); } }
.toast-prestige { border-color: rgba(var(--purp-rgb), 0.2); }
.toast-prestige .toastBar { background: rgba(var(--purp-rgb), 0.3); }
.toast-achieve { border-color: rgba(var(--gold-rgb), 0.2); }
.toast-achieve .toastBar { background: rgba(var(--gold-rgb), 0.3); }
.toast-golden {
	border-color: rgba(var(--gold-rgb), 0.2);
	background: rgba(var(--gold-rgb), 0.04);
}
.toast-golden .toastBar { background: rgba(var(--gold-rgb), 0.4); }

.ripple {
	position: absolute; border-radius: 50%; pointer-events: none;
	transform: translate(-50%,-50%);
	background: rgba(var(--pri-rgb), 0.3);
	width: 6px; height: 6px; opacity: 0.6;
	animation: rip 0.5s ease-out forwards;
}
@keyframes rip { to { opacity: 0; transform: translate(-50%,-50%) scale(25); } }

.floatAdd {
	position: absolute; left: 0; top: 0;
	transform: translate(-50%,-50%);
	pointer-events: none; z-index: 70;
	color: var(--pri); font-weight: 900; font-size: 28px;
	text-shadow: 0 2px 12px rgba(0,0,0,0.7), 0 0 20px rgba(var(--pri-rgb), 0.4);
	opacity: 0;
	animation: fAdd 0.9s ease-out forwards;
}
@keyframes fAdd {
	0% { transform: translate(-50%,-50%) translate(var(--x0,0), var(--y0,0)) scale(0.6); opacity: 0; }
	12% { opacity: 1; transform: translate(-50%,-50%) translate(calc(var(--x0,0) + (var(--x1,0) - var(--x0,0)) * 0.12), calc(var(--y0,0) + (var(--y1,-80px) - var(--y0,0)) * 0.12)) scale(1); }
	65% { opacity: 1; }
	100% { transform: translate(-50%,-50%) translate(var(--x1,0), var(--y1,-80px)); opacity: 0; }
}


.wb-overlay {
	position: fixed; inset: 0; z-index: 300;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0, 0, 0, 0); transition: background 0.4s;
	padding: 20px;
}
.wb-overlay.show { background: rgba(0, 0, 0, 0.9); }
.wb-panel {
	background: var(--bg2);
	border: 1px solid var(--border-hi);
	border-radius: var(--rad);
	padding: 36px 32px;
	text-align: center;
	max-width: 360px; width: 100%;
	transform: scale(0.85) translateY(24px);
	opacity: 0;
	transition: all 0.4s var(--spring);
	box-shadow: 0 24px 80px rgba(0,0,0,0.5);
}
.wb-overlay.show .wb-panel { transform: scale(1) translateY(0); opacity: 1; }
.wb-title { font-size: 24px; font-weight: 900; margin-bottom: 16px; }
.wb-earned {
	font-size: 40px; font-weight: 900; color: var(--grn);
	margin-bottom: 8px;
	text-shadow: 0 0 24px rgba(var(--grn-rgb), 0.3);
}
.wb-time { font-size: 12px; color: var(--text3); margin-bottom: 24px; }
.wb-collect {
	background: rgba(var(--grn-rgb), 0.1);
	border: 1px solid rgba(var(--grn-rgb), 0.25);
	color: var(--grn);
	padding: 12px 36px; font-size: 15px; font-weight: 800;
	border-radius: var(--rad-sm); cursor: pointer;
	transition: all 0.2s;
}
.wb-collect:hover {
	background: rgba(var(--grn-rgb), 0.2);
	box-shadow: 0 0 20px rgba(var(--grn-rgb), 0.12);
}

.screenShake { animation: shake 0.15s ease-out; }
@keyframes shake {
	0%, 100% { transform: translate(0, 0); }
	25% { transform: translate(-2px, 1px); }
	50% { transform: translate(1px, -2px); }
	75% { transform: translate(-1px, 1px); }
}

