/* loader.css */
body {
  margin: 0;
  padding: 0;
  background: black;
  font-family: 'Courier New', monospace;
  color: white;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  flex-direction: column;
}

#logo {
  width: 180px;
  height: auto;
  image-rendering: pixelated;
  margin-bottom: 1rem;
  animation: logoGlitch 1s infinite steps(2, end);
}

h2 {
  margin: 0.5rem 0;
  font-weight: 400;
  font-size: 1.5rem;
  color: #ff0000;
}

#loading-text {
  font-size: 1.2rem;
  margin-bottom: 1rem;
  letter-spacing: 2px;
  animation: textGlitch 1s infinite steps(2, end);
}

#progress-bar {
  width: 200px;
  height: 10px;
  border: 1px solid white;
  margin-top: 1rem;
  position: relative;
  background-color: transparent;
}

#progress-fill {
  height: 100%;
  width: 0%;
  background-color: #ff0000;
  transition: width 0.1s linear;
}

.glitch-out {
  animation: glitchFade 0.8s steps(2, end) forwards;
}

@keyframes glitchFade {
  0% { transform: scale(1); opacity: 1; filter: contrast(1) hue-rotate(0deg); }
  30% { transform: scale(1.01); filter: hue-rotate(20deg); }
  50% { transform: scale(0.98); filter: contrast(1.2) hue-rotate(-20deg); }
  70% { transform: scale(1.03); filter: hue-rotate(45deg); }
  100% { transform: scale(1.05); opacity: 0; filter: grayscale(1); }
}

@keyframes logoGlitch {
  0%, 100% { transform: none; }
  20% { transform: translateX(1px) skewX(5deg); }
  40% { transform: translateX(-1px) skewX(-5deg); }
  60% { transform: translateY(1px); }
  80% { transform: translateY(-1px); }
}

@keyframes textGlitch {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; transform: translateX(-1px); }
}