@import url("https://fonts.googleapis.com/css?family=Oswald:400,700,300");
@import url("https://fonts.googleapis.com/css?family=Space+Mono:400,700");

#tech {
  height: 100vh;
  background-color: #121516;
}

.tech-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  padding: 0 5%;
  top: 0%;
}

.tech-container h1 {
  color: #e7e5e4;
  top: 0;
  padding: 1vh 0;
  margin: 0;
}
.tech-caption {
  top: 0;
  font-family: "Space Mono", monospace;
  font-size: 1.5em;
  font-weight: 100;
  letter-spacing: -0.05em;
  color: #e7e5e4;
  z-index: 2;
  padding: 0;
}
.category-container {
  display: flex;
  flex-direction: row;
  height: 100%;
  padding: 0 5%;
  /* gap: 5%; */
}

.category {
  position: relative;
  padding: 30px;
  /* background-color: rgba(255, 255, 255, 0.05); */
  height: 60vh;
  overflow: hidden;
  align-items: center;
  width: 100%;
}

.tech-list {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: "Oswald", sans-serif;
  font-size: 80%;
  text-transform: uppercase;
  color: #666;
  cursor: context-menu;
}
#techList {
  left: -3vh;
}
#languageList {
  left: 8vh;
}

#frameworkList {
  top: 0;
  left: -1vh;
}

.category-title {
  font-family: "Space Mono", monospace;
  position: relative;
  text-align: center;
  top: 1vh;
  font-size: 2.5em;
  font-weight: 700;
  letter-spacing: -0.05em;
  color: #ee5d29;
  text-transform: uppercase;
  z-index: 2;
  height: 5vh;
}

.tech-list li {
  position: absolute;
  /* top: 5vh; */
  left: 0;
  transition: color 0.3s ease;
}

/* Software items */
.maya {
  font-weight: 600;
  letter-spacing: -0.05em;
  -webkit-transform: scale(7.5, 7.8) translate(0.9em, 0.68em);
  -moz-transform: scale(7.5, 7.8) translate(1.18em, 0.68em);
  transform: scale(7.5, 7.8) translate(0.9em, 0.68em);
}

.maya:hover {
  color: #248fdc;
}

.houdini {
  letter-spacing: 0.18em;
  font-weight: 1000;
  -webkit-transform: scale(2.8) rotate(90deg) translate(3.1em, -5.25em);
  -moz-transform: scale(1.4) rotate(90deg) translate(3.88em, -13.2em);
  transform: scale(2.8) rotate(90deg) translate(3.1em, -5.25em);
}

.houdini:hover {
  color: #e47c15;
}

.photoshop {
  letter-spacing: -0.01em;
  font-weight: 500;
  -webkit-transform: scale(2.8, 4) rotate(90deg) translate(4.6em, -10.6em);
  -moz-transform: scale(1.4, 1.33) rotate(90deg) translate(4.1em, 1em);
  transform: scale(4, 3.5) rotate(90deg) translate(4.9em, -7.45em);
}

.photoshop:hover {
  color: #23bdf5;
}

.substancepainter {
  font-weight: 300;
  letter-spacing: 0.05em;
  word-spacing: 0.3em;
  -webkit-transform: scale(2.25) translate(2.5em, 7.25em);
  -moz-transform: scale(2) translate(2.12em, 5.14em);
  transform: scale(2.25) translate(2.5em, 7.25em);
}

.substancepainter:hover {
  color: #61c21b;
}

.equalizer {
  letter-spacing: -0.01em;
  font-weight: 700;
  -webkit-transform: scale(3.5, 2.5) rotate(90deg) translate(6.5em, -5.05em);
  -moz-transform: scale(2.4, 2.3) rotate(90deg) translate(6em, -5.8em);
  transform: scale(3.5, 2.5) rotate(90deg) translate(6.45em, -5.05em);
}

.equalizer:hover {
  color: #ddd9c8;
}

.nuke {
  letter-spacing: 0.01em;
  font-weight: 700;
  -webkit-transform: scale(6.8, 6.75) rotate(90deg) translate(1.4em, -5.24em);
  -moz-transform: scale(6.8, 6.75) rotate(90deg) translate(1.32em, -4.54em);
  transform: scale(6.8, 6.75) rotate(90deg) translate(1.4em, -5.24em);
}

.nuke:hover {
  color: #f3af1c;
}

.katana {
  letter-spacing: 0.14em;
  font-weight: 1000;
  -webkit-transform: scale(3.88, 3.8) translate(1.62em, 3.42em);
  -moz-transform: scale(3.88, 3.8) translate(5.42em, 3.72em);
  transform: scale(3.88, 3.8) translate(1.62em, 3.42em);
}

