html.cult-orb-gesture-lock,
body.cult-orb-gesture-lock {
  overflow: hidden;
  overscroll-behavior: none;
  touch-action: none;
}

.bookshelves-orb {
  --bookshelves-orb-x: 0px;
  --bookshelves-orb-y: 0px;
  --bookshelves-orb-scale: 1;
  --bookshelves-orb-hover-scale: 1;
  --bookshelves-orb-rotation: 0deg;
  --bookshelves-orb-hue-rotate: 0deg;
  --bookshelves-orb-saturate: 1;
  --bookshelves-orb-depth-scale: 1;
  position: fixed;
  left: 50%;
  top: 50%;
  width: clamp(76px, 9vw, 118px);
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  z-index: 3310;
  transform:
    translate(-50%, -50%)
    translate3d(var(--bookshelves-orb-x), var(--bookshelves-orb-y), 0)
    rotate(var(--bookshelves-orb-rotation))
    scale(calc(var(--bookshelves-orb-scale) * var(--bookshelves-orb-hover-scale)));
  transform-origin: center center;
  transition: opacity 0.18s ease;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: none;
  user-select: none;
}

.bookshelves-orb.is-docked:hover,
.bookshelves-orb.is-docked:focus-visible {
  --bookshelves-orb-hover-scale: 1.04;
}

.bookshelves-orb:focus-visible {
  outline: 2px solid rgba(162, 232, 255, 0.9);
  outline-offset: 4px;
}

.bookshelves-orb.is-transitioning {
  transition: transform 0.82s cubic-bezier(0.2, 0.72, 0.18, 1), opacity 0.18s ease;
}

.bookshelves-orb.is-free,
.bookshelves-orb.is-undocked {
  cursor: grab;
}

.bookshelves-orb.is-grabbing {
  cursor: grabbing;
}

.bookshelves-orb-shell {
  position: relative;
  display: block;
  width: 100%;
  transform-origin: center bottom;
  filter: hue-rotate(var(--bookshelves-orb-hue-rotate)) saturate(var(--bookshelves-orb-saturate));
  transition: transform 0.18s ease, filter 0.22s ease;
}

.bookshelves-orb.is-docked .bookshelves-orb-shell {
  animation: bookshelves-orb-bob 4.8s ease-in-out infinite;
}

.bookshelves-orb.is-docked.is-entering .bookshelves-orb-shell {
  animation:
    bookshelves-orb-rise 0.9s cubic-bezier(0.2, 0.72, 0.18, 1) both,
    bookshelves-orb-bob 4.8s ease-in-out 0.9s infinite;
}

.bookshelves-orb.is-docked:hover .bookshelves-orb-shell,
.bookshelves-orb.is-docked:focus-visible .bookshelves-orb-shell {
  transform: scale(1.04);
  animation-play-state: paused;
}

.bookshelves-orb-shell::before {
  content: "";
  position: absolute;
  inset: 4% 4% 1%;
  border-radius: 50%;
  background:
    radial-gradient(circle,
      rgba(214, 250, 255, 0.88) 0%,
      rgba(146, 224, 255, 0.62) 24%,
      rgba(108, 173, 255, 0.34) 46%,
      rgba(86, 116, 255, 0.16) 62%,
      rgba(67, 92, 255, 0.06) 74%,
      transparent 84%);
  filter: blur(28px);
  transform: scale(calc(1.3 * var(--bookshelves-orb-depth-scale)));
  opacity: 1;
  mix-blend-mode: screen;
  pointer-events: none;
  animation: bookshelves-orb-glow-pulse 3.4s ease-in-out infinite;
  transition: transform 0.12s ease;
}

.bookshelves-orb-image {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.34));
  transform: scale(var(--bookshelves-orb-depth-scale));
  transform-origin: center center;
  transition: transform 0.12s ease;
  user-select: none;
  -webkit-user-drag: none;
}

.bookshelves-orb.is-dribbling .bookshelves-orb-image {
  animation: bookshelves-orb-dribble 0.6s cubic-bezier(0.22, 0.88, 0.24, 1);
}

