/* DS §05.07 — Modal / dialog (web) · token-only */

.ds-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  background: rgba(0, 0, 0, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-6);
  animation: ds-backdrop-in var(--dur-normal) var(--ease-inout);
}

@keyframes ds-backdrop-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.ds-modal {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--rad-xl);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 560px;
  max-height: calc(100vh - var(--sp-12));
  overflow-y: auto;
  animation: ds-modal-in var(--dur-normal) var(--ease-organic);
}

@keyframes ds-modal-in {
  from { opacity: 0; transform: translateY(var(--sp-6)) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.ds-modal-sm { max-width: 400px; }
.ds-modal-lg { max-width: 720px; }

.ds-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) var(--sp-6) var(--sp-4);
  border-bottom: 1px solid var(--border);
}

.ds-modal-title {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--fg1);
  margin: 0;
}

.ds-modal-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--fg3);
  padding: var(--sp-2);
  border-radius: var(--rad-sm);
  line-height: 1;
  transition: color var(--dur-fast) var(--ease-smooth),
              background var(--dur-fast) var(--ease-smooth);
}
.ds-modal-close:hover        { color: var(--fg1); background: var(--bg2); }
.ds-modal-close:focus-visible { outline: none; box-shadow: var(--focus-ring-web); }

.ds-modal-body {
  padding: var(--sp-6);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--fg2);
  line-height: 1.6;
}

.ds-modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-6) var(--sp-5);
  border-top: 1px solid var(--border);
}
