/* [project]/src/app/globals.css [app-client] (css) */
:root {
  --cor-primaria: #41b9e1;
  --cor-primaria-escura: #2a9bbf;
  --cor-primaria-clara: #6ecce9;
  --cor-fundo: #f5f6fb;
  --cor-texto: #27324a;
  --cor-sucesso: #28a745;
  --cor-erro: #dc3545;
}

html, body {
  height: 100%;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  font-family: Segoe UI, Tahoma, Geneva, Verdana, sans-serif;
}

.login-container {
  background: linear-gradient(135deg, var(--cor-primaria) 0%, var(--cor-primaria-escura) 100%);
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  padding: 20px;
  display: flex;
}

.login-card {
  background: #fff;
  border-radius: 15px;
  width: 100%;
  max-width: 420px;
  padding: 40px;
  box-shadow: 0 10px 30px #0003;
}

.login-logo {
  text-align: center;
  margin-bottom: 30px;
}

.login-titulo {
  text-align: center;
  color: var(--cor-primaria);
  margin-bottom: 30px;
  font-size: 1.5rem;
  font-weight: 600;
}

.btn-primario {
  background-color: var(--cor-primaria);
  border-color: var(--cor-primaria);
  color: #fff;
  cursor: pointer;
  border: 1px solid #0000;
  border-radius: 8px;
  width: 100%;
  padding: 12px 30px;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
  transition: all .3s;
}

.btn-primario:hover {
  background-color: var(--cor-primaria-escura);
  border-color: var(--cor-primaria-escura);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px #4e76c14d;
}

.btn-primario:disabled {
  cursor: not-allowed;
  background-color: #6c757d;
  border-color: #6c757d;
  transform: none;
}

.form-control {
  color: #212529;
  box-sizing: border-box;
  background-color: #fff;
  border: 1px solid #ced4da;
  border-radius: .375rem;
  width: 100%;
  padding: .375rem .75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
  display: block;
}

.form-control:focus {
  border-color: var(--cor-primaria);
  outline: none;
  box-shadow: 0 0 0 .2rem #4e76c140;
}

.form-label {
  color: var(--cor-texto);
  margin-bottom: 8px;
  font-weight: 500;
  display: block;
}

.mb-3 {
  margin-bottom: 1rem;
}

.d-grid {
  display: grid;
}

.text-center {
  text-align: center;
}

.text-decoration-none {
  text-decoration: none;
}

.text-decoration-none:hover {
  text-decoration: underline;
}

.senha-toggle {
  cursor: pointer;
  color: #6c757d;
  z-index: 2;
  background: none;
  border: none;
  justify-content: center;
  align-items: center;
  padding: 2px;
  display: flex;
  position: absolute;
  bottom: 6px;
  right: 10px;
}

.senha-toggle:after {
  content: "";
  opacity: 0;
  background: currentColor;
  width: 18px;
  height: 2px;
  transition: opacity .2s;
  position: absolute;
  transform: rotate(-45deg);
}

.senha-toggle--ativo {
  color: var(--cor-primaria);
}

.senha-toggle--ativo:after {
  opacity: 1;
}

.senha-toggle:hover {
  color: var(--cor-primaria);
}

.position-relative {
  position: relative;
}

.form-check {
  align-items: center;
  gap: 8px;
  display: flex;
}

.form-check-input {
  cursor: pointer;
  width: 1em;
  height: 1em;
  accent-color: var(--cor-primaria);
}

.form-check-label {
  cursor: pointer;
  color: var(--cor-texto);
  font-size: .9rem;
}

.alert {
  border: none;
  border-radius: 8px;
  margin-bottom: 1rem;
  padding: 15px 20px;
  font-size: .9rem;
}

.alert-danger {
  color: #721c24;
  background-color: #f8d7da;
}

.alert-success {
  color: #155724;
  background-color: #d4edda;
}

.spinner-border {
  vertical-align: -.125em;
  border: .2em solid;
  border-right-color: #0000;
  border-radius: 50%;
  width: 1rem;
  height: 1rem;
  animation: .75s linear infinite spinner-border;
  display: inline-block;
}

.spinner-border-sm {
  border-width: .15em;
  width: .85rem;
  height: .85rem;
}

.me-2 {
  margin-right: .5rem;
}

@keyframes spinner-border {
  to {
    transform: rotate(360deg);
  }
}

