@import url('https://fonts.googleapis.com/css2?family=Poppins&display=swap');
/**CSSRESET**/
a,abbr,acronym,address,applet,article,aside,audio,b,big,blockquote,body,canvas,caption,center,cite,code,dd,del,details,dfn,div,dl,dt,em,embed,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,output,p,pre,q,ruby,s,samp,section,small,span,strike,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,tt,u,ul,var,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}html{scroll-behavior:smooth}body{line-height:1}ol,ul{padding-left: 1em}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}table{border-collapse:collapse;border-spacing:0}*{-ms-interpolation-mode:nearest-neighbor;image-rendering:-webkit-optimize-contrast;image-rendering:-moz-crisp-edges;image-rendering:-o-pixelated;image-rendering:pixelated;box-sizing:border-box}
/**CSSRESET**/

:root {
    --dark-color: black;
    --bright-color: white;
    --friend-color: #00ffff;
    --obesk-color: #ff00ff;
    --neutral-color: #ffff00;
    --bastard-color: #ff0066;
    --fundfriend-color: #00ff66;
    --baseTransform: translateX(0);
}

.bright-color { color: var(--bright-color) }
.obesk-color { color: var(--obesk-color) }
.neutral-color { color: var(--neutral-color) }
.friend-color { color: var(--friend-color) }
.bastard-color { color: var(--bastard-color) }
.fundfriend-color { color: var(--fundfriend-color) }

/* fonts */
@font-face {
    font-family: 'beech';
    src: url('/fonts/Beech.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'barcode';
    src: url('/fonts/LibreBarcode128-Regular.woff2') format('woff2'),
        url('/fonts/LibreBarcode128-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'barcodetext';
    src: url('/fonts/LibreBarcode128Text-Regular.woff2') format('woff2'),
        url('/fonts/LibreBarcode128Text-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'spacemono';
    src: url('/fonts/SpaceMono-Regular.woff2') format('woff2'),
        url('/fonts/SpaceMono-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'spacemono';
    src: url('/fonts/SpaceMono-Bold.woff2') format('woff2'),
        url('/fonts/SpaceMono-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'bastard';
    src: url('/fonts/newspaper.woff2') format('woff2'),
        url('/fonts/newspaper.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

::selection {
    background-color: var(--obesk-color);
    color: var(--dark-color);
}

img::selection {
    background-color: transparent;
}

body {
    background: var(--dark-color);
    color: var(--bright-color);
    font-family: spacemono, monospace;
    font-size: 16px;
}

em {
    font-style: italic;
}

img {
    max-width: 100%;
}

/* icons */
.icons a {
    text-decoration: none;
    transform-origin: center;
    transition: transform 100ms cubic-bezier(.54,2.77,.54,.38); 
}

.icons a:hover {
    color: var(--obesk-color);
}

.icons a:active {
    transform: scale(1.2);
}

.icons a > i, .icons svg {
    pointer-events: none; /*for definitions*/
}

.icons svg {
    width: 1.25em;
    height: 1.25em;
}

#splash .icons:nth-of-type(2) {
    transform: translateY(calc(1em + 5vh + 150%));
}

/* DEFINITION BOX */
#definition-box {
    position: fixed;
    top: 0;
    left: 0;
    max-width: 40vw;
    z-index: 30;
    transform: 
        translate(
            calc(  (var(--x) * 1px)   +   ((var(--xFlip) * (100% + 2em)) + 1em)  ), 
            calc(  (var(--y) * 1px)   +   ((var(--yFlip) * (100% + 2em)) + 1em)  )
        );
    pointer-events: none;
    transition: opacity 1s ease-in-out;
    background: var(--dark-color);
    color: var(--bright-color);
    padding: 10px;
    font-size: 12px;
    line-height: 1.5em;
    border: 1px dashed var(--obesk-color);
}

#definition-box:not(.active) {
    opacity: 0;
}

/* FUNDFRIEND STUFF */
.kofi {
    background-color: var(--dark-color);
    position: relative;
    z-index: 2;
    padding: 0.5em;
}

.kofi h2 {
    text-align: center;
    text-transform: uppercase;
    font-family: barcodetext;
    color: var(--fundfriend-color);
    margin: 0.25em 0.25em 0.75em;
}

.kofi h2 a {
    color: inherit;
    text-decoration: unset;
}

.fundfriend {
    position: relative;
    z-index: 1;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    cursor: alias;
    margin: 0.25em;
    padding: 5px;
    width: 1.5em;
    height: 1.5em;
    font-size: 2em;
    border: 2px dotted;
    border-radius: 100%;
    color: var(--fundfriend-color);
    background: url(/img/hazeflowtiny.gif);
    background-size: 100%;
    box-shadow: 0px 0px 10px var(--obesk-color);
    animation: SPIN 30s linear infinite;
    pointer-events: none;
}

.fundfriend span {
    position: absolute;
    font-family: beech;
    pointer-events: none;
    display: inline-block;
    text-transform: uppercase;
    transform: scale(0.75) rotate(20deg);
    color: var(--friend-color);
}

.fundfriend span:nth-child(2) {
    transform: translate(10%, 30%) scale(0.5) scaleX(1.5) rotate(200deg);
    z-index: -1;
    text-shadow: 1px 1px 0px var(--dark-color);
    color: var(--fundfriend-color);
}

.fundfriend span:nth-child(3) {
    transform: translate(-10%, -30%) scale(0.5) scaleX(1.5) rotate(100deg);
    z-index: -2;
    color: var(--fundfriend-color);
}

.fundfriends ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding-left: 0;
}

.fundfriends .fundetail {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    border: 1px dashed var(--fundfriend-color);
    flex-grow: 1;
    font-size: 10px;
    padding: 0.5em;
    max-width: 10vw;
    cursor: alias;
}

.fundetail.past-funder {
    order: 2;
    opacity: 0.75;
    --fundfriend-color: gray;
    display: none;
}

.fundfriends:hover .past-funder {
    display: inline-flex;
}

@keyframes SPIN {
    0% { transform: rotate(0deg) }
    100% { transform: rotate(360deg) }
}

@media only screen and (min-width: 800px) {
    .fundfriend {
        font-size: 2.5em;
    }
}

@media only screen and (max-width: 800px) {
    .kofi h2 {
        margin: 0.25rem 0.25rem 0.75rem;
        font-size: 1.5em;
    }
}

.video-wrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 25px;
	height: 0;
	width: 100%;
    margin-bottom: 3em;
}

.video-wrapper iframe, .video-wrapper img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}