*,
*::before,
*::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	transition: background-color 0.2s ease;
}

:root {
	font-family: Arial, sans-serif;
	background: var(--bg-primary);
	color: var(--fg-primary);
	font-size: var(--fs-regular);
	user-select: none;
	-webkit-user-select: none;
	overflow-y: auto;
	height: 100%;
	width: 100%;

	--fs-tiny: 12px;
	--fs-small: 14px;
	--fs-regular: 16px;
	--fs-medium: 20px;
	--fs-large: 36px;

	--game-width: 500px;
	--game-width-mobile: 90vw;

	--fg-primary: #d7dadc;
	--fg-secondary: #818384;
	--icon-color: #565758;
	--border-primary: #3a3a3c;
	--border-secondary: #272729;
	--bg-secondary: #1a1a1b;
	--mode-symbol-color: var(--bg-secondary);
	--bg-primary: #121213;
	
	/* Enhanced tile styling */
	--tile-bg: #1a1a1b;
	--tile-border: #3a3a3c;
	--tile-shadow: 0 2px 4px rgba(0,0,0,0.3);
	--key-bg: #1a1a1b;

	--red: #9C2323;
	--color-present: #b59f3b;
	--color-correct: #538d4e;
	--color-absent: var(--border-primary);
	--evaluated-key-color: var(--fg-primary);
	--key-bg: var(--fg-secondary);
}

body {
	height: 100%
}

.light {
	--fg-primary: #1a1a1b;
	--fg-secondary: #787c7e;
	--icon-color: var(--fg-secondary);
	--border-primary: #d3d6da;
	--border-secondary: var(--border-primary);
	--bg-secondary: #e0e0e0;
	--mode-symbol-color: #f1f1f1;
	--bg-primary: #ffffff;

	--red: #C42C2C;
	--color-present: #c9b458;
	--color-correct: #6aaa64;
	--color-absent: var(--fg-secondary);
	--evaluated-key-color: var(--bg-primary);
	--key-bg: var(--border-primary);
}

.colorblind {
	--color-correct: #f5793a;
	--color-present: #85c0f9;
}

h3 {
	text-align: center;
	text-transform: uppercase;
	margin-bottom: 10px;
}

.⬛,
.🟨,
.🟩 {
	color: var(--evaluated-key-color);
}

a:link,
a:visited {
	color: inherit;
}

.tutorial {
	--arrow-size: 10px;
	--padding: 10px;
	font-size: var(--fs-small);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: initial;
	position: absolute;
	top: calc(var(--arrow-size) + var(--height));
	left: 50%;
	transform: translateX(-50%);
	width: max-content;
	max-width: min(var(--game-width), 95vw);
	display: flex;
	align-items: center;
	padding: var(--padding);
	border-radius: 4px;
	color: var(--bg-primary);
	background: var(--fg-primary);
	z-index: 1;
}

.tutorial::before {
	content: "";
	position: absolute;
	left: 50%;
	transform: translate(-50%);
	top: calc(-2 * var(--arrow-size));
	border: var(--arrow-size) solid transparent;
	border-bottom: var(--arrow-size) solid var(--fg-primary);
}

.ok {
	padding: 10px;
	margin-left: var(--padding);
	border-radius: 4px;
	color: white;
	background: var(--color-correct);
	cursor: pointer;
}

.button {
	margin-top: 15px;
	text-transform: uppercase;
	color: #fff;
	cursor: pointer;
	font-size: var(--fs-medium);
	font-weight: bold;
	padding: 15px;
	border-radius: 4px;
	text-align: center;
}

.button:hover {
	opacity: 0.9;
}

select {
	border: solid 1px var(--border-secondary);
	padding: 8px;
	min-width: 85px;
	border-radius: 4px;
	cursor: pointer;
	background: var(--bg-secondary);
	color: var(--fg-primary);
}

/* Enhanced tile styling - override Svelte component styles */
.tile {
	background: var(--tile-bg) !important;
	border: 2px solid var(--tile-border) !important;
	border-radius: 8px !important;
	box-shadow: var(--tile-shadow) !important;
	min-height: 60px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	position: relative !important;
	width: 100% !important;
	height: 100% !important;
}

