:root {
    --black: #141314;
    --white: #ffffff;
    --grey: #28292b;
    --purple: #3b2f48;
    --lpurple: #a88ecc;
    --lpurpler: #8e70b9;
    --lpurplest: #776197;
    --yellow: #f1d369;
    --yellower: #d8ba4f;
    --yellowest: #caa82e;
    --cyan: #2BF6E1;
    --cyaner: #17e9d4f8;
    --cyanest: #06c1aef8;
    --blue: #0071E7;
    --magenta: #fc2a89;
    --magentaer: #fb1b80;
    --magentaest: #ff0073;
    --pink: #fba1cd;
    --pinker: #fb8fc3;
    --pinkest: #ff72b6;
    --salmon: #CF807C;
    --orange: #ff734c;
    --oranger: #fa663e;
    --orangest: #ff592b;
}

@font-face {
    font-family: "billo";
    src: url("fonts/BILLD___.TTF");
}

@font-face {
    font-family: "alucky";
    src: url("fonts/Alucky.otf");
}

@font-face {
    font-family: "cogtan";
    src: url("fonts/cogtan_shadow_regular.otf");
}

@font-face {
    font-family: "madgroove";
    src: url("fonts/Mad\ Groove\ Blast.ttf");
}

@font-face {
    font-family: "betaport";
    src: url("fonts/KDBetaport-Regular.otf");
}

@font-face {
    font-family: "poppins";
    src: url("fonts/Poppins-Regular.ttf");
}

html {
    min-height: 100%;
    background-color: var(--purple);

    background-image: url("images/pixel-bg3.png"), url("images/star-bg.png");
    background-repeat: repeat-y, repeat;
    background-position: top left;
    background-attachment: fixed;
    background-size: auto 80%, auto 70%;

    margin: 0;
    height: 100%;

    cursor: url(images/cursor.png), auto;
}

body {
    margin: 0px;
    padding: 0px;

    height: 100%;
    width: 100%;

    overflow: scroll;
}

.header {
    position: relative;

    margin: 2.5% auto 0px;

    width: 80%;
    height: 20%;

    display: flex;
    align-items: center;
    justify-content: center;

    border: 1px solid white;

    background-image: url("images/blue-tile-lighter.jpg");
    background-repeat: repeat;
}

.faux-gif {
    position: absolute;

    height: 135%;
    width: 85%;

    display: flex;
    align-items: center;
    justify-content: center;

    background-image: url('images/arcade-machines3-bright.png');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: left center;

    animation: giffy 0.2s infinite ease-in-out;
}

@keyframes giffy {
    0% {
        background-image: url('images/arcade-machines3-dim.png');
    }

    50% {
        background-image: url('images/arcade-machines3-bright.png');
    }
}

.crane {
    position: absolute;

    height: 135%;
    width: 85%;

    display: flex;
    align-items: center;
    justify-content: center;

    background-image: url('images/cranebow.png');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: right center;
}

.menu {
    position: relative;

    margin: 10px auto;
    padding: 1%;

    width: 80%;
    height: auto;

    display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}

.menu-item {
    flex: initial;
    margin: 10px;
}

.container {
    position: relative;

    margin: 0% auto 0;
    padding: 0;

    width: 80%;
}

.container-title {
    position: relative;

    width: 100%;
    /* height: 10%; */

    margin: 0% auto 0;
    padding: 0;

    border: 1px solid white;

    background-image: url("images/blue-tile-lighter.jpg");
    background-repeat: repeat;
}

div.container:nth-child(odd) {
    text-align: right;
}

div.container:nth-child(even) {
    text-align: left;
}

.container-body {
    position: relative;

    width: 100%;
    /* height: 90%; */

    margin: 0% auto 0;
    padding: 1% 0;

    border: 1px solid #ffffff;

    background-color: #beb7c3;

    text-align: left;
}

footer {
    width: 100%;
    background-image: url("images/blue-tile-lighter.jpg");
    background-repeat: repeat;
    text-align: center;    
}

footer p {
    padding: 0;
    margin: 0;

    color: var(--purple);

    font-family: "poppins";
    font-size: 0.8rem;
    font-size: clamp(0.8rem, 0.76rem + 0.19999999999999996vw, 1rem);
}

a {
    text-decoration: none;
    cursor: url(images/cursor-hover.png), auto;
}

p {
    margin: 0px;
    padding: 10px;

    color: var(--purple);

    font-family: "poppins";
    font-size: 0.8rem;
    font-size: clamp(0.8rem, 0.74rem + 0.30000000000000004vw, 1.1rem);
}

h1 {
    margin: 0px 0px 0px 0px;
    padding: 0px;

    font-family: "betaport";
    font-size: 4rem;
    font-size: clamp(4rem, 3.2rem + 4vw, 8rem);

    z-index: 1;
}

