@font-face { font-family: "Beaufort for LOL"; src:  url("BeaufortforLOL-Bold.woff") format("woff"); }
@font-face { font-family: "Spiegel"; src: url("Spiegel-Regular.woff") format("woff"); }
html,body
{
    width: 100%;
    height: 100%;
    overflow: hidden;
}
body
{
    background-color: rgb(18, 0, 46);
    /*text-rendering: optimizeLegibility;
    overflow: auto;
    perspective: 600px;*/
    margin: 0;
}
.cat-list{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.cat-item
{
    position: relative;
    border: 2px solid white;
    border-radius: 50%;
    margin: 1.5em 5px;
    height: 100px;
    width: 100px;
    background-position: center center;
    background-size: cover;
}
.cat-item:focus,.cat-item:hover
{
    border: 2px solid rgb(0, 162, 255);
}
a.cat-item
{
    color: inherit;
    display: block;
    text-decoration: none;
}
.cat-item-num,.cat-item-name
{
    position: absolute;
    bottom: -1em;
    left: 50%;
    background-color: rgb(66, 66, 66);
    color: white;
    padding: 0 .3em;
    border: 1px solid white;
    transform: translateX(-50%);
    height: 1.2em;
    line-height: 1.2em;
    border-radius: .6em;
}
.cat-item-name
{
    top: -1em;
    bottom: auto;
}
.circle-cluster
{
    height: 100%;
    width: 100%;
}
.phy-circle
{
    border: 2px solid white;
    border-radius: 50%;
    position: absolute;
    height: 100px;
    width: 100px;
}
.floating-video-container
{
    position: fixed;
    top: 100px;
    left: 100px;
    width: min(50vw, 60vh);
    border: 1px solid #0007;
    color: white;
    pointer-events: none;
    background-color: #222;
    display: none;
}
.floating-video-container.-lock
{
    border: 1px solid white;
    pointer-events: initial;
}
.floating-video-container.-show
{
    display: block;
}
.video-title
{
    font-size: 1.5em;
    font-family: "Beaufort for LOL";
    padding: .2em .5em;
}
.video-reason
{
    font-size: 1.2em;
    font-family: "Spiegel";
    padding: .2em .5em;
}
.iframe-container
{
    padding-top: 56.25%;
    width: 100%;
    position: relative;
}
.iframe-container iframe
{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
}
svg
{
    outline: 1px solid white;
    height: 100%;
    width: 100%;
}
svg *
{
    pointer-events: none;
}
path
{
    stroke: #FFF8;
    fill: none;
    stroke-width: 2px;
}
.svg-node
{
    filter: drop-shadow(0 0 20px white);
    fill: rgb(148, 148, 148);
    transition: .2s;
    pointer-events: initial;
}
.svg-node:hover
{
    filter: drop-shadow(0 0 20px white) drop-shadow(0 0 20px white);
}
.svg-node.-new
{
    fill: rgb(255, 124, 124);
}
.svg-halo
{
    fill: none;
    stroke: rgba(255, 255, 0, 0.288);
    stroke-width: 2px;
    pointer-events: none;
}
.svg-difficulty
{
    fill: none;
    stroke: #FFF4;
    stroke-width: 1;
}
.svg-difficulty-text
{
    font-family: Arial, Helvetica, sans-serif;
    fill: #FFF9;
    font-weight: bold;
    font-size: .8em;
}
text{
    line-height: 2em;
}