:root {
  /* ----- COLOR ------ */
  --default-dark-color: #fff;
  --default-light-color: #09001f;
  --first-font-color: #36187e;
  --second-font-color: #eee8fd;
  --third-font-color: #c0abf0;
  --button-bg-color: #5a24d9;

  --first-bg-color: #250d5e;
  --second-bg-color: #330e89;
  --third-bg-color: #4c15cd;
  --fourth-bg-color: #2d0a6a;

  --greencheck: #00d26a;
  --neutral-color: #fff;
  --dark-shadow-color: transparent;
  --main-font-color: #f823f4;
  --nav-bg-color: #2d0a6a94;

  --special-color-1: #ff4866;
  --special-color-2: #2bd0d0;
  --special-color-3: #fa843b;
  --special-color-4: #4a93f2;
  --special-color-5: #e31717;

  /* ----- for bg effect ----- */
  --color1: #bf163848;
  --color2: #131dd363;
  --color3: #bc18d25f;
  --color4: #5a24d988;

  /* ----- DIMENTION ------ */
  --header-height: 4rem;
  --main-img-width: 30rem;
  --main-img-height: 30rem;
  --project-img-width: 60%;
  --max-about-text-height: 27vh;

  /* ----- ANIMATION ------ */
  --bounce-animation-duration: 8s;

  /* ------- FONTS --------- */
  --main-font-family: "poppins", "Segoe UI", "CJay-font", "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* ----- FONT SIZE -------- */
  --h1-font-size: 4.8rem;
  --h2-font-size: 3.5rem;
  --h3-font-size: 2.6rem;
  --h4-font-size: 1.1rem;
  --p-font-size: 1.1rem;

  /* ----- others ----- */
  --hover-blur: 15px;
}

@font-face {
  font-family: "CJay-font";
  src: url("font/Segoe\ UI.woff") format("woff");
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  text-decoration: none;
  color: var(--default-dark-color);
  font-family: var(--main-font-family);
  scroll-behavior: smooth;
}
.light-mode-colors {
  /* ----- COLOR ------ */
  --default-dark-color: #000;
  --default-light-color: #fff;
  --first-font-color: #5a24d9;
  --second-font-color: #928d9f;
  --third-font-color: #2d0a6a;
  --button-bg-color: #ae8cff;

  --first-bg-color: #f5f8fa;
  --second-bg-color: #c0abf0;
  --third-bg-color: #fff;
  --fourth-bg-color: #eee8fd;

  --greencheck: #00d26a;
  --neutral-color: #fff;
  --dark-shadow-color: #00000052;
  --main-font-color: #5a24d9;
  --nav-bg-color: #eee8fd;

  --special-color-1: #e43bfa;
  --special-color-2: #2bd0d0;
  --special-color-3: #fa843b;
  --special-color-4: #1743e3;
  --special-color-5: #e31717;

  /* ----- for bg effect ----- */
  --color1: #bf163800;
  --color2: #131dd300;
  --color3: #bc18d200;
  --color4: #5a24d900;
}
.night-mode-colors {
  /* ----- COLOR ------ */
  --default-dark-color: #fff;
  --default-light-color: #09001f;
  --first-font-color: #36187e;
  --second-font-color: #eee8fd;
  --third-font-color: #c0abf0;
  --button-bg-color: #5a24d9;

  --first-bg-color: #250d5e;
  --second-bg-color: #330e89;
  --third-bg-color: #4c15cd;
  --fourth-bg-color: #2d0a6a;

  --greencheck: #00d26a;
  --neutral-color: #fff;
  --dark-shadow-color: transparent;
  --main-font-color: #ed67ff;
  --nav-bg-color: #2d0a6a94;

  --special-color-1: #ff4866;
  --special-color-2: #2bd0d0;
  --special-color-3: #fa843b;
  --special-color-4: #4a93f2;
  --special-color-5: #e31717;

  /* ----- for bg effect ----- */
  --color1: #82203476;
  --color2: #2d0a6a;
  --color3: #9e13b083;
  --color4: #5a24d9;
}
body {
  background: var(--default-light-color);
}

body a {
  cursor: pointer;
}

h1,
h2,
h3 {
  font-weight: 900;
}