.glow {
    color: #fef9e1;
    text-align: center;
    animation: glow 400ms ease infinite alternate;
}

@keyframes glow {
    from {
        text-shadow: 0 0 0px #ffe595, 0 0 10px #ffe595, 0 0 20px var(--yellower), 0 0 30px var(--yellower), 0 0 40px var(--yellower);
    }

    to {
        text-shadow: 0 0 10px #ffe595, 0 0 20px var(--yellow), 0 0 30px var(--yellow), 0 0 40px var(--yellow), 0 0 50px var(--yellow);
    }
}

h2 {
    margin: 0px;
}

h2.cyan {
    color: #c9faef;

    font-family: "madgroove";
    font-size: 1rem;
    font-size: clamp(1rem, 0.86rem + 0.7vw, 1.7rem);
    text-shadow: 0 0 10px var(--cyanest), 0 0 20px var(--cyaner), 0 0 30px var(--cyan);
}

h2.yellow {
    color: #fef9e1;

    font-family: "billo";
    font-size: 3rem;
    font-size: clamp(3rem, 2.8rem + 1vw, 4rem);
    text-shadow: 0 0 10px var(--yellow), 0 0 20px var(--yellower), 0 0 30px var(--yellowest);
}

h2.orange {
    color: #fae3d9;

    font-family: "billo";
    font-size: 2.2rem;
    font-size: clamp(2.2rem, 1.8400000000000003rem + 1.7999999999999998vw, 4rem);
    text-shadow: 0 0 5px var(--orange), 0 0 10px var(--orangest), 0 0 20px var(--oranger), 0 0 30px var(--orange);
}

h2.pink {
    color: #fac9db;

    font-family: "cogtan";
    font-size: 2.6rem;
    font-size: clamp(2.6rem, 2.3200000000000003rem + 1.4vw, 4rem);
    text-shadow: 0 0 10px var(--pinkest), 0 0 20px var(--pinker), 0 0 30px var(--pink);
}

h2.magenta {
    color: #f9c6d5;

    font-family: "cogtan";
    font-size: 2.4rem;
    font-size: clamp(2.4rem, 2.1599999999999997rem + 1.2000000000000002vw, 3.6rem);
    text-shadow: 0 0 5px var(--magenta), 0 0 10px var(--magentaest), 0 0 20px var(--magentaer), 0 0 30px var(--magenta);
}

h2.purple {
    color: #e0c9e9;

    font-family: "alucky";
    font-size: 2.4rem;
    font-size: clamp(2.4rem, 1.96rem + 2.1999999999999997vw, 4.6rem);
    text-shadow: 0 0 5px var(--lpurple), 0 0 8px var(--lpurplest), 0 0 18px var(--lpurpler), 0 0 20px var(--lpurple);
}

button {
    position: relative;
    margin: 0vw 2vw;
    padding: 2vw 0vw;
    filter: saturate(130%);
}

button:hover {
    transform: scale(1.1);
    animation: none;
    filter: brightness(120%);
    cursor: url(images/cursor-hover.png), auto;
}

button:nth-child(1) {
    animation-delay: 4s;
}

button:nth-child(2) {
    animation-delay: 2s;
}

button:nth-child(3) {
    animation-delay: 8s;
}

button:nth-child(4) {
    animation-delay: 6s;
}

.orange-btn {
    padding: 0 .8em;

    color: #fae3d9;
    border: 0.25em solid #fae3d9;
    border-radius: 0.5em;
    background: none;

    box-shadow: inset 0px 0px 0.7em 0px var(--oranger), 0px 0px 0.7em 0px var(--orangest);
    animation: border-flicker 2s linear infinite;
}

.cyan-btn {
    padding: 1.3em 1.7em;

    color: #c9faef;
    border: 0.28em #c9faef;
    border-style: solid dotted solid dotted;
    border-radius: 4em;
    background: none;

    box-shadow: inset 0px 0px 0.7em 0px var(--cyaner), 0px 0px 0.7em 0px var(--cyanest);
    animation: border-flicker 4s linear infinite;
}

.magenta-btn {
    padding: 0em 1.1em;

    color: #f9c6d5;
    border: 0.6em var(--magenta);
    border-style: groove none groove none;
    border-radius: 2em;
    background: none;

    box-shadow: inset 0px 0px 0.7em 0px var(--magentaer), 0px 0px 0.7em 0px var(--magentaest);
    animation: border-flicker 6s linear infinite;
}

.purple-btn {
    padding: 15px 10px 0px 20px;

    color: #e0c9e9;
    border: #e0c9e9;
    border-width: 0.25em 0 0.25em 0;
    border-style: solid hidden solid hidden;
    border-radius: 0em;
    background: none;

    line-height: 4em;

    box-shadow: 0px 0px 0.8em 0px var(--lpurplest);
    clip-path: inset(-0.8em 0 -0.8em 0);
    animation: border-flicker 8s linear infinite;
}

