html, body {
	height: 100%;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	font-family: sans-serif;
}

body > main {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
}
body.noscroll {
	overflow: hidden;
	height: 100vh;
}

body.noscroll main {
	overflow: hidden;
	height: 100%;
}

body.noscroll #map {
	height: 100vh;
}

#map {
	flex: 1 1 auto;
	width: 100%;
}

#controls form {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

#controls input[type="text"],
#controls input[type="number"],
#controls input[type="submit"] {
	width: 100%;
	box-sizing: border-box;
	padding: 6px;
	font-size: 14px;
}


header, footer {
	background: #333;
	color: white;
	padding: 1em;
}

nav {
	background: #eee;
}

a {
	text-decoration: none;
	margin-right: 1em;
}
#searchBox {
	padding: 10px;
	font-size: 14px;
	width: 25%;
	box-sizing: border-box;
	margin-top:10px;
}

	.menu-bar {
		background: #f8f8f8;
		padding: 12px 20px;
		border-bottom: 1px solid #ccc;
		display: flex;
		gap: 20px;
		font-family: sans-serif;
	}

	.menu-bar a {
		color: #333;
		text-decoration: none;
		padding: 6px 10px;
		border-radius: 5px;
		transition: background 0.2s, color 0.2s;
	}

	.menu-bar a:hover {
		background: #ddd;
	}

	.menu-bar a.active {
		background: #4285f4;
		color: white;
	}