:root {
    /* Fonts */
    --title-family: Upheavtt;
    --text-family: Terminal;

    /* TRANSITION */
    --theme-transition-duration: 500ms;
    --theme-hover-duration: 150ms;
    --theme-transition-function: ease-in-out;

    /* LIGHT MODE COLORS */
    --light-background-color: #E6E6E6;
    --light-foreground-color: #1E1E1E;
    --light-overlay: #E6E6E6AA;
    --light-disabled-color: #828282;
    --light-accent-color: #D49D08;
    --light-faded-accent-color: #DDC277;
    /* DARK MODE COLORS */
    --dark-background-color: var(--light-foreground-color);
    --dark-foreground-color: #DADADD;
    --dark-overlay: #1E1E1EAA;
    --dark-disabled-color: var(--light-disabled-color);
    --dark-accent-color: #E6B028;
    --dark-faded-accent-color: #826723;

    /* CTA TV Colors */
    /* Light */
    --light-tv-color-1: #f9fb00;
    --light-tv-color-2: #02feff;
    --light-tv-color-3: #01ff00;
    --light-tv-color-4: #fd00fb;
    --light-tv-color-5: #fb0102;
    --light-tv-color-6: #0301fc;
    /* Dark */
    --dark-tv-color-1: #f9fb00;
    --dark-tv-color-2: #02feff;
    --dark-tv-color-3: #01ff00;
    --dark-tv-color-4: #fd00fb;
    --dark-tv-color-5: #fb0102;
    --dark-tv-color-6: #0301fc;
}
/* HANDLE LIGHT/DARK MODE */
html, html[data-theme="light"] { 
    --background-color: var(--light-background-color);
    --foreground-color: var(--light-foreground-color);
    --overlay-color: var(--light-overlay);
    --disabled-color: var(--light-disabled-color);
    --accent-color: var(--light-accent-color);
    --faded-accent-color: var(--light-faded-accent-color);

    --light-toggle-color: var(--accent-color);
    --dark-toggle-color: var(--faded-accent-color);
    --accordion-text-color: var(--foreground-color);
    
    /* CTA TV */
    --tv-color-1: var(--light-tv-color-1);
    --tv-color-2: var(--light-tv-color-2);
    --tv-color-3: var(--light-tv-color-3);
    --tv-color-4: var(--light-tv-color-4);
    --tv-color-5: var(--light-tv-color-5);
    --tv-color-6: var(--light-tv-color-6);
}
html [data-themeonly="dark"], html[data-theme="light"] [data-themeonly="dark"] {
    display: none;
}
html [data-themeonly="light"], html[data-theme="light"] [data-themeonly="light"] {
    display: block;
}
html[data-theme="dark"] {
    --background-color: var(--dark-background-color);
    --foreground-color: var(--dark-foreground-color);
    --overlay-color: var(--dark-overlay);
    --disabled-color: var(--dark-disabled-color);
    --accent-color: var(--dark-accent-color);
    --faded-accent-color: var(--dark-faded-accent-color);

    --light-toggle-color: var(--faded-accent-color);
    --dark-toggle-color: var(--accent-color);
    --accordion-text-color: var(--background-color);

    /* CTA TV */
    --tv-color-1: var(--dark-tv-color-1);
    --tv-color-2: var(--dark-tv-color-2);
    --tv-color-3: var(--dark-tv-color-3);
    --tv-color-4: var(--dark-tv-color-4);
    --tv-color-5: var(--dark-tv-color-5);
    --tv-color-6: var(--dark-tv-color-6);
}
html[data-theme="dark"] [data-themeonly="dark"] {
    display: block;
}
html[data-theme="dark"] [data-themeonly="light"] {
    display: none;
}
span[data-class="dark"]{
    color: var(--dark-toggle-color);
}
span[data-class="light"]{
    color: var(--light-toggle-color);
}
@media (prefers-color-scheme: dark) {
	html, html[data-theme="dark"] {
		--background-color: var(--dark-background-color);
        --foreground-color: var(--dark-foreground-color);
        --overlay-color: var(--dark-overlay);
        --disabled-color: var(--dark-disabled-color);
        --accent-color: var(--dark-accent-color);
        --faded-accent-color: var(--dark-faded-accent-color);

        --light-toggle-color: var(--faded-accent-color);
        --dark-toggle-color: var(--accent-color);
        --accordion-text-color: var(--background-color);
	}
    html [data-themeonly="dark"], html[data-theme="dark"] [data-themeonly="dark"] {
        display: block;
    }
    html [data-themeonly="light"], html[data-theme="dark"] [data-themeonly="light"] {
        display: none;
    }
	html[data-theme="light"] { 
        --background-color: var(--light-background-color);
        --foreground-color: var(--light-foreground-color);
        --overlay-color: var(--light-overlay);
        --disabled-color: var(--light-disabled-color);
        --accent-color: var(--light-accent-color);
        --faded-accent-color: var(--light-faded-accent-color);

        --light-toggle-color: var(--accent-color);
        --dark-toggle-color: var(--faded-accent-color);
        --accordion-text-color: var(--foreground-color);
	}
    html[data-theme="light"] [data-themeonly="dark"] {
        display: none;
    }
    html[data-theme="light"] [data-themeonly="light"] {
        display: block;
    }
}