h1 {
  font-size: var(--h1-font-size);
}
h2 {
  font-size: var(--h2-font-size);
}
h3 {
  font-size: var(--h3-font-size);
}
h4 {
  font-size: var(--h4-font-size);
  font-weight: 600;
}
p {
  font-size: var(--p-font-size);
  font-weight: 400;
}

#container {
  width: 100%;
  max-width: 2400px;
  margin: 0 auto;
}
/*  NAVBAR section ------------------------------- */
header {
  display: flex;
  position: fixed;
  top: 0;
  width: 100%;
  max-width: 2400px;
  margin: 0 auto;
  height: var(--header-height);
  z-index: 100;
  transition: top 0.5s;
}
header::before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
}
header.header-bg::before {
  backdrop-filter: blur(15px);
  background: var(--nav-bg-color);
}

header > * {
  display: flex;
  align-items: center;
  position: relative;
}
#main-logo {
  margin-left: 3rem;
  overflow: hidden;
  cursor: pointer;
}

#logo-img {
  display: none;
  width: 110px;
  border-radius: 25px;
}
#main-logo #logo-img {
  animation: shake 4s linear infinite;
}
.logo-text a {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  color: var(--main-font-color);
  transition: color 0.3s ease;
}

#main-logo:hover a {
  color: var(--third-font-color);
}

.navbar {
  flex: 2;
  justify-content: flex-end;
  margin-right: 3%;
}

.navbar a {
  margin: 0 1.2rem;
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.15rem;
  color: var(--default-dark-color);
  position: relative;
  width: max-content;
}
.navbar a:hover::after {
  width: 100%;
}
.navbar a::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  height: 5px;
  width: 0;
  border-radius: 10px;
  background: linear-gradient(to right, var(--second-bg-color), var(--main-font-color));
  transition: width 0.2s ease;
}
.navbar a:active,
.navbar a:hover {
  color: var(--main-font-color);
}
.navbar .active {
  font-weight: 500;
  color: var(--main-font-color);
}

.navbar > .night-mode {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 5px;
  margin-left: 2%;
}
.navbar .switch-mode {
  display: flex;
  align-items: center;
  width: 40px;
  height: 13px;
  border-radius: 30px;
  background-color: var(--neutral-color);
  cursor: pointer;
  box-shadow: inset -2px -2px 2px #fff, inset 2px 2px 2px #0000007e, 0 2px 5px #00000035;
  border: 1px solid #fff;
}
.navbar .switch-mode i {
  width: 22px;
  height: 22px;
  font-size: 11px;
  border-radius: 50%;
  transform: translateX(-5px);
  background-color: var(--third-bg-color);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.3s;
  border: 0.5px solid var(--second-bg-color);
  box-shadow: inset -2px -2px 2px #0000002d, inset 2px 2px 2px #fff, inset 0 0 2px #fff, 2px 0 5px #000000;
}
.navbar .switch-mode:hover i,
.navbar .switch-mode:active i {
  box-shadow: inset -2px -2px 2px #0000002d, inset 2px 2px 2px #fff, 0 0 10px var(--main-font-color);
}

.menu-icon {
  border: none;
  background-color: transparent;
  margin-left: auto;
  display: none;
}
.menu-icon i {
  font-size: 2.5rem;
  padding: 10px;
  cursor: pointer;
}

/* ===================== MAIN BODY SECTION ====================== */
#body-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  overflow: hidden;
}

/* ===================== HOME SECTION ====================== */
#home {
  width: 100%;
  position: relative;
  height: 100svh;
  max-height: 1200px;
  padding: 12%;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  flex-wrap: wrap;
  background: url("iil/image/bg-grid-lighter.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.box-content {
  flex: 1;
  overflow: hidden;
}

.text-content > * {
  display: block;
}

.text-content {
  padding: 0 0 2rem 2rem;
}
#name-text {
  letter-spacing: 0.15rem;
  font-family: "Rubik Moonrocks";
  font-weight: 300;
  animation: slideLeft 2s;
}