.requisitos-senha {
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 8px;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 4px;
  padding: 12px 14px;
  display: flex;
}

.requisito {
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  transition: color .2s;
  display: flex;
}

.requisito--ok {
  color: #28a745;
}

.requisito--erro {
  color: #dc3545;
}

@media (max-width: 576px) {
  .login-card {
    padding: 28px 20px;
  }

  .login-logo svg {
    width: 52px;
    height: 52px;
  }
}

:root {
  --altura-header: 68px;
  --largura-sidebar: 240px;
  --largura-sidebar-colapsada: 78px;
  --sidebar-label-offset: 14px;
  --sidebar-collapsed-icon-offset: -8px;
  --cor-sidebar: #fff;
  --cor-sidebar-texto: #2b3552;
  --cor-sidebar-hover: #41b9e11f;
  --cor-header: #41b9e1;
  --cor-borda: #d3d6e899;
  --tam-icone-card: 56px;
  --raio-icone-card: 16px;
  --tam-icone-svg: 26px;
}

body.tema-escuro {
  --cor-fundo: #121420;
  --cor-texto: #e6e9f5;
  --cor-sidebar: #1c1f2d;
  --cor-sidebar-texto: #d7dbf2;
  --cor-sidebar-hover: #41b9e133;
  --cor-header: #1a3a4a;
  --cor-borda: #d3d6e82e;
}

.bi {
  fill: currentColor;
  width: 1em;
  height: 1em;
  display: inline-block;
}

.header-dashboard {
  top: 0;
  left: var(--largura-sidebar);
  width: calc(100% - var(--largura-sidebar));
  height: var(--altura-header);
  background: var(--cor-header);
  color: #fff;
  z-index: 1040;
  justify-content: space-between;
  align-items: center;
  padding: 0 24px;
  transition: left .3s, width .3s, background .3s;
  display: flex;
  position: fixed;
  box-shadow: 0 14px 32px #324a7847;
}

body.sidebar-collapsed .header-dashboard {
  left: var(--largura-sidebar-colapsada);
  width: calc(100% - var(--largura-sidebar-colapsada));
}

.header-left, .header-right {
  align-items: center;
  gap: 16px;
  display: flex;
}

.btn-toggle-sidebar {
  color: #fff;
  cursor: pointer;
  background: none;
  border: 1px solid #ffffff73;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  padding: 0;
  transition: background .2s, border .2s;
  display: flex;
}

.btn-toggle-sidebar:hover {
  background: #fff3;
  border-color: #ffffffa6;
}

.header-system-name {
  letter-spacing: .02em;
  white-space: nowrap;
  font-size: .95rem;
  font-weight: 300;
}

.header-icon {
  color: #fff;
  cursor: pointer;
  background: none;
  border: 1px solid #0000;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 38px;
  height: 38px;
  padding: 0;
  transition: background .2s, border .2s;
  display: flex;
}

.header-icon:hover {
  background: #fff3;
  border-color: #fff6;
}

.header-finance {
  align-items: center;
  gap: 18px;
  display: flex;
}

.finance-item {
  color: #fff;
  cursor: pointer;
  background: none;
  border: none;
  justify-content: center;
  align-items: center;
  padding: 0;
  display: inline-flex;
  position: relative;
}

.finance-icon {
  background: #ffffff26;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 28px;
  display: flex;
}

.finance-symbol {
  font-size: .95rem;
  font-weight: 700;
  line-height: 1;
}

.finance-badge {
  color: #fff;
  border-radius: 9px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  font-size: .68rem;
  font-weight: 700;
  line-height: 18px;
  position: absolute;
  top: -6px;
  right: -10px;
}

.badge-expense {
  background: #d9534f;
}

.badge-income {
  background: #28a745;
}

.header-icones {
  align-items: center;
  gap: 8px;
  display: flex;
}

.badge-notificacao {
  color: #fff;
  background: #d9534f;
  border-radius: 8px;
  min-width: 16px;
  height: 16px;
  padding: 0 3px;
  font-size: .62rem;
  font-weight: 700;
  line-height: 16px;
  position: absolute;
  top: 4px;
  right: 4px;
}

.header-user-info {
  cursor: pointer;
  color: #fff;
  background: #ffffff24;
  border: 1px solid #ffffff59;
  border-radius: 26px;
  align-items: center;
  gap: 10px;
  min-width: 0;
  max-width: 220px;
  padding: 6px 12px;
  transition: background .2s, border .2s;
  display: flex;
}

