/* ========================================
   Modal Components - Shared Styles
   ======================================== */

.modal-overlay,
.confirm-dialog-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-backdrop-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: var(--z-modal, 400);
  backdrop-filter: blur(8px);
  animation: modalFadeIn 0.2s ease;
}

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

.modal,
.confirm-dialog {
  background: var(--modal-bg);
  border-radius: 16px;
  border: 1px solid var(--modal-border);
  width: 100%;
  max-width: 960px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  animation: modalSlideUp 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal.modal--lg,
.modal.modal-large,
.modal.modal-lg,
.confirm-dialog.modal--lg,
.confirm-dialog.modal-large,
.confirm-dialog.modal-lg { max-width: 1200px; }

.modal.modal--xl,
.modal.modal-xl,
.confirm-dialog.modal--xl,
.confirm-dialog.modal-xl { max-width: 1400px; }

.modal.modal--sm,
.modal.modal-small,
.modal.modal-sm,
.confirm-dialog.modal--sm,
.confirm-dialog.modal-small,
.confirm-dialog.modal-sm { max-width: 520px; }

.modal.modal--md,
.modal.modal-medium,
.modal.modal-md,
.confirm-dialog.modal--md,
.confirm-dialog.modal-medium,
.confirm-dialog.modal-md { max-width: 820px; }

.modal.modal--full,
.modal.modal-full,
.confirm-dialog.modal--full,
.confirm-dialog.modal-full {
  max-width: none;
  width: 96vw;
  height: 92vh;
}

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

.modal-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--surface-border);
  background: var(--surface-default);
  flex-shrink: 0;
}

.modal-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-strong);
  margin: 0;
}

.modal-close {
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 6px;
  border-radius: 8px;
  transition: background 0.2s, color 0.2s;
}

.modal-close:hover {
  background: var(--surface-alt);
  color: var(--text-strong);
}

.modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  background: var(--surface-default);
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 14px 20px;
  border-top: 1px solid var(--surface-border);
  background: var(--surface-default);
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .modal-overlay { padding: 0; }
  .modal {
    width: 100%;
    height: 100%;
    border-radius: 0;
    max-width: none;
    max-height: none;
  }
  .modal-body { padding: 16px; }
  .modal-header, .modal-footer { padding: 12px 16px; }
}

/* === CONFIRM DIALOG CONTENT === */
.confirm-dialog {
  width: min(420px, 90vw);
  padding: 0;
}

.confirm-dialog-content {
  display: flex;
  gap: 16px;
  padding: 20px 24px;
  align-items: flex-start;
}

.confirm-dialog-icon {
  display: inline-flex;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--attention-bg) 70%, transparent);
  color: var(--attention-fg);
  flex-shrink: 0;
}

.confirm-dialog-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.confirm-dialog-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-strong);
  margin: 0;
}

.confirm-dialog-message {
  font-size: 14px;
  color: var(--text-subtle);
  line-height: 1.5;
  margin: 0;
}

.confirm-dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid var(--surface-border);
  background: var(--surface-default);
}