.text-content > h3:first-child {
  letter-spacing: 0.05rem;
  position: relative;
  animation: slideRight 1s;
}
.my-title {
  display: flex;
  flex-wrap: wrap;
  gap: 1%;
}
.my-title span:nth-child(1) h3 {
  letter-spacing: 0.01rem;
  font-weight: 600;
  animation: slideRight 2.5s ease;
}
.my-title span:nth-child(2) h3 {
  color: var(--main-font-color);
  letter-spacing: 0.2rem;
  animation: slideUp 1s, flicker 3s linear infinite;
  opacity: 0;
  animation-delay: 3s;
}
.text-content p {
  max-width: 60rem;
  color: var(--default-dark-color);
  animation: slideRight 5s;
}

.socials {
  isolation: isolate;
  display: flex;
  margin-top: 5vh;
}
.socials a {
  height: 3rem;
  width: 3rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--first-font-color);
  border-radius: 50%;
  margin-right: 1.5rem;
  transition: 0.3s ease;
  animation: stepSlideLeft 4s ease;
  position: relative;
}
.socials a i {
  font-size: 1.3rem;
  color: #fff;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  border: 0.5px solid transparent;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--first-font-color);
}
.socials a::before,
.socials a::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  padding: 3px;
  background: conic-gradient(
    from var(--angle),
    var(--first-font-color),
    var(--main-font-color),
    var(--default-light-color),
    var(--main-font-color),
    var(--first-font-color)
  );
  border-radius: 50%;
  z-index: -1;
  animation: spinHexBorder 5s linear infinite;
}
.socials a:hover i,
.socials a:active i {
  background-color: var(--second-bg-color);
  color: var(--main-font-color);
}
.socials a:active i {
  border-color: var(--main-font-color);
  box-shadow: inset -2px -2px 3px var(--default-light-color), inset 2px 2px 3px var(--first-font-color);
}
.socials a:hover::before {
  filter: blur(15px);
}
.socials a:nth-child(1),
.socials a:nth-child(1)::before,
.socials a:nth-child(1)::after {
  animation-delay: -1.2s;
}
.socials a:nth-child(2),
.socials a:nth-child(2)::before,
.socials a:nth-child(2)::after {
  animation-delay: -0.6s;
}
.img-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
  padding: 3rem 1rem;
}
.home-img {
  height: 80%;
  margin: 3% 3% 0;
  padding: 4rem;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  animation: bounce var(--bounce-animation-duration) ease-in-out infinite;
  transition: opacity 2s;
}

.home-img img {
  width: var(--main-img-width);
  height: var(--main-img-height);
  border-radius: 50%;
  background: linear-gradient(to bottom right, #fff, #fff, #e43bfa, #e43bfa);
}

.home-img::before {
  content: "";
  position: absolute;
  width: var(--main-img-width);
  height: var(--main-img-height);
  padding: 1.2rem;
  border-radius: 50%;
  background: conic-gradient(var(--third-font-color), var(--third-bg-color), var(--third-font-color));
  z-index: -1;
  animation: rotateRight 5s linear infinite;
  box-shadow: 0 0 30px #777;
}

.home-img::after {
  content: "Hover to View";
  color: var(--third-font-color);
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: var(--main-img-width);
  height: var(--main-img-height);
  border-radius: 50%;
  background-color: var(--third-bg-color);
  opacity: 0.8;
  transition: 1s ease;
}

.home-img:hover::after,
.home-img:active::after {
  /* border: none; */
  opacity: 0;
  /* z-index: -2; */
  background-color: transparent;
  /* filter: blur(5px); */
  height: 0;
  width: 0;
  /* transform: translateY(100%); */
}
.shadow {
  height: 3rem;
  width: 100%;
  border-radius: 50%;
  /* position: absolute; */
  margin-top: auto;
  background: radial-gradient(rgba(0, 0, 0, 2), transparent, transparent);
  filter: blur(8px);
  animation: shadowEffect var(--bounce-animation-duration) ease-in-out infinite;
}

/* ===================== ABOUT SECTION ====================== */
#about {
  min-height: 100svh;
  padding: 0 10%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  /* background: url("iil/image/bg-grid-lighter.svg");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center; */
  /* padding: 0 5%; */
  /* background-color: #000; */
  /* border: 2px solid blue; */
}
#about::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("iil/image/bg-grid-lighter.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  transform: scaleY(-1);
  pointer-events: none;
}
.about-container {
  margin-top: var(--header-height);
  padding: 1%;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  flex-wrap: wrap;
  z-index: 1;
  /* border: 2px solid red; */
}

