* {
  box-sizing: border-box;
}

a {
  /* text-decoration: none; */
  color: rgb(255, 255, 255); 

  background:
  linear-gradient(
    to right,
    rgba(100, 200, 200, 1),
    rgba(100, 200, 200, 1)
  ),
  linear-gradient(
    to right,
    rgb(0, 255, 191),
    rgb(237, 255, 73),
    rgb(23, 139, 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: white;
}

.app_link_api_div {
  font-family: Arial, Helvetica, sans-serif;
  letter-spacing: 1px;
  color: white;
  background-color: #003640;
  border: 1px solid;
  padding: 10px;
  border-color: #c9ed29;
  max-width: 700px;
}

.app_link_app_div {
  font-family: Arial, Helvetica, sans-serif;
  background-color: #003640;
  letter-spacing: 1px;
  color: white;
  border: 1px solid;
  border-color: #c9ed29;
  padding: 10px;
  max-width: 700px;
}

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

/* .app_link_app_algo_inner {
  overflow-x: auto;
  padding: 20px;
  background-color: #28cd8b58;
  border: 2px solid;
  border-color: rgba(255, 255, 0, 0.508);
} */

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

.emailbtn-style-x {
  text-decoration: none;
  color: rgb(12, 0, 236);
}


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

#btn {
  border-color: #3dffc5;
  background-color: #014333a0;
  padding-bottom: 3px;
}

#btn-x{
  border-color: #3dffc5;
  background-color: #23e1fe;
  padding-bottom: 3px;
}

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

body {
  background: 
    linear-gradient(100deg,rgb(0, 11, 73), #00102ea5,rgb(9, 0, 108), #012e2a98 ,rgb(0, 12, 88) , #000a52,#002d4470,rgb(3, 0, 96), #00431db1),
    linear-gradient(100deg, rgba(144, 120, 0, 0.8), rgba(228, 13, 21, 0) 40.71%), 
    linear-gradient(217deg, rgb(0, 108, 85), 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(28, 0, 89, 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%}
  }

/* expertise/specialization */
.content-describe{
  font-family:'Courier New', Courier, monospace;
  height: auto; 
  max-height: 1000px; 
  padding: 0;
  color: white; 
  overflow: hidden;
  transition-property: opacity, max-height;
  transition-duration: 1s, 0.5s;
}

.activator {
  font-family: Arial, Helvetica, sans-serif;
  color: #ffffff;
  cursor: pointer;
  padding: .5em;
}

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

/* details */
.wrapper .activator:after {
  font-family: Arial, Helvetica, sans-serif;
  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-color:#021163;
  z-index: -3;
  padding: 0;
  margin: 0;
  line-height: 1.5;
}

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;
}

.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: #575656eb;
  display: none;
}

.line:before,
.line:after{
  position: absolute;
  display: block;
  content: '';
  height: 1rem;
  width: 1rem;
  border-radius: 50%;
  background-color: #ffffff;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: rgb(255, 255, 255) 1px 0 20px;

}

.line:after{
  bottom: 0;
  background-color: #ffffff;
  box-shadow: rgb(255, 255, 255) 1px 0 20px;
}

.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: #ffffff ;
  left: 50%;
  top: 20%;
  transform: translateX(-50%);
  box-shadow: rgb(255, 255, 255) 1px 0 20px;
}

.main-description {
  font-family: Arial, Helvetica, sans-serif;
  background-color: #003640;
  letter-spacing: 1px;
  color: white;
  border: 1px solid;
  border-color: #29eda5;
  padding: 10px;
  max-width: 700px;
}

.description {
  font-family: 'Courier New', Courier, monospace;
  background-color: #014e4369;
  color: white;
  border: 1px solid;
  padding: 10px;
  border-color:#29eda5;
  max-width: 300px;
}

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

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

h1 {
  letter-spacing: 1px;
}

