/* modal.css */

.modal {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.modal.hidden { display: none; }
.modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(15, 23, 42, 0.42);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: fadeIn 180ms ease;
}
.modal__panel {
  position: relative;
  width: min(560px, 100%);
  max-height: calc(100vh - 60px);
  overflow: auto;
  background: var(--card);
  border-radius: 22px;
  box-shadow: 0 30px 80px rgba(15,23,42,0.25);
  animation: pop 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes pop {
  from { transform: translateY(8px) scale(0.98); opacity: 0; }
  to   { transform: translateY(0) scale(1);     opacity: 1; }
}

.modal__hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px; border-bottom: 1px solid var(--border);
}
.modal__hd h3 { margin: 0; font-size: 15px; font-weight: 600; }
.modal__x {
  border: 0; background: transparent; cursor: pointer;
  font-size: 22px; line-height: 1; color: var(--ink-mute);
  width: 32px; height: 32px; border-radius: 50%;
}
.modal__x:hover { background: var(--bg-soft); color: var(--ink); }

.modal__bd {
  padding: 16px 18px 18px;
  display: flex; flex-direction: column; gap: 12px;
}
.field { display: flex; flex-direction: column; gap: 4px; font-size: 12.5px; color: var(--ink-2); }
.field > input, .field > select {
  font: inherit; padding: 9px 12px; border-radius: 10px;
  border: 1px solid var(--border-strong); background: var(--card-2); color: var(--ink);
  outline: none; transition: border-color 140ms ease, box-shadow 140ms ease;
}
.field > input:focus, .field > select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(10,132,255,0.18);
}
.field-row {
  display: grid; grid-template-columns: 1fr 1fr 1.2fr; gap: 10px;
}
@media (max-width: 520px) {
  .field-row { grid-template-columns: 1fr; }
}
.modal__actions {
  display: flex; align-items: center; gap: 8px; margin-top: 6px;
}
.modal__msg {
  margin: 0; font-size: 12.5px; color: var(--ink-mute); min-height: 1.2em;
}
.modal__msg.is-ok  { color: var(--good); }
.modal__msg.is-err { color: var(--bad); }