.header-user-info:hover {
  background: #ffffff38;
  border-color: #ffffff73;
}

.header-user-foto {
  background: #fff;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  display: flex;
  overflow: hidden;
}

.header-user-dados {
  flex-direction: column;
  flex: 1;
  min-width: 0;
  line-height: 1.2;
  display: flex;
}

.header-user-nome {
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: .88rem;
  font-weight: 600;
  overflow: hidden;
}

.header-user-perfil {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #ffffffbf;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: .68rem;
  overflow: hidden;
}

.header-user-seta {
  color: #fffc;
  align-items: center;
  display: flex;
}

.header-dropdown {
  position: relative;
}

.dropdown-menu {
  z-index: 1100;
  border: 1px solid var(--cor-borda);
  background: #fff;
  border-radius: 18px;
  min-width: 280px;
  max-width: 320px;
  padding: 18px 0;
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  box-shadow: 0 24px 48px #2029442e;
}

.dropdown-header {
  border-bottom: 1px solid var(--cor-borda);
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 0 16px 16px;
  display: flex;
}

.dropdown-user-foto {
  background: linear-gradient(135deg, var(--cor-primaria) 0%, var(--cor-primaria-clara) 100%);
  color: #fff;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  font-weight: 700;
  display: flex;
}

.dropdown-header-info {
  flex: 1;
  min-width: 0;
}

.dropdown-header h4 {
  color: var(--cor-texto);
  white-space: nowrap;
  text-overflow: ellipsis;
  margin: 0 0 2px;
  font-size: .95rem;
  font-weight: 600;
  overflow: hidden;
}

.dropdown-header span {
  color: #6b7186;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: .78rem;
  display: block;
  overflow: hidden;
}

.dropdown-menu a {
  color: var(--cor-texto);
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  font-size: .9rem;
  text-decoration: none;
  transition: background .2s, color .2s;
  display: flex;
}

.dropdown-menu a:hover {
  color: var(--cor-primaria);
  background: #41b9e11f;
}

.sidebar {
  width: var(--largura-sidebar);
  background: var(--cor-sidebar);
  border-right: 1px solid var(--cor-borda);
  z-index: 999;
  flex-direction: column;
  transition: width .3s, background .3s;
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  overflow-y: auto;
  box-shadow: 6px 0 18px #1e263e0f;
}

.sidebar::-webkit-scrollbar {
  width: 4px;
}

.sidebar::-webkit-scrollbar-thumb {
  background-color: #41b9e14d;
  border-radius: 2px;
}

.sidebar-topo {
  border-bottom: 1px solid var(--cor-borda);
  min-height: var(--altura-header);
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  display: flex;
}

.sidebar-logo {
  flex: 1;
  justify-content: center;
  align-items: center;
  display: flex;
}

.sidebar-compact-icon {
  background: var(--cor-primaria);
  color: #fff;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 46px;
  height: 46px;
  margin: 0 auto;
  display: none;
}

.sidebar-label {
  padding: 12px var(--sidebar-label-offset) 4px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #434a5e8c;
  white-space: nowrap;
  font-size: .7rem;
  overflow: hidden;
}

.sidebar-menu {
  flex: 1;
  padding: 6px 0 18px;
}

.sidebar-item {
  margin-top: 2px;
}

.sidebar-link {
  color: var(--cor-sidebar-texto);
  border-radius: 10px;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  font-size: .875rem;
  font-weight: 500;
  text-decoration: none;
  transition: background .2s, color .2s;
  display: flex;
}

.sidebar-link:hover, .sidebar-link.active {
  background: var(--cor-sidebar-hover);
  color: var(--cor-primaria);
}

.sidebar-icon {
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 20px;
  height: 20px;
  display: flex;
}

.sidebar-texto {
  white-space: nowrap;
  flex: 1;
}

.sidebar-arrow {
  align-items: center;
  transition: transform .3s;
  display: flex;
}

.sidebar-arrow.rotated {
  transform: rotate(90deg);
}

.sidebar-submenu {
  max-height: 0;
  padding-left: 28px;
  padding-right: 8px;
  transition: max-height .3s;
  overflow: hidden;
}

.sidebar-submenu.show {
  max-height: 600px;
}

.sidebar-submenu-link {
  color: var(--cor-sidebar-texto);
  border-radius: 8px;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  font-size: .875rem;
  text-decoration: none;
  transition: background .2s, color .2s;
  display: flex;
}

