/* Minimal CSS - Keep it simple */

body {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 1em;
	line-height: 1.5;
	color: #333;
	background: #fff;
	padding: 1em 1em;
	max-width: 120ch;
	margin: auto;
}

a {
	color: #0066cc;
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

a:visited {
	color: #663300;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 3em 0 1em;
}

p,
ul,
ol {
	margin-bottom: 2em;
	color: #1d1d1d;
	font-family: sans-serif;
}

table {
	border-collapse: collapse;
	margin: 15px 0;
	width: 100%;
	max-width: 100%;
}

table td,
table th {
	border: 1px solid #ddd;
	padding: 8px 10px;
	text-align: left;
}

table th {
	background: #f0f0f0;
	font-weight: bold;
}

/* Layout */
div#headline {
	text-align: center;
	padding: 20px 0;
	margin: 0 0 20px 0;
	border-bottom: 1px solid #ddd;
}

div#headline h1 {
	margin: 0;
	padding: 0;
	font-size: 32px;
	font-weight: bold;
}

div#headline h1 a {
	color: #000;
	text-decoration: none;
	transition: color 0.2s ease;
}

div#headline h1 a:hover {
	color: #0066cc;
}

/* Navigation containers */
div#linkbarcontainer1,
div#linkbarcontainer2 {
	float: none !important;
	width: 100% !important;
	margin: 10px 0 !important;
	padding: 0 !important;
	background: transparent !important;
	text-align: center;
	clear: both;
}

/* Top menu */
.Hmenu {
	width: auto !important;
	height: auto !important;
	float: none !important;
	display: inline-block;
	margin: 0 auto;
}

.Hmenu ul {
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0;
	background: #f5f5f5;
	border: 1px solid #ddd;
	border-radius: 4px;
}

.Hmenu li {
	float: none !important;
	width: auto !important;
	position: relative;
	margin: 0;
	border-right: 1px solid #ddd;
}

.Hmenu li:last-child {
	border-right: none;
}

.Hmenu a,
.Hmenu a:visited {
	display: block !important;
	padding: 8px 12px !important;
	width: auto !important;
	height: auto !important;
	line-height: 1.4 !important;
	border: none !important;
	background: transparent !important;
	color: #333 !important;
	font-size: 13px !important;
	font-weight: normal;
}

.Hmenu a:hover {
	background: #e8e8e8 !important;
	text-decoration: none;
}

/* Dropdown menus */
.Hmenu ul ul {
	position: absolute !important;
	top: 100%;
	left: 0;
	display: none !important;
	visibility: hidden !important;
	width: 180px !important;
	background: white;
	border: 1px solid #ccc;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	z-index: 100;
	margin-top: 0 !important;
	padding: 0 !important;
}

.Hmenu li:hover > ul {
	display: block !important;
	visibility: visible !important;
}

.Hmenu ul ul a,
.Hmenu ul ul a:visited {
	border: none !important;
	border-right: none !important;
	padding: 8px 12px !important;
	width: 100% !important;
	background: white !important;
	text-align: left;
}

.Hmenu ul ul a:hover {
	background: #f0f0f0 !important;
}

.Hmenu table {
	display: none !important;
}

/* Sidebar menu */
div#lmenucontainer {
	float: left !important;
	width: 200px !important;
	margin: 0 20px 0 0 !important;
	padding: 0 !important;
	flex-shrink: 0;
}

.table-of-contents {
	background: #f9f9f9;
	border: 1px solid #ddd;
	border-radius: 4px;
	padding: 15px;
	margin: 0;
	font-size: 13px;
	overflow-y: visible;
}

.table-of-contents h2 {
	font-size: 16px;
	margin: 0 0 15px 0;
	padding-bottom: 10px;
	border-bottom: 2px solid #ddd;
}

.table-of-contents ul {
	margin: 0 !important;
	padding-left: 20px;
	font-size: 13px;
}

.table-of-contents li {
	margin: 0;
	line-height: 1.5;
}

