header,
footer {
	position: fixed;
	top: 0;
	bottom: 0;
	height: 100vh;
}

header {
	width: calc(var(--navbar) * 2);
	left: 0;
	padding-top: var(--s5);
	display: flex;
	z-index: 100;
}

header .img-circle-wrapper {
	position: absolute;
	top: var(--s2);
	left: var(--s2);
	z-index: 10;
}

header a,
header a:hover,
header a:focus,
footer a,
footer a:hover,
footer a:focus {
	color: var(--light) !important;
}

header a.active i,
.navigation a:last-of-type:hover,
footer a:hover {
	opacity: 0.5;
}

/* border frames */

.borderframe > div:not(.borderframecornerborder-topright):not(.borderframecornerborder-topleft):not(.borderframecornerborder-bottomright):not(.borderframecornerborder-bottomleft) {
	position: fixed;
	background: var(--bg) no-repeat;
	filter: var(--backdrop-dark);
	background-size: auto;
	pointer-events: none;
	z-index: 95;
}

.borderframe-top,
.borderframe-bottom {
	width: 100vw;
	height: var(--navbar);
	right: 0;
	left: 0;
}

.borderframe-right,
.borderframe-left {
	width: var(--navbar);
	height: 100vh;
	top: 0;
	bottom: 0;
}

.borderframe-top {
	top: 0;
}

.borderframe-right {
	right: 0;
	background-position-x: calc(-100vw + var(--navbar)) !important;
}

.borderframe-bottom {
	bottom: 0;
	background-position-y: calc(-100vh + var(--navbar)) !important;
}

.borderframe-left {
	left: 0;
}

/*.borderframe > div:not(.borderframecornerborder-topright):not(.borderframecornerborder-topleft):not(.borderframecornerborder-bottomright):not(.borderframecornerborder-bottomleft):not(.borderframecorner-topright):not(.borderframecorner-topleft):not(.borderframecorner-bottomright):not(.borderframecorner-bottomleft)::before {
	content: "";
	position: fixed;
	pointer-events: none;
	background: var(--border-color);
	opacity: 0.5;
}

.borderframe-top::before,
.borderframe-bottom::before {
	width: calc(100vw - var(--navbar) * 2);
	height: 1px;
	left: var(--navbar);
}

.borderframe-right::before,
.borderframe-left::before {
	width: 1px;
	height: calc(100vh - var(--navbar) * 2);
	top: var(--navbar);
}

.borderframe-top::before {
	top: calc(var(--navbar) - 1px);
}

.borderframe-right::before {
	right: calc(var(--navbar) - 1px);
}

.borderframe-bottom::before {
	bottom: calc(var(--navbar) - 1px);
}

.borderframe-left::before {
	left: calc(var(--navbar) - 1px);
}*/

.borderframecorner-topright,
.borderframecorner-topleft,
.borderframecorner-bottomright,
.borderframecorner-bottomleft {
	width: calc(var(--navbar) * 3);
	aspect-ratio: 1;
}

.borderframecorner-topright {
	top: 0;
	right: 0;
	clip-path: polygon(0 0, 100% 100%, 100% 0);
	background-position-x: calc(-100vw + var(--navbar) * 3) !important;
}

.borderframecorner-bottomright {
	bottom: 0;
	right: 0;
	clip-path: polygon(0 100%, 100% 100%, 100% 0);
	background-position-x: calc(-100vw + var(--navbar) * 3) !important;
	background-position-y: calc(-100vh + var(--navbar) * 3) !important;
}

.borderframecorner-topleft {
	top: 0;
	left: 0;
	clip-path: polygon(0 0, 0 100%, 100% 0);
}

.borderframecorner-bottomleft {
	bottom: 0;
	left: 0;
	clip-path: polygon(0 0, 0 100%, 100% 100%);
	background-position-y: calc(-100vh + var(--navbar) * 3) !important;
}

.borderframecornerborder-topright,
.borderframecornerborder-topleft,
.borderframecornerborder-bottomright,
.borderframecornerborder-bottomleft {
	position: fixed;
	width: calc(var(--navbar) * 3);
	height: 1px;
	background: var(--border-color);
	opacity: 0.5;
	pointer-events: none;
}

.borderframecornerborder-topright,
.borderframecornerborder-bottomleft {
	transform: rotate(45deg);
	transform-origin: top left;
}