.sidebar-submenu-link:hover, .sidebar-submenu-link.active {
  background: var(--cor-sidebar-hover);
  color: var(--cor-primaria);
}

.sidebar-submenu-texto {
  white-space: nowrap;
}

body.sidebar-collapsed .sidebar {
  width: var(--largura-sidebar-colapsada);
}

body.sidebar-collapsed .sidebar-logo {
  display: none;
}

body.sidebar-collapsed .sidebar-compact-icon {
  display: flex;
}

body.sidebar-collapsed .sidebar-topo {
  padding: 12px 6px;
}

body.sidebar-collapsed .sidebar-label, body.sidebar-collapsed .sidebar-texto, body.sidebar-collapsed .sidebar-arrow {
  opacity: 0;
  pointer-events: none;
  width: 0;
  position: absolute;
  overflow: hidden;
}

body.sidebar-collapsed .sidebar-submenu {
  display: none;
}

body.sidebar-collapsed .sidebar-link {
  justify-content: center;
  padding: 10px;
}

.main-content {
  margin-top: var(--altura-header);
  margin-left: var(--largura-sidebar);
  min-height: calc(100vh - var(--altura-header));
  background: var(--cor-fundo);
  z-index: 1;
  padding: 24px 28px 80px;
  transition: margin-left .3s;
  position: relative;
}

body.sidebar-collapsed .main-content {
  margin-left: var(--largura-sidebar-colapsada);
}

.footer-dashboard {
  border-top: 1px solid var(--cor-borda);
  margin-left: var(--largura-sidebar);
  text-align: center;
  color: var(--cor-texto);
  background: #fff;
  padding: 14px 28px;
  transition: margin-left .3s, background .3s;
}

body.sidebar-collapsed .footer-dashboard {
  margin-left: var(--largura-sidebar-colapsada);
}

body.tema-escuro .footer-dashboard, body.tema-escuro .sidebar, body.tema-escuro .dropdown-menu {
  background: var(--cor-sidebar);
}

.dashboard-cards {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 32px;
  display: grid;
}

.dashboard-card {
  background: #fff;
  border: 1px solid #1f35561a;
  border-radius: 16px;
  align-items: center;
  gap: 14px;
  padding: 12px;
  transition: transform .25s, box-shadow .25s;
  display: flex;
  box-shadow: 0 10px 24px #0f172a0f;
}

body.tema-escuro .dashboard-card {
  background: var(--cor-sidebar);
  border-color: var(--cor-borda);
}

.dashboard-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 26px 48px #0f172a1f;
}

.dashboard-card-icon {
  width: var(--tam-icone-card);
  height: var(--tam-icone-card);
  flex: 0 0 var(--tam-icone-card);
  border-radius: var(--raio-icone-card);
  color: #fff;
  background: linear-gradient(135deg, var(--cor-primaria) 0%, var(--cor-primaria-escura) 100%);
  justify-content: center;
  align-items: center;
  display: flex;
  box-shadow: 0 8px 16px #41b9e140;
}

.dashboard-card-icon .bi {
  width: var(--tam-icone-svg);
  height: var(--tam-icone-svg);
}

.dashboard-card-content {
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  display: flex;
}

.dashboard-card-titulo {
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #27324a9e;
  font-size: .72rem;
  font-weight: 600;
}

.dashboard-card-valor {
  color: var(--cor-primaria-escura);
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.1;
}

.dashboard-card-info {
  color: #27324aa6;
  font-size: .8rem;
}

body.tema-escuro .dashboard-card-titulo, body.tema-escuro .dashboard-card-info {
  color: #e6e9f599;
}

body.tema-escuro .dashboard-card-valor {
  color: var(--cor-primaria-clara);
}

.dashboard-welcome-card {
  background: #fff;
  border: 1px solid #1f35561a;
  border-radius: 16px;
  margin-bottom: 24px;
  padding: 24px;
  box-shadow: 0 10px 24px #0f172a0f;
}

body.tema-escuro .dashboard-welcome-card {
  background: var(--cor-sidebar);
  border-color: var(--cor-borda);
}

.dashboard-welcome-card h2 {
  color: var(--cor-primaria);
  margin: 0 0 6px;
  font-size: 1.15rem;
  font-weight: 600;
}

.dashboard-welcome-card p {
  color: #27324abf;
  margin: 0;
  font-size: .92rem;
}

