body, html {
  overflow-x: hidden; /* avoid horizontal scroll issues */
}

.float-div{
  z-index: 999;
  position: fixed;
  top: 5em;
  right: 1em;
}

  .dark-mode {
  background-color: black;
  color: white;
  font-family: "IBM Plex Mono", monospace;
  font-weight: 400;
  font-style: arial;

}

.light-mode {
  body, .unslate_co--site-inner, div.portfolio-single-inner span.detail-label, div.portfolio-single-inner span.detail-val, div.portfolio-single-inner span.detail-val a
    {
    color: black;
    background-color: white;
      font-family: "IBM Plex Mono", monospace;
      font-weight: 400;
      font-style: arial;
  }
  .testimonial-inner-bg
  {
    color: white;
  }
  }
#hoverText {
    position: absolute;
    top: 0;
    left: 0;
    padding: 5px 10px;
    font-size: 18px;
    font-family: "IBM Plex Mono", monospace;
    font-weight: bold;
    background-color: rgba(0, 0, 0, 0.8);
    color: white;
    border-radius: 5px;
    pointer-events: none; /* So it doesn't interfere with mouse events */
    white-space: nowrap; /* Ensure text stays on one line */
}

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap');

.ibm-plex-mono-thin {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 100;
  font-style: normal;
}

.ibm-plex-mono-extralight {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 200;
  font-style: normal;
}

.ibm-plex-mono-light {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 300;
  font-style: normal;
}

.ibm-plex-mono-regular {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 400;
  font-style: normal;
}

.ibm-plex-mono-medium {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 500;
  font-style: normal;
}

.ibm-plex-mono-semibold {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 600;
  font-style: normal;
}

.ibm-plex-mono-bold {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 700;
  font-style: normal;
}

.ibm-plex-mono-thin-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 100;
  font-style: italic;
}

.ibm-plex-mono-extralight-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 200;
  font-style: italic;
}

.ibm-plex-mono-light-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 300;
  font-style: italic;
}

.ibm-plex-mono-regular-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 400;
  font-style: italic;
}

.ibm-plex-mono-medium-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 500;
  font-style: italic;
}

.ibm-plex-mono-semibold-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 600;
  font-style: italic;
}

.ibm-plex-mono-bold-italic {
  font-family: "IBM Plex Mono", monospace;
  font-weight: 700;
  font-style: italic;
}


.h1 { 
  
  margin: 0;
  height: 100%;
  overflow: hidden;
  font-family: 'Roboto' !important; 
  color: white;
  font-size: 3.5rem;
}


#magic {

  position: fixed;
  width: 100%;
  height: 100vh;
  display: block;
  top: 0;
  left: 0;
  z-index: -9999;
}

.playground{

  position: fixed;
  width: 100%;
  height: 100vh;
  display: block;
  top: 0;
  left: 0;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
}
.bottomPosition{

  text-align: center;
  margin-bottom: 50px;
  
}
.special{
  font-size: 2em;

}
.minText{
  
  font-size: 17px;
}


.logo {
    width: 50px;
    height: 50px;
}



* {
  box-sizing: border-box;
  cursor: none;
}

.nav-title {
  font-size: 4em;
}

.white, a.white {
  color: #efefef;
}


.bg-green {
  background-color: #00BCD4;
}

.bg-topographic {
  background-image: url(https://assets.codepen.io/319606/bg-topographic.svg);
  background-size: 5000px;
  opacity: 0.1;
  pointer-events: none;
}

.custom-cursor {
  position: fixed;
  opacity: 0;
  pointer-events: none;
  mix-blend-mode: difference;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #00BCD4;
  transition: transform 350ms ease;
  transform: translate(-50%, -50%) scale(0.3);
  z-index: 99995;
}

.custom-cursor--link {
  transform: translate(-50%, -50%) scale(1.5);
}



.sticky-nav {
  top: 20px;
  left: 20px;
  position: fixed;
  width: calc(100% - 40px);
  z-index: 999;
}
.sticky-nav.difference {
  background-repeat: no-repeat;
  background-size: contain;
  mix-blend-mode: difference;
}
.sticky-nav.difference #nav-btn {
  filter: invert(0);
}

.sticky-nav #nav-btn {
  width: 60px;
  z-index: 999;
  filter: invert(1);
}
.sticky-nav #nav-btn .icon {
  position: relative;
  width: 100%;
  height: 100%;
  fill: none;
  stroke-width: 8;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: #fff;
}

/* replace the above: starting from 'stroke: #fff;'

-webkit-animation-name: blackWhite;  
-webkit-animation-iteration-count: infinite;  
-webkit-animation-duration: 2s; 


}

@-webkit-keyframes blackWhite {  
 0% { stroke: white; }
 50% { stroke: red; }
 51% { stroke: orange; }
 100% { stroke: grey; }
}

*/