.katana:hover {
  color: #efde1e;
}

.unrealengine {
  font-weight: 700;
  letter-spacing: 0.01em;
  -webkit-transform: scale(2.3, 2.2) translate(2em, 4.6em);
  -moz-transform: scale(1.85, 1.9) translate(1.86em, 6.5em);
  transform: scale(2.3, 2.2) translate(2em, 4.6em);
}

.unrealengine:hover {
  color: #a8a29c;
}

.blender {
  font-weight: 300;
  letter-spacing: -0.08em;
  -webkit-transform: scale(3, 6) translate(8.2em, 1.95em);
  -moz-transform: scale(2.75, 3) translate(1.72em, 4.95em);
  transform: scale(3, 6) translate(8.2em, 1.95em);
}

.blender:hover {
  color: #f98100;
}

.hiero {
  font-weight: 700;
  letter-spacing: 0.1em;
  -webkit-transform: scale(5, 8) translate(4.9em, 0.65em);
  -moz-transform: scale(3.9, 4) translate(6.05em, 0.95em);
  transform: scale(5, 8) translate(4.9em, 0.65em);
}

.hiero:hover {
  color: #e9c01b;
}

.deadline {
  font-weight: 500;
  letter-spacing: 0em;
  word-spacing: 0.1em;
  -webkit-transform: scale(3, 6) translate(1.4em, 3.35em);
  -moz-transform: scale(2) translate(12.7em, 8.6em);
  transform: scale(2.3, 4) translate(10.55em, 4.05em);
}

.deadline:hover {
  color: #e5722b;
}

/* Languages items */
.python {
  font-weight: 700;
  letter-spacing: 0.02em;
  -webkit-transform: scale(6, 6) translate(1.4em, 0.8em);
  -moz-transform: scale(6, 6) translate(1.2em, 0.8em);
  transform: scale(6, 6) translate(1.4em, 0.8em);
}

.python:hover {
  color: #306998;
}

.javascript {
  font-weight: 600;
  letter-spacing: -0.01em;
  -webkit-transform: scale(3, 3) translate(0.5em, 5em);
  -moz-transform: scale(3, 3) translate(0.5em, 5em);
  transform: scale(3, 3) rotate(90deg) translate(3.2em, -6.5em);
}

.javascript:hover {
  color: #f7df1e;
}

.html {
  font-weight: 700;
  letter-spacing: 0.01em;
  -webkit-transform: scale(4, 4) translate(3.9em, 3.3em);
  -moz-transform: scale(4, 4) translate(3.9em, 3.3em);
  transform: scale(4, 4) translate(3.9em, 3.5em);
}

.html:hover {
  color: #e34c26;
}

.css {
  font-weight: 500;
  letter-spacing: 0.1em;
  -webkit-transform: scale(5, 5) translate(2.6em, 1.8em);
  -moz-transform: scale(5, 5) translate(2.6em, 1.8em);
  transform: scale(5, 5) translate(3em, 2em);
}

.css:hover {
  color: #264de4;
}

.mel {
  font-weight: 600;
  letter-spacing: 0.05em;
  -webkit-transform: scale(7, 7) translate(1.3em, 1.3em);
  -moz-transform: scale(7, 7) translate(1.3em, 1.3em);
  transform: scale(7, 7) translate(0.73em, 1.5em);
}

.mel:hover {
  color: #8e44ad;
}

/* Framework & Pipeline items */
.shotgrid {
  font-weight: 700;
  letter-spacing: 0.06em;
  -webkit-transform: scale(4.5, 4.5) translate(0.9em, 1.2em);
  -moz-transform: scale(4.5, 4.5) translate(0.9em, 1.2em);
  transform: scale(3, 5) translate(8.9em, 1.15em);
}

.shotgrid:hover {
  color: #0ea8eb;
}

.ftrack {
  font-weight: 600;
  letter-spacing: -0.01em;
  -webkit-transform: scale(6, 6) translate(1.5em, 1.7em);
  -moz-transform: scale(6, 6) translate(1.5em, 1.7em);
  transform: scale(6, 6) translate(1.2em, 1em);
}

.ftrack:hover {
  color: #8d34e0;
}

.git {
  font-weight: 1000;
  letter-spacing: -0.01em;
  -webkit-transform: scale(8, 8) translate(1.1em, 0.7em);
  -moz-transform: scale(8, 8) translate(1.1em, 0.7em);
  transform: scale(5, 5) rotate(90deg) translate(2.45em, -3.05em);
}

.git:hover {
  color: #f05033;
}