@media (min-width: 1101px) {
  .sidebar {
    transform: none !important;
  }

  .header-dashboard {
    left: var(--largura-sidebar) !important;
    width: calc(100% - var(--largura-sidebar)) !important;
  }

  .main-content {
    margin-left: var(--largura-sidebar) !important;
  }

  body.sidebar-collapsed .header-dashboard {
    left: var(--largura-sidebar-colapsada) !important;
    width: calc(100% - var(--largura-sidebar-colapsada)) !important;
  }

  body.sidebar-collapsed .main-content, body.sidebar-collapsed .footer-dashboard {
    margin-left: var(--largura-sidebar-colapsada) !important;
  }
}

@media (max-width: 1200px) {
  :root {
    --tam-icone-card: 44px;
    --raio-icone-card: 14px;
    --tam-icone-svg: 20px;
  }
}

@media (max-width: 900px) {
  :root {
    --tam-icone-card: 36px;
    --raio-icone-card: 13px;
    --tam-icone-svg: 16px;
  }

  .dashboard-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  :root {
    --tam-icone-card: 32px;
    --raio-icone-card: 12px;
    --tam-icone-svg: 12px;
  }

  .dashboard-cards {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .main-content {
    padding: 16px 14px 60px;
  }
}

.pagina-modulo {
  padding: 0;
}

.modulo-header {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  display: flex;
}

.modulo-titulo {
  color: var(--cor-texto);
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 1.35rem;
  font-weight: 700;
  display: flex;
}

.btn-primario-mod {
  background: var(--cor-primaria);
  color: #fff;
  cursor: pointer;
  white-space: nowrap;
  border: none;
  border-radius: 8px;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  font-size: .9rem;
  font-weight: 600;
  transition: background .2s;
  display: inline-flex;
}

.btn-primario-mod:hover {
  background: var(--cor-primaria-escura);
}

.modulo-filtros {
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  display: flex;
}

.filtro-busca {
  flex: 1;
  min-width: 200px;
  max-width: 380px;
  position: relative;
}

.filtro-busca svg {
  color: #9aa0b0;
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
}

.filtro-input {
  width: 100%;
  color: var(--cor-texto);
  background: #fff;
  border: 1px solid #dde1ea;
  border-radius: 8px;
  outline: none;
  padding: 8px 12px 8px 34px;
  font-size: .88rem;
  transition: border-color .2s;
}

.filtro-input:focus {
  border-color: var(--cor-primaria);
}

.filtro-select {
  color: var(--cor-texto);
  cursor: pointer;
  background: #fff;
  border: 1px solid #dde1ea;
  border-radius: 8px;
  outline: none;
  padding: 8px 12px;
  font-size: .88rem;
}

.filtro-select:focus {
  border-color: var(--cor-primaria);
}

.filtro-total {
  color: #9aa0b0;
  white-space: nowrap;
  margin-left: auto;
  font-size: .82rem;
}

.modulo-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 12px #00000012;
}

.tabela-wrapper {
  overflow-x: auto;
}

.tabela {
  border-collapse: collapse;
  width: 100%;
  font-size: .875rem;
}

.tabela thead tr {
  background: #f5f6fb;
  border-bottom: 2px solid #e9ecef;
}

.tabela th {
  text-align: left;
  color: #6b7a99;
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
  padding: 11px 14px;
  font-size: .78rem;
  font-weight: 600;
}

.tabela td {
  color: var(--cor-texto);
  vertical-align: middle;
  border-bottom: 1px solid #f0f1f5;
  padding: 12px 14px;
}

.tabela tbody tr:last-child td {
  border-bottom: none;
}

.tabela tbody tr:hover {
  background: #f9fafb;
}

.tabela-vazio {
  text-align: center;
  color: #9aa0b0;
  padding: 48px 20px;
  font-size: .9rem;
}

.linha-inativa td {
  opacity: .55;
}

.celula-nome {
  align-items: center;
  gap: 10px;
  display: flex;
}

.avatar-iniciais {
  background: var(--cor-primaria);
  color: #fff;
  letter-spacing: .02em;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  font-size: .75rem;
  font-weight: 700;
  display: flex;
}

.nome-principal {
  color: var(--cor-texto);
  font-weight: 600;
  display: block;
}

.badge-primeiro-acesso {
  color: #856404;
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 4px;
  margin-top: 2px;
  padding: 1px 6px;
  font-size: .7rem;
  display: inline-block;
}