.about-content {
  margin-left: 5rem;
  padding: 0.5rem;
  width: 40rem;
  /* border: 2px solid blue; */
}

.about-content h1 {
  padding: 0;
  color: var(--main-font-color);
}
.about-content h3 {
  margin-top: 0;
}
.skills {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  width: max-content;
  padding: 20px 0;
  /* border: 1px solid red; */
}
.skills .tools > * {
  margin: 0;
  /* padding: 0; */
  /* border: 1px solid yellow; */
}
.skills .tools {
  /* margin: 0 1rem; */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  height: 80px;
  width: 60px;
  transition: transform 0.2s;
  /* border: 1px solid yellow; */
}
.skills .tools:hover {
  transform: scale(1.2);
}
.skills .tools img {
  /* padding: 1px; */
  width: 100%;
  border-radius: 5px;
}
.skills .tools p {
  font-size: 0.7rem;
  width: max-content;
  text-align: center;
}

/* -------- SKILL ANIMAATION ------ */
.wrapper {
  height: 120px;
  width: 90%;
  /* max-width: 600px; */
  position: relative;
  /* overflow: hidden; */
  mask-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, 1) 15%, rgba(0, 0, 0, 1) 85%, rgba(0, 0, 0, 0));
}

@keyframes skillScrollLeft {
  to {
    left: -100px;
  }
}

.tools {
  position: absolute;
  animation: skillScrollLeft 20s linear infinite;
  left: max(calc(90px * 18), 100%);
}

.skills:hover .tools {
  animation-play-state: paused;
}

.tools {
  animation-delay: calc(20s / 18 * (18 - var(--item-index)) * -1);
}

/* Individual item classes */
.item1 {
  --item-index: 1;
}
.item2 {
  --item-index: 2;
}
.item3 {
  --item-index: 3;
}
.item4 {
  --item-index: 4;
}
.item5 {
  --item-index: 5;
}
.item6 {
  --item-index: 6;
}
.item7 {
  --item-index: 7;
}
.item8 {
  --item-index: 8;
}
.item9 {
  --item-index: 9;
}
.item10 {
  --item-index: 10;
}
.item11 {
  --item-index: 11;
}
.item12 {
  --item-index: 12;
}
.item13 {
  --item-index: 13;
}
.item14 {
  --item-index: 14;
}
.item15 {
  --item-index: 15;
}
.item16 {
  --item-index: 16;
}
.item17 {
  --item-index: 17;
}
.item18 {
  --item-index: 18;
}
/* ---------------------------------------------------- */

#string-typing {
  display: inline;
  color: var(--main-font-color);
}

/* Cursor */
.typed-cursor {
  color: var(--main-font-color);
  font-size: var(--h3-font-size);
  font-weight: 600;
  animation: slideUp 1s, flicker 3s linear infinite;
  display: none;
}
.about-content p {
  font-weight: 200;
}
.more-text {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows 0.3s;
}
.hide {
  grid-template-rows: 0fr;
}
.about-content .more-text > p {
  overflow: hidden;
}
.styled-text {
  /* color: var(--third-font-color); */
  font-weight: 600;
  /* font-style: italic; */
}

.more-about-me {
  color: var(--neutral-color);
  font-size: 1rem;
  font-weight: 500;
  cursor: pointer;
  margin-top: 2vh;
  border: none;
  padding: 0.5rem 1.5rem;
  border-radius: 5px;
  border: 1px solid transparent;
  background-color: var(--first-font-color);
}
.more-about-me:hover {
  border-color: var(--default-dark-color);
}

.more-about-me:active {
  color: var(--default-light-color);
  background-color: var(--main-font-color);
}

/* --------------- profit image animation ------------------ */

