/* ============================================
   LOADER
   ============================================ */

#loader {
  position: fixed;
  inset: 0;
  z-index: 9997;
  /* No background — body provides #050508, canvas (z:2) shows through */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* Clip mask — slides up on exit */
#loader .loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.5rem;
}

/* Name block */
.loader-name {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  line-height: 0.9;
  overflow: hidden;
}

.loader-name-line {
  display: block;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(3.5rem, 11vw, 10rem);
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--color-text);
  overflow: hidden;
  opacity: 0;
}

/* Revealed by JS after char-splitting; GSAP then animates the chars */
.loader-name-line.chars-ready {
  opacity: 1;
}

/* Each char is wrapped in a span for animation */
.loader-name-line .char {
  display: inline-block;
  will-change: transform, opacity;
}

/* Bottom bar: counter + line */
.loader-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  width: clamp(200px, 30vw, 400px);
}

.loader-counter {
  font-family: var(--font-mono);
  font-size: var(--text-label);
  letter-spacing: 0.3em;
  color: var(--color-text-muted);
  text-transform: uppercase;
  align-self: flex-start;
  font-feature-settings: 'tnum';
  min-width: 3ch;
}

.loader-track {
  width: 100%;
  height: 1px;
  background: var(--color-border);
  position: relative;
  overflow: hidden;
}

.loader-fill {
  position: absolute;
  inset: 0;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left center;
  will-change: transform;
}

/* Tagline below */
.loader-tagline {
  font-family: var(--font-mono);
  font-size: var(--text-caption);
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  opacity: 0;
}