.celula-email {
  color: #6b7a99;
  font-size: .82rem;
}

.badge-nivel, .badge-estado {
  white-space: nowrap;
  border-radius: 20px;
  align-items: center;
  padding: 3px 10px;
  font-size: .75rem;
  font-weight: 600;
  display: inline-flex;
}

.badge-nivel {
  color: var(--cor-primaria-escura);
  background: #e8f4fd;
}

.badge-ativo {
  color: #15803d;
  background: #d1f5e0;
}

.badge-inativo {
  color: #b91c1c;
  background: #fce8e8;
}

.acoes {
  align-items: center;
  gap: 4px;
  display: flex;
}

.btn-acao {
  cursor: pointer;
  color: #6b7a99;
  background: none;
  border: none;
  border-radius: 7px;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  transition: background .15s, color .15s;
  display: inline-flex;
}

.btn-acao:hover {
  color: var(--cor-texto);
  background: #f0f1f5;
}

.btn-acao:disabled {
  opacity: .4;
  cursor: not-allowed;
}

.btn-acao-ver:hover {
  color: var(--cor-primaria);
  background: #e8f4fd;
}

.btn-acao-editar:hover {
  color: #b45309;
  background: #fff8e1;
}

.btn-acao-toggle-on:hover {
  color: #15803d;
  background: #d1f5e0;
}

.btn-acao-toggle-off:hover {
  color: #b91c1c;
  background: #fce8e8;
}

.btn-acao-reenviar:hover {
  color: #7c3aed;
  background: #f3e8ff;
}

.btn-acao-apagar:hover {
  color: #b91c1c;
  background: #fce8e8;
}

