@font-face
{ /*	Vecna font create by Pixel Sagas
		https://www.fontspace.com/pixel-sagas
	*/
	font-family: "vecna";
	src: url("../layout/Vecna-oppx.ttf");
}
/*	Font: dhicons
		A: Open menu
		B: Close menu
		E: Explosion icon
		M: Forward arrow
		N: Back arrow
		O: Close button
		W: Check mark
		Y: Yeild sign
*/
@font-face
{
	font-family: "dhicons";
	src: url("../layout/dhicons.ttf") format("truetype");
	font-display: block;
}
/*
	CSS vars
*/
:root
{
	--icon-menu-open: "A";
	--icon-menu-close: "B";
	--icon-explode: "E";
	--icon-arrow_forward: "M";
	--icon-arrow_backward: "N";
	--icon-close: "O";
	--icon-check: "W";
	--icon-yeild: "Y";
	/*	link color and styles	*/
	--link-color: #900;
	--link-color-focus: #555;
}
/*
	Main Elements
*/
html,
body
{
	height: 100%;
	position: static;
	margin: 0;
	padding: 0;
	font-family: Arial, Helvetica, sans-serif;
}
body
{
	background-color: #210;
	background-repeat: repeat-x;
	background-position: top;
	background-image: url("../layout/header_banner_to_brown.jpg");
}
body:after
{
	display: block;
	position: absolute;
	content: url("../layout/CompassRose.svg");
	bottom: 10px;
	right: 10px;
}
h1
{
	margin: 0 10px;
	font-size: 42px;
	color: #210;
	font-family: vecna;
	position: absolute;
	right: 10px;
	top: 10px;
}
nav
{
	position: absolute;
	z-index: 1500;
	bottom: 0px;
}
#main_header
{
	height: 60px;
	position: relative
}
#main_content
{
	position: relative;
	margin: 0px 10px;
	min-width: 900px;
	display: flex;
	z-index: 1000;
}
#editor_container
{
	width: 100%;
	height: 600px;
	overflow: hidden;
	white-space: pre;
	border: inset 5px #ccc;
	background: #fff;
	position: relative;
	display: inline-block;	
}
#menu_container
{
	width: 300px;
	height: 600px;
	border: outset 5px #ccc;
	position: relative;
	display: inline-block;
	margin: 0 0 0 10px;
	color: #fff;
	overflow: auto;
	background: rgba(0, 0, 0, 0.8);
}
.menu_component
{
	margin: 10px;
}
.menu_component_title
{
	background-color: #000;
	font-size: 16px;
	padding: 4px;
}
.menu_component.map_title
{
	font-size: 21px;
	background: #000;
}
.menu_tile_icon
{
	display: inline-block;
}
.select_tile_list
{
	background: #222;
	border: solid 1px #222;
	margin: 0;
	padding: 0;
}
.select_tile_list li
{

}
/*
	Fancy "swtich" checkbox
*/
.switch 
{
	position: relative;
	display: inline-block;
	width: 50px;
	height: 28px;
}
.switch input 
{
	opacity: 0;
	width: 0;
	height: 0;
}
.slider 
{
	position: absolute;
	cursor: pointer;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	border: solid 1px #555;
	background-color: var(--link-color-focus);
	-webkit-transition: .4s;
	transition: .4s;
}
.slider:before 
{
	position: absolute;
	content: "";
	height: 19px;
	width: 19px;
	left: 4px;
	bottom: 4px;
	background-color: white;
	-webkit-transition: .4s;
	transition: .4s;
}
input:checked + .slider 
{
	background-color: var(--link-color);
}
input:hover + .slider 
{
	border: solid 1px var(--link-color);
}
input:checked + .slider:before 
{
	transform: translateX(19px);
}
/*	OptionsUI
*/
.options_ui_bar
{
	position: relative;
	z-index: 1600;
	margin: 0 10px;
}
.options_ui_select
{
	position: relative;
	display: inline-block;
	
}
.options_ui_select .options_ui_button
{
	position: relative;
	display: inline-block;
	font-size: 16px;
	padding: 6px 20px 6px 20px;
	color: #fff;
	background: var(--link-color);
	border: solid 2px var(--link-color-focus);
	border-bottom: 0;
	border-radius: 10px 10px 0px 0px;
}
.options_ui_select .options_ui_button:hover,
.options_ui_select .options_ui_button:focus
{
	background: var(--link-color-focus);
}
.options_ui_select .options_ui_list
{
	display: block;
	position: absolute;
	margin: 0;
	padding: 0;
	z-index: 1610;
	background: #eee;
}
.options_ui_select .options_ui_list_item
{
	list-style: none;
	text-align: left;
	display: inline-block;
	min-width: 200px;
	width: max-content;
}

