@property --oca-border-angle {
  syntax: "<angle>";
  inherits: false;
  initial-value: 0deg;
}

.oca-card,
.oca-path,
.oca-article,
.oca-quote,
.oca-event {
  position: relative;
  background-clip: padding-box;
}

.oca-card::after,
.oca-path::after,
.oca-article::after,
.oca-quote::after,
.oca-event::after {
  content: "";
  position: absolute;
  inset: 0;
  padding: 1px;
  border-radius: inherit;
  background: linear-gradient(var(--oca-border-angle, 135deg), #714b67, #017e84, #714b67);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  z-index: 5;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.oca-card:hover::after,
.oca-path:hover::after,
.oca-article:hover::after,
.oca-quote:hover::after,
.oca-event:hover::after {
  opacity: 1;
  animation: ocaBorderRotate 3s linear infinite;
}

@keyframes ocaBorderRotate {
  to {
    --oca-border-angle: 360deg;
  }
}
