/* ── loader.css — Page loader overlay styles ── */

#loader {
  position: fixed;
  inset: 0;
  background: var(--black);
  z-index: 10000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  transition: transform 0.95s cubic-bezier(0.76, 0, 0.24, 1);
}
#loader.loader-exit {
  transform: translateY(-100%);
}
#loader-logo {
  height: 52px;
  width: auto;
  opacity: 0;
  transform: translateY(12px);
  animation: heroFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.15s forwards;
}
#loader-track {
  width: min(220px, 65vw);
  height: 1px;
  background: var(--gray-border);
  position: relative;
  overflow: hidden;
}
#loader-fill {
  position: absolute;
  inset: 0;
  background: var(--neon);
  box-shadow: 0 0 10px rgba(221, 251, 0, 0.5);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}
#loader-label {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #444;
  opacity: 0;
  animation: heroFadeIn 0.4s ease 0.3s forwards;
}