.options_ui_select .options_ui_list.collapsed
{
	display: none;
}
.options_ui_select .options_ui_list_button
{
	padding: 3px 20px 3px 10px;
	border: solid 1px #888;
	text-align: left;
	width: 100%;
	color: var(--link-color);
}
.options_ui_select .options_ui_list_button:hover,
.options_ui_select .options_ui_list_button:focus
{
	color: var(--link-color-focus);
}
/*	Tile container
*/
svg.menu_tile_icon
{
	width: 40px !important;
	height: 40px !important;
/*	stroke-width: 5px; */
	cursor: pointer;
}
svg.menu_tile_icon > g
{
	transform: scale(0.4);
	user-select: none;
}
svg.menu_tile_icon:hover .map_tile_outline,
svg.menu_tile_icon:focus .map_tile_outline
{
	stroke: #900;
}
/*
*/
.map_editor
{
	display: block;
	position: relative;
	user-select: none;
}
.map_editor .map_tile
{
	display: block;
	position: absolute;
	padding: 0;
	margin: 0;
	user-select: none;
}
.map_tile_outline
{
	fill: none;
	stroke: #555;
}
.clear_button
{
	font-family: inherit;
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	cursor: pointer;
}
/*
	Modal Styles
*/
.modal_screen
{
	z-index: 2020;
	background-color: #000000;
	width: 100%;
	height: 100%;
	opacity: 0.8;
	top: 0;
	left: 0;
	position: fixed;
}
.modal_wrapper
{
	z-index: 2030;
	width: 100%;
	top: 0;
	text-align: center;
	position: fixed;
	display: block;
}
.modal_content
{
	z-index: 2040;
	text-align: left;
	background-color: #fff;
	display: inline-block;
	position: relative;
	overflow: hidden;
	max-width: 80%;
	max-height: 100%;
	border-radius: 0.5rem 0.5rem;
}
.modal_content img, 
.modal_content object{}
{
	float: left;
	padding: 5px;
	display: inline-block;
	overflow: hidden;
}
.modal_header
{
	background: #900;
}
.modal_footer
{
	height: 1em;
}
.modal_body
{
	text-align: left;
	margin: auto 1em;
	max-width: 100%;
	max-height: 100%;
}
.modal_body img
{
	max-width: 100%;
}
.modal_title
{
	color: rgb(255, 255, 255);
	display: inline-block;
	font-size: 21px;
	line-height: 24px;
	margin: 10px 20px;
}
.modal_title a
{
	color: #fff;
}
.modal_ttl a:hover, 
.modal_ttl a:active
{
	color: #ccf;
}
.modal_btn
{
	cursor: pointer; 
	margin: 5px 0px;
	height: 20px;
	width: 20px;
	display: block;
	font-size: 24px;
	line-height: 24px;
	color: #fff; /* var(--link-color); */
	
	border: none;
	background: transparent;
	
	position: absolute;
	right: 20px;
	top: 4px;
}
.modal_btn:hover, 
.modal_btn:active
{
	color: #c92;/* var(--link-color-focus); */
}
.modal_btn.close:after
{
	font-family: dhicons;
	content: var(--icon-close);
}

.modal_btn.next:after
{
	color: #99f;
	font-family: dhicons;
	content: var(--icon-arrow-forward);
}
.modal_btn.next:after:hover, 
.modal_btn.next:after:active
{
	color: #33f;
}
.modal_btn.prev:after
{
	color: #99f;
	font-family: dhicons;
	content: var(--icon-arrow_backward);
}
.modal_btn.prev:after:hover, 
.modal_btn.prev:after:active
{
	color: #33f;
}
.modal_fade_in
{
	opacity: 1;
	visibility: visible;
	speak: normal;
}
.modal_fade_out
{
	opacity: 0;
	visibility: hidden;
	speak: none;
}
/*
	Specific Modal Screen Styles
*/
.new_map_form
{
	margin: 20px 0;
	min-width: 400px;
}
.new_map_form label
{
	position: relative;
	display: block;
	text-align: left;
	height: 32px;
	width: 100%;
	margin: 10px 0;
}
.new_map_form label input
{
	position: absolute;
	left: 80px;
}