@keyframes border-flicker {
    0% {
        opacity: 0.1;
    }

    2% {
        opacity: 1;
    }

    4% {
        opacity: 0.1;
    }

    8% {
        opacity: 1;
    }

    70% {
        opacity: 0.7;
    }

    100% {
        opacity: 1;
    }
}

h3 {
    margin: 0px 0px 0px 0px;
    padding: 0px 1%;

    color: #fffad8;

    font-family: "betaport";
    font-size: 2rem;
    font-size: clamp(2rem, 1.8rem + 1vw, 3rem);
    text-shadow: 0 0 10px var(--yellow), 0 0 20px var(--yellowest), 0 0 30px var(--yellower);
}

h3.arrow {
    margin: auto;
    padding: 10px;

    font-size: 2rem;
    font-size: clamp(2rem, 1.92rem + 0.3999999999999999vw, 2.4rem);

    text-align: center;
    rotate: 180deg;

    width: 70px;

    background-color: var(--purple);
}

img.divider {
    display: block;
    margin: 0px auto;
    padding: 20px 0px;

    width: auto;
    height: 3vw;

    /* filter: brightness(100%);
    filter: drop-shadow(0 0 5px var(--yellower)); */

    animation: divider-glow 1400ms ease-in-out infinite;
}

@keyframes divider-glow {
    0% {
        filter: drop-shadow(0 0 2px var(--yellower));
    }

    50% {
        filter: drop-shadow(0 0 4px var(--yellower));
    }    

    100% {
        filter: drop-shadow(0 0 2px var(--yellower));
    }
}

img.boxart {
    display: block;
    margin: auto;
    padding: 5px;

    width: 269px;
    height: 375px;
}

img.screens {
    display: block;
    margin: auto;
    padding: 10px;

    width: 80%;
    max-width: 1000px;
    height: auto;
}

h4 {
    margin: 0px 0px 0px 0px;
    padding: .8%;

    color: #fffad8;

    text-align: center;

    font-family: "madgroove";
    font-size: 1.2rem;
    font-size: clamp(1.2rem, 1.04rem + 0.8vw, 2rem);
    text-shadow: 0 0 10px var(--yellow), 0 0 20px var(--yellowest), 0 0 30px var(--yellower);
}

h5 {
    margin: 0px 0px 0px 0px;
    padding: 0px 20px;

    color: #fffad8;

    text-align: left;
    text-decoration: underline;

    font-family: "betaport";
    font-size: 1.6rem;
    font-size: clamp(1.6rem, 1.4400000000000002rem + 0.7999999999999998vw, 2.4rem);
    text-shadow: 0 0 10px var(--yellow), 0 0 15px var(--yellower);
}

.collapsible {
    display: block;
    margin: auto;
    padding: 0;

    width: 90%;

    background-color: transparent;
    border: none;
    color: #fffad8;
}

.collapsible:hover {
    background-color: transparent;
    color: #fffad8;
}

.collapsible:after {
    content: '\2BC6';
    display: block;
}

.active:after {
    content: '\2BC5';
}

.content {
    padding: 0 1vw;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.2s ease-out;
    width: 90%;
}

@media screen and (max-width: 1000px) {
    .faux-gif {
        position: absolute;
    
        height: 135%;
        width: 100%;
    
        display: flex;
        align-items: center;
        justify-content: center;
    
        background-image: url('images/arcade-machines3-bright.png');
        background-repeat: no-repeat;
        background-size: contain;
        background-position: left center;
    
        animation: giffy 0.2s infinite ease-in-out;
    }
    
    .crane {
        position: absolute;
    
        height: 135%;
        width: 100%;
    
        display: flex;
        align-items: center;
        justify-content: center;
    
        background-image: url('images/cranebow.png');
        background-repeat: no-repeat;
        background-size: contain;
        background-position: right center;
    }
}

@media screen and (max-width: 600px) {
    .faux-gif {
        position: absolute;
    
        height: 135%;
        width: 130%;
    
        display: flex;
        align-items: center;
        justify-content: center;
    
        background-image: url('images/arcade-machines3-bright.png');
        background-repeat: no-repeat;
        background-size: contain;
        background-position: left center;
    
        animation: giffy 0.2s infinite ease-in-out;
    }
    
    .crane {
        position: absolute;
    
        height: 135%;
        width: 140%;
    
        display: flex;
        align-items: center;
        justify-content: center;
    
        background-image: url('images/cranebow.png');
        background-repeat: no-repeat;
        background-size: contain;
        background-position: right center;
    }
}