.bookshelves-orb-label {
  position: absolute;
  left: 50%;
  top: calc(100% + 12px);
  z-index: 2;
  padding: 0;
  color: rgba(232, 244, 255, 0.94);
  font: 700 13px/1 "Courier New", Courier, monospace;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.45);
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, 8px);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.bookshelves-orb.is-docked:hover .bookshelves-orb-label,
.bookshelves-orb.is-docked:focus-visible .bookshelves-orb-label {
  opacity: 1;
  transform: translate(-50%, 0);
}

.bookshelves-orb-dock-target {
  --bookshelves-orb-dock-x: 0px;
  --bookshelves-orb-dock-y: 0px;
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 3308;
  width: calc(clamp(76px, 9vw, 118px) + 12px);
  aspect-ratio: 1;
  border: 2px dotted rgba(219, 237, 255, 0.58);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(185, 221, 255, 0.08) 0%, rgba(185, 221, 255, 0.02) 54%, transparent 68%);
  box-shadow: 0 0 0 1px rgba(144, 198, 255, 0.08);
  pointer-events: none;
  opacity: 0;
  transform:
    translate(-50%, -50%)
    translate3d(var(--bookshelves-orb-dock-x), var(--bookshelves-orb-dock-y), 0)
    scale(0.94);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.bookshelves-orb-dock-target.is-active {
  opacity: 0.92;
  transform:
    translate(-50%, -50%)
    translate3d(var(--bookshelves-orb-dock-x), var(--bookshelves-orb-dock-y), 0)
    scale(1);
}

.bookshelves-orb-controls {
  position: fixed;
  right: clamp(16px, 3vw, 34px);
  bottom: clamp(16px, 3vh, 28px);
  z-index: 997;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  pointer-events: none;
}

.bookshelves-orb-reset,
.bookshelves-put-back {
  pointer-events: auto;
  appearance: none;
  font: 700 13px/1 "Courier New", Courier, monospace;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(8px);
  transition:
    opacity 0.24s ease,
    transform 0.24s ease,
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}

.bookshelves-orb-reset {
  padding: 8px 12px;
  border: 1px solid rgba(195, 214, 255, 0.24);
  border-radius: 999px;
  background: rgba(6, 11, 20, 0.48);
  color: rgba(220, 231, 248, 0.88);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
}

.bookshelves-orb-reset.is-active,
.bookshelves-put-back.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.bookshelves-orb-reset:hover,
.bookshelves-orb-reset:focus-visible,
.bookshelves-put-back:hover,
.bookshelves-put-back:focus-visible {
  background: rgba(18, 28, 48, 0.86);
  border-color: rgba(201, 230, 255, 0.62);
}

.bookshelves-orb-reset:focus-visible,
.bookshelves-put-back:focus-visible {
  outline: 2px solid rgba(162, 232, 255, 0.9);
  outline-offset: 3px;
}

.bookshelves-put-back {
  padding: 10px 14px;
  border: 1px solid rgba(201, 230, 255, 0.38);
  border-radius: 999px;
  background: rgba(6, 11, 20, 0.72);
  color: rgba(232, 244, 255, 0.96);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
}

.bookshelves-put-back:disabled {
  opacity: 0.72;
  cursor: default;
}

.bookshelves-orb.bookshelves-ui-idle-hidden {
  opacity: 0;
  pointer-events: none;
}

@keyframes bookshelves-orb-rise {
  0% {
    opacity: 0;
    transform: translateY(132%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes bookshelves-orb-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

@keyframes bookshelves-orb-glow-pulse {
  0%,
  100% {
    transform: scale(1.24);
    opacity: 0.88;
  }
  50% {
    transform: scale(1.42);
    opacity: 1;
  }
}

@keyframes bookshelves-orb-dribble {
  0% {
    transform: scale(1);
  }
  18% {
    transform: scale(0.76);
  }
  38% {
    transform: scale(1.08);
  }
  56% {
    transform: scale(0.88);
  }
  76% {
    transform: scale(1.03);
  }
  100% {
    transform: scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .bookshelves-orb-shell {
    animation: none;
  }
}
