/* ==========================================================================
   Modal Base Styles - Shared across all pages
   ========================================================================== */

/*
 * Base dialog styles for all modals.
 * Each modal can customize via CSS custom properties:
 *   --modal-max-width: max-width (default: 480px)
 *
 * Component-specific styles remain in their page CSS files.
 */

dialog {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: var(--glass-border);
  border-radius: 12px;
  color: var(--text-primary);
  padding: 0;
  max-width: var(--modal-max-width, 480px);
  width: calc(100% - 32px);
  box-shadow: var(--glass-shadow);
}

dialog::backdrop {
  background: rgb(0 0 0 / 60%);
}

/* Modal close button - shared pattern */
.modal-close {
  padding: 4px 8px;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--text-muted);
  background: transparent;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

.modal-close:hover {
  color: var(--text-primary);
  background: var(--bg-elevated);
}

.modal-close:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ==========================================================================
   Contact Form - Shared across all pages
   ========================================================================== */

.contact-modal {
  --modal-max-width: 480px;
}

.contact-form {
  padding: 24px;
}

.contact-form h2 {
  margin: 0 0 20px;
  font-family: var(--sans);
  font-size: 1.125rem;
  font-weight: 600;
}

.contact-form .form-field {
  margin-bottom: 16px;
}

.contact-form label {
  display: block;
  margin-bottom: 6px;
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 10px 12px;
  font-family: var(--sans);
  font-size: 1rem;
  color: var(--text-primary);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
}

.contact-form textarea {
  resize: vertical;
  min-height: 100px;
}

/* Focus states after base styles (no-descending-specificity) */
.contact-form :where(input, textarea):focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-color: var(--accent);
}

.contact-form .form-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 20px;
}

@media (width < 400px) {
  .contact-form .form-actions {
    grid-template-columns: 1fr;
  }
}

.contact-form .form-status {
  margin: 12px 0 0;
  font-size: 0.875rem;
  text-align: center;
}

.contact-form .form-status:empty {
  display: none;
}

.contact-form .form-status.error {
  color: var(--critical);
}

.contact-form .form-status.success {
  color: var(--accent);
}

/* ==========================================================================
   Confirm Modal - Delete confirmations, etc.
   ========================================================================== */

.confirm-modal {
  --modal-max-width: 400px;
}

.confirm-content {
  padding: 24px;
}

.confirm-content h2 {
  margin: 0 0 12px;
  font-family: var(--sans);
  font-size: 1.125rem;
  font-weight: 600;
}

.confirm-content p {
  margin: 0 0 24px;
  font-size: 0.9375rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.confirm-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

/* ==========================================================================
   Accessibility - High Contrast
   ========================================================================== */

@media (prefers-contrast: more) {
  dialog {
    border-width: 2px;
  }
}

/* ==========================================================================
   Accessibility - Forced Colors (Windows High Contrast)
   ========================================================================== */

@media (forced-colors: active) {
  dialog {
    border: 2px solid CanvasText;
  }

  .modal-close {
    border: 1px solid ButtonText;
  }
}
