* {
  box-sizing: border-box;
}

a {
  /* text-decoration: none; */
  color: black; 

  background:
  linear-gradient(
    to right,
    rgb(255, 255, 255),
    rgba(100, 200, 200, 1)
  ),
  linear-gradient(
    to right,
    rgb(255, 255, 255),
    rgb(59, 162, 157),
    rgb(255, 255, 255)
  );
  background-size: 100% 3px, 0 3px;
  background-position: 100% 100%, 0 100%;
  background-repeat: no-repeat;
  transition: background-size 400ms;
}

a:hover {
  background-size: 0 3px, 100% 3px;
}

.applink {
  color: black;
}

.app_link_api_div {
  font-family: 'Courier New', Courier, monospace;
  letter-spacing: 0px;
  color: black;
  background-color: white;
  border: 1px solid;
  padding: 10px;
  border-color:#000000;
  max-width: 700px;
}

.app_link_app_div {
  font-family: 'Courier New', Courier, monospace;
  letter-spacing: 0px;
  color: black;
  background-color: white;
  border: 1px solid;
  padding: 10px;
  border-color:#000000;
  max-width: 700px;
  }

.app_link_app_algo_1 {
  font-family: 'Courier New', Courier, monospace;
  letter-spacing: 0px;
  color: black;
  background-color:white;
  border: 1px solid;
  padding: 10px;
  border-color:#000000;
  max-width: 900px;
  }

/* .app_link_app_algo_inner {
  overflow-x: auto;
  padding: 20px;
  background-color: rgb(242, 251, 253);
  border: none;
} */

/* email button */
.emailbtn-style {
  /* text-decoration: none; */
  color: rgb(0, 0, 0); 
}

.emailbtn-style:hover {
  background-size: 0 3px, 100% 3px;
}

 #btn {
  border-color: #1134f7;
  background-color: white;
  padding-bottom: 3px;
} 

.wrapper {
  margin-left: 1rem;
  border-radius: 5px;
} 

/* expertise/specialization */
.content-describe{
  height: auto; 
  max-height: 1000px; 
  padding: 0;
  color: #000000;
  background-color: white;
  overflow: hidden;
  transition-property: opacity, max-height;
  transition-duration: 1s, 0.5s;
}

.activator {
  color: #1134f7;
  cursor: pointer;
  padding: .5em;
}

.block {
  display: block;
  margin: 0.5em;
  padding: 0.5em;
  border-radius: 5px;
}

/* details */
.wrapper .activator:after {
  content: "🌿";
  height: 1em;
  width: 1em;
  display: inline-block;

  transition: transform 0.3s linear;
}

.wrapper.collapsed .activator:after {
  transform: rotate(-0.25turn);
}

.wrapper.collapsed .content-describe{
  max-height: 0;
  opacity: 0;
}

