.skills {
  height: 100%;
  background-color: var(--secondary-background-color);
  align-items: flex-start;
  padding: 8rem 2rem;
  overflow: hidden;

  .base-limitator {
    .title {
      font-size: 2.2rem;
      font-weight: 600;
      line-height: 6rem;
      color: var(--dark-color);
      opacity: 0;
      transform: translateY(-50px);
      transition: opacity 1s ease, transform 1s ease;
      margin-bottom: 1rem;

      &.animate {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .skills-description {
      font-size: 1.6rem;
      color: var(--text-secondary);
      margin-bottom: 3rem;
      opacity: 0;
      transform: translateY(-30px);
      transition: opacity 1s ease, transform 1s ease;
      transition-delay: 0.2s;
      text-align: center;

      &.animate {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .skills-container {
      display: flex;
      flex-direction: column;
      gap: 4rem;
      width: 100%;

      .skills-category {
        opacity: 0;
        transform: translateY(50px);
        transition: opacity 1s ease, transform 1s ease;

        &.animate {
          opacity: 1;
          transform: translateY(0);
        }

        .category-title {
          font-size: 2rem;
          color: var(--dark-color);
          margin-bottom: 2rem;
          font-weight: 600;
        }

        .skills-grid {
          display: grid;
          grid-template-columns: repeat(auto-fit, minmax(25rem, 1fr));
          gap: 2rem;

          .skill-item {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 1.5rem;
            padding: 2.5rem;
            background-color: var(--card-background);
            border-radius: 12px;
            box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
            transition: all 0.3s ease;
            border: 1px solid rgba(229, 231, 235, 0.8);

            &:hover {
              transform: translateY(-5px);
              box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1), 0 4px 10px rgba(0, 0, 0, 0.06);
              border-color: var(--primary-color);
            }

            &:focus-within {
              outline: 2px solid var(--focus-color);
              outline-offset: 2px;
            }

            img {
              width: 4rem;
              height: 4rem;
              object-fit: contain;
            }

            span {
              font-size: 1.6rem;
              color: var(--dark-color);
              font-weight: 600;
              text-align: center;
            }

            .skill-level {
              width: 100%;
              height: 1rem;
              background-color: #E5E7EB;
              border-radius: 8px;
              overflow: hidden;
              position: relative;

              .progress {
                height: 100%;
                background: var(--gradient-primary);
                border-radius: 8px;
                transition: width 1.5s ease;
                position: relative;

                &::after {
                  content: '';
                  position: absolute;
                  top: 0;
                  left: 0;
                  right: 0;
                  bottom: 0;
                  background: linear-gradient(90deg,
                    rgba(255, 255, 255, 0.2) 0%,
                    rgba(255, 255, 255, 0.1) 50%,
                    rgba(255, 255, 255, 0.2) 100%);
                  border-radius: 8px;
                }
              }
            }
          }
        }
      }
    }
  }
}

@media (max-width: 1074px) {
  .skills {
    padding: 2rem 1rem;

    .base-limitator {
      .title {
        font-size: 2rem;
        line-height: 4rem;
      }

      .skills-container {
        gap: 3rem;

        .skills-category {
          .category-title {
            font-size: 1.8rem;
            margin-bottom: 1.5rem;
          }

          .skills-grid {
            gap: 1.5rem;

            .skill-item {
              padding: 1.5rem;

              img {
                width: 3.5rem;
                height: 3.5rem;
              }

              span {
                font-size: 1.4rem;
              }
            }
          }
        }
      }
    }
  }
}