/* ORIGIN v2 — restrained motion (3 moments only) */

@keyframes screenIn {
  from { opacity: 0; transform: translateX(18px); }
  to { opacity: 1; transform: none; }
}

@keyframes screenBack {
  from { opacity: 0; transform: translateX(-18px); }
  to { opacity: 1; transform: none; }
}

@keyframes rise {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}

@keyframes stamp {
  from { opacity: 0; transform: scale(1.2); }
  55% { opacity: 1; }
  to { opacity: 1; transform: none; }
}

@keyframes haloPulse {
  0%, 100% { opacity: 0.45; transform: scale(0.98); }
  50% { opacity: 0.75; transform: scale(1.03); }
}

@keyframes badgePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(35, 72, 230, 0.35); }
  50% { box-shadow: 0 0 0 8px rgba(35, 72, 230, 0); }
}

@keyframes scanLine {
  0%, 100% { top: 18%; }
  50% { top: 62%; }
}

@keyframes breathe {
  0%, 100% { transform: scale(1); opacity: 0.92; }
  50% { transform: scale(1.04); opacity: 1; }
}

@keyframes tapGlow {
  0%, 100% {
    box-shadow: 0 0 0 4px var(--paper), 0 0 0 6px var(--cobalt), 0 10px 28px -8px var(--cobalt-glow);
  }
  50% {
    box-shadow: 0 0 0 4px var(--paper), 0 0 0 6px var(--cobalt), 0 0 0 14px rgba(35, 72, 230, 0.15);
  }
}

@keyframes chipStagger {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: none; }
}

@keyframes dualSlide {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: none; }
}

@keyframes sweepY {
  0%, 100% { top: 22%; }
  50% { top: 68%; }
}

@keyframes detIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: none; }
}

@keyframes contentRise {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: none; }
}

@keyframes finderFlash {
  from { opacity: 0.85; }
  to { opacity: 0; }
}

@keyframes winReveal {
  from { transform: scale(0.98); box-shadow: none; }
  to { transform: none; }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes sealDraw {
  from { stroke-dashoffset: 120; opacity: 0; }
  to { stroke-dashoffset: 0; opacity: 1; }
}

@keyframes segPulse {
  0%, 100% { color: var(--cobalt); transform: scale(1); }
  50% { color: var(--poor); transform: scale(1.06); }
}

@keyframes shareScaleIn {
  from { opacity: 0; transform: scale(0.94); }
  to { opacity: 1; transform: scale(1); }
}

@keyframes chipPulse {
  0%, 100% { box-shadow: none; }
  50% { box-shadow: 0 0 0 4px rgba(35, 72, 230, 0.2); }
}

@keyframes bracketLock {
  0%, 100% { border-color: rgba(255, 255, 255, 0.92); }
  50% { border-color: var(--cobalt); box-shadow: 0 0 12px rgba(35, 72, 230, 0.5); }
}

@keyframes scoreDiffSlide {
  from { opacity: 0; transform: translateX(-12px); }
  to { opacity: 1; transform: none; }
}

@keyframes insightUnblur {
  from { filter: blur(8px); opacity: 0.4; }
  to { filter: none; opacity: 1; }
}

@keyframes morphBar {
  from { width: 80%; }
  to { width: 20%; }
}

@keyframes cartFan {
  from { opacity: 0; transform: rotate(-4deg) translateY(8px); }
  to { opacity: 1; transform: none; }
}

@keyframes countUpGlow {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

@keyframes clientFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

@keyframes meshDrift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

@media (prefers-reduced-motion: reduce) {
  .insight-chip.is-pulse,
  .vs-card.seg-pulse .vsn.you .big,
  body.client-mode .device.is-active .device-stage,
  .scanline,
  .halo {
    animation: none !important;
  }
}