body {
  background: 
  linear-gradient(100deg,white, #d8fde2a5,white, #caf6f298 ,white , #ebedfd,#cceeff70,white, #c7f7dcb1),
  linear-gradient(100deg, rgba(238, 235, 220, 0.8), rgba(228, 13, 21, 0) 40.71%), 
  linear-gradient(217deg, rgb(255, 255, 255), rgba(228, 13, 21, 0) 70.71%),
  linear-gradient(127deg, rgba(190, 255, 251, 0.684), rgba(174, 106, 60, 0) 70.71%),
  linear-gradient(300deg, rgba(169, 169, 169, 0.8), rgba(163, 60, 174, 0) 70.71%);

  /* background-color:white;
  background:
  linear-gradient(100deg, rgba(238, 235, 220, 0.8), rgba(228, 13, 21, 0) 40.71%), 
  linear-gradient(217deg, rgb(255, 255, 255), rgba(228, 13, 21, 0) 70.71%),
  linear-gradient(127deg, rgba(20, 250, 235, 0.684), rgba(174, 106, 60, 0) 70.71%),
  linear-gradient(300deg, rgba(169, 169, 169, 0.8), rgba(163, 60, 174, 0) 70.71%);
  color: rgb(255, 255, 255); */
  background-size: 600% 100%;
  animation: gradient 16s linear infinite;
  animation-direction: alternate;
  padding: 0;
  margin: 0;
  line-height: 1.5;
}

@keyframes gradient {
  0% {background-position: 0%}
  100% {background-position: 100%}
}

header {
    display:flex;
    text-align: center;
    color: whitesmoke;
    padding: 20px;
    justify-content: space-between;
    list-style: none;
    text-decoration: none;
}

@media screen and (max-width: 800px) {
  html, body {
    overflow-x: hidden;
  }
}

/* time-line */
.timeline-container {
  padding: 2rem;
  padding-bottom: 400px;
  margin: 0 auto;
  max-width: 800px;
  color: black;
}

.top-left {
  text-align: center;
  padding: 4rem 0;
  max-width: 600px;
  margin: 0 auto;
}

.top-left h1 {
  font-family: 'Courier New', Courier, monospace;
}

.timeline-line {
  position: relative;
  min-height: 150px;
}

.line{
  position: absolute;
  left: calc(50% - 1px);
  width: 2px;
  top: -50px;
  bottom: -50px;
  background-color: #000;
  display: none;
}

.line:before,
.line:after{
  position: absolute;
  display: block;
  content: '';
  height: 1rem;
  width: 1rem;
  border-radius: 50%;
  background-color: #000;
  left: 50%;
  transform: translateX(-50%)
}

.line:after{
  bottom: 0;
}

.section{
  display: flex;
  opacity: 0;
  transform: translateX(-100%);
  transition: 600ms ease;
  position: relative;
  margin: 50px 0;
  padding: 1rem;
  border-radius: 1rem;
  align-items:center;
  min-height: 300px;
}

.section:nth-child(odd){
  flex-direction: row-reverse;
  transform: translateX(100%);
}

.dash{
  position:absolute;
  display: block;
  height: 1rem;
  width: 1rem;
  border-radius: 50%;
  background-color: #000;
  left: 50%;
  top: 20%;
  transform: translateX(-50%);
}

.main-description {
  font-family: 'Courier New', Courier, monospace;
  letter-spacing: 0px;
  color: black;
  background-color: white;
  border: 1px solid;
  padding: 10px;
  border-color:#000000;
  max-width: 700px;
}

.description {
  background-color: white;
  color: black;
  border: 1px solid;
  padding: 10px;
  border-color:#000000;
  max-width: 300px;
}

content {
  width: calc(50% - 2rem);
}

.show-me:nth-child(n){
  transform: none;
  opacity: 1;
}

h1 {
  letter-spacing: 1px;
}

h2 {
  background-color: white;
  
  font-family: 'Titillium Web';
  color: rgb(255, 255, 255);
  text-shadow:
      0 0 7px rgb(107, 107, 107),
      00 0 20px rgb(90, 90, 90),
      0 0 21px #fff,
      0 0 42px rgb(0, 191, 255),
      0 0 82px rgb(0, 47, 255),
      0 0 92px rgb(255, 255, 255),
      0 0 102px rgb(255, 0, 123),
      0 0 151px rgb(255, 0, 140);
}

.timeline-container h1 {
  font-size: 22px;
}

.hamburger-button {
  display: none;
}

.menu-icon {
    width: 100px;
    height: 100px;
    background: linear-gradient(
      165deg,
      rgba(255, 255, 255, 1) 0%,
      rgb(35, 25, 235) 40%,
      rgb(58, 206, 179) 98%,
      rgb(239, 240, 245) 100%
    );
    border-radius: 50%;
    position:relative;
  }

  .menu-icon:before {
    margin: -15px;
    padding: 8px;
    position: absolute;
    content: '';
    width: 20%;
    height:20%;
    border-radius: 100%;
    border-bottom: 0 solid #9af7e3e9;
    box-shadow: 0 -10px 20px 20px #ffffff inset,
      0 -10px 20px 10px #3cf5a5 inset, 0 -2px 5px #87c9a5f0 inset,
      0 -1px 1px #30ff86f1 inset, 0 2px 0px #ffffff, 0 2px 3px #ffffff,
      0 1px 1px #d9c8ecec, 0 10px 15px #ba63f0ef, 0 10px 20px 20px #7ef8bb65;
    filter: blur(3px) drop-shadow(16px 16px 20px #11f7c9) ;
    animation: 3s rotate linear infinite;
  }
  @keyframes rotate {
    100% { transform: rotate(360deg) }
  }


.ul-nav, a#open_to_work {
    margin-inline-end: 0.75em;
    list-style: none;
    justify-content: center;
    color: #5ad5a6;
    font-family: "poppins", sans-serif;
    text-decoration: none;
    text-align: right;
    transition: all 0.3s ease 0s;
} 

.ul-nav[data-visible="true"] {
  transform: translateX(0%);
  z-index: 1;
}

/* mobile ////////////////////////////////////////////////////////*/
@media (max-width: 35em) {

  h2 {
    text-align: center;
  }

  .ul-nav {
    text-align: left;
    position: fixed;
    inset: 0 0 0 30%;
    padding: 14rem 5rem;
    
    -webkit-backdrop-filter: blur(10px);
    background: rgba(88, 98, 174, 0.185);
    backdrop-filter: blur(1rem);

    transform: translateX(100%);
    
    
    @supports (backdrop-filter: blur(1rem)) {
      .ul-nav {
        background: rgba(88, 98, 174, 0.185);
        backdrop-filter: blur(1rem);
      }
    }

  }

  .hamburger-button {
    display: none;
  }
  
  .menu-icon {
      width: 100px;
      height: 100px;
      background: linear-gradient(
        165deg,
        rgba(255, 255, 255, 1) 0%,
        rgb(35, 25, 235) 40%,
        rgb(58, 206, 179) 98%,
        rgb(239, 240, 245) 100%
      );
      border-radius: 50%;
      position:relative;
    }
  
    .menu-icon:before {
      margin: -15px;
      padding: 8px;
      position: absolute;
      content: '';
      width: 20%;
      height:20%;
      border-radius: 100%;
      border-bottom: 0 solid #9af7e3e9;
      box-shadow: 0 -10px 20px 20px #ffffff inset,
        0 -10px 20px 10px #3cf5a5 inset, 0 -2px 5px #87c9a5f0 inset,
        0 -1px 1px #30ff86f1 inset, 0 2px 0px #ffffff, 0 2px 3px #ffffff,
        0 1px 1px #d9c8ecec, 0 10px 15px #ba63f0ef, 0 10px 20px 20px #7ef8bb65;
      filter: blur(3px) drop-shadow(16px 16px 20px #11f7c9) ;
      animation: 3s rotate linear infinite;
    }
    @keyframes rotate {
      100% { transform: rotate(360deg) }
    }

  .hamburger-button {
    display: block;
    position: absolute;
    border-radius: 100%;
    border-color: white;
    aspect-ratio: 1;
    box-shadow:
    0 0 10px 9px rgb(255, 255, 255),
    0 0 60px 20px rgb(6, 245, 201),
    0 0 50px 11px rgb(205, 183, 87);
    filter: drop-shadow(16px 16px 70px #11f7c9) ;
    top: 2rem;
    right: 2rem;
    z-index: 3;
  }

  .hamburger-button:before {
    display: block;
    position: absolute;
    box-shadow: 0 -10px 20px 20px #ffffff inset,
      0 -10px 20px 10px #3cf5a5 inset, 0 -2px 5px #87c9a5f0 inset,
      0 -1px 1px #30ff86f1 inset, 0 2px 0px #ffffff, 0 2px 3px #ffffff,
      0 1px 1px #c8ecdaec, 0 10px 15px #f0ca63ef, 0 10px 20px 20px #7ef8bb65;
    filter: blur(3px) drop-shadow(16px 16px 20px rgb(17, 228, 247)) ;
    animation: 3s rotate linear infinite;
  }
  @keyframes rotate {
    100% { transform: rotate(360deg) }
  }

  .hamburger-button[aria-expanded="true"] {
    box-shadow: 0 -10px 20px 20px #faf7f7 inset,
    0 0px 20px 20px #06f28865;
    filter: blur(2px) drop-shadow(30px -9px 30px #f4f2f5) ;
    z-index: 100;
  }  

  .hamburger-button[aria-expanded="true"]:hover {
    box-shadow: 0 -1px 20px 10px #08ebc9 inset,
    0 0px 20px 20px #fcfbf9,
    0 0px 20px 20px hsl(51, 75%, 53%);
    filter: blur(2px) drop-shadow(30px -9px 30px #f4f2f5) ;
    
  } 
}
/* mobile ////////////////////////////////////////////////////////*/

.ul-nav, a#blog:hover {
    color: aquamarine;
}
.ul-nav, a#creations:hover {
    color: lightgreen
}
.ul-nav, a#bio:hover {
    color: cyan
}

.hamburger-button:hover {
  background-color: #5ac396;
  filter: drop-shadow(16px 16px 20px #1134f7) ;
}

.parent-container {
    width: 90%;
    margin: auto;
    padding: 10px;
}

.title-container {
    display: inline-block;
}

.title {
    text-align: center;
    color: black;
    font-family: poppins;
    overflow: hidden;
    border-right: .15em solid black;
    white-space: nowrap;
    animation: 
    typing 1s steps(20, end) forwards;
    font-size: 1.6rem;
    width: 0;
}
@keyframes typing {
    from { width: 0 }
    to { width: 100% }
  }


.fetchQuotes {
    text-align: center;
    border: 1px solid 63c595;
    color: black;
    padding: 10px;
    margin: 10px;
    font-family: "poppins", sans-serif;
    animation: 1s ease-out 0s 1 slideInFromLeft;
}  
@keyframes slideInFromLeft {
    0% {
      transform: translateX(-100%);
    }
    100% {
      transform: translateX(0);
    }
  }

input {
  font-family: "Poppins", sans-serif;
  background-color: #002930;
  border: 1px #172920 solid; 
  color:#93344c;
}

input:hover {
    background-color:#003640 ;
}

.sun-moon{
color: black;
cursor: pointer;
}

.sun-moon:hover{
color: rgb(163, 195, 255);
cursor: pointer;
}

.sun-moon.active{
  color: yellow;
  }

@media screen and (max-width: 35em) {
  .sun-moon  {
    color: black;
    cursor: pointer;
    margin: 0 4rem;
    }
    
  .sun-moon:hover  {
    color: white;
    cursor: pointer;
    }

  .sun-moon.active {
    color: rgb(0, 0, 131);
    cursor: pointer;
    }
    
  .appImg {
    width: 100%;
    height: auto;
  } 

}

.algo_description {
  background-color: white;
  margin: 13px;
}

#buttons {
display: flex;
list-style: none;
}

/* language algo toggling */
#javaScript_button {
  background-color: white;
  border-style: solid;
  border-color: #1134f7;
  color:black;
  border-width: 1px;
  padding: 7px;
  margin: 5px;
  font-family: "poppins", sans-serif;
  font-size: 13px;
}

#java_button {
  background-color: white;
  border-style: solid;
  border-color: #1134f7;
  color:black;
  border-width: 1px;
  padding: 7px;
  margin: 5px;
  font-family: "poppins", sans-serif;
  font-size: 13px;
} 

