:root {
	/* Light theme */
	--light-primary: #32CD32;
	--light-secondary: #228B22;
	--light-accent: #90EE90;
	--light-bg: #f5f6fa;
	--light-text: #1a1a1a;
	--light-modal-bg: #ffffff;

	/* Dark theme */
	--dark-primary: #006400;
	--dark-secondary: #004d00;
	--dark-accent: #008000;
	--dark-bg: #1a1a1a;
	--dark-text: #ffffff;
	--dark-modal-bg: #2d2d2d;

    --health-bar-height: 15px;
    --health-bar-min-height: 4vmin;
    --health-bar-radius: 5px;
    --boss-scale: 1.2;
    --super-hit-font-size: 100px;
    --super-hit-duration: 0.8s;
}

[data-theme="light"] {
	--primary-color: var(--light-primary);
	--secondary-color: var(--light-secondary);
	--accent-color: var(--light-accent);
	--bg-color: var(--light-bg);
	--text-color: var(--light-text);
	--modal-bg: var(--light-modal-bg);
}

[data-theme="dark"] {
	--primary-color: var(--dark-primary);
	--secondary-color: var(--dark-secondary);
	--accent-color: var(--dark-accent);
	--bg-color: var(--dark-bg);
	--text-color: var(--dark-text);
	--modal-bg: var(--dark-modal-bg);
}

.tab-content.locked {
    display: none !important;
}

[data-tab="boosts"] {
    display: none;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Bangers', cursive;
	letter-spacing: 1px;
	background-color: var(--bg-color);
	color: var(--text-color);
	height: 100vh;
}

h3 {
	font-size: 1.8rem;
	letter-spacing: 1.5px;
	color: var(--primary-color);
}

button {
	border: none;
	cursor: pointer;
	color: var(--text-color);
	letter-spacing: 1px;
	font-size: 1.2rem;
	padding: 0.5rem 1rem;
	transform-origin: center;
	transform: scale(1);
	transition: transform 0.075s ease-in-out;
	border-radius: 4px;
	font-family: 'Bangers', cursive;
}

button:not(:disabled):active {
	transform: scale(0.9);
}

.content-btn {
	background-color: var(--primary-color);
}

.top-bar {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	padding: 1rem;
	background-color: var(--primary-color);
	color: var(--text-color);
	gap: 1rem;
}

