/**
 * VIP Popover - Frontend Styles
 * High-performance popover styling with modern CSS
 */

/* Variables for easy customization */
:root {
  --vip-popover-z-index: 999999;
  --vip-popover-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --vip-popover-border-radius: 12px;
  --vip-popover-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --vip-popover-backdrop-filter: blur(4px);
}

/* Popover Overlay */
.vip-popover-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: var(--vip-popover-backdrop-filter);
  z-index: var(--vip-popover-z-index);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: var(--vip-popover-transition);
  cursor: pointer;
}

.vip-popover-overlay.vip-popover-active {
  opacity: 1;
  visibility: visible;
}

/* Popover Container */
.vip-popover-container {
  position: relative;
  background: white;
  border-radius: var(--vip-popover-border-radius);
  box-shadow: var(--vip-popover-shadow);
  max-width: min(1600px, 90vw);
  max-height: 90vh;
  overflow: hidden;
  cursor: default;
  transform: scale(0.9) translateY(20px);
  transition: var(--vip-popover-transition);
}

.vip-popover-active .vip-popover-container {
  transform: scale(1) translateY(0);
}

/* Popover Content */
.vip-popover-content {
  padding: 2rem;
  padding-right: 3.5rem; /* Extra padding to avoid close button overlap */
  overflow-y: auto;
  max-height: calc(90vh - 4rem);
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE and Edge */
}

.vip-popover-content::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}



/* Close Button */
.vip-popover-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(10px);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--vip-popover-transition);
  z-index: 1;
  color: white;
}

.vip-popover-close:hover {
  background: rgba(0, 0, 0, 0.85);
  transform: scale(1.1);
}

.vip-popover-close::before,
.vip-popover-close::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 2px;
  background: white;
  border-radius: 1px;
}

.vip-popover-close::before {
  transform: rotate(45deg);
}

.vip-popover-close::after {
  transform: rotate(-45deg);
}

/* Trigger Styles */
.vip-popover-trigger {
  cursor: pointer;
  transition: var(--vip-popover-transition);
}

.vip-popover-trigger:hover {
  transform: translateY(-1px);
}

.vip-popover-trigger.vip-trigger-button {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background-color: #0073aa;
  color: white;
  text-decoration: none;
  border-radius: 6px;
  border: none;
  font-size: 1rem;
  font-weight: 500;
}

.vip-popover-trigger.vip-trigger-button:hover {
  background-color: #005a87;
}

.vip-popover-trigger.vip-trigger-link {
  color: #0073aa;
  text-decoration: underline;
}

.vip-popover-trigger.vip-trigger-link:hover {
  color: #005a87;
}

/* Animation Classes */
.vip-popover-container.vip-popover-fade-enter {
  opacity: 0;
  transform: scale(0.9) !important;
}

.vip-popover-container.vip-popover-fade-enter-active {
  opacity: 1;
  transform: scale(1) translateY(0) !important;
}

.vip-popover-container.vip-popover-slide-enter {
  transform: translateY(100px) !important;
  opacity: 0;
}

.vip-popover-container.vip-popover-slide-enter-active {
  transform: translateY(0) !important;
  opacity: 1;
}

.vip-popover-container.vip-popover-scale-enter {
  transform: scale(0.7) !important;
  opacity: 0;
}

.vip-popover-container.vip-popover-scale-enter-active {
  transform: scale(1) !important;
  opacity: 1;
}

.vip-popover-container.vip-popover-bounce-enter {
  transform: scale(0.3) !important;
  opacity: 0;
}

.vip-popover-container.vip-popover-bounce-enter-active {
  transform: scale(1) !important;
  opacity: 1;
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) !important;
}

/* Body scroll lock */
body.vip-popover-lock-scroll {
  overflow: hidden !important;
  position: relative;
}

/* Accessibility */
.vip-popover-overlay:focus {
  outline: none;
}

.vip-popover-container:focus {
  outline: 2px solid #0073aa;
  outline-offset: 2px;
}

/* Reduce Motion */
@media (prefers-reduced-motion: reduce) {
  .vip-popover-overlay,
  .vip-popover-container,
  .vip-popover-trigger,
  .vip-popover-close {
    transition: none !important;
  }

  .vip-popover-container {
    transform: none !important;
  }
}

/* Responsive Design */
@media (max-width: 768px) {
  .vip-popover-overlay {
    align-items: flex-start;
    padding: 0;
  }

  .vip-popover-container {
    margin: 0;
    margin-top: 40px;
    max-width: 100vw;
    width: 100vw;
    height: calc(100vh - 40px);
    max-height: calc(100vh - 40px);
    border-radius: 12px 12px 0 0;
  }

  .vip-popover-content {
    padding: 1rem;
    max-height: calc(100vh - 40px - 2rem);
  }

  .vip-popover-close {
    top: 1rem;
    right: 1rem;
  }
}

@media (max-width: 480px) {
  .vip-popover-overlay {
    align-items: flex-start;
    padding: 0;
  }

  .vip-popover-container {
    margin: 0;
    margin-top: 40px;
    max-width: 100vw;
    width: 100vw;
    height: calc(100vh - 40px);
    max-height: calc(100vh - 40px);
    border-radius: 12px 12px 0 0;
  }

  .vip-popover-content {
    padding: 0;
    max-height: calc(100vh - 40px - 1.5rem);
  }
}