.img-container {
  position: relative;
  align-self: center;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px;
  /* border: 2px solid red; */
}
@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
.img-container::before,
.img-container::after {
  content: "";
  position: absolute;
  width: 100%;
  max-width: 400px;
  height: 100%;
  /* top: -20px; */
  /* padding: 10px; */
  clip-path: polygon(40% 0%, 60% 0%, 95% 11%, 100% 16%, 100% 70%, 95% 80%, 52% 100%, 48% 100%, 5% 80%, 0% 70%, 0 16%, 5% 11%);
  /* z-index: 1; */
  background: conic-gradient(from var(--angle), transparent, var(--default-light-color), var(--third-bg-color), var(--first-font-color), transparent 90%);
  animation: bounce var(--bounce-animation-duration) ease-in-out infinite, spinHexBorder 7s linear infinite;
  animation-delay: 2s;
  /* border: 2px solid red; */
}
.img-container::after {
  padding: 30px;
  filter: blur(50px);
  background: radial-gradient(var(--main-font-color), transparent 65%);
}
@keyframes spinHexBorder {
  0% {
    --angle: 0deg;
  }

  100% {
    --angle: 360deg;
  }
}

.img-container .hexagon {
  position: relative;
  display: flex;
  justify-content: center;
  width: 30vh;
  height: 40vh;
  /* margin-top: 50px; */
  z-index: 1;
  /* border: 2px solid red; */
}

.img-container .hexagon::after {
  content: "";
  position: absolute;
  bottom: -5rem;
  width: 100%;
  height: 5vh;
  /* background-color: #000; */
  background: radial-gradient(#000000b6, transparent, transparent);
  filter: blur(6px);
  border-radius: 50%;
  transition: 0.5s;
  animation: shadowEffect var(--bounce-animation-duration) ease-in-out infinite;
  animation-delay: 2s;
}

.img-container .hexagon .shape {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background-color: var(--first-font-color);
  background: radial-gradient(var(--main-font-color), var(--first-bg-color));
  animation: bounce var(--bounce-animation-duration) ease-in-out infinite;
  animation-delay: 2s;
  clip-path: polygon(40% 0%, 60% 0%, 95% 11%, 100% 16%, 100% 70%, 95% 80%, 52% 100%, 48% 100%, 5% 80%, 0% 70%, 0 16%, 5% 11%);
  box-shadow: 0px 0px 60px 0px rgba(33, 2, 2, 0.5);
}

.img-container .hexagon .shape img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translateY(70px) scale(0.9);
}

/* ===================== PROJECTS SECTION ====================== */
#portfolio-section {
  display: flex;
  overflow: hidden;
}
#other-portfolio {
  transform: translateX(-100%);
}
#portfolio,
#other-portfolio {
  min-width: 100%;
  min-height: 100svh;
  padding: 2rem 0;
  position: relative;
  background: linear-gradient(transparent, var(--nav-bg-color), transparent);
  transition: 1s transform ease-in-out;
}

#portfolio > h2,
#other-portfolio > h2 {
  text-align: center;
  letter-spacing: 0.15rem;
  margin-top: 3rem;
  color: var(--default-dark-color);
}
#portfolio .projects,
#other-portfolio .projects {
  z-index: 2;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 3.5rem;
}

.box {
  width: 21.8%;
  display: flex;
  flex-direction: column;
  border-radius: 5px 50px 5px 50px;
  overflow: hidden;
  margin: 1%;
  box-shadow: 3px 3px 10px #0000001e;
  transition: transform 0.3s ease-in-out, margin-inline 0.3s ease-in-out;
  background: linear-gradient(var(--third-bg-color), var(--default-light-color));
}
.box-img {
  transition: transform 0.3s;
}

.box:hover,
.box:active {
  border-color: var(--first-font-color);
  box-shadow: 1px 1px 5px var(--second-bg-color);
}

.box:hover,
.box:active {
  transform: scale(1.05);
}

.projects:hover > :not(:hover),
.projects:active > :not(:active) {
  margin-inline: -3rem;
  transform: perspective(400px) rotateY(30deg) scale(0.75);
}

.box:hover ~ .box,
.box:active ~ .box {
  transform: perspective(400px) rotateY(-30deg) scale(0.75);
}

