/**
 * @file
 * HCP Full Modal component styles.
 *
 * Extends existing external-link-popup styles for consistent appearance.
 */

/* Modal overlay */
.hcp-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(81, 88, 97, 0.60);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Modal dialog - inherits from external-link-popup styles */
.hcp-modal-dialog.external-link-popup.external-link-popup-id-modal-home_splash.ui-dialog {
  position: relative;
  margin: auto;
  max-height: 90vh;
  overflow-y: auto;
}

/* Ensure modal is hidden by default */
.hcp-modal-overlay[style*="display:none"],
.hcp-modal-overlay[style*="display: none"] {
  display: none !important;
}

/* Show modal when active */
.hcp-modal-overlay.hcp-modal-show {
  display: flex !important;
}

/* Focus management */
.hcp-modal-dialog:focus {
  outline: 2px solid var(--color-primary, #f16b50);
  outline-offset: 2px;
}

/* Enhanced button styling for accessibility */
.hcp-modal-buttonpane .button:focus {
  outline: 2px solid var(--color-primary, #f16b50);
  outline-offset: 2px;
}

.hcp-modal-buttonpane .button:focus-visible {
  outline: 2px solid var(--color-primary, #f16b50);
  outline-offset: 2px;
}

/* Ensure proper stacking context */
.hcp-modal-overlay {
  isolation: isolate;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .hcp-modal-overlay {
    background: rgba(0, 0, 0, 0.85);
  }

  .hcp-modal-dialog {
    border: 3px solid;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .hcp-modal-overlay {
    transition: none;
  }

  .hcp-modal-dialog {
    transition: none;
    animation: none;
  }
}

/* Animation for modal entrance */
@media (prefers-reduced-motion: no-preference) {
  .hcp-modal-overlay {
    transition: opacity 0.2s ease-in-out;
  }

  .hcp-modal-overlay.hcp-modal-show {
    animation: hcpModalFadeIn 0.2s ease-in-out;
  }

  .hcp-modal-dialog {
    animation: hcpModalSlideIn 0.3s ease-out;
  }
}

@keyframes hcpModalFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes hcpModalSlideIn {
  from {
    transform: translateY(-20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}