.baby-boo-scope {
  position: relative;
}

.baby-boo {
  --baby-boo-flip: 1;
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  position: absolute;
  z-index: 32;
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  width: var(--baby-boo-size, clamp(128px, 10.5vw, 160px));
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  overflow: visible;
}

.baby-boo:focus-visible {
  outline: none;
}

.baby-boo__figure {
  position: relative;
  z-index: 2;
  width: 100%;
  transform-origin: center bottom;
  animation: baby-boo-float 4.8s ease-in-out infinite;
  transition:
    filter 0.26s var(--ease-out),
    transform 0.2s var(--ease-out);
  filter: drop-shadow(0 18px 28px rgba(0, 0, 0, 0.18));
  will-change: transform;
}

.baby-boo:hover .baby-boo__figure {
  filter: drop-shadow(0 22px 34px rgba(0, 0, 0, 0.22));
}

.baby-boo__figure img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
  transform-origin: center bottom;
  will-change: transform;
}

.baby-boo__pulse {
  position: absolute;
  left: 50%;
  bottom: 7%;
  z-index: 1;
  width: 52%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(141, 113, 80, 0.26) 0%, rgba(141, 113, 80, 0.08) 48%, transparent 72%);
  opacity: 0;
  transform: translateX(-50%) scale(0.42);
  pointer-events: none;
}

.baby-boo__bubble {
  --bubble-start-x: -16px;
  --bubble-overshoot-x: 4px;
  position: absolute;
  top: 0.45rem;
  z-index: 3;
  width: max-content;
  max-width: min(18rem, 42vw);
  min-width: 10rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(141, 113, 80, 0.28);
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(247, 241, 231, 0.97));
  box-shadow:
    0 18px 32px rgba(53, 42, 22, 0.14),
    0 0 0 1px rgba(255, 255, 255, 0.68) inset;
  color: var(--navy);
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: -0.01em;
  white-space: normal;
  text-align: left;
  opacity: 0;
  pointer-events: none;
  filter: blur(8px);
  will-change: transform, opacity, filter;
  transition:
    opacity 0.24s var(--ease),
    transform 0.28s var(--ease-out),
    filter 0.26s var(--ease);
}

.baby-boo--bubble-right .baby-boo__bubble {
  --bubble-start-x: -20px;
  --bubble-overshoot-x: 6px;
  left: calc(100% - 0.35rem);
  transform: translate3d(var(--bubble-start-x), 22px, 0) scale(0.62);
  transform-origin: left bottom;
}

.baby-boo--bubble-right .baby-boo__bubble::after {
  content: '';
  position: absolute;
  left: -7px;
  bottom: 1.15rem;
  width: 14px;
  height: 14px;
  background: rgba(248, 243, 235, 0.98);
  border-left: 1px solid rgba(141, 113, 80, 0.28);
  border-bottom: 1px solid rgba(141, 113, 80, 0.28);
  transform: rotate(45deg);
}

.baby-boo--bubble-left .baby-boo__bubble {
  --bubble-start-x: 20px;
  --bubble-overshoot-x: -6px;
  right: calc(100% - 0.25rem);
  transform: translate3d(var(--bubble-start-x), 22px, 0) scale(0.62);
  transform-origin: right bottom;
}

.baby-boo--bubble-left .baby-boo__bubble::after {
  content: '';
  position: absolute;
  right: -7px;
  bottom: 1.15rem;
  width: 14px;
  height: 14px;
  background: rgba(248, 243, 235, 0.98);
  border-right: 1px solid rgba(141, 113, 80, 0.28);
  border-top: 1px solid rgba(141, 113, 80, 0.28);
  transform: rotate(45deg);
}

.baby-boo.is-open .baby-boo__bubble {
  opacity: 1;
  filter: blur(0);
}

.baby-boo.is-open.baby-boo--bubble-right .baby-boo__bubble,
.baby-boo.is-open.baby-boo--bubble-left .baby-boo__bubble {
  transform: translate3d(0, 0, 0) scale(1);
}

.baby-boo.is-bubble-popping .baby-boo__bubble {
  animation: baby-boo-bubble-pop 0.52s var(--ease-spring) both;
}

.baby-boo.is-pumping .baby-boo__figure {
  animation: baby-boo-pump 0.74s var(--ease-spring) both;
}

.baby-boo.is-pumping .baby-boo__figure img {
  animation: baby-boo-squash 0.74s var(--ease-spring) both;
}

.baby-boo.is-pumping .baby-boo__pulse {
  animation: baby-boo-pulse 0.82s ease-out;
}

.quick-menu-stage.baby-boo-scope--quick {
  overflow: visible;
}

.baby-boo--quick {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  left: clamp(-7.4rem, -5.4vw, -4.6rem);
  bottom: 0.55rem;
}

.server-gallery-stage {
  position: relative;
}

.baby-boo--gallery {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  right: clamp(-4.8rem, -3.4vw, -2.2rem);
  bottom: -0.7rem;
}

.map-layout.baby-boo-scope--map {
  position: relative;
  padding-left: clamp(5rem, 7.4vw, 6.8rem);
  padding-bottom: 1.15rem;
}

.baby-boo--map {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  left: clamp(-3.5rem, -2.6vw, -1.5rem);
  bottom: -0.2rem;
}

@keyframes baby-boo-float {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scaleX(var(--baby-boo-flip));
  }
  50% {
    transform: translate3d(0, -8px, 0) scaleX(var(--baby-boo-flip));
  }
}

