@import "https://fonts.googleapis.com/css?family=Gotu&display=swap";

:root {
  --textColor: #ffffff;
  --shadowColor: #7799BB;
  --hoverShadow: .08em .08em #ffffff;
  --normalShadow: .1em .1em #7799BB;
  --topStart: 50vw;
  --topIncr: 7vw;
  --bgWidth: 100vw;
  --bgHeight: auto;
}

body {
  color: var(--textColor);
  background-color: #000;
  font-family:'Gotu',sans-serif;
  font-size: .8vw;
  line-height: 2.0;
  border: none;
}

.hamburger-icon {
  position: absolute;
  z-index: 2;
  top: 1vw;
  left: 1vw;
  width: 3vw;
}

.hamburger-icon span {
  height: .2vw;
  width: 1.6vw;
  background-color: #ffffff;
  display: block;
  margin: .2vw 0 .2vw 0;
  transition: 0.7s ease-in-out;
  transform: none;
}

input.hamburger-checkbox {
  position: absolute;
  z-index: 3;
  top: 1vw;
  left: 1vw;
  width: 2vw;
  opacity: 0;
  height: 3vw;
}

#openmenu:checked ~ .menu-pane {
  left: 0;
  transform: translateX(0);
}

#openmenu:checked ~ .hamburger-icon span:nth-of-type(2) {
  transform: translate(0%, 175%) rotate(-45deg);
}

#openmenu:checked ~ .hamburger-icon span:nth-of-type(3) {
  transform: rotate(45deg);
}

#openmenu:checked ~ .hamburger-icon span:nth-of-type(1) {
  opacity: 0;
}

#openmenu:checked ~ .hamburger-icon span:nth-of-type(4) {
  opacity: 0;
}

div.menu-pane {
  border: thin #dddddd solid;
  position: absolute;
  transform: translateX(-105vw);
  transform-origin: (0, 0);
  width: 16vw;
  transition: 0.6s ease-in-out;
  background-image: linear-gradient(to bottom right, #000000, #555555);
  z-index: 1;
}

.menu-pane nav {
  padding: 5vw 1vw 1vw 1vw;
  font-size: 1vw;
}

.section p {
  color: #ffffff;
  margin: 0;
  text-align: left;
}

nav form {
  text-align: left;
  width: 15vw;
}

#kwdfield {
  width: calc(90% - 2em);
}

#kwdbtn {
  width: 2em;
}

nav > a {
  color: #ffffff;
  display: block;
  text-decoration: none;
  text-align: left;
  padding-bottom: .5vw;
  font-size: 1.0vw;
  text-shadow: none;
}

nav > a img {
  height: 1.6vw;
  padding: .5vw .5vw .15vw 0;
  vertical-align: text-bottom;
}

nav label {
  display: block;
  text-align: left;
  padding: 0 0 .5vw .5vw;
  line-height: normal;
}

label input {
   float: right;
   margin: .5vw 1.3vw 0 0;
   accent-color: black;
   transform: scale(1.5);
}

div.opt {
   position: relative;
   text-align: left;
   color: #ffffff;
   margin-left: .5vw;
   line-height: normal;
   width: 14vw;
}

.opt span {
   float: right;
   margin-right: 1vw;
   font-size: 1.5vw;
}

.subopt {
   position: relative;
   text-align: left;
   color: #ffffff;
   margin-left: .5vw;
   padding-left: 1vw;
   line-height: 2vw;
   width: 12.5vw;
}

.flex-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  position: static;
}

.flex-container a img {
   height: 2vw;
   padding: .5vw 1vw 0 1vw;
}

.flex-container > div {
   height: 1.2vw;
   width: 6vw;
   background-color: #666666;
   position: relative;
   margin: 0 1vw .5vw 1vw;
   padding: 0 1vw 0 1vw;
   border-radius: 1vw;
   box-sizing: border-box;
}

#toggleLeft {
   position: relative;
   font-size: 1vw;
   top: -.3vw;
   left: -.8vw;
   opacity: 1;
}

