.contact-link {
    display: inline-block;
    position: relative;
    font-size: 1.25rem;
    color: black;
    text-decoration: none;
    padding: 0.5rem 1rem;
    overflow: hidden;
    border-radius: 1.5rem;
    background-color: transparent;
    transition: color 0.4s ease-in-out;
  }
  
  .contact-link::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    height: 100%;
    width: 20%;
    background-color: #8ac926;
    border-radius: 1.5rem;
    z-index: -1;
    transition: width 0.4s ease-in-out;
  }
  
  .contact-link:hover::before {
    width: 100%;
  }
  
  .contact-link:hover {
    color: white;
  }
  
  .contact-link i {
    margin-left: 0.5rem;
    transition: color 0.4s ease-in-out;
  }
  
