User prompt
Prevent the progress bar from appearing full when it first appears and then decreasing and filling up again. Prevent the progress bar from starting at 0 and continuing to fill up as shown. āŖš” Consider importing and using the following plugins: @upit/tween.v1
User prompt
Make the loading bars in the game fill more smoothly. āŖš” Consider importing and using the following plugins: @upit/tween.v1
User prompt
In the record video panel, let players type in the video name themselves, move the random button next to the name input field, and increase the space between the listed UI elements in the record video panel.
User prompt
Make the record video panel even wider and increase the space between buttons, text, etc. that you have listed.
User prompt
Expand the record video panel more. List the record new video text, name text, random button, category selection, record video button one below the other with some space between them.
User prompt
Expand the record video panel a little more and remove the text "Ready to record a new video? This will take 3 hours." and please do not put other names, specify a random name, select a category and record video button next to each other, keep them separate and add spaces between them.
User prompt
in the record video panel, Below the title section, add a dropdown or list of video categories for the player to choose from.
User prompt
In the Record Video Panel, the player should be able to enter a custom title for the video. There should also be a "Random" button that generates a random video title.
User prompt
When the player clicks the "Record Video" button, instead of starting the video recording immediately, show a panel first.
User prompt
Make sure the loading bar fills properly, from left to right.
User prompt
Please fix the bug: 'updateEnergy is not defined' in or related to this line: 'updateEnergy();' Line Number: 595
User prompt
Please fix the bug: 'energyBar is not defined' in or related to this line: 'energyBar.y = 210;' Line Number: 411
User prompt
Please fix the bug: 'editBtn is not defined' in or related to this line: 'editBtn.action = function () {' Line Number: 279
User prompt
remove energy mechanics from the game and add time mechanics to the game every second will be equal to 1 hour in the game and the player will be able to stop and continue the time if they want and shooting a video will take 3 hours for the game, editing a video will take 5 hours for the game and promoting will take 2 hours for the game and while one of them is being done the other cannot be done and while any process is being done we will be able to watch that process with a loading bar. āŖš” Consider importing and using the following plugins: @upit/tween.v1
User prompt
make the buttons a little bigger and stack them one under the other and also put some space between some of the UI's. āŖš” Consider importing and using the following plugins: @upit/tween.v1
User prompt
Make the positions of the ui more smooth and separate and design the shape of the ui buttons more modern.
User prompt
make the ui looks modern
User prompt
improve game
User prompt
improve game
User prompt
improve game
Code edit (1 edits merged)
Please save this source code
User prompt
Youtuber Tycoon: Fame Rush
Initial prompt
make a youtuber tycoon game
/**** 
* Plugins
****/ 
var tween = LK.import("@upit/tween.v1");
/**** 
* Classes
****/ 
// Energy bar class
var EnergyBar = Container.expand(function () {
	var self = Container.call(this);
	self.bg = self.attachAsset('energyBarBg', {
		anchorX: 0,
		anchorY: 0.5
	});
	self.fill = self.attachAsset('energyBarFill', {
		anchorX: 0,
		anchorY: 0.5
	});
	self.fill.x = 0;
	self.bg.x = 0;
	self.bg.y = 0;
	self.fill.y = 0;
	self.maxWidth = self.fill.width;
	self.set = function (ratio) {
		if (ratio < 0) ratio = 0;
		if (ratio > 1) ratio = 1;
		self.fill.width = self.maxWidth * ratio;
	};
	return self;
});
// Button class for all clickable actions
var GameButton = Container.expand(function () {
	var self = Container.call(this);
	self.bg = null;
	self.label = null;
	self.action = null;
	self.enabled = true;
	self.setButton = function (assetId, labelText, color, width, height) {
		self.bg = self.attachAsset(assetId, {
			anchorX: 0.5,
			anchorY: 0.5
		});
		self.bg.width = width;
		self.bg.height = height;
		// Modern look: more pronounced rounded corners and soft drop shadow
		self.bg.cornerRadius = Math.min(width, height) * 0.28;
		self.bg.shadow = {
			color: 0x111111,
			blur: 36,
			offsetX: 0,
			offsetY: 16,
			alpha: 0.32
		};
		self.label = new Text2(labelText, {
			size: 80,
			fill: color,
			font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
			dropShadow: true,
			dropShadowColor: "#222",
			dropShadowBlur: 12,
			dropShadowDistance: 2
		});
		self.label.anchor.set(0.5, 0.5);
		self.addChild(self.label);
	};
	self.setEnabled = function (val) {
		self.enabled = val;
		if (self.bg) {
			self.bg.alpha = val ? 1 : 0.4;
		}
	};
	self.down = function (x, y, obj) {
		if (!self.enabled) return;
		if (typeof self.action === 'function') {
			self.action();
		}
	};
	return self;
});
/**** 
* Initialize Game
****/ 
var game = new LK.Game({
	backgroundColor: 0x000000
});
/**** 
* Game Code
****/ 
// --- Game State Variables ---
// Studio background (simple box for now)
// Video button
// Edit button
// Promote button
// Upgrade button
// Energy bar background
// Energy bar fill
// Subscriber icon
// Money icon
// Sound for making a video
var subscribers = 0;
var money = 0;
var videoQuality = 1; // upgrades increase this
var editSkill = 1; // upgrades increase this
var promoteSkill = 1; // upgrades increase this
var videoCount = 0;
var upgradeCost = 20;
var upgradeLevel = 1;
// --- Time Mechanics ---
var gameHour = 8; // Start at 8:00
var gameDay = 1;
var isTimePaused = false;
var timeTimer = null;
var timeProcess = null; // {type: 'record'|'edit'|'promote', hoursLeft: int, onFinish: fn}
// --- UI Elements ---
var studioBg = LK.getAsset('studioBg', {
	anchorX: 0,
	anchorY: 0,
	x: 0,
	y: 0
});
game.addChild(studioBg);
// --- Time Display ---
var timeTxt = new Text2('Day 1, 08:00', {
	size: 80,
	fill: 0xFFFFFF
});
timeTxt.anchor.set(0.5, 0.5);
timeTxt.x = 2048 / 2;
timeTxt.y = 180;
game.addChild(timeTxt);
// --- Pause/Resume Button ---
var pauseBtn = new GameButton();
pauseBtn.setButton('editBtn', 'Pause', "#fff", 320, 120);
pauseBtn.x = 2048 / 2 + 520;
pauseBtn.y = 180;
pauseBtn.action = function () {
	isTimePaused = !isTimePaused;
	pauseBtn.label.setText(isTimePaused ? "Resume" : "Pause");
};
game.addChild(pauseBtn);
// Subscribers display
var subIcon = LK.getAsset('subIcon', {
	anchorX: 0.5,
	anchorY: 0.5,
	x: 2048 / 2 - 520,
	y: 140
});
game.addChild(subIcon);
var subTxt = new Text2('0', {
	size: 64,
	fill: 0xFFFFFF
});
subTxt.anchor.set(0, 0.5);
subTxt.x = subIcon.x + 70;
subTxt.y = subIcon.y;
game.addChild(subTxt);
// Money display
var moneyIcon = LK.getAsset('moneyIcon', {
	anchorX: 0.5,
	anchorY: 0.5,
	x: 2048 / 2 + 320,
	y: 140
});
game.addChild(moneyIcon);
var moneyTxt = new Text2('$0', {
	size: 64,
	fill: 0xFFE066
});
moneyTxt.anchor.set(0, 0.5);
moneyTxt.x = moneyIcon.x + 70;
moneyTxt.y = moneyIcon.y;
game.addChild(moneyTxt);
// --- Action Buttons ---
// Button layout: stack vertically, bigger, with spacing
var btnW = 540;
var btnH = 220;
var btnSpacingY = 60;
var btnStartY = 900;
// Make Video Button
var makeVideoBtn = new GameButton();
makeVideoBtn.setButton('videoBtn', 'Record Video', "#fff", btnW, btnH);
makeVideoBtn.x = 2048 / 2;
makeVideoBtn.y = btnStartY;
// Edit Button
var editBtn = new GameButton();
editBtn.setButton('editBtn', 'Edit Video', "#fff", btnW, btnH);
editBtn.x = 2048 / 2;
editBtn.y = makeVideoBtn.y + btnH + btnSpacingY;
// Promote Button
var promoteBtn = new GameButton();
promoteBtn.setButton('promoteBtn', 'Promote Video', "#fff", btnW, btnH);
promoteBtn.x = 2048 / 2;
promoteBtn.y = editBtn.y + btnH + btnSpacingY;
// --- Loading Bar for Process ---
var processBarBg = LK.getAsset('energyBarBg', {
	anchorX: 0.5,
	anchorY: 0.5
});
processBarBg.width = 600;
processBarBg.height = 60;
processBarBg.x = 2048 / 2;
processBarBg.y = 600;
processBarBg.visible = false;
game.addChild(processBarBg);
// AnchorX 0 for left-to-right fill
var processBarFill = LK.getAsset('energyBarFill', {
	anchorX: 0,
	anchorY: 0.5
});
processBarFill.width = 600;
processBarFill.height = 60;
// Position left edge of fill to match left edge of bg
processBarFill.x = processBarBg.x - processBarBg.width / 2;
processBarFill.y = 600;
processBarFill.visible = false;
game.addChild(processBarFill);
function showProcessBar(ratio) {
	processBarBg.visible = true;
	processBarFill.visible = true;
	if (ratio < 0) ratio = 0;
	if (ratio > 1) ratio = 1;
	processBarFill.width = 600 * ratio;
}
function hideProcessBar() {
	processBarBg.visible = false;
	processBarFill.visible = false;
}
// --- Action Button Logic (time-based) ---
makeVideoBtn.action = function () {
	if (timeProcess) return; // Only one process at a time
	// Show a panel before starting the process
	var panelBg = LK.getAsset('energyBarBg', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	panelBg.width = 1400;
	panelBg.height = 1100;
	panelBg.x = 2048 / 2;
	panelBg.y = 2732 / 2;
	panelBg.alpha = 0.98;
	// --- Panel Title ---
	var panelText = new Text2("Record New Video", {
		size: 100,
		fill: "#fff",
		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
		dropShadow: true,
		dropShadowColor: "#222",
		dropShadowBlur: 12,
		dropShadowDistance: 2
	});
	panelText.anchor.set(0.5, 0.5);
	panelText.x = panelBg.x;
	panelText.y = panelBg.y - 420;
	// --- Video Title Input ---
	var titleInputBg = LK.getAsset('energyBarBg', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	titleInputBg.width = 1000;
	titleInputBg.height = 130;
	titleInputBg.x = panelBg.x;
	titleInputBg.y = panelText.y + 140;
	titleInputBg.alpha = 0.92;
	var videoTitle = "";
	var titleInputTxt = new Text2("Enter video title...", {
		size: 72,
		fill: "#fff",
		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
		dropShadow: true,
		dropShadowColor: "#222",
		dropShadowBlur: 8,
		dropShadowDistance: 2
	});
	titleInputTxt.anchor.set(0.5, 0.5);
	titleInputTxt.x = titleInputBg.x;
	titleInputTxt.y = titleInputBg.y;
	// Simulate input: tap to edit, prompt for text
	titleInputBg.down = function (x, y, obj) {
		var prompt = LK.prompt ? LK.prompt : window.prompt; // fallback for dev
		var val = prompt ? prompt("Enter video title:", videoTitle) : "";
		if (typeof val === "string" && val.length > 0) {
			videoTitle = val;
			titleInputTxt.setText(videoTitle);
		}
	};
	// --- Random Title Button ---
	var randomBtn = new GameButton();
	randomBtn.setButton('promoteBtn', 'Random', "#fff", 340, 120);
	randomBtn.x = panelBg.x;
	randomBtn.y = titleInputBg.y + 130;
	randomBtn.action = function () {
		var titles = ["My Daily Vlog", "Epic Challenge!", "Reacting to Comments", "24 Hours in My Studio", "Behind the Scenes", "Q&A Special", "Trying Viral Trends", "Unboxing Surprise", "Life Update", "Funny Moments"];
		var idx = Math.floor(Math.random() * titles.length);
		videoTitle = titles[idx];
		titleInputTxt.setText(videoTitle);
	};
	// --- Video Category Dropdown/List ---
	var videoCategories = ["Vlog", "Challenge", "Reaction", "Tutorial", "Unboxing", "Gaming", "Music", "Comedy", "Q&A", "Other"];
	var selectedCategoryIdx = 0;
	var categoryBg = LK.getAsset('energyBarBg', {
		anchorX: 0.5,
		anchorY: 0.5
	});
	categoryBg.width = 1000;
	categoryBg.height = 120;
	categoryBg.x = panelBg.x;
	categoryBg.y = randomBtn.y + 140;
	categoryBg.alpha = 0.92;
	var categoryTxt = new Text2("Category: " + videoCategories[selectedCategoryIdx], {
		size: 68,
		fill: "#fff",
		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
		dropShadow: true,
		dropShadowColor: "#222",
		dropShadowBlur: 8,
		dropShadowDistance: 2
	});
	categoryTxt.anchor.set(0.5, 0.5);
	categoryTxt.x = categoryBg.x;
	categoryTxt.y = categoryBg.y;
	// Left/Right buttons for category selection
	var catLeftBtn = new GameButton();
	catLeftBtn.setButton('editBtn', "<", "#fff", 120, 120);
	catLeftBtn.x = categoryBg.x - categoryBg.width / 2 + 90;
	catLeftBtn.y = categoryBg.y;
	catLeftBtn.action = function () {
		selectedCategoryIdx = (selectedCategoryIdx - 1 + videoCategories.length) % videoCategories.length;
		categoryTxt.setText("Category: " + videoCategories[selectedCategoryIdx]);
	};
	var catRightBtn = new GameButton();
	catRightBtn.setButton('editBtn', ">", "#fff", 120, 120);
	catRightBtn.x = categoryBg.x + categoryBg.width / 2 - 90;
	catRightBtn.y = categoryBg.y;
	catRightBtn.action = function () {
		selectedCategoryIdx = (selectedCategoryIdx + 1) % videoCategories.length;
		categoryTxt.setText("Category: " + videoCategories[selectedCategoryIdx]);
	};
	// --- Confirm/Record Button ---
	var confirmBtn = new GameButton();
	confirmBtn.setButton('videoBtn', 'Start Recording', "#fff", 600, 180);
	confirmBtn.x = panelBg.x;
	confirmBtn.y = categoryBg.y + 170;
	confirmBtn.action = function () {
		// Remove panel
		panelBg.destroy();
		panelText.destroy();
		confirmBtn.destroy();
		cancelBtn.destroy();
		titleInputBg.destroy();
		titleInputTxt.destroy();
		randomBtn.destroy();
		categoryBg.destroy();
		categoryTxt.destroy();
		catLeftBtn.destroy();
		catRightBtn.destroy();
		// Start the process
		timeProcess = {
			type: 'record',
			hoursLeft: 3,
			total: 3,
			category: videoCategories[selectedCategoryIdx],
			title: videoTitle,
			onFinish: function onFinish() {
				LK.getSound('makeVideo').play();
				var baseSubs = 10 + Math.floor(Math.random() * 5) * videoQuality;
				var baseMoney = 5 + Math.floor(Math.random() * 3) * videoQuality;
				subscribers += baseSubs;
				money += baseMoney;
				videoCount += 1;
				updateStats();
				// Animate button
				tween(makeVideoBtn, {
					scaleX: 1.1,
					scaleY: 1.1
				}, {
					duration: 80,
					onFinish: function onFinish() {
						tween(makeVideoBtn, {
							scaleX: 1,
							scaleY: 1
						}, {
							duration: 80
						});
					}
				});
				if (subscribers >= 1000) {
					LK.showYouWin();
				}
			}
		};
		showProcessBar(0);
	};
	// --- Cancel Button ---
	var cancelBtn = new GameButton();
	cancelBtn.setButton('editBtn', 'Cancel', "#fff", 420, 150);
	cancelBtn.x = panelBg.x;
	cancelBtn.y = confirmBtn.y + 140;
	cancelBtn.action = function () {
		panelBg.destroy();
		panelText.destroy();
		confirmBtn.destroy();
		cancelBtn.destroy();
		titleInputBg.destroy();
		titleInputTxt.destroy();
		randomBtn.destroy();
		categoryBg.destroy();
		categoryTxt.destroy();
		catLeftBtn.destroy();
		catRightBtn.destroy();
	};
	// Add all panel elements to game
	game.addChild(panelBg);
	game.addChild(panelText);
	game.addChild(titleInputBg);
	game.addChild(titleInputTxt);
	game.addChild(randomBtn);
	game.addChild(categoryBg);
	game.addChild(categoryTxt);
	game.addChild(catLeftBtn);
	game.addChild(catRightBtn);
	game.addChild(confirmBtn);
	game.addChild(cancelBtn);
};
editBtn.action = function () {
	if (timeProcess) return;
	if (videoCount < 1) return;
	timeProcess = {
		type: 'edit',
		hoursLeft: 5,
		total: 5,
		onFinish: function onFinish() {
			LK.getSound('editVideo').play();
			var editBonus = 5 + Math.floor(Math.random() * 5) * editSkill;
			subscribers += editBonus;
			money += 2 * editSkill;
			updateStats();
			// Animate button
			tween(editBtn, {
				scaleX: 1.1,
				scaleY: 1.1
			}, {
				duration: 80,
				onFinish: function onFinish() {
					tween(editBtn, {
						scaleX: 1,
						scaleY: 1
					}, {
						duration: 80
					});
				}
			});
			if (subscribers >= 1000) {
				LK.showYouWin();
			}
		}
	};
	showProcessBar(0);
};
promoteBtn.action = function () {
	if (timeProcess) return;
	if (money < 5) return;
	money -= 5;
	updateStats();
	timeProcess = {
		type: 'promote',
		hoursLeft: 2,
		total: 2,
		onFinish: function onFinish() {
			LK.getSound('promoteVideo').play();
			var promoSubs = 15 + Math.floor(Math.random() * 10) * promoteSkill;
			subscribers += promoSubs;
			updateStats();
			// Animate button
			tween(promoteBtn, {
				scaleX: 1.1,
				scaleY: 1.1
			}, {
				duration: 80,
				onFinish: function onFinish() {
					tween(promoteBtn, {
						scaleX: 1,
						scaleY: 1
					}, {
						duration: 80
					});
				}
			});
			if (subscribers >= 1000) {
				LK.showYouWin();
			}
		}
	};
	showProcessBar(0);
};
// Upgrade Button (slightly wider, shorter, and spaced further)
var upgradeBtn = new GameButton();
upgradeBtn.setButton('upgradeBtn', 'Upgrade Studio', "#222", btnW, 140);
upgradeBtn.x = 2048 / 2;
upgradeBtn.y = promoteBtn.y + btnH + btnSpacingY + 40;
upgradeBtn.action = function () {
	if (money < upgradeCost) return;
	money -= upgradeCost;
	upgradeLevel += 1;
	videoQuality += 1;
	editSkill += 1;
	promoteSkill += 1;
	LK.getSound('upgrade').play();
	upgradeCost = Math.floor(upgradeCost * 1.7);
	updateStats();
	// Animate button
	tween(upgradeBtn, {
		scaleX: 1.1,
		scaleY: 1.1
	}, {
		duration: 80,
		onFinish: function onFinish() {
			tween(upgradeBtn, {
				scaleX: 1,
				scaleY: 1
			}, {
				duration: 80
			});
		}
	});
};
// Add buttons to game
game.addChild(makeVideoBtn);
game.addChild(editBtn);
game.addChild(promoteBtn);
game.addChild(upgradeBtn);
// Add extra vertical space between money/sub displays and buttons
subIcon.y = 110;
subTxt.y = subIcon.y;
moneyIcon.y = 110;
moneyTxt.y = moneyIcon.y;
// Removed undefined energyBar and energyTxt
// --- GUI: Timer/Score (use subscribers as score) ---
var scoreTxt = new Text2('0', {
	size: 120,
	fill: "#fff"
});
scoreTxt.anchor.set(0.5, 0);
LK.gui.top.addChild(scoreTxt);
// --- Helper Functions ---
function updateStats() {
	subTxt.setText(subscribers);
	moneyTxt.setText('$' + money);
	scoreTxt.setText(subscribers);
	upgradeBtn.label.setText('Upgrade Studio\n($' + upgradeCost + ')');
	// Enable/disable buttons based on process and resources
	makeVideoBtn.setEnabled(!timeProcess);
	editBtn.setEnabled(!timeProcess && videoCount > 0);
	promoteBtn.setEnabled(!timeProcess && money >= 5);
	upgradeBtn.setEnabled(money >= upgradeCost);
	// --- Achievements ---
	if (!updateStats.milestones) updateStats.milestones = {};
	var milestones = [100, 250, 500, 750, 1000];
	for (var i = 0; i < milestones.length; i++) {
		var m = milestones[i];
		if (subscribers >= m && !updateStats.milestones[m]) {
			updateStats.milestones[m] = true;
			var ach = new Text2("Milestone: " + m + " Subs!", {
				size: 110,
				fill: "#ff0",
				stroke: "#000",
				strokeThickness: 12,
				font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
				dropShadow: true,
				dropShadowColor: "#222",
				dropShadowBlur: 12,
				dropShadowDistance: 4
			});
			ach.anchor.set(0.5, 0.5);
			ach.x = 2048 / 2;
			ach.y = 400 + i * 80;
			game.addChild(ach);
			tween(ach, {
				alpha: 0,
				y: ach.y - 100
			}, {
				duration: 1800,
				onFinish: function onFinish() {
					ach.destroy();
				}
			});
		}
	}
}
// --- Time Update ---
function updateTimeDisplay() {
	var h = gameHour;
	var hStr = (h < 10 ? "0" : "") + h + ":00";
	timeTxt.setText("Day " + gameDay + ", " + hStr);
}
// --- Process Update ---
function updateProcessBar() {
	if (timeProcess) {
		var ratio = 1 - timeProcess.hoursLeft / timeProcess.total;
		showProcessBar(ratio);
	} else {
		hideProcessBar();
	}
}
// --- Time Timer ---
if (timeTimer) LK.clearInterval(timeTimer);
timeTimer = LK.setInterval(function () {
	if (isTimePaused) return;
	// Advance time
	gameHour += 1;
	if (gameHour >= 24) {
		gameHour = 0;
		gameDay += 1;
	}
	updateTimeDisplay();
	// Process logic
	if (timeProcess) {
		timeProcess.hoursLeft -= 1;
		updateProcessBar();
		if (timeProcess.hoursLeft <= 0) {
			var finish = timeProcess.onFinish;
			timeProcess = null;
			updateProcessBar();
			updateStats();
			if (typeof finish === "function") finish();
		}
	}
	updateStats();
}, 1000);
// --- Random Event Timer ---
var eventTimer = LK.setInterval(function () {
	// Pick a random event: 0 = trend, 1 = sponsorship, 2 = copyright strike, 3 = viral short (rare)
	var eventType;
	// 10% chance for viral short, else normal events
	if (Math.random() < 0.1) {
		eventType = 3;
	} else {
		eventType = Math.floor(Math.random() * 3);
	}
	var eventMsg = "";
	if (eventType === 0) {
		// Trend: bonus subs and money
		var trendSubs = 50 + Math.floor(Math.random() * 50);
		var trendMoney = 20 + Math.floor(Math.random() * 20);
		subscribers += trendSubs;
		money += trendMoney;
		updateStats();
		eventMsg = "Trending Topic! +" + trendSubs + " subs, +$" + trendMoney;
	} else if (eventType === 1) {
		// Sponsorship: big money
		var sponsorMoney = 60 + Math.floor(Math.random() * 40);
		money += sponsorMoney;
		updateStats();
		eventMsg = "Sponsorship! +$" + sponsorMoney;
	} else if (eventType === 2) {
		// Copyright strike: lose subs, lose money
		var strikeSubs = 30 + Math.floor(Math.random() * 30);
		var strikeMoney = 10 + Math.floor(Math.random() * 10);
		subscribers = Math.max(0, subscribers - strikeSubs);
		money = Math.max(0, money - strikeMoney);
		updateStats();
		eventMsg = "Copyright Strike! -" + strikeSubs + " subs, -$" + strikeMoney;
	} else if (eventType === 3) {
		// Viral Short: huge sub and money boost
		var viralSubs = 200 + Math.floor(Math.random() * 200);
		var viralMoney = 100 + Math.floor(Math.random() * 100);
		subscribers += viralSubs;
		money += viralMoney;
		updateStats();
		eventMsg = "Viral Short! +" + viralSubs + " subs, +$" + viralMoney;
	}
	// Show popup in the center of the screen
	var popup = new Text2(eventMsg, {
		size: 100,
		fill: "#fff",
		stroke: "#000",
		strokeThickness: 12,
		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
		dropShadow: true,
		dropShadowColor: "#222",
		dropShadowBlur: 12,
		dropShadowDistance: 4
	});
	popup.anchor.set(0.5, 0.5);
	popup.x = 2048 / 2;
	popup.y = 2732 / 2;
	game.addChild(popup);
	tween(popup, {
		alpha: 0,
		y: popup.y - 120
	}, {
		duration: 1800,
		onFinish: function onFinish() {
			popup.destroy();
		}
	});
}, 20000);
// --- Game Update Loop ---
game.update = function () {
	// Nothing needed for now, all logic is event/click based
};
// --- Touch/Drag Handling (no drag needed, but block top left 100x100) ---
game.down = function (x, y, obj) {
	// Prevent accidental clicks in top left
	if (x < 100 && y < 100) return;
};
game.move = function (x, y, obj) {};
game.up = function (x, y, obj) {};
// --- Initialize UI ---
updateStats();
// --- Daily Bonus at game start ---
(function showDailyBonus() {
	var bonusType = Math.floor(Math.random() * 2);
	var bonusMsg = "";
	if (bonusType === 0) {
		// Bonus subs
		var bonusSubs = 50 + Math.floor(Math.random() * 50);
		subscribers += bonusSubs;
		updateStats();
		bonusMsg = "Daily Bonus: +" + bonusSubs + " subs!";
	} else {
		// Bonus money
		var bonusMoney = 30 + Math.floor(Math.random() * 30);
		money += bonusMoney;
		updateStats();
		bonusMsg = "Daily Bonus: +$" + bonusMoney + "!";
	}
	var popup = new Text2(bonusMsg, {
		size: 110,
		fill: "#0ff",
		stroke: "#000",
		strokeThickness: 12,
		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
		dropShadow: true,
		dropShadowColor: "#222",
		dropShadowBlur: 12,
		dropShadowDistance: 4
	});
	popup.anchor.set(0.5, 0.5);
	popup.x = 2048 / 2;
	popup.y = 2732 / 2 - 200;
	game.addChild(popup);
	tween(popup, {
		alpha: 0,
		y: popup.y - 120
	}, {
		duration: 2000,
		onFinish: function onFinish() {
			popup.destroy();
		}
	});
})();
; ===================================================================
--- original.js
+++ change.js
@@ -235,16 +235,16 @@
 	var panelBg = LK.getAsset('energyBarBg', {
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
-	panelBg.width = 900;
-	panelBg.height = 900;
+	panelBg.width = 1400;
+	panelBg.height = 1100;
 	panelBg.x = 2048 / 2;
 	panelBg.y = 2732 / 2;
 	panelBg.alpha = 0.98;
 	// --- Panel Title ---
 	var panelText = new Text2("Record New Video", {
-		size: 90,
+		size: 100,
 		fill: "#fff",
 		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
 		dropShadow: true,
 		dropShadowColor: "#222",
@@ -252,22 +252,22 @@
 		dropShadowDistance: 2
 	});
 	panelText.anchor.set(0.5, 0.5);
 	panelText.x = panelBg.x;
-	panelText.y = panelBg.y - 320;
+	panelText.y = panelBg.y - 420;
 	// --- Video Title Input ---
 	var titleInputBg = LK.getAsset('energyBarBg', {
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
-	titleInputBg.width = 700;
-	titleInputBg.height = 110;
+	titleInputBg.width = 1000;
+	titleInputBg.height = 130;
 	titleInputBg.x = panelBg.x;
-	titleInputBg.y = panelText.y + 110;
+	titleInputBg.y = panelText.y + 140;
 	titleInputBg.alpha = 0.92;
 	var videoTitle = "";
 	var titleInputTxt = new Text2("Enter video title...", {
-		size: 64,
+		size: 72,
 		fill: "#fff",
 		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
 		dropShadow: true,
 		dropShadowColor: "#222",
@@ -287,11 +287,11 @@
 		}
 	};
 	// --- Random Title Button ---
 	var randomBtn = new GameButton();
-	randomBtn.setButton('promoteBtn', 'Random', "#fff", 260, 100);
+	randomBtn.setButton('promoteBtn', 'Random', "#fff", 340, 120);
 	randomBtn.x = panelBg.x;
-	randomBtn.y = titleInputBg.y + 100;
+	randomBtn.y = titleInputBg.y + 130;
 	randomBtn.action = function () {
 		var titles = ["My Daily Vlog", "Epic Challenge!", "Reacting to Comments", "24 Hours in My Studio", "Behind the Scenes", "Q&A Special", "Trying Viral Trends", "Unboxing Surprise", "Life Update", "Funny Moments"];
 		var idx = Math.floor(Math.random() * titles.length);
 		videoTitle = titles[idx];
@@ -303,15 +303,15 @@
 	var categoryBg = LK.getAsset('energyBarBg', {
 		anchorX: 0.5,
 		anchorY: 0.5
 	});
-	categoryBg.width = 700;
-	categoryBg.height = 100;
+	categoryBg.width = 1000;
+	categoryBg.height = 120;
 	categoryBg.x = panelBg.x;
-	categoryBg.y = randomBtn.y + 100;
+	categoryBg.y = randomBtn.y + 140;
 	categoryBg.alpha = 0.92;
 	var categoryTxt = new Text2("Category: " + videoCategories[selectedCategoryIdx], {
-		size: 60,
+		size: 68,
 		fill: "#fff",
 		font: "'GillSans-Bold',Impact,'Arial Black',Tahoma",
 		dropShadow: true,
 		dropShadowColor: "#222",
@@ -322,28 +322,28 @@
 	categoryTxt.x = categoryBg.x;
 	categoryTxt.y = categoryBg.y;
 	// Left/Right buttons for category selection
 	var catLeftBtn = new GameButton();
-	catLeftBtn.setButton('editBtn', "<", "#fff", 90, 90);
-	catLeftBtn.x = categoryBg.x - categoryBg.width / 2 + 70;
+	catLeftBtn.setButton('editBtn', "<", "#fff", 120, 120);
+	catLeftBtn.x = categoryBg.x - categoryBg.width / 2 + 90;
 	catLeftBtn.y = categoryBg.y;
 	catLeftBtn.action = function () {
 		selectedCategoryIdx = (selectedCategoryIdx - 1 + videoCategories.length) % videoCategories.length;
 		categoryTxt.setText("Category: " + videoCategories[selectedCategoryIdx]);
 	};
 	var catRightBtn = new GameButton();
-	catRightBtn.setButton('editBtn', ">", "#fff", 90, 90);
-	catRightBtn.x = categoryBg.x + categoryBg.width / 2 - 70;
+	catRightBtn.setButton('editBtn', ">", "#fff", 120, 120);
+	catRightBtn.x = categoryBg.x + categoryBg.width / 2 - 90;
 	catRightBtn.y = categoryBg.y;
 	catRightBtn.action = function () {
 		selectedCategoryIdx = (selectedCategoryIdx + 1) % videoCategories.length;
 		categoryTxt.setText("Category: " + videoCategories[selectedCategoryIdx]);
 	};
 	// --- Confirm/Record Button ---
 	var confirmBtn = new GameButton();
-	confirmBtn.setButton('videoBtn', 'Start Recording', "#fff", 480, 150);
+	confirmBtn.setButton('videoBtn', 'Start Recording', "#fff", 600, 180);
 	confirmBtn.x = panelBg.x;
-	confirmBtn.y = categoryBg.y + 120;
+	confirmBtn.y = categoryBg.y + 170;
 	confirmBtn.action = function () {
 		// Remove panel
 		panelBg.destroy();
 		panelText.destroy();
@@ -394,11 +394,11 @@
 		showProcessBar(0);
 	};
 	// --- Cancel Button ---
 	var cancelBtn = new GameButton();
-	cancelBtn.setButton('editBtn', 'Cancel', "#fff", 340, 120);
+	cancelBtn.setButton('editBtn', 'Cancel', "#fff", 420, 150);
 	cancelBtn.x = panelBg.x;
-	cancelBtn.y = confirmBtn.y + 110;
+	cancelBtn.y = confirmBtn.y + 140;
 	cancelBtn.action = function () {
 		panelBg.destroy();
 		panelText.destroy();
 		confirmBtn.destroy();
:quality(85)/https://cdn.frvr.ai/682b95eed57badfe131e115a.png%3F3) 
 subscriber icon 2d. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682b962fd57badfe131e1175.png%3F3) 
 money icon 2d. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682b98dbd57badfe131e1207.png%3F3) 
 solid grey colour background for panel. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682ba15cdea61304a2551ae8.png%3F3) 
 viewers icon for a mobile game. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682ba9a4dea61304a2551cc9.png%3F3) 
 make bigger this monitor
:quality(85)/https://cdn.frvr.ai/682c7ab2d8547f226be06ae3.png%3F3) 
 please to this white color
:quality(85)/https://cdn.frvr.ai/682c7b49d8547f226be06b28.png%3F3) 
 white play button solid white color. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682cbc364e929b7a3abcfc03.png%3F3) 
 double speed icon for mobile games. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat. no text. only white color.
:quality(85)/https://cdn.frvr.ai/682db9d5fa43d16281815466.png%3F3) 
 2d phone for mobile games. modern phone. looks good but phone is one color, phone's screen one color. Let it be completely 2-dimensional and not look like 3-dimensional. There should be a mute button and small volume up and down and hang up buttons on the sides of the phone.. In-Game asset. 2d. High contrast. No shadows - Fill the entire screen with a light gray color. - The outer cover color of the phone should be dark gray.
:quality(85)/https://cdn.frvr.ai/682dc052fa43d16281815542.png%3F3) 
 youtube button logo. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682dc1c4fa43d1628181555b.png%3F3) 
 white background rounded corners. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat white color. all white color no border.
:quality(85)/https://cdn.frvr.ai/682dc356fa43d16281815596.png%3F3) 
 playstore logo. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682dea63061118b95a6b14a0.png%3F3) 
 editing application logo. No background. Transparent background. Blank background. No shadows. 2d. In-Game asset. flat
:quality(85)/https://cdn.frvr.ai/682e034efa43d16281815dee.png%3F3) 
 çoĢp kutusu logosu fakat kırmızı arka planlı (çoĢp kutusu logosu beyaz renkte olacak). In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e039bfa43d16281815df7.png%3F3) 
 kırmızıya boya
:quality(85)/https://cdn.frvr.ai/682e0454fa43d16281815e10.png%3F3) 
 beyaza boya
:quality(85)/https://cdn.frvr.ai/682e0499fa43d16281815e1a.png%3F3) 
 maviye boya
:quality(85)/https://cdn.frvr.ai/682e08c6fa43d16281815e43.png%3F3) 
 istatistik logosu. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e09a9fa43d16281815e68.png%3F3) 
 reklam logosu herhangi bir yazı olmasın. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e0dc3fa43d16281815ebc.png%3F3) 
 record video logo with not text. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e19b1efead8bd4a0b8229.png%3F3) 
 finans logosu. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e3c44a71862ff1d51fbc5.png%3F3) 
 youtube studio logo with no text only logo. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e4509a71862ff1d51fc38.png%3F3) 
 create youtube channel avatar cartoon 2d. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e459aa71862ff1d51fc55.png%3F3) 
 youtube channel logo. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e4a5ea71862ff1d51fc8f.png%3F3) 
 "rastgele" ikonu, beyaz renginde olacak.. In-Game asset. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682e8335a71862ff1d51fe7c.png%3F3) 
 youtube thumbnail for vlog. 2d. High contrast. No shadows
:quality(85)/https://cdn.frvr.ai/682ea742efead8bd4a0b876d.png%3F3) 
 kilit ikonu beyaz. In-Game asset. 2d. High contrast. No shadows