.modal-overlay-mod {
  z-index: 2000;
  background: #00000073;
  justify-content: center;
  align-items: center;
  padding: 16px;
  animation: .15s fadeIn;
  display: flex;
  position: fixed;
  inset: 0;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.modal-caixa {
  background: #fff;
  border-radius: 14px;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  animation: .18s slideUp;
  overflow-y: auto;
  box-shadow: 0 8px 32px #0000002e;
}

.modal-caixa-sm {
  max-width: 380px;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.modal-cabecalho {
  border-bottom: 1px solid #f0f1f5;
  justify-content: space-between;
  align-items: center;
  padding: 18px 22px 14px;
  display: flex;
}

.modal-cabecalho h2, .modal-cabecalho h3 {
  color: var(--cor-texto);
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
}

.modal-cabecalho button {
  cursor: pointer;
  color: #9aa0b0;
  background: none;
  border: none;
  border-radius: 6px;
  align-items: center;
  padding: 4px;
  transition: background .15s;
  display: flex;
}

.modal-cabecalho button:hover {
  color: var(--cor-texto);
  background: #f0f1f5;
}

.modal-corpo {
  padding: 20px 22px;
}

.modal-rodape {
  border-top: 1px solid #f0f1f5;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding: 14px 22px 18px;
  display: flex;
}

.form-grid {
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
  display: grid;
}

.form-grupo {
  flex-direction: column;
  gap: 4px;
  display: flex;
}

.form-grupo-full {
  flex-direction: column;
  grid-column: 1 / -1;
  gap: 4px;
  display: flex;
}

.form-label-mod {
  color: #6b7a99;
  font-size: .82rem;
  font-weight: 600;
}

.obrigatorio {
  color: var(--cor-erro);
  margin-left: 2px;
}

.form-input-mod {
  color: var(--cor-texto);
  box-sizing: border-box;
  background: #fff;
  border: 1px solid #dde1ea;
  border-radius: 8px;
  outline: none;
  width: 100%;
  padding: 9px 12px;
  font-size: .88rem;
  transition: border-color .2s;
}

.form-input-mod:focus {
  border-color: var(--cor-primaria);
}

.form-input-mod.input-erro {
  border-color: var(--cor-erro);
}

.form-hint {
  color: #9aa0b0;
  margin-top: 2px;
  font-size: .75rem;
}

.erro-campo {
  color: var(--cor-erro);
  margin-top: 2px;
  font-size: .75rem;
}

.alerta-erro {
  color: #b91c1c;
  background: #fce8e8;
  border: 1px solid #fca5a5;
  border-radius: 8px;
  margin-bottom: 14px;
  padding: 10px 14px;
  font-size: .85rem;
}

.btn-cancelar-mod {
  color: var(--cor-texto);
  cursor: pointer;
  background: #fff;
  border: 1px solid #dde1ea;
  border-radius: 8px;
  padding: 9px 18px;
  font-size: .88rem;
  font-weight: 600;
  transition: background .15s;
}

.btn-cancelar-mod:hover {
  background: #f5f6fb;
}

.btn-guardar-mod {
  background: var(--cor-primaria);
  color: #fff;
  cursor: pointer;
  border: none;
  border-radius: 8px;
  padding: 9px 22px;
  font-size: .88rem;
  font-weight: 600;
  transition: background .2s;
}

.btn-guardar-mod:hover {
  background: var(--cor-primaria-escura);
}

.btn-guardar-mod:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.btn-apagar-mod {
  background: var(--cor-erro);
  color: #fff;
  cursor: pointer;
  border: none;
  border-radius: 8px;
  padding: 9px 22px;
  font-size: .88rem;
  font-weight: 600;
  transition: background .2s;
}

.btn-apagar-mod:hover {
  background: #b91c1c;
}

.btn-apagar-mod:disabled {
  opacity: .6;
  cursor: not-allowed;
}

.ver-avatar {
  background: var(--cor-primaria);
  color: #fff;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
}

.ver-linhas {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.ver-linha {
  border-bottom: 1px solid #f0f1f5;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 10px;
  display: flex;
}

.ver-linha:last-child {
  border-bottom: none;
}

.ver-label {
  color: #9aa0b0;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: .75rem;
  font-weight: 600;
}

.modal-apagar-icone {
  width: 56px;
  height: 56px;
  color: var(--cor-erro);
  background: #fce8e8;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  margin: 0 auto 12px;
  display: flex;
}

.modal-apagar-titulo {
  text-align: center;
  color: var(--cor-texto);
  margin: 0 0 8px;
  font-size: 1.05rem;
  font-weight: 700;
}

.modal-apagar-texto {
  text-align: center;
  color: #6b7a99;
  margin: 0 0 16px;
  font-size: .88rem;
  line-height: 1.5;
}

.modal-apagar-acoes {
  justify-content: center;
  gap: 10px;
  display: flex;
}

body.tema-escuro .modulo-card {
  background: #1e2639;
}

body.tema-escuro .tabela thead tr {
  background: #252f45;
}

body.tema-escuro .tabela th {
  color: #8892aa;
  border-color: #2e3a52;
}

body.tema-escuro .tabela td {
  color: #d0d5e3;
  border-color: #252f45;
}

body.tema-escuro .tabela tbody tr:hover {
  background: #252f45;
}

body.tema-escuro .filtro-input, body.tema-escuro .filtro-select {
  color: #d0d5e3;
  background: #1e2639;
  border-color: #2e3a52;
}

body.tema-escuro .modal-caixa {
  background: #1e2639;
}

body.tema-escuro .modal-cabecalho {
  border-color: #2e3a52;
}

body.tema-escuro .modal-cabecalho h2, body.tema-escuro .modal-cabecalho h3 {
  color: #d0d5e3;
}

body.tema-escuro .modal-rodape {
  border-color: #2e3a52;
}

body.tema-escuro .form-input-mod, body.tema-escuro .btn-cancelar-mod {
  color: #d0d5e3;
  background: #252f45;
  border-color: #2e3a52;
}

body.tema-escuro .ver-linha {
  border-color: #2e3a52;
}

body.tema-escuro .ver-label {
  color: #8892aa;
}

body.tema-escuro .nome-principal {
  color: #d0d5e3;
}

body.tema-escuro .badge-nivel {
  color: #41b9e1;
  background: #1a3a52;
}

body.tema-escuro .badge-ativo {
  color: #4ade80;
  background: #14302a;
}

body.tema-escuro .badge-inativo {
  color: #f87171;
  background: #3a1a1a;
}

body.tema-escuro .alerta-erro {
  color: #f87171;
  background: #3a1a1a;
  border-color: #7f1d1d;
}

body.tema-escuro .btn-acao:hover {
  background: #252f45;
}

body.tema-escuro .modulo-titulo {
  color: #d0d5e3;
}

@media (max-width: 640px) {
  .form-grid {
    grid-template-columns: 1fr;
  }

  .modulo-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .tabela th, .tabela td {
    padding: 10px;
  }
}

/*# sourceMappingURL=src_app_globals_0p2ml0n.css.map*/