/* Override Svelte component front/back styling */
.tile .front {
	background: var(--tile-bg) !important;
	border: 2px solid var(--tile-border) !important;
	border-radius: 6px !important;
	color: var(--fg-primary) !important;
	width: 100% !important;
	height: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.tile .back {
	background: var(--tile-bg) !important;
	border-radius: 6px !important;
	width: 100% !important;
	height: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

/* Responsive tile sizing */
@media (max-width: 768px) {
	.tile {
		min-height: 50px !important;
		border-radius: 6px !important;
	}
}

@media (max-width: 480px) {
	.tile {
		min-height: 40px !important;
		border-radius: 4px !important;
	}
}

.tile .front {
	background: var(--tile-bg) !important;
	border-radius: 6px !important;
	width: 100% !important;
	height: 100% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.tile .back {
	border-radius: 6px !important;
}

/* Board container styling - override Svelte component */
.board {
	background: var(--bg-secondary) !important;
	border-radius: 12px !important;
	padding: 20px !important;
	box-shadow: 0 4px 20px rgba(0,0,0,0.3) !important;
	margin: 20px auto !important;
	max-width: var(--game-width) !important;
	border: 2px solid var(--border-primary) !important;
}

/* Override Svelte board grid styling */
.board {
	display: grid !important;
	grid-template-rows: repeat(6, 1fr) !important;
	gap: 8px !important;
	aspect-ratio: 5 / 6 !important;
}

/* Keyboard styling - override Svelte component */
.keyboard {
	background: var(--bg-secondary) !important;
	border-radius: 12px !important;
	padding: 20px !important;
	box-shadow: 0 4px 20px rgba(0,0,0,0.3) !important;
	margin: 20px auto !important;
	max-width: var(--game-width) !important;
	border: 2px solid var(--border-primary) !important;
	display: grid !important;
	grid-template-rows: repeat(3, 1fr) !important;
	gap: 8px !important;
}

.key {
	background: var(--key-bg) !important;
	border: 2px solid var(--border-primary) !important;
	border-radius: 8px !important;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2) !important;
	transition: all 0.2s ease !important;
	color: var(--fg-primary) !important;
	font-weight: bold !important;
	font-size: 1rem !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 50px !important;
	cursor: pointer !important;
}

.key:hover {
	background: var(--fg-primary) !important;
	color: var(--bg-primary) !important;
	transform: translateY(-1px) !important;
	box-shadow: 0 4px 8px rgba(0,0,0,0.3) !important;
}

.key:active {
	transform: translateY(0) !important;
	box-shadow: 0 1px 2px rgba(0,0,0,0.2) !important;
}

/* Game area specific styling */
.game-area {
	background: var(--bg-secondary) !important;
	border-radius: 16px !important;
	padding: 0px !important;
	box-shadow: 0 6px 24px rgba(0,0,0,0.4) !important;
	border: 2px solid var(--border-primary) !important;
	position: relative !important;
}

/* Ensure Svelte app container is properly styled */
#svelte {
	width: 100% !important;
	height: 100% !important;
	position: relative !important;
}

/* Responsive design for mobile devices */
@media (max-width: 768px) {
	.board {
		padding: 15px !important;
		margin: 15px auto !important;
		gap: 8px !important;
		max-width: var(--game-width-mobile) !important;
	}
	
	.keyboard {
		padding: 15px !important;
		margin: 15px auto !important;
		gap: 8px !important;
		max-width: var(--game-width-mobile) !important;
	}
	
	.key {
		border-radius: 6px !important;
		font-size: 14px !important;
		padding: 8px 4px !important;
	}
}

@media (max-width: 480px) {
	.board {
		padding: 10px !important;
		margin: 10px auto !important;
		gap: 6px !important;
		max-width: var(--game-width-mobile) !important;
	}
	
	.keyboard {
		padding: 10px !important;
		margin: 10px auto !important;
		gap: 6px !important;
		max-width: var(--game-width-mobile) !important;
	}
	
	.key {
		border-radius: 4px !important;
		font-size: 12px !important;
		padding: 6px 2px !important;
	}
}