/* =================================================================
   MCFans.de - Animations
   ================================================================= */

/* Loader fade out */
@keyframes loaderFadeOut {
  to { opacity: 0; transform: scale(1.1); }
}

/* Hero entry */
@keyframes heroRise {
  from { opacity: 0; transform: translateY(40px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Status pulse */
@keyframes statusPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.7); }
  50%      { box-shadow: 0 0 0 8px rgba(74, 222, 128, 0); }
}

/* Counter pulse */
@keyframes counterPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(1.4); }
}
.counter-pulse {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: var(--ok);
  border-radius: 50%;
  margin-right: 0.5rem;
  vertical-align: middle;
  animation: counterPulse 1.5s ease-in-out infinite;
}

/* Noise shift */
@keyframes noiseShift {
  0%   { transform: translate(0, 0); }
  20%  { transform: translate(-3%, 2%); }
  40%  { transform: translate(2%, -2%); }
  60%  { transform: translate(-2%, -1%); }
  80%  { transform: translate(3%, 1%); }
  100% { transform: translate(0, 0); }
}

/* Glitch effects */
@keyframes glitch1 {
  0%   { transform: translate(0, 0); opacity: 1; }
  20%  { transform: translate(-4px, 1px); opacity: 0.7; }
  40%  { transform: translate(3px, -2px); opacity: 1; }
  60%  { transform: translate(-2px, 2px); opacity: 0.8; }
  80%  { transform: translate(3px, -1px); opacity: 1; }
  100% { transform: translate(0, 0); opacity: 0; }
}
@keyframes glitch2 {
  0%   { transform: translate(0, 0); opacity: 1; }
  20%  { transform: translate(4px, -1px); opacity: 0.7; }
  40%  { transform: translate(-3px, 2px); opacity: 1; }
  60%  { transform: translate(2px, -2px); opacity: 0.8; }
  80%  { transform: translate(-3px, 1px); opacity: 1; }
  100% { transform: translate(0, 0); opacity: 0; }
}

/* Float (gentle bob) */
@keyframes float {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-12px) rotate(2deg); }
}
@keyframes floatSlow {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-30px); }
}
@keyframes floatFast {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-8px) rotate(-2deg); }
}

/* Spin */
@keyframes spin {
  to { transform: rotate(360deg); }
}
@keyframes spinReverse {
  to { transform: rotate(-360deg); }
}

/* Glow pulse */
@keyframes glowPulse {
  0%, 100% { filter: drop-shadow(0 0 8px currentColor); }
  50%      { filter: drop-shadow(0 0 24px currentColor) drop-shadow(0 0 48px currentColor); }
}

/* Breath (subtle scale) */
@keyframes breath {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.04); }
}

/* Antenna blink (logo) */
@keyframes antennaBlink {
  0%, 80%, 100% { opacity: 1; filter: drop-shadow(0 0 4px #ff3d00); }
  40%           { opacity: 0.3; filter: drop-shadow(0 0 0 transparent); }
}

/* Block fall in (logo letters) */
@keyframes letterFall {
  0%   { opacity: 0; transform: translateY(-200%) rotate(-30deg); }
  60%  { opacity: 1; transform: translateY(20px) rotate(8deg); }
  80%  { transform: translateY(-8px) rotate(-3deg); }
  100% { transform: translateY(0) rotate(0); }
}

@keyframes letterFallLeft {
  0%   { opacity: 0; transform: translateX(-300%) rotate(-45deg); }
  60%  { opacity: 1; transform: translateX(30px) rotate(10deg); }
  80%  { transform: translateX(-8px) rotate(-3deg); }
  100% { transform: translateX(0) rotate(0); }
}

@keyframes letterFallRight {
  0%   { opacity: 0; transform: translateX(300%) rotate(45deg); }
  60%  { opacity: 1; transform: translateX(-30px) rotate(-10deg); }
  80%  { transform: translateX(8px) rotate(3deg); }
  100% { transform: translateX(0) rotate(0); }
}

@keyframes dustPuff {
  0%   { opacity: 0.8; transform: translate(0, 0) scale(0.5); }
  100% { opacity: 0; transform: translate(0, 30px) scale(1.4); }
}

/* Letter color shift */
@keyframes colorShiftYellow {
  0%, 100% { filter: drop-shadow(0 0 8px rgba(255, 215, 0, 0.5)); }
  50%      { filter: drop-shadow(0 0 16px rgba(255, 107, 0, 0.7)); }
}
@keyframes colorShiftBlue {
  0%, 100% { filter: drop-shadow(0 0 8px rgba(0, 229, 255, 0.5)); }
  50%      { filter: drop-shadow(0 0 16px rgba(41, 121, 255, 0.7)); }
}

/* Block floating in hero */
@keyframes blockFloat1 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  25%      { transform: translate(20px, -10px) rotate(8deg); }
  50%      { transform: translate(0, -20px) rotate(0); }
  75%      { transform: translate(-20px, -10px) rotate(-8deg); }
}

@keyframes blockFloat2 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50%      { transform: translate(-30px, 15px) rotate(15deg); }
}

@keyframes blockFloat3 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50%      { transform: translate(25px, -20px) rotate(-12deg); }
}

/* Scroll arrow bounce */
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 0.5; }
  50%      { transform: translateY(10px); opacity: 1; }
}

/* Letter reveal */
@keyframes letterReveal {
  from { opacity: 0; transform: translateY(20px) rotateX(-90deg); }
  to   { opacity: 1; transform: translateY(0) rotateX(0); }
}

/* Toast slide */
@keyframes toastIn {
  from { opacity: 0; transform: translateX(100px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastOut {
  to { opacity: 0; transform: translateX(100px); }
}

/* Section transitions */
@keyframes sectionReveal {
  from { opacity: 0; transform: translateY(60px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tool/Block float in OnlyPW section */
@keyframes toolFloat {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-20px) rotate(15deg); }
}

/* Card hover glow */
@keyframes cardGlow {
  0%, 100% { box-shadow: 0 0 30px rgba(0, 229, 255, 0.2), 0 0 60px rgba(0, 229, 255, 0.05); }
  50%      { box-shadow: 0 0 50px rgba(0, 229, 255, 0.4), 0 0 100px rgba(0, 229, 255, 0.1); }
}

/* Console typing */
@keyframes blink {
  50% { opacity: 0; }
}

/* Button shine */
@keyframes btnShine {
  from { transform: translateX(-100%); }
  to   { transform: translateX(100%); }
}

/* Page section divider (block-build) */
@keyframes blockBuild {
  from { clip-path: inset(0 0 100% 0); }
  to   { clip-path: inset(0 0 0 0); }
}