#python_button {
  background-color: white;
  border-style: solid;
  border-color: #1134f7;
  color:black;
  border-width: 1px;
  padding: 7px;
  margin: 5px;
  font-family: "poppins", sans-serif;
  font-size: 13px;
}

.language_button_style {
  text-decoration: none;
  color: rgb(0, 0, 0); 

  background:
    linear-gradient(
      to right,
      rgb(255, 255, 255),
      rgba(100, 200, 200, 1)
    ),
    linear-gradient(
      to right,
      rgb(255, 255, 255),
      rgb(59, 162, 157),
      rgb(255, 255, 255)
  );
  background-size: 100% 3px, 0 3px;
  background-position: 100% 100%, 0 100%;
  background-repeat: no-repeat;
  transition: background-size 400ms;
  
} 

.language_button_style:hover {
  background-size: 0 3px, 100% 3px;
  
}

.js_java {
  overflow-x: auto;
  background-color: mintcream;
  margin: 1px;
  padding: 13px;
}
/* language algo toggling */




/* link loader */

/* #spinner {
  display: none;
} */


/* .loader {
  top: 50%;
  left: 50%;
  position: absolute;
  transform: translate(-50%, -50%);
} */

/* .loading {
  border: 2px solid #ccc;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border-top-color: #1ecd97;
  border-left-color: #1ecd97;
  animation: spin 1s infinite ease-in;
} */

