
body {
	background: #1c1c1c;
	font-family: "Poppins", sans-serif;
	font-size: 22px;
	color: #fff;
	margin: 0;
	padding: 0;
}

a{
    color: #fff;
}

div {
    position: relative;
    text-align: center;
}

div a.button{
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    color: #444;
}

#canvas{
    position: relative;
    margin: auto;
    width: 100%;
    background-color: #1c1c1c;
}

#BG_image{
    position: relative;
    top: 0px;
    width: 100%;
    height: auto;
    object-fit: cover;
    max-height: 600px;
    transform: rotateY(180deg);
}

#Img_Credit{
    display: block;
    position: relative;
    width: 100%;
    height: 0%;
    color: #444;
    text-align: right;
    font-size: 14px;
}

#Img_Credit a{
    position: relative;
    padding-right: 10px;
    top: -10px;
    height: 0%;
    vertical-align: top;
    color: #555;
    text-align: right;
    font-size: 12px;
}

#Portfolio{
    margin-top: 120px;
    width: 100%;
    background-image: linear-gradient(to bottom, #1c1c1c,#1c2a2a);
    height: fit-content;
}

#Portfolio-Title{
    left: 25%;
    background-image: linear-gradient(to bottom right, #233,#254);
    font-weight: 700;
    font-size: 56px;
    width: 75%;
    line-height: 0.8em;
    text-align: left;
    padding: 20px;
}

#Puzzle{
    margin-top: 60px;
    position: relative;
    width: 100%;
    height: fit-content;
}

#Puzzle-Title{
    left: 30%;
    width: 70%;
    font-style: italic;
    text-align: left;
    padding-left: 20px;
    font-weight: 700;
}

#Puzzle-Desc{
    left: 30%;
    width: 70%;
    text-align: left;
    padding-left: 20px;
    font-weight: 300;
}

#Puzzle-Content{
    position: relative;
    display: block;
    height: fit-content;
    align-items: center;
    width: 100%;
    margin-top: 50px;
}

#Puzzle-Embed{
    display: block;
    width: 90%;
    margin: auto;
    max-height: 90vh;
}


.break-light-bg{
    display: block;
    width: 100%;
    height: 140px;
    background-color: #1c2a2a;
}

#Contact{
    width: 100%;
    background-image: linear-gradient(to bottom, #1c2a2a,#1c1c1c);
    height: fit-content;
}

#Contact-Title{
    left: 25%;
    background-image: linear-gradient(to bottom right, #233,#254);
    font-weight: 700;
    font-size: 56px;
    width: 75%;
    line-height: 0.8em;
    text-align: left;
    padding: 20px;
}

#Contact-Content{
    text-align: left;
    margin-top: 50px;
    margin-left: 30%;
    padding-left: 20px;
    width: 70%;
    overflow-wrap: break-word;
}

#outline0{
    left: 10px;
    top: 10px;
    width: 515px;
    height: 120px;
    background-color: #233;
}

#outline1{
    left: 525px;
    top: 20px;
    width: 55px;
    height: 95px;
    background-color: #233;
}

#outline2{
    left: 580px;
    top: 30px;
    width: 20px;
    height: 50px;
    background-color: #233;
}

#outline3{
    left: 600px;
    top: 50px;
    width: 30px;
    height: 50px;
    background-color: #233;
}

#rect0{
    left: 425px;
    top: 10px;
    width: 100px;
    height: 90px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect1{
    left: 340px;
    top: 10px;
    width: 80px;
    height: 25px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect2{
    left: 295px;
    top: 10px;
    width: 40px;
    height: 40px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect3{
    left: 340px;
    
    top: 40px;
    width: 10px;
    height: 10px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect4{

    left: 355px;
    top: 40px;
    width: 65px;
    height: 60px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect5{
    left: 295px;
    top: 55px;
    width: 55px;
    height: 75px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #fff;
}

#rect6{
    left: 355px;
    top: 105px;
    width: 110px;
    height: 35px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect7{
    left: 530px;
    top: 20px;
    width: 50px;
    height: 50px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect8{
    left: 585px;
    top: 50px;
    width: 190px;
    height: 20px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect9{
    left: 530px;
    top: 75px;
    width: 100px;
    height: 40px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #999;
}

#rect10{
    left: 470px;
    top: 105px;
    width: 55px;
    height:25px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #282;
}


#rect11{
    left: 585px;
    top: 30px;
    width: 15px;
    height: 15px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #fff;
}

div.rect-bg{
    visibility: hidden;
    background-color: #444;
}

div.rect-arrow{
    visibility: hidden;
    background-color: #fff;
}

#wrapper{
    position: fixed;
    left: 10px;
    top: 10px;
    width: 100;
    height: 300px;
    background-color: #555;
}

#wrapper div{
    position: fixed;
}

#JH-wrapper-small{
    position: fixed;
    left: 10px;
    top: 10px;
    width: 180px;
    height: 80px;
    background-image: linear-gradient(to bottom right, #233,#254);
    background-color: #adb;
}

#JH-small{
    left: 10px;
    top: 25px;
    width: 160px;
    height: 100px;
    font-size: 32px;
    font-weight: 700;
    text-align: right;
    line-height: 0.8em;
    position: fixed;
	color: #fff;
}

#JH-wrapper{
    width: 280px;
    height: 240px;
    background-image: linear-gradient(to bottom right, #233,#254);
}

#JH{
    left: 30px;
    top: 30px;
    width: 240px;
    height: 100px;
    font-size: 48px;
    font-weight: 700;
    text-align: right;
    line-height: 0.8em;
    position: fixed;
	color: #fff;
}

#Engineer{
    left: 30px;
    top: 160px;
    width: 240px;
    height: 100px;
    font-size: 16px;
    font-weight: 700;
    text-align: right;
    line-height: 0.8em;
    position: fixed;
	color: #fff;
}

#Company{
    left: 30px;
    top: 180px;
    width: 240px;
    height: 100px;
    font-size: 16px;
    font-weight: 400;
    text-align: right;
    line-height: 0.8em;
    position: fixed;
	color: #fff;
}

#Text{
    position: absolute;
    top: 270px;
    width: 100%;
    height: 280px;
}

#Mission_BG{
    position: absolute;
    left: 50%;
    height: 100%;
    width: 50%;
    background-image: linear-gradient(to bottom right, #233,#254);
    opacity: 0.7;
}

#Mission{
    position: absolute;
    left: 50%;
    width: 50%;
}

#Mission_Text{
    position: relative;
    padding-left: 10px;
    top: 10px;
    height: 180px;
    text-align: left;
    font-weight: 500;
    color: #fff;
    opacity: 100;
}

#Text-cutout{
    visibility: visible;
    left: 310px;
    top: 240px;
    width: 170px;
    height: 90px;
}

#About{
    left: 770px;
    top: 570px;
    width: 160px;
    height: 80px;
}

#About-arrow{
    left: 0px;
    top: 0px;
    width: 180px;
    height: 100px;
}

#About-bg{
    left: 0px;
    top: 0px;
    width: 170px;
    height: 90px;
}

#About-button{
    left: 0px;
    top: 0px;
    width: 160px;
    height: 80px;
    background-color: #bdb;
    line-height: 3em;
}

#About:hover #About-button{
    background-color: #fff;
}

#About:hover #About-arrow{
    visibility: visible;
}

#About:hover #About-bg{
    visibility: visible;
}

#Copyright{
    text-align: left;
    font-size: 12px;
    margin-top: 350px;
    padding-left: 20px;
    padding-bottom: 20px;
    color: #555;
}