.top-bar-stats {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.top-bar-stat-icon {
	--size: 2.25rem;
	width: var(--size);
	height: var(--size);
	vertical-align: middle;
}

.top-bar-stat {
	line-height: 1;
	font-size: 2.25rem;
	display: flex;
	align-items: center;
	gap: 5px;
}

.top-bar-buttons {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.top-bar-btn {
	background-color: var(--accent-color);
	transition: background-color 0.3s;
}

.top-bar-btn[data-button="shop"] {
    display: none;
}

.top-bar-btn[data-button="shop"].unlocked {
    display: block;
}

.top-bar-btn[data-button="stats"] {
    display: none;
}

.top-bar-btn[data-button="stats"].unlocked {
    display: block;
}

.top-bar-btn:hover {
	background-color: var(--secondary-color);
	color: var(--text-color);
}

.top-bar-btn:disabled {
    background-color: #cccccc;
    cursor: not-allowed;
    color: #666666;
    opacity: 0.5;
}

.game-container {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 80vh;
	flex-direction: column;
	width: 100%;
	padding: 20px;
	box-sizing: border-box;
}

.ork-area {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 80vmin;
	max-width: 800px;
}

.ork {
	position: relative;
	cursor: pointer;
	user-select: none;
	display: inline-block;
	width: 100%;
}

.ork img {
	display: block;
	width: 100%;
	height: auto;
	transform-origin: center;
	transform: scale(1);
	transition: transform 0.075s ease-in-out;
}

.ork img.defeated {
	transform: scale(0) !important;
	transition: transform 0.32s ease-in-out;
}

.ork img:active {
	transform: none;
}

.ork img.boss {
    filter: hue-rotate(45deg) brightness(0.8) saturate(2);
    transform: scale(var(--boss-scale, 1.2));
}

.ork img.boss:active {
    transform: scale(calc(var(--boss-scale, 1.2) * 0.95));
}

.health-bar {
    width: 100%;
    height: min(var(--health-bar-height, 15px), var(--health-bar-min-height, 4vmin));
    background-color: #444;
    border-radius: var(--health-bar-radius, 5px);
    margin-top: 10px;
    overflow: hidden;
    border: 1px solid var(--primary-color);
}

.health-bar.boss {
	border-color: #ff4444;
}

.health-bar.boss .health-fill {
	background-color: #ff4444;
}

.health-fill {
	width: 100%;
	height: 100%;
	background-color: var(--primary-color);
	border-radius: 5px;
	transition: width 0.3s;
}

.modal {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--primary-color);
	z-index: 1000;
}

.modal-content {
	position: relative;
	width: 100%;
	height: 100%;
	background-color: var(--bg-color);
	padding: 0;
	display: flex;
	flex-direction: column;
}

.modal-header {
	background-color: var(--primary-color);
	color: var(--text-color);
	padding: 1rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.modal-header h2 {
	margin: 0;
	font-size: 2.5rem;
	letter-spacing: 2px;
}

.close-btn {
	margin: 0;
	padding: 0;
	background: none;
	color: var(--text-color);
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.close-btn svg {
	width: 100%;
	height: 100%;
}

.close-btn:hover svg {
	opacity: 0.8;
}

.tabs {
	display: flex;
	background-color: var(--bg-color);
	padding: 0.5rem;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.tab-btn {
	transition: background-color 0.3s;
}

.tab-btn:hover {
	background-color: var(--accent-color);
	color: var(--text-color);
}

.tab-btn.active {
	background-color: var(--accent-color);
	color: var(--text-color);
}

#shop-modal .tab-content {
	display: none;
	flex: 1;
	overflow-y: auto;
	padding: 1rem;
	background-color: var(--bg-color);
}

#shop-modal .tab-content.active {
	display: block;
}

#settings-modal .settings-content {
	display: block; 
	flex: 1;
	overflow-y: auto;
	padding: 1rem;
	background-color: var(--bg-color);
}

.settings-content {
	flex: 1;
	overflow-y: auto;
	padding: 1rem;
	background-color: var(--bg-color);
	display: block;
}

.content-item {
	background-color: var(--modal-bg);
	margin-bottom: 1rem;
	padding: 1.5rem;
	border-radius: 8px;
	border: 2px solid var(--primary-color);
	box-shadow: 0 2px 4px rgba(0,0,0,0.1);
	max-width: 600px;
}

.shop-item {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.shop-item-info {
	flex: 1;
}

.shop-item h3 {
	margin: 0 0 0.5rem 0;
}

.shop-item p {
	margin: 0;
	color: var(--secondary-color);
}

.shop-item-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ability-upgrades {
	display: none;	
	gap: 10px;
	flex-direction: column;
	border-top: var(--dark-accent) 2px solid;
	padding-top: 15px;
}

[data-super-hit-owned="true"] .ability-upgrades {
	display: flex;
}

.buy-btn {
	transition: background-color 0.3s;
}

.buy-btn:hover {
	background-color: var(--accent-color);
	color: var(--text-color);
}

.buy-btn:disabled {
	background-color: #cccccc;
	cursor: not-allowed;
	color: #666666;
}

.settings-option h3 {
	margin: 0 0 1rem 0;
	color: var(--primary-color);
}

.setting-buttons {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.theme-btn {
	border: 2px solid var(--primary-color);
	transition: all 0.15s;
	position: relative;
}

.theme-btn:hover {
	opacity: 0.85;
}

.theme-btn.active {
	border-color: var(--accent-color);
	transform: scale(1.05);
}

.effects-btn {
	border: 2px solid var(--primary-color);
	transition: all 0.15s;
	position: relative;
}

.effects-btn:hover {
	opacity: 0.85;
}

.effects-btn.active {
	border-color: var(--accent-color);
	transform: scale(1.05);
}

.stat-item h3 {
	margin: 0 0 0.5rem 0;
}

.stat-item p {
	margin: 0;
	color: var(--secondary-color);
	font-size: 1.5rem;
}

#stats-modal .stats-content {
	display: block; 
	flex: 1;
	overflow-y: auto;
	padding: 1rem;
	background-color: var(--bg-color);
}

.super-hit-upgrade {
	display: none;
}

.particle {
	position: fixed;
	pointer-events: none;
	background: var(--primary-color);
	border-radius: 50%;
	animation: particle-fade 0.5s ease-out forwards;
}

@keyframes particle-fade {
	0% {
		opacity: 1;
		transform: translate(0, 0) scale(1);
	}
	100% {
		opacity: 0;
		transform: translate(var(--tx), var(--ty)) scale(0);
	}
}

.super-hit-glove {
    position: fixed;
    font-size: var(--super-hit-font-size, 100px);
    bottom: -120px;
    left: 50%;
    transform: translateX(-50%);
    pointer-events: none;
    animation: glove-punch var(--super-hit-duration, 0.8s) cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

@keyframes glove-punch {
  0% {
	bottom: -120px;
	transform: translateX(-50%) rotate(0deg);
  }
  50% {
	bottom: 50%;
	transform: translateX(-50%) rotate(-45deg);
  }
  100% {
	bottom: -120px;
	transform: translateX(-50%) rotate(0deg);
  }
}

[data-unlock-condition] {
	opacity: 0;
	visibility: hidden;
	max-height: 0;
	overflow: hidden;
	transition: all 0.3s ease-out;
}

[data-unlock-condition].unlocked {
	opacity: 1;
	visibility: visible;
	max-height: 500px; 
}

@media (max-width: 525px) {
	.top-bar {
		flex-direction: column;
		align-items: stretch;
	}

	.top-bar-stats, .top-bar-buttons {
		width: 100%;
		justify-content: center;
	}

	.shop-item-content {
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}

	.buy-btn {
		max-width: 15rem;
		width: 100%;
		padding: 10px;
	}
}

.health-labels {
	display: flex;
	justify-content: center;
	gap: 1rem;
	margin-bottom: 1rem;
	flex-wrap: wrap;
}

.health-label {
	background-color: var(--primary-color);
	padding: 0.5rem 1rem;
	border-radius: 4px;
	font-size: 1.2rem;
}

.boss-label {
	background-color: #ff4444;
	animation: pulse 1s infinite alternate;
	font-weight: bold;
}

.coin-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 1000;
}

.floating-coin {
	position: absolute;
	display: flex;
	align-items: center;
	gap: 5px;
	transition: transform 1s cubic-bezier(0.3, 1, 0.64, 1), opacity 0.3s ease-in;
	transition-delay: 0s, 0.7s;
}

.floating-coin .coin-icon {
	--size: 2.25rem;
	width: var(--size);
	height: var(--size);
}

.floating-coin .coin-amount {
	color: var(--text-color);
	font-weight: bold;
	font-size: 2rem;
}

@keyframes pulse {
	from { transform: scale(1); }
	to { transform: scale(1.1); }
}