/* ── futuristic.css — board zoom viewport + elite motion polish ─────────────── */

/* Zoom viewport: the board's existing parent, now clipping the transformed
   board and giving it depth (we don't move the board in the DOM). */
.board-zoom-viewport {
  position: relative;
  overflow: hidden;
  touch-action: none;                 /* we own pinch/scroll gestures */
}
.board-zoom-viewport.is-zoomed { cursor: grab; }
.board-zoom-viewport.bz-grabbing { cursor: grabbing; }

.board-zoom-target { will-change: transform; }

/* Holds get a subtle glow + spring on hover (feels alive, not flat). */
.board-zoom-target .hold {
  transition: filter .18s ease, transform .18s cubic-bezier(.16,1,.3,1);
}
.board-zoom-target .hold:hover {
  filter: drop-shadow(0 0 6px rgba(0,229,200,.85)) brightness(1.15);
  transform: scale(1.18);
  z-index: 5;
}

/* Zoom HUD — glassy neon chip, bottom-right of the wall. */
.board-zoom-hud {
  position: absolute; right: 12px; bottom: 12px; z-index: 20;
  display: flex; align-items: center; gap: 2px;
  padding: 4px; border-radius: 12px;
  background: rgba(8,14,18,.62);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(0,229,200,.22);
  box-shadow: 0 6px 22px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.03) inset;
  opacity: .55; transition: opacity .25s ease;
}
.board-zoom-viewport:hover .board-zoom-hud,
.board-zoom-viewport.is-zoomed .board-zoom-hud { opacity: 1; }

.board-zoom-hud .bz-btn {
  width: 28px; height: 28px; border: none; border-radius: 8px;
  background: transparent; color: #cfeee9; font-size: 16px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .15s ease, color .15s ease, transform .1s ease;
}
.board-zoom-hud .bz-btn:hover { background: rgba(0,229,200,.16); color: #00E5C8; }
.board-zoom-hud .bz-btn:active { transform: scale(.9); }
.board-zoom-hud .bz-reset { font-size: 13px; }
.board-zoom-hud .bz-pct {
  min-width: 42px; text-align: center; font-size: 11px; font-weight: 700;
  color: #8fb7b1; font-family: 'Space Mono', monospace; letter-spacing: .02em;
}

/* ── Elite micro-motion across the app (additive, respects reduced-motion) ──── */
@media (prefers-reduced-motion: no-preference) {
  /* Cards / route rows lift toward you on hover. */
  .rc-card, .route-card, .metric, .jump-card, .friend-row, .pitch-card {
    transition: transform .22s cubic-bezier(.16,1,.3,1), box-shadow .22s ease, border-color .22s ease;
  }
  .rc-card:hover, .route-card:hover, .jump-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0,0,0,.35);
  }
  /* Primary buttons get a soft neon push. */
  .btn-primary, .pricing-cta.primary, .nav-cta {
    transition: transform .15s ease, box-shadow .25s ease, filter .2s ease;
  }
  .btn-primary:hover, .pricing-cta.primary:hover, .nav-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 26px rgba(0,229,200,.28);
  }
}