.project-text-content {
  padding: 1.5rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.project-text-content h4 {
  font-size: var(--h4-font-size);
  line-height: 1.2;
  color: var(--main-font-color);
}

.project-text-content p {
  font-size: 0.8rem;
  color: var(--second-font-color);
  margin: 0.6rem 0 1.3rem;
  font-weight: 300;
}

.project-options {
  margin-top: auto;
  display: flex;
  /* justify-content: center; */
  align-items: center;
  flex-wrap: wrap-reverse;
  gap: 0.6rem;
}
.project-options a {
  margin-right: 0.7rem;
  font-size: 0.9rem;
  font-weight: 500;
  text-align: center;
  color: var(--default-dark-color);
  padding: 0.05rem 0.4rem 0.2rem 0;
  border-right: 1px solid transparent;
  border-bottom: 1px solid transparent;
}
.project-options .live-demo a:active,
.project-options .live-demo a:hover {
  border-color: var(--default-dark-color);
  color: var(--default-dark-color);
}
.project-options > .source-code {
  order: -1;
  padding: 0.5rem 1.5rem;
  border-radius: 3px 25px 3px 25px;
  font-weight: 600;
  color: var(--default-light-color);
  background-color: var(--second-bg-color);
}

.project-options > .source-code:hover {
  color: var(--default-light-color);
  background-color: var(--first-font-color);
}

.box:nth-child(1):hover,
.box:nth-child(1):active {
  border-color: var(--special-color-1);
  box-shadow: 1px 1px 10px var(--special-color-1);
}
.box:nth-child(1) .project-text-content h4 {
  color: var(--special-color-1);
}
.box:nth-child(1) .project-options > .source-code {
  border: none;
  background-color: var(--special-color-1);
}
.box:nth-child(1) .project-options > .source-code:hover {
  background: linear-gradient(to right, var(--special-color-1), var(--first-font-color));
}

.box:nth-child(2):hover,
.box:nth-child(2):active {
  border-color: var(--special-color-2);
  box-shadow: 1px 1px 10px var(--special-color-2);
}
.box:nth-child(2) .project-text-content h4 {
  color: var(--special-color-2);
}
.box:nth-child(2) .project-options > .source-code {
  border: none;
  background-color: var(--special-color-2);
}
.box:nth-child(2) .project-options > .source-code:hover {
  background: linear-gradient(to right, var(--special-color-2), var(--first-font-color));
}

.box:nth-child(3):hover,
.box:nth-child(3):active {
  border-color: var(--special-color-3);
  box-shadow: 1px 1px 10px var(--special-color-3);
}
.box:nth-child(3) .project-text-content h4 {
  color: var(--special-color-3);
}

.box:nth-child(3) .project-options > .source-code {
  border: none;
  background-color: var(--special-color-3);
}
.box:nth-child(3) .project-options > .source-code:hover {
  background: linear-gradient(to right, var(--special-color-3), var(--first-font-color));
}

.box:nth-child(4):hover,
.box:nth-child(4):active {
  border-color: var(--special-color-4);
  box-shadow: 1px 1px 10px var(--special-color-4);
}
.box:nth-child(4) .project-text-content h4 {
  color: var(--special-color-4);
}
.box:nth-child(4) .project-options > .source-code {
  border: none;
  background-color: var(--special-color-4);
}
.box:nth-child(4) .project-options > .source-code:hover {
  background: linear-gradient(to right, var(--special-color-4), var(--first-font-color));
}

#portfolio .other-projects,
#other-portfolio .other-projects {
  margin-top: 50px;
  width: 100%;
  display: flex;
  justify-content: center;
}
#portfolio .other-projects a,
#other-portfolio .other-projects a {
  font-size: 14px;
  padding: 5px 30px;
  color: var(--default-dark-color);
  background-color: var(--button-bg-color);
  border-radius: 30px;
  border: 1px solid var(--default-dark-color);
  cursor: pointer;
}
#portfolio .other-projects a:hover,
#other-portfolio .other-projects a:hover {
  background-color: var(--first-bg-color);
}
#portfolio .other-projects a:active,
#other-portfolio .other-projects a:active {
  background-color: var(--button-bg-color);
}
/* ===================== CONTACT SECTION ====================== */
#contact {
  min-height: 100svh;
  display: flex;
  justify-content: center;
  background: url("iil/image/bg-grid-lighter.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.contact-container {
  width: 80%;
  padding-top: 3rem;
  margin-top: 5rem;
}
.contact-container h2 {
  width: 100%;
  text-align: center;
  margin-bottom: 1.5rem;
}
.contact-container .row1 {
  position: relative;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.contact-container .row1 .col {
  position: relative;
  width: 100%;
  padding: 0 2rem;
  margin: 2rem 0 1rem;
  transition: 0.3s;
}
.contact-container .contact-input-box {
  position: relative;
  width: 100%;
  height: 2.5rem;
}
.contact-container .contact-input-box input,
.contact-container .contact-input-box.textarea textarea {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: transparent;
  box-shadow: none;
  border: none;
  outline: none;
  font-size: 1rem;
  padding: 0 1rem;
  z-index: 1;
  color: var(--default-dark-color);
}
.contact-container .contact-input-box .contact-text {
  position: absolute;
  top: 0;
  left: 0;
  line-height: 3rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--default-dark-color);
  padding: 0 1rem;
  display: block;
  transition: 0.3s;
  pointer-events: none;
}
.contact-container .contact-input-box input:focus + .contact-text,
.contact-container .contact-input-box input:valid + .contact-text {
  top: -2.5rem;
  left: -1rem;
  /* color: var(--third-bg-color); */
  opacity: 0.5;
  font-weight: normal;
}
.contact-container .contact-input-box .contact-line {
  position: absolute;
  bottom: 0;
  display: block;
  width: 100%;
  height: 0.1rem;
  /* background-color: var(--fourth-bg-color); */
  border-bottom: 1px solid var(--default-dark-color);
  transition: 0.3s;
  /* border-radius: 0.1rem; */
  pointer-events: none;
}
.contact-container .contact-input-box input:focus ~ .contact-line,
.contact-container .contact-input-box input:valid ~ .contact-line {
  height: 100%;
  /* border: none; */
}
.contact-container .textarea {
  position: relative;
  width: 100%;
  height: 10rem;
  padding: 1rem 0;
}
.contact-container .contact-input-box.textarea textarea {
  height: 100%;
  resize: none;
}
.contact-container .contact-input-box textarea:focus + .contact-text,
.contact-container .contact-input-box textarea:valid + .contact-text {
  top: -2.5rem;
  left: -1rem;
  /* color: var(--third-bg-color); */
  opacity: 0.5;
  font-weight: normal;
}
.contact-container .contact-input-box textarea:focus ~ .contact-line,
.contact-container .contact-input-box textarea:valid ~ .contact-line {
  height: 100%;
  /* border: none; */
}
.contact-container .submit-message {
  border: none;
  padding: 0.3rem 1.5rem;
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: 0.2rem;
  cursor: pointer;
  outline: none;
  background-color: var(--first-font-color);
  color: var(--neutral-color);
  border-radius: 0.2rem;
  border: 1px solid transparent;
}
.contact-container .submit-message:hover {
  /* background-color: var(--fourth-bg-color); */
  /* color: var(--third-font-color); */
  border-color: var(--default-dark-color);
}
.contact-container .submit-message:active {
  color: var(--default-light-color);
  background-color: var(--main-font-color);
}
/* ===================== FOOTER SECTION ====================== */