/* .loadingDiv {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f7f9fb89;
  transition: opacity 0.75s, visibility 0.75s;
}

.loadingDiv::after {
  content: "";
  width: 60px;
  height: 60px;
  border: 15px solid #dddddd;
  border-top-color: #1ecd97;
  border-radius: 50%;
  animation: loading 0.75s ease infinite;
} */

.loadingDiv {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f7f9fb89;
}

.loadingDiv::after {
  content: "";
  width: 60px;
  height: 60px;
  /* border: 15px solid #dddddd; */
  /* border-top-color: #1ecd97; */
  border-radius: 50%;
  box-shadow: 10px 1px 20px 1px rgb(126, 238, 171);
  animation: loading 0.75s ease infinite;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f7f9fb89;
  transition: opacity 0.75s, visibility 0.75s;
}

.loading-hidden {
  opacity: 0;
  visibility: hidden;
}

.loading::after {
  content: "";
  width: 60px;
  height: 60px;
  border: 15px solid #dddddd;
  border-top-color: #1ecd97;
  border-radius: 50%;
  animation: loading 0.75s ease infinite;
}

@keyframes loading {
  from {
    transform: rotate(0turn);
  }

  to {
    transform: rotate(1turn);
  }
}

  /* language buttons*/
#javaScript_info {
  background-color: white;
  border:1px solid #1134f7;

  padding: 10px;
  text-decoration: none;
}

