/* Animations */
@keyframes gridMove {
    0% { transform: translate(0, 0); }
    100% { transform: translate(100px, 100px); }
}

@keyframes glitch {
    0% { transform: translate(0); }
    20% { transform: translate(-2px, 2px); }
    40% { transform: translate(-2px, -2px); }
    60% { transform: translate(2px, 2px); }
    80% { transform: translate(2px, -2px); }
    100% { transform: translate(0); }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes scanIn {
    0% { transform: scale(0.8); opacity: 0; filter: blur(5px); }
    50% { transform: scale(1.1); filter: blur(0); }
    100% { transform: scale(1); opacity: 1; }
}

@keyframes slideUp {
    from { transform: translateY(50px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

@keyframes scroll {
    0% { transform: translateY(0); opacity: 1; }
    50% { transform: translateY(15px); opacity: 0.5; }
    100% { transform: translateY(0); opacity: 1; }
}

@keyframes cyber-text-animation {
  0%   { clip: rect(0.9em, 100em, 1.8em, 0); }
  5%   { clip: rect(1.5em, 100em, 1.1em, 0); }
  10%  { clip: rect(0.3em, 100em, 1em, 0); }
  15%  { clip: rect(1.2em, 100em, 0.4em, 0); }
  20%  { clip: rect(0.2em, 100em, 0.9em, 0); }
  25%  { clip: rect(0.25em, 100em, 1em, 0); }
  30%  { clip: rect(1.3em, 100em, 0.9em, 0); }
  35%  { clip: rect(0.6em, 100em, 1.4em, 0); }
  40%  { clip: rect(0.4em, 100em, 1em, 0); }
  45%  { clip: rect(1em, 100em, 1.2em, 0); }
  50%  { clip: rect(0.2em, 100em, 0.5em, 0); }
  55%  { clip: rect(0.6em, 100em, 1.1em, 0); }
  60%  { clip: rect(1em, 100em, 0.7em, 0); }
  65%  { clip: rect(0.9em, 100em, 0.9em, 0); }
  70%  { clip: rect(1.2em, 100em, 1em, 0); }
  75%  { clip: rect(0.2em, 100em, 0.25em, 0); }
  80%  { clip: rect(0.7em, 100em, 0.6em, 0); }
  85%  { clip: rect(0.6em, 100em, 0.5em, 0); }
  90%  { clip: rect(0.7em, 100em, 0.7em, 0); }
  95%  { clip: rect(1.6em, 100em, 0.7em, 0); }
  100% { clip: rect(1.5em, 100em, 1.5em, 0); }
}

@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}

.fade-in {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}


.transi-left {
    opacity: 0;
    filter: blur(5px);
    transition: all 1.2s;
    transform: translateX(-25%);
}

.transi-left-visible {
    opacity: 1;
    filter: blur(0);
    transform: translateX(0);
}

.bug {
    opacity: 0;
    box-shadow: 0;
}


.glitched-text {
  position: relative;
}

.glitched-text::after {
  position: absolute;
  top: 0;
  left: 0.05em;
  overflow: hidden;
  color: var(--neon-blue);
  content: attr(data-text);
  background-color: var(--bg-dark);
  white-space: pre; 
  text-shadow: -1px 0 rgb(0, 0, 250);
  clip: rect(0, 900px, 0, 0);
  animation: cyber-text-animation 3s infinite linear alternate-reverse;
}

.glitched-text-about {
  position: relative;
}

.glitched-text-about::after {
  position: absolute;
  top: 0;
  left: 0.05em;
  overflow: hidden;
  color: var(--neon-blue);
  content: attr(data-text);
  background-color: #1E2028;
  white-space: pre; 
  text-shadow: -1px 0 rgb(0, 0, 250);
  clip: rect(0, 900px, 0, 0);
  animation: cyber-text-animation 3s infinite linear alternate-reverse;
}

.glitched-text-yellow {
  position: relative;
}

.glitched-text-yellow::after {
  position: absolute;
  top: 0;
  left: 0.05em;
  overflow: hidden;
  color: var(--neon-yellow);
  content: attr(data-text);
  white-space: pre; 
  text-shadow: -1px 0 rgb(180,0,250);
  clip: rect(0, 900px, 0, 0);
  animation: cyber-text-animation 2s infinite linear alternate-reverse;
}

.hidden {
    opacity: 0;
    filter: blur(5px);
    transition: opacity 0.7s ease-out, transform 0.7s ease-out;
    transform: translateY(100px);
}

.hidden.faq-item {
  transition-delay: 0.3s;
}

.show {
    opacity: 1;
    filter: blur(0);
    transform: translateX(0);
}

.tempoHero:nth-child(1) {
    transition-delay: 2.10s;
}
.tempoHero:nth-child(2) {
    transition-delay: 2.50s;
}
.tempoHero:nth-child(3) {
    transition-delay: 2.80s;
}
.tempoHero:nth-child(4) {
    transition-delay: 3.20s;
}
.tempoHero:nth-child(5) {
    transition-delay: 3.60s;
}