.table-of-contents a {
	color: #0066cc;
	text-decoration: none;
}

.table-of-contents a:hover {
	text-decoration: underline;
}

.table-of-contents a:visited {
	color: #663300;
}

.Vmenu {
	margin: 0 !important;
	height: auto !important;
	font-size: 12px !important;
	font-family: inherit !important;
	background: transparent;
	border: none;
	border-radius: 0;
	padding: 0;
}

.Vmenu ul {
	list-style: none;
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column;
	width: auto !important;
	z-index: auto !important;
	position: relative !important;
}

.Vmenu li {
	background: transparent !important;
	float: none !important;
	position: relative;
	margin: 0;
	border-bottom: 1px solid #ddd;
}

.Vmenu li:last-child {
	border-bottom: none;
}

.Vmenu a,
.Vmenu a:visited {
	display: block !important;
	padding: 8px 10px !important;
	text-decoration: none !important;
	color: #333 !important;
	height: auto !important;
	line-height: 1.3 !important;
	width: auto !important;
	font-weight: normal;
	background: transparent !important;
	border: none !important;
}

.Vmenu a:hover {
	background: #e8e8e8 !important;
}

/* Colored menu items */
.Vmenu li[style*="background-color"] {
	background: transparent !important;
}

.Vmenu li[style*="background-color"] a {
	background: transparent !important;
	font-weight: bold;
}

/* Nested menus */
.Vmenu ul ul {
	position: static !important;
	display: none !important;
	visibility: visible !important;
	flex-direction: column;
	width: 100% !important;
	background: white;
	border-top: 1px solid #ddd;
	margin: 0 !important;
	padding: 0 !important;
	box-shadow: none;
}

.Vmenu li:hover > ul {
	display: flex !important;
}

.Vmenu ul ul a {
	padding: 6px 15px !important;
	font-size: 11px;
}

.Vmenu table {
	display: none !important;
}

.Vmenu b {
	display: none;
}

/* Search box */
div#search {
	float: right !important;
	width: auto !important;
	margin: 10px 0 10px 15px !important;
	padding: 10px;
	background: #ffffcc !important;
	border: 1px solid #999 !important;
	border-radius: 4px;
	clear: none;
}

div#search table {
	margin: 0;
	border: none;
}

div#search td {
	border: none;
	padding: 2px 5px;
}

div#search input {
	padding: 4px;
	border: 1px solid #999;
	border-radius: 3px;
	font-size: 12px;
}

/* Main content */
div#main {
	overflow: visible;
	font-family: inherit !important;
	display: flow-root;
}

div#main a span {
	display: inline !important;
	position: relative !important;
	margin: 0 !important;
	background: transparent !important;
}

/* Footer */
div#footer {
	clear: both;
	margin-top: 30px !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	padding: 20px 0;
	border-top: 1px solid #ddd;
	font-size: 11px;
	text-align: center;
	color: #666;
}

div#footer a {
	margin: 0 5px;
	color: #666;
}

/* Responsive */
@media (max-width: 768px) {
	body {
		padding: 10px;
	}

	div#lmenucontainer {
		float: none !important;
		width: 100% !important;
		margin: 0 0 15px 0 !important;
	}

	.table-of-contents {
		max-height: none;
	}

	div#main {
		margin-left: 0 !important;
	}

	.Vmenu ul {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.Vmenu ul ul {
		position: static;
		width: 100% !important;
		border: none;
		display: flex;
	}

	.Hmenu ul {
		flex-direction: column;
	}

	.Hmenu li {
		border-right: none;
		border-bottom: 1px solid #ddd;
	}

	.Hmenu li:last-child {
		border-bottom: none;
	}

	div#search {
		float: none !important;
		margin: 10px 0 !important;
	}
}

/* Remove deprecated elements styling */
font {
	font-family: inherit;
	font-size: inherit;
}

blink {
	animation: none;
}

/* Utility */
small {
	font-size: 0.85em;
}