#toggleRt {
   position: relative;
   font-size: 1vw;
   top: -2.3vw;
   left: .8vw;
   opacity: 0;
}

#toggleLeft:hover {
   opacity: 1;
}

#toggleLeft:hover + a {
   opacity: 0;
}

#toggleRt:hover {
   opacity: 1;
}

#toggleLeft:has(+ a:hover) {
   opacity: 0;
}

.subopt input {
   padding-right: 1vw;
}

.subopt span {
   float: right;
   margin-right: 1vw;
   font-size: 1.5vw;
}

.section {
  position: static;
  display:  block;
  color: #ffffff;
  border-bottom: thin #ffffff solid;
  margin: 0 0 1vw 0;
  width: 13vw;
  height: 1vw;
  padding: 1vw 1vw .5vw 0;
}

body > div > a {
  font-size: 1.2vw;
  text-decoration: none;
  text-shadow: var(--normalShadow);
  z-index: 2;
}

body > div > a:link {color: var(--textColor);}
body > div > a:visited	{color: var(--textColor);}
body > div > a:active	{color: var(--textColor);}

body > div > a:hover {
  color: var(--shadowColor);
  text-shadow: var(--hoverShadow);
}

#eclipse {
    position: absolute;
    width: 100vw;
    height: auto;
    left: 0;
    top: 0;
    z-index: 0;
}

#topicPhoto {
    position: absolute;
    width: 100vw;
    height: auto;
    left: 0;
    top: 0;
    z-index: -1;
}

#canvas1 {
    z-index: -2;
    position: absolute;
    left: 0;
    top: 0;
}

#dim {
    position: absolute;
    color: white;
    top: 0;
    left: 30%;
    text-align: left;
    text-decoration: none;
    text-shadow: none;
}

div {
  position: absolute;
  text-align: right;
  top: 0;
  border-style: none;
  width: 10%;
  z-index: 1;
}

/*
div:hover .newContent { 
  visibility: visible;
}

.newContent {
  color: var(--textColor);
  visibility: hidden;
  font-family: "Bradley Hand", "Lucida Handwriting", cursive;
}
*/

img {
    height: 100px;
}

.topLabel {
  position: absolute;
  left: 45%;
  margin-top: 9%;
  text-align: center;
}

.topLabel > a > p {
  display: inline;
  text-decoration: none;
  position: relative;
  letter-spacing: .1em;
  text-shadow: var(--normalShadow);
}
.topLabel p:nth-child(2) {
   top: -.05em;    
}
.topLabel p:nth-child(3) {
   top: -.07em;    
}
.topLabel p:nth-child(4) {
   top: -.09em;    
}
.topLabel p:nth-child(5) {
   top: -.11em;    
}
.topLabel p:nth-child(6) {
   top: -.11em;    
}
.topLabel p:nth-child(7) {
   top: -.09em;    
}
.topLabel p:nth-child(8) {
   top: -.07em;    
}
.topLabel p:nth-child(9) {
   top: -.05em;    
}

.bottomLabel {
  position: absolute;
  left: 44.8%;
  margin-top: 48%;
  text-align: center;
  text-shadow: var(--normalShadow);
}

.bottomLabel > a > p {
  display: inline;
  position: relative;
  text-decoration: none;
  letter-spacing: .1em;
}

.bottomLabel p:nth-child(2) {
   top: .05em;    
}
.bottomLabel p:nth-child(3) {
   top: .1em;    
}
.bottomLabel p:nth-child(4) {
   top: .05em;    
}

#tagline {
  font-size: 1em;
  color: #000000;
  text-shadow: 0 0 1.5em #ffccff, 0 0 1em #ffffff, 0 0 .8em #ffffff;
  left: 39%;
  margin-top: 52%;
  width: 50%;
  text-align: left;
}

.left {
  display: none; 
}

.right {
  position: absolute;
  text-align: left;
  top: 0;
  border-style: none; 
  width: 22%;
  display: none;  
}

@media only screen and (max-width: 1000px) {
  label input {
   transform: none;
  }
}