:root{
  --white: #FFFFFF;
  --licorice: #000000;
  --blue-green: #2EC4B6;
  --redical: #FF3366;
  --florange: #E4572E;
  --gray: #D2CECD;
  --window: #3A6EA5;
}

.blinking-cursor {
  display: inline-block;
  margin-left: 2px;
  width: 10px; /* Increase width */
  height: 1em;
  background-color: #00ff00; /* Green, matches previous color */
  animation: blink 1s step-start infinite;
}

@keyframes blink {
  50% {
    opacity: 0;
  }
}


body{
margin:0;
overflow: auto; /* Changed from hidden to allow scrolling */
background-color: var(--window);

}

.main{
width:100%;
height:100vh;
z-index: 400;
top:0;
left:0;
position: absolute;
display: flex;
justify-content: center;
}

#home___mainbox{
background-color: var(--white);
height:70%;
width:50%;
min-width: 500px;
max-width: 800px;
margin-right: auto;
margin-left: auto;
display: flex;
flex-direction: column;
padding-top: 1px;
justify-content: space-between;
margin-top: auto;
margin-bottom: auto;
box-shadow: 10px 10px 5px #0A3B76;
}



/*https://iros.github.io/patternfills/sample_css.html*/
#home___tool-bar-name{
display: flex;
justify-content: space-between;
border-bottom: solid;
}

#home___namebar{
font-size: 3.25vh;
padding-left: 1vh;
padding-right: 1vh;
white-space: nowrap;
font-family: 'VT323', monospace;
padding-bottom: 1px;
padding-top:1px;

}
.home___namebar-fill{
margin: 5px;
width:100%;
background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiPjxkZWZzPjxwYXR0ZXJuIGlkPSJwYXR0ZXJuX29rRmoiIHBhdHRlcm5Vbml0cz0idXNlclNwYWNlT25Vc2UiIHdpZHRoPSI0IiBoZWlnaHQ9IjQiIHBhdHRlcm5UcmFuc2Zvcm09InJvdGF0ZSg5MCkiPjxsaW5lIHgxPSIwIiB5PSIwIiB4Mj0iMCIgeTI9IjQiIHN0cm9rZT0iIzAwMDAwMCIgc3Ryb2tlLXdpZHRoPSI0Ii8+PC9wYXR0ZXJuPjwvZGVmcz4gPHJlY3Qgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsbD0idXJsKCNwYXR0ZXJuX29rRmopIiBvcGFjaXR5PSIxIi8+PC9zdmc+');
background-repeat: repeat;
}

#home___tool-bar{
display:flex;
flex-direction: column;

border-bottom: double;
padding-bottom: 1px;
border-width: thick;
}

#home___tool-bar___entries{
display: flex;
flex-direction: row;
justify-content: flex-start;
flex-wrap: wrap;
height: auto;
margin-left:1px;
}

#home___tool-bar-tiles{
height: auto;
display: flex;
flex-direction: row;
justify-content: space-between;
flex-wrap: wrap;
margin-top:1px;
}
.home___tool-bar__entry{
font-family: 'VT323', monospace;
font-size: 3vh;
background-color: white;
color:black;
}

.home___tool-bar__entry:hover{
background-color: black;
color:white;

}


.home___tool-bar__entry-text{
margin:0;
padding-left: 1vh;
padding-right: 1vh;
line-height: 3vh;
}

.home___tool-bar__exit{
line-height: 2.5vh;
}

.home__content{
display: flex;
flex-direction: column;
justify-content: flex-start;
margin-left: 1vh;
margin-right:1vh;
height:100%;
overflow-y: scroll;
}


.output {
font-family: 'IBM Plex Mono', monospace;
color:var(--licorice);
margin-top:0;
margin-bottom: 0;
}
.output > h1{
font-size: 2.5vh;
}

/* Cursor Styling */

.cursor::after {
  content:'';
  display:inline-block;
  margin-left:3px;
  background-color:pink;
  animation-name:blink;
  animation-duration:0.5s;
  animation-iteration-count: infinite;
  line-height: 1vh;
  vertical-align: middle;

}

h1.cursor::after {
height:2.6vh;
width:1vh;
line-height: 2.6vh;
}

@keyframes blink {
0% {
  opacity:1;
}
49% {
  opacity:1;
}
50% {
  opacity:0;
}
100% {
  opacity:0;
}
}

.home___mainbox-text{
font-family: 'IBM Plex Mono', monospace;
font-size: 2vh;
color: var(--licorice);
}