.usd {
  font-weight: 1000;
  letter-spacing: 0.01em;
  -webkit-transform: scale(5, 5) translate(2.6em, 1.8em);
  -moz-transform: scale(5, 5) translate(2.6em, 1.8em);
  transform: scale(4.5, 4.3) translate(3.1em, 4.05em);
}

.usd:hover {
  color: #4c9ef1;
}

.qt {
  font-weight: 600;
  letter-spacing: 0.05em;
  /* word-spacing: -0.3em; */
  -webkit-transform: scale(3, 3) translate(3.3em, 3.5em);
  -moz-transform: scale(3, 3) translate(3.3em, 3.5em);
  transform: scale(3.15, 4) translate(2.2em, 5.3em);
}

.qt:hover {
  color: #41cd52;
}

.vue {
  font-weight: 500;
  letter-spacing: -0.01em;
  -webkit-transform: scale(5.8, 5.8) translate(1.6em, 1.5em);
  -moz-transform: scale(5.8, 5.8) translate(1.6em, 1.5em);
  transform: scale(5.8, 7) translate(0.9em, 1.7em);
}

.vue:hover {
  color: #42b883;
}

.ffmpeg {
  font-weight: 100;
  letter-spacing: -0.03em;
  -webkit-transform: scale(4.2, 4.2) translate(0.8em, 3.3em);
  -moz-transform: scale(4.2, 4.2) translate(0.8em, 3.3em);
  transform: scale(4.2, 4.2) translate(0.9em, 4.1em);
}

.ffmpeg:hover {
  color: #007808;
}

.mattermost {
  font-weight: 300;
  letter-spacing: 0.01em;
  -webkit-transform: scale(2.5, 2.5) translate(2.2em, 4.8em);
  -moz-transform: scale(2.5, 2.5) translate(2.2em, 4.8em);
  transform: scale(5, 4) rotate(90deg) translate(4.6em, -4.4em);
}

.mattermost:hover {
  color: #0072c6;
}

.openexr {
  font-weight: 400;
  letter-spacing: 0.1em;
  -webkit-transform: scale(3.5, 3.5) translate(3.5em, 1.2em);
  -moz-transform: scale(3.5, 3.5) translate(3.5em, 1.2em);
  transform: scale(3.5, 4) rotate(90deg) translate(2.93em, -5.23em);
}

.openexr:hover {
  color: #b3b3b3;
}

.oiio {
  font-weight: 800;
  letter-spacing: -0.05em;
  -webkit-transform: scale(6.5, 6.5) translate(1.2em, 2.5em);
  -moz-transform: scale(6.5, 6.5) translate(1.2em, 2.5em);
  transform: scale(6.5, 7.5) translate(4.75em, 1.5em);
}

.oiio:hover {
  color: #e67e22;
}

/* Mobile responsive styles */
@media (max-width: 768px) {
  #tech {
    height: 100vh;
    overflow: hidden;
    padding: 0;
    margin: 0;
  }

  .tech-container {
    height: auto;
    overflow-y: auto;
  }

  .tech-caption {
    font-size: 1rem;
    text-align: center;
    margin-bottom: 0.5rem;
    padding: 0 10px;
    line-height: 1.3;
  }

  .category-container {
    flex-direction: column;
    padding: 0;
    height: auto;
    gap: 0.5rem;
  }

  .category {
    padding: 10px 5px;
    height: auto;
    min-height: 20vh;
    margin-bottom: 0.5rem;
  }

  .category-title {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
    height: auto;
    padding-bottom: 0.25rem;
  }

  /* Adjust tech list items scaling and positioning for mobile */
  .tech-list li {
    transform: scale(1) !important;
    position: relative !important;
    display: inline-block !important;
    margin: 3px 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    padding: 3px 6px !important;
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: 3px;
    transition: color 0.3s ease, transform 0.3s ease, background-color 0.3s ease !important;
  }

  .tech-list li:hover {
    transform: scale(1.1) !important;
    background-color: rgba(255, 255, 255, 0.1);
  }

  .tech-list {
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 0;
  }

  #techList,
  #languageList,
  #frameworkList {
    left: 0 !important;
    position: static !important;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .tech-container h1 {
    font-size: 2rem;
    /* margin-top: 1rem; */
  }

  .tech-caption {
    font-size: 0.7rem;
    margin-bottom: 1rem;
    padding: 0 5px;
  }

  .category-title {
    font-size: 1.3rem;
  }

  .tech-list li {
    margin: 2px 3px !important;
    font-size: 12px !important;
    padding: 2px 4px !important;
  }

  .category {
    min-height: 15vh;
    margin: 0;
    padding: 5px 2px;
  }
}
