/**
 * Confirmation modal — programmatic + data-confirm attribute
 */

.confirm-backdrop {
  z-index: calc(var(--z-modal-backdrop) + 20);
  backdrop-filter: blur(4px);
}

.confirm-backdrop.is-open {
  animation: confirmBackdropIn 200ms ease forwards;
}

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

.confirm-modal {
  max-width: 26rem;
  padding: 0;
  text-align: center;
  border: var(--border-default);
  overflow: hidden;
  transform: scale(0.92) translateY(var(--space-4));
  transition: transform 280ms cubic-bezier(0.34, 1.56, 0.64, 1), opacity 200ms ease;
}

.confirm-backdrop.is-open .confirm-modal {
  transform: scale(1) translateY(0);
}

.confirm-modal__hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-8) var(--space-6) var(--space-5);
  background:
    linear-gradient(180deg, var(--color-surface-secondary) 0%, var(--color-surface) 100%);
}

.confirm-modal__icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-md);
}

.confirm-modal__icon-wrap svg {
  width: 1.75rem;
  height: 1.75rem;
}

.confirm-modal__icon-wrap--danger {
  color: var(--color-danger);
  background: var(--color-danger-bg);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--color-danger) 12%, transparent);
}

.confirm-modal__icon-wrap--warning {
  color: var(--color-warning);
  background: var(--color-warning-bg);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--color-warning) 12%, transparent);
}

.confirm-modal__icon-wrap--info {
  color: var(--color-info);
  background: var(--color-info-bg);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--color-info) 12%, transparent);
}

.confirm-modal__title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  line-height: var(--line-height-tight);
}

.confirm-modal__message {
  margin: var(--space-2) 0 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-base);
}

.confirm-modal__detail {
  margin: var(--space-4) 0 0;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  text-align: left;
  background: var(--color-surface-secondary);
  border: var(--border-default);
  border-radius: var(--radius-md);
}

.confirm-modal__footer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6) var(--space-6);
  border-top: var(--border-default);
  background: var(--color-surface);
}

.confirm-modal__footer .btn {
  width: 100%;
  justify-content: center;
}

@media (max-width: 480px) {
  .confirm-modal__footer {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .confirm-backdrop.is-open,
  .confirm-modal,
  .confirm-backdrop.is-open .confirm-modal {
    animation: none;
    transition: none;
    transform: none;
  }
}