.home___tool-bar-button{
text-decoration: none;
text-decoration-color: black;
color:black;
}

.home___link-text{
font-family: 'IBM Plex Mono', monospace;
font-size: 2vh;
color: var(--licorice);
margin-top:1px;
}



#home___image{
display: block;
margin: 0 auto;
max-height: 25vh;
}

/* Projects Page Styles */
.projects-page-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 2.5vh;
  margin-top: 10px;
  margin-bottom: 20px;
  font-weight: normal;
}

.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  padding: 20px 0;
}

.project-card {
  background-color: #f5f5f5;
  border: 2px solid #000;
  padding: 15px;
  transition: transform 0.2s;
  box-sizing: border-box;
}

.project-card:hover {
  transform: translateY(-5px);
  box-shadow: 5px 5px 0px #000;
}

.project-title {
  font-family: 'VT323', monospace;
  font-size: 24px;
  margin: 0 0 10px 0;
  color: #000;
}

.project-description {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 15px;
  color: #333;
}

.project-tech {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 12px;
  color: #666;
  margin-bottom: 10px;
}

.project-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  box-sizing: border-box;
}

.project-link {
  font-family: 'VT323', monospace;
  font-size: 16px;
  background-color: #000;
  color: #fff;
  padding: 5px 15px;
  text-decoration: none;
  border: 2px solid #000;
  display: inline-block;
  box-sizing: border-box;
}

.project-link:hover {
  background-color: #fff;
  color: #000;
}

/*https://stackoverflow.com/questions/6370690/media-queries-how-to-target-desktop-tablet-and-mobile*/

/* Tablet and smaller devices */
@media only screen and (max-width: 768px) {
  #home___mainbox {
    min-width: unset; /* Remove fixed minimum */
    width: 95%;
    height: 85vh;
  }

  .projects-grid {
    grid-template-columns: 1fr;
    gap: 15px;
    padding: 15px 0;
  }

  .project-card {
    padding: 12px;
  }

  .project-title {
    font-size: 20px;
  }

  .project-description {
    font-size: 13px;
  }

  .project-tech {
    font-size: 11px;
  }

  .project-link {
    font-size: 14px;
    padding: 5px 12px;
  }

  .projects-page-title {
    font-size: 2.5vh;
  }
}

/* Mobile devices */
@media only screen and (max-width: 480px){
  #home___mainbox{
    background-color: var(--white);
    height:80%;
    width:98%; /* Increased from 95% */
    min-width: unset; /* Remove fixed minimum */
    margin-right: auto;
    margin-left: auto;
    display: flex;
    flex-direction: column;
    padding-top: 1px;
    justify-content: space-between;
    margin-top: auto;
    margin-bottom: auto;
    box-shadow: 20px 20px 10px #0A3B76;
  }

  .output > h1{
    font-size: 2.5vh;
  }

  .home___mainbox-text{
    font-size: 2vh;
  }

  #home___namebar{
    font-size: 3.25vh;
  }
  .home___tool-bar__entry{
    font-size:2vh;
  }

  .aboutme{
    display: block;
  }

  .projects-grid {
    padding: 10px 0;
    gap: 12px;
  }

  .project-card {
    padding: 10px;
  }

  .project-links {
    flex-direction: column;
    gap: 8px;
  }

  .project-link {
    text-align: center;
    width: 100%;
  }
}

@media only screen and (min-width:1900px){
#home___mainbox{
  height:50%;
  width:50%;
  min-width: 500px;
  max-width: 800px;
}
.output > h1{
  font-size: 2vh;
}
.home___mainbox-text{
  font-size: 1.5vh;
}
#home___namebar{
  /*width:100%;*/
  font-size: 2.25vh;
}
.home___tool-bar__entry{
  font-size:2vh;
}
.home___tool-bar__entry-text{
  line-height: 2vh;
}
#home___tool-bar___entries{
  height: 2vh;
}
#home___tool-bar-tiles{
  height: 2vh;
}
#home___image{
  max-height: 20vh;
}

}

/*

https://www.coffee-break-designs.com/labs/svg_stripe_generator/
https://iros.github.io/patternfills/sample_css.html

font-family: 'Press Start 2P', cursive;
font-family: 'IBM Plex Mono', monospace;
font-family: 'VT323', monospace;
*/

/* Footer */
.site-footer {
  position: fixed;
  bottom: 10px;
  left: 0;
  right: 0;
  text-align: center;
  z-index: 500;
}

.site-footer p {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}
