@layer blocks {
  .project-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition:
      transform var(--duration-normal) var(--ease-out-expo),
      box-shadow var(--duration-normal) var(--ease-out-expo),
      border-color var(--duration-normal) ease;
  }

  @media (prefers-reduced-motion: no-preference) {
    .project-card:hover {
      transform: translateY(-6px);
      box-shadow: 0 12px 40px var(--color-glow);
      border-color: var(--color-accent);
    }

    .project-card:active {
      transform: translateY(-2px) scale(0.98);
    }
  }

  .project-card-title {
    font-size: var(--font-size-h4);
    color: var(--color-text);
  }

  .project-card-desc {
    color: var(--color-text-muted);
    line-height: 1.6;
    flex-grow: 1;
  }

  .project-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .project-card-tag {
    display: inline-block;
    padding: var(--space-xs) var(--space-sm);
    background: var(--color-accent-subtle);
    color: var(--color-accent);
    font-size: 0.8rem;
    font-family: var(--font-mono);
    border-radius: var(--radius-sm);
    position: relative;
    overflow: hidden;
  }

  .project-card:hover .project-card-tag::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, hsl(198deg 93% 60% / 0.15) 50%, transparent 100%);
    animation: shimmer 1.5s ease-in-out;
  }

  @keyframes shimmer {
    from {
      transform: translateX(-100%);
    }

    to {
      transform: translateX(100%);
    }
  }

  .project-card-link {
    color: var(--color-accent);
    font-weight: 600;
    text-decoration: none;
    margin-block-start: var(--space-sm);
  }

  .project-card-link:hover {
    color: var(--color-accent-hover);
  }
}
