@font-face {
    font-family: "MCR";
    src: url("/assets/fonts/MCR.woff2") format("woff2");
}
@font-face {
    font-family: "MCB";
    src: url("/assets/fonts/MCB.woff2") format("woff2");
}
@keyframes loadingDots {
    0%   {content: '';}
    25%  {content: '.';}
    50%  {content: '..';}
    75%  {content: '...';}
    100% {content: '';}
}
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
p, span, div, a, i, u, b, textarea, h1, h2, h3, h4, h5, h6, ul, li, input, td, th, label, button, q {
    text-size-adjust: none;
	-webkit-text-size-adjust: none;
    color: white;
    font-family: "MCR", monospace;
    font-weight: normal;
}
p, span, div, a, i, u, b, textarea, h4, ul, li, td, label, button, q {text-shadow: 0 0.0625em 0 blue;}
@-moz-document url-prefix() {* {scrollbar-color: blue black;}}
a, a * {color: cyan;}
a:hover, a:hover * {color: blue;}
iframe {border: none;}
img {image-rendering: crisp-edges;}
img, iframe {user-select: none;}
img, a, iframe {-webkit-user-drag: none;}
b, b * {font-family: "MCB", monospace;}
p, ul {padding: 0.25rem 0.5rem;}
ul {list-style: none;}
ul li::before {content: "- ";}
li:hover, li:hover *:not(a, a *) {color: cyan;}
#c404 {
    width: min(37.5rem, 100%);
    filter: drop-shadow(0.25rem 0.25rem 0 blue);
    image-rendering: pixelated;
}
.mainFilter {filter: invert(1) sepia(1) invert(1) saturate(2) contrast(2);}
.mainFilter:hover {filter: invert(1) sepia(0) invert(1) saturate(1) contrast(1);}
html {
    font-size: calc(100vw / max(100vw, calc(var(--layout-width)) + 1.5rem) * 16px);
    background-color: black;
    --layout-width: 1000px
}
html[data-siteFontSize="small"] {
    font-size: calc(100vw / max(100vw, calc(var(--layout-width)) + 1.5rem) * 14px);
    --layout-width: 875px;
}
html[data-animationsMode="off"] * {
    animation: none !important;
    transition: none !important;
}
body {
    display: flex;
    align-items: center;
    flex-direction: column;
    overflow-y: hidden;
}
html, body {
    scroll-behavior: smooth;
    cursor: cell;
    line-height: 1.5;
    accent-color: blue;
    min-width: 100%;
    min-height: 100vh;
}
#loadingScreen {
    transition: opacity 0.3s;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background-color: black;
    font-family: "MCR", monospace;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 7.5rem;
    user-select: none;
}
#loadingScreen::after {
    content: '';
    animation: loadingDots 1s linear infinite;
}
header {
    display: flex;
    align-items: center;
    width: 100%;
    flex-direction: column;
    padding: 2rem 1rem;
    background-color: black;
    border-bottom: 1px solid white;
}
nav {
    border-bottom: 1px solid white;
    box-shadow: 0 0.25rem 0 blue;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: black;
}
html[data-navbarMode="static"] nav {position: static;}
.nav {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem;
    background: linear-gradient(black 33%, white 33% 67%, black 67%);
}
.nav a {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    user-select: none;
    text-shadow: none;
    font-family: "MCB", monospace;
    padding: 0.5rem 0.75rem;
    border: 1px solid white;
    font-size: 1.25rem;
    box-shadow: 0.125rem 0.125rem 0 blue;
    corner-shape: bevel;
    border-radius: 0.25rem / 0.25rem;
    color: white;
    text-decoration: none;
    background: linear-gradient(transparent 10%, black 10% 90%, transparent 90%), repeating-linear-gradient(90deg, black 0 1px, white 1px 2px);
}
.nav a:hover {background: linear-gradient(transparent 10%, blue 10% 90%, transparent 90%), repeating-linear-gradient(90deg, blue 0 1px, white 1px 2px);}
.nav a:active {
    background: white;
    color: black;
}
footer {
    width: 100%;
    background-color: black;
    border-top: 1px solid white;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 0.5rem;
}
.footerContent {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    margin: 0 0.75rem;
    hr {margin: 0;}
}
main {
    flex: 1;
    width: calc(100% - 1.5rem);
    max-width: var(--layout-width);
    padding: 0.5rem 0 1rem;
    display: flex;
    flex-direction: column;
}
.dividerEnds {
    width: 100%;
    padding: 0.5rem;
    background-color: black;
    background-image: repeating-linear-gradient(90deg, transparent 0 1rem, white 1rem 2rem);
    background-size: 200vw 1rem;
    animation: dividerEndsAnimation 4s linear infinite;
}
.dividerEnds:hover {background-color: blue;}
@keyframes dividerEndsAnimation {
    0% {background-position-x: 100vw;}
    100% {background-position-x: calc(100vw + 2rem);}
}
textarea {
    box-shadow: inset 0.125rem 0.125rem 0 blue;
    background: black;
    border: 1px solid white;
    cursor: text;
    font-size: 0.875rem;
    line-height: 1.3;
    padding: 0.5rem 0.5rem;
    resize: none;
}
textarea:hover {border-color: cyan;}
textarea:hover::-webkit-scrollbar-track, textarea:hover::-webkit-scrollbar-thumb {border-color: cyan;}
textarea:hover::-webkit-scrollbar-thumb {box-shadow: 0 1px 0 cyan, 0 -1px 0 cyan;}
section {
    border: 3px double white;
    padding: 0.25rem;
    box-shadow: 0.25rem 0.25rem 0 blue;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    background: black;
}
article {
    border: 1px solid white;
    padding: 0.5rem;
    box-shadow: inset 0.125rem 0.125rem 0 blue;
    display: flex;
    flex-direction: column;
    background: black;
}
section:hover, article:hover {border-color: cyan;}
section:not(:has(h2, h3, h5, .tabContainer)) {
    border-style: solid;
    border-image: repeating-linear-gradient(135deg, white 0 1px, black 1px 2px) 1;
}
section:not(:has(h2, h5, .tabContainer)):hover {border-image: repeating-linear-gradient(45deg, cyan 0 1px, black 1px 2px) 1;}
.emptyFill {
    display: flex;
    flex: 1;
    border: 1px solid white;
    box-shadow: 0.25rem 0.25rem 0 blue;
    background-color: black;
    background-image: repeating-linear-gradient(135deg, white 0 1rem, transparent 1rem 2rem);
    background-size: 200vw auto;
    cursor: not-allowed;
    animation: emptyAnimation 4s linear infinite;
}
@keyframes emptyAnimation {
    0% {background-position-x: 100vw;}
    100% {background-position-x: calc(100vw + 2.828rem);}
}
.emptyFill:hover {background-color: blue;}
.boxContainer {
    display: flex;
    flex-direction: column;
}
h1 {
    background-color: black;
    background-image: linear-gradient(transparent 33%, white 33% 67%, transparent 67%);
    justify-content: center;
    display: flex;
    margin: 1.5rem 0 1.75rem;
    border: 1px solid white;
    filter: drop-shadow(0.25rem 0.25rem 0 blue);
}
h1 span {
    background-color: white;
    font-size: 1.875rem;
    color: black;
    font-family: "MCB", monospace;
    text-shadow: none;
    padding: 0.25rem 1rem 0;
    outline: 1px solid white;
    outline-offset: 0.875rem;
}
h1:hover {
    background-color: blue;
    span {color: blue;}
}
.hBtn {
    display: flex;
    gap: 0.5rem;
    div {
        border: 3px double black;
        color: black;
        text-shadow: none;
        height: 1.75rem;
        width: 1.75rem;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0.125rem 0 0;
        margin: -0.125rem;
        font-family: Arial, Helvetica, sans-serif;
        user-select: none;
    }
    div:hover {background: cyan;}
}
h2, h3, h4, h5 {
    font-weight: normal;
    font-size: 1rem;
}
h2 {
    background-color: white;
    color: black;
    padding: 0.25rem 0.25rem 0.25rem 0.5rem;
    text-shadow: 0 0 0 black;
    border: 1px solid white;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
h3 {
    background-image: linear-gradient(to right, white 50%, cyan 55%, blue 70% 80%, black 90%);
    border: 1px solid white;
    color: black;
    padding: 0.125rem 0.5rem;
    margin-bottom: 0.25rem;
    box-shadow: 0.125rem 0.125rem 0 blue;
    text-shadow: 0 0 0 black;
}
h3:hover {background: white;}
h2:hover:not(:has(.hBtn div:hover)) {
    background: cyan;
    border: 1px solid cyan;
}
h4 {
    border: 1px solid white;
    padding: 0.25rem 0.5rem;
    margin-bottom: 0.25rem;
    box-shadow: 0.125rem 0.125rem 0 blue;
    font-family: "MCB", monospace;
    background: black;
}
h4 a:hover, h4 a:hover * {color: white;}
h4:hover {background-color: blue;}
article > h4:not(:first-child), article > h3:not(:first-child)  {margin-top: 0.25rem;}
section:has(h5, .tabContainer) {
    position: relative;
    margin-top: calc(2rem + 6px);
}
h5 {
    width: calc(100% + 6px);
    position: absolute;
    bottom: calc(100% + 3px);
    padding-top: 3px;
    left: -3px;
    background-color: white;
    background-image: repeating-linear-gradient(to bottom, transparent 0 1px, black 1px 0.625rem);
    span {
        display: block;
        width: min-content;
        height: 100%;
        background-color: black;
        border: 3px double white;
        border-bottom: none;
        corner-shape: bevel;
        border-radius: 1rem / 100%;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        border-top-left-radius: 0;
        padding: 0.25rem 1.125rem 0.25rem 0.625rem;
        color: black;
        box-shadow: inset 0 3rem 0 white;
        text-shadow: 0 0 0 black;
        white-space: nowrap;
    }
    span:hover {box-shadow: inset 0 3rem cyan;}
}
@supports not (corner-shape: bevel) {
    h5 span {
        border-radius: 0;
        padding-right: 0.75rem;
    }
}
h5:hover {background-color: cyan;}
section:hover h5 span {border-color: cyan;}
h6 {
    border: 1px solid white;
    box-shadow: 0.25rem 0.25rem 0 blue;
    margin-bottom: 0.75rem;
    display: flex;
    justify-content: center;
    background-color: black;
    background-image: linear-gradient(transparent 33%, white 33% 66%, transparent 66%);
    span {
        font-size: 1rem;
        padding: 0.25rem 0.75rem;
        background: white;
        color: black;
        text-shadow: none;
        font-family: "MCB", monospace;
        font-size: 1.25rem;
    }
}
h6:hover {
    background-color: blue;
    span {color: blue;}
}
.tabContainer {
    width: calc(100% + 0.25rem);
    position: absolute;
    bottom: calc(100% + 3px);
    left: -1px;
    display: flex;
    background-color: white;
    background-image: repeating-linear-gradient(black 0 calc(0.5rem - 1px), transparent calc(0.5rem - 1px) 0.5rem);
}
.tabContainer:hover {background-color: cyan;}
.tabSelection {
    display: block;
    height: 100%;
    background-color: black;
    border: 3px double white;
    border-bottom: none;
    padding: 0.3rem 0.75rem;
    white-space: nowrap;
    text-shadow: none;
    user-select: none;
    cursor: pointer;
}
.tabContainer .tabSelection:first-child {margin-left: -2px;}
.tabContainer .tabSelection:not(:first-child) {border-left: none;}
.tabSelection:not(.selectedTab):hover {box-shadow: inset 0 3rem 0 blue;}
.selectedTab, .tabSelection:active {
    text-shadow: 0 0 0 black;
    color: black;
}
.selectedTab {
    cursor: cell;
    box-shadow: inset 0 3rem 0 white !important;
}
.selectedTab:hover, .tabSelection:active {box-shadow: inset 0 3rem 0 cyan !important;}
section:hover .tabSelection {border-color: cyan;}
hr {
    margin: 0.75rem 0 0.5rem;
    border: none;
    border-top: 1px dashed white;
    filter: drop-shadow(0.125rem 0.125rem 0 blue);
}
button {all: unset;}
.button, button {
    box-shadow: 0.125rem 0.125rem 0 blue;
    text-shadow: none;
    border: 1px solid white;
    padding: 0.3rem 0.55rem;
    display: flex;
    align-items: center;
    justify-content: center;
    user-select: none;
    cursor: pointer;
    color: white !important;
    white-space: nowrap;
    background: black;
    text-decoration: none;
    flex: 1;
}
a:has(.button, button) {text-decoration: none;}
.button:hover, button:hover {background-color: blue;}
.button:active, button:active {
    background-color: white;
    text-shadow: none;
    color: black !important;
    text-shadow: 0 0 0 black !important;
}
main > .button, main > button {flex: unset;}
table {
    border: 1px solid white;
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}
td, th {
    padding: 0.25rem 0.75rem;
    border: 1px solid white;
    white-space: nowrap;
}
th {
    color: black;
    text-shadow: 0 0 0 black;
    background-color: white;
    font-weight: normal;
    border-right-color: black;
}
th:last-child {border-right-color: white;}
th:hover {
    border-color: cyan;
    border-right-color: black;
    background: cyan;
}
th:last-child:hover {border-right-color: cyan;}
td:hover {background: blue;}
td:hover a:hover {color: white;}
.blogImg {
    width: 100%;
    border: 3px double white;
    box-shadow: 0.25rem 0.25rem 0 blue;
    margin-bottom: 0.5rem;
}
#tooltip {
    pointer-events: none;
    position: fixed;
    display: none;
    background: black;
    z-index: 99999;
    border: 1px solid white;
    box-shadow: 0.125rem 0.125rem 0 blue;
    font-family: "MCR", monospace;
    padding: 0.5rem 0.75rem;
    max-width: 25rem;
    transform: translate(0.25rem, -0.25rem);
    outline: 1px solid black;
    width: max-content;
    word-wrap: break-word;
    white-space: normal;
}
html[data-tooltipShow="false"] #tooltip {visibility: hidden;}
#menuButton {
    position: fixed;
    left: 0.75rem;
    bottom: 0.75rem;
    font-size: 1.25rem;
    font-family: "MCB", monospace;
    z-index: 30;
    outline: 1px solid black;
}
#siteMenu {
    position: fixed;
    left: 0.75rem;
    z-index: 200;
    bottom: 0.75rem;
    transform: translateY(calc(100% + 2rem));
    transition: transform 0.15s;
    width: 25rem;
    display: none;
    max-width: calc(100% - 1.5rem);
    outline: 1px solid black;
}
.mobileNavButton {
    display: none;
    width: 100%;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    background: linear-gradient(black 33%, white 33% 67%, black 67%);;
    user-select: none;
    span {
        text-shadow: none;
        font-size: 1.875rem;
        font-family: "MCB", monospace;
        padding: 0.5rem 1rem;
        background: black;
        border: 1px solid white;
        border-top: none;
        border-bottom: none;
    }
}
.mobileNavButton:hover span {background: blue;}
.mobileNavButton:active span {
    text-shadow: 0 0 0 black;
    color: black;
    background: white;
}
nav details[open] .mobileNavButton {
    border-bottom: 1px solid white;
    filter: drop-shadow(0 0.125rem 0 blue);
}
q {
    font-style: italic;
    display: flex;
    text-align: center;
    gap: 0.75rem;
    margin-top: 1rem;
}
q::after, q::before {
    content: "";
    flex: 1;
    background: linear-gradient(transparent calc(50% - 1px), white calc(50% - 1px) 50%, transparent 50%);
    filter: drop-shadow(0.125rem 0.125rem 0 blue);
}
q::after {border-left: 1px solid white;}
q::before {border-right: 1px solid white;}
q:hover {color: cyan;}
q:hover::after, q:hover::before {
    border-color: cyan;
    background: linear-gradient(transparent calc(50% - 1px), cyan calc(50% - 1px) 50%, transparent 50%);
}
audio {
    filter: sepia(0.5) invert(1) saturate(2) contrast(64) drop-shadow(0.125rem 0.125rem 0 blue);
    background: white;
    width: 20rem;
    height: 2rem;
    border: 1px solid black;
}
audio:hover {
    background: yellow;
    filter: sepia(0.5) invert(1) saturate(8) contrast(64) drop-shadow(0.125rem 0.125rem 0 blue);
}
@-moz-document url-prefix() {
    audio {
        filter: invert(1) sepia(1) invert(1) saturate(2) contrast(16) drop-shadow(0.125rem 0.125rem 0 blue);
        background: black;
        width: 20rem;
        height: 2rem;
        border: 1px solid white;
    }
    audio:hover {
        background: blue;
        filter: invert(1) sepia(1) invert(1) saturate(8) contrast(64) drop-shadow(0.125rem 0.125rem 0 blue);
    }
}
#fullscreenImageButton {
    display: none;
    position: fixed;
    right: 0.75rem;
    top: 0.75rem;
    font-size: 1.25rem;
    font-family: "MCB", monospace;
    z-index: 1010;
    outline: 1px solid black;
}
img[data-fullscreenimage] {cursor: pointer;}
img[data-fullscreenimage="true"] {
    filter: none;
    border: none;
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 1000;
    cursor: cell;
    background: #000000cc;
}
::selection {
    background-color: white;
    color: black;
    text-shadow: 0 0 0 black;
}
:focus-visible {
    outline: 3px double cyan !important;
    outline-offset: 0.125rem !important;
    z-index: 200;
}
::-webkit-scrollbar {width: 1rem;}
::-webkit-scrollbar-track, ::-webkit-scrollbar-thumb {border: 1px solid white;}
::-webkit-scrollbar-thumb:hover {background-color: blue;}
::-webkit-scrollbar-thumb:active {background-color: white;}
body::-webkit-scrollbar-track, body::-webkit-scrollbar-thumb, textarea::-webkit-scrollbar-track, textarea::-webkit-scrollbar-thumb {
    border-right: none;
    border-top: none;
    border-bottom: none;
}
body::-webkit-scrollbar-thumb, textarea::-webkit-scrollbar-thumb {box-shadow: 0 1px 0 white, 0 -1px 0 white;}
::-webkit-scrollbar-thumb {cursor: default;}
::-webkit-scrollbar-track:hover {border-color: cyan;}
@media (max-width: 768px) {
    html {font-size: 4vw}
    html[data-siteFontSize="small"] {font-size: calc(4vw / 16 * 14);}
    .nav {
        background: black;
        display: none;
        grid-template-columns: 1fr 1fr;
    }
    .mobileOptimizedGrid {grid-template-columns: 1fr !important;}
    .mobileFlex {flex-direction: column;}
    .emptyFill, .mobileNone {display: none;}
    #loadingScreen {font-size: 4rem;}
    .mobileNavButton {display: flex;}
    nav:has(details[open]) .nav {display: grid;}
    #menuButton {opacity: 0.75;}
    #menuButton:hover {opacity: 1;}
}
@media (min-width: 769px) {.mobileDisappear {display: none !important;}}
@media (min-width: calc(1001px + 1.5rem)) {
    html {
        background-image: repeating-linear-gradient(black 0 1px, transparent 1px 2px), repeating-linear-gradient(to right, black 0 1px, transparent 1px 2px), linear-gradient(black, transparent 20% 80%, black), linear-gradient(to right, black, transparent, transparent, transparent, black calc(50% - calc(var(--layout-width) / 2)) calc(50% + calc(var(--layout-width) / 2)), transparent, transparent, transparent, black), url("/assets/img/backgrounds/pcb.webp");
        background-size: cover;
        background-attachment: fixed;
        background-position-x: center;
    }
}