.mx-auth {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--espaco-6);
  background:
    radial-gradient(circle at 18% 18%, rgba(37, 99, 235, 0.18), transparent 38%),
    radial-gradient(circle at 82% 76%, rgba(30, 64, 175, 0.2), transparent 35%),
    linear-gradient(160deg, #eef3ff 0%, #f8fbff 48%, #edf4ff 100%);
}

.mx-auth__layout {
  width: 100%;
  max-width: 1080px;
  display: grid;
  grid-template-columns: 1.15fr minmax(340px, 430px);
  gap: var(--espaco-6);
  align-items: center;
}

.mx-auth__brand {
  color: var(--cor-texto, #0f172a);
  padding: var(--espaco-8);
  border-radius: var(--raio-xl, 20px);
  border: 1px solid rgba(37, 99, 235, 0.16);
  background: linear-gradient(160deg, rgba(255,255,255,0.84), rgba(239,246,255,0.72));
  box-shadow: 0 20px 40px rgba(30, 64, 175, 0.12);
  backdrop-filter: blur(6px);
}

.mx-auth__brand-badge {
  display: inline-flex;
  padding: 6px 12px;
  border-radius: var(--raio-pill, 999px);
  background: rgba(37, 99, 235, 0.12);
  color: var(--azul-700, #1d4ed8);
  letter-spacing: 0.08em;
  font: var(--peso-semi, 600) 11px/1 var(--fonte, sans-serif);
}

.mx-auth__brand-titulo {
  margin: 18px 0 10px;
  max-width: 18ch;
  font: var(--peso-bold, 700) clamp(28px, 4vw, 44px)/1.1 var(--fonte, sans-serif);
}

.mx-auth__brand-texto {
  margin: 0;
  max-width: 46ch;
  color: var(--cor-texto-suave, #475569);
  font: var(--peso-regular, 400) var(--tam-md, 14px)/1.7 var(--fonte, sans-serif);
}

.mx-auth__brand-itens {
  margin-top: 28px;
  display: grid;
  gap: 12px;
}

.mx-auth__brand-itens span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--azul-800, #1e40af);
  font: var(--peso-medio, 500) var(--tam-sm, 13px)/1.2 var(--fonte, sans-serif);
}

.mx-auth__brand-itens span::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--cor-sucesso, #16a34a);
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.12);
}

.mx-auth__card {
  width: 100%;
  border-radius: 18px;
}

.mx-auth__card::part(card) {
  border-radius: 18px;
}

.mx-auth__card > div:first-child {
  position: relative;
}

.mx-auth__header {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: var(--espaco-5);
}

.mx-auth__logo {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: var(--cor-primaria, #2563eb);
  color: #fff;
  font: var(--peso-bold, 700) 20px/1 var(--fonte, sans-serif);
}

.mx-auth__header h1 {
  margin: 0;
  font: var(--peso-semi, 600) var(--tam-xl, 22px)/1.2 var(--fonte, sans-serif);
  color: var(--cor-texto, #0f172a);
}

.mx-auth__header p {
  margin: 6px 0 0;
  color: var(--cor-texto-suave, #475569);
  font: var(--peso-regular, 400) var(--tam-sm, 13px)/1.4 var(--fonte, sans-serif);
}

.mx-auth__campos {
  display: flex;
  flex-direction: column;
  gap: var(--espaco-4);
}

.mx-auth__mensagem {
  min-height: 22px;
  margin: var(--espaco-4) 0;
  font: var(--peso-medio, 500) var(--tam-sm, 13px)/1.3 var(--fonte, sans-serif);
}

.mx-auth__mensagem--erro { color: var(--cor-perigo, #dc2626); }
.mx-auth__mensagem--sucesso { color: var(--cor-sucesso, #16a34a); }

.mx-auth__acoes {
  margin-top: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.mx-auth__botao {
  margin-top: 0;
}

.mx-auth__botao--secundario {
  margin-top: 0;
}

.mx-auth__recuperar {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mx-auth__recuperar-info,
.mx-auth__recuperar-ajuda {
  margin: 0;
  color: var(--cor-texto-suave, #475569);
  font: var(--peso-regular, 400) var(--tam-sm, 13px)/1.5 var(--fonte, sans-serif);
}

.mx-auth__recuperar-feedback {
  margin: 0;
  min-height: 18px;
  font: var(--peso-medio, 500) var(--tam-sm, 13px)/1.3 var(--fonte, sans-serif);
}

.mx-auth__recuperar-feedback--erro {
  color: var(--cor-perigo, #dc2626);
}

.mx-auth__recuperar-feedback--sucesso {
  color: var(--cor-sucesso, #16a34a);
}

@media (max-width: 980px) {
  .mx-auth__layout {
    grid-template-columns: 1fr;
    max-width: 520px;
  }

  .mx-auth__brand {
    padding: var(--espaco-6);
  }

  .mx-auth__brand-titulo {
    max-width: none;
    font-size: clamp(26px, 7vw, 34px);
  }
}

.mx-home {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--espaco-4);
}

.mx-home__acoes {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: var(--espaco-4);
}

.mx-home__titulo {
  margin: 0 0 8px;
  color: var(--cor-texto, #0f172a);
  font: var(--peso-semi, 600) var(--tam-lg, 17px)/1.2 var(--fonte, sans-serif);
}

.mx-home__texto {
  margin: 0;
  color: var(--cor-texto-suave, #475569);
  font: var(--peso-regular, 400) var(--tam-md, 14px)/1.5 var(--fonte, sans-serif);
}

.mx-acessos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap: var(--espaco-4);
}

.mx-acesso-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mx-acessos-tabs {
  display: flex;
  gap: 10px;
  margin-bottom: var(--espaco-4);
}

.mx-lista-wrap {
  margin-top: 12px;
  border: 1px solid var(--cor-borda, #e2e8f0);
  border-radius: var(--raio, 10px);
  overflow: auto;
}

.mx-lista {
  width: 100%;
  border-collapse: collapse;
  min-width: 360px;
}

.mx-lista th,
.mx-lista td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--cor-borda, #e2e8f0);
  font: var(--peso-regular, 400) var(--tam-sm, 13px)/1.4 var(--fonte, sans-serif);
}

.mx-lista th {
  color: var(--cor-texto-suave, #475569);
  font-weight: var(--peso-semi, 600);
  background: var(--cor-fundo-suave, #f1f5f9);
}

.mx-lista tbody tr {
  cursor: pointer;
  transition: background var(--transicao-rapida, 120ms);
}

.mx-lista tbody tr:hover {
  background: var(--azul-50, #eff6ff);
}

.mx-lista tbody tr.ativo {
  background: rgba(37, 99, 235, 0.1);
}

.mx-acessos-permissoes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mx-chip {
  display: inline-flex;
  align-items: center;
  border-radius: var(--raio-pill, 999px);
  padding: 6px 10px;
  background: var(--azul-50, #eff6ff);
  color: var(--azul-700, #1d4ed8);
  border: 1px solid var(--azul-200, #bfdbfe);
  font: var(--peso-medio, 500) var(--tam-xs, 12px)/1 var(--fonte, sans-serif);
}
