/* ============================================
   TRANSITION.CSS - Full-screen cabinet switch overlay
   Deep black, neon red, crimson, cyberpunk / matrix style
   ============================================ */

.cabinet-transition-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}

.cabinet-transition-overlay.visible {
  opacity: 1;
  pointer-events: auto;
}

.cabinet-transition-overlay.fade-out {
  opacity: 0;
  transition: opacity 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Canvas fills overlay */
.cabinet-transition-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}

/* Shake container (slight screen shake at transition peak) */
.cabinet-transition-overlay.shake .cabinet-transition-canvas {
  animation: transition-shake 0.1s ease-out;
}

@keyframes transition-shake {
  0%, 100% { transform: translate(0, 0); }
  25% { transform: translate(-4px, 2px); }
  50% { transform: translate(4px, -2px); }
  75% { transform: translate(-2px, -2px); }
}

/* Zoom effect on wrapper */
.cabinet-transition-overlay.zoom .cabinet-transition-canvas {
  animation: transition-zoom 0.12s ease-out;
}

@keyframes transition-zoom {
  from { transform: scale(1.02); }
  to { transform: scale(1); }
}
