/* From Uiverse.io by verschuls */ 
.card {
    height: 350px;
    width: 280px;
    min-width: 280px;
    min-height: 350px;
    
    display: flex;
    flex-direction: row;
    justify-content: center;
    text-align: center;
    align-items: center;
    padding: 20px 5px 20px 5px;
    transition: transform 0.3s ease-in-out;
  }

  @media (max-width: 768px) {
    .card {
        max-width: 100%;
    }
}
  
  .card-content {
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    transition: transform 300ms;
    box-shadow: 0px 0px 10px 1px #000000ee;
    border-radius: 10px;
  }
  
  .card-front,
  .card-back {
    background-color: #151515;
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    border-radius: 10px;
    overflow: hidden;
  }
  
  .card-back {
    width: 100%;
    height: 100%;
    justify-content: center;
    display: flex;
    align-items: center;
    overflow: hidden;
  }
  
  .card-back::before {
    position: absolute;
    content: " ";
    display: block;
    width: 160px;
    height: 160%;
    background: linear-gradient(
      90deg,
      transparent,
      var(--primary),
      var(--secondary),
      var(--accent),
      var(--secondary),
      var(--primary),
      transparent
    );
    animation: rotation_481 5000ms infinite linear;
  }
  
  .card-back-content {
    position: absolute;
    width: 98%;
    height: 98%;
    background-color: #111;
    border-radius: 10px;
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 30px;
  }
  
  .card:hover .card-content {
    transform: rotateY(180deg);
  }
  
  @keyframes rotation_481 {
    0% {
      transform: rotateZ(0deg);
    }
  
    0% {
      transform: rotateZ(360deg);
    }
  }
  
  .card-front {
    transform: rotateY(180deg);
    color: white;
  }
  
  .card-front .card-front-content {
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 10px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
  }
  
  .card-front-content .card-badge {
    background-color: #00000041;
    padding: 5px 2px;
    width: 80%;
    border-radius: 10px;
    backdrop-filter: blur(5px);
  }
  
  .card-description {
    box-shadow: 0px 0px 10px 5px #00000088;
    width: 100%;
    padding: 10px;
    background-color: #0000005d;
    backdrop-filter: blur(5px);
    border-radius: 10px;
  }
  
  .card-title {
    font-size: 20px;
    max-width: 100%;
    display: center;
    justify-content: space-between;
  }
  
  .card-title p {
    width: 50%;
  }

  .card-hover {
    color: #ffffff88;
    margin-top: -5px;
  }

  @media (max-width: 767px) {
    .desktop-text {
        display: none;
    }
  }
  
  @media (min-width: 768px) {
    .mobile-text {
        display: none;
    }
  }
  

  .card-sub {
    color: #ffffff88;
    margin-top: 10px;
    font-size: 15px;
  }
  
  .card-front .card-img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
  
  .card-circle {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background-color: var(--secondary);
    position: relative;
    filter: blur(15px);
    animation: floating 2600ms infinite linear;
  }
  
  #card-bottom {
    background-color: var(--primary);
    left: 50px;
    top: 0px;
    width: 150px;
    height: 150px;
    animation-delay: -800ms;
  }
  
  #card-right {
    background-color: var(--accent);
    left: 160px;
    top: -80px;
    width: 30px;
    height: 30px;
    animation-delay: -1800ms;
  }
  
  @keyframes card-floating {
    0% {
      transform: translateY(0px);
    }
  
    50% {
      transform: translateY(10px);
    }
  
    100% {
      transform: translateY(0px);
    }
  }
  