.pet-widget {
  position: fixed;
  left: var(--vrm-pet-left, auto);
  right: var(--vrm-pet-right, 42px);
  bottom: var(--vrm-pet-bottom, 0px);
  z-index: var(--vrm-pet-z-index, 30);
  box-sizing: border-box;
  width: var(--vrm-pet-width, 220px);
  height: var(--vrm-pet-height, 280px);
  max-width: calc(100vw - 16px);
  max-height: calc(100vh - 16px);
  overflow: visible;
  background: transparent;
  touch-action: none;
  user-select: none;
  contain: layout style;
}

.pet-widget[data-webpet-hidden="true"] {
  opacity: 0;
  pointer-events: none;
  transform: none;
}

.pet-widget[data-webpet-hidden="false"] {
  opacity: 1;
  transform: none;
  transition: opacity 220ms ease;
}

.pet-widget.is-webpet-revealed {
  animation: webpet-egg-reveal 820ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

@keyframes webpet-egg-reveal {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }

  62% {
    opacity: 1;
    transform: translateY(-6px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.pet-viewport {
  position: absolute;
  inset: 0;
  overflow: visible;
  background: transparent;
  cursor: grab;
}

.pet-viewport:active {
  cursor: grabbing;
}

.pet-widget[data-draggable="false"] .pet-viewport,
.pet-widget[data-draggable="false"] .pet-viewport:active {
  cursor: default;
}

.pet-viewport canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
  background: transparent;
}

.pet-effects {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.pet-effect {
  position: absolute;
  display: inline-block;
  font-size: clamp(22px, 8vw, 42px);
  line-height: 1;
  text-shadow: 0 3px 10px rgba(37, 42, 58, 0.18);
  transform: translate(-50%, -50%);
  animation: pet-effect-float 900ms ease-out forwards;
  will-change: transform, opacity;
}

.pet-effect-pop {
  color: #f97316;
  font-weight: 900;
}

.pet-effect-anger {
  font-size: clamp(20px, 7vw, 36px);
}

.pet-effect-drool,
.pet-effect-tear {
  font-size: clamp(20px, 7vw, 34px);
}

@keyframes pet-effect-float {
  0% {
    opacity: 0;
    transform: translate(-50%, -35%) scale(0.68) rotate(-8deg);
  }

  18% {
    opacity: 1;
    transform: translate(calc(-50% + var(--pet-effect-drift, 0px)), -60%) scale(1.08) rotate(3deg);
  }

  100% {
    opacity: 0;
    transform: translate(calc(-50% + var(--pet-effect-drift, 0px)), -165%) scale(0.86) rotate(12deg);
  }
}

.silhouette-debug {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}

.loading {
  position: absolute;
  z-index: 4;
  left: 50%;
  bottom: 32%;
  padding: 8px 12px;
  border: 1px solid rgba(37, 99, 235, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #1e3a8a;
  font-size: 14px;
  transform: translateX(-50%);
  backdrop-filter: blur(10px);
}

.loading.is-hidden {
  display: none;
}

.pet-menu {
  position: fixed;
  z-index: 20;
  width: min(320px, calc(100vw - 16px));
  max-height: min(620px, calc(100vh - 16px));
  overflow: auto;
  border: 1px solid rgba(44, 82, 130, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 44px rgba(47, 72, 98, 0.22);
  backdrop-filter: blur(16px);
}

.pet-menu[hidden] {
  display: none;
}

.pet-menu-section {
  padding: 6px;
}

.pet-menu-section + .pet-menu-section {
  border-top: 1px solid rgba(44, 82, 130, 0.12);
}

.pet-menu-title {
  margin: 2px 4px 6px;
  color: #52627a;
  font-size: 12px;
  font-weight: 800;
  cursor: grab;
  user-select: none;
}

.pet-menu.is-dragging,
.pet-menu.is-dragging .pet-menu-title {
  cursor: grabbing;
}

.pet-action-root {
  display: grid;
  gap: 8px;
}

.pet-menu-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}

.pet-menu button {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 6px;
  padding: 8px 9px;
  background: transparent;
  color: #172033;
  font: inherit;
  font-size: 12px;
  text-align: left;
  cursor: pointer;
}

.pet-menu button[data-pet-action] {
  font-size: 13px;
}

.pet-menu button:hover {
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
}

.pet-menu-label,
.pet-menu-id {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pet-menu-label {
  font-weight: 700;
}

.pet-menu-id {
  margin-top: 2px;
  color: #697993;
  font-size: 11px;
}

.pet-peek-controls,
.pet-turn-controls {
  display: grid;
  gap: 7px;
}

.pet-peek-control,
.pet-turn-control {
  display: grid;
  grid-template-columns: minmax(84px, 1fr) auto;
  gap: 4px 8px;
  align-items: center;
  padding: 5px 4px;
}

.pet-peek-name,
.pet-turn-name {
  color: #172033;
  font-size: 12px;
  font-weight: 700;
}

.pet-peek-value,
.pet-turn-value {
  min-width: 42px;
  color: #697993;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.pet-peek-control input,
.pet-turn-control input {
  grid-column: 1 / -1;
  width: 100%;
}

.pet-action-detail,
.pet-action-controls {
  display: grid;
  gap: 7px;
}

.pet-action-status {
  display: grid;
  grid-template-columns: minmax(92px, 0.9fr) minmax(0, 1.1fr);
  gap: 3px 8px;
  margin: 0;
  padding: 7px 8px;
  border: 1px solid rgba(44, 82, 130, 0.14);
  border-radius: 6px;
  background: rgba(37, 99, 235, 0.07);
  color: #172033;
  font-size: 11px;
}

.pet-action-status dt {
  color: #52627a;
  font-weight: 800;
}

.pet-action-status dd {
  margin: 0;
  overflow: hidden;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.pet-action-back {
  color: #1d4ed8;
  font-weight: 700;
}

.pet-action-detail-header {
  padding: 4px;
}

.pet-action-description {
  margin: 6px 0 0;
  color: #52627a;
  font-size: 11px;
  line-height: 1.35;
}

.pet-action-control {
  display: grid;
  grid-template-columns: minmax(84px, 1fr) auto;
  gap: 4px 8px;
  align-items: center;
  padding: 5px 4px;
}

.pet-action-name {
  color: #172033;
  font-size: 12px;
  font-weight: 700;
}

.pet-action-value {
  min-width: 42px;
  color: #697993;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.pet-action-control input[type="range"] {
  grid-column: 1 / -1;
  width: 100%;
}

.pet-action-select-control select {
  min-width: 112px;
  border: 1px solid rgba(44, 82, 130, 0.2);
  border-radius: 6px;
  padding: 5px 7px;
  background: rgba(255, 255, 255, 0.82);
  color: #172033;
  font: inherit;
  font-size: 12px;
}

.pet-action-checkbox {
  display: flex;
  gap: 7px;
  align-items: center;
  padding: 5px 4px;
  color: #172033;
  font-size: 12px;
  font-weight: 700;
}

.pet-action-checkbox input {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: #2563eb;
}

.pet-action-footer {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}

.pet-menu .pet-action-footer button,
.pet-menu .pet-action-back {
  background: rgba(37, 99, 235, 0.1);
  color: #1d4ed8;
  text-align: center;
}

.pet-hit-helper {
  border-top: 1px solid rgba(44, 82, 130, 0.12);
  padding-top: 6px;
}

.pet-hit-helper summary {
  margin: 0 4px 5px;
  color: #52627a;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.pet-hit-region-debug {
  display: grid;
  gap: 7px;
}

.pet-hit-region-readout {
  display: grid;
  grid-template-columns: minmax(80px, 0.9fr) minmax(0, 1.1fr);
  gap: 3px 8px;
  margin: 0;
  padding: 4px;
  color: #172033;
  font-size: 12px;
}

.pet-hit-region-readout dt {
  color: #697993;
  font-weight: 700;
}

.pet-hit-region-readout dd {
  margin: 0;
  overflow: hidden;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.pet-hit-region-toggles {
  display: grid;
  gap: 4px;
  padding: 0 4px;
}

.pet-hit-region-toggle {
  display: flex;
  gap: 7px;
  align-items: center;
  color: #172033;
  font-size: 12px;
  font-weight: 700;
}

.pet-hit-region-toggle input {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: #2563eb;
}

.pet-turn-preview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
}

.pet-menu .pet-turn-reset,
.pet-menu .pet-turn-preview-button,
.pet-menu .pet-menu-full-debug {
  margin-top: 2px;
  background: rgba(37, 99, 235, 0.1);
  color: #1d4ed8;
  text-align: center;
}

.pet-menu .pet-menu-full-debug {
  width: 100%;
  font-size: 12px;
  font-weight: 700;
}

@media (max-width: 700px) {
  .pet-widget {
    width: var(--vrm-pet-width, 220px);
    height: var(--vrm-pet-height, 280px);
  }
}
