
/* ==== MENU ==== */

nav.menu {
	padding: 0;
	margin: 0;
	line-height: 1.5em;
	font-size: 0.9em;
}


nav.menu {
}

nav.menu ul {
	display: -webkit-box;
	display: -moz-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	/* align-items: flex-start; */
	align-items: center;
	justify-content: center;
	flex-direction: row;
	flex-wrap: wrap;
	margin: 0;
}

nav.menu li {
	flex-grow: 3;
	margin: 0;
	padding: 1px;
	min-width: 2.5em;
	text-align: center;
	position: relative;
	z-index: 1;
}

.menu a:link, .menu a:visited, .menu a:hover, .menu a:active {
	padding: 0.5em .2em 0.3em;
	display: block;
	border: 1px solid rgba(255,255,255,0.2);
	white-space: nowrap;
	text-decoration: none;
}


/* ==== MAIN MENU ==== */

.menu.menu--main {
	background-color: var(--menu-main-bg);
}

.menu.menu--main li:first-of-type, .menu.menu--main li:last-of-type {
	/* flex-grow: 1; */
}

.menu.menu--main {
	width: 100%;	
	box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
	border-bottom: var(--menu-main-border-b);
}

.menu.menu--main a:link, .menu.menu--main a:visited, .menu.menu--main a:hover, .menu.menu--main a:active {
	color: var(--menu-main-a-color);
	background-color: var(--menu-main-a-bg);
}


.menu.menu--main a[data-curr='1'] {
	background-color: var(--menu-main-a-curr-bg);
	color: var(--menu-main-a-curr-color);
	border: 1px solid rgba(0,100,0,0.3);
}

.menu.menu--main a:hover, .menu.menu--main a:active {
	border: 1px solid rgba(0,0,0,0.1);
	background-color: var(--menu-main-a-hover-bg);
	color: var(--menu-main-a-hover-color);
}

/* ==== SUBMENU ==== */


nav.menu--sub {
	background-color: var(--menu-sub-bg);
	border-bottom: var(--menu-sub-border-b);
	box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
	/* box-shadow: 0px 3px 3px rgba(0,0,0,0.1); */
	padding: 1em;
	font-size: .85em;
}


section nav.menu--sub {
	background-color: rgba(255,255,255,0.05);
	border-bottom: 0;
	margin-bottom: 2rem;
	/* box-shadow: 0; */
}

nav.menu--sub a {
	display: inline-block;
	padding: 0.1em 1em;
	margin: 0.3em;
	border: 1px solid #115533;
	border-radius: 0.5em 0;
}

.menu--sub a:link, .menu--sub a:visited, .menu--sub a:hover, .menu--sub a:active {
	color: var(--menu-sub-a-color);
	background-color: var(--menu-sub-a-bg);
}
.menu--sub a:hover, .menu--sub a:active {
	color: var(--menu-sub-a-hover-color);
	background-color: var(--menu-sub-a-hover-bg);
}


.menu.menu--sub a[data-curr='1'] {
	background-color: var(--menu-sub-a-curr-bg);
	color: var(--menu-sub-a-curr-color);
	border: 1px solid rgba(0,100,0,0.3);
}


nav.menu--sub:last-of-type {
	/* border: none; */
}


nav.menu--sub a:hover, a.link--button:hover {
	background-color: rgba(255,255,255,0.1);	
	border: 1px solid #117766;
}

/* ==== NODE MENU ==== */


nav.menu--node {
	background-color: var(--menu-sub-bg);
	border-bottom: var(--menu-sub-border-b);
	box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
	/* padding: 1em; */
	/* border: 1px solid white; */
	
}


nav.menu--node {
	background-color: rgba(255,255,255,0.05);
	border-bottom: 0;
	/* margin-bottom: 2rem; */
}

nav.menu--node:empty, nav.menu--node ul:empty {
	display: none;
}

nav.menu--node ul {
	width: fit-content;
}

nav.menu--node li {
	box-sizing: border-box;
	min-width: fit-content;
	
}
nav.menu--node a {
	/* box-sizing: border-box; */
}

.menu--node a:link, .menu--node a:visited, .menu--node a:hover, .menu--node a:active {
	display: inline-block;
	padding: 0.1rem 3rem;
	margin: 0.2rem;
	border: 1px solid #115533;
	border-radius: 0.5em 0;
	font-size: .75rem;
	
	color: var(--menu-sub-a-color);
	background-color: var(--menu-sub-a-bg);
}
.menu--node a:hover, .menu--node a:active {
	color: var(--menu-sub-a-hover-color);
	background-color: var(--menu-sub-a-hover-bg);
}


.menu.menu--node a[data-curr='1'] {
	background-color: var(--menu-sub-a-curr-bg);
	color: var(--menu-sub-a-curr-color);
	border: 1px solid rgba(255,255,255,0.2);
}


nav.menu--node:last-of-type {
	/* border: none; */
}


nav.menu--node a:hover, a.link--button:hover {
	background-color: rgba(255,255,255,0.1);	
	border: 1px solid #117766;
}

nav.menu--node li.menu-name {
	font-weight: bold;
	font-weight: 700;
	font-size: .8rem;
	/* width: fit-content; */
	max-width: fit-content;
	padding: 0 2rem;
	/* flex-shrink: 3; */
}



/* ==== CAAT MENU ==== */


nav.menu--cat {
	background-color: var(--menu-sub-bg);
	border-bottom: var(--menu-sub-border-b);
	box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
	/* padding: 1em; */
	/* border: 1px solid white; */
	
}


nav.menu--cat {
	background-color: rgba(255,255,255,0.05);
	border-bottom: 0;
	margin-bottom: 2rem;
	border-radius: .35rem;
}
nav.menu--cat:empty {
	display: none;
}

nav.menu--cat ul {
	/* width: fit-content; */
}

nav.menu--cat li {
	/* box-sizing: border-box; */
	/* min-width: fit-content; */
	
}
nav.menu--cat a {
	/* box-sizing: border-box; */
}

.menu--cat a:link, .menu--cat a:visited, .menu--cat a:hover, .menu--cat a:active {
	/* display: inline-block; */
	padding: .1rem 1rem;
	margin: .2rem .1rem;
	border: 1px solid #115533;
	border-radius: 0;
	font-size: .75rem;
	
	color: var(--menu-sub-a-color);
	background-color: var(--menu-sub-a-bg);
}
.menu--cat a:hover, .menu--cat a:active {
	color: var(--menu-sub-a-hover-color);
	background-color: var(--menu-sub-a-hover-bg);
}


.menu.menu--cat a[data-curr='1'] {
	background-color: var(--menu-sub-a-curr-bg);
	color: var(--menu-sub-a-curr-color);
	border: 1px solid rgba(255,255,255,0.2);
}


nav.menu--cat li:first-of-type a {
	border-radius: .25rem 0 0 .25rem;
	margin-left: .2rem;
}

nav.menu--cat li:last-of-type a {
	border-radius: 0 .25rem .25rem 0;
	margin-right: .2rem;
}


nav.menu--cat a:hover, a.link--button:hover {
	background-color: rgba(255,255,255,0.1);	
	border: 1px solid #117766;
}