body, #page-container, #site-header {
    background: var(--background-color) url('../assets/background-noise.png') repeat;
    animation: 0.2s infinite noise;
    color: var(--foreground-color);
    transition-property: background, color, opacity;
    transition-duration: var(--theme-transition-duration),  var(--theme-transition-duration), var(--game-transition-duration);
    transition-timing-function: var(--theme-transition-function),var(--theme-transition-function), ease-in-out;
    transition-delay: 0ms;
    will-change: background, color, opacity;
}
#page-container > div{
    transition-property: opacity;
    transition-duration: var(--game-transition-duration);
    transition-timing-function: ease-in-out;
    transition-delay: 0ms;
    will-change: opacity;
}

@keyframes noise {
    0%, 100% {
      background-position: 0 0;
    }
    10% {
      background-position: -5% -10%;
    }
    20% {
      background-position: -15% 5%;
    }
    30% {
      background-position: 7% -25%;
    }
    40% {
      background-position: 20% 25%;
    }
    50% {
      background-position: -25% 10%;
    }
    60% {
      background-position: 15% 5%;
    }
    70% {
      background-position: 0% 15%;
    }
    80% {
      background-position: 25% 35%;
    }
    90% {
      background-position: -10% 10%;
    }
  }


/* Fonts */
@font-face {
    font-family: Upheavtt;
    src: url(../assets/fonts/upheavtt.ttf);
}
@font-face {
    font-family: Terminal;
    src: url(../assets/fonts/terminal-grotesque.ttf);
}
h1, h2, h3, h4, h5, h6, nav, a, strong {
    font-family: var(--title-family);
}
strong {
    color: var(--accent-color);
}
* {
    font-family: var(--text-family);
}
input::placeholder, textarea::placeholder {
    color: var(--disabled-color);
}
input[type=button], input[type=submit], input[type=reset] {
    color: var(--background-color);
    background-color: var(--accent-color);
    
    text-decoration: none;
    cursor: pointer;
    font-size: 1.5em;
    padding: 5px 15px;
    font-family: var(--text-family);

    border-width: var(--small-border-size);
    border-style: solid;
    border-color: var(--accent-color);
}
input[type=button]:disabled, input[type=submit]:disabled, input[type=reset]:disabled {
    color: var(--disabled-color);
    background-color: var(--background-color);
    border-color: var(--foreground-color);
    cursor: not-allowed;
}
@media screen and (max-width: 799px) {
    strong {
        letter-spacing: 0.5px;
    }
}


/* Theme toggler */
#theme-toggle {
    vertical-align: middle;
}
#theme-toggle > #toggle-icon {
    height: 1.5em;
    vertical-align: middle;
}

::-webkit-scrollbar {
    width: var(--scrollbar-width);
    transition: opacity 200ms ease-out;
    will-change: opacity;
    opacity: 1;
}
:not(.scrolling)::-webkit-scrollbar {
    opacity: 0;
}
::-webkit-scrollbar:hover {
    opacity: 1 !important;
}
::-webkit-scrollbar-track {
    background: var(--disabled-color); 
}
::-webkit-scrollbar-thumb {
    background: var(--faded-accent-color); 
}
::-webkit-scrollbar-thumb:hover {
    background: var(--accent-color); 
}
::-webkit-scrollbar-corner,
::-webkit-resizer { display: none; }