h2 {
  background-color: #01224564;

  font-family: 'Titillium Web';
  color: rgba(255, 255, 255, 0.818);
  text-shadow:
    0 0 7px rgba(255, 255, 255, 0.645),
    0 0 10px rgba(255, 255, 255, 0.657),
    0 0 21px #fff,
    0 0 42px rgb(0, 191, 255),
    0 0 82px rgb(0, 47, 255),
    0 0 92px rgb(255, 0, 153),
    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 #63f0f0ef, 0 10px 20px 20px #7ef8bb65;
  filter: blur(3px) drop-shadow(16px 16px 20px #ffffff) ;
  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: #ffffff;
  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;
}

@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: 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(87, 205, 187);
  filter: drop-shadow(16px 16px 70px #7511f7) ;
  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 #d9c8ecec, 0 10px 15px #ba63f0ef, 0 10px 20px 20px #7ef8bb65;
  filter: blur(3px) drop-shadow(16px 16px 20px #f7b211) ;
  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 #0660f265;
  filter: blur(2px) drop-shadow(30px -9px 30px #f4f2f5) ;
  }  

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

}

.ul-nav, span#open_to_work:hover {
  color: rgb(0, 0, 0);
}
.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;
  text-shadow: rgb(255, 255, 255) 1px 0 10px;
}

.title {
  text-align: center;
  color: rgb(255, 255, 255);
  font-family: poppins;
  overflow: hidden;
  border-right: .15em solid rgb(247, 247, 247);
  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);
  }
}

button {
  margin: 10px;
  background-color: #74e98d;
  border: 1px #7c40ff solid;
  border-radius: 1px;
  display: flex;
  justify-content: center;
  text-align: center;
  transition: all 0.3s ease;
  background-color: mintcream;
  font-family: "poppins", sans-serif;

}

button:hover {
  background-color: #eeeeeefc;
  cursor: pointer;
}

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

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

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

 .sun-moon:hover  {
  cursor: pointer;
  color: rgb(249, 249, 0);
 }



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

  .sun-moon:hover  {
    cursor: pointer;
    color: yellow;
    /* filter: drop-shadow(16px 16px 20px #000208) */
  }

  .sun-moon:active  {
    cursor: pointer;
    color: rgb(5, 0, 0); 
    /* filter: drop-shadow(16px 16px 20px #000208); */
    }

  .appImg {
    width: 100%;
    height: auto;
    margin-top: 10px;
    }

  }

  .algo_description {
    background-color: rgb(3, 0, 155);
    margin: 13px;
    padding: 8px;
  }

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

  /*language algo toggling*/
  #javaScript_button {
    color: rgb(50, 224, 175);
    background-color: #250287a0;
    border-color: #5d3dff;
    border-style: solid;
    border-width: 1px;
    padding: 7px;
    margin: 5px;
    font-family: "poppins", sans-serif;
    font-size: 13px;
  }

  #java_button {
    color: rgb(50, 224, 175);
    background-color: #250287a0;
    border-color: #5d3dff;
    border-style: solid;
    border-width: 1px;
    padding: 7px;
    margin: 5px;
    font-family: "poppins", sans-serif;
    font-size: 13px;
    
  }

  #python_button {
    color: rgb(50, 224, 175);
    background-color: #250287a0;
    border-color: #5d3dff;
    border-style: solid;
    border-width: 1px;
    padding: 7px;
    margin: 5px;
    font-family: "poppins", sans-serif;
    font-size: 13px;
    
  }


  .js_java {
    overflow-x: auto;
    background-color: rgb(16, 162, 155);
    margin: 1px;
    padding: 13px;
  }

  .loadingDiv {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #015e5d89;
  }
  
  .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;
  }

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

  #javaScript_info {
    background-color: rgb(2, 13, 132);
    border:1px solid #1130f7;
    padding: 10px;
    text-decoration: none;
  }
  
  #java_info {
    background-color: rgb(2, 13, 132);
    border:1px solid #1130f7;
    padding: 10px;
    text-decoration: none;
  }

  #python_info {
    background-color: rgb(2, 13, 132);
    border:1px solid #1130f7;
    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: rgb(2, 13, 132);
    border:1px solid #1130f7;
    padding: 8px;
    margin: 5px;
    text-decoration: none;
  }
  
  .creators_container{
    display: flex;
    justify-content: center;
    margin: 5px;
    padding: 1px;
  }

  #creators_meta {
    background-color: rgb(2, 13, 132);
    border:1px solid #1130f7;
    padding: 4px;
    margin: 5px;
    text-decoration: none;
  }
  
  .tech_line_break {
    margin: 10px;
  }

  @media screen and (max-width: 800px) {
    #creators_meta {
      background-color: rgb(2, 13, 132);
      border:1px solid #1130f7;
      padding: 4px;
      margin: 5px;
      text-decoration: none;
    }
  
    .tech_line_break {
      margin: 10px;
    }
  }