/*
  Polimento isolado do modal Novo/Editar Contato.
  Ajusta overlay, scroll interno e hierarquia visual sem alterar campos ou eventos.
*/

html.auto-contact-modal-open,
body.auto-contact-modal-open {
  overflow: hidden !important;
  overscroll-behavior: none !important;
}

.auto-contact-modal-overlay,
.fixed.inset-0.bg-black.bg-opacity-50.flex.items-center.justify-center.p-4.z-50.backdrop-blur-sm:has([role="dialog"][aria-labelledby="form-title"] #telefone) {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  background: rgba(2, 6, 23, .54) !important;
  backdrop-filter: blur(10px) !important;
  z-index: 10050 !important;
  overflow: hidden !important;
}

.auto-contact-modal-box,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) {
  display: flex !important;
  flex-direction: column !important;
  width: min(560px, calc(100vw - 48px)) !important;
  max-width: none !important;
  max-height: min(90vh, 760px) !important;
  max-height: min(90dvh, 760px) !important;
  min-height: 0 !important;
  padding: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  border: 1px solid #dbe7e6 !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  box-shadow: 0 28px 80px rgba(15, 23, 42, .26) !important;
  box-sizing: border-box !important;
  overscroll-behavior: contain !important;
}

.auto-contact-modal-box > div:first-child,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child {
  position: sticky !important;
  top: 0 !important;
  z-index: 5 !important;
  display: grid !important;
  grid-template-columns: 46px minmax(0, 1fr) !important;
  grid-template-rows: auto auto !important;
  column-gap: 14px !important;
  row-gap: 3px !important;
  align-items: center !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 20px 22px !important;
  text-align: left !important;
  border-bottom: 1px solid #dbe7e6 !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%) !important;
  box-sizing: border-box !important;
}

.auto-contact-modal-box > div:first-child > div:first-child,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child > div:first-child {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  align-self: center !important;
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  margin: 0 !important;
  border-radius: 13px !important;
  background: linear-gradient(135deg, #0f766e 0%, #07363b 100%) !important;
  box-shadow: 0 10px 24px rgba(15, 118, 110, .20) !important;
}

.auto-contact-modal-box > div:first-child svg,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child svg {
  width: 21px !important;
  height: 21px !important;
}

.auto-contact-modal-box #form-title,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 0 !important;
  margin: 0 !important;
  color: #0f172a !important;
  font-size: 21px !important;
  font-weight: 850 !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

.auto-contact-modal-box #form-title + p,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title + p {
  grid-column: 2 !important;
  grid-row: 2 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: manual !important;
}

.auto-contact-modal-form,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form {
  display: flex !important;
  flex: 1 1 auto !important;
  flex-direction: column !important;
  min-height: 0 !important;
  width: 100% !important;
  padding: 20px 22px 0 !important;
  box-sizing: border-box !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  margin-top: 14px !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) label {
  display: block !important;
  margin-bottom: 7px !important;
  color: #334155 !important;
  font-size: 13px !important;
  font-weight: 760 !important;
  line-height: 1.25 !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) .input-field {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 44px !important;
  padding: 10px 12px !important;
  border: 1px solid #c8d8d6 !important;
  border-radius: 11px !important;
  background: #fbfefd !important;
  color: #0f172a !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .74) !important;
  box-sizing: border-box !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) textarea.input-field {
  min-height: 104px !important;
  max-width: 100% !important;
  resize: vertical !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) .input-field:focus {
  border-color: rgba(15, 118, 110, .62) !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(15, 118, 110, .12) !important;
  outline: none !important;
}

.auto-contact-modal-footer,
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 {
  position: sticky !important;
  bottom: 0 !important;
  z-index: 5 !important;
  display: flex !important;
  flex: 0 0 auto !important;
  gap: 12px !important;
  width: auto !important;
  margin: 18px -22px 0 !important;
  padding: 14px 22px 18px !important;
  border-top: 1px solid #dbe7e6 !important;
  background: rgba(255, 255, 255, .96) !important;
  backdrop-filter: blur(8px) !important;
  box-sizing: border-box !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 > button {
  min-width: 0 !important;
  min-height: 44px !important;
  border-radius: 11px !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1 !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 > button[type="button"] {
  color: #334155 !important;
  border: 1px solid #dbe7e6 !important;
  background: #f8fafc !important;
}

[role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 > button[type="submit"],
[role="dialog"][aria-labelledby="form-title"]:has(#telefone) .btn-primary {
  color: #ffffff !important;
  border: 1px solid transparent !important;
  background: linear-gradient(135deg, #0f766e 0%, #07363b 100%) !important;
  box-shadow: 0 12px 26px rgba(15, 118, 110, .20) !important;
}

@media (max-width: 768px) {
  .auto-contact-modal-overlay,
  .fixed.inset-0.bg-black.bg-opacity-50.flex.items-center.justify-center.p-4.z-50.backdrop-blur-sm:has([role="dialog"][aria-labelledby="form-title"] #telefone) {
    align-items: center !important;
    padding: 10px !important;
  }

  .auto-contact-modal-box,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) {
    width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px) !important;
    border-radius: 16px !important;
  }

  .auto-contact-modal-box > div:first-child,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child {
    grid-template-columns: 38px minmax(0, 1fr) !important;
    column-gap: 11px !important;
    padding: 15px 15px !important;
  }

  .auto-contact-modal-box > div:first-child > div:first-child,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child > div:first-child {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    border-radius: 12px !important;
  }

  .auto-contact-modal-box > div:first-child svg,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child svg {
    width: 18px !important;
    height: 18px !important;
  }

  .auto-contact-modal-box #form-title,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title {
    font-size: 18px !important;
    line-height: 1.18 !important;
  }

  .auto-contact-modal-box #form-title + p,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title + p {
    font-size: 12.5px !important;
    line-height: 1.28 !important;
    max-width: 100% !important;
  }

  .auto-contact-modal-form,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form {
    padding: 15px 15px 0 !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form.space-y-6 > :not([hidden]) ~ :not([hidden]) {
    margin-top: 11px !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) .input-field {
    min-height: 42px !important;
    font-size: 14px !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) textarea.input-field {
    min-height: 88px !important;
  }

  .auto-contact-modal-footer,
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 {
    gap: 10px !important;
    margin: 14px -15px 0 !important;
    padding: 12px 15px calc(14px + env(safe-area-inset-bottom)) !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 > button {
    min-height: 42px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    font-size: 13px !important;
  }
}
