/* The standard CSS for doxygen */
body, table, div, p, dl {
    font-family: Lucida Grande, Verdana, Geneva, Arial, sans-serif;
    font-size: 12px;
}
/* @group Heading Levels */
h1 {
    font-size: 150%;
}

h2 {
    font-size: 120%;
}

h3 {
    font-size: 100%;
}
dt {
    font-weight: bold;
}

div.multicol {
    -moz-column-gap: 1em;
    -webkit-column-gap: 1em;
    -moz-column-count: 3;
    -webkit-column-count: 3;
}

p.startli, p.startdd, p.starttd {
    margin-top: 2px;
}

p.endli {
    margin-bottom: 0px;
}

p.enddd {
    margin-bottom: 4px;
}

p.endtd {
    margin-bottom: 2px;
}
/* @end */

caption {
    font-weight: bold;
}

span.legend {
        font-size: 70%;
        text-align: center;
}

h3.version {
        font-size: 90%;
        text-align: center;
}

div.qindex, div.navtab{
	background-color: #DCEDFA;
	border: 1px solid #5FB1EB;
	text-align: center;
	margin: 2px;
	padding: 2px;
}

div.qindex, div.navpath {
	width: 100%;
	line-height: 140%;
}

div.navtab {
	margin-right: 15px;
}

/* @group Link Styling */

a {
	color: #0E4B76;
	font-weight: normal;
	text-decoration: none;
}

.contents a:visited {
	color: #115C92;
}

a:hover {
	text-decoration: underline;
}

a.qindex {
	font-weight: bold;
}

a.qindexHL {
	font-weight: bold;
	background-color: #54ABEA;
	color: #ffffff;
	border: 1px double #319AE6;
}

.contents a.qindexHL:visited {
        color: #ffffff;
}

a.el {
	font-weight: bold;
}

a.elRef {
}

a.code {
	color: #115C92;
}

a.codeRef {
	color: #115C92;
}

/* @end */

dl.el {
	margin-left: -1cm;
}

.fragment {
	font-family: monospace, fixed;
	font-size: 105%;
}

pre.fragment {
	border: 1px solid #97CCF2;
	background-color: #F8FBFE;
	padding: 4px 6px;
	margin: 4px 8px 4px 2px;
	overflow: auto;
	word-wrap: break-word;
	font-size:  9pt;
	line-height: 125%;
}