.borderframecornerborder-topleft,
.borderframecornerborder-bottomright {
	transform: rotate(-45deg);
	transform-origin: top left;
}

.borderframecornerborder-topright {
	top: 0;
	right: 0;
	transform-origin: top left;
}

.borderframecornerborder-topleft {
	top: 0;
	left: 0;
	transform-origin: bottom right;
}

.borderframecornerborder-bottomright {
	bottom: 0;
	right: 0;
	transform-origin: top left;
}

.borderframecornerborder-bottomleft {
	bottom: 0;
	left: 0;
	transform-origin: bottom right;
}

/* carousel menu */

ul#carouselIndicators {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: calc(var(--navbar) * 2);
	list-style-type: none;
	padding: 0 var(--navbar) 0 var(--s5);
	margin: 0;
}

ul#carouselIndicators > a {
	position: relative;
	display: block;
	font-family: var(--font-sub);
	font-size: var(--font-xs);
	font-weight: bold;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	padding: var(--ssmall) var(--s1);
	margin: 0 var(--s1);
	display: flex;
	align-items: center;
	background: var(--dark) linear-gradient(to top, var(--light) 0 100%);
	background-position: 100% 100%;
	background-repeat: repeat-x;
	background-size: 0 0;
}

ul#carouselIndicators > a.active {
	pointer-events: none;
}

ul#carouselIndicators > a.active,
ul#carouselIndicators > a:hover {
	opacity: 1;
	background-size: 100% 100%;
	color: var(--dark) !important;
}

/* user menu */

ul#headerMenu {
	width: 100%;
	padding: 0;
	margin: 0;
}

ul#headerMenu > a {
	width: 100%;
	display: flex;
	justify-content: center;
	font-size: var(--font-lg);
	padding: var(--s0);
	margin: var(--s1) 0;
}

ul#headerMenu > a.active {
	pointer-events: none;
}

header a.with-counter {
	position: relative;
}

header a.with-counter::after {
	position: absolute;
	top: -5px;
	right: -10px;
	background: var(--secondary);
	border-radius: 50%;
	color: var(--primary);
	font-family: var(--font-default);
	font-size: var(--font-xs);
	width: 12px;
	height: 12px;
	text-align: center;
}

header a.with-counter.shaking::after {
	content: attr(data-counter);
}

.modal#quick_login .modal-content {
	width: auto;
	margin: auto auto;
}

.modal#quick_login .modal-content a {
	font-size: var(--font-md);
	display: flex;
	padding: 0;
}

.modal#quick_login .modal-content .row {
	margin: 0;
}

.modal#quick_login .modal-content .col {
	padding: var(--ssmall);
	background: var(--transparent);
	margin: var(--s0) 0;
}

.modal#quick_login .modal-content .button {
	background: none;
	border: none;
	transform: none;
	padding: 0;
	margin: 0;
}

.modal#quick_login .modal-content .button i {
	padding: var(--s0);
	background: var(--dark);
}

.modal#quick_login .modal-content .button i svg {
	transform: none;
}

.modal#quick_login .modal-content input {
	background: none;
	padding: 0 var(--s0);
}

span.dot {
	position: absolute;
	width: var(--s0);
	height: var(--s0);
	background: var(--bui);
	top: var(--s0);
	right: var(--s0);
	border-radius: 50%;
}

/* footer */

footer {
	width: var(--navbar);
	right: 0;
	padding: var(--navbar) 0;
	z-index: 99;
}

footer a,
footer button {
	color: var(--light);
}

footer > .copyright {
	transform: rotate(-90deg) translate3d(0, 50%, 0);
	transform-origin: bottom right;
	position: fixed;
	right: calc(var(--navbar) / 2);
	top: var(--s5);
	width: calc(100vh - 150px);
	font-family: var(--font-sub);
	font-size: var(--font-xxs);
	text-align: right;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--light);
	opacity: 0.8;
}

footer > .copyright a {
	font-weight: bold;
}

footer > .footer-buttons {
	position: absolute;
	right: 0;
	bottom: var(--navbar);
	width: calc(var(--navbar) * 2);
	z-index: 10;
}

footer > .footer-buttons a,
footer > .footer-buttons button {
	position: relative;
	display: flex;
	font-size: var(--font-lg);
	padding: var(--s0);
	margin: var(--s0) 0;
	border: none;
	background: none;
}

footer > .footer-buttons a:last-child {
	padding-bottom: 0;
	margin-bottom: 0;
}