#takeover-nav {
  position: fixed;
  width: 100vw;
  height: 100vh;
  overflow-y: auto;
  left: 0;
  top: -200%;
  transition: all 0.5s ease-in-out;
  z-index: 996;
  background: black;
}
#takeover-nav.shown {
  top: 0;
}
#takeover-nav .nav-col {
  min-height: 100vh;
}
#takeover-nav .nav-col a {
  color: #efefef;
}
#takeover-nav .nav-col a:hover {
  color: #212121;
}
#takeover-nav .nav-contact .content {
  max-width: 700px;
}
#takeover-nav .nav-items {
  font-size: 2.5em;
  font-weight: 700;
}
#takeover-nav .contact-items {
  font-size: 1.25em;
  font-weight: 700;
}
#takeover-nav .contact-items a:hover {
  color: #00BCD4;
}
#takeover-nav .social {
  font-size: 0.85em;
}
#takeover-nav .social a {
  color: #00BCD4;
}
#takeover-nav .social a:hover {
  color: #efefef;
}

@media only screen and (max-width: 768px) {
.bottomPosition{

  text-align: center;
  margin-bottom: 120px;
  
}
.special{
  font-size: 1.3em;

}
.minText{
  
  font-size: 14px;
}
}


/*
.gradient-overlay {
  bottom: 0;
  height: 50%;
  background: -moz-linear-gradient(top, rgba(33, 33, 33, 0) 0%, #212121 50%);
  background: -webkit-linear-gradient(top, rgba(33, 33, 33, 0) 0%, #212121 50%);
  background: linear-gradient(to bottom, rgba(33, 33, 33, 0) 0%, #212121 50%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#00212121", endColorstr="#212121",GradientType=0 );
  z-index: 1;
  border-bottom-right-radius: 15vw;
  pointer-events: none;
}

*/

.niki{
  padding-bottom: -50px !important;
  margin-bottom: -50px !important;
}

.center-image{
    display: block;
    margin-left: auto;
    margin-right: auto;


}




/*
SYLIZE LIGHT DARK MODE BUTTON
SYLIZE LIGHT DARK MODE BUTTON
SYLIZE LIGHT DARK MODE BUTTON
SYLIZE LIGHT DARK MODE BUTTON
SYLIZE LIGHT DARK MODE BUTTON

*/


.toggle-checkbox {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.toggle-slot {
  position: relative;
  height: 3em;
  width: 6em;
  border: 5px solid #e4e7ec;
  border-radius: 10em;
  background-color: white;
  transition: background-color 250ms;
}

.toggle-checkbox:checked ~ .toggle-slot {
  background-color: #161a20;
}

.toggle-button {
  transform: translate(3.35em, 0.5em);
  position: absolute;
  height: 1.5em;
  width: 1.5em;
  border-radius: 50%;
  background-color: #ffeccf;
  box-shadow: inset 0px 0px 0px 0.25em #ffbb52;
  transition: background-color 250ms, border-color 250ms, transform 500ms cubic-bezier(.26,2,.46,.71);
}

.toggle-checkbox:checked ~ .toggle-slot .toggle-button {
  background-color: #161a20;
  box-shadow: inset 0px 0px 0px 0.25em white;
  transform: translate(0.45em, 0.45em);
}

.sun-icon {
  position: absolute;
  height: 1.8em;
  width: 1.8em;
  color: #ffbb52;
}

.sun-icon-wrapper {
  position: absolute;
  height: 2em;
  width: 2em;
  opacity: 1;
  transform: translate(0.2em, 0.35em) rotate(15deg);
  transform-origin: 50% 50%;
  transition: opacity 150ms, transform 500ms cubic-bezier(.26,2,.46,.71);
}

.toggle-checkbox:checked ~ .toggle-slot .sun-icon-wrapper {
  opacity: 0;
  transform: translate(2em, 2em) rotate(0deg);
}

.moon-icon {
  position: absolute;
  height: 1.8em;
  width: 1.8em;
  color: white;
}

.moon-icon-wrapper {
  position: absolute;
  height: 2em;
  width: 2em;
  opacity: 0;
  transform: translate(1.75em, 0.2em) rotate(15deg);
  transform-origin: 50% 50%;
  transition: opacity 150ms, transform 500ms cubic-bezier(.26,2.5,.46,.71);
}

.toggle-checkbox:checked ~ .toggle-slot .moon-icon-wrapper {
  opacity: 1;
  transform: translate(3.2em, 0.25em) rotate(-15deg);
}