div.ah {
	background-color: black;
	font-weight: bold;
	color: #ffffff;
	margin-bottom: 3px;
	margin-top: 3px;
	padding: 0.2em;
	border: solid thin #333;
	border-radius: 0.5em;
	-webkit-border-radius: .5em;
	-moz-border-radius: .5em;
	-webkit-box-shadow: 2px 2px 3px #999;
	-moz-box-shadow: rgba(0, 0, 0, 0.15) 2px 2px 2px;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#eee), to(#000),color-stop(0.3, #444));
	background-image: -moz-linear-gradient(center top, #eee 0%, #444 40%, #000);
}

div.groupHeader {
	margin-left: 16px;
	margin-top: 12px;
	margin-bottom: 6px;
	font-weight: bold;
}

div.groupText {
	margin-left: 16px;
	font-style: italic;
}

body {
	background: white;
	color: black;
        margin: 0;
}

div.contents {
	margin-top: 10px;
	margin-left: 10px;
	margin-right: 10px;
}

td.indexkey {
	background-color: #DCEDFA;
	font-weight: bold;
	border: 1px solid #97CCF2;
	margin: 2px 0px 2px 0;
	padding: 2px 10px;
}

td.indexvalue {
	background-color: #DCEDFA;
	border: 1px solid #97CCF2;
	padding: 2px 10px;
	margin: 2px 0px;
}

tr.memlist {
	background-color: #E0EFFB;
}

p.formulaDsp {
	text-align: center;
}

img.formulaDsp {
	
}

img.formulaInl {
	vertical-align: middle;
}

div.center {
    text-align: center;
    margin-top: 0px;
    margin-bottom: 0px;
    padding: 0px;
}

div.center img {
    border: 0px;
    width: 100%;
    max-width: fit-content;
}

address.footer {
	text-align: right;
	padding-right: 12px;
}

img.footer {
	border: 0px;
	vertical-align: middle;
}

/* @group Code Colorization */

span.keyword {
	color: #008000
}

span.keywordtype {
	color: #604020
}

span.keywordflow {
	color: #e08000
}

span.comment {
	color: #800000
}

span.preprocessor {
	color: #806020
}

span.stringliteral {
	color: #002080
}

span.charliteral {
	color: #008080
}

span.vhdldigit { 
	color: #ff00ff 
}

span.vhdlchar { 
	color: #000000 
}

span.vhdlkeyword { 
	color: #700070 
}

span.vhdllogic { 
	color: #ff0000 
}

/* @end */

/*
.search {
	color: #003399;
	font-weight: bold;
}

form.search {
	margin-bottom: 0px;
	margin-top: 0px;
}

input.search {
	font-size: 75%;
	color: #000080;
	font-weight: normal;
	background-color: #e8eef2;
}
*/

td.tiny {
	font-size: 75%;
}

.dirtab {
	padding: 4px;
	border-collapse: collapse;
	border: 1px solid #5FB1EB;
}

th.dirtab {
	background: #DCEDFA;
	font-weight: bold;
}

hr {
	height: 0px;
	border: none;
	border-top: 1px solid #12639D;
}

hr.footer {
	height: 1px;
}

/* @group Member Descriptions */

table.memberdecls {
	border-spacing: 0px;
	padding: 0px;
}

.mdescLeft, .mdescRight,
.memItemLeft, .memItemRight,
.memTemplItemLeft, .memTemplItemRight, .memTemplParams {
	background-color: #F4F9FD;
	border: none;
	margin: 4px;
	padding: 1px 0 0 8px;
}

.mdescLeft, .mdescRight {
	padding: 0px 8px 4px 8px;
	color: #555;
}

.memItemLeft, .memItemRight, .memTemplParams {
	border-top: 1px solid #97CCF2;
}

.memItemLeft, .memTemplItemLeft {
        white-space: nowrap;
}

.memTemplParams {
	color: #115C92;
        white-space: nowrap;
}

/* @end */

/* @group Member Details */

/* Styles for detailed member documentation */

.memtemplate {
	font-size: 80%;
	color: #115C92;
	font-weight: normal;
	margin-left: 3px;
}

.memnav {
	background-color: #DCEDFA;
	border: 1px solid #5FB1EB;
	text-align: center;
	margin: 2px;
	margin-right: 15px;
	padding: 2px;
}

.memitem {
	padding: 0;
	margin-bottom: 10px;
	margin-right: 2px;
}

.memname {
    word-break: break-all;
    min-width: 6em;
    white-space: nowrap;
    font-weight: bold;
    margin-left: 6px;
}

.memproto {
        border-top: 1px solid #67B5EC;
        border-left: 1px solid #67B5EC;
        border-right: 1px solid #67B5EC;
        padding: 6px 0px 6px 0px;
        color: #062439;
        font-weight: bold;
        text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9);
        /* firefox specific markup */
        -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px;
        -moz-border-radius-topright: 8px;
        -moz-border-radius-topleft: 8px;
        /* webkit specific markup */
        -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15);
        -webkit-border-top-right-radius: 8px;
        -webkit-border-top-left-radius: 8px;
        background-image:url('nav_f.png');
        background-repeat:repeat-x;
        background-color: #CBE5F8;

}

