/* ================================================================
   modals.css — overlays, dialog boxes, keyboard shortcut table
   ================================================================ */
.modal-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(44,20,20,.6);
  z-index: 500;
  align-items: center; justify-content: center;
  padding: 1rem;
}
.modal-overlay.open { display: flex; }

.modal-box {
  background: #fff; border-radius: var(--r-xl); padding: 2rem;
  max-width: 420px; width: 100%;
  box-shadow: 0 12px 40px rgba(0,0,0,.2);
  border-top: 4px solid var(--red);
  position: relative;
}
.modal-box.wide { max-width: 560px; }

.modal-close {
  position: absolute; top: var(--sp-md); right: var(--sp-md);
  background: var(--pa); border: none;
  width: 28px; height: 28px; border-radius: 50%;
  cursor: pointer; font-size: 15.4px;
  display: flex; align-items: center; justify-content: center;
  color: var(--im);
}
.modal-title {
  font-family: var(--heading-font);
  font-size: 19.8px; color: var(--rd); font-style: italic;
  margin-bottom: var(--sp-sm);
}
.modal-actions { display: flex; gap: var(--sp-sm); justify-content: center; margin-top: var(--sp-lg); }

/* ── KEYBOARD SHORTCUT TABLE ────────────────────────────────────── */
kbd {
  background: var(--pa); border: 1px solid var(--bs);
  border-radius: 4px; padding: 2px 6px;
  font-family: monospace; font-size: 12.1px; color: var(--rd);
}
.kbd-table { width: 100%; border-collapse: collapse; font-size: 13.2px; }
.kbd-table tr   { border-bottom: 1px dashed var(--bo); }
.kbd-table td   { padding: 6px 8px; color: var(--im); }
.kbd-table td:first-child { text-align: right; padding-right: 12px; }
.kbd-section    { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); font-weight: 500; padding: 8px 8px 4px; border-bottom: 2px solid var(--go); }

