/* ============================================================================
 * CNPA — Modal de termos do cadastro público (<dialog> nativo).
 * Desktop: modal centralizado. Mobile (<36rem): bottom drawer.
 * Token-first sobre a DS do CNPA.
 * ========================================================================== */

.reg-dialog {
  position: fixed;
  inset: 0;
  margin: auto;                          /* centraliza no desktop (h + v) */
  width: min(34rem, calc(100% - 2rem));
  max-height: calc(100dvh - 4rem);
  border: none;
  padding: 0;
  background: var(--surface-card);
  color: var(--text-body);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  font-family: var(--font-sans);
}
.reg-dialog::backdrop { background: rgba(0, 0, 0, 0.5); }

.reg-dialog__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
}
.reg-dialog__title { font-weight: var(--weight-bold); color: var(--text-strong); font-size: var(--text-base); }
.reg-dialog__close {
  flex: none;
  width: 2rem; height: 2rem;
  border: none; border-radius: var(--radius-full);
  background: var(--surface-sunken); color: var(--text-muted);
  font-size: 1.25rem; line-height: 1; cursor: pointer;
  transition: background-color var(--duration-fast) var(--ease-standard);
}
.reg-dialog__close:hover { background: var(--border-default); color: var(--text-strong); }

.reg-dialog__body {
  padding: var(--space-5);
  max-height: 60vh;
  overflow-y: auto;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--text-body);
}
.reg-dialog__body h1, .reg-dialog__body h2, .reg-dialog__body h3 {
  color: var(--text-strong); font-weight: var(--weight-bold); margin: var(--space-3) 0 var(--space-2);
}
.reg-dialog__body h1 { font-size: var(--text-lg); }
.reg-dialog__body h2 { font-size: var(--text-base); }
.reg-dialog__body p { margin: 0 0 var(--space-2); }
.reg-dialog__body ul, .reg-dialog__body ol { margin: 0 0 var(--space-2); padding-left: var(--space-5); }
.reg-dialog__body li { margin-bottom: var(--space-1); }
.reg-dialog__body a { color: var(--action-primary); }
.reg-dialog__body strong { font-weight: var(--weight-semibold); color: var(--text-strong); }

/* ---- Bottom drawer no mobile ------------------------------------------- */
@media (max-width: 36rem) {
  .reg-dialog {
    width: 100%;
    max-width: 100%;
    margin: 0;
    inset: auto 0 0 0;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  }
  .reg-dialog[open] { animation: reg-sheet-up var(--duration-normal) var(--ease-standard); }
  .reg-dialog__body { max-height: 70vh; }
}
@keyframes reg-sheet-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