.memdoc {
        border-bottom: 1px solid #67B5EC;      
        border-left: 1px solid #67B5EC;      
        border-right: 1px solid #67B5EC; 
        padding: 2px 5px;
        background-color: #F8FBFE;
        border-top-width: 0;
        /* firefox specific markup */
        -moz-border-radius-bottomleft: 8px;
        -moz-border-radius-bottomright: 8px;
        -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px;
        background-image: -moz-linear-gradient(center top, #FFFEFE 0%, #FFFEFE 60%, #F0F7FD 95%, #E0EFFB);
        /* webkit specific markup */
        -webkit-border-bottom-left-radius: 8px;
        -webkit-border-bottom-right-radius: 8px;
        -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15);
        background-image: -webkit-gradient(linear,center top,center bottom,from(#FFFEFE), color-stop(0.6,#FFFEFE), color-stop(0.60,#FFFEFE), color-stop(0.95,#F0F7FD), to(#E0EFFB));
}

.paramkey {
	text-align: right;
}

.paramtype {
	white-space: nowrap;
}

.paramname {
	color: #602020;
	white-space: nowrap;
}
.paramname em {
	font-style: normal;
}

/* @end */

/* @group Directory (tree) */

/* for the tree view */

.ftvtree {
	font-family: sans-serif;
	margin: 0px;
}

/* these are for tree view when used as main index */

.directory {
	font-size: 9pt;
	font-weight: bold;
	margin: 5px;
}

.directory h3 {
	margin: 0px;
	margin-top: 1em;
	font-size: 11pt;
}

/*
The following two styles can be used to replace the root node title
with an image of your choice.  Simply uncomment the next two styles,
specify the name of your image and be sure to set 'height' to the
proper pixel height of your image.
*/

/*
.directory h3.swap {
	height: 61px;
	background-repeat: no-repeat;
	background-image: url("yourimage.gif");
}
.directory h3.swap span {
	display: none;
}
*/

.directory > h3 {
	margin-top: 0;
}

.directory p {
	margin: 0px;
	white-space: nowrap;
}

.directory div {
	display: none;
	margin: 0px;
}

.directory img {
	vertical-align: -30%;
}

/* these are for tree view when not used as main index */

.directory-alt {
	font-size: 100%;
	font-weight: bold;
}

.directory-alt h3 {
	margin: 0px;
	margin-top: 1em;
	font-size: 11pt;
}

.directory-alt > h3 {
	margin-top: 0;
}

.directory-alt p {
	margin: 0px;
	white-space: nowrap;
}

.directory-alt div {
	display: none;
	margin: 0px;
}

.directory-alt img {
	vertical-align: -30%;
}

/* @end */

div.dynheader {
        margin-top: 8px;
}

address {
	font-style: normal;
	color: #082C46;
}

table.doxtable {
	border-collapse:collapse;
}

table.doxtable td, table.doxtable th {
	border: 1px solid #09304C;
	padding: 3px 7px 2px;
}

table.doxtable th {
	background-color: #0C4167;
	color: #FFFFFF;
	font-size: 110%;
	padding-bottom: 4px;
	padding-top: 5px;
	text-align:left;
}

.tabsearch {
	top: 0px;
	left: 10px;
	height: 36px;
	background-image: url('tab_b.png');
	z-index: 101;
	overflow: hidden;
	font-size: 13px;
}

.navpath ul
{
	font-size: 11px;
	background-image:url('tab_b.png');
	background-repeat:repeat-x;
	height:30px;
	line-height:30px;
	color:#379DE6;
	border:solid 1px #93CAF1;
	overflow:hidden;
	margin:0px;
	padding:0px;
}

.navpath li
{
	list-style-type:none;
	float:left;
	padding-left:10px;
	padding-right: 15px;
	background-image:url('bc_s.png');
	background-repeat:no-repeat;
	background-position:right;
	color:#0C3F63;
}

.navpath a
{
	height:32px;
	display:block;
	text-decoration: none;
	outline: none;
}

.navpath a:hover
{
	color:#1881CC;
}

div.summary
{
	float: right;
	font-size: 8pt;
	padding-right: 5px;
	width: 50%;
	text-align: right;
}       

div.summary a
{
	white-space: nowrap;
}

div.header
{
        background-image:url('nav_h.png');
        background-repeat:repeat-x;
	background-color: #F4F9FD;
	margin:  0px;
	border-bottom: 1px solid #97CCF2;
}

div.headertitle
{
	padding: 5px 5px 5px 10px;
}

body {
    background-image: url("body-gradient.png");
    background-repeat: repeat-x;
    overflow-y: scroll;
    padding-top: 0px;
    margin-top: 0px;
}

.tabs0 {
    background-image: url('tab_b.png');
    width: 100%;
    z-index: 101;
    font-size: 15px;
    margin-bottom: 0px;
}

.tabs0, .tabs, .tabs2, .tabs3, .navpath {
    border-bottom-width: 1px;
    border-bottom-color: #0077cf;
    border-bottom-style: solid;
    margin-bottom: 1px;
}
.navpath ul {
    border: 0px;
}
.tabs2 .tablist li {
    line-height: 30px;
}
.tabs3 {
    margin-bottom: 0px;
}
.tabs3 .tablist li {
    line-height: 27px;
}
.tablist {
    width: 100%;
}
#MSearchBox {
    position: relative;
    float: right;
}
div#header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0.25em;
    text-align: center;
}
div#header h1 {
    order: 2;
    padding: 1em;
    margin: 0px;
}
div#header a {
    order: 1;
    margin-left: auto;
}
div#header img {
    margin-right: 10px;
}
div.subnav {
    order: 3;
    /*font-weight: bold;*/
    font-size: 13px;
    /*color: #072941;*/
    color: #0077cf;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 1.0);
    z-index: 1;
    margin-right: auto;
}
div.subnav a {
    text-decoration: none;
    color: #0077cf;
}