#move-to-top {
  position: sticky;
  bottom: 3%;
  left: 100%;
  display: none;
}
#move-to-top i {
  font-size: 3rem;
  padding: 1rem;
  color: var(--main-font-color);
  background-color: transparent;
  animation: shortBounce 1s infinite;
  /* border: 2px solid blue; */
}
#move-to-top:hover i {
  color: var(--third-font-color);
}

footer {
  /* height: 10svh; */
  padding: 1rem 3rem;
  display: flex;
  /* flex-direction: column; */
  justify-content: space-between;
  align-items: center;
  /* flex-wrap: wrap; */
  gap: 0.5rem;
  /* background-color: var(--first-font-color); */
}
/* .footer-socials {
    margin-bottom: 1rem;
} */
.footer-socials a {
  margin: 0.2rem;
}
.footer-socials i {
  font-size: 1.1rem;
  color: var(--default-dark-color);
  padding: 0.6em;
  border-radius: 50%;
  border: 1px solid transparent;
  transition: 0.3s;
}
.footer-socials i:hover,
.footer-socials i:active {
  /* border-color: var(--default-dark-color); */
  color: var(--default-light-color);
  background-color: var(--main-font-color);
  box-shadow: 1px 1px 15px var(--main-font-color);
}
footer p {
  font-size: 0.9rem;
  font-weight: 500;
  text-align: center;
  color: var(--default-dark-color);
  /* border: 2px solid #fff; */
}

