table.map {
	border: 1px solid #000000;
	border-collapse: collapse;
}

td.map {
	border: 1px solid #666666;
	width: 32px;
	height: 32px;
}

td.wall {
	background-color: #000000;
}

td.red {
	background-color: #ff0000;
}

td.blue {
	background-color: #0000ff;
}

td.green {
	background-color: #00ff00;
}

td.field {
	background-color: #ffffff;
}

td.goal {
	background-color: #ffff00;
}

td.map > div {
	position: relative;
	top: 0;
	left: 0;
	margin: 0;
	padding: 0;
	width: 32px;
	height: 32px;
}

td.map > div > img {
	position: absolute;
	top: 1px;
	left: 1px;
	width: 30px;
	height: 30px;
	z-index: 5;
}

td.map > div > input[type="text"] {
	position: absolute;
	top: 1px;
	left: 1px;
	padding: 0;
	margin :0;
	border: 0 none;
	background-color: transparent;
	width: 30px;
	height: 30px;
	font-size: 16px;
	text-align: center;
	z-index: 1;
}
