@font-face {
  font-family: 'Orbitron';
  src: url('./fonts/orbitron.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Share Tech Mono';
  src: url('./fonts/share-tech-mono.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg-color: #0d0208;
  --neon-cyan: #00ffff;
  --neon-magenta: #ff00ff;
  --neon-yellow: #fefe33;
  --font-main: 'Orbitron', sans-serif;
  --font-mono: 'Share Tech Mono', monospace;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background-color: var(--bg-color);
  color: var(--neon-cyan);
  font-family: var(--font-main);
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  position: relative;
}

/* Scanlines Effect */
.scanlines {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    rgba(18, 16, 16, 0) 50%,
    rgba(0, 0, 0, 0.25) 50%
  ),
  linear-gradient(
    90deg,
    rgba(255, 0, 0, 0.06),
    rgba(0, 255, 0, 0.02),
    rgba(0, 0, 255, 0.06)
  );
  background-size: 100% 4px, 3px 100%;
  pointer-events: none;
  z-index: 10;
}

.container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  z-index: 5;
  text-align: center;
}

/* Glitch Text Effect */
.glitch {
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0.5rem;
  text-transform: uppercase;
  position: relative;
  text-shadow: 0.05em 0 0 var(--neon-magenta),
               -0.025em -0.05em 0 var(--neon-cyan),
               0.025em 0.05em 0 var(--neon-yellow);
  animation: glitch 1s infinite;
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.glitch::before {
  animation: glitch 650ms infinite;
  clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
  transform: translate(-0.025em, -0.0125em);
  opacity: 0.8;
}

.glitch::after {
  animation: glitch 375ms infinite;
  clip-path: polygon(0 80%, 100% 20%, 100% 100%, 0 100%);
  transform: translate(0.0125em, 0.025em);
  opacity: 0.8;
}

@keyframes glitch {
  0% {
    text-shadow: 0.05em 0 0 var(--neon-magenta), -0.05em -0.025em 0 var(--neon-cyan),
      -0.025em 0.05em 0 var(--neon-yellow);
  }
  14% {
    text-shadow: 0.05em 0 0 var(--neon-magenta), -0.05em -0.025em 0 var(--neon-cyan),
      -0.025em 0.05em 0 var(--neon-yellow);
  }
  15% {
    text-shadow: -0.05em -0.025em 0 var(--neon-magenta), 0.025em 0.025em 0 var(--neon-cyan),
      -0.05em -0.05em 0 var(--neon-yellow);
  }
  49% {
    text-shadow: -0.05em -0.025em 0 var(--neon-magenta), 0.025em 0.025em 0 var(--neon-cyan),
      -0.05em -0.05em 0 var(--neon-yellow);
  }
  50% {
    text-shadow: 0.025em 0.05em 0 var(--neon-magenta), 0.05em 0 0 var(--neon-cyan),
      0.05em -0.05em 0 var(--neon-yellow);
  }
  99% {
    text-shadow: 0.025em 0.05em 0 var(--neon-magenta), 0.05em 0 0 var(--neon-cyan),
      0.05em -0.05em 0 var(--neon-yellow);
  }
  100% {
    text-shadow: -0.025em 0 0 var(--neon-magenta), -0.025em -0.025em 0 var(--neon-cyan),
      -0.025em -0.05em 0 var(--neon-yellow);
  }
}

/* Input Styling */
.input-wrapper {
  position: relative;
  width: 300px;
}

input[type="password"] {
  width: 100%;
  padding: 15px 20px;
  background: transparent;
  border: 2px solid var(--neon-cyan);
  color: var(--neon-cyan);
  font-family: var(--font-mono);
  font-size: 1.2rem;
  letter-spacing: 2px;
  outline: none;
  transition: all 0.3s ease;
  box-shadow: 0 0 10px rgba(0, 255, 255, 0.2);
}

input[type="password"]::placeholder {
  color: rgba(0, 255, 255, 0.4);
  font-family: var(--font-mono);
}

input[type="password"]:focus {
  border-color: var(--neon-magenta);
  box-shadow: 0 0 20px rgba(255, 0, 255, 0.4),
              inset 0 0 10px rgba(255, 0, 255, 0.2);
  color: var(--neon-magenta);
}

/* Animated Border for Input */
.input-wrapper::after {
  content: '';
  position: absolute;
  top: -5px;
  left: -5px;
  right: -5px;
  bottom: -5px;
  border: 1px solid var(--neon-cyan);
  opacity: 0.3;
  pointer-events: none;
  transition: all 0.3s ease;
}

.input-wrapper:hover::after {
  opacity: 0.6;
  border-color: var(--neon-magenta);
  transform: scale(1.02);
}

/* CRT Flicker */
@keyframes flicker {
  0% { opacity: 0.97; }
  5% { opacity: 0.95; }
  10% { opacity: 0.9; }
  15% { opacity: 0.95; }
  20% { opacity: 0.98; }
  25% { opacity: 0.95; }
  30% { opacity: 0.9; }
  35% { opacity: 0.98; }
  40% { opacity: 0.95; }
  45% { opacity: 0.9; }
  50% { opacity: 0.98; }
  55% { opacity: 0.95; }
  60% { opacity: 0.98; }
  65% { opacity: 0.95; }
  70% { opacity: 0.9; }
  75% { opacity: 0.95; }
  80% { opacity: 0.98; }
  85% { opacity: 0.95; }
  90% { opacity: 0.9; }
  95% { opacity: 0.98; }
  100% { opacity: 0.95; }
}

body::before {
  content: " ";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.25) 50%), linear-gradient(90deg, rgba(255, 0, 0, 0.06), rgba(0, 255, 0, 0.02), rgba(0, 0, 255, 0.06));
  z-index: 2;
  background-size: 100% 2px, 3px 100%;
  pointer-events: none;
}

body::after {
  content: " ";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: rgba(18, 16, 16, 0.1);
  opacity: 0;
  z-index: 2;
  pointer-events: none;
  animation: flicker 0.15s infinite;
}
