@keyframes flicker {
  0%    { opacity: 0.27861; }
  5%    { opacity: 0.34769; }
  10%   { opacity: 0.23604; }
  15%   { opacity: 0.90626; }
  20%   { opacity: 0.18128; }
  25%   { opacity: 0.83891; }
  30%   { opacity: 0.65583; }
  35%   { opacity: 0.67807; }
  40%   { opacity: 0.26559; }
  45%   { opacity: 0.84693; }
  50%   { opacity: 0.96019; }
  55%   { opacity: 0.08594; }
  60%   { opacity: 0.20313; }
  65%   { opacity: 0.71988; }
  70%   { opacity: 0.53455; }
  75%   { opacity: 0.37288; }
  80%   { opacity: 0.71428; }
  85%   { opacity: 0.70419; }
  90%   { opacity: 0.70031; }
  95%   { opacity: 0.36108; }
  100%  { opacity: 0.24387; }
}
@keyframes textShadow {
  0%    { text-shadow: 0.43899241933008640px 0 1px rgba(0,30,255,0.5), -0.438992419330086400px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  5%    { text-shadow: 2.79289740107882170px 0 1px rgba(0,30,255,0.5), -2.792897401078821700px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  10%   { text-shadow: 0.02956275843481219px 0 1px rgba(0,30,255,0.5), -0.029562758434812190px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  15%   { text-shadow: 0.40218538552878136px 0 1px rgba(0,30,255,0.5), -0.402185385528781360px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  20%   { text-shadow: 3.47940378998520170px 0 1px rgba(0,30,255,0.5), -3.479403789985201700px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  25%   { text-shadow: 1.61256304011495840px 0 1px rgba(0,30,255,0.5), -1.612563040114958400px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  30%   { text-shadow: 0.70155900851439560px 0 1px rgba(0,30,255,0.5), -0.701559008514395600px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  35%   { text-shadow: 3.89691404765035100px 0 1px rgba(0,30,255,0.5), -3.896914047650351000px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  40%   { text-shadow: 3.87090561484881900px 0 1px rgba(0,30,255,0.5), -3.870905614848819000px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  45%   { text-shadow: 2.23105696336189900px 0 1px rgba(0,30,255,0.5), -2.231056963361899000px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  50%   { text-shadow: 0.08084290417898504px 0 1px rgba(0,30,255,0.5), -0.080842904178985040px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  55%   { text-shadow: 2.37584610674275430px 0 1px rgba(0,30,255,0.5), -2.375846106742754300px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  60%   { text-shadow: 2.20219305105063600px 0 1px rgba(0,30,255,0.5), -2.202193051050636000px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  65%   { text-shadow: 2.86387806148749750px 0 1px rgba(0,30,255,0.5), -2.863878061487497500px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  70%   { text-shadow: 0.48874025155497314px 0 1px rgba(0,30,255,0.5), -0.488740251554973140px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  75%   { text-shadow: 1.89484913057579570px 0 1px rgba(0,30,255,0.5), -1.894849130575795700px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  80%   { text-shadow: 0.08330373080388570px 0 1px rgba(0,30,255,0.5), -0.083303730803885700px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  85%   { text-shadow: 0.09769827255241735px 0 1px rgba(0,30,255,0.5), -0.097698272552417350px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  90%   { text-shadow: 3.44333976148178200px 0 1px rgba(0,30,255,0.5), -3.443339761481782000px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  95%   { text-shadow: 2.18418388527997860px 0 1px rgba(0,30,255,0.5), -2.184183885279978600px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
  100%  { text-shadow: 2.62087644738325130px 0 1px rgba(0,30,255,0.5), -2.620876447383251300px 0 1px rgba(255,0,80,0.3), 0 0 3px; }
}

.crt::after,.crt::before {
  content: " ";
  display: block;
  position: absolute;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;

  z-index: 999;
  pointer-events: none;
}

.crt::after {
  background: rgba(18, 16, 16, 0.1);
  opacity: 0;
  
  animation: flicker 0.15s infinite;
}
.crt::before {
  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, 6px 100%;
}
.crt {
  text-shadow: 2.6208764473832513px 0 1px rgba(0,30,255,0.5), -2.6208764473832513px 0 1px rgba(255,0,80,0.3), 0 0 3px;
  animation: textShadow 1.6s infinite;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
  }
}

.crt::after {
    animation: none;
}

.crt {
    animation: none;
}

.crt a:hover {
    animation: textShadow 1.6s infinite;
}