#java_info {
  background-color:white;
  border:1px solid #1134f7;

  padding: 10px;
  text-decoration: none;
}

#python_info {
  background-color:white;
  border:1px solid #1134f7;

  padding: 10px;
  text-decoration: none;
}

.audio_container {
  display: flex;
  justify-content: center;
  align-items: center;
  width:100%;
}
#audioPlay {
  width:100%;
}

.audio-footer {
  background-color: #000;
  /* padding: 30px; */
  position: fixed;
  left: 0;
  bottom: 0;
  /* height: 5vh; */
  width: 100%;
}

.creators {
  background-color: white;
  border:1px solid #1134f7;
  padding: 8px;
  margin: 5px;
  text-decoration: none;
}

.creators_container{
  display: flex;
  justify-content: center;
  margin: 5px;
  padding: 1px;
}

#creators_meta {
  background-color: white;
  border:1px solid #1134f7;
  padding: 4px;
  margin: 5px;
  text-decoration: none;
}

.tech_line_break {
  margin: 10px;
}

@media screen and (max-width: 800px) {
  #creators_meta {
    background-color: rgb(255, 255, 255);
    border:1px solid #1134f7;
    padding: 4px;
    margin: 5px;
    text-decoration: none;
  }

  .tech_line_break {
    margin: 10px;
  }
}

.gradientWrapper {
  width: 100%;
  height: 100%;
  position: absolute;
  background: linear-gradient(45deg,#F17C58, #E94584, #24AADB , #27DBB1,#FFDC18, #FF3706);
  background-size: 600% 100%;
  animation: gradient 16s linear infinite;
  animation-direction: alternate;
}
@keyframes gradient {
  0% {background-position: 0%}
  100% {background-position: 100%}
}