/* =============== message-success ================ */
#loader {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: none;
  width: 45px;
  aspect-ratio: 0.75;
  --c: no-repeat linear-gradient(#000 0 0);
  background: var(--c) 0% 50%, var(--c) 50% 50%, var(--c) 100% 50%;
  animation: l7 1s infinite linear alternate;
}
@keyframes l7 {
  0% {
    background-size: 20% 50%, 20% 50%, 20% 50%;
  }
  20% {
    background-size: 20% 20%, 20% 50%, 20% 50%;
  }
  40% {
    background-size: 20% 100%, 20% 20%, 20% 50%;
  }
  60% {
    background-size: 20% 50%, 20% 100%, 20% 20%;
  }
  80% {
    background-size: 20% 50%, 20% 50%, 20% 100%;
  }
  100% {
    background-size: 20% 50%, 20% 50%, 20% 50%;
  }
}

#message-success {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 10%;
  background-color: var(--default-light-color);
  z-index: 1;
  border-radius: 0.6rem;
  display: none;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--greencheck);
  /* filter: ; */
}
#report-cancel {
  position: absolute;
  top: 2%;
  left: 90%;
  cursor: pointer;
  /* margin: 5%; */
}
#report-cancel i {
  font-size: 2rem;
  color: var(--second-font-color);
}
#report-cancel:hover i {
  color: var(--default-dark-color);
}
#message-success h4 {
  text-align: center;
  /* font-size: 1.2rem; */
  font-weight: 500;
}

/* =============== ANIMATION SECTION ================ */

@keyframes shadowEffect {
  10% {
    opacity: 0.75;
    transform: scale(0.75);
  }
  20% {
    opacity: 1;
    transform: scale(1);
  }
  30% {
    opacity: 0.8;
    transform: scale(0.8);
  }
  40% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.85;
    transform: scale(0.85);
  }
  60% {
    opacity: 1;
    transform: scale(1);
  }
  70% {
    opacity: 0.9;
    transform: scale(0.9);
  }
  80% {
    opacity: 1;
    transform: scale(1);
  }
  90% {
    opacity: 0.95;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes blurEffect {
  100% {
    opacity: 0;
    filter: blur(5px);
    transform: translateY(100%);
  }
}

@keyframes rotateRight {
  100% {
    transform: rotate(360deg);
  }
}

@keyframes bounce {
  10% {
    transform: translateY(-50px);
  }
  20% {
    transform: translateY(0px);
  }
  30% {
    transform: translateY(-40px);
  }
  40% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-30px);
  }
  60% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(-20px);
  }
  80% {
    transform: translateY(0px);
  }
  90% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0px);
  }
}
@keyframes shortBounce {
  50% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}

@keyframes slideRight {
  0% {
    transform: translateX(-5000px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slideLeft {
  0% {
    transform: translateX(5000px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes stepSlideLeft {
  0% {
    z-index: -1;
    transform: translateX(5000px);
    opacity: 0;
  }
  30% {
    z-index: -1;
    transform: translateX(5000px);
    opacity: 0;
  }
  60% {
    z-index: -1;
    opacity: 1;
  }
  80% {
    z-index: -1;
    opacity: 1;
  }
  80% {
    z-index: -1;
    opacity: 1;
  }
  100% {
    z-index: -1;
    transform: translateX(0);
  }
}
@keyframes slideUp {
  0% {
    transform: translateY(250px);
    opacity: 0;
  }
  30% {
    opacity: 0;
  }
  60% {
    opacity: 0;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slideDown {
  0% {
    transform: translateY(-500px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes flicker {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 1;
  }
  95% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes shake {
  10% {
    transform: translateY(-15px) rotate(-50deg);
  }
  20% {
    transform: translateY(0px) rotate(-45deg);
  }
  30% {
    transform: translateY(-10px) rotate(-40deg);
  }
  40% {
    transform: translateY(0px) rotate(-35deg);
  }
  50% {
    transform: translateY(-7px) rotate(-30deg);
  }
  60% {
    transform: translateY(0px) rotate(-25deg);
  }
  70% {
    transform: translateY(-4px) rotate(-20deg);
  }
  80% {
    transform: translateY(0px) rotate(-15deg);
  }
  90% {
    transform: translateY(-2px) rotate(-10deg);
  }
  100% {
    transform: translateY(0px) rotate(-5deg);
  }
}
