/*
Primary:    #0B0E14
Secondary:  #151921
Tertiary:   #140C06
Neutral:    #787777
Background: #131314
*/

:root {
  --main-color: #007bff;
  --purple-color: #777bb4;
  --yellow-color: #f7df1e;
  --red-color: #dd0031;
  --blue-color: #2196f3;
  --green-color: #339933;
  --orange-color: #f97316;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Ubuntu Sans Mono", monospace;
  padding: 48px 24px;
  background-color: #131314;
  color: #ffffff;
  line-height: 1.5;
  position: relative;
}

p {
  font-size: 14px;
}

.material-symbols-outlined {
  font-size: 16px;
}

.container {
  background-color: #1c1b1c;
  margin: 0 auto;
  max-width: 1080px;
}

.terminal {
  margin-bottom: 48px;
  border: 1px solid #45474b;
  border-radius: 8px;
  overflow: hidden;

  .header {
    padding: 8px;
    background-color: #45474b;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
  }

  .content {
    padding: 30px;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 16px;

    .name {
      font-size: 18px;
      color: #c4c6cf;
    }

    .location {
      position: absolute;
      top: 30px;
      right: 30px;
      color: #c4c6cfb3;
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 8px;
    }

    .job-title {
      font-weight: 500;
    }
  }
}

.skills {
  display: flex;
  align-items: center;
  gap: 16px;

  .item {
    border-left: 2px solid #c3c6d1;
    padding: 4px 8px;
    background: #c3c6d11a;
    color: #c3c6d1;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;

    &.typescript {
      border-left: 2px solid #3178c6;
      background: #3178c61a;
      color: #63a9ff;
    }

    &.python {
      border-left: 2px solid #ffd43b;
      background: #ffd43b1a;
      color: #ffe27a;
    }

    &.php {
      border-left: 2px solid #777bb4;
      background: #777bb41a;
      color: #a9b0ff;
    }

    &.angular {
      border-left: 2px solid #dd0031;
      background: #dd00311a;
      color: #ff5c7c;
    }

    &.nest {
      border-left: 2px solid #e0234e;
      background: #e0234e1a;
      color: #ff6b8d;
    }

    &.fabric {
      border-left: 2px solid #2f74c0;
      background: #2f74c01a;
      color: #74b2ff;
    }

    &.postgresql {
      border-left: 2px solid #336791;
      background: #3367911a;
      color: #6fa8dc;
    }
  }
}

.container .logs-container {
  padding: 30px;
  display: flex;
  gap: 30px;

  .overflow-container {
    flex-basis: 30%;
    max-height: 1300px;
    position: relative;
    overflow: hidden;

    &::before {
      content: "";
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 24px;
      background-color: #1c1b1c;
      z-index: 1;
    }

    &::after {
      content: "";
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 24px;
      background: radial-gradient(
        ellipse 60% 100% at 50% 0%,
        #007bff 0%,
        rgba(0, 123, 255, 0.5) 40%,
        transparent 100%
      );
      z-index: 2;
    }
  }

  .tree-container {
    display: flex;
    flex-direction: column;
    position: relative;
    top: 10px;
  }
}