button.tobottom {
	margin-bottom: var(--s2) !important;
}

#debug {
	float: right;
	text-align: right;
	margin-top: 20px;
	font-size: 11px;
}

.scaleimages img {
	max-width: 100%;
}

/* navigation */

.navigation {
	position: fixed;
	top: var(--navbar);
	right: var(--navbar);
	font-size: var(--font-lg);
	z-index: 85;
	transform: translate3d(50%, -50%, 0);
}

.navigation a {
	display: none;
}

.navigation a:last-of-type {
	display: flex;
}

.navigation > * {
	padding: var(--s0);
}

.navigation i {
	color: var(--light);
}

/* theme selector */

.theme form {
	display: flex;
	flex-direction: column;
}

.theme button {
	display: none !important;
}

/* cookie banner */

.cookiebanner {
	position: fixed;
	width: calc(100vw - var(--s5));
	max-width: 400px;
	right: var(--s4);
	bottom: var(--s4);
	background: var(--secondary);
	padding: var(--s3);
	z-index: 90;
	font-size: var(--font-lg);
	text-align: justify;
	color: var(--primary);
}

.cookieok {
	position: absolute;
	right: var(--s0);
	bottom: var(--s0);
	aspect-ratio: unset !important;
}

.cookieok i {
	margin-left: var(--s1);
}

.cookiebanner a {
	color: var(--primary);
	font-weight: bold;
}

/* submenu */

.navbar-expand-lg {
	width: 100%;
	color: var(--light);
	z-index: 90;
	transition: all 0.3s linear;
	-webkit-backdrop-filter: var(--backdrop-dark);
	backdrop-filter: var(--backdrop-dark);
	display: flex;
	align-items: flex-start;
	gap: var(--s3);
	padding: 0 var(--s2) var(--s2) var(--s2);
}

.navbar-expand-lg ul p {
	font-size: var(--font-md);
	text-align: justify;
	padding: var(--s2);
	background: var(--dark);
}

.navbar-expand-lg a {
	color: var(--light);
}

.navbar-expand-lg > ul {
	width: calc((100% - var(--s3)) / 4);
	list-style-type: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
}

#guideTabs > ul:nth-child(2),
#usercpNav > ul:nth-child(2) {
	width: calc((100% - var(--s3)) / 2);
}

#encyclopediaTabsAlt {
	margin-bottom: var(--s2);
}

#encyclopediaTabs > ul:not(:first-child),
#encyclopediaTabsAlt > ul:not(:first-child) {
	width: calc(((100% - var(--s3)) / 4) * 1.5);
}

#pmsNav > ul {
	width: calc((100% - var(--s3)) / 3);
}

.navbar-expand-lg > ul > ul {
	width: 50%;
	list-style-type: none;
	margin: 0;
	padding: 0;
}

.navbar-expand-lg ul h4 {
	width: 100%;
	padding: var(--s2) var(--s0);
	display: flex;
	align-items: center;
}

.navbar-expand-lg ul h4::after {
	content: "";
	height: 1px;
	background: var(--transparent);
	flex: 1;
	margin-left: var(--s1);
}

.navbar-expand-lg ul li {
	width: 100%;
	font-family: var(--font-sub);
	font-size: var(--font-sm);
	letter-spacing: 0.15em;
	padding: var(--s0) var(--s1);
	cursor: pointer;
	transition: all 0.2s linear;
	outline: none;
	box-shadow: none;
	margin: 0;
}

.navbar-expand-lg ul a {
	width: 100%;
}

.navbar-expand-lg ul li.active {
	pointer-events: none;
}

.navbar-expand-lg ul li:not(.active):hover,
.navbar-expand-lg ul li.active {
	opacity: 0.5;
}

.navbar-expand-lg ul li::before {
	content: "\00D7";
	color: var(--border-color);
	margin-right: var(--s1);
	font-size: var(--font-md);
}

.navbar-expand-lg ul form {
	display: flex;
}

.navbar-expand-lg ul form select {
	background: var(--dark);
	color: var(--light);
	font-size: var(--font-sm);
	font-family: var(--font-sub);
	letter-spacing: 0.15em;
	padding: var(--s0) var(--s1);
	margin: var(--ssmall) 0;
}

.navbar-expand-lg ul li input {
	font-family: var(--font-sub);
	font-size: var(--font-sm);
	letter-spacing: 0.15em;
	padding: 0;
	background: transparent;
	color: unset;
}