@keyframes baby-boo-pump {
  0% {
    transform: translate3d(0, 0, 0) scaleX(var(--baby-boo-flip)) scale(1);
  }
  18% {
    transform: translate3d(0, -10px, 0) scaleX(var(--baby-boo-flip)) scale(1.12);
  }
  42% {
    transform: translate3d(0, 1px, 0) scaleX(var(--baby-boo-flip)) scale(0.92);
  }
  66% {
    transform: translate3d(0, -4px, 0) scaleX(var(--baby-boo-flip)) scale(1.04);
  }
  100% {
    transform: translate3d(0, 0, 0) scaleX(var(--baby-boo-flip)) scale(1);
  }
}

@keyframes baby-boo-squash {
  0% {
    transform: scale(1);
  }
  18% {
    transform: scale(0.96, 1.08);
  }
  42% {
    transform: scale(1.06, 0.92);
  }
  66% {
    transform: scale(0.985, 1.02);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes baby-boo-pulse {
  0% {
    opacity: 0;
    transform: translateX(-50%) scale(0.38);
  }
  26% {
    opacity: 0.68;
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) scale(1.85);
  }
}

@keyframes baby-boo-bubble-pop {
  0% {
    opacity: 0;
    filter: blur(8px);
    transform: translate3d(var(--bubble-start-x), 24px, 0) scale(0.58);
  }
  64% {
    opacity: 1;
    filter: blur(0);
    transform: translate3d(var(--bubble-overshoot-x), -3px, 0) scale(1.06);
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@media (max-width: 1024px) {
  .baby-boo__bubble {
    max-width: min(16rem, 52vw);
  }
}

@media (max-width: 768px) {
  .baby-boo {
    --baby-boo-size: 104px;
  }

  .quick-menu-stage.baby-boo-scope--quick {
    padding-bottom: 5.7rem;
  }

  .baby-boo--quick {
    --baby-boo-flip: -1;
    right: 0.2rem;
    left: auto;
    bottom: 0.15rem;
  }

  .baby-boo--quick .baby-boo__bubble {
    left: auto;
    right: calc(100% - 0.35rem);
    transform: translate3d(18px, 22px, 0) scale(0.62);
    transform-origin: right bottom;
  }

  .baby-boo--quick .baby-boo__bubble::after {
    left: auto;
    right: -7px;
    border-left: none;
    border-bottom: none;
    border-right: 1px solid rgba(141, 113, 80, 0.28);
    border-top: 1px solid rgba(141, 113, 80, 0.28);
  }

  .server-gallery-stage {
    padding-bottom: 5.4rem;
  }

  .baby-boo--gallery {
    right: -0.1rem;
    bottom: 0.15rem;
  }

  .map-layout.baby-boo-scope--map {
    padding-top: 5.5rem;
    padding-left: 0;
    padding-bottom: 0.35rem;
  }

  .baby-boo--map {
    left: -0.05rem;
    top: -2.85rem;
    bottom: auto;
  }

  .baby-boo__bubble {
    min-width: 8.6rem;
    max-width: min(14rem, 62vw);
    padding: 0.78rem 0.88rem;
    font-size: 0.72rem;
  }
}

@media (max-width: 640px) {
  .baby-boo--quick {
    right: 0.1rem;
    left: auto;
    bottom: 0.05rem;
  }

  .server-gallery-stage {
    padding-bottom: 5rem;
  }

  .baby-boo--gallery {
    right: -0.2rem;
    bottom: 0.05rem;
  }

  .map-layout.baby-boo-scope--map {
    padding-top: 5rem;
  }

.baby-boo--map {
    --baby-boo-size: 104px;
    left: -0.18rem;
    top: -2.4rem;
  }

  .baby-boo__bubble {
    max-width: min(13rem, 66vw);
  }
}

@media (prefers-reduced-motion: reduce) {
  .baby-boo__figure,
  .baby-boo.is-pumping .baby-boo__pulse {
    animation: none !important;
  }

  .baby-boo__bubble,
  .baby-boo__figure,
  .baby-boo__figure img {
    transition-duration: 0.18s !important;
  }
}

#notices-list.baby-boo-scope--notices .baby-boo,
#updates-list.baby-boo-scope--updates .baby-boo,
.feat-stage.baby-boo-scope--features .baby-boo,
.mod-setup-stage.baby-boo-scope--mod-setup .baby-boo {
  z-index: 6;
}

.baby-boo--notices {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  right: clamp(-5rem, -3.8vw, -3rem);
  top: -5.2rem;
  bottom: auto;
}

.baby-boo--updates {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  right: clamp(-5rem, -3.8vw, -3rem);
  top: -5.2rem;
  bottom: auto;
}

.feat-stage.baby-boo-scope--features {
  padding-right: clamp(4.8rem, 7vw, 6rem);
}

.baby-boo--features {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  right: clamp(-3.6rem, -2.6vw, -1rem);
  top: -1.8rem;
}

.mod-setup-stage.baby-boo-scope--mod-setup {
  padding-right: clamp(4.8rem, 7vw, 6rem);
}

.baby-boo--mod-setup {
  --baby-boo-size: clamp(128px, 10.5vw, 160px);
  right: clamp(-3.7rem, -2.8vw, -1rem);
  top: -1.2rem;
}

@media (max-width: 768px) {
  .baby-boo--notices,
  .baby-boo--updates {
    right: -0.2rem;
    top: -2.8rem;
    bottom: auto;
  }

  .feat-stage.baby-boo-scope--features,
  .mod-setup-stage.baby-boo-scope--mod-setup {
    padding-right: 0;
    padding-top: 5rem;
  }

  .baby-boo--features,
  .baby-boo--mod-setup {
    right: -0.15rem;
    top: -2.9rem;
  }
}