/* Git Graph */
.tree {
  height: 600px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: baseline;

  .branch {
    position: absolute;
    width: 40px;

    &.level-2 {
      width: 80px;
      z-index: 1;
    }

    &.left {
      right: 50%;
      border: 5px solid;
      border-radius: 20px 0 0 20px;
      border-right: none;

      &.active {
        border-top: none;
        border-top-left-radius: 0;
      }

      .commit {
        left: -10px;

        .tooltip {
          left: 0;
        }
      }
    }

    &.right {
      left: 50%;
      border: 5px solid;
      border-radius: 0 20px 20px 0;
      border-left: none;

      &.active {
        border-top: none;
        border-top-right-radius: 0;
      }

      .commit {
        right: -10px;

        .tooltip {
          right: 0;
        }
      }
    }

    &.purple {
      border-color: var(--purple-color);

      &.active .commit {
        animation: pulse-purple 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--purple-color);
        animation-name: pulse-purple;
      }
    }

    &.yellow {
      border-color: var(--yellow-color);

      &.active .commit {
        animation: pulse-yellow 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--yellow-color);
      }
    }

    &.red {
      border-color: var(--red-color);

      &.active .commit {
        animation: pulse-red 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--red-color);
      }
    }

    &.blue {
      border-color: var(--blue-color);

      &.active .commit {
        animation: pulse-blue 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--blue-color);
      }
    }

    &.green {
      border-color: var(--green-color);

      &.active .commit {
        animation: pulse-green 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--green-color);
      }
    }

    &.orange {
      border-color: var(--orange-color);

      &.active .commit {
        animation: pulse-orange 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }

      .commit {
        background-color: var(--orange-color);
      }
    }

    .commit {
      position: absolute;
      width: 16px;
      height: 16px;
      border-radius: 50%;
      z-index: 1;
      cursor: pointer;
      transition: all 0.3s ease;

      &:hover {
        scale: 1.2;
      }

      &::after {
        content: "";
        display: block;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        transform: translate(50%, 50%);
        background-color: #0d1117;
      }
    }
  }

  .commit {
    &:hover {
      .tooltip {
        visibility: visible;
      }
    }

    .tooltip {
      visibility: hidden;
      background-color: #131314;
      border: 1px solid #45474b;
      border-radius: 4px;
      padding: 4px;
      position: absolute;
      top: 20px;
      font-size: 10px;
      white-space: nowrap;
      transition: all 0.3s ease;
      z-index: 1;
      transform: scale(1);
    }
  }

  .main {
    width: 5px;
    height: 100%;
    background-color: #58a6ff;
    background-color: var(--main-color);

    .commit {
      left: -5px;
      background-color: var(--main-color);
      z-index: 2;

      &.release {
        box-shadow:
          0 0 6px rgba(0, 123, 255, 1),
          0 0 12px rgba(0, 123, 255, 0.65);
      }

      &.active {
        animation: pulse-main 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
      }
    }
  }
}

.merge-block {
  padding: 32px 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.merge-message {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  color: white;

  .branch-name {
    color: #c6c6cfb3;
  }

  .commit-hash {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #c6c6cf66;
  }

  .version {
    border: 1px solid #c4c6cf33;
    padding: 0 4px;
    font-size: 12px;
    color: #c4c6cf80;
  }
}

/* Card */
.card {
  background-color: #131314;
  border: 1px solid #45474b;
  border-radius: 4px;
  margin-bottom: 16px;
  padding: 16px;
  position: relative;
  transition: all 0.3s ease;

  &:hover {
    border-color: #c4c6cf;
  }

  .title {
    margin-bottom: 8px;

    .subtitle {
      margin-bottom: 8px;
      display: flex;
      gap: 8px;

      p {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 4px;
        padding: 0 8px;
      }

      .release-version {
        color: #c4c6cf;
      }

      .branch-name {
        color: #c3c6d1;
        background-color: #c4c6cf1a;
      }

      .commit-hash {
        margin-left: auto;
        color: #c4c6cf;
      }
    }
  }

  .body {
    .description {
      margin-bottom: 16px;
    }

    .skills {
      .item p {
        font-size: 12px;
      }
    }
  }
}

/* Footer */
.footer {
  padding: 16px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #09090b;
  width: 100%;
  height: 64px;
  display: flex;
  justify-content: space-between;

  .left,
  .right,
  .center {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
  }

  p,
  a {
    font-size: 14px;
    color: white;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  #copy {
    cursor: pointer;
  }
}

@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}

.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes pulse-main {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--main-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--main-color))
      drop-shadow(0 0 6px var(--main-color));
  }
}

@keyframes pulse-purple {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--purple-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--purple-color))
      drop-shadow(0 0 6px var(--purple-color));
  }
}

@keyframes pulse-yellow {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--yellow-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--yellow-color))
      drop-shadow(0 0 6px var(--yellow-color));
  }
}

@keyframes pulse-red {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--red-color));
    opacity: 0.75;
  }
  50% {
    filter: drop-shadow(0 0 2px var(--red-color))
      drop-shadow(0 0 6px var(--red-color));
    opacity: 1;
  }
}

@keyframes pulse-blue {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--blue-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--blue-color))
      drop-shadow(0 0 6px var(--blue-color));
  }
}

@keyframes pulse-green {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--green-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--green-color))
      drop-shadow(0 0 6px var(--green-color));
  }
}

@keyframes pulse-orange {
  0%,
  100% {
    filter: drop-shadow(0 0 0px var(--orange-color));
  }
  50% {
    filter: drop-shadow(0 0 2px var(--orange-color))
      drop-shadow(0 0 6px var(--orange-color));
  }
}