div#content {
    background-image: url('content_b.png');
    background-repeat: repeat-x;
    width: 960px;
    min-height: 700px;
    margin-left: auto;
    margin-right: auto;
    padding: 10px 0px;
    text-align: justify;
    background-color: #ffffff;
    border-radius: 8px;
}

div.footer {
    width: 100%;
}
div.footer img {
    float: left;
    margin: 0px 5px;
}

a img {
    border:none;
}
.tabs, .tabs2, .tabs3 {
    background-image: url('tab_b.png');
    width: 100%;
    z-index: 101;
    font-size: 13px;
}

.tabs2 {
    font-size: 10px;
}
.tabs3 {
    font-size: 9px;
}

.tablist {
    margin: 0;
    padding: 0;
    display: table;
}

.tablist li {
    float: left;
    display: table-cell;
    background-image: url('tab_b.png');
    line-height: 36px;
    list-style: none;
}

.tablist a {
    display: block;
    padding: 0 1.5em;
    font-weight: bold;
    background-image:url('tab_s.png');
    background-repeat:no-repeat;
    background-position:right;
    color: #072941;
    text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9);
    text-decoration: none;
    outline: none;
}

.tabs3 .tablist a {
    padding: 0 1em;
}

.tablist a:hover {
    background-image: url('tab_h.png');
    background-repeat:repeat-x;
    color: #fff;
    text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0);
    text-decoration: none;
}

.tablist li.current a {
    background-image: url('tab_a.png');
    background-repeat:repeat-x;
    color: #fff;
    text-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0);
}
.memname { white-space: normal; }

@media screen and (max-width: 960px){
    div#content { width: 720px; min-width: 720px; }
    .tablist a { padding: 0 1em; }
}
@media screen and (max-width: 740px){
    div#content { width: 520px; min-width: 520px; }
    .tablist a { padding: 0 0.75em; }
    dl dd { margin-left: 20px; }
}

@media screen and (max-width: 540px){
    div#content { width: 100%; min-width: 100%; }
    div.contents { margin: 5px 5px 0px 5px; }
    .tablist a { padding: 0 0.5em; }
    .min500 { display: none; }
    dl dd { margin-left: 10px; }
    dl dd table tr td:nth-child(2) { word-break: break-all; min-width: 5em;}
    table.doxtable th, table.doxtable td { padding: 2px 4px; word-break: break-all; }
    .memdoc dl dd table tr td ul li { word-break: break-all; }
    .header .headertitle h1 { word-break: break-all; }
    a.el { word-break: break-all; }
    ul { padding-left: 20px; }
}

@media screen and (max-width: 400px){
    div.contents { margin: 2px 2px 0px 2px; }
    .min400 { display: none; }
    .tablist a { padding: 0 0.25em; }
    dl dd { margin-left: 0px; }
    table.doxtable th, table.doxtable td { padding: 1px 2px; }
}
