/* ═══════════════════════════════════════════════════════════════════
   Loomiel Radar Loader — standalone stylesheet
   ───────────────────────────────────────────────────────────────────
   Drop-in loading indicator that matches the Loomiel brand: terminal
   green, monospace caption, a slow sweep wedge that evokes "narrative
   formation scanning."

   Markup:
     <span class="loomiel-radar loomiel-radar--md">
       <span class="lr-cross"></span>
       <span class="lr-sweep"></span>
       <span class="lr-ping"></span>
       <span class="lr-dot"></span>
     </span>
     <span class="loomiel-radar-caption">Scanning</span>

   Sizes: --sm (40 px), default (72 px), --lg (112 px).

   --font-mono fallback: 'JetBrains Mono' if --font-mono CSS var is
   not provided by the host page.
   ─────────────────────────────────────────────────────────────────── */

.loomiel-radar {
  --radar-color: rgba(61, 255, 180, 0.85);
  --radar-color-dim: rgba(61, 255, 180, 0.22);
  --radar-bg: rgba(61, 255, 180, 0.04);
  display: inline-block;
  position: relative;
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--radar-bg);
  box-shadow: 0 0 0 1px var(--radar-color-dim), inset 0 0 12px rgba(61,255,180,0.06);
}
.loomiel-radar--sm { width: 40px; height: 40px; }
.loomiel-radar--lg { width: 112px; height: 112px; }

.loomiel-radar::before, .loomiel-radar::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 50%;
  pointer-events: none;
}
.loomiel-radar::before {
  inset: 16%;
  border: 1px solid var(--radar-color-dim);
}
.loomiel-radar::after {
  inset: 36%;
  border: 1px solid var(--radar-color-dim);
}

.loomiel-radar > .lr-cross {
  position: absolute; inset: 0;
  pointer-events: none;
}
.loomiel-radar > .lr-cross::before,
.loomiel-radar > .lr-cross::after {
  content: '';
  position: absolute;
  background: var(--radar-color-dim);
}
.loomiel-radar > .lr-cross::before {
  left: 0; right: 0; top: 50%;
  height: 1px;
  transform: translateY(-0.5px);
}
.loomiel-radar > .lr-cross::after {
  top: 0; bottom: 0; left: 50%;
  width: 1px;
  transform: translateX(-0.5px);
}

.loomiel-radar > .lr-dot {
  position: absolute;
  width: 5px; height: 5px;
  left: 50%; top: 50%;
  margin-left: -2.5px; margin-top: -2.5px;
  border-radius: 50%;
  background: var(--radar-color);
  box-shadow: 0 0 6px var(--radar-color);
  pointer-events: none;
}

.loomiel-radar > .lr-sweep {
  position: absolute; inset: 0;
  border-radius: 50%;
  pointer-events: none;
  background: conic-gradient(
    from 0deg,
    transparent 0deg,
    transparent 270deg,
    rgba(61,255,180,0.08) 300deg,
    rgba(61,255,180,0.28) 340deg,
    rgba(61,255,180,0.85) 360deg
  );
  -webkit-mask: radial-gradient(circle, black 0 100%);
          mask: radial-gradient(circle, black 0 100%);
  animation: loomielRadarSweep 1.8s linear infinite;
}
@keyframes loomielRadarSweep {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.loomiel-radar > .lr-ping {
  position: absolute; inset: 0;
  border-radius: 50%;
  pointer-events: none;
  border: 1px solid rgba(61,255,180,0.5);
  opacity: 0;
  animation: loomielRadarPing 1.8s ease-out infinite;
}
@keyframes loomielRadarPing {
  0%   { transform: scale(0.5); opacity: 0; }
  10%  { opacity: 0.7; }
  60%  { opacity: 0.25; }
  100% { transform: scale(1.05); opacity: 0; }
}

.loomiel-radar-caption {
  margin-top: 10px;
  font-family: var(--font-mono, 'JetBrains Mono', monospace);
  font-size: 10px;
  letter-spacing: 1.5px;
  color: rgba(61,255,180,0.55);
  text-transform: uppercase;
  text-align: center;
}
.loomiel-radar-caption::after {
  content: '...';
  display: inline-block;
  width: 1.5em; text-align: left;
  animation: loomielRadarDots 1.5s steps(4, end) infinite;
  overflow: hidden;
  vertical-align: bottom;
}
@keyframes loomielRadarDots {
  0%   { width: 0; }
  100% { width: 1.5em; }
}

@media (prefers-reduced-motion: reduce) {
  .loomiel-radar > .lr-sweep,
  .loomiel-radar > .lr-ping,
  .loomiel-radar-caption::after {
    animation: none;
  }
  .loomiel-radar > .lr-sweep {
    background: conic-gradient(
      from 0deg,
      transparent 0deg,
      rgba(61,255,180,0.25) 300deg,
      rgba(61,255,180,0.65) 360deg
    );
  }
}

/* Convenience: a radar-empty container that centers the radar + caption
   in a flex column. Use as the wrapper class on any "loading" empty
   state — e.g. <div class="radar-empty"><span class="loomiel-radar">...
   <span class="loomiel-radar-caption">…</span></div> */
.radar-empty {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 16px;
  min-height: 240px;
  padding: 32px 16px;
  text-align: center;
}
