body,
html {
    padding: 0;
    margin: 0;
    text-rendering: optimizeLegibility;
    line-height: 1.3;
    letter-spacing: .03em;
    box-sizing: border-box;
    color: #eee;
    background: #0b0c10;
    scroll-behavior: smooth;
    font-size: 1.175rem
}

@media screen and (max-width:700px) {
    body,
    html {
        font-size: 1rem
    }
    table {
        font-size: .75em
    }
}

body,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Lato, "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 600;
    margin-top: 0
}

#particles-js {
    padding-top: 0;
    padding-bottom: 0;
    text-align: right;
    background: 0 0;
    background-size: cover;
    height: 100%;
    width: 100%;
    position: fixed;
    pointer-events: all
}

h1 {
    font-size: 2em
}

h1,
p,
table {
    position: relative
}

a {
    color: #66fcf1
}

.intro-divider-div {
    width: 65%;
    margin: 2vh auto 2vh
}

.intro-divider {
    border-top: 1.5px solid #f8f8f8
}

.seperator {
    width: 100%;
    height: 1vh;
    background-color: #45a29e
}

h4 span {
    font-size: 2em
}

@media screen and (max-width:700px) {
    h4 span {
        font-size: 1.4em
    }
}

strong {
    color: #66fcf1
}

nav {
    z-index: 200;
    font-size: 1.2em;
    user-select: none;
    -webkit-user-drag: none;
    position: fixed
}

nav a {
    color: #eee;
    padding: .5em;
    text-align: center;
    text-decoration: none;
    outline: 0
}

nav a:hover {
    color: #66fcf1
}

nav.nav-social {
    left: 0;
    top: 4rem;
    text-align: left
}

@media screen and (max-width:1000px) {
    nav.nav-social {
        display: none
    }
}

nav.nav-social .social-container {
    display: block;
    float: none;
    padding-left: .5rem;
    padding-bottom: .5rem;
    padding-top: .2rem
}

nav.nav-social a {
    font-size: calc(1.325rem + 1.5vw)
}

@media (min-width:1200px) {
    nav.nav-social a {
        font-size: 2rem
    }
}

.social-container {
    position: relative
}

.splash-container {
    min-height: 100vh
}

.splash-container .splash {
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    overflow: hidden
}

.splash-container .splash .maintitle {
    font-size: calc(1.725rem + 5.7vw)
}

@media (min-width:1200px) {
    .splash-container .splash .maintitle {
        font-size: 6rem
    }
}

@media screen and (max-width:700px) {
    .splash-container .splash .maintitle {
        font-size: 3rem
    }
}

.intro-section {
    margin-left: 5rem;
    margin-right: 5rem;
    min-height: 100vh;
    max-width: 100%
}

.contact-section {
    padding-left: 5rem;
    padding-right: 5rem;
    padding-top: 4rem;
    padding-bottom: 4rem;
    margin-left: auto;
    margin-right: auto;
    max-width: 1140px
}

.general-section {
    padding-left: 5rem;
    padding-right: 5rem;
    padding-top: 4rem;
    padding-bottom: 4rem;
    min-height: 100vh;
    max-width: 100%
}

@media screen and (max-width:700px) {
    .general-section {
        padding-left: 2rem;
        padding-right: 2rem
    }
}

.section>* {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto
}

.section:last-of-type {
    min-height: calc(100vh - 4em)
}

.about-section {
    width: 100%;
    min-height: 100vh;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    display: flex;
    justify-content: center;
    flex-direction: row
}

.about-section p {
    font-size: 1rem
}

@media only screen and (max-width:500px) {
    .about-section {
        flex-direction: column
    }
}

.light-background {
    background: #212529
}

.dark-background {
    background: #0b0c10
}

.nav-main {
    width: 100%;
    background: #15171f;
    text-align: right
}

.nav-link-list {
    margin: 0 auto;
    padding: 0
}

.nav-link {
    list-style: none;
    display: inline-block;
    padding: 12px
}

.nav-link a {
    color: #fff;
    text-decoration: none
}

.toggle {
    width: 100%;
    padding: 10px 20px;
    background: #15171f;
    text-align: right;
    box-sizing: border-box;
    color: fff;
    font-size: 30px;
    display: none
}

@media screen and (max-width:1085px) {
    .toggle {
        display: block
    }
    .nav-link-list {
        width: 100%;
        display: none
    }
    .nav-link {
        display: block;
        text-align: center
    }
    .active {
        display: block
    }
}

@media screen and (max-width:700px) {
    .toggle {
        font-size: 20px
    }
}

.about-section-profile-image {
    margin-top: 2em;
    width: 22em;
    height: 22em;
    border: 0 solid #fff;
    border-radius: 50em;
    box-shadow: 0 0 0 #fff;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out
}

@media only screen and (max-width:400px) {
    .about-section-profile-image {
        margin-top: 2em;
        width: 15em;
        height: 15em
    }
}

@media only screen and (max-width:330px) {
    .about-section-profile-image {
        width: 15em;
        height: 15em
    }
}

.about-section-seperator {
    width: 100%;
    height: 100%;
    z-index: 100;
    display: flex;
    flex-direction: row;
    justify-content: space-evenly;
    margin: auto
}

@media only screen and (max-width:500px) {
    .about-section-seperator {
        flex-direction: column
    }
}

.about-section-content-container {
    display: flex;
    flex-direction: row;
    justify-content: center
}

@media screen and (max-width:1380px) {
    .about-section-content-container {
        flex-direction: column
    }
}

.about-section-profile {
    display: flex;
    justify-content: center;
    margin: 2em
}

.about-section-content {
    padding: 1em;
    width: 30em;
    border-top: 1.5px solid #f8f8f8;
    border-bottom: 1.5px solid #f8f8f8;
    margin: auto auto 3.3em
}

@media only screen and (max-width:550px) {
    .about-section-content {
        width: 20em
    }
}

@media only screen and (max-width:370px) {
    .about-section-content {
        width: 15em
    }
}

@media only screen and (max-width:330px) {
    .about-section-content {
        width: 13.5em
    }
}

.subsection {
    position: relative;
    margin-bottom: 2rem
}

.subsection h3 {
    margin-bottom: 0;
    color: #66fcf1
}

.subsection .right-align {
    position: absolute;
    right: 0;
    top: 0;
    text-align: right
}

@media screen and (max-width:800px) {
    .subsection .right-align {
        position: relative;
        display: inline-block;
        text-align: left
    }
}

.subsection.no-bottom {
    margin-bottom: 0
}

.subsection p {
    margin: 0
}

.block-quote {
    max-width: 40em;
    margin: 1em 0;
    padding-left: 1em;
    border-left: .2em solid #66fcf1
}