:root{
    --red: #F06543;
    --white: #E8E9EB;
    --grey: #E0DFD5;
    --drkgrey: #909B87;
    --black: #313638;
    --drkblack: rgb(25, 27, 28);
    --orange: #F09D51;
    
    --fontMain: 'Anton', sans-serif;
    --fontBold: 'Bungee', cursive;
    --fontDetail: 'Lilita One', cursive;
    --fontPlay: 'Play', sans-serif;
}


.bold{
    font-family: var(--fontBold);
}

.detail{
    font-family: var(--fontPlay);
}

span.small{
    font-size: 12pt;
    font-family: var(--fontBold);
    color: var(--white)
}

body{
    background-color: var(--black);
    box-sizing: border-box;
    text-decoration: none;
    overflow-x: hidden;
}

a{
    text-decoration: none;
    color:var(--orange);
}

a:visited{
    text-decoration: none;
    color:var(--orange);
}

.main{
    background-color: var(--black);
    color:var(--white);
    font-size: 2em;
    font-family: var(--fontMain);
    overflow-x: hidden;
    transition: height 1s;
    padding:25px;
}

.nav{
    width: 100%;
    background-color: var(--drkblack);
    border-bottom: 2px solid var(--black);
}

.nav ul{
    list-style-type: none;
    margin: 0;
    padding-left: 20px;
    overflow: hidden;
    width:100%;
    font-family: var(--fontMain);
    color: var(--orange);
    font-size: 18pt;
}

.nav li{
    display: block;
    text-align: center;
    padding: 10px;
    margin-right: 20px;
    float:left;
    border-right: 2px solid var(--red);
    background-color: var(--black);
}

.portrait{
    float:right;
    margin: 20px 50px;
    border: 1px solid black;
    border-radius: 20px;
}

.tag{
    border: 1px solid var(--black);
    border-radius: 8px;
    font-family: monospace;
    padding: 0px 3px;
    margin: 1px;
    font-size: 12pt;
}

.gamedev{
    background-color: rgb(185, 240, 240);
    color:rgb(0, 69, 69);
}

.tag a:hover, a:hover span{
    background-color: white;
}

.teaching{
    background-color: rgb(207, 252, 216);
    color:rgb(0, 76, 16);
}

.programmer{
    background-color: rgb(243, 174, 236);
    color:rgb(71, 0, 54);
}

.gameSelect{
    height: 92vh;
}

.typed{
    font-size: 21pt;
    color:var(--red);
    overflow: hidden;
    border-right: 5px solid rgba(0,0,0,0);
    white-space: nowrap;
    margin: 0 auto;
    letter-spacing: 3px;
    animation: 
        typing 1.25s steps(20, end),
        blink-caret .60s step-end infinite;
}

.typedArea1{
    width: 580px;
}

.typedArea2{
    width: 370px;
}

.infinite{
    animation: 
        typing 1.5s steps(25, end),
        blink-caret .60s step-end infinite;
}

.slide{
    color: var(--white);
    font-family: var(--fontPlay);
    animation: 
        slide 0.5s ease-in;
}

.slide2{
    width: 90%;
    color: var(--white);
    font-size: 1em;
    animation: 
        slide 0.5s ease-in;
}

.gameGrid{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content:space-evenly;
    align-content:center;
    gap: 5px;
    padding: 10px;
    margin: 10px;
    overflow-y: scroll;
    margin-right: -50px;
}

.gameGridItem{
    border: 1px solid var(--white);
    border-radius: 5px;
    margin: 30px 15px ;
    background-color: var(--drkblack);
    width:350px;
    height:250px;
    font-family: var(--fontDetail);
    text-align: center;
    font-size: 20pt;
    color: var(--black);
    transition: border 0.1s;
    animation: fadein 0.5s;
}

.gameGridItem p{
    text-wrap: wrap;
    padding-top: 40%;
}

.gameGridItem:hover{
    border: 1px double var(--red);
    border-radius: 5px;
    color: var(--white);
}

portfolioBackground
{
	padding: 5px;
	float:right;
    margin: 10px 0px;
    overflow-x: hidden;
	background-color: rgb(25,25,50);
	letter-spacing: .05em;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 20pt;
	color: rgb(25, 25, 25);
	border: 1px solid black;	
	text-align: center;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows:repeat(20, fit-content);
}

portfolioBox
{
    display:block;
    padding:5px;
    padding-bottom: 5px;
    margin: auto;
    width: 50%;
    margin-bottom: 5px;
    overflow: hidden;
	background-color:lightslategray;
	font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	font-size: 16pt;
	color: rgb(5, 5, 5);
	border: 0.25px solid black;
	text-align: left;
	line-height: 90%;
}
portfolioBox a:link,portfolioBox a:visited{
    color:aquamarine;
    text-shadow: 1px 1px 1px darkgreen;
    text-decoration: none;
    text-align: center;
}
portfolioBox a:hover{
    color: rgb(255, 150, 0);
    text-shadow: 1px 1px 1px white;
    cursor: pointer;
    text-align: center;
}

@keyframes typing {
    from { width: 0 }
    to { width: 100% }
}

@keyframes blink-caret {
    from, to {border-color: transparent }
    50% { border-color: var(--white); }
}

@keyframes slide {
    0%{ opacity: 0; color: rgba(0,0,0,0); margin-left: 25%;}
    80%{opacity: 0;}
    100%{opacity: 1; color:var(--white);margin-left: 0;}
}

@keyframes fadein {
    0%{ opacity: 0; margin: -30px 15px ;}
    10%{opacity: 0; margin: -30px 15px ;}
    100%{opacity: 1; margin: 30px 15px ;}
}

@keyframes lettersClear{
    50%{opacity: 1;}
    100%{opacity: 0;}
}

/* ================================================ */
/* ============ Mobile Portrait =================== */
/* ================================================ */

@media only screen and (max-width: 600px) {
    .main{
        background-color: var(--black);
        color:var(--white);
        font-size: 2.5em;
        font-family: var(--fontMain);
        margin: 0.5%;
        padding: 2%;
        border: 5px double var(--orange);
        border-radius: 10px;
    }
    
    .typed{
        color:var(--red);
        overflow: hidden;                    /* Ensures the content is not revealed until the animation */
        border-right: .2em solid rgba(0,0,0,0); /* The typwriter cursor */
        white-space: nowrap;                /* Keeps the content on a single line */
        margin: 0 auto;                     /* Gives that scrolling effect as the typing happens */
        letter-spacing: .10em;              /* Adjust as needed */
        animation: 
            typing 1.5s steps(25, end),
            blink-caret .60s step-end 5;
    }
    
    .typedArea1{
        width: 450px;
    }

    .typedArea2{
        width: 310px;
    }

    .slide{
        width: 90%;
        color: var(--white);
        font-size: 1em;
        animation: 
            slide 0.5s ease-in;
    }

    .slide2{
        width: 90%;
        color: var(--white);
        font-size: 1em;
        animation: 
            slide 0.5s ease-in;
    }
}