/**
 * CS Repair — modais (público + área restrita)
 * Centrados, tamanho proporcional, scroll no conteúdo, botão fechar fixo no topo.
 */
:root {
  --cs-modal-pad: clamp(12px, 2.5vw, 22px);
  --cs-modal-max-w: min(720px, 92vw);
  --cs-modal-max-w-wide: min(900px, 94vw);
  --cs-modal-max-w-narrow: min(420px, 92vw);
  --cs-modal-max-h: min(88dvh, calc(100vh - 2 * var(--cs-modal-pad)));
  --cs-modal-z: 10000;
  --cs-modal-radius: clamp(10px, 1.5vw, 14px);
  --cs-modal-head-bg: #fff;
  --cs-modal-border: rgba(0, 0, 0, 0.08);
}

/* —— Shell: fixo, centrado, sem scroll no overlay —— */
.cs-modal-shell,
[id$="Modal"]:not(#printModal):not(#subseccaoModal),
.rep-add-modal.is-open,
.loja-modal:not([hidden]),
.modal-subseccao.active,
.revenda-modal-overlay.active,
body.admin .modal.active,
.user-editor-overlay.is-open {
  position: fixed !important;
  inset: 0 !important;
  z-index: var(--cs-modal-z) !important;
  margin: 0 !important;
  padding: var(--cs-modal-pad) !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  overscroll-behavior: contain;
}

.cs-modal-shell[style*="display: flex"],
.cs-modal-shell[style*="display:flex"],
[id$="Modal"][style*="display: flex"]:not(#printModal),
[id$="Modal"][style*="display:flex"]:not(#printModal),
.rep-add-modal.is-open,
.loja-modal:not([hidden]),
.modal-subseccao.active,
.revenda-modal-overlay.active,
body.admin .modal.active,
.user-editor-overlay.is-open {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Backdrop cobre o ecrã (painel não se desloca) */
.cs-modal-shell > .modal-backdrop,
.cs-modal-shell > .loja-modal-backdrop,
.cs-modal-shell > .rep-add-modal__backdrop,
[id$="Modal"] > .modal-backdrop,
.rep-add-modal > .modal-backdrop,
.rep-add-modal > .rep-add-modal__backdrop,
.loja-modal > .loja-modal-backdrop,
.modal-subseccao.active,
.revenda-modal-overlay.active {
  /* subseccao/revenda: o próprio shell é o fundo */
}

.cs-modal-shell > .modal-backdrop,
[id$="Modal"] > .modal-backdrop,
.rep-add-modal > .modal-backdrop,
.rep-add-modal > .rep-add-modal__backdrop,
.loja-modal > .loja-modal-backdrop {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1 !important;
  margin: 0 !important;
}

.modal-subseccao.active,
.revenda-modal-overlay.active,
.user-editor-overlay.is-open {
  background: rgba(15, 23, 42, 0.52) !important;
  backdrop-filter: blur(2px);
}

body.admin .modal.active {
  background: rgba(15, 23, 42, 0.5) !important;
}

/* —— Painel —— */
.cs-modal-panel,
.cs-modal-shell > .modal-card,
.cs-modal-shell > .modal-content,
[id$="Modal"] > .modal-card,
[id$="Modal"] > .modal-content,
.rep-add-modal .rep-add-modal__card,
.rep-add-modal .modal-card,
.loja-modal-card,
.modal-subseccao.active > .modal-content-subseccao,
.revenda-modal-overlay.active > .revenda-modal,
body.admin .modal.active > .modal-content,
.user-editor-overlay.is-open > .user-editor-panel {
  position: relative !important;
  z-index: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  width: min(100%, var(--cs-modal-max-w)) !important;
  max-width: var(--cs-modal-max-w) !important;
  max-height: var(--cs-modal-max-h) !important;
  height: auto !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  border-radius: var(--cs-modal-radius) !important;
  box-shadow: 0 16px 48px rgba(15, 23, 42, 0.18) !important;
  padding: 0 !important;
  animation: csModalIn 0.22s ease-out;
}

@keyframes csModalIn {
  from {
    opacity: 0;
    transform: scale(0.97);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Larguras */
[id$="Modal"][id*="create"] > .modal-card,
[id$="Modal"][id*="view"] > .modal-card,
[id$="Modal"][id*="detail"] > .modal-card,
[id$="Modal"][id*="archive"] > .modal-card,
.loja-modal-card--wide {
  --cs-modal-max-w: var(--cs-modal-max-w-wide);
  max-width: var(--cs-modal-max-w-wide) !important;
  width: min(100%, var(--cs-modal-max-w-wide)) !important;
}

#printModal > .modal-card {
  --cs-modal-max-w: var(--cs-modal-max-w-narrow);
  max-width: var(--cs-modal-max-w-narrow) !important;
  width: min(100%, var(--cs-modal-max-w-narrow)) !important;
}

/* FAQ público: sempre centrado no ecrã (viewport), não na página */
#subseccaoModal.modal-subseccao,
.modal-subseccao.cs-modal-shell {
  z-index: var(--cs-modal-z) !important;
}

#subseccaoModal.modal-subseccao:not(.active),
.modal-subseccao:not(.active) {
  display: none !important;
}

#subseccaoModal.modal-subseccao.active,
.modal-subseccao.active {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  max-height: 100dvh !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  padding: var(--cs-modal-pad) !important;
  box-sizing: border-box !important;
  background: rgba(15, 23, 42, 0.52) !important;
  backdrop-filter: blur(2px);
}

.modal-content-subseccao {
  width: min(100%, min(760px, 94vw)) !important;
  max-width: min(760px, 94vw) !important;
}

.modal-content-subseccao.cs-modal-panel {
  padding: 0 !important;
  background: #fff !important;
}

.modal-content-subseccao .modal-header.cs-modal-head {
  margin-bottom: 0 !important;
  border-bottom: 1px solid var(--cs-modal-border, #e8e6e1) !important;
}

.modal-content-subseccao .modal-header.cs-modal-head h2 {
  margin: 0 !important;
  color: var(--azul, #0d47a1);
  font-size: clamp(1.05rem, 2.5vw, 1.25rem);
}

.modal-content-subseccao .close-btn.cs-modal-close {
  font-size: 18px !important;
}

.modal-content-subseccao .cs-modal-body .modal-section {
  margin-bottom: 20px;
}

.modal-content-subseccao .cs-modal-body .modal-section:last-child {
  margin-bottom: 0;
}

.modal-content-subseccao .cs-modal-body .modal-section h3 {
  margin: 0 0 10px;
  color: var(--azul, #0d47a1);
  font-size: 1rem;
}

.modal-content-subseccao .cs-modal-body .modal-section p {
  margin: 0;
  color: #333;
  line-height: 1.8;
  white-space: pre-wrap;
}

body.cs-modal-body-lock {
  overflow: hidden;
}

.revenda-modal-overlay.active > .revenda-modal {
  width: min(100%, 520px) !important;
  max-width: min(520px, 92vw) !important;
}

.user-editor-overlay.is-open > .user-editor-panel {
  width: min(100%, 520px) !important;
  max-width: min(520px, 92vw) !important;
}

/* Cabeçalho + fechar fixos */
.cs-modal-head,
.rep-add-modal__head {
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: clamp(14px, 2.5vw, 18px) clamp(16px, 3vw, 22px) clamp(10px, 2vw, 14px) !important;
  margin: 0 !important;
  background: var(--cs-modal-head-bg) !important;
  border-bottom: 1px solid var(--cs-modal-border) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 5 !important;
  border-radius: var(--cs-modal-radius) var(--cs-modal-radius) 0 0 !important;
}

.cs-modal-head h2,
.cs-modal-head h3,
.rep-add-modal__head h3 {
  margin: 0 !important;
  flex: 1 1 auto;
  min-width: 0;
  font-size: clamp(1.05rem, 2.5vw, 1.25rem);
  line-height: 1.3;
  padding-right: 8px;
}

/* Corpo com scroll */
.cs-modal-body {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: clamp(12px, 2.5vw, 18px) clamp(16px, 3vw, 22px) !important;
  box-sizing: border-box;
}

/* Rodapé fixo (acções) */
.cs-modal-foot {
  flex-shrink: 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding: clamp(10px, 2vw, 14px) clamp(16px, 3vw, 22px) clamp(14px, 2.5vw, 18px) !important;
  margin: 0 !important;
  background: var(--cs-modal-head-bg) !important;
  border-top: 1px solid var(--cs-modal-border) !important;
  position: sticky !important;
  bottom: 0 !important;
  z-index: 5 !important;
  border-radius: 0 0 var(--cs-modal-radius) var(--cs-modal-radius) !important;
}

/* Botão fechar — sempre visível no topo */
.cs-modal-close,
.rep-add-modal__close,
.revenda-modal-close {
  flex-shrink: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1px solid var(--cs-modal-border) !important;
  border-radius: 10px !important;
  background: #f5f6f8 !important;
  color: #4b5563 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease !important;
  transform: scale(1) !important;
}

.cs-modal-close:hover,
.rep-add-modal__close:hover,
.revenda-modal-close:hover {
  background: #eef0f3 !important;
  border-color: #c5cad3 !important;
  color: #1f2937 !important;
  transform: scale(1.06) !important;
}

/* Fechar antigo no rodapé: esconder se houver cópia no topo */
.cs-modal-panel:has(.cs-modal-close--header) .cs-modal-foot [id$="_close"],
.cs-modal-panel:has(.cs-modal-close--header) .cs-modal-foot [id$="Close"],
.cs-modal-panel:has(.cs-modal-close--header) .cs-modal-body > div:last-child > [id$="_close"].btn.del:only-child {
  /* mantém botão Cancelar/Fechar no rodapé se for acção — só esconder duplicado ✕ */
}

.revenda-modal > .revenda-modal-close:not(.cs-modal-close--header) {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 6;
}

.revenda-modal:has(.cs-modal-head) > .revenda-modal-close:not(.cs-modal-close--header) {
  display: none !important;
}

/* Rep-add: corpo após cabeçalho */
.rep-add-modal__card.cs-modal-panel > .cs-modal-body,
.rep-add-modal__card.cs-modal-panel > .rep-add-modal__intro,
.rep-add-modal__card.cs-modal-panel > .rep-add-modal__err,
.rep-add-modal__card.cs-modal-panel > form {
  /* form inside body after enhance */
}

.rep-add-modal__card.cs-modal-panel .rep-add-modal__actions {
  margin-top: 0;
}

/* Painel admin — tema suave */
body.admin.admin-theme-parceiro .cs-modal-head,
body.admin.admin-theme-parceiro .cs-modal-foot,
body.admin.admin-theme-admin .cs-modal-head,
body.admin.admin-theme-admin .cs-modal-foot {
  --cs-modal-head-bg: #fcfbfa;
}

body.admin.admin-theme-parceiro .cs-modal-panel,
body.admin.admin-theme-admin .cs-modal-panel,
body.admin.admin-theme-parceiro [id$="Modal"] > .modal-card,
body.admin.admin-theme-admin [id$="Modal"] > .modal-card {
  background: #fcfbfa !important;
  border: 1px solid #e8e6e1 !important;
}

/* Anular scroll / tamanhos inline no cartão (scroll só no .cs-modal-body) */
[id$="Modal"] > .modal-card[style*="overflow"],
.modal-card[style*="overflow-y"],
.modal-card[style*="max-height"] {
  overflow: hidden !important;
  max-height: var(--cs-modal-max-h) !important;
}

/* Legado admin: backdrop claro → escuro suave (centrado fixo) */
#assistModal > .modal-backdrop,
#clientModal > .modal-backdrop,
#archiveModal > .modal-backdrop {
  background: rgba(15, 23, 42, 0.45) !important;
  backdrop-filter: blur(2px);
}

@media (prefers-reduced-motion: reduce) {
  .cs-modal-panel,
  [id$="Modal"] > .modal-card {
    animation: none;
  }

  .cs-modal-close:hover,
  .rep-add-modal__close:hover,
  .revenda-modal-close:hover {
    transform: none !important;
  }
}
