/*
  Ajuste visual isolado para Novo Contato mobile e modal de Importacao.
  Nao altera logica, eventos, APIs, payloads, validacoes, campos ou fluxo.
*/

:root {
  --acmf-ink: #0f172a;
  --acmf-muted: #64748b;
  --acmf-line: #dbe7e6;
  --acmf-line-strong: #c8d8d6;
  --acmf-soft: #f7fbfa;
  --acmf-accent: #0f766e;
  --acmf-accent-hover: #115e59;
  --acmf-shadow: 0 24px 70px rgba(15, 23, 42, .22);
  --acmf-radius: 16px;
}

/* Modal Importar Contatos CSV/XLSX - desktop e mobile */
.fixed.inset-0.z-50.backdrop-blur-sm:has([role="dialog"][aria-labelledby="import-title"] #csv-file) {
  z-index: 10030 !important;
  padding: 20px !important;
  background: rgba(2, 6, 23, .52) !important;
  backdrop-filter: blur(10px);
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) {
  width: min(720px, calc(100vw - 40px)) !important;
  max-width: none !important;
  max-height: calc(100dvh - 40px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0 !important;
  border: 1px solid var(--acmf-line) !important;
  border-radius: var(--acmf-radius) !important;
  background: #ffffff !important;
  box-shadow: var(--acmf-shadow) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > div:first-child {
  position: sticky;
  top: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  column-gap: 14px;
  row-gap: 3px;
  align-items: center;
  margin: 0 !important;
  padding: 18px 22px !important;
  text-align: left !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%);
  border-bottom: 1px solid var(--acmf-line);
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > div:first-child > div:first-child {
  grid-column: 1;
  grid-row: 1 / span 2;
  width: 44px !important;
  height: 44px !important;
  margin: 0 !important;
  border-radius: 13px !important;
  background: linear-gradient(135deg, var(--acmf-accent), #2563eb) !important;
  box-shadow: 0 10px 24px rgba(15, 118, 110, .22);
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > div:first-child svg {
  width: 21px !important;
  height: 21px !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #import-title {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  color: var(--acmf-ink) !important;
  font-size: 1.22rem !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #import-title + p {
  grid-column: 2;
  grid-row: 2;
  min-width: 0;
  margin-top: 0 !important;
  color: var(--acmf-muted) !important;
  font-size: .88rem !important;
  line-height: 1.35 !important;
  overflow-wrap: normal;
  word-break: normal;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  padding: 18px 22px 0;
  background: #fbfefd;
}

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

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div {
  border-color: var(--acmf-line) !important;
  border-radius: 14px !important;
  background: #ffffff !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .045);
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:nth-child(3) {
  padding: 16px !important;
  background: linear-gradient(180deg, #ffffff 0%, var(--acmf-soft) 100%) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child > div,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:nth-child(3) > div {
  gap: 12px !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child > div > div:first-child,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:nth-child(3) > div > div:first-child {
  width: 38px !important;
  height: 38px !important;
  border-radius: 11px !important;
  background: #e8f4f2 !important;
  color: var(--acmf-accent) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) h3 {
  color: var(--acmf-ink) !important;
  font-size: .96rem !important;
  line-height: 1.35 !important;
  margin-bottom: 5px !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) p,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) li {
  color: var(--acmf-muted) !important;
  line-height: 1.45 !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) button {
  min-height: 40px;
  border-radius: 10px !important;
  font-weight: 700 !important;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) button:hover {
  transform: translateY(-1px);
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child button,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) .btn-primary {
  background: linear-gradient(135deg, var(--acmf-accent), #2563eb) !important;
  box-shadow: 0 10px 22px rgba(15, 118, 110, .18) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child button:hover,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) .btn-primary:hover {
  background: linear-gradient(135deg, var(--acmf-accent-hover), #1d4ed8) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) label[for="csv-file"].block {
  color: #334155 !important;
  font-size: .86rem !important;
  margin-bottom: 8px !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #csv-file + label,
[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) div:has(> #csv-file) {
  border-color: var(--acmf-line-strong) !important;
  border-radius: 14px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfb 100%) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) div:has(> #csv-file) {
  padding: 18px !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #csv-file + label > div:first-child {
  width: 40px !important;
  height: 40px !important;
  margin-bottom: 8px !important;
  border-radius: 11px !important;
  background: #eef8f6 !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) ul {
  display: grid;
  gap: 7px;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) li {
  align-items: flex-start !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) li > div:first-child {
  margin-top: .45em;
  background: var(--acmf-accent) !important;
}

[role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:last-child {
  position: sticky;
  bottom: 0;
  z-index: 3;
  margin: 16px -22px 0 !important;
  padding: 14px 22px 18px !important;
  border-top: 1px solid var(--acmf-line);
  background: rgba(255, 255, 255, .96) !important;
  border-radius: 0 !important;
  box-shadow: none;
  backdrop-filter: blur(8px);
}

/* Novo Contato - somente mobile */
@media (max-width: 768px) {
  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) {
    width: calc(100vw - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    overflow: auto !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child {
    grid-template-columns: 36px minmax(0, 1fr) !important;
    column-gap: 10px !important;
    row-gap: 2px !important;
    align-items: center !important;
    padding: 14px 15px !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) > div:first-child > div:first-child {
    grid-column: 1;
    grid-row: 1 / span 2;
    width: 36px !important;
    height: 36px !important;
    align-self: start;
    margin: 1px 0 0 !important;
    border-radius: 11px !important;
  }

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

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    font-size: 1.04rem !important;
    line-height: 1.2 !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) #form-title + p {
    grid-column: 2;
    grid-row: 2;
    min-width: 0;
    max-width: 100%;
    margin: 1px 0 0 !important;
    font-size: .82rem !important;
    line-height: 1.28 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form {
    padding: 14px 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 {
    width: 100% !important;
    min-height: 42px;
    box-sizing: border-box;
    font-size: 16px !important;
  }

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

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px !important;
    margin: 13px -15px 0 !important;
    padding: 11px 15px calc(11px + env(safe-area-inset-bottom)) !important;
  }

  [role="dialog"][aria-labelledby="form-title"]:has(#telefone) form > div.flex.gap-4.pt-6 button {
    min-height: 40px !important;
    padding: 9px 10px !important;
    font-size: .9rem !important;
    white-space: nowrap;
  }

  .fixed.inset-0.z-50.backdrop-blur-sm:has([role="dialog"][aria-labelledby="import-title"] #csv-file) {
    align-items: stretch !important;
    padding: 7px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) {
    width: calc(100vw - 14px) !important;
    max-height: calc(100dvh - 14px) !important;
    border-radius: 14px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > div:first-child {
    grid-template-columns: 36px minmax(0, 1fr);
    column-gap: 10px;
    padding: 14px 15px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > div:first-child > div:first-child {
    width: 36px !important;
    height: 36px !important;
    border-radius: 11px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #import-title {
    font-size: 1.04rem !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) #import-title + p {
    font-size: .8rem !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 {
    padding: 14px 15px 0;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child > div,
  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:nth-child(3) > div {
    display: grid !important;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:first-child > div > div:first-child,
  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:nth-child(3) > div > div:first-child {
    width: 34px !important;
    height: 34px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) div:has(> #csv-file) {
    padding: 14px !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:last-child {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px !important;
    margin: 14px -15px 0 !important;
    padding: 11px 15px calc(11px + env(safe-area-inset-bottom)) !important;
  }

  [role="dialog"][aria-labelledby="import-title"]:has(#csv-file) > .space-y-6 > div:last-child button {
    min-height: 40px !important;
    padding: 9px 10px !important;
    font-size: .88rem !important;
  }
}
