/* =========================================================
   ZYSTOCK — STYLE LIMPO CONSOLIDADO
   Gerado a partir do CSS atual, removendo duplicações internas
   e mantendo os últimos valores efetivos por seletor/contexto.
========================================================= */

:root {
  --cor-fundo: #0b1e3a;
  --cor-topo: #12396d;
  --cor-menu: #f4f7fc;
  --cor-conteudo: #edf2f8;
  --cor-card: #ffffff;
  --cor-card-login: #173b6d;
  --cor-borda: #2a5a93;
  --cor-input: #27497a;
  --cor-input-borda: #345f96;
  --cor-botao: #39c86d;
  --cor-botao-hover: #49d97d;
  --cor-botao-azul: #4f86c6;
  --cor-botao-azul-hover: #5d96d8;
  --cor-botao-sec: #516481;
  --cor-botao-sec-hover: #627594;
  --cor-botao-sair: #dc2626;
  --cor-botao-sair-hover: #ef4444;
  --cor-texto: #ffffff;
  --cor-texto-sec: #d5deea;
  --cor-texto-info: #9fb4cf;
  --cor-texto-azul: #9fd0ff;
  --cor-link: #9fd0ff;
  --cor-link-hover: #c5e4ff;
  --cor-erro: #fca5a5;
  --cor-ok: #39c86d;
  --cor-alerta: #f59e0b;
  --cor-alerta-bloqueio: #f87171;
  --cor-linha: #29466f;
  --cor-badge: #ef4444;
  --sombra: 0 18px 50px rgba(0, 0, 0, 0.25);
  --shadow: 0 18px 42px rgba(15, 23, 42, 0.10);
  --shadow-soft: 0 10px 24px rgba(15, 23, 42, 0.06);
  --muted: #64748b;
  --text: #0f172a;
  --line-soft: #d9e3f0;
  --bg-soft: #f8fbff;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  font-family: Arial, Helvetica, sans-serif;
  background: var(--cor-fundo);
  color: var(--cor-texto);
  height: 100%;
  overflow: hidden;
}

button,
input,
select,
textarea {
  font: inherit;
}

.hidden {
  display: none !important;
}

.page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.12), transparent 28%),
    radial-gradient(circle at top right, rgba(79, 70, 229, 0.12), transparent 32%),
    linear-gradient(180deg, #f8fbff 0%, #eef3f9 100%);
}

.card-login {
  width: 520px;
  max-width: 100%;
  min-height: auto;
  padding: 32px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.90);
  border: 1px solid rgba(207, 217, 230, 0.95);
  box-shadow: 0 30px 90px rgba(15, 23, 42, 0.12),
    0 10px 24px rgba(15, 23, 42, 0.05);
  backdrop-filter: blur(16px);
  text-align: left;
}

.top-bar {
  height: 5px;
  width: 100%;
  border-radius: 999px;
  margin-bottom: 24px;
  background: linear-gradient(90deg, #4f46e5, #2563eb, #22c55e);
}

.login-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.08);
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.logo-login {
  margin: 0;
  text-align: left;
  font-size: 44px;
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: #0f172a;
}

.subtitle-login {
  margin: 12px 0 6px;
  text-align: left;
  color: #475569;
  font-size: 16px;
}

.version-login {
  margin: 0 0 22px;
  text-align: left;
  color: #64748b;
  font-size: 12px;
}

.form-area label {
  display: block;
  margin-bottom: 8px;
  text-align: left;
  color: #334155;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.input-wrap {
  background: rgba(248, 250, 252, 0.96);
  border: 1px solid #dce5f0;
  border-radius: 18px;
  margin-bottom: 16px;
  transition: 0.22s ease;
  flex: 1;
}

.input-wrap:focus-within {
  border-color: #6366f1;
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.10);
}

.input-wrap input,
.input-wrap textarea,
.input-wrap select {
  width: 100%;
  padding: 15px 16px;
  border: none;
  background: transparent;
  color: #0f172a;
  font-size: 14px;
  outline: none;
  appearance: none;
}

.input-wrap textarea {
  min-height: 96px;
  resize: vertical;
}

.input-wrap input::placeholder,
.input-wrap textarea::placeholder {
  color: #94a3b8;
}

.check-row {
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin: 6px 0 12px;
  color: #475569;
  font-size: 12px;
  font-weight: 500 !important;
  cursor: pointer;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.check-row input {
  accent-color: #4f46e5;
  width: auto;
  margin: 0;
}

.helper-text {
  margin: 0 0 10px;
  color: #64748b;
  font-size: 12px;
  text-align: left;
}

.error-text {
  min-height: 18px;
  margin: 0 0 12px;
  color: #f87171;
  font-size: 12px;
  font-weight: 700;
  text-align: left;
}

.info-text {
  min-height: 18px;
  margin: 0 0 12px;
  color: #16a34a;
  font-size: 12px;
  font-weight: 700;
  text-align: left;
}

.btn-primary,
.btn-secondary,
.btn-blue,
.link-admin {
  width: 100%;
  border: none;
  cursor: pointer;
  transition: 0.2s ease;
}

.btn-primary {
  min-height: 56px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid rgba(79, 70, 229, 0.20);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-top: 6px;
  background: #1d4ed8;
  color: #fff;
}

.btn-primary:hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, #4338ca, #1d4ed8);
}

.btn-primary:active {
  transform: scale(0.98);
}

.btn-primary:disabled {
  opacity: 0.75;
  cursor: default;
  transform: none;
}

.btn-secondary {
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 16px;
  font-size: 13px;
  font-weight: 700;
  margin-top: 10px;
  background: #eef4ff;
  color: #1d4ed8;
  border: 1px solid #c7d7fe;
}

.btn-secondary:hover {
  background: #cbd5e1;
}

.btn-blue {
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 16px;
  background: #4f86c6;
  color: white;
  font-size: 13px;
  font-weight: 700;
  margin-top: 10px;
}

.btn-blue:hover {
  background: #5d96d8;
}

.link-admin {
  background: transparent;
  color: #2563eb;
  font-size: 12px;
  font-weight: 700;
  text-decoration: underline;
  padding: 8px;
  background: transparent !important;
  color: #2563eb !important;
}

.link-admin:hover {
  color: #1d4ed8;
}

.app-shell {
  display: grid;
  grid-template-columns: 320px 1fr;
  grid-template-rows: 106px 1fr;
  grid-template-areas: "topo topo"
    "menu main";
  min-height: 100vh;
  background: radial-gradient(circle at top right, rgba(29, 78, 216, 0.06), transparent 22%),
    linear-gradient(180deg, #f5f7fb 0%, #edf2f8 100%);
  height: 100vh;
  overflow: hidden;
}

.topo {
  grid-area: topo;
  background: linear-gradient(135deg, #12396d, #1d4ed8);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 28px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.10);
  height: 104px;
}

.topo-esq .logo-app {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #fff;
}

.topo-esq .sub {
  margin-top: 4px;
  font-size: 11px;
  color: #fff;
}

.topo-dir {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.perfil {
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 18px;
  padding: 12px 16px;
  box-shadow: var(--shadow-soft);
  text-align: right;
  min-width: 320px;
}

.perfil-l1 {
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
}

.perfil-l2 {
  margin-top: 4px;
  font-size: 9px;
  color: #fff;
}

.relogio {
  font-size: 10px;
  color: #fff;
}

.menu {
  grid-area: menu;
  background: linear-gradient(180deg, #fbfcfe 0%, #f4f7fc 100%);
  min-height: 0;
  border-right: 1px solid #dce5f0;
  height: calc(100vh - 104px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 10px 12px;
}

.menu-top h2 {
  color: var(--text);
  margin: 0 0 4px;
  font-size: 14px;
}

.menu-top p {
  color: var(--muted);
  max-width: 250px;
  margin: 0;
  font-size: 11px;
  line-height: 1.25;
}

.menu-lista {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow: hidden;
}

.menu-item {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
  border: 1px solid #dbe5f1;
  color: var(--text);
  cursor: pointer;
  transition: 0.18s ease;
  text-align: left;
  box-shadow: var(--shadow-soft);
  min-height: 56px;
  padding: 8px 10px;
  border-radius: 16px;
}

.menu-item:hover {
  background: linear-gradient(180deg, #ffffff 0%, #f1f6ff 100%);
  transform: translateY(-1px);
}

.menu-item.ativo {
  background: linear-gradient(135deg, #12396d, #1d4ed8);
  border-color: transparent;
  color: #ffffff;
}

.menu-item.ativo .menu-sub,
.menu-item.ativo .menu-titulo,
.menu-item.ativo .menu-icon {
  color: #ffffff;
}

.menu-item.sair {
  background: #fff5f5;
  border-color: #fecaca;
  color: #991b1b;
  margin-top: 8px;
}

.menu-item.sair:hover {
  background: #ffe8e8;
}

.menu-ind {
  width: 4px;
  align-self: stretch;
  background: #1d4ed8;
  border-radius: 999px;
  flex-shrink: 0;
}

.menu-item.ativo .menu-ind {
  background: #ffffff;
}

.menu-icon {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 18px;
}

.menu-txt {
  flex: 1;
  min-width: 0;
}

.menu-titulo {
  font-weight: 700;
  color: inherit;
  font-size: 13px;
  line-height: 1.1;
}

.menu-sub {
  margin-top: 3px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.15;
}

.badge {
  min-width: 24px;
  min-height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--cor-badge);
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  flex-shrink: 0;
}

.badge.show {
  display: flex;
}

.ambiente {
  padding: 16px 4px 0;
  margin-top: 8px;
  padding-top: 8px;
}

.linha {
  height: 1px;
  background: #dbe4ee;
  margin-bottom: 18px;
}

.ambiente .tt {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 8px;
}

.ambiente .ok {
  font-size: 11px;
  font-weight: 700;
  color: var(--cor-ok);
  margin-bottom: 12px;
}

.ambiente .alerta {
  font-size: 10px;
  font-weight: 700;
  color: var(--cor-alerta);
  line-height: 1.4;
  white-space: pre-line;
}

.main {
  grid-area: main;
  background: transparent;
  padding: 24px;
  height: calc(100vh - 104px);
  overflow: hidden;
  padding-top: 10px;
  padding-bottom: 10px;
}

.hero {
  background: linear-gradient(135deg, #0f2f57 0%, #1d4ed8 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 20px;
  padding: 24px;
  box-shadow: var(--shadow);
  margin-bottom: 20px;
  color: #fff;
}

.hero h1 {
  margin: 0 0 8px;
  font-size: 26px;
  color: #fff;
}

.hero p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  line-height: 1.5;
}

.dashboard-hero {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 18px;
  margin-bottom: 18px;
}

.dashboard-hero-copy {
  background: linear-gradient(135deg, #0f2f57, #1d4ed8);
  color: #fff;
  border-radius: 24px;
  padding: 28px;
  box-shadow: var(--shadow);
}

.dashboard-badge {
  display: inline-flex;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.dashboard-hero-copy h2 {
  margin: 0 0 10px;
  font-size: 34px;
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.dashboard-hero-copy p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.6;
}

.dashboard-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.quick-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  border-radius: 14px;
  padding: 12px 14px;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.96);
  color: #12396d;
  font-weight: 700;
  transition: 0.18s ease;
}

.quick-action-btn:hover {
  transform: translateY(-1px);
}

.dashboard-hero-side {
  background: linear-gradient(180deg, #ffffff 0%, #f5f9ff 100%);
  border: 1px solid #d9e3f0;
  border-radius: 24px;
  padding: 24px;
  box-shadow: var(--shadow);
}

.hero-side-label {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 800;
  margin-bottom: 12px;
}

.hero-side-value {
  font-size: 30px;
  font-weight: 800;
  color: #12396d;
  margin-bottom: 8px;
}

.hero-side-desc {
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 16px;
}

.hero-side-meta {
  display: grid;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid #e3eaf3;
}

.hero-side-meta div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 13px;
}

.hero-side-meta strong {
  color: var(--text);
}

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

.grid-insights {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d9e3f0;
  border-radius: 18px;
  padding: 20px;
  box-shadow: var(--shadow-soft);
  color: var(--text);
}

.card .rotulo {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 8px;
}

.card .valor {
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 8px;
  word-break: break-word;
  color: #12396d;
}

.card .desc {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.45;
}

.painel,
.panel.two-col {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 16px;
}

.lista {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}

.item-lista {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #e3eaf3;
  border-left: 5px solid #39c86d;
  border-radius: 14px;
  padding: 12px 14px;
}

.item-lista.alerta {
  border-left-color: var(--cor-alerta);
}

.item-lista.bloqueio {
  border-left-color: var(--cor-alerta-bloqueio);
}

.item-lista .t {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 4px;
  color: var(--text);
}

.item-lista .d {
  font-size: 10px;
  color: var(--muted);
  line-height: 1.45;
}

.acoes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.btn-acao {
  font-weight: 700;
  transition: 0.18s ease;
  background: #2563eb;
  color: #fff;
  border: none;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
}

.btn-acao:hover {
  background: linear-gradient(135deg, #0f2f57, #1e40af);
}

.vazio {
  color: var(--muted);
  font-size: 11px;
  margin-top: 12px;
}

.section-title {
  margin: 0 0 14px;
  font-size: 22px;
  color: var(--text);
}

.module-panel,
.dashboard-shortcut-card,
.users-panel {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d9e3f0;
  border-radius: 18px;
  padding: 20px;
  box-shadow: var(--shadow-soft);
  color: var(--text);
}

.toolbar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.toolbar .input-wrap {
  margin: 0;
  flex: 1;
  min-width: 220px;
  background: #ffffff;
  border: 1px solid #d9e3f0;
}

.toolbar .input-wrap input,
.toolbar .input-wrap textarea,
.toolbar .input-wrap select {
  color: var(--text);
}

.toolbar .input-wrap input::placeholder,
.toolbar .input-wrap textarea::placeholder {
  color: #94a3b8;
}

.list-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.record-card,
.user-record-card {
  background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
  border: 1px solid #e3eaf3;
  border-radius: 14px;
  padding: 16px;
  color: var(--text);
  box-shadow: var(--shadow-soft);
}

.record-card h3,
.user-record-card h3 {
  margin: 0 0 8px;
  font-size: 16px;
  color: var(--text);
}

.record-card p,
.user-record-card p {
  margin: 4px 0;
  font-size: 12px;
  color: var(--muted);
}

.user-record-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.record-empty {
  padding: 28px;
  border: 1px dashed #cfd9e5;
  border-radius: 16px;
  text-align: center;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.55);
}

.status-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 700;
}

.status-chip.ok {
  background: #dcfce7;
  color: #15803d;
}

.status-chip.warn {
  background: rgba(245, 158, 11, 0.14);
  color: #b45309;
}

.status-chip.block {
  background: rgba(248, 113, 113, 0.14);
  color: #b91c1c;
}

.popup-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(3, 10, 20, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 50;
}

.popup-card {
  width: 720px;
  max-width: 100%;
  max-height: 82vh;
  overflow: auto;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d9e3f0;
  border-radius: 18px;
  padding: 20px;
  box-shadow: var(--shadow);
  color: var(--text);
}

.popup-card h3 {
  margin: 0 0 10px;
  color: var(--text);
}

.popup-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 16px;
}

.page-auth {
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.12), transparent 28%),
    radial-gradient(circle at top right, rgba(79, 70, 229, 0.12), transparent 32%),
    linear-gradient(180deg, #f8fbff 0%, #eef3f9 100%);
}

.premium-auth-card {
  width: 500px;
  max-width: 100%;
  min-height: auto;
  padding: 32px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(207, 217, 230, 0.95);
  box-shadow: 0 30px 90px rgba(15, 23, 42, 0.12), 0 10px 24px rgba(15, 23, 42, 0.05);
  backdrop-filter: blur(16px);
}

.auth-accent-line {
  height: 5px;
  width: 100%;
  border-radius: 999px;
  margin-bottom: 24px;
  background: linear-gradient(90deg, #4f46e5, #2563eb, #22c55e);
}

.auth-header {
  text-align: left;
  margin-bottom: 22px;
}

.auth-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.08);
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.auth-title {
  text-align: left;
  margin: 0;
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #0f172a;
}

.auth-subtitle {
  text-align: left;
  margin: 10px 0 6px;
  color: #475569;
  font-size: 16px;
}

.auth-version {
  text-align: left;
  margin: 0;
  color: #64748b;
  font-size: 12px;
}

.auth-form-area label {
  color: #334155;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.auth-input-wrap {
  background: rgba(248, 250, 252, 0.95);
  border: 1px solid #dce5f0;
  border-radius: 16px;
  margin-bottom: 16px;
  transition: 0.22s ease;
}

.auth-input-wrap:focus-within {
  border-color: #6366f1;
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.10);
}

.auth-input-wrap input,
.auth-input-wrap textarea,
.auth-input-wrap select {
  color: #0f172a;
  font-size: 14px;
  padding: 15px 16px;
}

.auth-input-wrap input::placeholder,
.auth-input-wrap textarea::placeholder {
  color: #94a3b8;
}

.auth-check-row {
  color: #64748b;
  font-size: 12px;
  margin: 6px 0 16px;
}

.auth-check-row input {
  accent-color: #4f46e5;
}

.auth-helper-text {
  color: #64748b;
  font-size: 12px;
  margin: 0 0 10px;
}

.auth-error-text,
.auth-info-text {
  text-align: left;
  font-size: 12px;
  min-height: 18px;
}

.auth-btn-primary {
  min-height: 52px;
  border-radius: 16px;
  font-size: 14px;
  font-weight: 700;
  background: linear-gradient(135deg, #4f46e5, #2563eb);
  border: 1px solid rgba(79, 70, 229, 0.2);
}

.auth-btn-primary:hover {
  transform: translateY(-1px);
  background: linear-gradient(135deg, #4338ca, #1d4ed8);
}

.page,
.page-auth,
.premium-auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.10), transparent 28%),
    radial-gradient(circle at top right, rgba(79, 70, 229, 0.10), transparent 32%),
    linear-gradient(180deg, #f4f7fb 0%, #e9eef5 100%) !important;
}

.card-login,
.premium-auth-card {
  width: 520px !important;
  max-width: 100% !important;
  min-height: auto !important;
  padding: 32px !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, 0.92) !important;
  border: 1px solid #cfd9e6 !important;
  box-shadow: 0 32px 70px rgba(15, 23, 42, 0.12),
    0 10px 24px rgba(15, 23, 42, 0.05) !important;
  backdrop-filter: blur(14px);
  text-align: left !important;
}

.top-bar,
.auth-accent-line {
  display: block !important;
  height: 5px !important;
  width: 100% !important;
  border-radius: 999px !important;
  margin-bottom: 18px !important;
  background: linear-gradient(90deg, #5b4df1, #2563eb, #22c55e) !important;
}

.login-chip,
.auth-chip {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  background: rgba(79, 70, 229, 0.08) !important;
  color: #1d4ed8 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 18px !important;
}

.logo-login,
.auth-title {
  margin: 0 !important;
  text-align: left !important;
  font-size: 44px !important;
  font-weight: 800 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
  color: #0f172a !important;
}

.subtitle-login,
.auth-subtitle {
  margin: 12px 0 6px !important;
  text-align: left !important;
  font-size: 16px !important;
  color: #475569 !important;
}

.version-login,
.auth-version {
  margin: 0 0 22px !important;
  text-align: left !important;
  font-size: 12px !important;
  color: #64748b !important;
}

.form-area label,
.auth-form-area label {
  display: block !important;
  margin-bottom: 8px !important;
  text-align: left !important;
  color: #334155 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.input-wrap,
.auth-input-wrap {
  background: rgba(248, 250, 252, 0.98) !important;
  border: 1px solid #d8e2ee !important;
  border-radius: 18px !important;
  margin-bottom: 16px !important;
  box-shadow: none !important;
  transition: 0.22s ease !important;
}

.input-wrap:focus-within,
.auth-input-wrap:focus-within {
  background: #ffffff !important;
  border-color: #6366f1 !important;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.10) !important;
}

.input-wrap input,
.input-wrap textarea,
.input-wrap select,
.auth-input-wrap input,
.auth-input-wrap textarea,
.auth-input-wrap select {
  width: 100% !important;
  padding: 15px 16px !important;
  border: none !important;
  background: transparent !important;
  color: #0f172a !important;
  font-size: 14px !important;
  outline: none !important;
  appearance: none !important;
}

.input-wrap input::placeholder,
.input-wrap textarea::placeholder,
.auth-input-wrap input::placeholder,
.auth-input-wrap textarea::placeholder {
  color: #94a3b8 !important;
}

.input-wrap select,
.auth-input-wrap select {
  color: #0f172a !important;
}

.check-row,
.auth-check-row {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 6px 0 12px !important;
  color: #475569 !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.check-row input,
.auth-check-row input {
  accent-color: #4f46e5 !important;
  width: auto !important;
  margin: 0 !important;
}

.helper-text,
.auth-helper-text {
  margin: 0 0 10px !important;
  color: #64748b !important;
  font-size: 12px !important;
  text-align: left !important;
}

.error-text,
.auth-error-text {
  min-height: 18px !important;
  margin: 0 0 12px !important;
  color: #f87171 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-align: left !important;
}

.info-text,
.auth-info-text {
  min-height: 18px !important;
  margin: 0 0 12px !important;
  color: #16a34a !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-align: left !important;
}

.btn-primary,
.auth-btn-primary {
  width: 100% !important;
  min-height: 52px !important;
  margin-top: 6px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(79, 70, 229, 0.18) !important;
  border-radius: 18px !important;
  background: linear-gradient(135deg, #4f46e5, #2563eb) !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  box-shadow: none !important;
}

.btn-primary:hover,
.auth-btn-primary:hover {
  background: linear-gradient(135deg, #4338ca, #1d4ed8) !important;
  transform: translateY(-1px) !important;
}

.btn-primary:active,
.auth-btn-primary:active {
  transform: scale(0.98) !important;
}

.input-light {
  background: #ffffff !important;
  border: 1px solid #d9e3f0 !important;
}

.input-light input,
.input-light select,
.input-light textarea {
  color: var(--text) !important;
}

.input-light input::placeholder,
.input-light textarea::placeholder {
  color: #94a3b8 !important;
}

.input-disabled {
  background: #eef4fb !important;
  border: 1px solid #d9e3f0 !important;
}

.input-disabled input {
  color: #516481 !important;
}

.helper-light {
  color: var(--muted) !important;
  font-size: 11px !important;
  margin-top: -8px !important;
  margin-bottom: 12px !important;
}

.usuarios-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  align-content: start;
}

.usuarios-acoes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.tabs-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}

.tab-btn {
  border: 0;
  border-radius: 14px;
  padding: 12px 14px;
  cursor: pointer;
  background: #e8f0fb;
  color: #12396d;
  font-weight: 700;
}

.tab-btn.ativo {
  background: linear-gradient(135deg, #12396d, #1d4ed8);
  color: #fff;
}

.mini-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  margin-left: 8px;
  padding: 0 6px;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  font-size: 10px;
}

.space-between {
  justify-content: space-between !important;
}

#app {
  height: 100vh;
}

body[data-tela="dashboard"] .main {
  overflow: hidden;
}

body[data-tela="dashboard"] .module-panel,
body[data-tela="dashboard"] .painel-dashboard,
body[data-tela="dashboard"] .dashboard-wrap {
  height: 100%;
}

body[data-tela="dashboard"] .dashboard-hero {
  margin-bottom: 12px;
}

body[data-tela="dashboard"] .grid-stats {
  margin-bottom: 12px;
}

body[data-tela="dashboard"] .dashboard-hero,
body[data-tela="dashboard"] .grid-stats,
body[data-tela="dashboard"] .grid-insights {
  max-height: fit-content;
}

.user-record-card .inline-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
}

.user-record-card .inline-actions .btn-secondary,
.user-record-card .inline-actions .btn-acao {
  width: auto;
  min-width: 140px;
  padding-left: 18px;
  padding-right: 18px;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill {
  -webkit-text-fill-color: #0f172a;
  -webkit-box-shadow: 0 0 0px 1000px #f8fafc inset;
  box-shadow: 0 0 0px 1000px #f8fafc inset;
  transition: background-color 9999s ease-in-out 0s;
  border-radius: 18px;
}

.menu-top {
  margin-bottom: 8px;
}

.ambiente .tt,
.ambiente .ok,
.ambiente .alerta {
  font-size: 11px;
  line-height: 1.2;
}

.chat-shell {
  grid-template-columns: 320px 1fr;
  min-height: 72vh;
  border: 1px solid #dbe4ee;
  display: flex;
  height: 100%;
  background: #f8fbff;
  border-radius: 16px;
  overflow: hidden;
}

.chat-sidebar {
  width: 280px;
  background: #ffffff;
  border-right: 1px solid #dbe3ef;
  display: flex;
  flex-direction: column;
  height: calc(100vh - 250px);
  max-height: calc(100vh - 250px);
  overflow: hidden;
}

.chat-sidebar-top {
  font-size: 18px;
  padding: 16px;
  font-weight: 700;
  border-bottom: 1px solid #e2e8f0;
  color: #0f172a;
  flex-shrink: 0;
}

.chat-lista {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  flex: 1;
  height: calc(100vh - 390px);
  max-height: calc(100vh - 390px);
  overflow-y: auto;
  padding-right: 6px;
  padding-bottom: 12px;
}

.chat-item {
  border-radius: 16px;
  width: 100%;
  padding: 12px 14px;
  text-align: left;
  border: none;
  background: transparent;
  cursor: pointer;
  border-bottom: 1px solid #f1f5f9;
  transition: 0.2s;
  min-height: 64px;
}

.chat-item.ativo {
  border-color: #2563eb;
  background: #e0edff;
}

.chat-item .nome {
  font-weight: 600;
  color: #0f172a;
}

.chat-item .previa {
  margin-top: 4px;
  font-size: 12px;
  color: #64748b;
}

.chat-item-meta {
  gap: 8px;
  opacity: 0.8;
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  margin-top: 4px;
  color: #94a3b8;
}

.chat-badge {
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  background: #2563eb;
  color: #fff;
  border-radius: 999px;
  padding: 2px 6px;
  font-size: 10px;
}

.chat-main {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  background: #111827;
}

.chat-main-top {
  padding: 14px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #1f2937;
  border-bottom: 1px solid #374151;
}

.chat-title {
  font-size: 18px;
  font-weight: 700;
  color: #0f172a;
}

.chat-subtitle {
  margin-top: 4px;
  font-size: 12px;
  color: #64748b;
}

.chat-msgs {
  flex: 1;
  padding: 16px;
  overflow-y: auto;
  background: #111827;
}

.chat-vazio {
  font-size: 14px;
  text-align: center;
  color: #94a3b8;
  padding: 20px;
}

.msg-row {
  display: flex;
  flex-direction: column;
  margin-bottom: 12px;
  max-width: 70%;
}

.msg-row.me {
  margin-left: auto;
  align-items: flex-end;
}

.msg-row.other {
  margin-right: auto;
  align-items: flex-start;
}

.msg-bubble {
  color: #0f172a;
  word-break: break-word;
  background: #ffffff;
  padding: 10px 12px;
  border-radius: 14px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}

.msg-row.me .msg-bubble {
  background: #2563eb;
  color: #fff;
}

.msg-meta {
  font-size: 11px;
  color: #94a3b8;
  margin-top: 4px;
}

.chat-input-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  background: #1f2937;
  border-top: 1px solid #374151;
}

.chat-icon-btn {
  width: 44px;
  min-width: 44px;
  height: 44px;
  border: none;
  background: #e2e8f0;
  padding: 8px;
  border-radius: 8px;
  cursor: pointer;
}

.chat-emoji-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  border-top: 1px solid #e2e8f0;
  position: absolute;
  bottom: 80px;
  background: white;
  padding: 10px;
  border-radius: 10px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

.chat-emoji-btn {
  border-radius: 12px;
  padding: 8px 10px;
  border: none;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
}

.chat-anexo-preview {
  border-top: 1px solid #e2e8f0;
  padding: 8px 12px;
  background: #fff;
}

.chat-anexo-card {
  align-items: center;
  gap: 12px;
  border: 1px solid #dbe4ee;
  display: flex;
  justify-content: space-between;
  background: #e2e8f0;
  padding: 8px;
  border-radius: 8px;
}

.chat-img-msg {
  max-width: 220px;
  border-radius: 14px;
  display: block;
}

.chat-file-link {
  display: inline-block;
  text-decoration: none;
  color: #2563eb;
  font-weight: 600;
}

.msg-text {
  margin-top: 6px;
  font-size: 14px;
}

.msg-reacoes {
  flex-wrap: wrap;
  display: flex;
  gap: 6px;
  margin-top: 6px;
}

.msg-reacao,
.msg-emoji-add {
  border: none;
  background: #eef2ff;
  border-radius: 999px;
  padding: 4px 8px;
  cursor: pointer;
  font-size: 12px;
}

.msg-reacao.minha {
  font-weight: 700;
  background: #2563eb;
  color: white;
}

.msg-acoes {
  margin-top: 4px;
}

.msg-visto {
  margin-left: 8px;
  font-weight: 600;
  color: #64748b;
}

.msg-visto.ok {
  color: #22c55e;
}

.chat-body-wrap {
  display: flex;
  flex: 1;
  min-height: 0;
}

.chat-sidepanel {
  min-width: 320px;
  width: 300px;
  padding: 16px;
  transition: 0.3s;
  background: #0f172a;
  color: #f8fafc;
  border-left: 1px solid #334155;
}

.chat-sidepanel.hidden {
  display: none;
  width: 0;
  padding: 0;
  border: none;
  overflow: hidden;
}

.chat-sidepanel-header {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
}

.chat-msg-image {
  display: block;
  max-width: 220px;
  border-radius: 10px;
}

.chat-item:hover {
  background: #f1f5f9;
}

.msg-reacao {
  border: none;
  background: #e2e8f0;
  padding: 2px 6px;
  border-radius: 999px;
  cursor: pointer;
}

.chat-icon-btn:hover {
  background: #cbd5f5;
}

.input-wrap input {
  width: 100%;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #cbd5f5;
}

.chat-sidepanel-body p {
  margin: 6px 0;
}

.chat-sidebar-actions {
  padding: 12px;
  border-bottom: 1px solid #e2e8f0;
  background: #fff;
  position: relative;
}

#chatBuscaPessoa {
  width: 100%;
}

.chat-resultados-busca {
  margin-top: 8px;
  overflow: hidden;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  max-height: 260px;
  overflow-y: auto;
  background: #ffffff;
  border: 1px solid #dbe3f0;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
  z-index: 40;
  padding: 6px 0;
}

.chat-busca-item {
  border-bottom: 1px solid #eef2f7;
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  display: block;
  padding: 12px 16px;
  cursor: pointer;
}

.chat-busca-item:hover {
  background: #f7faff;
}

.chat-busca-vazio {
  font-size: 12px;
  padding: 14px 16px;
  color: #64748b;
}

.chat-title,
.chat-subtitle {
  color: #f9fafb;
}

.msg-row.other .msg-bubble {
  background: #1f2937;
  color: #f9fafb;
}

.chat-input-bar .input-wrap input {
  background: #111827;
  color: #f9fafb;
  border: 1px solid #374151;
}

body[data-tela="dashboard"] .hero {
  padding: 18px;
  margin-bottom: 14px;
}

body[data-tela="dashboard"] .hero h1 {
  font-size: 18px;
  margin-bottom: 6px;
}

body[data-tela="dashboard"] .hero p {
  font-size: 12px;
  line-height: 1.35;
}

body[data-tela="dashboard"] .grid-stats,
body[data-tela="dashboard"] .grid-insights {
  gap: 12px;
  margin-bottom: 14px;
}

body[data-tela="dashboard"] .card {
  padding: 14px;
  border-radius: 14px;
}

body[data-tela="dashboard"] .card .rotulo {
  font-size: 10px;
  margin-bottom: 6px;
}

body[data-tela="dashboard"] .card .valor {
  font-size: 20px;
  margin-bottom: 6px;
}

body[data-tela="dashboard"] .card .desc {
  font-size: 10px;
  line-height: 1.3;
}

body[data-tela="dashboard"] .painel {
  gap: 12px;
}

body[data-tela="dashboard"] .lista {
  gap: 8px;
  margin-top: 10px;
}

body[data-tela="dashboard"] .item-lista {
  padding: 10px 12px;
}

body[data-tela="dashboard"] .item-lista .t {
  font-size: 11px;
}

body[data-tela="dashboard"] .item-lista .d {
  font-size: 9px;
  line-height: 1.3;
}

body[data-tela="dashboard"] .acoes {
  gap: 8px;
  margin-top: 10px;
}

body[data-tela="dashboard"] .btn-acao {
  padding: 9px 12px;
  font-size: 12px;
  border-radius: 10px;
}

.menu-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

#miniChatDock {
  pointer-events: none;
  position: fixed;
  right: 8px;
  bottom: 0;
  display: flex;
  gap: 12px;
  align-items: flex-end;
  z-index: 9999;
  padding: 0 8px 0 8px;
}

#miniChatDock>* {
  pointer-events: auto;
}

.mini-chat-window {
  backdrop-filter: blur(10px);
  width: 340px;
  height: 520px;
  display: flex;
  flex-direction: column;
  border-radius: 20px;
  overflow: hidden;
  background: radial-gradient(circle at top, rgba(76, 76, 255, 0.16), transparent 30%),
    linear-gradient(180deg, #08142f 0%, #091225 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
}

.mini-chat-window.min {
  height: 64px;
}

.mini-chat-header {
  gap: 10px;
  cursor: default;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.04);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.mini-chat-user {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.mini-chat-avatar {
  flex-shrink: 0;
  font-size: 14px;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.28);
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #6d5dfc, #3b82f6);
  color: #fff;
  font-weight: 700;
}

.mini-chat-user-info {
  flex: 1;
  min-width: 0;
}

.mini-chat-title-row {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.mini-chat-title {
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mini-chat-status {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
  font-size: 12px;
  color: #9ca3af;
}

.mini-chat-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #22c55e;
  flex-shrink: 0;
}

.mini-chat-status.offline .mini-chat-status-dot {
  background: #6b7280;
}

.mini-chat-actions {
  flex-shrink: 0;
  align-items: center;
  display: flex;
  gap: 8px;
}

.mini-chat-icon-btn {
  line-height: 1;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 15px;
  transition: 0.2s ease;
}

.mini-chat-icon-btn:hover {
  color: #c084fc;
  background: rgba(255, 255, 255, 0.22);
}

.mini-chat-window.min .mini-chat-body,
.mini-chat-window.min .mini-chat-footer {
  display: none;
}

.mini-chat-body {
  background: radial-gradient(circle at top, rgba(139, 92, 246, 0.08), transparent 24%),
    linear-gradient(180deg, #0f172a 0%, #111827 100%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-sizing: border-box;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 14px 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.18) transparent;
  gap: 4px !important;
  padding: 8px 10px !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  touch-action: pan-y;
}

.mini-chat-body::-webkit-scrollbar {
  width: 6px;
}

.mini-chat-body::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.18);
  border-radius: 999px;
}

.mini-chat-date {
  align-self: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: #9ca3af;
  font-size: 11px;
  font-weight: 600;
}

.mini-chat-msg-wrap {
  min-width: 0;
  gap: 6px;
  display: flex;
  flex-direction: column;
  max-width: 82%;
  gap: 2px !important;
  margin: 0 !important;
}

.mini-chat-msg-wrap.me {
  align-self: flex-end;
  align-items: flex-end;
  margin-left: auto;
}

.mini-chat-msg-wrap.other {
  align-self: flex-start;
  align-items: flex-start;
  margin-right: auto;
}

.mini-msg-nome {
  font-size: 11px;
  color: #9ca3af;
  padding: 0 4px;
}

.mini-chat-msg {
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.14);
  width: fit-content;
  min-width: 0;
  white-space: pre-wrap;
  overflow-wrap: break-word;
  max-width: 78%;
  border-radius: 14px;
  font-size: 13px;
  display: inline-block;
  overflow: hidden;
  word-break: break-word;
  padding: 6px 10px;
  line-height: 1.2;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08) !important;
  display: inline-block !important;
  width: auto !important;
  max-width: 68% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 5px 9px !important;
  border-radius: 12px !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  font-weight: 400 !important;
  white-space: normal !important;
  word-break: break-word !important;
}

.mini-chat-msg-wrap.other .mini-chat-msg {
  border-top-left-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom-left-radius: 8px;
}

.mini-chat-msg-wrap.me .mini-chat-msg {
  border-top-right-radius: 8px;
  background: linear-gradient(135deg, #7c4dff, #3b82f6);
  color: #fff;
  border-bottom-right-radius: 8px;
}

.mini-msg-meta {
  align-items: center;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 10px;
  opacity: 0.65;
  margin-top: 2px;
  padding: 0 4px;
  line-height: 1 !important;
  color: rgba(148, 163, 184, 0.9) !important;
  font-size: 9px !important;
  margin-top: 2px !important;
}

.mini-msg-status {
  color: #cbd5e1;
  font-weight: 700;
}

.mini-chat-empty {
  flex: 1;
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.52);
  font-size: 13px;
  text-align: center;
  padding: 18px 10px;
}

.mini-chat-footer {
  padding: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(5, 10, 25, 0.95);
  overflow: hidden;
}

.mini-chat-input-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.mini-chat-tool-btn {
  width: 34px;
  height: 34px;
  border: none;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: transparent;
  color: #3b82f6;
  cursor: pointer;
  transition: 0.18s ease;
  flex-shrink: 0;
  font-size: 18px;
}

.mini-chat-tool-btn:hover {
  background: rgba(59, 130, 246, 0.12);
}

.mini-chat-input-shell {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  padding: 4px 4px 4px 12px;
  min-width: 0;
  flex: 1;
}

.mini-chat-input-shell input {
  height: 40px;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff;
  font-size: 13px;
  min-width: 0;
  width: 100%;
}

.mini-chat-input-shell input::placeholder {
  color: rgba(255, 255, 255, 0.45);
}

.mini-chat-send-btn {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: 999px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: 0.18s ease;
  flex-shrink: 0;
  background: linear-gradient(135deg, #4f7cff, #6f47ff);
  color: #fff;
  font-size: 14px;
}

.mini-chat-send-btn:hover {
  background: rgba(59, 130, 246, 0.12);
  transform: scale(1.05);
}

.mini-chat-send-btn:disabled {
  opacity: 0.45;
  cursor: default;
}

.mini-chat-window.typing .mini-chat-input-shell {
  border-color: rgba(59, 130, 246, 0.35);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.08);
}

.mini-chat-window.has-new {
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.28),
    0 8px 20px rgba(15, 23, 42, 0.18),
    0 0 0 2px rgba(59, 130, 246, 0.22);
}

.mini-chat-window.has-new .mini-chat-header {
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.35);
}

.mini-chat-new-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #3b82f6;
  display: inline-block;
  flex-shrink: 0;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.16);
}

body[data-tela="chat"] .main {
  overflow: auto;
}

.chat-only-panel {
  height: 100%;
  padding: 18px;
}

.chat-only-shell {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.chat-only-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.chat-only-subtitle {
  font-size: 12px;
  color: var(--muted);
}

.chat-only-search-wrap {
  position: relative;
}

.chat-only-search-wrap .input-wrap {
  margin: 0;
  background: #ffffff;
  border: 1px solid #d9e3f0;
}

.chat-only-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 220px;
  max-height: calc(100vh - 290px);
  overflow-y: auto;
  padding-right: 4px;
}

.chat-only-item {
  width: 100%;
  border: 1px solid #dbe5f1;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  padding: 14px;
  text-align: left;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
  box-shadow: var(--shadow-soft);
  appearance: none;
  -webkit-appearance: none;
  outline: none;
}

.chat-only-item:hover {
  background: linear-gradient(180deg, #ffffff 0%, #f1f6ff 100%);
  border-color: #bfd4ef;
  transform: none;
}

.chat-only-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 6px;
}

.chat-only-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-only-time {
  font-size: 11px;
  color: #94a3b8;
  flex-shrink: 0;
}

.chat-only-item-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.chat-only-preview {
  font-size: 12px;
  color: var(--muted);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chat-only-badge {
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: #ef4444;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}

.chat-busca-item:last-child {
  border-bottom: 0;
}

.chat-busca-item .nome {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
  margin-bottom: 2px;
}

.chat-busca-item .previa {
  margin-top: 3px;
  font-size: 13px;
  color: #64748b;
}

.loja-autocomplete-wrap {
  position: relative;
}

.loja-sugestoes {
  margin-top: 8px;
  background: #ffffff;
  border: 1px solid #d9e3f0;
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}

.loja-sugestao-item {
  width: 100%;
  border: 0;
  background: #ffffff;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid #eef2f7;
}

.loja-sugestao-item:last-child {
  border-bottom: 0;
}

.loja-sugestao-item:hover {
  background: #f8fbff;
}

.loja-sugestao-nome {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}

.loja-sugestao-codigo {
  font-size: 11px;
  color: #64748b;
  margin-top: 2px;
}

.mini-chat-date-divider {
  position: relative;
  max-width: 100%;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  text-align: center;
  margin: 12px auto;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  background: rgba(0, 0, 0, .08);
  color: #374151;
  width: fit-content;
  margin: 10px auto !important;
  padding: 4px 10px !important;
  font-size: 10px !important;
  border-radius: 999px !important;
}

.mini-chat-date-divider::before,
.mini-chat-date-divider::after {
  display: inline-block;
  width: 30%;
  vertical-align: middle;
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, .18);
  margin: 0 10px;
}

.mini-chat-icon-btn.danger:hover {
  background: rgba(255, 77, 77, 0.22);
}

.mini-chat-round-btn,
.mini-chat-send-btn {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  transition: 0.2s ease;
}

.mini-chat-round-btn {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  font-size: 20px;
}

.mini-chat-round-btn:hover {
  background: rgba(255, 255, 255, 0.18);
}

.mini-emoji-picker {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
  overflow-x: auto;
  overflow-y: hidden;
  flex-wrap: nowrap;
  padding-bottom: 2px;
}

.mini-emoji-item {
  width: 30px;
  transition: 0.2s ease;
  min-width: 34px;
  height: 34px;
  border: none;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
  font-size: 18px;
  flex-shrink: 0;
}

.mini-emoji-item:hover {
  background: rgba(255, 255, 255, 0.16);
  transform: translateY(-1px);
}

.mini-chat-file-card {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 10px 12px;
  text-decoration: none;
  color: #fff;
  transition: 0.2s ease;
  display: flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
}

.mini-chat-file-card:hover {
  background: rgba(255, 255, 255, 0.10);
  transform: translateY(-1px);
}

.mini-chat-file-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: rgba(111, 71, 255, 0.20);
  font-size: 18px;
  flex-shrink: 0;
}

.mini-chat-file-content {
  flex: 1;
  min-width: 0;
}

.mini-chat-file-name {
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mini-chat-file-meta {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.60);
  margin-top: 2px;
}

.mini-chat-file-action {
  font-size: 11px;
  font-weight: 700;
  color: #a78bfa;
  flex-shrink: 0;
}

.mini-chat-img-link {
  display: block;
  text-decoration: none;
}

.mini-chat-img {
  cursor: pointer;
  max-width: 100%;
  max-height: 180px;
  border-radius: 12px;
  display: block;
  margin-bottom: 4px;
  object-fit: cover;
}

.mini-chat-msg,
.mini-chat-file-card,
.mini-chat-arquivo {
  min-width: 0;
  box-sizing: border-box;
  max-width: 72%;
}

.mini-chat-img-link,
.mini-chat-img {
  max-width: 100%;
}

.mini-chat-body::-webkit-scrollbar:horizontal {
  display: none;
}

.mini-chat-window.min .mini-chat-content {
  display: none;
}

.mini-chat-action-btn {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.86);
  cursor: pointer;
}

.mini-chat-content {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}

.mini-chat-body::-webkit-scrollbar-track {
  background: transparent;
}

.mini-msg {
  display: flex;
  margin: 8px 0;
}

.mini-msg--me {
  justify-content: flex-end;
}

.mini-msg--other {
  justify-content: flex-start;
}

.mini-msg-bubble {
  display: inline-block;
  width: fit-content;
  max-width: 82%;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 18px;
  word-break: normal;
  overflow-wrap: break-word;
  white-space: pre-wrap;
}

.mini-msg--me .mini-msg-bubble {
  background: linear-gradient(135deg, #7c4dff, #3b82f6);
  color: #fff;
  border-bottom-right-radius: 8px;
}

.mini-msg--other .mini-msg-bubble {
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom-left-radius: 8px;
}

.mini-msg-texto {
  margin-top: 6px;
  line-height: 1.42;
  font-size: 14px;
}

.mini-msg-media {
  margin-bottom: 6px;
}

.mini-msg-image {
  display: block;
  max-width: 100%;
  max-height: 220px;
  border-radius: 14px;
}

.mini-msg-anexo {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.mini-msg-anexo-icone {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(124, 77, 255, 0.22);
  flex-shrink: 0;
}

.mini-msg-anexo-info {
  flex: 1;
  min-width: 0;
}

.mini-msg-anexo-nome {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mini-msg-anexo-meta {
  margin-top: 2px;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.68);
}

.mini-msg-anexo-acao {
  font-size: 13px;
  font-weight: 700;
  color: #b9a8ff;
  text-decoration: none;
  flex-shrink: 0;
}

.mini-chat-emojis-wrap {
  padding: 8px 10px 4px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.mini-chat-emojis {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 2px 2px 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.18) transparent;
}

.mini-chat-emojis::-webkit-scrollbar {
  height: 4px;
}

.mini-chat-emojis::-webkit-scrollbar-track {
  background: transparent;
}

.mini-chat-emojis::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.18);
  border-radius: 999px;
}

.mini-chat-inputbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px 12px;
}

.mini-chat-plus,
.mini-chat-send {
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 999px;
  flex-shrink: 0;
  cursor: pointer;
}

.mini-chat-plus {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 24px;
}

.mini-chat-send {
  background: linear-gradient(135deg, #6d5dfc, #3b82f6);
  color: #fff;
  font-size: 18px;
}

.mini-chat-input {
  flex: 1;
  min-width: 0;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  padding: 0 16px;
  outline: none;
}

.mini-chat-input::placeholder {
  color: rgba(255, 255, 255, 0.45);
}

.mini-chat-arquivo {
  display: flex;
  flex-direction: column;
  width: fit-content;
  max-width: 100%;
}

.mini-chat-msg-wrap.me .mini-chat-file-card,
.mini-chat-msg-wrap.me .mini-chat-arquivo {
  margin-left: auto;
}

.mini-chat-msg-wrap.other .mini-chat-file-card,
.mini-chat-msg-wrap.other .mini-chat-arquivo {
  margin-right: auto;
}

.auditoria-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.page-title {
  font-size: 20px;
  font-weight: 800;
  color: #0f172a;
  margin: 0 0 6px 0;
}

.auditoria-lista {
  max-height: calc(100vh - 240px);
  height: calc(100vh - 320px);
  padding-right: 6px;
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.auditoria-item {
  border-left: 5px solid #cbd5e1;
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: flex-start;
  padding: 12px 14px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(226, 232, 240, 0.9);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.04);
}

.auditoria-ok {
  border-left-color: #22c55e;
}

.auditoria-info {
  border-left-color: #3b82f6;
  color: #64748b;
  font-size: 13px;
  font-weight: 700;
}

.auditoria-warn {
  border-left-color: #f59e0b;
}

.auditoria-neutral {
  border-left-color: #94a3b8;
}

.auditoria-topo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 6px;
}

.auditoria-titulo {
  font-size: 15px;
  font-weight: 800;
  color: #0f172a;
}

.auditoria-data {
  font-size: 12px;
  color: #64748b;
  white-space: nowrap;
}

.auditoria-desc {
  font-size: 13px;
  color: #334155;
  line-height: 1.45;
  margin-bottom: 8px;
}

.auditoria-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.35;
}

.audit-list {
  max-height: calc(100vh - 200px);
  overflow-y: auto;
  padding-right: 8px;
}

.auditoria-footer {
  margin-top: 10px;
  flex: 0 0 auto;
  height: 58px;
  padding: 10px 14px;
  border-top: 1px solid rgba(226, 232, 240, 0.95);
  background: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.btn-carregar {
  min-width: 180px;
  padding: 10px 16px;
  border-radius: 12px;
  border: none;
  background: #2563eb;
  color: #fff;
  cursor: pointer;
  font-weight: 700;
  box-shadow: 0 6px 16px rgba(37, 99, 235, 0.18);
}

.btn-carregar:hover {
  background: #1d4ed8;
}

.btn-carregar:disabled {
  opacity: 0.75;
  cursor: default;
}

.auditoria-contador {
  font-size: 14px;
  color: #64748b;
  font-weight: 600;
  min-width: 140px;
  text-align: center;
}

.btn-paginacao {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid #d9e3f0;
  background: #ffffff;
  color: #334155;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
}

.btn-paginacao:hover {
  background: #f8fbff;
}

.btn-paginacao:disabled {
  opacity: 0.45;
  cursor: default;
}

.auditoria-badge {
  min-width: 92px;
  text-align: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: #eef4ff;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
}

.auditoria-content {
  flex: 1;
  min-width: 0;
}

.auditoria-texto {
  color: #0f172a;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.35;
  margin-bottom: 6px;
}

.chat-only-item:focus,
.chat-only-item:focus-visible {
  outline: none;
  border-color: #9fc2ea;
  box-shadow: 0 0 0 3px rgba(79, 134, 198, 0.12);
}

.chat-only-item.ativo {
  border-color: #4f86c6;
  background: linear-gradient(180deg, #ffffff 0%, #eef5ff 100%);
  box-shadow: 0 0 0 3px rgba(79, 134, 198, 0.10);
}

.chat-resultados-busca.hidden {
  display: none;
}

.chat-busca-item+.chat-busca-item {
  border-top: 1px solid #eef2f7;
}

.somente-lista-chat {
  grid-template-columns: 320px !important;
  align-items: start !important;
}

.somente-lista-chat .chat-sidebar {
  min-height: 560px;
}

.chat-page-clean .section-head h3,
.chat-page-clean .section-head p {
  color: #111827 !important;
}

.chat-page-clean .section-head {
  margin-bottom: 18px !important;
}

.chat-page-clean .btn-secondary {
  display: none !important;
}

.chat-item-clean {
  display: flex !important;
  align-items: center;
  gap: 12px;
  width: 100%;
  text-align: left;
}

.chat-item-avatar {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .14);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  flex-shrink: 0;
}

.chat-item-info {
  flex: 1;
  min-width: 0;
}

.chat-item-top,
.chat-item-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.chat-item-top strong {
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-item-top span {
  font-size: 10px;
  opacity: .75;
  flex-shrink: 0;
}

.chat-item-bottom small {
  font-size: 11px;
  opacity: .8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-item-bottom em {
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: #22c55e;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

.mini-chat-subtitle {
  font-size: 10px;
  opacity: .7;
}

.mini-chat-emoji-btn {
  border: none;
  background: transparent;
  font-size: 20px;
  cursor: pointer;
  padding: 0 6px;
}

.mini-chat-emoji-panel {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px;
}

.mini-chat-emoji-panel.hidden {
  display: none;
}

.mini-chat-emoji-panel button {
  border: none;
  background: rgba(255, 255, 255, .12);
  border-radius: 8px;
  padding: 6px;
  cursor: pointer;
  font-size: 16px;
}

.mini-chat-file {
  border: none;
  border-radius: 10px;
  padding: 8px 10px;
  cursor: pointer;
  background: rgba(255, 255, 255, .14);
  color: inherit;
  font-size: 12px;
}

.mini-chat-attach-btn {
  border: none;
  background: transparent;
  font-size: 19px;
  cursor: pointer;
  padding: 0 6px;
}

.mini-msg-row {
  display: flex;
  flex-direction: column;
  margin: 6px 10px;
  display: flex !important;
  flex-direction: column !important;
  margin-bottom: 6px !important;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
}

.mini-msg-row.me {
  align-items: flex-end;
  align-items: flex-end !important;
}

.mini-msg-row.other {
  align-items: flex-start;
  align-items: flex-start !important;
}

.mini-msg-row.me .mini-chat-msg {
  background: #dcf8c6;
  color: #111827;
  border-bottom-right-radius: 4px;
  background: #d8f8c4 !important;
  color: #111827 !important;
  border-bottom-right-radius: 5px !important;
}

.mini-msg-row.other .mini-chat-msg {
  background: #ffffff;
  color: #111827;
  border-bottom-left-radius: 4px;
  background: #1e293b !important;
  color: #ffffff !important;
  border-bottom-left-radius: 5px !important;
}

.mini-chat-file-link {
  transition: .2s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 100%;
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .12);
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.mini-chat-file-link:hover {
  background: rgba(255, 255, 255, .22);
}

.mini-chat-msg img {
  max-width: 100%;
}

.mini-chat-file-invisible {
  color: inherit;
  text-decoration: none;
  font: inherit;
  all: unset;
  cursor: pointer;
  display: inline;
  all: unset !important;
  cursor: pointer !important;
  display: inline !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
}

.mini-chat-file-invisible:hover {
  opacity: 0.8;
}

.mini-chat-msg a {
  display: inline;
  line-height: inherit;
  display: inline !important;
  line-height: inherit !important;
}

.mini-chat-msg-wrap.me,
.mini-chat-msg-wrap.other {
  margin: 0 !important;
}

.clientes-page {
  padding: 24px;
  padding-bottom: 90px;
  max-height: calc(100vh - 140px);
  height: calc(100vh - 140px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.clientes-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 20px;
}

.section-subtitle {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 14px;
}

.clientes-actions {
  display: flex;
  gap: 10px;
}

.btn-primary,
.btn-secondary {
  border: none;
  border-radius: 12px;
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
}

.clientes-metricas {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.cliente-metrica-card {
  background: #fff;
  border: 1px solid #dbe4f0;
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
}

.cliente-metrica-card span {
  display: block;
  color: #64748b;
  font-size: 13px;
  margin-bottom: 8px;
}

.cliente-metrica-card strong {
  font-size: 26px;
  color: #0f172a;
}

.clientes-toolbar {
  display: flex;
  gap: 12px;
  margin-bottom: 14px;
}

.clientes-toolbar input,
.clientes-toolbar select {
  border: 1px solid #dbe4f0;
  border-radius: 12px;
  padding: 11px 12px;
  background: #fff;
  outline: none;
}

.clientes-toolbar input {
  flex: 1;
}

.clientes-table {
  margin-bottom: 8px;
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  width: max-content !important;
  min-width: 100% !important;
}

.clientes-table th {
  text-align: left;
  font-size: 12px;
  color: #475569;
  background: #f8fafc;
  padding: 14px;
  border-bottom: 1px solid #e2e8f0;
}

.clientes-table td {
  padding: 14px;
  border-bottom: 1px solid #eef2f7;
  color: #0f172a;
  vertical-align: middle;
}

.clientes-table td small {
  display: block;
  margin-top: 4px;
  color: #64748b;
  font-size: 11px;
}

.status-chip.danger {
  background: #fee2e2;
  color: #b91c1c;
}

.clientes-row-actions {
  align-items: center;
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
}

.clientes-row-actions button {
  border: 1px solid #dbe4f0;
  background: #fff;
  border-radius: 9px;
  padding: 7px 9px;
  cursor: pointer;
  font-weight: 600;
}

.clientes-row-actions button.danger {
  color: #dc2626;
}

.clientes-pagination {
  margin-top: 16px;
  align-items: center;
  margin: 18px 0 10px;
  padding-bottom: 24px;
  position: sticky;
  bottom: 0;
  right: 0;
  z-index: 12;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 12px;
  background: #ffffff;
  border-top: 1px solid #e5edf7;
}

.clientes-pagination button {
  padding: 8px 12px;
  min-width: 38px;
  min-height: 36px;
  border: 1px solid #d6e0ee;
  border-radius: 10px;
  background: #ffffff;
  color: #12396d;
  font-weight: 800;
  cursor: pointer;
}

.clientes-empty {
  text-align: center;
  color: #64748b;
  padding: 28px !important;
  height: 260px !important;
  text-align: center !important;
  color: #64748b !important;
  font-weight: 700;
  background: #ffffff;
}

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.48);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.cliente-modal {
  width: min(820px, 100%);
  max-height: 92vh;
  overflow: auto;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.25);
  padding: 22px;
}

.cliente-modal-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid #e2e8f0;
  padding-bottom: 16px;
  margin-bottom: 18px;
}

.cliente-modal-head h3 {
  margin: 0;
  font-size: 22px;
  color: #0f172a;
}

.cliente-modal-head p {
  margin: 4px 0 0;
  color: #64748b;
}

.cliente-modal-head button {
  width: 36px;
  height: 36px;
  border: none;
  border-radius: 999px;
  background: #f1f5f9;
  cursor: pointer;
  font-size: 22px;
}

.cliente-form-grid,
.cliente-detalhe-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.cliente-form-grid input,
.cliente-form-grid textarea {
  border: 1px solid #dbe4f0;
  border-radius: 12px;
  padding: 12px;
  outline: none;
}

.cliente-form-grid textarea {
  grid-column: 1 / -1;
  min-height: 90px;
  resize: vertical;
}

.cliente-detalhe-grid div,
.cliente-observacao {
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 14px;
  padding: 13px;
}

.cliente-detalhe-grid span,
.cliente-observacao span {
  display: block;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 5px;
}

.cliente-detalhe-grid strong {
  color: #0f172a;
}

.cliente-observacao {
  margin-top: 12px;
}

.cliente-observacao p {
  margin: 0;
  color: #334155;
}

.cliente-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.upload-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 2px dashed #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  border-radius: 18px;
  padding: 28px;
  cursor: pointer;
  text-align: center;
}

.upload-box input {
  margin-top: 14px;
}

.import-result {
  margin-top: 14px;
  border-radius: 14px;
  padding: 14px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  color: #0f172a;
}

.toast-box {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 10000;
  display: grid;
  gap: 10px;
}

.toast {
  min-width: 260px;
  max-width: 360px;
  padding: 14px 16px;
  border-radius: 16px;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.25);
  animation: toastIn 0.22s ease;
}

.toast-ok {
  background: linear-gradient(135deg, #16a34a, #22c55e);
}

.toast-erro {
  background: linear-gradient(135deg, #dc2626, #ef4444);
}

.toast-info {
  background: linear-gradient(135deg, #2563eb, #4f46e5);
}

.skeleton-row {
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef2f7, #dbe4f0, #eef2f7);
  background-size: 200% 100%;
  animation: skeletonMove 1.1s infinite linear;
}

.import-preview-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e2e8f0;
}

.import-preview-head span,
.import-help {
  display: block;
  color: #64748b;
  font-size: 13px;
  margin-top: 4px;
}

.import-section {
  margin-top: 16px;
}

.import-map-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.import-map-item {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 10px;
  background: #f8fafc;
}

.import-map-item span {
  display: block;
  font-size: 12px;
  color: #64748b;
}

.import-map-item strong {
  color: #0f172a;
}

.import-map-item.ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.import-map-item.warn {
  border-color: #fed7aa;
  background: #fff7ed;
}

.import-extra-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.import-extra-check {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1e3a8a;
  padding: 12px;
  border-radius: 14px;
  cursor: pointer;
}

.import-extra-check input {
  width: 16px;
  height: 16px;
  accent-color: #2563eb;
}

.import-preview-table {
  max-height: 280px;
  overflow: auto;
}

.import-success {
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #166534;
  border-radius: 14px;
  padding: 14px;
}

.import-error {
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  border-radius: 14px;
  padding: 14px;
}

.import-loading {
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1d4ed8;
  border-radius: 14px;
  padding: 14px;
}

.mini-msg-row.me .mini-msg-meta {
  text-align: right !important;
  padding-right: 4px !important;
}

.mini-msg-row.other .mini-msg-meta {
  text-align: left !important;
  padding-left: 4px !important;
}

.mini-chat-msg * {
  font-size: 12px !important;
  line-height: 1.2 !important;
  font-weight: 400 !important;
}

.clientes-table-wrap {
  scroll-behavior: smooth;
  overflow-x: auto;
  overflow-y: visible;
  margin-bottom: 18px;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  max-height: calc(100vh - 430px);
  flex: 1;
  min-height: 0;
  width: 100%;
  overflow: auto;
  background: #ffffff;
  padding-bottom: 18px;
}

.clientes-table-dinamica {
  width: max-content;
  min-width: 980px;
  white-space: nowrap;
}

.clientes-table-dinamica th,
.clientes-table-dinamica td {
  min-width: 140px;
}

.clientes-table-dinamica th:first-child,
.clientes-table-dinamica td:first-child {
  min-width: 220px;
}

.cliente-extra-col {
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: grab;
}

.clientes-acoes-sticky {
  max-width: 280px !important;
  min-width: 245px !important;
  box-shadow: -8px 0 16px rgba(15, 23, 42, 0.08);
  position: sticky;
  right: 0;
  z-index: 12;
  background: #ffffff;
}

thead .clientes-acoes-sticky {
  background: #f8fafc;
  z-index: 14;
}

.modal form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

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

.modal input,
.modal select,
.modal textarea {
  width: 100%;
  height: 46px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #f8fafc;
  padding: 0 14px;
  font-size: 14px;
  color: #111827;
  outline: none;
  transition: all 0.2s ease;
}

.modal textarea {
  height: auto;
  min-height: 100px;
  padding-top: 12px;
  resize: vertical;
}

.modal input::placeholder,
.modal textarea::placeholder {
  color: #8a94a6;
}

.modal input:focus,
.modal select:focus,
.modal textarea:focus {
  border-color: #4f63ff;
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(79, 99, 255, 0.12);
}

.extra-campo {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 12px;
  margin-top: 10px;
  align-items: center;
}

.extra-campo input {
  height: 46px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #f8fafc;
  padding: 0 14px;
  font-size: 14px;
}

.extra-campo button {
  height: 46px;
  padding: 0 16px;
  border-radius: 12px;
  border: none;
  background: #eef2ff;
  color: #4f63ff;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.extra-campo button:hover {
  background: #e0e7ff;
}

.btn-novo-campo {
  width: 100%;
  height: 46px;
  border-radius: 14px;
  border: 1px dashed #c7d2fe;
  background: #f8fafc;
  color: #4f63ff;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.btn-novo-campo:hover {
  background: #eef2ff;
  border-color: #4f63ff;
}

.modal .form-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.modal .form-actions {
  display: flex;
  gap: 12px;
  margin-top: 10px;
}

.modal .form-actions button {
  flex: 1;
  height: 48px;
  border-radius: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
}

.modal .btn-cancelar {
  background: #eef2ff;
  color: #4f63ff;
}

.modal .btn-primary {
  background: linear-gradient(135deg, #4f63ff, #6b7cff);
  color: white;
}

.cliente-extra-box {
  margin-top: 20px;
  padding: 16px;
  border: 1px solid #d9e3f0;
  border-radius: 18px;
  background: #f8fbff;
}

.cliente-extra-lista {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 6px;
}

.cliente-extra-form-row {
  display: grid;
  grid-template-columns: minmax(210px, 1fr) minmax(210px, 1fr) 110px;
  gap: 12px;
  align-items: center;
}

.cliente-extra-form-row input {
  transition: 0.2s;
  width: 100%;
  height: 46px;
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: #ffffff;
  padding: 0 14px;
  font-size: 14px;
  color: #111827;
  outline: none;
}

.cliente-extra-form-row input::placeholder {
  color: #8a94a6;
}

.cliente-extra-form-row input:focus {
  background: #ffffff;
  border-color: #4f63ff;
  box-shadow: 0 0 0 4px rgba(79, 99, 255, 0.12);
}

.cliente-extra-form-row button.danger {
  transition: 0.2s;
  height: 46px;
  width: 100%;
  border: none;
  border-radius: 14px;
  background: #eef2ff;
  color: #4f63ff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}

.cliente-extra-form-row button.danger:hover {
  background: #e0e7ff;
}

.cliente-extra-head {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.cliente-extra-head strong {
  color: #0f172a;
  font-size: 14px;
  font-weight: 800;
}

.cliente-extra-head small {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: #475569;
  font-weight: 500;
}

.cliente-extra-head .btn-secondary {
  width: 100% !important;
  height: 48px;
  margin: 0 !important;
  border-radius: 14px;
  background: #eef4ff;
  color: #2454e8;
  font-weight: 800;
}

.cliente-extra-label {
  height: 46px;
  display: flex;
  align-items: center;
  padding: 0 14px;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff, #f1f5f9);
  border: 1px solid #dbe4f0;
  font-size: 14px;
  font-weight: 600;
  color: #0f172a;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.cliente-extra-opcional {
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #f1f5f9;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.cliente-extra-form-row input:-webkit-autofill,
.cliente-extra-form-row input:-webkit-autofill:hover,
.cliente-extra-form-row input:-webkit-autofill:focus {
  -webkit-text-fill-color: #111827 !important;
  -webkit-box-shadow: 0 0 0px 1000px #ffffff inset !important;
  box-shadow: 0 0 0px 1000px #ffffff inset !important;
}

.cliente-extra-th {
  min-width: 160px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.cliente-extra-th span {
  user-select: none;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.btn-remover-coluna {
  width: 22px;
  height: 22px;
  border: none;
  border-radius: 999px;
  background: #fee2e2;
  color: #b91c1c;
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  flex: 0 0 auto;
}

.btn-remover-coluna:hover {
  background: #fecaca;
}

.clientes-pagination button:hover {
  background: #f1f5f9;
}

.clientes-pagination button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.clientes-paginacao-numeros {
  display: flex;
  align-items: center;
  gap: 6px;
}

.pagina-numero.ativo {
  background: #12396d;
  color: #fff;
  border-color: #12396d;
  background: #12396d !important;
  border-color: #12396d !important;
  color: #ffffff !important;
}

.clientes-campos-contador {
  font-size: 13px;
  margin-top: 6px;
  color: #64748b;
}

.clientes-campos-contador.limite {
  color: #dc2626;
  font-weight: 600;
}

.clientes-campos-ocultos {
  margin: 14px 0 18px;
  padding: 14px;
  border: 1px solid #d9e3f0;
  border-radius: 16px;
  background: #f8fbff;
}

.clientes-campos-ocultos-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
  color: #0f172a;
  font-size: 13px;
}

.clientes-campos-ocultos-head span {
  color: #64748b;
  font-size: 12px;
}

.clientes-campos-ocultos-lista {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cliente-campo-restaurar {
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #0f172a;
  border-radius: 999px;
  padding: 8px 10px;
  cursor: pointer;
  font-size: 12px;
}

.cliente-campo-restaurar span {
  margin-left: 8px;
  color: #2563eb;
  font-weight: 700;
}

.clientes-table-wrap::-webkit-scrollbar {
  height: 14px;
  width: 12px;
}

.clientes-table-wrap::-webkit-scrollbar-track {
  background: #eef3f9;
  border-radius: 999px;
}

.clientes-table-wrap::-webkit-scrollbar-thumb {
  background: #94a3b8;
  border-radius: 999px;
  border: 3px solid #eef3f9;
}

.clientes-table-wrap::-webkit-scrollbar-thumb:hover {
  background: #64748b;
}

.import-extra-check.bloqueado {
  opacity: 0.6;
  cursor: not-allowed;
}

.import-extra-check em {
  display: block;
  margin-top: 3px;
  font-style: normal;
  color: #64748b;
  font-size: 11px;
}

.import-warn-text {
  color: #dc2626;
  font-weight: 600;
}

.cliente-extra-col:active {
  cursor: grabbing;
}

.clientes-table thead th {
  font-size: 12px;
  font-weight: 800;
  color: #475569;
  position: sticky;
  top: 0;
  z-index: 10;
  background: #f8fafc;
}

.clientes-table th,
.clientes-table td {
  text-align: left;
  color: #0f172a;
  max-width: 210px;
  padding: 12px 14px;
  white-space: nowrap;
  vertical-align: middle;
  border-bottom: 1px solid #edf2f7;
  min-width: 140px;
}

.clientes-table td strong {
  display: block;
  font-weight: 800;
  color: #0f172a;
}

.btn-cliente-action,
.clientes-row-actions button {
  min-height: 34px;
  padding: 7px 11px;
  border-radius: 10px;
  border: 1px solid #d6e0ee;
  background: #ffffff;
  color: #12396d;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
}

.btn-cliente-action:hover,
.clientes-row-actions button:hover {
  background: #f1f6ff;
}

.btn-cliente-action.danger,
.clientes-row-actions button.danger {
  border-color: #fecaca;
  background: #fff5f5;
  color: #dc2626;
}

.btn-cliente-action.ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
}

.clientes-pagina-info {
  text-align: center;
  color: #64748b;
  font-size: 12px;
  padding-bottom: 18px;
}

.cliente-drop-zone {
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  cursor: grab;
}

.cliente-drop-zone:hover {
  border-left-color: #4f46e5;
  background: #eef4ff;
}

.clientes-pagination-inline {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: 12px;
}

.clientes-pagination-inline button {
  height: 34px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1px solid #dbe4f0;
  background: #fff;
  cursor: pointer;
}

.clientes-grid-toolbar {
  position: sticky;
  top: 0;
  z-index: 20;
  gap: 12px;
  height: 48px;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 14px;
  background: #ffffff;
  border-bottom: 1px solid #e5edf7;
  flex-shrink: 0;
}

.clientes-grid-info {
  font-size: 12px;
  color: #64748b;
  white-space: nowrap;
}

.clientes-grid-paginacao {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.clientes-grid-paginacao button,
.clientes-paginacao-numeros button {
  min-width: 36px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid #d6e0ee;
  background: #ffffff;
  color: #12396d;
  font-weight: 800;
  cursor: pointer;
}

.clientes-grid-paginacao button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.clientes-grid-box {
  width: 100%;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  background: #ffffff;
  overflow: hidden;
}

.clientes-page-erp {
  height: calc(100vh - 154px);
  min-height: 680px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow: hidden;
}

.clientes-page-erp .clientes-grid-box {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-rows: 64px minmax(0, 1fr) 58px;
  width: 100%;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.07);
}

.clientes-page-erp .clientes-grid-toolbar {
  height: 64px;
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 0 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-bottom: 1px solid #e5edf7;
  z-index: 20;
}

.clientes-grid-title {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 170px;
}

.clientes-grid-title strong {
  color: #0f172a;
  font-size: 14px;
}

.clientes-grid-title span {
  color: #64748b;
  font-size: 12px;
}

.clientes-grid-filtros {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.clientes-grid-filtros input,
.clientes-grid-filtros select,
.clientes-ir-pagina input {
  height: 38px;
  border: 1px solid #dbe4f0;
  border-radius: 12px;
  background: #ffffff;
  color: #0f172a;
  padding: 0 12px;
  outline: none;
  font-size: 13px;
}

.clientes-grid-filtros input {
  flex: 1;
  max-width: 440px;
  min-width: 260px;
}

.clientes-grid-filtros select {
  min-width: 130px;
}

.clientes-table-area {
  min-height: 0;
  overflow: hidden;
  background: #ffffff;
}

.clientes-table-scroll {
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow: auto;
  padding-bottom: 18px;
  scrollbar-gutter: stable both-edges;
  overscroll-behavior: contain;
  background: #ffffff;
  overflow-x: auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.clientes-table-scroll::-webkit-scrollbar {
  height: 14px;
  width: 13px;
}

.clientes-table-scroll::-webkit-scrollbar-track {
  background: #eef3f9;
}

.clientes-table-scroll::-webkit-scrollbar-thumb {
  background: #94a3b8;
  border-radius: 999px;
  border: 3px solid #eef3f9;
}

.clientes-table-scroll::-webkit-scrollbar-thumb:hover {
  background: #64748b;
}

.clientes-page-erp .clientes-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
  background: #ffffff;
}

.clientes-page-erp .clientes-table th,
.clientes-page-erp .clientes-table td {
  min-width: 170px;
  max-width: 240px;
  height: 52px;
  padding: 12px 14px;
  border-bottom: 1px solid #edf2f7;
  border-right: 1px solid #f1f5f9;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
  color: #0f172a;
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.clientes-page-erp .clientes-table thead th {
  position: sticky;
  top: 0;
  z-index: 9;
  height: 48px;
  background: #f8fafc;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 1px 0 #e2e8f0;
}

.clientes-page-erp .clientes-table tbody tr {
  background: #ffffff;
}

.clientes-page-erp .clientes-table tbody tr:hover {
  background: #f8fbff;
}

.clientes-page-erp .clientes-acoes-sticky {
  position: sticky;
  right: 0;
  z-index: 8;
  min-width: 260px !important;
  max-width: 280px !important;
  background: #ffffff;
  box-shadow: -10px 0 18px rgba(15, 23, 42, 0.08);
}

.clientes-page-erp thead .clientes-acoes-sticky {
  z-index: 14;
  background: #f8fafc;
}

.clientes-grid-footer {
  height: 58px;
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 0 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-top: 1px solid #e5edf7;
  z-index: 18;
}

.clientes-footer-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 160px;
}

.clientes-footer-info strong {
  color: #0f172a;
  font-size: 13px;
}

.clientes-footer-info span {
  color: #64748b;
  font-size: 12px;
}

.clientes-grid-paginacao button,
.clientes-paginacao-numeros button,
.clientes-ir-pagina button {
  min-width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid #d6e0ee;
  background: #ffffff;
  color: #12396d;
  font-weight: 800;
  cursor: pointer;
}

.clientes-grid-paginacao button:hover,
.clientes-paginacao-numeros button:hover,
.clientes-ir-pagina button:hover {
  background: #f1f6ff;
}

.clientes-ir-pagina {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 190px;
}

.clientes-ir-pagina label {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.clientes-ir-pagina input {
  width: 68px;
  text-align: center;
}

.clientes-ir-pagina button {
  padding: 0 12px;
}

.clientes-skeleton-tr td {
  height: 52px;
  padding: 12px 14px;
}

.clientes-skeleton-line {
  height: 18px;
  width: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef2f7, #dbe4f0, #eef2f7);
  background-size: 200% 100%;
  animation: clientesSkeletonMove 1.1s infinite linear;
}

.clientes-colunas-removidas {
  display: block;
  width: 100%;
  margin: 18px 0;
  margin-top: 18px;
}

.clientes-colunas-removidas.hidden {
  display: none !important;
  display: none;
}

.clientes-colunas-removidas-card {
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  background: #fff;
  border: 1px solid #dbe4f0;
  border-radius: 18px;
  padding: 18px;
}

.clientes-colunas-removidas-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
}

.clientes-colunas-removidas-head strong {
  display: block;
  font-size: 16px;
  color: #12396d;
}

.clientes-colunas-removidas-head span {
  display: block;
  margin-top: 3px;
  font-size: 13px;
  color: #64748b;
}

.clientes-colunas-removidas-lista {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.clientes-coluna-removida-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #f8fbff;
}

.clientes-coluna-removida-item strong {
  display: block;
  font-size: 13px;
  color: #0f172a;
}

.clientes-coluna-removida-item span {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  color: #64748b;
}

.clientes-coluna-removida-actions {
  align-items: center;
  display: flex;
  gap: 10px;
}

body[data-tela="clientes"] .main {
  overflow: auto !important;
}

.clientes-colunas-removidas .btn-secondary,
.clientes-colunas-removidas .btn-cliente-action {
  width: auto !important;
  margin-top: 0 !important;
  white-space: nowrap;
}

.clientes-colunas-removidas-vazio {
  border-radius: 14px;
  background: #fff;
  border: 1px dashed #cbd5e1;
  color: #64748b;
  text-align: center;
  padding: 18px 20px;
  min-height: auto;
}

.clientes-table th.clientes-acoes-sticky,
.clientes-table td.clientes-acoes-sticky {
  min-width: 190px;
}

.btn-danger-soft {
  margin-top: 8px;
  width: 100%;
  color: #dc2626;
  border-color: #fecaca;
  background: #fff1f2;
}

.btn-danger-soft:hover {
  background: #ffe4e6;
  border-color: #fca5a5;
}

.usuario-inativo {
  opacity: 0.72;
  border: 1px dashed rgba(239, 68, 68, 0.35);
}

.tab-btn[data-tab="usuarios_ocultos"] {
  position: relative;
}

.module-panel {
  height: calc(100vh - 110px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#usuariosTabContent {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
}

.clientes-colunas-vazio {
  position: relative;
  padding: 28px 20px;
  text-align: center;
  color: #7b8aa5;
}

.clientes-colunas-vazio-texto {
  font-size: 15px;
}

.btn-fechar-colunas-removidas {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 30px;
  height: 30px;
  border: 1px solid #d7e0f5;
  background: #fff;
  border-radius: 10px;
  font-size: 18px;
  font-weight: 700;
  color: #5a6c92;
  cursor: pointer;
  transition: 0.2s;
}

.btn-fechar-colunas-removidas:hover {
  background: #f4f7ff;
}

.btn-icon-fechar {
  width: 34px;
  height: 34px;
  border: 1px solid #dbe4ff;
  background: #fff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: #6b7aa6;
  cursor: pointer;
  transition: all .2s ease;
}

.btn-icon-fechar:hover {
  background: #f5f8ff;
  border-color: #c8d7ff;
}

.chat-search-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}

.chat-search-input {
  flex: 1;
}

.chat-new-btn {
  width: 42px;
  height: 42px;
  border: none;
  border-radius: 14px;
  background: linear-gradient(135deg, #4f46e5, #2563eb);
  color: #fff;
  font-size: 24px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(37, 99, 235, .25);
}

.chat-new-btn:hover {
  transform: translateY(-1px);
}

.chat-modal {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .35);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.chat-modal.hidden {
  display: none;
}

.chat-modal-card {
  width: min(440px, calc(100vw - 32px));
  background: #fff;
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .25);
}

.chat-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.chat-modal-head strong {
  font-size: 18px;
}

.chat-modal-close {
  width: 34px;
  height: 34px;
  border: 1px solid #dbe4ff;
  background: #fff;
  border-radius: 10px;
  font-size: 20px;
  cursor: pointer;
}

.chat-modal-input {
  width: 100%;
  height: 44px;
  border: 1px solid #d8e2f3;
  border-radius: 14px;
  padding: 0 14px;
  outline: none;
  margin-bottom: 14px;
}

.chat-modal-lista {
  max-height: 340px;
  overflow-y: auto;
}

.chat-contato-item {
  width: 100%;
  border: 1px solid #edf2fb;
  background: #fff;
  border-radius: 14px;
  padding: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  margin-bottom: 8px;
  text-align: left;
}

.chat-contato-item:hover {
  background: #f8fbff;
  border-color: #cfe0ff;
}

.chat-contato-avatar {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background: #eef4ff;
  color: #1d4ed8;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}

.chat-contato-info strong {
  display: block;
  font-size: 14px;
}

.chat-contato-info span {
  display: block;
  font-size: 12px;
  color: #64748b;
}

.chat-lista::-webkit-scrollbar {
  width: 8px;
}

.chat-lista::-webkit-scrollbar-thumb {
  background: #9fb2ce;
  border-radius: 999px;
}

.chat-lista::-webkit-scrollbar-track {
  background: transparent;
}

.auditoria-page {
  height: calc(100vh - 96px);
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.auditoria-head {
  flex: 0 0 auto;
  margin-bottom: 14px;
}

.auditoria-shell {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
  overflow: hidden;
}

.auditoria-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.auditoria-actions .btn-secondary {
  min-width: 110px;
  height: 36px;
}

.auditoria-empty {
  height: 100%;
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
  font-weight: 700;
}

.auditoria-skeleton {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(226, 232, 240, 0.9);
}

.auditoria-skeleton-badge {
  height: 26px;
  border-radius: 999px;
  background: #e5e7eb;
}

.auditoria-skeleton-content div {
  width: 60%;
  height: 14px;
  border-radius: 999px;
  background: #e5e7eb;
  margin-bottom: 8px;
}

.auditoria-skeleton-content span {
  display: block;
  width: 38%;
  height: 10px;
  border-radius: 999px;
  background: #e5e7eb;
}

.auditoria-page-clean {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  gap: 14px;
  height: calc(100vh - 125px);
  padding: 18px 22px 28px;
}

.auditoria-header-clean {
  flex: 0 0 auto;
  color: #0f172a;
}

.auditoria-header-clean h3 {
  margin: 0 0 4px;
  font-size: 22px;
  font-weight: 800;
  color: #0f172a;
}

.auditoria-header-clean p {
  margin: 0;
  font-size: 14px;
  color: #64748b;
}

.auditoria-card-clean {
  flex: 1;
  min-height: 0;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
  margin-bottom: 10px;
}

.auditoria-lista-clean {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 14px;
  background: #f8fafc;
  scrollbar-gutter: stable;
}

.auditoria-item-clean {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  align-items: start;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 12px 14px;
  margin-bottom: 10px;
}

.auditoria-badge-clean {
  background: #eef4ff;
  color: #334155;
  border-radius: 999px;
  padding: 7px 10px;
  text-align: center;
  font-size: 12px;
  font-weight: 800;
}

.auditoria-content-clean strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
  line-height: 1.35;
  margin-bottom: 6px;
}

.auditoria-meta-clean {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  color: #64748b;
  font-size: 12px;
}

.auditoria-footer-clean {
  flex: 0 0 auto;
  border-top: 1px solid #e2e8f0;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 64px;
  padding: 12px 14px 16px;
  margin-bottom: 8px;
}

.auditoria-info-clean {
  color: #475569;
  font-size: 13px;
  font-weight: 700;
}

.auditoria-actions-clean {
  display: flex;
  gap: 8px;
}

.auditoria-actions-clean .btn-secondary {
  min-width: 100px;
  height: 36px;
}

.auditoria-empty-clean {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
  font-weight: 700;
}

.auditoria-skeleton-clean {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  background: #ffffff;
  border-radius: 14px;
  padding: 12px 14px;
  margin-bottom: 10px;
}

.auditoria-skeleton-clean span,
.auditoria-skeleton-clean strong,
.auditoria-skeleton-clean small {
  display: block;
  background: #e5e7eb;
  border-radius: 999px;
}

.auditoria-skeleton-clean span {
  height: 28px;
}

.auditoria-skeleton-clean strong {
  width: 55%;
  height: 14px;
  margin-bottom: 8px;
}

.auditoria-skeleton-clean small {
  width: 35%;
  height: 10px;
}

#mainContent {
  min-height: 0;
  overflow: hidden;
}

.section.auditoria-page-clean {
  margin: 0 !important;
  box-sizing: border-box;
}

.auditoria-page-clean,
.auditoria-page-clean * {
  box-sizing: border-box;
}

.mini-chat-image-preview {
  display: block;
  width: 180px;
  max-width: 180px;
  max-height: 180px;
  border-radius: 12px;
  object-fit: cover;
  cursor: pointer;
}

.mini-chat-image-link {
  display: inline-block;
  text-decoration: none;
}

.mini-chat-msg-menu {
  position: fixed;
  z-index: 9999999;
  width: 190px;
  padding: 8px;
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.22);
}

.mini-chat-msg-menu button {
  width: 100%;
  border: none;
  background: transparent;
  padding: 11px 12px;
  border-radius: 12px;
  text-align: left;
  cursor: pointer;
  font-size: 13px;
  color: #0f172a;
}

.mini-chat-msg-menu button:hover {
  background: #f1f5f9;
}

.mini-chat-msg-menu button.danger {
  color: #dc2626;
}

.mini-chat-msg-menu button.danger:hover {
  background: #fee2e2;
}

.mini-chat-msg-menu,
.chat-conversa-menu {
  position: fixed;
  z-index: 99999999;
  pointer-events: auto;
}

.chat-conversa-menu {
  position: fixed;
  z-index: 99999999;
  width: 220px;
  padding: 8px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid #dbe4f0;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.22);
  backdrop-filter: blur(12px);
}

.chat-conversa-menu button {
  width: 100%;
  min-height: 44px;
  border: none;
  background: transparent;
  padding: 10px 12px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  color: #0f172a;
  font-size: 13px;
  text-align: left;
}

.chat-conversa-menu button:hover {
  background: #f1f5f9;
}

.chat-conversa-menu button.danger {
  color: #dc2626;
}

.chat-conversa-menu button.danger:hover {
  background: #fee2e2;
}

@media (max-width: 720px) {
  .card-login {
    padding: 24px 20px 22px;
    border-radius: 22px;
  }

  .logo-login {
    font-size: 32px;
  }

  .page {
    padding: 18px;
  }

}

@media (max-width: 1200px) {
  .grid-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-insights {
    grid-template-columns: 1fr;
  }

  .painel,
  .panel.two-col,
  .dashboard-hero {
    grid-template-columns: 1fr;
  }

}

@media (max-width: 1100px) {

  .dashboard-hero,
  .panel.two-col {
    grid-template-columns: 1fr;
  }

}

@media (max-width: 900px) {
  .app-shell {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
    grid-template-areas: "topo"
      "menu"
      "main";
  }

  .menu {
    border-right: none;
    border-bottom: 1px solid #dce5f0;
  }

  .perfil {
    min-width: unset;
    width: 100%;
  }

  .topo {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .topo-dir {
    align-items: stretch;
  }

}

@media (max-width: 720px) {

  .dashboard-hero-copy,
  .dashboard-hero-side {
    padding: 20px;
  }

  .dashboard-hero-copy h2 {
    font-size: 28px;
  }

  .premium-auth-card {
    padding: 24px 20px 22px;
    border-radius: 22px;
  }

  .auth-title {
    font-size: 32px;
  }

}

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

  .main {
    padding: 16px;
  }

  .hero {
    padding: 18px;
  }

  .card-login {
    min-height: auto;
    padding: 26px 20px;
  }

}

@media (max-width: 720px) {

  .card-login,
  .premium-auth-card {
    padding: 24px 20px 22px !important;
    border-radius: 22px !important;
  }

  .logo-login,
  .auth-title {
    font-size: 32px !important;
  }

  .page,
  .page-auth,
  .premium-auth-page {
    padding: 18px !important;
  }

}

@media (max-height: 900px) {
  .menu {
    padding: 8px 10px;
  }

  .menu-lista {
    gap: 6px;
  }

  .menu-item {
    min-height: 50px;
    padding: 7px 9px;
  }

  .menu-icon {
    font-size: 16px;
  }

  .menu-titulo {
    font-size: 12px;
  }

  .menu-sub {
    font-size: 9px;
  }

  .ambiente {
    margin-top: 6px;
    padding-top: 6px;
  }

}

@media (max-width: 980px) {
  #miniChatDock {
    right: 10px;
    gap: 8px;
  }

  .mini-chat-window {
    width: 320px;
  }

}

@media (max-width: 760px) {
  #miniChatDock {
    right: 0;
    left: 0;
    bottom: 0;
    justify-content: center;
  }

  .mini-chat-window {
    width: min(100vw, 100%);
    max-width: 100vw;
    border-radius: 16px 16px 0 0;
  }

}

@keyframes toastIn {
  from {
    transform: translateY(12px);
    opacity: 0;
  }

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

@keyframes skeletonMove {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

@keyframes clientesSkeletonMove {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

@media (max-width: 1100px) {
  .clientes-page-erp {
    height: auto;
    min-height: calc(100vh - 154px);
    overflow: visible;
  }

  .clientes-page-erp .clientes-grid-box {
    min-height: 620px;
  }

  .clientes-page-erp .clientes-grid-toolbar {
    height: auto;
    min-height: 64px;
    align-items: flex-start;
    flex-direction: column;
    padding: 12px;
  }

  .clientes-grid-filtros {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .clientes-grid-filtros input {
    max-width: none;
    min-width: 100%;
  }

  .clientes-grid-footer {
    height: auto;
    min-height: 58px;
    align-items: flex-start;
    flex-direction: column;
    padding: 12px;
  }

  .clientes-ir-pagina {
    justify-content: flex-start;
  }

}

@media (max-width: 780px) {
  .auditoria-page {
    height: calc(100vh - 82px);
  }

  .auditoria-item,
  .auditoria-skeleton {
    grid-template-columns: 1fr;
  }

  .auditoria-badge {
    width: fit-content;
  }

  .auditoria-footer {
    height: auto;
    align-items: stretch;
    flex-direction: column;
  }

  .auditoria-actions {
    width: 100%;
  }

  .auditoria-actions .btn-secondary {
    flex: 1;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"] .app-shell {
    display: block !important;
    height: 100dvh !important;
    overflow: hidden !important;
  }

  body[data-tela="chat"] .topo,
  body[data-tela="chat"] .menu {
    display: none !important;
  }

  body[data-tela="chat"] .main {
    display: block !important;
    height: 100dvh !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  body[data-tela="chat"] .section,
  body[data-tela="chat"] .chat-page-clean {
    height: 100dvh !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body[data-tela="chat"] .section-head,
  body[data-tela="chat"] .chat-head-clean {
    display: none !important;
  }

  body[data-tela="chat"] .chat-shell {
    height: 100dvh !important;
    min-height: 100dvh !important;
    width: 100vw !important;
    border-radius: 0 !important;
    border: none !important;
  }

  body[data-tela="chat"] .chat-sidebar {
    width: 100vw !important;
    height: 100dvh !important;
    border-right: none !important;
  }

  body[data-tela="chat"] .chat-sidebar-top {
    position: sticky;
    top: 0;
    z-index: 2;
    padding: 16px !important;
  }

  body[data-tela="chat"] .chat-lista {
    flex: 1;
    height: auto !important;
    padding: 10px !important;
    overflow-y: auto !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"] #miniChatDock {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    pointer-events: none;
  }

  body[data-tela="chat"] #miniChatDock>* {
    pointer-events: auto;
  }

  body[data-tela="chat"] .mini-chat-window {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    border-radius: 0 !important;
    margin: 0 !important;
    max-width: none !important;
    max-height: none !important;
  }

  body[data-tela="chat"] .mini-chat-window.min {
    height: 62px !important;
    top: auto !important;
    bottom: 0 !important;
  }

  body[data-tela="chat"] .mini-chat-header {
    border-radius: 0 !important;
    padding-top: max(10px, env(safe-area-inset-top)) !important;
  }

  body[data-tela="chat"] .mini-chat-content {
    flex: 1 !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
  }

  body[data-tela="chat"] .mini-chat-body {
    flex: 1 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }

  body[data-tela="chat"] .mini-chat-footer {
    flex-shrink: 0 !important;
    padding-bottom: calc(env(safe-area-inset-bottom) + 10px) !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"] .chat-sidebar-top {
    padding: 18px 18px 14px !important;
    background: #ffffff !important;
    border-bottom: 1px solid #e5e7eb !important;
  }

  body[data-tela="chat"] .chat-mobile-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
  }

  body[data-tela="chat"] .chat-mobile-top strong {
    font-size: 24px;
    color: #0f172a;
  }

  body[data-tela="chat"] .chat-mobile-close {
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 14px;
    background: #e8eef7;
    color: #12396d;
    font-size: 22px;
    font-weight: 800;
    cursor: pointer;
  }

  body[data-tela="chat"] .chat-lista {
    padding: 16px !important;
    gap: 12px !important;
    background: #f4f7fb !important;
  }

  body[data-tela="chat"] .chat-item {
    min-height: 86px;
    border-radius: 22px !important;
    padding: 16px !important;
    background: #ffffff !important;
    border: 1px solid #d9e3f0 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
  }

  body[data-tela="chat"] .chat-item.ativo,
  body[data-tela="chat"] .chat-item:hover {
    background: linear-gradient(135deg, #12396d, #1d4ed8) !important;
    color: #ffffff !important;
  }

  body[data-tela="chat"] .chat-item.ativo strong,
  body[data-tela="chat"] .chat-item.ativo small,
  body[data-tela="chat"] .chat-item.ativo span {
    color: #ffffff !important;
  }

  body[data-tela="chat"] .chat-item-avatar {
    width: 52px !important;
    height: 52px !important;
    font-size: 20px !important;
  }

  body[data-tela="chat"] .chat-item-top strong {
    font-size: 17px !important;
  }

  body[data-tela="chat"] .chat-item-bottom small {
    font-size: 14px !important;
  }

  body[data-tela="chat"] .mini-chat-actions button:first-child {
    display: none !important;
  }

}

@media (max-width: 768px) {
  body.is-mobile {
    overflow-x: hidden;
  }

  .mobile-topbar {
    position: sticky;
    top: 0;
    z-index: 99990;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 14px;
    background: linear-gradient(135deg,
        #12396d,
        #1d4ed8);
    color: #fff;
  }

  .mobile-topbar-left {
    display: flex;
    align-items: center;
    gap: 12px;
  }

  .mobile-topbar-title {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: .3px;
  }

  .mobile-menu-btn {
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 14px;
    background: rgba(255, 255, 255, .12);
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    cursor: pointer;
  }

  .mobile-menu-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .45);
    backdrop-filter: blur(2px);
    z-index: 99991;
    opacity: 0;
    pointer-events: none;
    transition: .25s ease;
  }

  body.mobile-menu-open .mobile-menu-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .menu {
    position: fixed !important;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(88vw, 340px) !important;
    max-width: 340px !important;
    z-index: 99992;
    overflow-y: auto;
    transform: translateX(-105%);
    transition: transform .28s ease;
    border-radius: 0 !important;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .04),
      0 20px 60px rgba(0, 0, 0, .35);
  }

  body.mobile-menu-open .menu {
    transform: translateX(0);
  }

  .main {
    width: 100% !important;
    min-width: 0 !important;
  }

  .app-shell {
    display: block !important;
  }

  body.mobile-menu-open {
    overflow: hidden;
  }

  .mobile-only {
    display: flex;
  }

}

@media (min-width: 769px) {

  .mobile-topbar,
  .mobile-menu-overlay {
    display: none !important;
  }

  .mobile-only {
    display: none !important;
  }

}

@media (max-width: 768px) {

  body:not([data-tela]),
  body[data-tela="login"],
  body[data-tela="troca_senha"] {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    height: auto !important;
    min-height: 100dvh !important;
  }

  body:not([data-tela]) #app,
  body[data-tela="login"] #app,
  body[data-tela="troca_senha"] #app {
    height: auto !important;
    min-height: 100dvh !important;
  }

  .page {
    min-height: 100dvh !important;
    align-items: flex-start !important;
    padding: 18px 14px !important;
    overflow-y: auto !important;
  }

  .card-login {
    width: 100% !important;
    max-width: 460px !important;
    margin: 18px auto !important;
    padding: 24px 18px 20px !important;
    border-radius: 24px !important;
  }

  .logo-login {
    font-size: 34px !important;
  }

  .subtitle-login {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  .version-login {
    font-size: 11px !important;
    margin-bottom: 18px !important;
  }

  .form-area label {
    font-size: 11px !important;
  }

  .input-wrap input,
  .input-wrap select,
  .input-wrap textarea {
    min-height: 48px !important;
    font-size: 16px !important;
  }

  .btn-primary,
  .btn-secondary,
  .btn-blue {
    min-height: 50px !important;
    border-radius: 16px !important;
  }

  .check-row {
    align-items: flex-start !important;
    line-height: 1.35 !important;
  }

  .helper-text,
  .error-text,
  .info-text {
    font-size: 12px !important;
    line-height: 1.45 !important;
  }

}

@media (max-width: 768px) {

  body[data-tela="login"],
  body[data-tela="troca_senha"] {
    background: linear-gradient(180deg,
        #eef3ff 0%,
        #f7f9fc 100%) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body[data-tela="login"] .page,
  body[data-tela="troca_senha"] .page {
    min-height: 100dvh !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: max(20px, env(safe-area-inset-top)) 16px max(28px, env(safe-area-inset-bottom)) !important;
  }

  body[data-tela="login"] .card-login,
  body[data-tela="troca_senha"] .card-login {
    width: 100% !important;
    max-width: 430px !important;
    margin: 0 auto !important;
    padding: 24px 22px 22px !important;
    border-radius: 30px !important;
    background: rgba(255, 255, 255, .92) !important;
    backdrop-filter: blur(12px);
    box-shadow: 0 10px 30px rgba(15, 23, 42, .08),
      0 2px 10px rgba(15, 23, 42, .04) !important;
  }

  body[data-tela="login"] .top-bar,
  body[data-tela="troca_senha"] .top-bar {
    height: 6px !important;
    border-radius: 999px !important;
    margin-bottom: 22px !important;
  }

  body[data-tela="login"] .login-chip,
  body[data-tela="troca_senha"] .login-chip {
    font-size: 13px !important;
    padding: 8px 14px !important;
    border-radius: 999px !important;
    margin-bottom: 18px !important;
  }

  body[data-tela="login"] .logo-login,
  body[data-tela="troca_senha"] .logo-login {
    font-size: 54px !important;
    line-height: .95 !important;
    letter-spacing: -2px !important;
    margin-bottom: 14px !important;
  }

  body[data-tela="login"] .subtitle-login,
  body[data-tela="troca_senha"] .subtitle-login {
    font-size: 16px !important;
    line-height: 1.45 !important;
    margin-bottom: 6px !important;
  }

  body[data-tela="login"] .version-login,
  body[data-tela="troca_senha"] .version-login {
    font-size: 13px !important;
    margin-bottom: 28px !important;
    opacity: .72;
  }

  body[data-tela="login"] .form-area,
  body[data-tela="troca_senha"] .form-area {
    gap: 14px !important;
  }

  body[data-tela="login"] .form-area label,
  body[data-tela="troca_senha"] .form-area label {
    font-size: 12px !important;
    letter-spacing: .08em !important;
    margin-bottom: 8px !important;
  }

  body[data-tela="login"] .input-wrap,
  body[data-tela="troca_senha"] .input-wrap {
    border-radius: 22px !important;
  }

  body[data-tela="login"] .input-wrap input,
  body[data-tela="login"] .input-wrap select,
  body[data-tela="troca_senha"] .input-wrap input {
    min-height: 58px !important;
    font-size: 18px !important;
    padding: 0 18px !important;
    border-radius: 22px !important;
  }

  body[data-tela="login"] .btn-primary,
  body[data-tela="troca_senha"] .btn-primary {
    min-height: 58px !important;
    border-radius: 22px !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    margin-top: 10px !important;
  }

  body[data-tela="login"] .btn-secondary,
  body[data-tela="troca_senha"] .btn-secondary {
    min-height: 54px !important;
    border-radius: 20px !important;
  }

  body[data-tela="login"] .check-row,
  body[data-tela="troca_senha"] .check-row {
    margin-top: 4px !important;
    gap: 10px !important;
  }

  body[data-tela="login"] .helper-text,
  body[data-tela="troca_senha"] .helper-text {
    font-size: 13px !important;
    line-height: 1.5 !important;
    opacity: .8;
  }

}

@media (max-width: 768px) {

  body[data-tela="login"] .page,
  body[data-tela="troca_senha"] .page {
    align-items: flex-start !important;
    justify-content: flex-start !important;
    padding: 12px 14px 120px !important;
  }

  body[data-tela="login"] .card-login,
  body[data-tela="troca_senha"] .card-login {
    padding: 18px 18px 20px !important;
    border-radius: 24px !important;
  }

  body[data-tela="login"] .top-bar,
  body[data-tela="troca_senha"] .top-bar {
    margin-bottom: 14px !important;
  }

  body[data-tela="login"] .login-chip,
  body[data-tela="troca_senha"] .login-chip {
    margin-bottom: 12px !important;
    padding: 6px 12px !important;
  }

  body[data-tela="login"] .logo-login,
  body[data-tela="troca_senha"] .logo-login {
    font-size: 36px !important;
    margin-bottom: 8px !important;
  }

  body[data-tela="login"] .subtitle-login,
  body[data-tela="troca_senha"] .subtitle-login {
    font-size: 14px !important;
    margin-bottom: 4px !important;
  }

  body[data-tela="login"] .version-login,
  body[data-tela="troca_senha"] .version-login {
    font-size: 11px !important;
    margin-bottom: 16px !important;
  }

  body[data-tela="login"] .input-wrap,
  body[data-tela="troca_senha"] .input-wrap {
    margin-bottom: 12px !important;
  }

  body[data-tela="login"] .input-wrap input,
  body[data-tela="login"] .input-wrap select,
  body[data-tela="troca_senha"] .input-wrap input {
    min-height: 48px !important;
    font-size: 15px !important;
  }

  body[data-tela="login"] .helper-text,
  body[data-tela="troca_senha"] .helper-text {
    margin-bottom: 6px !important;
  }

  body[data-tela="login"] .btn-primary,
  body[data-tela="troca_senha"] .btn-primary {
    min-height: 50px !important;
    margin-top: 6px !important;
  }

  body[data-tela="troca_senha"] .btn-secondary {
    min-height: 48px !important;
  }

}

@media (max-width: 768px) {

  html,
  body {
    height: auto !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  #app,
  .app-shell {
    height: auto !important;
    min-height: 100dvh !important;
    overflow: visible !important;
  }

  body.is-mobile .topo {
    display: none !important;
  }

  body.is-mobile .mobile-topbar {
    position: sticky;
    top: 0;
    z-index: 99990;
    height: 72px;
    padding: 0 16px;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, #12396d, #1d4ed8);
    color: #fff;
  }

  body.is-mobile .mobile-topbar-left {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
  }

  body.is-mobile .mobile-menu-btn {
    width: 46px;
    height: 46px;
    border: none;
    border-radius: 16px;
    background: rgba(255, 255, 255, .14);
    color: #fff;
    font-size: 24px;
    font-weight: 800;
  }

  body.is-mobile .mobile-topbar-text {
    min-width: 0;
    display: flex;
    flex-direction: column;
  }

  body.is-mobile .mobile-topbar-title {
    font-size: 20px;
    font-weight: 800;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  body.is-mobile .mobile-topbar-subtitle {
    margin-top: 3px;
    font-size: 12px;
    opacity: .82;
  }

  body.is-mobile .main {
    height: auto !important;
    min-height: calc(100dvh - 72px) !important;
    overflow: visible !important;
    padding: 16px 16px 110px !important;
  }

  body.is-mobile .mobile-context-card {
    margin: 0 0 16px;
    padding: 16px;
    border-radius: 22px;
    background: #ffffff;
    border: 1px solid #d9e3f0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
    color: #0f172a;
  }

  body.is-mobile .mobile-context-label {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #2563eb;
    margin-bottom: 6px;
  }

  body.is-mobile .mobile-context-title {
    font-size: 18px;
    font-weight: 800;
    margin-bottom: 4px;
  }

  body.is-mobile .mobile-context-sub {
    font-size: 13px;
    color: #64748b;
    line-height: 1.4;
    margin-bottom: 14px;
  }

  body.is-mobile .mobile-context-btn {
    width: 100%;
    min-height: 46px;
    border: none;
    border-radius: 16px;
    background: linear-gradient(135deg, #12396d, #1d4ed8);
    color: #fff;
    font-weight: 800;
    font-size: 14px;
  }

  body.is-mobile .hero {
    margin-top: 0 !important;
    border-radius: 24px !important;
    padding: 20px !important;
  }

  body.is-mobile .hero h1 {
    font-size: 26px !important;
    line-height: 1.12 !important;
  }

  body.is-mobile .hero p {
    font-size: 15px !important;
    line-height: 1.4 !important;
  }

  body.is-mobile .grid-stats,
  body.is-mobile .grid-insights,
  body.is-mobile .painel,
  body.is-mobile .panel.two-col,
  body.is-mobile .dashboard-hero {
    grid-template-columns: 1fr !important;
  }

}

@media (max-width: 768px) {
  body.is-mobile .hero>div {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }

  body.is-mobile #btnRefreshDashboard {
    width: 100% !important;
    min-width: 0 !important;
    margin-top: 18px !important;
  }

}

@media (max-width: 768px) {
  .mobile-store-modal {
    position: fixed;
    inset: 0;
    z-index: 9999999;
    background: rgba(15, 23, 42, 0.52);
    display: flex;
    align-items: flex-end;
  }

  .mobile-store-sheet {
    width: 100%;
    max-height: 78dvh;
    background: #ffffff;
    border-radius: 28px 28px 0 0;
    padding: 18px;
    overflow-y: auto;
    box-shadow: 0 -20px 60px rgba(15, 23, 42, 0.25);
  }

  .mobile-store-sheet-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
  }

  .mobile-store-sheet-head strong {
    display: block;
    font-size: 22px;
    color: #0f172a;
  }

  .mobile-store-sheet-head span {
    display: block;
    margin-top: 4px;
    color: #64748b;
    font-size: 13px;
  }

  .mobile-store-sheet-head button {
    width: 42px;
    height: 42px;
    border: none;
    border-radius: 14px;
    background: #e8eef7;
    color: #12396d;
    font-size: 24px;
    font-weight: 800;
  }

  .mobile-store-list {
    display: grid;
    gap: 10px;
    padding-bottom: calc(env(safe-area-inset-bottom) + 12px);
  }

  .mobile-store-option {
    min-height: 58px;
    border: 1px solid #d9e3f0;
    border-radius: 18px;
    background: #f8fbff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    text-align: left;
  }

  .mobile-store-option span {
    color: #0f172a;
    font-weight: 800;
    font-size: 15px;
  }

  .mobile-store-option small {
    color: #64748b;
    font-size: 12px;
    font-weight: 700;
  }

  .mobile-store-option.ativo {
    background: linear-gradient(135deg, #12396d, #1d4ed8);
    border-color: transparent;
  }

  .mobile-store-option.ativo span,
  .mobile-store-option.ativo small {
    color: #ffffff;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"].is-mobile .main {
    padding: 14px !important;
    overflow-x: hidden !important;
  }

  body[data-tela="chat"].is-mobile .chat-page-clean,
  body[data-tela="chat"].is-mobile .chat-shell,
  body[data-tela="chat"].is-mobile .chat-sidebar {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body[data-tela="chat"].is-mobile .chat-shell {
    height: calc(100dvh - 100px) !important;
    min-height: calc(100dvh - 100px) !important;
    border-radius: 22px !important;
    overflow: hidden !important;
  }

  body[data-tela="chat"].is-mobile .chat-sidebar {
    border-right: none !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"].is-mobile .main {
    padding: 12px !important;
    background: #eef3f9 !important;
    min-height: calc(100dvh - 72px) !important;
  }

  body[data-tela="chat"].is-mobile .chat-page-clean {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
  }

  body[data-tela="chat"].is-mobile .chat-shell {
    width: 100% !important;
    max-width: 100% !important;
    height: calc(100dvh - 96px) !important;
    min-height: calc(100dvh - 96px) !important;
    margin: 0 auto !important;
    border-radius: 22px !important;
    overflow: hidden !important;
    background: #ffffff !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.12) !important;
  }

  body[data-tela="chat"].is-mobile .chat-sidebar {
    width: 100% !important;
    height: 100% !important;
    background: #f8fbff !important;
    border: 1px solid #d9e3f0 !important;
    border-radius: 22px !important;
    overflow: hidden !important;
  }

  body[data-tela="chat"].is-mobile .chat-sidebar-top {
    background: #ffffff !important;
    padding: 18px 16px 14px !important;
    border-bottom: 1px solid #e5edf7 !important;
  }

  body[data-tela="chat"].is-mobile .chat-lista {
    padding: 14px !important;
    background: #f3f7fc !important;
    height: calc(100% - 122px) !important;
    overflow-y: auto !important;
  }

  body[data-tela="chat"].is-mobile .chat-item {
    width: 100% !important;
    min-height: 72px !important;
    border-radius: 18px !important;
    background: #ffffff !important;
    color: #0f172a !important;
    border: 1px solid #d9e3f0 !important;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06) !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"].is-mobile .main {
    padding: 12px !important;
    background: #eef3f9 !important;
    overflow: visible !important;
  }

  body[data-tela="chat"].is-mobile .chat-page-clean {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body[data-tela="chat"].is-mobile .chat-shell {
    width: 100% !important;
    height: calc(100dvh - 96px) !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  body[data-tela="chat"].is-mobile .chat-sidebar {
    width: 100% !important;
    height: 100% !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    border: 1px solid #d9e3f0 !important;
    box-shadow: 0 18px 42px rgba(15, 23, 42, .12) !important;
    overflow: hidden !important;
  }

  body[data-tela="chat"].is-mobile .chat-lista {
    height: calc(100% - 126px) !important;
    overflow-y: auto !important;
    background: #f3f7fc !important;
  }

  body[data-tela="chat"].is-mobile .mobile-topbar {
    z-index: 100000 !important;
  }

  body[data-tela="chat"].is-mobile .menu {
    z-index: 100002 !important;
  }

  body[data-tela="chat"].is-mobile .mobile-menu-overlay {
    z-index: 100001 !important;
  }

}

@media (max-width: 768px) {
  body.is-mobile .mobile-menu-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999990 !important;
    background: rgba(15, 23, 42, 0.55) !important;
    backdrop-filter: blur(3px);
    opacity: 0 !important;
    pointer-events: none !important;
  }

  body.is-mobile.mobile-menu-open .mobile-menu-overlay {
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  body.is-mobile .menu {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: min(86vw, 340px) !important;
    max-width: 340px !important;
    height: 100dvh !important;
    z-index: 999999 !important;
    transform: translateX(-110%) !important;
    transition: transform .25s ease !important;
    overflow-y: auto !important;
    border-radius: 0 24px 24px 0 !important;
  }

  body.is-mobile.mobile-menu-open .menu {
    transform: translateX(0) !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"].is-mobile .main {
    padding: 12px !important;
    background: #eef3f9 !important;
  }

  body[data-tela="chat"].is-mobile .chat-page-clean,
  body[data-tela="chat"].is-mobile .chat-shell {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  body[data-tela="chat"].is-mobile .chat-shell {
    height: calc(100dvh - 96px) !important;
  }

  body[data-tela="chat"].is-mobile .chat-sidebar {
    width: 100% !important;
    height: 100% !important;
    margin: 0 auto !important;
    border-radius: 24px !important;
    background: #fff !important;
    overflow: hidden !important;
  }

}

@media (max-width: 768px) {
  body .mobile-menu-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999990 !important;
    background: rgba(15, 23, 42, .55) !important;
    backdrop-filter: blur(3px) !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  body.mobile-menu-open .mobile-menu-overlay {
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  body .menu {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: min(86vw, 340px) !important;
    max-width: 340px !important;
    height: 100dvh !important;
    z-index: 999999 !important;
    transform: translateX(-110%) !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow-y: auto !important;
    border-radius: 0 24px 24px 0 !important;
    transition: transform .25s ease !important;
  }

  body.mobile-menu-open .menu {
    transform: translateX(0) !important;
  }

}

@media (max-width: 768px) {
  body[data-tela="chat"].is-mobile .menu {
    display: flex !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: min(86vw, 340px) !important;
    max-width: 340px !important;
    height: 100dvh !important;
    z-index: 999999 !important;
    transform: translateX(-110%) !important;
    transition: transform .25s ease !important;
    overflow-y: auto !important;
    border-radius: 0 24px 24px 0 !important;
  }

  body[data-tela="chat"].is-mobile.mobile-menu-open .menu {
    transform: translateX(0) !important;
  }

  body[data-tela="chat"].is-mobile .mobile-menu-overlay {
    display: block !important;
    z-index: 999990 !important;
  }

}

@media (max-width: 768px) {
  .chat-page-clean {
    padding: 12px !important;
  }

  .chat-shell.somente-lista-chat {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
  }

  .chat-sidebar {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  .chat-sidebar-top {
    padding: 20px !important;
  }

  .chat-lista {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  .chat-item {
    width: calc(100% - 24px) !important;
    margin: 12px auto !important;
    box-sizing: border-box !important;
  }

}

@media (max-width: 768px) {

  .clientes-header,
  .clientes-actions,
  .clientes-grid-toolbar,
  .clientes-grid-filtros {
    flex-direction: column;
    align-items: stretch;
  }

  .clientes-actions button,
  .clientes-grid-filtros input,
  .clientes-grid-filtros select {
    width: 100%;
  }

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

  .clientes-mobile-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .cliente-mobile-card {
    background: #fff;
    border: 1px solid #d9e3f0;
    border-radius: 18px;
    padding: 16px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  }

  .cliente-mobile-card-top {
    display: flex;
    justify-content: space-between;
    gap: 12px;
  }

  .cliente-mobile-identidade strong {
    display: block;
    color: #0f172a;
    font-size: 15px;
  }

  .cliente-mobile-identidade span,
  .cliente-mobile-info small {
    color: #64748b;
    font-size: 11px;
  }

  .cliente-mobile-card-top em {
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-style: normal;
    font-weight: 700;
    height: fit-content;
  }

  .cliente-mobile-card-top em.ativo {
    background: #dcfce7;
    color: #166534;
  }

  .cliente-mobile-card-top em.inativo {
    background: #fee2e2;
    color: #991b1b;
  }

  .cliente-mobile-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 14px;
  }

  .cliente-mobile-info span {
    display: block;
    color: #0f172a;
    font-size: 13px;
    margin-top: 3px;
    word-break: break-word;
  }

  .cliente-mobile-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 14px;
  }

  .cliente-mobile-actions .btn-cliente-action {
    min-height: 42px;
    border-radius: 12px;
  }

  .clientes-grid-footer {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .clientes-grid-paginacao {
    justify-content: center;
    flex-wrap: wrap;
  }

  .clientes-ir-pagina {
    width: 100%;
    justify-content: center;
  }

}

@media (max-width: 768px) {

  input,
  select,
  textarea,
  button {
    font-size: 16px;
  }

}

@media (max-width: 768px) {

  .modal-card,
  .clientes-modal,
  .modal-content {
    width: 100%;
    max-width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    border-radius: 0;
    margin: 0;
  }

  .modal-body {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 120px;
  }

}

@media (max-width: 768px) {
  .clientes-grid-toolbar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .clientes-grid-toolbar>* {
    width: 100%;
  }

  .clientes-grid-toolbar .input-wrap,
  .clientes-grid-toolbar button,
  .clientes-grid-toolbar select,
  .clientes-grid-toolbar input {
    width: 100%;
  }

}

@media (max-width: 768px) {
  .clientes-grid-footer {
    position: sticky;
    bottom: 0;
    background: #fff;
    z-index: 20;
    padding-bottom: env(safe-area-inset-bottom);
  }

}

@media (max-width: 768px) {
  .clientes-page {
    padding: 14px !important;
  }

  .clientes-header {
    gap: 18px;
  }

  .clientes-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .clientes-actions button {
    width: 100%;
    min-height: 54px;
    border-radius: 18px;
    font-size: 16px;
    font-weight: 800;
  }

  .clientes-metricas {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin: 18px 0;
  }

  .cliente-metrica-card {
    min-height: 104px;
    border-radius: 20px;
  }

  .clientes-grid-box {
    margin-top: 18px;
    border-radius: 24px;
    padding: 14px;
    overflow: visible;
  }

  .clientes-grid-toolbar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .clientes-grid-title {
    display: flex;
    justify-content: space-between;
    gap: 10px;
  }

  .clientes-grid-filtros {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .clientes-grid-filtros input,
  .clientes-grid-filtros select {
    width: 100%;
    min-height: 48px;
    border-radius: 16px;
    font-size: 16px;
  }

  .clientes-mobile-list {
    margin-top: 14px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .clientes-grid-footer {
    position: sticky;
    bottom: 0;
    margin-top: 16px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    border-radius: 20px;
    padding: 14px;
    z-index: 20;
    box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.08);
  }

  .clientes-footer-info {
    text-align: center;
  }

  .clientes-grid-paginacao {
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
  }

  .clientes-grid-paginacao button {
    min-width: 42px;
    min-height: 42px;
    border-radius: 12px;
  }

  .clientes-ir-pagina {
    margin-top: 10px;
    justify-content: center;
  }

  .clientes-ir-pagina input {
    width: 80px;
    min-height: 42px;
    font-size: 16px;
  }

  .clientes-colunas-removidas {
    margin: 16px 0;
    border-radius: 20px;
    padding: 14px;
  }

}

@media (max-width: 768px) {

  html,
  body {
    height: auto !important;
    min-height: 100% !important;
    overflow-y: auto !important;
  }

  #app,
  .app-shell,
  .main,
  .content,
  #mainContent {
    height: auto !important;
    min-height: 100dvh !important;
    overflow-y: visible !important;
  }

  .clientes-page {
    padding: 14px !important;
    overflow: visible !important;
  }

  .clientes-header {
    padding: 22px !important;
    border-radius: 24px !important;
    margin-bottom: 14px !important;
  }

  .clientes-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .clientes-actions button {
    width: 100% !important;
    min-height: 50px !important;
    border-radius: 16px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
  }

  .clientes-metricas {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    margin: 12px 0 14px !important;
  }

  .cliente-metrica-card {
    min-height: 86px !important;
    padding: 14px !important;
    border-radius: 18px !important;
  }

  .clientes-grid-box {
    display: block !important;
    margin-top: 12px !important;
    padding: 14px !important;
    border-radius: 22px !important;
    overflow: visible !important;
  }

  .clientes-grid-toolbar {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }

  .clientes-grid-title {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .clientes-grid-filtros {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .clientes-grid-filtros input,
  .clientes-grid-filtros select {
    width: 100% !important;
    min-height: 48px !important;
    border-radius: 14px !important;
    font-size: 16px !important;
  }

  .clientes-mobile-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin-top: 14px !important;
  }

  .clientes-grid-footer {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin-top: 16px !important;
    padding: 14px !important;
    border-radius: 18px !important;
    background: #fff !important;
    border: 1px solid #dbeafe !important;
  }

  .clientes-grid-paginacao {
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .clientes-grid-paginacao button {
    min-width: 42px !important;
    min-height: 42px !important;
    border-radius: 12px !important;
  }

  .clientes-ir-pagina {
    display: flex !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .clientes-ir-pagina input {
    width: 80px !important;
    min-height: 42px !important;
    font-size: 16px !important;
  }

}

@media (max-width: 768px) {
  .clientes-page {
    padding: 12px !important;
  }

  .clientes-grid-box {
    overflow: hidden !important;
    padding: 12px !important;
    border-radius: 20px !important;
  }

  .clientes-table-area {
    width: 100% !important;
    overflow: hidden !important;
  }

  .clientes-table-scroll {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  .clientes-table {
    min-width: 900px !important;
  }

  .clientes-grid-footer {
    position: static !important;
    margin-top: 12px !important;
    border-radius: 18px !important;
  }

}

@media (max-width: 768px) {
  .clientes-table {
    min-width: 560px !important;
  }

  .clientes-table-scroll {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .clientes-acoes-sticky {
    position: sticky !important;
    right: 0 !important;
    background: #fff !important;
    z-index: 5 !important;
  }
}

/* =========================
   CLIENTES MOBILE DEFINITIVO
========================= */

@media (max-width: 768px) {

  html,
  body {
    width: 100% !important;
    height: 100% !important;
    overflow: hidden !important;
    overscroll-behavior-y: none !important;
  }

  #app,
  .app-shell {
    width: 100% !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    overflow: hidden !important;
  }

  .main,
  #mainContent {
    width: 100% !important;
    max-width: 100% !important;
    height: calc(100dvh - 104px) !important;
    min-height: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-y: contain !important;
    touch-action: pan-y !important;
    padding: 12px 12px 120px !important;
  }

  .clientes-mobile-screen {
    width: 100% !important;
    max-width: 100% !important;
    padding-bottom: 120px !important;
  }

  .clientes-mobile-actions-top {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-bottom: 12px !important;
  }

  .clientes-mobile-actions-top button {
    height: 42px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: #eef4ff !important;
    color: #1d4ed8 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
  }

  .clientes-mobile-metricas {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 16px !important;
  }

  .clientes-mobile-metricas div {
    background: #fff !important;
    border: 1px solid #dbe3f0 !important;
    border-radius: 16px !important;
    padding: 12px !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05) !important;
  }

  .clientes-mobile-metricas span {
    display: block !important;
    font-size: 11px !important;
    color: #64748b !important;
    margin-bottom: 5px !important;
  }

  .clientes-mobile-metricas strong {
    display: block !important;
    color: #12396d !important;
    font-size: 22px !important;
  }

  .clientes-mobile-consulta {
    width: 100% !important;
    background: #fff !important;
    border: 1px solid #dbe3f0 !important;
    border-radius: 22px !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
    padding: 14px !important;
    overflow: visible !important;
  }

  .clientes-mobile-consulta-head {
    text-align: center !important;
    margin-bottom: 12px !important;
  }

  .clientes-mobile-consulta-head strong {
    display: block !important;
    color: #0f172a !important;
    font-size: 16px !important;
    margin-bottom: 4px !important;
  }

  .clientes-mobile-consulta-head span {
    color: #64748b !important;
    font-size: 12px !important;
  }

  .clientes-mobile-filtros {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }

  .clientes-mobile-filtros input,
  .clientes-mobile-filtros select {
    width: 100% !important;
    height: 44px !important;
    border: 1px solid #dbe3f0 !important;
    border-radius: 14px !important;
    padding: 0 12px !important;
    font-size: 16px !important;
    background: #fff !important;
    color: #0f172a !important;
  }

  .clientes-mobile-lista {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    overflow: visible !important;
  }

  .cliente-mobile-item {
    width: 100% !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 16px !important;
    padding: 12px !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04) !important;
  }

  .cliente-mobile-item-top {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .cliente-mobile-avatar {
    width: 38px !important;
    height: 38px !important;
    border-radius: 12px !important;
    background: #eef4ff !important;
    color: #1d4ed8 !important;
    display: grid !important;
    place-items: center !important;
    font-weight: 800 !important;
    flex-shrink: 0 !important;
  }

  .cliente-mobile-main {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .cliente-mobile-main strong {
    display: block !important;
    color: #0f172a !important;
    font-size: 14px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .cliente-mobile-main span,
  .cliente-mobile-dados span {
    display: block !important;
    color: #64748b !important;
    font-size: 12px !important;
  }

  .cliente-mobile-dados {
    margin-top: 8px !important;
    display: grid !important;
    gap: 3px !important;
  }

  .cliente-mobile-botoes {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-top: 10px !important;
  }

  .cliente-mobile-botoes button {
    height: 34px !important;
    border-radius: 10px !important;
    border: 1px solid #dbe3f0 !important;
    background: #f8fafc !important;
    color: #1f2937 !important;
    font-size: 11px !important;
    font-weight: 800 !important;
  }

  .cliente-mobile-botoes button.danger {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #b91c1c !important;
  }

  .cliente-mobile-botoes button.ok {
    background: #ecfdf3 !important;
    border-color: #bbf7d0 !important;
    color: #15803d !important;
  }

  .clientes-mobile-paginacao {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    gap: 8px !important;
    align-items: center !important;
    margin-top: 12px !important;
  }

  .clientes-mobile-paginacao button {
    height: 36px !important;
    border-radius: 12px !important;
    border: 1px solid #dbe3f0 !important;
    background: #fff !important;
    color: #12396d !important;
    font-size: 12px !important;
    font-weight: 800 !important;
  }

  .clientes-mobile-paginacao button:disabled {
    opacity: 0.35 !important;
  }

  .clientes-mobile-paginacao strong {
    color: #12396d !important;
    font-size: 12px !important;
    white-space: nowrap !important;
  }

  .modal-overlay,
  #clientesModalOverlay,
  #importacaoClientesOverlay,
  .importacao-overlay {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    z-index: 999999 !important;
    overflow: hidden !important;
    background: #fff !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .cliente-modal,
  .importar-clientes-modal,
  .importacao-clientes-modal,
  .clientes-importar-modal {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 18px 16px 120px !important;
  }

  .cliente-modal-actions,
  .importacao-actions {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom)) !important;
    background: #fff !important;
    border-top: 1px solid #e2e8f0 !important;
    z-index: 1000000 !important;
  }

  .cliente-modal-actions button,
  .importacao-actions button {
    width: 100% !important;
    height: 48px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
  }

  .cliente-form-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .cliente-form-grid input,
  .cliente-form-grid textarea,
  .cliente-form-grid select {
    width: 100% !important;
    min-width: 0 !important;
    font-size: 16px !important;
    border-radius: 14px !important;
  }

  .importacao-upload-box {
    padding: 24px 14px !important;
    border-radius: 18px !important;
    text-align: center !important;
    background: #f8fbff !important;
  }

  .importacao-upload-box input[type="file"] {
    width: 100% !important;
    font-size: 14px !important;
  }
}

/* =========================
   AJUSTE FINAL MODAIS MOBILE
========================= */

@media (max-width: 768px) {

  /* MODAL CLIENTE E IMPORTAÇÃO */
  .cliente-modal,
  .importar-clientes-modal,
  .importacao-clientes-modal,
  .clientes-importar-modal {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 20px 18px 130px !important;
    border-radius: 0 !important;
    background: #fff !important;
  }

  /* CAMPOS PADRÃO DO CLIENTE */
  .cliente-form-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .cliente-form-grid input,
  .cliente-form-grid textarea {
    width: 100% !important;
    min-width: 0 !important;
    height: 48px !important;
    font-size: 16px !important;
    border-radius: 14px !important;
  }

  .cliente-form-grid textarea {
    height: 110px !important;
  }

  /* CAMPOS EXTRAS */
  .cliente-extra-form-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 12px !important;
    border-radius: 16px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
  }

  .cliente-extra-label {
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: unset !important;
    font-weight: 700 !important;
  }

  .cliente-extra-valor {
    width: 100% !important;
    min-width: 0 !important;
    height: 46px !important;
  }

  .cliente-extra-opcional {
    display: none !important;
  }

  /* IMPORTAR - ESCONDE INPUT FEIO */
  .importacao-upload-box input[type="file"] {
    opacity: 0 !important;
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    cursor: pointer !important;
  }

  .importacao-upload-box {
    position: relative !important;
    min-height: 170px !important;
    padding: 28px 18px !important;
    border-radius: 22px !important;
    border: 2px dashed #bfdbfe !important;
    background: #eff6ff !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    overflow: hidden !important;
  }

  .importacao-upload-box::after {
    content: "Toque aqui para escolher o arquivo" !important;
    display: block !important;
    margin-top: 12px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #2563eb !important;
  }

  /* BOTÕES FIXOS */
  .cliente-modal-actions,
  .importacao-actions {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    padding: 14px 18px calc(14px + env(safe-area-inset-bottom)) !important;
    background: #fff !important;
    border-top: 1px solid #e2e8f0 !important;
    z-index: 1000000 !important;
  }

  .cliente-modal-actions button,
  .importacao-actions button {
    width: 100% !important;
    min-width: 0 !important;
    height: 52px !important;
    border-radius: 16px !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    padding: 0 10px !important;
  }
}

@media (max-width: 768px) {
  .importacao-actions button {
    font-size: 12px !important;
    line-height: 1.1 !important;
    padding: 0 8px !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow: visible !important;
  }

  .importacao-actions button.btn-primary {
    font-size: 12px !important;
  }

  .importacao-actions {
    grid-template-columns: 0.9fr 1.1fr !important;
  }
}

@media (max-width: 768px) {

  .clientes-mobile-paginacao button:disabled {
    opacity: 0.5 !important;

    background: #eef4ff !important;

    cursor: wait !important;
  }

  .clientes-mobile-paginacao strong {
    min-width: 90px !important;

    text-align: center !important;
  }
}

/* =========================
   AUDITORIA MOBILE AJUSTE
========================= */

@media (max-width: 768px) {
  .auditoria-page-clean {
    height: auto !important;
    min-height: 100% !important;
    overflow: visible !important;
    padding: 12px !important;
    gap: 12px !important;
  }

  .auditoria-header-clean h3 {
    font-size: 20px !important;
  }

  .auditoria-header-clean p {
    font-size: 12px !important;
    line-height: 1.35 !important;
  }

  .auditoria-card-clean {
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  .auditoria-lista-clean {
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    padding: 10px !important;
    gap: 10px !important;
  }

  .auditoria-item-clean {
    display: grid !important;
    grid-template-columns: 72px 1fr !important;
    gap: 10px !important;
    padding: 12px !important;
    border-radius: 16px !important;
  }

  .auditoria-badge-clean {
    min-width: 0 !important;
    width: 72px !important;
    padding: 8px 6px !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
    text-align: center !important;
  }

  .auditoria-content-clean strong {
    font-size: 13px !important;
    line-height: 1.2 !important;
  }

  .auditoria-meta-clean {
    margin-top: 6px !important;
    display: grid !important;
    gap: 3px !important;
    font-size: 11px !important;
    line-height: 1.25 !important;
  }

  .auditoria-footer-clean {
    padding: 10px !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .auditoria-info-clean {
    text-align: center !important;
    font-size: 12px !important;
  }

  .auditoria-actions-clean {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  .auditoria-actions-clean .btn-secondary {
    min-width: 0 !important;
    width: 100% !important;
    height: 38px !important;
    margin: 0 !important;
    border-radius: 12px !important;
    font-size: 12px !important;
  }
}

/* =========================================================
   USUÁRIOS — PAGINAÇÃO + MOBILE AJUSTADO
========================================================= */

.usuarios-module-panel {
  overflow: visible;
}

.usuarios-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
}

.usuario-card {
  display: flex;
  flex-direction: column;
}

.usuarios-acoes {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.usuarios-acoes button {
  width: auto;
  min-width: 140px;
}

.btn-danger-soft {
  min-height: 48px;
  padding: 12px 16px;
  border-radius: 16px;
  border: 1px solid #fecaca;
  background: #fff1f2;
  color: #dc2626;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.18s ease;
}

.btn-danger-soft:hover {
  background: #ffe4e6;
}

.usuarios-pagination {
  margin-top: 22px;
  padding: 14px 16px;
  border: 1px solid #dbe5f1;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: #0f172a;
}

.usuarios-pagination-info,
.usuarios-pagination-single {
  font-size: 13px;
  font-weight: 700;
  color: #64748b;
}

.usuarios-pagination-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.usuarios-page-btn {
  min-height: 40px;
  padding: 0 16px;
  border: none;
  border-radius: 14px;
  background: #1d4ed8;
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.usuarios-page-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.usuarios-page-current {
  min-width: 64px;
  text-align: center;
  font-size: 13px;
  font-weight: 800;
  color: #12396d;
}

@media (max-width: 768px) {

  html,
  body {
    overflow-y: auto !important;
    height: auto !important;
  }

  .main {
    height: auto !important;
    min-height: calc(100dvh - 72px) !important;
    overflow: visible !important;
    padding: 20px 14px 120px !important;
  }

  .usuarios-module-panel {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .section-title {
    margin: 0 0 18px !important;
    font-size: 30px !important;
  }

  .usuarios-tabs-bar {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    margin-bottom: 22px !important;
  }

  .usuarios-tabs-bar .tab-btn {
    width: 100% !important;
    min-height: 50px !important;
    padding: 0 10px !important;
    border-radius: 14px !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    white-space: normal !important;
    text-align: center !important;
    line-height: 1.15 !important;
  }

  .usuarios-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }

  .usuario-card,
  .record-card {
    width: 100% !important;
    padding: 22px 18px !important;
    border-radius: 22px !important;
    overflow: visible !important;
    background: #ffffff !important;
    border: 1px solid #dbe5f1 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
  }

  .usuario-card h3,
  .record-card h3 {
    font-size: 22px !important;
    margin: 0 0 16px !important;
  }

  .usuario-card p,
  .record-card p {
    font-size: 16px !important;
    line-height: 1.45 !important;
    margin: 6px 0 !important;
  }

  .usuarios-acoes {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-top: 22px !important;
  }

  .usuarios-acoes button,
  .usuarios-acoes .btn-acao,
  .usuarios-acoes .btn-secondary,
  .usuarios-acoes .btn-danger-soft {
    width: 100% !important;
    min-height: 56px !important;
    margin: 0 !important;
    border-radius: 18px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
  }

  .usuarios-pagination {
    position: static !important;
    margin-top: 18px !important;
    margin-bottom: 0 !important;
    padding: 16px !important;
    border-radius: 22px !important;
    background: #ffffff !important;
    border: 1px solid #dbe5f1 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
  }

  .usuarios-pagination-info {
    text-align: center !important;
    font-size: 13px !important;
  }

  .usuarios-pagination-actions {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 64px 1fr !important;
    gap: 10px !important;
    align-items: center !important;
  }

  .usuarios-page-btn {
    width: 100% !important;
    min-height: 50px !important;
    padding: 0 10px !important;
    border-radius: 18px !important;
    font-size: 14px !important;
  }

  .usuarios-page-current {
    min-width: 64px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 15px !important;
  }

  #usuariosTabContent {
    overflow: visible !important;
    padding-bottom: 40px !important;
  }
}

/* =========================================================
   MÓDULOS OPERACIONAIS — PRODUTOS / FORNECEDORES / VENDAS
========================================================= */

.modulo-operacional-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: #0f172a;
}

.modulo-operacional-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.modulo-operacional-title {
  display: flex;
  align-items: center;
  gap: 14px;
}

.modulo-operacional-icon {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: #eef4ff;
  font-size: 24px;
}

.modulo-operacional-title h2 {
  margin: 0;
  font-size: 28px;
  color: #0f172a;
}

.modulo-operacional-title p {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 14px;
}

.modulo-operacional-primary {
  min-height: 48px;
  padding: 0 20px;
  border: none;
  border-radius: 16px;
  background: #1d4ed8;
  color: #ffffff;
  font-weight: 800;
  cursor: not-allowed;
  opacity: 0.55;
}

.modulo-operacional-metricas {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.modulo-operacional-metrica {
  padding: 18px;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.modulo-operacional-metrica span {
  display: block;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 8px;
}

.modulo-operacional-metrica strong {
  display: block;
  color: #12396d;
  font-size: 24px;
  font-weight: 900;
}

.modulo-operacional-toolbar {
  padding: 16px;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.modulo-operacional-search {
  margin: 0 !important;
}

.modulo-operacional-lista {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 16px;
}

.modulo-operacional-card {
  padding: 20px;
  border-radius: 22px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.modulo-operacional-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
}

.modulo-operacional-card-top h3 {
  margin: 0;
  color: #0f172a;
  font-size: 20px;
}

.modulo-operacional-card-top span {
  display: block;
  margin-top: 4px;
  color: #64748b;
  font-size: 13px;
}

.modulo-operacional-info {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.modulo-operacional-info div {
  padding: 12px;
  border-radius: 16px;
  background: #f8fbff;
  border: 1px solid #e5edf7;
  min-width: 0;
}

.modulo-operacional-info small {
  display: block;
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 5px;
}

.modulo-operacional-info strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
  word-break: break-word;
}

.modulo-operacional-obs {
  margin: 14px 0 0;
  padding: 12px;
  border-radius: 16px;
  background: #ffffbf;
  color: #334155;
  font-size: 13px;
  line-height: 1.45;
}

.modulo-operacional-pagination {
  padding: 16px 18px;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.modulo-operacional-pagination-info {
  color: #64748b;
  font-size: 13px;
  font-weight: 700;
}

.modulo-operacional-pagination-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.modulo-operacional-pagination-actions button {
  min-width: 120px;
  min-height: 44px;
  border: none;
  border-radius: 16px;
  background: #1d4ed8;
  color: #ffffff;
  font-weight: 800;
  cursor: pointer;
}

.modulo-operacional-pagination-actions button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.modulo-operacional-pagination-actions strong {
  min-width: 70px;
  text-align: center;
  color: #12396d;
}

/* =========================================================
   MOBILE — MÓDULOS OPERACIONAIS
========================================================= */

@media (max-width: 768px) {
  body.is-mobile .modulo-operacional-page {
    gap: 14px;
  }

  body.is-mobile .modulo-operacional-head {
    flex-direction: column;
    align-items: stretch;
    padding: 18px;
    border-radius: 22px;
  }

  body.is-mobile .modulo-operacional-title {
    align-items: flex-start;
  }

  body.is-mobile .modulo-operacional-icon {
    width: 46px;
    height: 46px;
    border-radius: 16px;
    font-size: 22px;
  }

  body.is-mobile .modulo-operacional-title h2 {
    font-size: 24px;
  }

  body.is-mobile .modulo-operacional-title p {
    font-size: 13px;
    line-height: 1.4;
  }

  body.is-mobile .modulo-operacional-primary {
    width: 100%;
    min-height: 50px;
  }

  body.is-mobile .modulo-operacional-metricas {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  body.is-mobile .modulo-operacional-metrica {
    padding: 16px;
    border-radius: 18px;
  }

  body.is-mobile .modulo-operacional-metrica strong {
    font-size: 22px;
  }

  body.is-mobile .modulo-operacional-toolbar {
    padding: 14px;
    border-radius: 18px;
  }

  body.is-mobile .modulo-operacional-lista {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  body.is-mobile .modulo-operacional-card {
    padding: 18px;
    border-radius: 22px;
  }

  body.is-mobile .modulo-operacional-card-top {
    flex-direction: column;
    align-items: flex-start;
  }

  body.is-mobile .modulo-operacional-card-top h3 {
    font-size: 21px;
  }

  body.is-mobile .modulo-operacional-info {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  body.is-mobile .modulo-operacional-info div {
    padding: 11px;
    border-radius: 14px;
  }

  body.is-mobile .modulo-operacional-pagination {
    position: static !important;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 16px;
    border-radius: 22px;
  }

  body.is-mobile .modulo-operacional-pagination-info {
    text-align: center;
  }

  body.is-mobile .modulo-operacional-pagination-actions {
    display: grid;
    grid-template-columns: 1fr 64px 1fr;
    gap: 10px;
    width: 100%;
  }

  body.is-mobile .modulo-operacional-pagination-actions button {
    width: 100%;
    min-width: 0;
    min-height: 50px;
  }

  body.is-mobile .modulo-operacional-pagination-actions strong {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 64px;
  }
}

/* =========================================================
   SOLICITAÇÕES — SOLICITAR ACESSO / MINHAS SOLICITAÇÕES
========================================================= */

.acesso-page {
  color: #0f172a;
}

.acesso-page .module-panel {
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

.acesso-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}

.acesso-card {
  background: #ffffff;
  border: 1px solid #dbe5f1;
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.acesso-card h3 {
  margin: 0 0 10px;
  font-size: 20px;
  color: #0f172a;
}

.acesso-card p {
  margin: 0 0 14px;
  color: #64748b;
  line-height: 1.45;
}

.acesso-card textarea {
  width: 100%;
  min-height: 92px;
  border: 1px solid #dbe5f1;
  border-radius: 16px;
  padding: 12px;
  resize: vertical;
  outline: none;
  color: #0f172a;
}

.acesso-card .btn-acao {
  width: 100%;
  min-height: 48px;
  border-radius: 16px;
  margin-top: 12px;
}

.acesso-status {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
}

.acesso-status.liberado,
.acesso-status.aprovado {
  background: #dcfce7;
  color: #15803d;
}

.acesso-status.pendente {
  background: #fef3c7;
  color: #b45309;
}

.acesso-status.recusado {
  background: #fee2e2;
  color: #b91c1c;
}

.acesso-historico {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.acesso-solic-card {
  background: #ffffff;
  border: 1px solid #dbe5f1;
  border-left: 6px solid #94a3b8;
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.acesso-solic-card.aprovado {
  border-left-color: #22c55e;
}

.acesso-solic-card.recusado {
  border-left-color: #ef4444;
}

.acesso-solic-card.pendente {
  border-left-color: #f59e0b;
}

.acesso-solic-card h3 {
  margin: 0 0 12px;
  font-size: 18px;
  color: #0f172a;
}

.acesso-solic-meta {
  display: grid;
  gap: 6px;
  color: #64748b;
  font-size: 14px;
  line-height: 1.35;
}

.acesso-solic-meta strong {
  color: #334155;
}

@media (max-width: 768px) {

  body.is-mobile[data-tela="solicitar_acesso"] .main,
  body.is-mobile[data-tela="minhas_solicitacoes"] .main {
    height: auto !important;
    min-height: calc(100dvh - 72px) !important;
    overflow: visible !important;
    padding: 16px 14px 120px !important;
  }

  body.is-mobile[data-tela="solicitar_acesso"] .module-panel,
  body.is-mobile[data-tela="minhas_solicitacoes"] .module-panel {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  body.is-mobile[data-tela="solicitar_acesso"] .section-title,
  body.is-mobile[data-tela="minhas_solicitacoes"] .section-title {
    font-size: 34px !important;
    line-height: 1.08 !important;
    margin-bottom: 14px !important;
  }

  body.is-mobile[data-tela="solicitar_acesso"] .section-subtitle,
  body.is-mobile[data-tela="minhas_solicitacoes"] .section-subtitle {
    font-size: 18px !important;
    line-height: 1.45 !important;
    margin-bottom: 22px !important;
  }

  .acesso-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .acesso-card {
    border-radius: 24px !important;
    padding: 22px !important;
  }

  .acesso-card h3 {
    font-size: 24px !important;
  }

  .acesso-card p {
    font-size: 17px !important;
  }

  .acesso-card .btn-acao {
    min-height: 56px !important;
    border-radius: 18px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
  }

  .acesso-historico {
    gap: 14px !important;
    padding-bottom: 80px !important;
  }

  .acesso-solic-card {
    border-radius: 22px !important;
    padding: 20px 18px !important;
  }

  .acesso-solic-card h3 {
    font-size: 20px !important;
  }

  .acesso-solic-meta {
    font-size: 15px !important;
  }
}

/* =========================================================
   AJUSTE PC/MOBILE — SOLICITAR ACESSO
========================================================= */

.acesso-page-solicitar {
  height: calc(100vh - 140px) !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 22px !important;
}

.acesso-page-solicitar .acesso-head {
  flex-shrink: 0 !important;
  padding-bottom: 18px !important;
}

.acesso-page-solicitar .section-title {
  margin: 0 0 10px !important;
}

.acesso-page-solicitar .section-subtitle {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.acesso-page-solicitar .acesso-content {
  flex: 1 !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 6px !important;
}

.acesso-page-solicitar .acesso-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 360px)) !important;
  justify-content: start !important;
  gap: 18px !important;
  align-items: start !important;
  padding-bottom: 20px !important;
}

.acesso-page-solicitar .acesso-card {
  min-height: 175px !important;
  padding: 20px !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid #dbe5f1 !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
}

.acesso-card-top {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  margin-bottom: 14px !important;
}

.acesso-card-icon {
  width: 38px !important;
  height: 38px !important;
  flex-shrink: 0 !important;
  border-radius: 14px !important;
  background: #eef4ff !important;
  display: grid !important;
  place-items: center !important;
}

.acesso-card-text h3 {
  margin: 0 0 8px !important;
  font-size: 19px !important;
  color: #0f172a !important;
}

.acesso-card-text p {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}

.acesso-status {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: fit-content !important;
  min-height: 30px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}

.acesso-status.liberado,
.acesso-status.aprovado {
  background: #dcfce7 !important;
  color: #15803d !important;
}

.acesso-status.pendente {
  background: #fef3c7 !important;
  color: #b45309 !important;
}

.acesso-status.recusado {
  background: #fee2e2 !important;
  color: #b91c1c !important;
}

.acesso-status.disponivel {
  background: #eef4ff !important;
  color: #1d4ed8 !important;
}

.acesso-card-note {
  margin: 12px 0 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
}

.acesso-btn-solicitar {
  width: 100% !important;
  min-height: 46px !important;
  margin-top: 14px !important;
  border-radius: 16px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

@media (max-width: 768px) {
  body.is-mobile .acesso-page-solicitar {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  body.is-mobile .acesso-page-solicitar .acesso-head {
    padding-bottom: 18px !important;
  }

  body.is-mobile .acesso-page-solicitar .section-title {
    font-size: 32px !important;
    line-height: 1.08 !important;
    margin-bottom: 12px !important;
  }

  body.is-mobile .acesso-page-solicitar .section-subtitle {
    font-size: 17px !important;
    line-height: 1.45 !important;
  }

  body.is-mobile .acesso-page-solicitar .acesso-content {
    overflow: visible !important;
    padding-right: 0 !important;
  }

  body.is-mobile .acesso-page-solicitar .acesso-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  body.is-mobile .acesso-page-solicitar .acesso-card {
    min-height: auto !important;
    padding: 22px !important;
    border-radius: 24px !important;
  }

  body.is-mobile .acesso-card-text h3 {
    font-size: 24px !important;
  }

  body.is-mobile .acesso-card-text p {
    font-size: 17px !important;
  }
}

/* =========================================================
   MINHAS SOLICITAÇÕES — PAGINAÇÃO PC/MOBILE
========================================================= */

.minhas-solicitacoes-page {
  height: calc(100vh - 140px) !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 22px !important;
}

.minhas-solicitacoes-page .acesso-head {
  flex-shrink: 0 !important;
  padding-bottom: 18px !important;
}

.minhas-solicitacoes-page .section-title {
  margin: 0 0 10px !important;
}

.minhas-solicitacoes-page .section-subtitle {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.minhas-solicitacoes-content {
  flex: 1 !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-right: 6px !important;
}

.acesso-historico {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  padding-bottom: 12px !important;
}

.acesso-solic-card {
  min-height: 120px !important;
  padding: 18px 20px !important;
  border-radius: 20px !important;
  background: #ffffff !important;
  border: 1px solid #dbe5f1 !important;
  border-left: 6px solid #94a3b8 !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
}

.acesso-solic-card.aprovado {
  border-left-color: #22c55e !important;
}

.acesso-solic-card.recusado {
  border-left-color: #ef4444 !important;
}

.acesso-solic-card.pendente {
  border-left-color: #f59e0b !important;
}

.acesso-solic-top {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}

.acesso-solic-top h3 {
  margin: 0 0 8px !important;
  font-size: 19px !important;
  color: #0f172a !important;
}

.acesso-solic-meta {
  display: grid !important;
  gap: 6px !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.acesso-solic-meta div {
  display: flex !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
}

.acesso-solic-meta strong {
  color: #334155 !important;
}

.acesso-pagination {
  flex-shrink: 0 !important;
  margin-top: 16px !important;
  padding: 14px 16px !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  border: 1px solid #dbe5f1 !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

.acesso-pagination-info {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #64748b !important;
}

.acesso-pagination-actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.acesso-pagination-actions button {
  min-width: 120px !important;
  min-height: 42px !important;
  border: none !important;
  border-radius: 14px !important;
  background: #1d4ed8 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}

.acesso-pagination-actions button:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
}

.acesso-pagination-actions strong {
  min-width: 70px !important;
  text-align: center !important;
  color: #12396d !important;
}

@media (max-width: 768px) {
  body.is-mobile .minhas-solicitacoes-page {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  body.is-mobile .minhas-solicitacoes-page .acesso-head {
    padding-bottom: 18px !important;
  }

  body.is-mobile .minhas-solicitacoes-page .section-title {
    font-size: 32px !important;
    line-height: 1.08 !important;
    margin-bottom: 12px !important;
  }

  body.is-mobile .minhas-solicitacoes-page .section-subtitle {
    font-size: 17px !important;
    line-height: 1.45 !important;
  }

  body.is-mobile .minhas-solicitacoes-content {
    overflow: visible !important;
    padding-right: 0 !important;
  }

  body.is-mobile .acesso-solic-card {
    min-height: auto !important;
    padding: 20px 18px !important;
    border-radius: 22px !important;
  }

  body.is-mobile .acesso-solic-top h3 {
    font-size: 21px !important;
  }

  body.is-mobile .acesso-solic-meta {
    font-size: 15px !important;
  }

  body.is-mobile .acesso-pagination {
    position: static !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    margin-top: 16px !important;
    padding: 16px !important;
    border-radius: 22px !important;
  }

  body.is-mobile .acesso-pagination-info {
    text-align: center !important;
  }

  body.is-mobile .acesso-pagination-actions {
    display: grid !important;
    grid-template-columns: 1fr 64px 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }

  body.is-mobile .acesso-pagination-actions button {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 50px !important;
    border-radius: 18px !important;
  }

  body.is-mobile .acesso-pagination-actions strong {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 64px !important;
  }
}

/* =========================================================
   ESTADOS GLOBAIS — VAZIO / LOADING / ERRO
========================================================= */

.estado-box {
  width: 100%;
  min-height: 220px;
  padding: 34px 24px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  color: #0f172a;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
}

.estado-icone {
  width: 58px;
  height: 58px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: #eef4ff;
  font-size: 28px;
}

.estado-box h3 {
  margin: 0;
  font-size: 22px;
  color: #0f172a;
}

.estado-box p {
  max-width: 520px;
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.5;
}

.estado-btn {
  margin-top: 8px;
  min-height: 46px;
  min-width: 180px;
  border-radius: 16px;
}

.estado-erro {
  border-color: #fecaca;
  background: #fffafa;
}

.estado-erro .estado-icone {
  background: #fee2e2;
}

.estado-skeleton-list {
  width: 100%;
  display: grid;
  gap: 12px;
  margin-top: 8px;
}

.estado-skeleton-card {
  width: 100%;
  padding: 16px;
  border-radius: 18px;
  background: #f8fbff;
  border: 1px solid #e5edf7;
}

.estado-skeleton-card span,
.estado-skeleton-card strong,
.estado-skeleton-card small {
  display: block;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef2f7, #dbe4f0, #eef2f7);
  background-size: 200% 100%;
  animation: estadoSkeletonMove 1.1s infinite linear;
}

.estado-skeleton-card span {
  width: 28%;
  margin-bottom: 12px;
}

.estado-skeleton-card strong {
  width: 70%;
  margin-bottom: 10px;
}

.estado-skeleton-card small {
  width: 45%;
}

@keyframes estadoSkeletonMove {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

@media (max-width: 768px) {
  .estado-box {
    min-height: 200px;
    padding: 28px 18px;
    border-radius: 24px;
  }

  .estado-box h3 {
    font-size: 21px;
  }

  .estado-box p {
    font-size: 15px;
  }

  .estado-btn {
    width: 100%;
    min-height: 54px;
    font-size: 16px;
    font-weight: 800;
  }
}

.login-legal-links {
  margin-top: 16px;
  text-align: center;
  color: #64748b;
  font-size: 12px;
  line-height: 1.5;
}

.login-legal-links button {
  border: none;
  background: transparent;
  color: #1d4ed8;
  font-weight: 800;
  cursor: pointer;
  padding: 0 3px;
  text-decoration: underline;
}

.legal-card {
  width: min(760px, 100%) !important;
}

.legal-content {
  margin: 22px 0;
  max-height: 54vh;
  overflow-y: auto;
  padding-right: 8px;
  color: #334155;
  font-size: 14px;
  line-height: 1.65;
}

.legal-content p {
  margin: 0 0 14px;
}

.login-aceite-row {
  align-items: flex-start;
  gap: 8px;
  margin-top: 8px;
}

.login-aceite-row span {
  display: inline;
  color: #334155;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .04em;
}

.login-aceite-row button,
.login-legal-links button {
  border: 0;
  background: transparent;
  color: #1d4ed8;
  font-weight: 800;
  cursor: pointer;
  padding: 0;
  font-size: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.login-aceite-row button:hover,
.login-legal-links button:hover {
  color: #123bb3;
}

.login-legal-links {
  margin-top: 16px;
  text-align: center;
  color: #64748b;
  font-size: 12px;
  line-height: 1.6;
}

.login-legal-links span {
  margin-right: 3px;
}

.hidden {
  display: none !important;
}

#aceiteTermosWrap.hidden {
  display: none !important;
}

#aceiteTermosWrap:not(.hidden) {
  display: flex !important;
}

.topo-loja-wrap {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.topo-loja-linha {
  display: flex;
  align-items: center;
  gap: 8px;
}

.topo-plano-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
}

.topo-plano-badge.plano-ativo {
  background: rgba(16, 185, 129, 0.14);
  color: #047857;
  border: 1px solid rgba(16, 185, 129, 0.25);
}

.topo-plano-badge.plano-inativo {
  background: rgba(239, 68, 68, 0.12);
  color: #b91c1c;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.btn-upgrade-dashboard {
  margin-top: 12px;
  border: 0;
  border-radius: 999px;
  padding: 9px 14px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  color: #0f172a;
  background: linear-gradient(135deg, #facc15, #f59e0b);
  box-shadow: 0 10px 26px rgba(245, 158, 11, 0.22);
}

.btn-upgrade-dashboard:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.planos-page {
  position: relative;
}

.planos-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.plano-card {
  position: relative;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 22px;
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.12), transparent 34%),
    rgba(15, 23, 42, 0.82);
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.20);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 520px;
}

.plano-card.plano-destaque {
  border-color: rgba(250, 204, 21, 0.58);
  transform: translateY(-6px);
  box-shadow: 0 22px 60px rgba(250, 204, 21, 0.14);
}

.plano-card.plano-atual {
  border-color: rgba(34, 197, 94, 0.55);
}

.plano-badge-top,
.plano-badge-atual {
  width: fit-content;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.02em;
  margin-bottom: 12px;
}

.plano-badge-top {
  color: #111827;
  background: linear-gradient(135deg, #fde68a, #facc15);
}

.plano-badge-atual {
  color: #052e16;
  background: linear-gradient(135deg, #86efac, #22c55e);
}

.plano-head h3 {
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: #fff;
}

.plano-preco {
  font-size: 34px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 8px;
}

.plano-preco span {
  font-size: 13px;
  font-weight: 600;
  color: rgba(226, 232, 240, 0.72);
}

.plano-head p {
  margin: 0;
  color: rgba(226, 232, 240, 0.72);
  font-size: 13px;
  line-height: 1.5;
  min-height: 42px;
}

.plano-recursos {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin: 22px 0;
  flex: 1;
}

.plano-recurso {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  line-height: 1.35;
}

.plano-recurso span {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  flex-shrink: 0;
}

.plano-recurso.ok {
  color: rgba(255, 255, 255, 0.92);
}

.plano-recurso.ok span {
  color: #052e16;
  background: #22c55e;
}

.plano-recurso.off {
  color: rgba(226, 232, 240, 0.44);
}

.plano-recurso.off span {
  color: #450a0a;
  background: #f87171;
}

.btnSelecionarPlano {
  width: 100%;
  margin-top: auto;
}

.planos-info {
  margin-top: 18px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 16px;
  padding: 14px 16px;
  color: rgba(226, 232, 240, 0.76);
  background: rgba(15, 23, 42, 0.56);
  font-size: 13px;
}

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

  .plano-card {
    min-height: auto;
  }

  .plano-card.plano-destaque {
    transform: none;
  }
}

.btn-upgrade-dashboard {
  margin-top: 12px;
  border: 0;
  border-radius: 999px;
  padding: 9px 14px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  color: #0f172a;
  background: linear-gradient(135deg, #facc15, #f59e0b);
  box-shadow: 0 10px 26px rgba(245, 158, 11, 0.22);
}

.btn-upgrade-dashboard:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
}

.planos-page {
  position: relative;
}

.planos-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.plano-card {
  position: relative;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 22px;
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.12), transparent 34%),
    rgba(15, 23, 42, 0.82);
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.22);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 520px;
}

.plano-card.plano-destaque {
  border-color: rgba(250, 204, 21, 0.58);
  transform: translateY(-6px);
  box-shadow: 0 22px 60px rgba(250, 204, 21, 0.14);
}

.plano-card.plano-atual {
  border-color: rgba(34, 197, 94, 0.55);
}

.plano-badge-top,
.plano-badge-atual {
  width: fit-content;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
}

.plano-badge-top {
  color: #111827;
  background: linear-gradient(135deg, #fde68a, #facc15);
}

.plano-badge-atual {
  color: #052e16;
  background: linear-gradient(135deg, #86efac, #22c55e);
}

.plano-head h3 {
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: #fff;
}

.plano-preco {
  font-size: 34px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 8px;
}

.plano-preco span {
  font-size: 13px;
  font-weight: 600;
  color: rgba(226, 232, 240, 0.72);
}

.plano-head p {
  margin: 0;
  color: rgba(226, 232, 240, 0.72);
  font-size: 13px;
  line-height: 1.5;
  min-height: 42px;
}

.plano-recursos {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin: 22px 0;
  flex: 1;
}

.plano-recurso {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  line-height: 1.35;
}

.plano-recurso span {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  flex-shrink: 0;
}

.plano-recurso.ok {
  color: rgba(255, 255, 255, 0.92);
}

.plano-recurso.ok span {
  color: #052e16;
  background: #22c55e;
}

.plano-recurso.off {
  color: rgba(226, 232, 240, 0.44);
}

.plano-recurso.off span {
  color: #450a0a;
  background: #f87171;
}

.btnSelecionarPlano {
  width: 100%;
  margin-top: auto;
}

.planos-info {
  margin-top: 18px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 16px;
  padding: 14px 16px;
  color: rgba(226, 232, 240, 0.76);
  background: rgba(15, 23, 42, 0.56);
  font-size: 13px;
}

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

  .plano-card {
    min-height: auto;
  }

  .plano-card.plano-destaque {
    transform: none;
  }
}

.upgrade-modal-overlay {
  z-index: 999999;
  padding: 18px;
}

.upgrade-modal-card {
  position: relative;
  width: 560px;
  max-width: 100%;
  border-radius: 26px;
  padding: 28px;
  background:
    radial-gradient(circle at top right, rgba(250, 204, 21, 0.12), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d9e3f0;
  box-shadow: 0 30px 90px rgba(15, 23, 42, 0.28);
  color: #0f172a;
}

.upgrade-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 24px;
  line-height: 1;
}

.upgrade-modal-chip {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 12px;
  margin-bottom: 14px;
  background: rgba(250, 204, 21, 0.20);
  color: #92400e;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.upgrade-modal-card h2 {
  margin: 0 42px 10px 0;
  font-size: 26px;
  line-height: 1.15;
  color: #0f172a;
}

.upgrade-modal-desc {
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.5;
}

.upgrade-modal-price {
  margin: 20px 0;
  font-size: 38px;
  font-weight: 900;
  color: #12396d;
}

.upgrade-modal-price span {
  font-size: 14px;
  color: #64748b;
  font-weight: 700;
}

.upgrade-modal-box {
  border: 1px solid #d9e3f0;
  border-radius: 18px;
  padding: 16px;
  background: #ffffff;
}

.upgrade-modal-box strong {
  display: block;
  margin-bottom: 12px;
  color: #0f172a;
}

.upgrade-modal-lista {
  display: grid;
  gap: 8px;
}

.upgrade-modal-recurso {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  color: #334155;
}

.upgrade-modal-recurso span {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  flex-shrink: 0;
}

.upgrade-modal-recurso.ok span {
  color: #052e16;
  background: #22c55e;
}

.upgrade-modal-recurso.off {
  color: #94a3b8;
}

.upgrade-modal-recurso.off span {
  color: #450a0a;
  background: #f87171;
}

.upgrade-modal-alert {
  margin-top: 14px;
  border-radius: 16px;
  padding: 12px 14px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #9a3412;
  font-size: 13px;
  line-height: 1.45;
}

.upgrade-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 18px;
}

.upgrade-modal-actions .btn-secondary,
.upgrade-modal-actions .btn-primary {
  margin-top: 0;
}

@media (max-width: 640px) {
  .upgrade-modal-card {
    padding: 22px;
    border-radius: 22px;
  }

  .upgrade-modal-actions {
    grid-template-columns: 1fr;
  }

  .upgrade-modal-card h2 {
    font-size: 22px;
  }
}

.perfil,
.topo .perfil {
  background: rgba(255, 255, 255, 0.14) !important;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  color: #ffffff !important;
}

.perfil-l1,
.perfil-l2,
.relogio {
  color: #ffffff !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
}

.perfil-l2 span,
.perfil-l2 strong {
  color: #ffffff !important;
}

.perfil .plano,
.perfil [class*="plano"] {
  color: #bbf7d0 !important;
  font-weight: 800 !important;
}

.lojas-admin-page {
  min-height: 100%;
}

.lojas-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.loja-admin-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #d9e3f0;
  border-radius: 20px;
  padding: 18px;
  box-shadow: var(--shadow-soft);
  color: var(--text);
}

.loja-admin-card.loja-admin-inativa {
  opacity: 0.65;
}

.loja-admin-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}

.loja-admin-nome {
  font-size: 17px;
  font-weight: 800;
  color: #12396d;
}

.loja-admin-codigo {
  margin-top: 4px;
  font-size: 11px;
  color: var(--muted);
}

.loja-admin-status {
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.loja-admin-status.ativo {
  color: #052e16;
  background: #bbf7d0;
}

.loja-admin-status.inativo {
  color: #7f1d1d;
  background: #fecaca;
}

.loja-admin-metas {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.loja-admin-metas div {
  border: 1px solid #e3eaf3;
  border-radius: 14px;
  padding: 10px;
  background: #ffffff;
}

.loja-admin-metas span {
  display: block;
  font-size: 10px;
  color: var(--muted);
  margin-bottom: 5px;
}

.loja-admin-metas strong {
  display: block;
  font-size: 13px;
  color: #12396d;
}

.loja-admin-actions {
  display: grid;
  grid-template-columns: 1fr 130px 100px;
  gap: 10px;
  align-items: center;
}

.loja-admin-select {
  width: 100%;
  min-height: 46px;
  border: 1px solid #d9e3f0;
  border-radius: 14px;
  padding: 0 12px;
  background: #ffffff;
  color: #0f172a;
  font-weight: 700;
  outline: none;
}

.btn-danger-soft {
  min-height: 48px;
  border: 1px solid #fecaca;
  border-radius: 16px;
  background: #fff5f5;
  color: #991b1b;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.18s ease;
}

.btn-danger-soft:hover {
  background: #ffe8e8;
  transform: translateY(-1px);
}

.btn-danger-soft:disabled,
.loja-admin-select:disabled,
.loja-admin-actions button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.form-label {
  display: block;
  margin: 12px 0 6px;
  font-size: 11px;
  font-weight: 800;
  color: #334155;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (max-width: 1100px) {
  .lojas-admin-grid {
    grid-template-columns: 1fr;
  }

  .loja-admin-actions {
    grid-template-columns: 1fr;
  }
}

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

  .loja-admin-top {
    flex-direction: column;
  }
}

.perfil {
  min-width: 280px !important;
  max-width: 360px !important;
  padding: 10px 14px !important;
  border-radius: 18px !important;
}

.perfil-l1 {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  margin-bottom: 6px !important;
}

.perfil-l2 {
  font-size: 11px !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 6px !important;
}

.topo-loja-linha {
  font-size: 11px !important;
  color: rgba(255, 255, 255, 0.92) !important;
  max-width: 280px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.topo-plano-badge {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  white-space: nowrap !important;
}

.topo-plano-badge.plano-ativo {
  color: #052e16 !important;
  background: linear-gradient(135deg, #bbf7d0, #22c55e) !important;
}

.topo-plano-badge.plano-inativo {
  color: #7f1d1d !important;
  background: linear-gradient(135deg, #fecaca, #f87171) !important;
}

.topo-dir {
  align-items: flex-end !important;
  justify-content: center !important;
  gap: 4px !important;
  max-width: 420px !important;
}

.perfil {
  min-width: 260px !important;
  max-width: 330px !important;
  padding: 8px 12px !important;
  border-radius: 18px !important;
  text-align: right !important;
  overflow: hidden !important;
}

.perfil-l1 {
  font-size: 11px !important;
  line-height: 1.2 !important;
  margin-bottom: 4px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.perfil-l2 {
  margin-top: 0 !important;
  font-size: 10px !important;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 4px !important;
}

.topo-loja-linha {
  max-width: 250px !important;
  font-size: 10px !important;
  line-height: 1.2 !important;
  color: rgba(255, 255, 255, 0.92) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.topo-loja-select {
  max-width: 160px !important;
  height: 22px !important;
  padding: 1px 6px !important;
  border-radius: 8px !important;
  font-size: 10px !important;
}

.topo-plano-badge {
  max-width: 250px !important;
  padding: 4px 9px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.relogio {
  font-size: 10px !important;
  line-height: 1.1 !important;
}

.topo-dir {
  position: relative !important;
  align-items: flex-end !important;
  gap: 4px !important;
}

.perfil {
  min-width: 270px !important;
  max-width: 340px !important;
  padding: 8px 12px 22px !important;
  position: relative !important;
}

.relogio {
  position: absolute !important;
  left: 14px !important;
  bottom: 7px !important;
  font-size: 10px !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

.perfil-l1 {
  font-size: 11px !important;
  line-height: 1.2 !important;
}

.perfil-l2 {
  font-size: 10px !important;
}

.topo-plano-badge {
  font-size: 10px !important;
  padding: 4px 8px !important;
}

.perfil {
  min-width: 270px !important;
  max-width: 340px !important;

  padding:
    10px 14px 28px !important;

  position: relative !important;

  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;

  gap: 6px !important;
}

.perfil-l1 {
  width: 100% !important;

  text-align: center !important;

  font-size: 12px !important;
  line-height: 1.2 !important;

  color: #fff !important;
  font-weight: 700 !important;
}

.perfil-l2 {
  width: 100% !important;

  display: flex !important;
  justify-content: center !important;
  align-items: center !important;

  text-align: center !important;

  font-size: 11px !important;
}

.topo-loja-wrap,
.topo-loja-wrap-super {
  width: 100% !important;

  display: flex !important;
  justify-content: center !important;
  align-items: center !important;

  gap: 8px !important;
}

.topo-loja-linha {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  gap: 6px !important;

  font-size: 11px !important;
  color: rgba(255, 255, 255, 0.92) !important;
}

.topo-loja-select {
  min-width: 120px !important;
}

.relogio {
  position: absolute !important;

  left: 50% !important;
  transform: translateX(-50%) !important;

  bottom: 7px !important;

  font-size: 10px !important;
  font-weight: 600 !important;

  color: rgba(255, 255, 255, 0.9) !important;

  text-align: center !important;
}

.perfil {
  min-width: 300px !important;
  max-width: 360px !important;
  padding: 10px 14px 26px !important;
  border-radius: 18px !important;
  position: relative !important;
  text-align: center !important;
}

.perfil-l1 {
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: #ffffff !important;
  text-align: center !important;
}

.perfil-l2 {
  margin-top: 5px !important;
  font-size: 11px !important;
  text-align: center !important;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
}

.topo-loja-linha {
  font-size: 11px !important;
  color: rgba(255, 255, 255, 0.92) !important;
  text-align: center !important;
}

.topo-loja-select {
  height: 24px !important;
  min-width: 120px !important;
  max-width: 160px !important;
  border-radius: 8px !important;
  padding: 2px 6px !important;
  font-size: 10px !important;
}

.topo-plano-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: fit-content !important;
  max-width: 280px !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

.relogio {
  position: absolute !important;
  left: 50% !important;
  bottom: 7px !important;
  transform: translateX(-50%) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  color: rgba(255, 255, 255, 0.9) !important;
  text-align: center !important;
}

/* ===== TOPO PERFIL COMPACTO ===== */

.topo-dir {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;

  min-width: 260px;
  max-width: 320px;

  padding: 10px 18px;
}

.perfil-topo-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;

  width: 100%;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.perfil-l1 {
  font-size: 15px;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.1;
  white-space: nowrap;
}

.perfil-l2 {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.1;
  white-space: nowrap;
}

.topo-loja-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.topo-loja-linha {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.1;
}

.topo-plano-badge,
.perfil-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-width: 190px;
  max-width: 230px;

  padding: 5px 12px;
  border-radius: 999px;

  background: #4ade80 !important;
  color: #052e16 !important;

  font-size: 11px;
  font-weight: 800;
  line-height: 1;

  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(34, 197, 94, 0.22);
}

.relogio {
  margin: 0;

  width: 100%;
  text-align: center;

  color: rgba(255, 255, 255, 0.9);

  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

/* remove qualquer bolinha/icone perdido no topo */
.topo-dir::before,
.perfil-topo-info::before,
.perfil::before {
  display: none !important;
  content: none !important;
}

.topo-dir {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 4px;
}

.perfil {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  text-align: right;
  min-width: unset;
}

.perfil-l1 {
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
  color: #ffffff;
}

.perfil-l2 {
  margin-top: 2px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.82);
}

.relogio {
  margin-top: 4px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 4px 10px;

  border-radius: 999px;

  background: #4ade80;

  color: #062814;

  font-size: 11px;
  font-weight: 800;

  box-shadow: 0 4px 12px rgba(74, 222, 128, 0.35);
}

.relogio {
  margin-top: 3px !important;

  display: block !important;

  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  color: rgba(255, 255, 255, 0.92) !important;

  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1 !important;

  text-align: center !important;
}

/* =========================================================
   ZYSTOCK — PATCH SEM VERDE / VISUAL SAAS AZUL
   Colocar no FINAL do style.css
========================================================= */

:root {
  --cor-botao: #2563eb !important;
  --cor-botao-hover: #1d4ed8 !important;
  --cor-ok: #2563eb !important;
}

/* Remove faixa verde do login */
.top-bar,
.auth-accent-line {
  background: linear-gradient(90deg,
      #4f46e5,
      #2563eb,
      #1d4ed8) !important;
}

/* Botões principais sem verde */
.btn-primary,
.auth-btn-primary,
.btn-acao,
.btn-upgrade-dashboard {
  background: linear-gradient(135deg,
      #4f46e5,
      #2563eb) !important;
  color: #ffffff !important;
  border: 1px solid rgba(79, 70, 229, 0.22) !important;
}

.btn-primary:hover,
.auth-btn-primary:hover,
.btn-acao:hover,
.btn-upgrade-dashboard:hover {
  background: linear-gradient(135deg,
      #4338ca,
      #1d4ed8) !important;
}

/* Remove verde dos status positivos */
.status-chip.ok,
.info-text,
.auth-info-text,
.ambiente .ok {
  background: rgba(37, 99, 235, 0.12) !important;
  color: #1d4ed8 !important;
}

/* Remove verde das bordas de listas/cards */
.item-lista {
  border-left-color: #2563eb !important;
}

/* Badge de plano ativo sem verde */
.topo-plano-badge.plano-ativo {
  background: rgba(37, 99, 235, 0.14) !important;
  color: #bfdbfe !important;
  border: 1px solid rgba(191, 219, 254, 0.35) !important;
}

/* Badge plano atual sem verde */
.plano-badge-atual {
  background: rgba(37, 99, 235, 0.14) !important;
  color: #1d4ed8 !important;
  border: 1px solid rgba(37, 99, 235, 0.25) !important;
}

/* Recursos positivos dos planos/modal sem verde */
.plano-recurso.ok span,
.upgrade-modal-recurso.ok span {
  background: #2563eb !important;
  color: #ffffff !important;
}

.plano-recurso.ok,
.upgrade-modal-recurso.ok {
  color: #1e293b !important;
}

/* Destaque do plano PRO sem verde */
.plano-destaque {
  border-color: #2563eb !important;
  box-shadow:
    0 18px 42px rgba(37, 99, 235, 0.16),
    0 8px 20px rgba(15, 23, 42, 0.08) !important;
}

.plano-badge-top {
  background: linear-gradient(135deg,
      #4f46e5,
      #2563eb) !important;
  color: #ffffff !important;
}

/* Remove qualquer bolinha/faixa verde no menu */
.menu-ind {
  background: #2563eb !important;
}

.menu-item.ativo .menu-ind {
  background: #ffffff !important;
}

/* Chat badge sem verde */
.chat-badge,
.msg-visto.ok,
.mini-chat-avatar {
  background: #2563eb !important;
  color: #ffffff !important;
}

/* ===== AJUSTE FINAL TOPO ===== */

.topo-dir {
  min-width: 310px !important;
  max-width: 340px !important;
  align-items: flex-end !important;
  justify-content: center !important;
  gap: 3px !important;
  padding-right: 18px !important;
}

.perfil {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  min-width: unset !important;
}

.perfil-l1,
.perfil-l2 {
  text-align: right !important;
}

.topo-plano-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  min-width: 230px !important;
  height: 22px !important;

  margin-top: 4px !important;
  padding: 0 14px !important;

  border-radius: 999px !important;
  background: #4ade80 !important;
  color: #052e16 !important;

  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1 !important;

  white-space: nowrap !important;
}

.relogio {
  display: block !important;
  width: 230px !important;

  margin-top: 4px !important;
  padding: 0 !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;

  color: rgba(255, 255, 255, 0.92) !important;

  text-align: center !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}

/* ===== MELHORA LEITURA DOS PLANOS ===== */

.plano-card,
.plan-card,
.card-plano {
  color: #ffffff !important;
}

.plano-card li,
.plan-card li,
.card-plano li,
.plano-card p,
.plan-card p,
.card-plano p {
  color: rgba(255, 255, 255, 0.88) !important;
  font-weight: 600 !important;
}

.plano-card .recurso-off,
.plan-card .recurso-off,
.card-plano .recurso-off,
.plano-recurso.off {
  color: rgba(255, 255, 255, 0.55) !important;
}

.plano-card strong,
.plan-card strong,
.card-plano strong {
  color: #ffffff !important;
}

/* =========================================================
   HOTFIX FINAL — TOPO + PLANOS
========================================================= */

/* TOPO */
.topo {
  height: 104px !important;
  padding: 16px 28px !important;
  align-items: center !important;
}

.topo-dir {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: center !important;
  gap: 5px !important;

  min-width: 280px !important;
  max-width: 360px !important;

  padding: 0 !important;
  margin: 0 !important;
}

.perfil,
.perfil-topo-info {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0 !important;
  width: auto !important;
  text-align: right !important;
}

.perfil-l1 {
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.perfil-l2,
.topo-loja-linha {
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 5px !important;

  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.topo-plano-badge,
.perfil-status {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: auto !important;
  min-width: 220px !important;
  max-width: 260px !important;
  height: 24px !important;

  padding: 0 14px !important;
  margin: 2px 0 0 !important;

  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.28) !important;

  background: rgba(74, 222, 128, 0.92) !important;
  color: #052e16 !important;

  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  white-space: nowrap !important;

  box-shadow: none !important;
}

.relogio {
  display: block !important;

  width: auto !important;
  min-width: 220px !important;

  margin: 0 !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  color: rgba(255, 255, 255, 0.92) !important;

  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  text-align: center !important;
}

/* PLANOS */
.planos-page,
.planos-container,
.planos-grid {
  color: #0f172a !important;
}

.plano-card,
.plan-card,
.card-plano {
  background: linear-gradient(180deg, #334155 0%, #1f2937 100%) !important;
  color: #ffffff !important;
  border: 1px solid rgba(148, 163, 184, 0.35) !important;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.16) !important;
}

.plano-card h2,
.plano-card h3,
.plano-card .plano-nome,
.plano-card .plano-preco,
.plan-card h2,
.plan-card h3,
.plan-card .plano-nome,
.plan-card .plano-preco,
.card-plano h2,
.card-plano h3,
.card-plano .plano-nome,
.card-plano .plano-preco {
  color: #ffffff !important;
}

.plano-card p,
.plan-card p,
.card-plano p,
.plano-card .plano-desc,
.plan-card .plano-desc,
.card-plano .plano-desc {
  color: rgba(255, 255, 255, 0.86) !important;
  font-weight: 600 !important;
}

.plano-card li,
.plan-card li,
.card-plano li,
.plano-recurso,
.plano-feature,
.plano-card .recurso,
.plan-card .recurso,
.card-plano .recurso {
  color: rgba(255, 255, 255, 0.90) !important;
  font-weight: 700 !important;
}

.plano-card .off,
.plan-card .off,
.card-plano .off,
.plano-recurso.off,
.plano-feature.off,
.recurso-off {
  color: rgba(255, 255, 255, 0.60) !important;
  font-weight: 600 !important;
}

.plano-card .off span,
.plan-card .off span,
.card-plano .off span {
  opacity: 1 !important;
}

.plano-card .btn-primary,
.plan-card .btn-primary,
.card-plano .btn-primary,
.plano-card button,
.plan-card button,
.card-plano button {
  color: #ffffff !important;
  font-weight: 800 !important;
}

.plano-card .btn-secondary,
.plan-card .btn-secondary,
.card-plano .btn-secondary {
  color: #1d4ed8 !important;
  background: #eef4ff !important;
  font-weight: 800 !important;
}

/* =========================================================
   TOPO
========================================================= */

.topo-plano-badge,
.perfil-status {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  min-width: 185px !important;
  height: 16px !important;

  padding: 0 10px !important;
  margin-top: 2px !important;

  border-radius: 999px !important;

  background: linear-gradient(90deg,
      #4ade80 0%,
      #34d399 100%) !important;

  border: none !important;
  box-shadow: none !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 800 !important;
}

.relogio {
  margin-top: -3px !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;

  color: rgba(255, 255, 255, 0.92) !important;

  font-size: 10px !important;
  font-weight: 700 !important;
}


/* =========================================================
   CARDS DOS PLANOS
========================================================= */

.plano-card,
.plan-card,
.card-plano {
  background:
    linear-gradient(180deg,
      #31463f 0%,
      #263740 100%) !important;

  border: 1px solid rgba(74, 222, 128, 0.14) !important;

  box-shadow:
    0 8px 22px rgba(15, 23, 42, 0.12) !important;

  transition: all 0.2s ease !important;
}

.plano-card:hover,
.plan-card:hover,
.card-plano:hover {
  transform: translateY(-2px);

  box-shadow:
    0 14px 28px rgba(15, 23, 42, 0.18) !important;
}


/* TITULOS */

.plano-card h2,
.plano-card h3,
.plan-card h2,
.plan-card h3,
.card-plano h2,
.card-plano h3 {
  color: #ffffff !important;
}


/* DESCRIÇÕES */

.plano-card p,
.plan-card p,
.card-plano p {
  color: rgba(255, 255, 255, 0.84) !important;
}


/* ITENS */

.plano-card li,
.plan-card li,
.card-plano li {
  color: rgba(255, 255, 255, 0.92) !important;
}


/* ITENS DESABILITADOS */

.plano-card .off,
.plan-card .off,
.card-plano .off,
.recurso-off {
  color: rgba(255, 255, 255, 0.52) !important;
}


/* BOTÕES */

.plano-card button,
.plan-card button,
.card-plano button {
  background: linear-gradient(90deg,
      #4f46e5 0%,
      #2563eb 100%) !important;

  border: none !important;

  color: #ffffff !important;

  font-weight: 800 !important;
}


/* BOTÃO PLANO ATUAL */

.plano-card .btn-secondary,
.plan-card .btn-secondary,
.card-plano .btn-secondary {
  background: #e5e7eb !important;
  color: #1d4ed8 !important;
}

/* =========================================================
   CORREÇÃO DEFINITIVA — TOPO E PLANOS
========================================================= */

/* tira qualquer verde/fundo do horário */
.relogio,
.topo-dir .relogio,
header .relogio {
  display: block !important;
  width: auto !important;
  min-width: 0 !important;

  margin: 2px 0 0 !important;
  padding: 0 !important;

  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;

  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  color: rgba(255, 255, 255, 0.9) !important;

  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  text-align: right !important;
}

/* deixa só o badge do plano fino */
.topo-plano-badge,
.perfil-status {
  height: 16px !important;
  min-width: 185px !important;
  padding: 0 10px !important;

  background: #4ade80 !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 999px !important;

  color: #052e16 !important;
  font-size: 10px !important;
  font-weight: 800 !important;
}

/* tira o cinza/preto pesado dos cards */
.plano-card,
.plan-card,
.card-plano {
  background: linear-gradient(180deg,
      #496f5a 0%,
      #3f604f 100%) !important;

  border: 1px solid rgba(74, 222, 128, 0.28) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10) !important;
}

/* melhora leitura */
.plano-card *,
.plan-card *,
.card-plano * {
  color: rgba(255, 255, 255, 0.92) !important;
}

.plano-card h2,
.plano-card h3,
.plan-card h2,
.plan-card h3,
.card-plano h2,
.card-plano h3,
.plano-card .plano-preco,
.plan-card .plano-preco,
.card-plano .plano-preco {
  color: #ffffff !important;
}

/* itens desativados continuam mais apagados, mas legíveis */
.plano-card .off,
.plan-card .off,
.card-plano .off,
.recurso-off {
  color: rgba(255, 255, 255, 0.62) !important;
}

/* botão atual claro */
.plano-card .btn-secondary,
.plan-card .btn-secondary,
.card-plano .btn-secondary {
  background: #eef4ff !important;
  color: #1d4ed8 !important;
}

/* botões de selecionar continuam azuis */
.plano-card button:not(.btn-secondary),
.plan-card button:not(.btn-secondary),
.card-plano button:not(.btn-secondary) {
  background: linear-gradient(90deg, #4f46e5, #2563eb) !important;
  color: #ffffff !important;
}

/* =========================================================
   HOTFIX FINAL — RELÓGIO SEM VERDE + CARDS MAIS FINOS
========================================================= */

/* remove definitivamente o verde do horário */
#relogio,
.relogio,
.topo-dir #relogio,
.topo-dir .relogio,
header #relogio,
header .relogio {
  display: block !important;

  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  height: auto !important;

  margin: 2px 0 0 0 !important;
  padding: 0 !important;

  background: none !important;
  background-color: transparent !important;
  background-image: none !important;

  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;

  color: rgba(255, 255, 255, 0.9) !important;

  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  text-align: right !important;
}

/* badge do plano fica verde e fino */
.topo-plano-badge,
.perfil-status {
  height: 15px !important;
  min-width: 180px !important;

  padding: 0 10px !important;

  background: #4ade80 !important;
  color: #052e16 !important;

  border: none !important;
  border-radius: 999px !important;
  box-shadow: none !important;

  font-size: 9.5px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

/* deixa os cards mais finos em largura */
.planos-grid,
.plans-grid,
.planos-cards {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(280px, 360px)) !important;
  justify-content: center !important;
  gap: 22px !important;
}

/* usa nos cards o mesmo verde do relógio antigo */
.plano-card,
.plan-card,
.card-plano {
  max-width: 360px !important;
  width: 100% !important;

  background: #4ade80 !important;

  border: 1px solid rgba(22, 101, 52, 0.18) !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.10) !important;
}

/* como o card agora é claro, texto precisa ficar escuro */
.plano-card *,
.plan-card *,
.card-plano * {
  color: #052e16 !important;
}

/* títulos e preço mais fortes */
.plano-card h2,
.plano-card h3,
.plan-card h2,
.plan-card h3,
.card-plano h2,
.card-plano h3,
.plano-card .plano-preco,
.plan-card .plano-preco,
.card-plano .plano-preco {
  color: #032713 !important;
}

/* itens desabilitados */
.plano-card .off,
.plan-card .off,
.card-plano .off,
.recurso-off {
  color: rgba(5, 46, 22, 0.58) !important;
}

/* botões continuam destacados */
.plano-card button:not(.btn-secondary),
.plan-card button:not(.btn-secondary),
.card-plano button:not(.btn-secondary) {
  background: linear-gradient(90deg, #4f46e5, #2563eb) !important;
  color: #ffffff !important;
}

/* botão plano atual */
.plano-card .btn-secondary,
.plan-card .btn-secondary,
.card-plano .btn-secondary {
  background: rgba(255, 255, 255, 0.88) !important;
  color: #1d4ed8 !important;
}

/* =========================================================
   TOPO — REMOVE VERDE DO HORÁRIO
========================================================= */

#relogio,
.relogio,
.topo-dir #relogio,
.topo-dir .relogio,
header #relogio,
header .relogio {
  display: block !important;

  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  height: auto !important;

  margin: 2px 0 0 0 !important;
  padding: 0 !important;

  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;

  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;

  color: rgba(255, 255, 255, 0.96) !important;

  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-align: right !important;
}


/* =========================================================
   ÁREA DO PERFIL — MAIS LIMPA
========================================================= */

.topo-dir {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.perfil {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;

  padding: 0 !important;
  margin: 0 !important;

  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.perfil-l1 {
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.perfil-l2 {
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}


/* =========================================================
   CARDS DOS PLANOS
========================================================= */

.planos-grid,
.planos-cards {
  display: flex !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}


/* =========================================================
   CARD BASE
========================================================= */

.plano-card,
.plan-card,
.card-plano {
  position: relative !important;

  width: 100% !important;
  max-width: 350px !important;
  min-height: 540px !important;

  padding: 22px !important;

  border-radius: 24px !important;

  background:
    linear-gradient(145deg,
      #3da966 0%,
      #327f52 100%) !important;

  border: 1px solid rgba(255, 255, 255, 0.08) !important;

  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;

  overflow: hidden !important;
}


/* =========================================================
   EFEITO SUAVE
========================================================= */

.plano-card::before,
.plan-card::before,
.card-plano::before {
  content: "";

  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle at top left,
      rgba(255, 255, 255, 0.06),
      transparent 40%);

  pointer-events: none;
}


/* =========================================================
   TEXTOS
========================================================= */

.plano-card *,
.plan-card *,
.card-plano * {
  color: #ffffff !important;
}

.plano-card h3,
.plan-card h3,
.card-plano h3 {
  font-size: 20px !important;
  font-weight: 900 !important;
  letter-spacing: 0.5px !important;
}

.plano-card .valor,
.plan-card .valor,
.card-plano .valor {
  font-size: 52px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}


/* =========================================================
   LISTA DE RECURSOS
========================================================= */

.plano-card ul,
.plan-card ul,
.card-plano ul {
  margin-top: 20px !important;
}

.plano-card li,
.plan-card li,
.card-plano li {
  margin-bottom: 10px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
}

.recurso-off {
  color: rgba(255, 255, 255, 0.70) !important;
}


/* =========================================================
   BOTÕES
========================================================= */

.plano-card button,
.plan-card button,
.card-plano button {
  margin-top: auto !important;

  height: 52px !important;

  border: 0 !important;
  border-radius: 16px !important;

  background:
    linear-gradient(90deg,
      #4d46ff,
      #2f6fff) !important;

  color: #ffffff !important;

  font-size: 15px !important;
  font-weight: 800 !important;

  box-shadow:
    0 8px 20px rgba(47, 111, 255, 0.28) !important;

  transition: 0.2s ease !important;
}

.plano-card button:hover,
.plan-card button:hover,
.card-plano button:hover {
  transform: translateY(-2px) !important;
}


/* =========================================================
   BADGES
========================================================= */

.plano-badge,
.badge-plano {
  display: inline-flex !important;
  align-items: center !important;

  padding: 6px 12px !important;

  border-radius: 999px !important;

  background: rgba(44, 99, 255, 0.92) !important;

  color: #ffffff !important;

  font-size: 11px !important;
  font-weight: 800 !important;

  letter-spacing: 0.4px !important;
}


/* =========================================================
   RESPONSIVO
========================================================= */

@media (max-width: 1200px) {

  .plano-card,
  .plan-card,
  .card-plano {
    max-width: 100% !important;
  }
}

#relogio,
.relogio,
.topo-dir #relogio,
.topo-dir .relogio {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  margin-top: 6px !important;
  padding: 4px 14px !important;

  background: #2f6fff !important;

  color: #ffffff !important;

  border-radius: 999px !important;
  border: 0 !important;

  box-shadow: none !important;
  text-shadow: none !important;

  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1 !important;

  text-align: center !important;
}

/* =========================================
   BLOCO PERFIL TOPO
========================================= */

.topo-dir {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;

  gap: 4px !important;

  text-align: center !important;
}


/* =========================================
   PERFIL
========================================= */

.perfil {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;

  gap: 3px !important;

  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.perfil-l1 {
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  text-align: center !important;
}

.perfil-l2 {
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-align: center !important;
}


/* =========================================
   BADGE PLANO
========================================= */

.badge-plano-topo,
.plano-topo,
.status-plano {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  padding: 5px 14px !important;

  border-radius: 999px !important;

  background: rgba(47, 111, 255, 0.22) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 700 !important;

  backdrop-filter: blur(8px) !important;
}


/* =========================================
   RELÓGIO
========================================= */

#relogio,
.relogio {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  padding: 4px 12px !important;

  border-radius: 999px !important;

  background: #2f6fff !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 700 !important;

  text-align: center !important;

  border: 0 !important;
  box-shadow: none !important;
}

.topo-plano-badge {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  padding: 2px 12px !important;
  border-radius: 999px !important;

  background: #2f6fff !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 800 !important;

  border: 0 !important;
  box-shadow: none !important;
}

#relogio,
.relogio {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;
  margin-top: 3px !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 700 !important;

  text-align: center !important;
}

#relogio,
.relogio {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;

  padding: 0 !important;

  margin-top: 8px !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 700 !important;

  text-align: center !important;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
}

.topo-plano-badge {
  background: #2f6fff !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 2px 12px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
}

#relogio,
.relogio {
  display: block !important;
  background: transparent !important;
  color: #fff !important;
  padding: 0 !important;
  margin-top: 4px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
}

/* ===== TOPO PERFIL ORGANIZADO ===== */

.topo-dir,
.perfil-topo-info,
.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  text-align: center !important;
}

.perfil-l1 {
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #ffffff !important;
  margin: 0 !important;
}

.topo-loja-linha {
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  color: #ffffff !important;
  margin: 0 !important;
}

.topo-plano-badge {
  order: 2 !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  min-width: 190px !important;
  height: 18px !important;

  padding: 0 12px !important;
  margin: 0 !important;

  background: #2f6fff !important;
  color: #ffffff !important;

  border: 0 !important;
  border-radius: 999px !important;
  box-shadow: none !important;

  font-size: 10px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

#relogio,
.relogio {
  order: 3 !important;

  display: block !important;

  margin: 0 !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;

  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.topo-dir {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 6px;
}

.perfil-topo-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.topo-loja-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.topo-loja-linha {
  font-size: 13px;
  font-weight: 600;
  color: #ffffff;
  text-align: center;
}

.topo-plano-badge {
  background: #1e4fc6;
  color: #ffffff;
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.relogio {
  background: #1e4fc6;
  color: #ffffff;
  border-radius: 999px;
  padding: 4px 14px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.topo-loja-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 5px !important;
}

#relogio,
.relogio {
  background: transparent !important;
  color: #ffffff !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-align: center !important;
}

.ok {
  color: #4ade80 !important;
  font-size: 12px;
  font-weight: 600;
}

.alerta {
  color: #facc15 !important;
  font-size: 12px;
  font-weight: 600;
}

.ambiente .ok {
  color: #4ade80;
  font-size: 12px;
  font-weight: 700;
  background: transparent !important;
}

.ambiente .alerta {
  color: #facc15;
  font-size: 12px;
  font-weight: 700;
  background: transparent !important;
}

.usuario-modal-scroll {
  max-height: 88vh;
  overflow-y: auto;
  padding-right: 6px;
}

.usuario-modal-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.usuario-modal-form label {
  font-size: 14px;
  font-weight: 600;
  color: #24324a;
  margin-bottom: 4px;
  display: block;
}

.usuario-modal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.usuario-modal-full {
  grid-column: 1 / -1;
}

.usuario-modal-permissoes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  padding: 14px;
  border: 1px solid #dfe7f5;
  border-radius: 18px;
  background: #f8fbff;
}

.usuario-modal-permissoes label {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-size: 14px;
  font-weight: 500;
}

.usuario-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid #e5ecf7;
}

.usuario-modal-footer .btn-secondary,
.usuario-modal-footer .btn-primary {
  min-width: 170px;
  height: 48px;
  border-radius: 14px;
}

@media (max-width: 768px) {
  .usuario-modal-grid {
    grid-template-columns: 1fr;
  }

  .usuario-modal-footer {
    flex-direction: column-reverse;
  }

  .usuario-modal-footer .btn-secondary,
  .usuario-modal-footer .btn-primary {
    width: 100%;
  }
}

.usuario-modal-scroll {
  max-height: 90vh;
  overflow-y: auto;
}

.usuario-modal-permissoes {
  margin-top: 14px;
  padding: 16px;
  border: 1px solid #dfe7f5;
  border-radius: 18px;
  background: #f8fbff;
}

.usuario-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 14px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid #e5ecf7;
}

.usuario-modal-footer .btn-primary,
.usuario-modal-footer .btn-secondary {
  min-width: 180px;
  height: 48px;
  border-radius: 14px;
}

.usuario-modal-footer .btn-primary {
  font-weight: 700;
}

@media (max-width: 768px) {
  .usuario-modal-footer {
    flex-direction: column-reverse;
  }

  .usuario-modal-footer .btn-primary,
  .usuario-modal-footer .btn-secondary {
    width: 100%;
  }
}

/* ===== AJUSTE FINAL - USUÁRIOS ===== */

.usuarios-grid {
  align-items: stretch;
}

.usuario-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.usuario-card h3 {
  margin-bottom: 6px;
}

.usuario-card p {
  margin: 0;
  line-height: 1.45;
}

.usuario-card .usuarios-acoes {
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.usuario-card .usuarios-acoes .btn-acao,
.usuario-card .usuarios-acoes .btn-secondary {
  width: 100%;
  height: 44px;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
}

.usuario-card .usuarios-acoes .btn-danger-soft {
  grid-column: 1 / -1;
  width: fit-content;
  min-width: 160px;
  height: 42px;
  margin-top: 4px;
  border-radius: 14px;
}

/* ===== MODAL EDITAR USUÁRIO ===== */

.usuario-modal-scroll {
  max-height: 88vh;
  overflow-y: auto;
  padding: 24px;
}

.usuario-modal-permissoes {
  display: block;
  margin-top: 16px;
  padding: 18px;
  border: 1px solid #dfe7f5;
  border-radius: 18px;
  background: #f8fbff;
}

.usuario-modal-permissoes>label {
  display: block;
  margin-bottom: 12px;
  font-weight: 700;
}

.usuario-modal-permissoes .usuarios-permissoes-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px, 1fr));
  gap: 10px 16px;
  margin-bottom: 18px;
}

.usuario-modal-permissoes .usuarios-permissao-item {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 14px;
}

.usuario-modal-permissoes .input-wrap {
  margin-top: 8px;
}

.usuario-modal-permissoes textarea {
  min-height: 96px;
  resize: vertical;
}

.usuario-modal-footer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid #e5ecf7;
}

.usuario-modal-footer .btn-primary,
.usuario-modal-footer .btn-secondary {
  width: 100%;
  height: 52px;
  border-radius: 16px;
  font-weight: 700;
}

@media (max-width: 768px) {
  .usuario-card .usuarios-acoes {
    grid-template-columns: 1fr;
  }

  .usuario-modal-scroll {
    max-height: 92vh;
    padding: 18px;
  }

  .usuario-modal-permissoes .usuarios-permissoes-grid {
    grid-template-columns: 1fr;
  }

  .usuario-modal-footer {
    grid-template-columns: 1fr;
  }
}

/* ===== AJUSTE FINAL BOTÕES USUÁRIOS ===== */

.usuario-card .usuarios-acoes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: center;
  margin-top: 18px;
}

.usuario-card .usuarios-acoes .btn-acao,
.usuario-card .usuarios-acoes .btn-secondary {
  height: 48px;
  width: 100%;
  margin: 0;
  border-radius: 14px;
}

.usuario-card .btn-danger-soft {
  margin-top: 14px;
  height: 46px;
  min-width: 170px;
  border-radius: 14px;
}

/* Modal editar usuário */
.usuario-modal-footer {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: center;
  padding-top: 24px;
  margin-top: 24px;
  border-top: 1px solid #e3eaf7;
}

.usuario-modal-footer .btn-secondary,
.usuario-modal-footer .btn-primary {
  width: 100% !important;
  height: 54px !important;
  margin: 0 !important;
  border-radius: 16px !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 768px) {

  .usuario-card .usuarios-acoes,
  .usuario-modal-footer {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {

  .usuario-card .acoes,
  .usuario-actions {
    flex-direction: column;
  }

  .usuario-card .acoes button,
  .usuario-actions button {
    width: 100%;
  }
}

.kiwify-page {
  padding: 20px;
}

.kiwify-cards {
  display: flex;
  gap: 16px;
  margin-bottom: 20px;
}

.card-metrica {
  background: var(--bg-card);
  border-radius: 12px;
  padding: 20px;
  min-width: 220px;
}

.card-metrica span {
  font-size: 28px;
  font-weight: 700;
  display: block;
}

.mono {
  font-family: monospace;
  font-size: 12px;
  word-break: break-all;
}

/* =========================
   AUDITORIA CLEAN - SAAS
   ========================= */

.auditoria-page-clean {
  padding: 28px;
  max-width: 100%;
}

.auditoria-header-clean {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 18px;
}

.auditoria-header-clean h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 850;
  color: #0f2344;
  letter-spacing: -0.03em;
}

.auditoria-header-clean p {
  margin: 6px 0 0;
  font-size: 14px;
  color: #64748b;
}

.auditoria-card-clean {
  background: #ffffff;
  border: 1px solid #dbe5f3;
  border-radius: 22px;
  box-shadow: 0 18px 45px rgba(15, 35, 68, 0.08);
  overflow: hidden;
}

.auditoria-lista-clean {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 245px);
  overflow-y: auto;
  padding: 16px;
  background: linear-gradient(180deg, #f8fbff 0%, #f4f7fb 100%);
}

.auditoria-lista-clean::-webkit-scrollbar {
  width: 10px;
}

.auditoria-lista-clean::-webkit-scrollbar-track {
  background: #eef3fa;
  border-radius: 999px;
}

.auditoria-lista-clean::-webkit-scrollbar-thumb {
  background: #b7c7dd;
  border-radius: 999px;
}

.auditoria-item-clean {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 16px;
  align-items: flex-start;
  padding: 16px 18px;
  background: #ffffff;
  border: 1px solid #e2eaf5;
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(15, 35, 68, 0.05);
  transition: 0.18s ease;
}

.auditoria-item-clean:hover {
  border-color: #3b82f6;
  box-shadow: 0 12px 28px rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}

.auditoria-badge-clean {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 9px 12px;
  border-radius: 999px;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
  line-height: 1.25;
  text-align: center;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.auditoria-content-clean {
  min-width: 0;
}

.auditoria-content-clean strong {
  display: block;
  max-width: 100%;
  color: #0f2344;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
  margin-bottom: 10px;
}

.auditoria-meta-clean {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.4;
}

.auditoria-meta-clean span {
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  background: #f8fafc;
  border: 1px solid #edf2f7;
  border-radius: 999px;
  white-space: nowrap;
}

.auditoria-footer-clean {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  background: #ffffff;
  border-top: 1px solid #e2eaf5;
}

.auditoria-info-clean {
  color: #334155;
  font-size: 13px;
  font-weight: 700;
}

.auditoria-actions-clean {
  display: flex;
  gap: 10px;
}

.auditoria-actions-clean .btn-secondary {
  border: 0;
  border-radius: 14px;
  padding: 12px 18px;
  background: #eef4ff;
  color: #2557d6;
  font-weight: 850;
  cursor: pointer;
  transition: 0.15s ease;
}

.auditoria-actions-clean .btn-secondary:hover:not(:disabled) {
  background: #dbeafe;
  transform: translateY(-1px);
}

.auditoria-actions-clean .btn-secondary:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.auditoria-empty-clean {
  padding: 42px 18px;
  text-align: center;
  color: #64748b;
  font-weight: 700;
}

.auditoria-skeleton-clean {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 16px;
  padding: 16px 18px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid #e2eaf5;
}

.auditoria-skeleton-clean span,
.auditoria-skeleton-clean strong,
.auditoria-skeleton-clean small {
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, #edf2f7, #f8fafc, #edf2f7);
  background-size: 200% 100%;
  animation: auditoriaSkeleton 1.2s infinite linear;
}

.auditoria-skeleton-clean span {
  width: 130px;
  height: 34px;
}

.auditoria-skeleton-clean strong {
  width: 85%;
  height: 16px;
  margin-bottom: 10px;
}

.auditoria-skeleton-clean small {
  width: 55%;
  height: 12px;
}

@keyframes auditoriaSkeleton {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

@media (max-width: 768px) {
  .auditoria-page-clean {
    padding: 16px;
  }

  .auditoria-header-clean h3 {
    font-size: 24px;
  }

  .auditoria-lista-clean {
    max-height: none;
    padding: 12px;
  }

  .auditoria-item-clean,
  .auditoria-skeleton-clean {
    grid-template-columns: 1fr;
  }

  .auditoria-badge-clean {
    width: fit-content;
    max-width: 100%;
  }

  .auditoria-meta-clean span {
    white-space: normal;
  }

  .auditoria-footer-clean {
    flex-direction: column;
    align-items: stretch;
  }

  .auditoria-actions-clean {
    width: 100%;
  }

  .auditoria-actions-clean .btn-secondary {
    flex: 1;
  }
}

/* =========================
   PENDÊNCIAS KIWIFY
   ========================= */

.kiwify-page {
  padding: 24px;
  background: #ffffff;
  border: 1px solid #dbe5f3;
  border-radius: 22px;
  box-shadow: 0 18px 45px rgba(15, 35, 68, 0.08);
}

.kiwify-page .section-title {
  margin: 0;
  font-size: 26px;
  font-weight: 850;
  color: #0f2344;
}

.kiwify-page p {
  color: #64748b;
}

.kiwify-cards {
  display: flex;
  gap: 14px;
  margin: 18px 0;
}

.kiwify-page .card-metrica {
  min-width: 230px;
  padding: 18px;
  background: #f8fbff;
  border: 1px solid #dbe5f3;
  border-radius: 18px;
}

.kiwify-page .card-metrica span {
  display: block;
  font-size: 34px;
  font-weight: 900;
  color: #0f2344;
}

.kiwify-page .card-metrica small {
  color: #64748b;
  font-weight: 700;
}

.kiwify-page .table-container {
  overflow-x: auto;
  border: 1px solid #dbe5f3;
  border-radius: 18px;
  background: #ffffff;
}

.kiwify-page table {
  width: 100%;
  border-collapse: collapse;
}

.kiwify-page th {
  padding: 14px;
  text-align: left;
  background: #f8fafc;
  color: #475569;
  font-size: 12px;
  text-transform: uppercase;
}

.kiwify-page td {
  padding: 14px;
  border-top: 1px solid #edf2f7;
  color: #0f2344;
  vertical-align: top;
}

.kiwify-page .mono {
  font-family: monospace;
  font-size: 12px;
  word-break: break-all;
}

.status-chip.warn {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff7ed;
  color: #c2410c;
  font-size: 12px;
  font-weight: 800;
}

.kiwify-page .btn-secondary {
  border: 0;
  border-radius: 14px;
  padding: 11px 16px;
  background: #eef4ff;
  color: #2557d6;
  font-weight: 850;
  cursor: pointer;
}

.kiwify-page .btn-secondary:hover {
  background: #dbeafe;
}

/* =========================
   AGENDA / RESERVAS
   ========================= */

.agenda-page {
  padding: 24px;
}

.agenda-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 20px;
}

.agenda-header h2 {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  color: #0f2344;
}

.agenda-header p {
  margin: 6px 0 0;
  color: #64748b;
  font-size: 14px;
}

.agenda-header-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.agenda-header-actions input[type="date"] {
  height: 42px;
  padding: 0 12px;
  border: 1px solid #dbe5f3;
  border-radius: 14px;
  background: #fff;
  color: #0f2344;
  font-weight: 700;
}

.agenda-cards {
  display: grid;
  grid-template-columns: repeat(6, minmax(130px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.agenda-card {
  min-height: 94px;
  padding: 18px;
  border: 1px solid #dbe5f3;
  border-radius: 20px;
  background: #ffffff;
  box-shadow: 0 14px 32px rgba(15, 35, 68, 0.07);
}

.agenda-card span {
  display: block;
  font-size: 24px;
  font-weight: 900;
  color: #0f2344;
}

.agenda-card small {
  display: block;
  margin-top: 8px;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.agenda-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(360px, 0.55fr);
  gap: 18px;
}

.agenda-main-card,
.agenda-side-card {
  background: #ffffff;
  border: 1px solid #dbe5f3;
  border-radius: 22px;
  box-shadow: 0 18px 45px rgba(15, 35, 68, 0.08);
  overflow: hidden;
}

.agenda-section-head {
  padding: 18px 20px;
  border-bottom: 1px solid #edf2f7;
  background: #fbfdff;
}

.agenda-section-head h3 {
  margin: 0;
  color: #0f2344;
  font-size: 18px;
  font-weight: 900;
}

.agenda-section-head p {
  margin: 5px 0 0;
  color: #64748b;
  font-size: 13px;
}

.agenda-movimento,
.agenda-lista-dia {
  padding: 16px;
}

.agenda-mov-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.agenda-mov-col {
  padding: 14px;
  border: 1px solid #edf2f7;
  border-radius: 18px;
  background: #f8fbff;
}

.agenda-mov-col h4 {
  margin: 0 0 12px;
  color: #0f2344;
  font-size: 14px;
  font-weight: 900;
}

.agenda-mini-item {
  padding: 12px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid #e2eaf5;
  margin-bottom: 10px;
}

.agenda-mini-item strong {
  display: block;
  color: #0f2344;
  font-size: 13px;
  font-weight: 900;
}

.agenda-mini-item span {
  display: block;
  margin-top: 4px;
  color: #475569;
  font-size: 12px;
}

.agenda-mini-item small {
  display: block;
  margin-top: 6px;
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
}

.agenda-mini-empty {
  padding: 18px 10px;
  border-radius: 14px;
  background: #ffffff;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 800;
  text-align: center;
}

.agenda-dia-item {
  display: grid;
  grid-template-columns: 68px 1fr;
  gap: 12px;
  padding: 14px;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: #ffffff;
  margin-bottom: 10px;
}

.agenda-dia-hora {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border-radius: 14px;
  background: #eef4ff;
  color: #2557d6;
  font-size: 13px;
  font-weight: 900;
}

.agenda-dia-info strong {
  display: block;
  color: #0f2344;
  font-size: 14px;
  font-weight: 900;
}

.agenda-dia-info span {
  display: block;
  margin-top: 4px;
  color: #475569;
  font-size: 12px;
}

.agenda-dia-info small {
  display: inline-flex;
  margin-top: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  background: #f1f5f9;
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.skeleton-card {
  background: linear-gradient(90deg, #edf2f7, #f8fafc, #edf2f7);
  background-size: 200% 100%;
  animation: agendaSkeleton 1.2s infinite linear;
}

@keyframes agendaSkeleton {
  from {
    background-position: 200% 0;
  }

  to {
    background-position: -200% 0;
  }
}

@media (max-width: 1100px) {
  .agenda-cards {
    grid-template-columns: repeat(3, 1fr);
  }

  .agenda-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .agenda-page {
    padding: 14px;
  }

  .agenda-header {
    flex-direction: column;
  }

  .agenda-header h2 {
    font-size: 24px;
  }

  .agenda-header-actions {
    width: 100%;
  }

  .agenda-header-actions input,
  .agenda-header-actions button {
    flex: 1;
  }

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

  .agenda-card {
    min-height: 84px;
    padding: 14px;
  }

  .agenda-card span {
    font-size: 20px;
  }

  .agenda-mov-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   MODAL AGENDA
   ========================= */

.agenda-modal-card {
  width: min(920px, calc(100vw - 28px));
  max-height: calc(100vh - 32px);
  overflow-y: auto;
}

.agenda-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.agenda-form label {
  display: flex;
  flex-direction: column;
  gap: 7px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
}

.agenda-form input,
.agenda-form select,
.agenda-form textarea {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid #dbe5f3;
  border-radius: 14px;
  background: #ffffff;
  color: #0f2344;
  font-size: 14px;
  font-weight: 700;
  outline: none;
}

.agenda-form textarea {
  resize: vertical;
  min-height: 86px;
}

.agenda-form input:focus,
.agenda-form select:focus,
.agenda-form textarea:focus {
  border-color: #3b82f6;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.form-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.form-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.agenda-hospedagem-box {
  padding: 16px;
  border: 1px solid #dbe5f3;
  border-radius: 18px;
  background: #f8fbff;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding-top: 8px;
}

@media (max-width: 768px) {
  .agenda-modal-card {
    width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
  }

  .form-grid-2,
  .form-grid-3 {
    grid-template-columns: 1fr;
  }

  .modal-actions {
    flex-direction: column-reverse;
  }

  .modal-actions button {
    width: 100%;
  }
}

/* =========================
   AGENDA - DETALHES EVENTO
   ========================= */

.agenda-detalhes {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.agenda-detail-row {
  padding: 14px;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: #f8fbff;
}

.agenda-detail-row strong {
  display: block;
  margin-bottom: 6px;
  color: #0f2344;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.agenda-detail-row span {
  display: block;
  color: #475569;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}

.agenda-detail-actions {
  flex-wrap: wrap;
}

.agenda-dia-item {
  cursor: pointer;
  transition: 0.16s ease;
}

.agenda-dia-item:hover {
  border-color: #3b82f6;
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}

/* =========================
   AGENDA - CALENDÁRIO MENSAL
   ========================= */

.agenda-cal-card {
  margin-bottom: 18px;
  background: #ffffff;
  border: 1px solid #dbe5f3;
  border-radius: 22px;
  box-shadow: 0 18px 45px rgba(15, 35, 68, 0.08);
  overflow: hidden;
}

.agenda-calendario-mes {
  padding: 16px;
}

.agenda-cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
  margin-bottom: 8px;
}

.agenda-cal-weekdays div {
  text-align: center;
  color: #64748b;
  font-size: 12px;
  font-weight: 900;
}

.agenda-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.agenda-cal-day {
  min-height: 112px;
  padding: 10px;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: #ffffff;
  text-align: left;
  cursor: pointer;
  transition: 0.16s ease;
}

.agenda-cal-day:hover {
  border-color: #3b82f6;
  box-shadow: 0 10px 26px rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}

.agenda-cal-day strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  border-radius: 999px;
  color: #0f2344;
  font-size: 13px;
  font-weight: 900;
}

.agenda-cal-day.fora {
  opacity: 0.45;
  background: #f8fafc;
}

.agenda-cal-day.hoje strong {
  background: #2563eb;
  color: #ffffff;
}

.agenda-cal-events {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 8px;
}

.agenda-cal-event {
  display: block;
  width: 100%;
  padding: 5px 7px;
  border-radius: 9px;
  color: #ffffff;
  font-size: 11px;
  font-weight: 850;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agenda-cal-events small {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
}

.agenda-cor-azul {
  background: #2563eb;
}

.agenda-cor-verde {
  background: #16a34a;
}

.agenda-cor-roxo {
  background: #7c3aed;
}

.agenda-cor-laranja {
  background: #ea580c;
}

.agenda-cor-amarelo {
  background: #ca8a04;
}

.agenda-cor-cinza {
  background: #64748b;
}

@media (max-width: 768px) {
  .agenda-calendario-mes {
    padding: 12px;
    overflow-x: auto;
  }

  .agenda-cal-weekdays,
  .agenda-cal-grid {
    min-width: 760px;
  }

  .agenda-cal-day {
    min-height: 96px;
  }
}

.agenda-cal-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.agenda-cal-nav {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .agenda-cal-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .agenda-cal-nav {
    width: 100%;
  }

  .agenda-cal-nav button {
    flex: 1;
  }
}

/* =========================
   AGENDA - IMPORTAÇÃO EXCEL
   ========================= */

.agenda-import-preview {
  margin-top: 6px;
  padding: 14px;
  border: 1px solid #dbe5f3;
  border-radius: 18px;
  background: #f8fbff;
}

.agenda-import-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 14px;
}

.agenda-import-info strong {
  color: #0f2344;
  font-size: 14px;
  font-weight: 900;
}

.agenda-import-info span {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.agenda-import-map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.agenda-import-map label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
}

.agenda-import-map select {
  min-height: 40px;
  padding: 9px 10px;
  border: 1px solid #dbe5f3;
  border-radius: 13px;
  background: #fff;
  color: #0f2344;
  font-size: 13px;
  font-weight: 750;
}

.agenda-import-table-wrap {
  width: 100%;
  overflow: auto;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: #fff;
}

.agenda-import-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.agenda-import-table th,
.agenda-import-table td {
  padding: 10px 12px;
  border-bottom: 1px solid #edf2f7;
  text-align: left;
  font-size: 12px;
  white-space: nowrap;
}

.agenda-import-table th {
  background: #f8fafc;
  color: #0f2344;
  font-weight: 900;
}

.agenda-import-table td {
  color: #475569;
  font-weight: 650;
}

@media (max-width: 768px) {
  .agenda-import-map {
    grid-template-columns: 1fr;
  }

  .agenda-import-preview {
    padding: 10px;
  }
}

.sidebar {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

.sidebar-content,
.menu-wrap,
#menuLista {
  min-height: 0;
}

#menuLista {
  flex: 1;
  overflow-y: auto;
  padding-right: 4px;
}

/* scrollbar bonita */

#menuLista::-webkit-scrollbar {
  width: 8px;
}

#menuLista::-webkit-scrollbar-thumb {
  background: rgba(37, 99, 235, 0.35);
  border-radius: 999px;
}

#menuLista::-webkit-scrollbar-track {
  background: transparent;
}

/* =========================
   USUÁRIOS - FIX BOTÕES
   ========================= */

.usuarios-page,
.usuarios-layout,
.usuarios-grid {
  min-height: 0;
}

.usuarios-table-wrap {
  width: 100%;
  overflow: auto;
  min-height: 0;
}

.usuarios-table {
  min-width: 1100px;
}

.usuarios-acoes {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  align-items: center;
}

.usuarios-acoes .btn-table,
.usuarios-acoes button {
  flex-shrink: 0;
}

.usuarios-card,
.usuarios-panel,
.module-panel {
  overflow: hidden;
}

.usuarios-table-area {
  overflow: auto;
  max-height: calc(100vh - 280px);
}

@media (max-width: 768px) {
  .usuarios-table {
    min-width: 980px;
  }

  .usuarios-table-area {
    max-height: unset;
  }
}

#menuLista {
  max-height: calc(100vh - 190px);
  overflow-y: auto;
  padding-right: 6px;
}

.usuarios-acoes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  align-items: stretch;
  margin-top: 18px;
}

.usuarios-acoes button {
  width: 100%;
  min-height: 46px;
  white-space: nowrap;
}

.usuarios-acoes .btn-danger-soft {
  grid-column: 1 / -1;
}

.senha-temp-box {
  display: inline-flex;
  max-width: 100%;
  padding: 4px 8px;
  border-radius: 8px;
  background: #eef4ff;
  color: #1d4ed8;
  font-weight: 800;
  word-break: break-all;
}

.senha-temp-vazia {
  color: #64748b;
  font-style: italic;
}

.usuarios-acoes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  align-items: stretch;
  margin-top: 18px;
}

.usuarios-acoes button {
  width: 100%;
  min-height: 46px;
  white-space: nowrap;
}

.usuarios-acoes .btn-danger-soft {
  grid-column: 1 / -1;
}

.senha-temp-box {
  display: inline-flex;
  max-width: 100%;
  padding: 4px 8px;
  border-radius: 8px;
  background: #eef4ff;
  color: #1d4ed8;
  font-weight: 800;
  word-break: break-all;
}

.senha-temp-vazia {
  color: #64748b;
  font-style: italic;
}

/* =========================================
   AGENDA PREMIUM UI
========================================= */

.agenda-premium {
  padding: 26px;
}

.agenda-premium-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 22px;
  margin-bottom: 22px;
}

.agenda-title-block h2 {
  margin: 0;
  font-size: 34px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: -0.04em;
  color: #0f172a;
}

.agenda-title-block p {
  margin: 10px 0 0;
  color: #64748b;
  font-size: 14px;
  font-weight: 600;
}

.agenda-kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  margin-bottom: 12px;
  background: rgba(37, 99, 235, 0.08);
  color: #2563eb;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.agenda-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.agenda-toolbar input[type="date"] {
  height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid #dbe5f3;
  background: #fff;
  color: #0f172a;
  font-weight: 800;
}

.agenda-icon-btn,
.agenda-today-btn,
.agenda-soft-btn,
.agenda-primary-btn {
  height: 46px;
  border: none;
  border-radius: 14px;
  padding: 0 18px;
  font-weight: 850;
  cursor: pointer;
  transition: 0.18s ease;
}

.agenda-icon-btn {
  min-width: 46px;
  background: #eef4ff;
  color: #2563eb;
  font-size: 20px;
}

.agenda-icon-btn:hover {
  background: #dbeafe;
}

.agenda-today-btn,
.agenda-soft-btn {
  background: #f8fafc;
  color: #2563eb;
  border: 1px solid #dbe5f3;
}

.agenda-today-btn:hover,
.agenda-soft-btn:hover {
  background: #eef4ff;
}

.agenda-primary-btn {
  background: linear-gradient(135deg,
      #4f46e5,
      #2563eb);

  color: #fff;
  min-width: 120px;

  box-shadow:
    0 14px 32px rgba(37, 99, 235, 0.28);
}

.agenda-primary-btn:hover {
  transform: translateY(-1px);
  box-shadow:
    0 18px 36px rgba(37, 99, 235, 0.36);
}

/* =========================
   MÉTRICAS
========================= */

.agenda-premium-metrics {
  display: grid;
  grid-template-columns: repeat(6, minmax(150px, 1fr));
  gap: 14px;
  margin-bottom: 22px;
}

.agenda-metric {
  padding: 18px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid #e2eaf5;

  box-shadow:
    0 14px 34px rgba(15, 23, 42, 0.05);
}

.agenda-metric strong {
  display: block;
  color: #0f172a;
  font-size: 28px;
  line-height: 1;
  font-weight: 950;
}

.agenda-metric span {
  display: block;
  margin-top: 10px;
  color: #64748b;
  font-size: 13px;
  font-weight: 700;
}

/* =========================
   SHELL
========================= */

.agenda-premium-shell {
  display: grid;
  grid-template-columns:
    minmax(0, 1.45fr) minmax(350px, 0.55fr);

  gap: 18px;
}

.agenda-calendar-panel,
.agenda-day-panel {
  background: #fff;
  border-radius: 26px;
  border: 1px solid #e2eaf5;

  overflow: hidden;

  box-shadow:
    0 18px 46px rgba(15, 23, 42, 0.06);
}

.agenda-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;

  padding: 20px 22px;

  border-bottom: 1px solid #edf2f7;

  background:
    linear-gradient(180deg,
      #ffffff,
      #fbfdff);
}

.agenda-panel-head.compact {
  padding-top: 16px;
}

.agenda-panel-head h3 {
  margin: 0;
  color: #0f172a;
  font-size: 19px;
  font-weight: 950;
}

.agenda-panel-head p {
  margin: 6px 0 0;
  color: #64748b;
  font-size: 13px;
  font-weight: 650;
}

/* =========================
   LEGENDA
========================= */

.agenda-legend {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.agenda-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;

  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.agenda-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.agenda-dot.verde {
  background: #16a34a;
}

.agenda-dot.azul {
  background: #2563eb;
}

.agenda-dot.roxo {
  background: #7c3aed;
}

.agenda-dot.amarelo {
  background: #ca8a04;
}

/* =========================
   CALENDÁRIO
========================= */

.agenda-calendar-premium {
  padding: 18px;
}

.agenda-cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;

  margin-bottom: 10px;
}

.agenda-cal-weekdays div {
  padding: 8px 0;
  text-align: center;

  color: #64748b;
  font-size: 12px;
  font-weight: 950;
}

.agenda-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.agenda-cal-day {
  min-height: 140px;

  padding: 10px;

  border-radius: 20px;
  border: 1px solid #e2eaf5;

  background: #fff;

  transition: 0.18s ease;

  cursor: pointer;
}

.agenda-cal-day:hover {
  transform: translateY(-1px);

  border-color: #2563eb;

  box-shadow:
    0 14px 28px rgba(37, 99, 235, 0.10);
}

.agenda-cal-day strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-width: 30px;
  height: 30px;

  border-radius: 999px;

  color: #0f172a;
  font-size: 13px;
  font-weight: 950;
}

.agenda-cal-day.hoje strong {
  background: #2563eb;
  color: #fff;
}

.agenda-cal-day.fora {
  background: #f8fafc;
  opacity: 0.45;
}

.agenda-cal-events {
  display: flex;
  flex-direction: column;
  gap: 6px;

  margin-top: 10px;
}

.agenda-cal-event {
  display: block;

  width: 100%;

  padding: 5px 8px;

  border-radius: 10px;

  color: #fff;
  font-size: 11px;
  font-weight: 850;

  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.agenda-cor-verde {
  background: #16a34a;
}

.agenda-cor-azul {
  background: #2563eb;
}

.agenda-cor-roxo {
  background: #7c3aed;
}

.agenda-cor-amarelo {
  background: #ca8a04;
}

.agenda-cor-laranja {
  background: #ea580c;
}

.agenda-cor-cinza {
  background: #64748b;
}

/* =========================
   LISTA DIA
========================= */

.agenda-lista-dia.premium,
.agenda-movimento.premium {
  padding: 18px;
}

.agenda-dia-item {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 12px;

  padding: 14px;

  border-radius: 18px;
  border: 1px solid #e2eaf5;

  background: #fff;

  margin-bottom: 12px;

  cursor: pointer;

  transition: 0.18s ease;
}

.agenda-dia-item:hover {
  transform: translateY(-1px);

  border-color: #2563eb;

  box-shadow:
    0 14px 24px rgba(37, 99, 235, 0.10);
}

.agenda-dia-hora {
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: 52px;

  border-radius: 14px;

  background: #eef4ff;

  color: #2563eb;

  font-size: 13px;
  font-weight: 950;
}

.agenda-dia-info strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.agenda-dia-info span {
  display: block;
  margin-top: 5px;

  color: #64748b;
  font-size: 12px;
  font-weight: 650;
}

/* =========================
   MOVIMENTO
========================= */

.agenda-mov-grid {
  display: grid;
  gap: 12px;
}

.agenda-mov-col {
  padding: 14px;
  border-radius: 18px;

  border: 1px solid #edf2f7;

  background:
    linear-gradient(180deg,
      #ffffff,
      #f8fbff);
}

.agenda-mov-col h4 {
  margin: 0 0 10px;

  color: #0f172a;
  font-size: 14px;
  font-weight: 950;
}

.agenda-mini-item {
  padding: 10px 12px;
  border-radius: 12px;

  background: #fff;
  border: 1px solid #e2eaf5;

  margin-bottom: 8px;

  font-size: 12px;
  color: #334155;
}

/* =========================
   RESPONSIVO
========================= */

@media (max-width: 1280px) {
  .agenda-premium-top {
    flex-direction: column;
  }

  .agenda-toolbar {
    width: 100%;
    justify-content: flex-start;
  }

  .agenda-premium-metrics {
    grid-template-columns: repeat(3, 1fr);
  }

  .agenda-premium-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .agenda-premium {
    padding: 14px;
  }

  .agenda-title-block h2 {
    font-size: 28px;
  }

  .agenda-toolbar {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .agenda-toolbar input[type="date"] {
    grid-column: 1 / -1;
  }

  .agenda-primary-btn {
    grid-column: 1 / -1;
  }

  .agenda-premium-metrics {
    grid-template-columns: repeat(2, 1fr);
  }

  .agenda-calendar-premium {
    overflow-x: auto;
  }

  .agenda-cal-weekdays,
  .agenda-cal-grid {
    min-width: 760px;
  }
}

/* =========================
   FIX USUÁRIOS - CARD/BOTÕES
   ========================= */

.usuarios-module-panel {
  min-height: calc(100vh - 130px);
  overflow: visible;
}

#usuariosTabContent {
  width: 100%;
  overflow: visible;
}

.usuarios-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 360px));
  gap: 18px;
  align-items: stretch;
  overflow: visible;
}

.usuario-card {
  min-height: 0;
  height: auto;
  overflow: visible !important;
  padding: 22px;
}

.usuario-card p {
  margin: 9px 0;
  line-height: 1.45;
}

.usuarios-acoes {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width: 100%;
  margin-top: 20px;
  align-items: stretch;
}

.usuarios-acoes button {
  width: 100% !important;
  min-width: 0 !important;
  height: 52px;
  padding: 0 14px;
  border-radius: 16px;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 900;
  box-sizing: border-box;
}

.usuarios-acoes .btn-danger-soft {
  grid-column: 1 / -1;
  width: 100% !important;
}

.senha-temp-box {
  display: inline-flex;
  max-width: 100%;
  padding: 4px 8px;
  border-radius: 8px;
  background: #eef4ff;
  color: #1d4ed8;
  font-weight: 900;
  word-break: break-all;
}

.senha-temp-vazia {
  color: #64748b;
  font-style: italic;
}

/* =========================
   FIX SCROLL GERAL DA ÁREA
   ========================= */

.app-shell {
  height: 100vh;
  overflow: hidden;
}

.main-content,
#mainContent {
  height: calc(100vh - 86px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: 80px;
}

/* =========================
   FIX AGENDA - SCROLL PAINEL
   ========================= */

.agenda-premium {
  min-height: calc(100vh - 86px);
  padding-bottom: 80px;
}

.agenda-premium-shell {
  align-items: start;
}

.agenda-calendar-panel {
  min-height: 0;
}

.agenda-day-panel {
  max-height: calc(100vh - 285px);
  overflow-y: auto;
}

.agenda-day-panel::-webkit-scrollbar,
#mainContent::-webkit-scrollbar {
  width: 8px;
}

.agenda-day-panel::-webkit-scrollbar-thumb,
#mainContent::-webkit-scrollbar-thumb {
  background: rgba(37, 99, 235, 0.35);
  border-radius: 999px;
}

.agenda-day-panel::-webkit-scrollbar-track,
#mainContent::-webkit-scrollbar-track {
  background: transparent;
}

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

  .usuarios-acoes {
    grid-template-columns: 1fr;
  }

  .usuarios-acoes .btn-danger-soft {
    grid-column: auto;
  }

  #mainContent {
    height: calc(100vh - 64px);
  }

  .agenda-day-panel {
    max-height: none;
    overflow: visible;
  }
}

/* =========================
   USUÁRIOS - BOTÕES FINAL
========================= */

.usuario-card {
  width: 340px;
  max-width: 340px;
  min-height: 0;
  height: auto;
  overflow: visible !important;
}

.usuarios-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 340px));
  gap: 18px;
  align-items: start;
}

.usuarios-acoes {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width: 100%;
  margin-top: 20px;
}

.usuarios-acoes button {
  width: 100% !important;
  height: 52px !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 0 12px !important;
  border-radius: 16px !important;
  white-space: nowrap !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  box-sizing: border-box !important;
}

.usuarios-acoes .btn-danger-soft {
  grid-column: 1 / -1;
}

@media (max-width: 768px) {
  .usuario-card {
    width: 100%;
    max-width: 100%;
  }

  .usuarios-grid {
    grid-template-columns: 1fr;
  }

  .usuarios-acoes {
    grid-template-columns: 1fr;
  }

  .usuarios-acoes .btn-danger-soft {
    grid-column: auto;
  }
}

/* =========================
   AGENDA - COMPACTA PREMIUM
========================= */

.agenda-premium {
  padding: 18px 22px 60px;
}

.agenda-premium-top {
  margin-bottom: 16px;
}

.agenda-title-block h2 {
  font-size: 28px;
}

.agenda-title-block p {
  margin-top: 6px;
  font-size: 13px;
}

.agenda-kicker {
  padding: 4px 9px;
  margin-bottom: 8px;
  font-size: 10px;
}

.agenda-toolbar input[type="date"],
.agenda-icon-btn,
.agenda-today-btn,
.agenda-soft-btn,
.agenda-primary-btn {
  height: 40px;
  border-radius: 12px;
  padding: 0 13px;
  font-size: 13px;
}

.agenda-icon-btn {
  min-width: 40px;
  font-size: 17px;
}

.agenda-primary-btn {
  min-width: 105px;
}

.agenda-premium-metrics {
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.agenda-metric {
  padding: 13px 15px;
  border-radius: 16px;
}

.agenda-metric strong {
  font-size: 22px;
}

.agenda-metric span {
  margin-top: 6px;
  font-size: 11px;
}

.agenda-premium-shell {
  grid-template-columns: minmax(0, 1.55fr) minmax(330px, 0.45fr);
  gap: 14px;
}

.agenda-calendar-panel,
.agenda-day-panel {
  border-radius: 20px;
}

.agenda-panel-head {
  padding: 14px 16px;
}

.agenda-panel-head h3 {
  font-size: 17px;
}

.agenda-panel-head p {
  margin-top: 4px;
  font-size: 12px;
}

.agenda-legend {
  gap: 10px;
}

.agenda-legend span {
  font-size: 11px;
}

.agenda-calendar-premium {
  padding: 12px;
}

.agenda-cal-weekdays {
  gap: 6px;
  margin-bottom: 6px;
}

.agenda-cal-weekdays div {
  padding: 5px 0;
  font-size: 11px;
}

.agenda-cal-grid {
  gap: 6px;
}

.agenda-cal-day {
  min-height: 92px;
  padding: 8px;
  border-radius: 14px;
}

.agenda-cal-day strong {
  min-width: 24px;
  height: 24px;
  font-size: 12px;
}

.agenda-cal-events {
  margin-top: 6px;
  gap: 4px;
}

.agenda-cal-event {
  padding: 4px 6px;
  border-radius: 8px;
  font-size: 10px;
}

.agenda-lista-dia.premium,
.agenda-movimento.premium {
  padding: 12px;
}

.agenda-day-panel {
  max-height: calc(100vh - 180px);
  overflow-y: auto;
}

.agenda-mov-grid {
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.agenda-mov-col {
  padding: 10px;
  border-radius: 14px;
}

.agenda-mov-col h4 {
  font-size: 12px;
  margin-bottom: 8px;
}

.agenda-mini-empty {
  padding: 14px 8px;
  font-size: 11px;
}

@media (max-width: 1280px) {
  .agenda-premium-metrics {
    grid-template-columns: repeat(3, 1fr);
  }

  .agenda-premium-shell {
    grid-template-columns: 1fr;
  }

  .agenda-day-panel {
    max-height: none;
  }
}

/* =========================
   LOJAS ADMIN - PREMIUM
========================= */

.lojas-admin-page {
  height: calc(100vh - 135px);
  overflow: hidden;
  padding: 18px;
}

.lojas-admin-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 14px;
}

.lojas-admin-subtitle {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
}

.lojas-admin-header-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.lojas-admin-header-actions .btn-primary,
.lojas-admin-header-actions .btn-secondary {
  width: auto;
  min-width: 150px;
  min-height: 40px;
  height: 40px;
  margin-top: 0;
  padding: 0 14px;
  border-radius: 13px;
  font-size: 12px;
  font-weight: 850;
}

.lojas-admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(390px, 1fr));
  gap: 12px;
  max-height: calc(100vh - 285px);
  overflow-y: auto;
  padding-right: 6px;
  padding-bottom: 10px;
}

.lojas-admin-grid::-webkit-scrollbar {
  width: 8px;
}

.lojas-admin-grid::-webkit-scrollbar-thumb {
  background: rgba(37, 99, 235, 0.28);
  border-radius: 999px;
}

.lojas-admin-grid::-webkit-scrollbar-track {
  background: transparent;
}

.loja-admin-card {
  padding: 14px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid #dbe5f1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
  transition: 0.18s ease;
}

.loja-admin-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}

.loja-admin-inativa {
  opacity: 0.68;
}

.loja-admin-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.loja-admin-nome {
  color: #0f172a;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.2;
}

.loja-admin-codigo {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 4px;
  color: #64748b;
  font-size: 11px;
  font-weight: 750;
}

.loja-master-badge {
  display: inline-flex;
  padding: 3px 7px;
  border-radius: 999px;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 10px;
  font-weight: 900;
}

.loja-admin-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 62px;
  height: 26px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.loja-admin-status.ativo {
  background: #dcfce7;
  color: #15803d;
}

.loja-admin-status.inativo {
  background: #fee2e2;
  color: #b91c1c;
}

.loja-admin-metas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
}

.loja-admin-metas>div {
  padding: 9px 10px;
  border-radius: 13px;
  background: #f8fbff;
  border: 1px solid #e2eaf5;
}

.loja-admin-metas span {
  display: block;
  color: #64748b;
  font-size: 10px;
  font-weight: 850;
  margin-bottom: 4px;
}

.loja-admin-metas strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
  font-weight: 950;
}

.loja-admin-actions {
  display: grid;
  grid-template-columns: minmax(130px, 1fr) 82px 82px;
  gap: 8px;
  margin-top: 12px;
  align-items: center;
}

.loja-admin-select,
.loja-admin-actions button {
  width: 100%;
  min-height: 38px !important;
  height: 38px !important;
  margin-top: 0 !important;
  padding: 0 10px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  font-weight: 850 !important;
  white-space: nowrap;
  box-sizing: border-box;
}

.loja-admin-select {
  border: 1px solid #dbe5f1;
  background: #fff;
  color: #0f172a;
}

.loja-admin-actions .btn-danger-soft:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.lojas-admin-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-top: 12px;
  margin-top: 10px;
  border-top: 1px solid #e2eaf5;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.lojas-admin-pagination {
  display: flex;
  align-items: center;
  gap: 10px;
}

.lojas-admin-pagination button {
  width: auto;
  min-width: 100px;
  height: 38px;
  min-height: 38px;
  margin-top: 0;
  border-radius: 12px;
  padding: 0 12px;
  font-size: 12px;
}

.lojas-admin-pagination strong {
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
}

@media (max-width: 1200px) {
  .lojas-admin-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .lojas-admin-page {
    height: auto;
    overflow: visible;
    padding: 12px;
  }

  .lojas-admin-header {
    flex-direction: column;
    align-items: stretch;
  }

  .lojas-admin-header-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .lojas-admin-header-actions .btn-primary,
  .lojas-admin-header-actions .btn-secondary {
    width: 100%;
  }

  .lojas-admin-grid {
    max-height: none;
    overflow: visible;
    grid-template-columns: 1fr;
  }

  .loja-admin-metas {
    grid-template-columns: 1fr;
  }

  .loja-admin-actions {
    grid-template-columns: 1fr;
  }

  .lojas-admin-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .lojas-admin-pagination {
    justify-content: space-between;
  }
}

/* =========================
   AGENDA / RESERVAS — PREMIUM COMPACTO
========================= */

.agenda-page,
.agenda-shell,
.agenda-container {
  padding: 22px 24px !important;
  border-radius: 22px !important;
  background: #ffffff !important;
}

.agenda-header,
.agenda-topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
}

.agenda-header h2,
.agenda-title {
  font-size: 22px !important;
  font-weight: 900 !important;
  margin: 0 0 6px !important;
  color: #07152f !important;
}

.agenda-header p,
.agenda-subtitle {
  font-size: 12px !important;
  color: #5d6b85 !important;
  margin: 0 !important;
}

.agenda-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.agenda-actions button,
.agenda-btn,
.agenda-page .btn-primary,
.agenda-page .btn-secondary {
  height: 38px !important;
  padding: 0 15px !important;
  border-radius: 13px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.agenda-resumo,
.agenda-cards {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.agenda-card,
.agenda-metrica {
  padding: 13px 14px !important;
  border: 1px solid #dbe6f6 !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, #ffffff, #f8fbff) !important;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.045) !important;
}

.agenda-card span,
.agenda-metrica span {
  font-size: 21px !important;
  font-weight: 900 !important;
  color: #07152f !important;
}

.agenda-card small,
.agenda-metrica small {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #65748d !important;
}

.agenda-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) 360px;
  gap: 16px;
  align-items: start;
}

.agenda-calendario-box,
.agenda-dia-box,
.agenda-movimento-box {
  border: 1px solid #dbe6f6 !important;
  border-radius: 18px !important;
  background: #fff !important;
  padding: 15px !important;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.045) !important;
}

.agenda-calendario-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.agenda-calendario-header h3 {
  font-size: 15px !important;
  font-weight: 900 !important;
  margin: 0 !important;
}

.agenda-calendario-header button {
  width: 34px !important;
  height: 34px !important;
  border-radius: 12px !important;
}

.agenda-calendar-grid,
.agenda-calendario-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 7px;
}

.agenda-weekday {
  font-size: 10px !important;
  font-weight: 900 !important;
  color: #71809a !important;
  text-align: center;
  padding: 6px 0;
}

.agenda-day {
  min-height: 72px !important;
  padding: 8px !important;
  border-radius: 14px !important;
  border: 1px solid #e1e9f6 !important;
  background: #f9fbff !important;
  transition: 0.18s ease;
}

.agenda-day:hover {
  background: #eef5ff !important;
  border-color: #bcd2f4 !important;
}

.agenda-day-num {
  font-size: 12px !important;
  font-weight: 900 !important;
  color: #0f1f3a !important;
}

.agenda-event-chip {
  margin-top: 5px !important;
  padding: 4px 6px !important;
  border-radius: 9px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  background: #eaf1ff !important;
  color: #1d4ed8 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.agenda-dia-box h3,
.agenda-movimento-box h3 {
  font-size: 15px !important;
  font-weight: 900 !important;
  margin: 0 0 10px !important;
}

.agenda-evento-item,
.agenda-list-item {
  padding: 11px 12px !important;
  border: 1px solid #e1e9f6 !important;
  border-radius: 14px !important;
  background: #f9fbff !important;
  margin-bottom: 8px !important;
}

.agenda-evento-item strong,
.agenda-list-item strong {
  font-size: 13px !important;
  font-weight: 900 !important;
}

.agenda-evento-item small,
.agenda-list-item small {
  font-size: 11px !important;
  color: #64748b !important;
}

.agenda-status,
.status-chip {
  padding: 5px 9px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  font-weight: 900 !important;
}

@media (max-width: 1100px) {

  .agenda-resumo,
  .agenda-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .agenda-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {

  .agenda-page,
  .agenda-shell,
  .agenda-container {
    padding: 16px !important;
  }

  .agenda-header,
  .agenda-topbar {
    flex-direction: column;
  }

  .agenda-actions {
    width: 100%;
    justify-content: stretch;
  }

  .agenda-actions button {
    flex: 1;
  }

  .agenda-day {
    min-height: 58px !important;
    padding: 6px !important;
  }
}

.modal-overlay {
  position: fixed !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 22px !important;
  background: rgba(15, 23, 42, .58) !important;
  backdrop-filter: blur(8px) !important;
  overflow: hidden !important;
}

.agenda-premium-modal {
  width: min(940px, 96vw) !important;
  max-height: 88vh !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 24px !important;
  background: #f8fbff !important;
  box-shadow: 0 30px 80px rgba(15, 23, 42, .32) !important;
  overflow: hidden !important;
}

.agenda-recurso-modal {
  width: min(760px, 96vw) !important;
}

.agenda-premium-head {
  flex: 0 0 auto !important;
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 22px 24px !important;
  background: linear-gradient(135deg, #12336d, #2454d8) !important;
  color: #fff !important;
}

.agenda-premium-head h3 {
  margin: 6px 0 4px !important;
  font-size: 22px !important;
  font-weight: 900 !important;
}

.agenda-premium-head p {
  margin: 0 !important;
  font-size: 13px !important;
  opacity: .88 !important;
}

.agenda-modal-chip {
  display: inline-flex !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .15) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.agenda-modal-x {
  width: 34px !important;
  height: 34px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, .16) !important;
  color: #fff !important;
  font-size: 22px !important;
  cursor: pointer !important;
}

.agenda-premium-body {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 18px 22px 20px !important;
}

.agenda-form-section {
  padding: 14px !important;
  margin-bottom: 12px !important;
  border: 1px solid #dbe6f6 !important;
  border-radius: 18px !important;
  background: #fff !important;
}

.agenda-form-section>strong,
.agenda-section-title-row strong {
  display: block !important;
  margin-bottom: 10px !important;
  color: #10213d !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.agenda-section-title-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.agenda-section-title-row small {
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: #eef4ff !important;
  color: #2454d8 !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.agenda-grid-2,
.agenda-grid-3,
.agenda-grid-4 {
  display: grid !important;
  gap: 10px !important;
}

.agenda-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.agenda-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.agenda-grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.agenda-premium-body label {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  color: #30435f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.agenda-premium-body input,
.agenda-premium-body select,
.agenda-premium-body textarea {
  width: 100% !important;
  min-height: 42px !important;
  padding: 0 13px !important;
  border: 1px solid #d7e3f4 !important;
  border-radius: 13px !important;
  background: #fbfdff !important;
  color: #0f1f3a !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  outline: none !important;
}

.agenda-premium-body textarea {
  min-height: 78px !important;
  padding-top: 12px !important;
  resize: vertical !important;
}

.agenda-premium-body input:focus,
.agenda-premium-body select:focus,
.agenda-premium-body textarea:focus {
  border-color: #2f63e7 !important;
  box-shadow: 0 0 0 3px rgba(47, 99, 231, .12) !important;
}

.agenda-hospedagem-premium {
  background: linear-gradient(180deg, #ffffff, #f5f8ff) !important;
}

.agenda-premium-actions {
  position: sticky !important;
  bottom: -20px !important;
  display: grid !important;
  grid-template-columns: 1fr 1.2fr !important;
  gap: 10px !important;
  padding: 14px 0 0 !important;
  background: linear-gradient(180deg, rgba(248, 251, 255, .72), #f8fbff 42%) !important;
}

.agenda-premium-actions button {
  height: 46px !important;
  border-radius: 14px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

@media (max-width: 900px) {

  .agenda-grid-4,
  .agenda-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .modal-overlay {
    padding: 10px !important;
    align-items: stretch !important;
  }

  .agenda-premium-modal {
    width: 100% !important;
    max-height: 96vh !important;
    border-radius: 20px !important;
  }

  .agenda-premium-head {
    padding: 18px !important;
  }

  .agenda-premium-body {
    padding: 14px !important;
  }

  .agenda-grid-2,
  .agenda-grid-3,
  .agenda-grid-4 {
    grid-template-columns: 1fr !important;
  }

  .agenda-premium-actions {
    grid-template-columns: 1fr !important;
  }
}

.agenda-help-text {
  display: block !important;
  margin: 6px 0 10px !important;
  color: #64748b !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}

.agenda-page {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
}

.agenda-premium-top {
  padding: 14px 18px;
  border-radius: 18px;
}

.agenda-title-block h2 {
  font-size: 26px;
}

.agenda-title-block p {
  font-size: 12px;
}

.agenda-toolbar {
  gap: 8px;
  flex-wrap: wrap;
}

.agenda-toolbar button,
.agenda-toolbar input {
  height: 40px;
}

.agenda-premium-shell {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: 1.4fr .8fr;
  gap: 12px;
}

.agenda-calendar-panel,
.agenda-day-panel {
  min-height: 0;
  overflow: hidden;
  border-radius: 20px;
}

.agenda-calendar-premium {
  height: 100%;
  overflow: auto;
  padding: 10px;
}

.agenda-lista-dia {
  max-height: 320px;
  overflow: auto;
}

.agenda-movimento {
  max-height: 220px;
  overflow: auto;
}

.agenda-premium-metrics {
  gap: 10px;
}

.agenda-metric {
  min-height: 82px;
  padding: 14px;
}

.agenda-panel-head {
  padding: 14px 16px;
}

.agenda-panel-head h3 {
  font-size: 16px;
}

.agenda-panel-head p {
  font-size: 11px;
}

.agenda-clientes-resultado {
  display: grid;
  gap: 6px;
  margin: 8px 0 10px;
}

.agenda-cliente-option {
  width: 100%;
  text-align: left;
  border: 1px solid #dbe6f6;
  background: #f8fbff;
  border-radius: 12px;
  padding: 9px 11px;
  cursor: pointer;
}

.agenda-cliente-option strong {
  display: block;
  font-size: 12px;
  color: #0f172a;
}

.agenda-cliente-option small,
.agenda-cliente-empty {
  font-size: 11px;
  color: #64748b;
}

.agenda-mini-btn {
  width: auto;
  min-height: 34px;
  padding: 7px 10px;
  border-radius: 10px;
  border: 1px solid #dbe6f6;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
  margin-bottom: 10px;
}

.agenda-premium-modal.compact {
  width: min(980px, 96vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.agenda-premium-head.slim {
  padding: 14px 18px;
}

.agenda-premium-head.slim h3 {
  font-size: 18px;
  margin: 4px 0;
}

.agenda-premium-head.slim p {
  font-size: 12px;
  margin: 0;
}

.agenda-premium-body.compact {
  padding: 14px 18px 0;
  overflow-y: auto;
  display: grid;
  gap: 10px;
}

.agenda-form-section.compact {
  padding: 12px;
  border-radius: 16px;
  gap: 8px;
}

.agenda-form-section.compact strong {
  font-size: 12px;
}

.agenda-form-section.compact label {
  font-size: 11px;
  gap: 5px;
}

.agenda-form-section.compact input,
.agenda-form-section.compact select,
.agenda-form-section.compact textarea {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 12px;
  border-radius: 10px;
}

.agenda-grid-3.compact,
.agenda-grid-4.compact {
  gap: 8px;
}

.agenda-grid-3.compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.agenda-grid-4.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.agenda-premium-actions.sticky {
  position: sticky;
  bottom: 0;
  background: #fff;
  padding: 10px 0 14px;
  margin-top: 4px;
  border-top: 1px solid #e5edf7;
}

.agenda-cliente-status {
  margin: -2px 0 6px;
  font-size: 11px;
}

.agenda-cliente-manual {
  color: #64748b;
}

.agenda-cliente-vinculado {
  color: #15803d;
  font-weight: 800;
}

.agenda-clientes-resultado {
  display: none;
  gap: 6px;
  margin-top: -4px;
}

.agenda-cliente-option {
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid #dbe6f6;
  background: #f8fbff;
  text-align: left;
  cursor: pointer;
}

.agenda-cliente-option strong {
  display: block;
  font-size: 12px;
  color: #0f172a;
}

.agenda-cliente-option small,
.agenda-cliente-empty {
  font-size: 11px;
  color: #64748b;
}

.agenda-mini-btn {
  width: auto;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #c7d7fe;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
}

@media (max-width: 900px) {

  .agenda-grid-3.compact,
  .agenda-grid-4.compact {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {

  .agenda-grid-3.compact,
  .agenda-grid-4.compact {
    grid-template-columns: 1fr;
  }
}

.agenda-dia-card {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
  border: 1px solid #e0e8f3;
  background: #fff;
  cursor: pointer;
  transition: 0.18s ease;
}

.agenda-dia-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.agenda-dia-hora-premium {
  font-size: 12px;
  font-weight: 800;
  color: #0f172a;
}

.agenda-dia-tipo {
  margin-top: 6px;
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
}

.agenda-dia-card-top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.agenda-dia-card-top strong {
  font-size: 12px;
  color: #0f172a;
}

.agenda-dia-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 5px;
  font-size: 10px;
  color: #64748b;
}

.agenda-status-badge {
  font-size: 9px;
  font-weight: 800;
  padding: 4px 7px;
  border-radius: 999px;
  background: #eef4ff;
}

.agenda-dia-payment {
  margin-top: 6px;
  font-size: 10px;
  font-weight: 700;
  color: #64748b;
}

.agenda-cal-grid.premium {
  gap: 8px;
}

.agenda-cal-day.premium {
  min-height: 96px;
  padding: 8px;
}

.agenda-cal-day.selecionado {
  outline: 2px solid #2563eb;
  outline-offset: -2px;
}

.agenda-cal-day-top {
  display: flex;
  justify-content: space-between;
  gap: 6px;
}

.agenda-cal-day-top strong {
  font-size: 12px;
}

.agenda-cal-day-top span {
  font-size: 9px;
  font-weight: 800;
  color: #2563eb;
}

.agenda-cal-receita {
  margin-top: 5px;
  font-size: 10px;
  font-weight: 800;
  color: #15803d;
}

/* =========================================================
   AGENDA — AJUSTE FINAL PREMIUM/COMPACTO
   colocar no FINAL do CSS
========================================================= */

.agenda-page.agenda-premium {
  height: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow: hidden;
}

.agenda-premium-top {
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, #ffffff, #f7faff);
  border: 1px solid #d9e3f0;
  box-shadow: var(--shadow-soft);
}

.agenda-title-block h2 {
  font-size: 22px;
  margin: 2px 0 4px;
}

.agenda-title-block p {
  font-size: 12px;
  margin: 0;
  color: #64748b;
}

.agenda-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.agenda-toolbar input[type="date"],
.agenda-toolbar button {
  height: 36px;
  min-height: 36px;
  width: auto;
  margin: 0;
  font-size: 12px;
  border-radius: 12px;
  white-space: nowrap;
}

.agenda-soft-btn,
.agenda-primary-btn,
.agenda-today-btn,
.agenda-icon-btn {
  padding: 0 12px;
}

.agenda-premium-metrics {
  gap: 8px;
  margin: 0;
}

.agenda-metric {
  padding: 10px 12px;
  border-radius: 14px;
  min-height: 74px;
}

.agenda-premium-shell {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 10px;
  overflow: hidden;
}

.agenda-calendar-panel,
.agenda-day-panel {
  min-height: 0;
  overflow: hidden;
  border-radius: 18px;
}

.agenda-calendar-panel {
  display: flex;
  flex-direction: column;
}

.agenda-day-panel {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.agenda-panel-head {
  padding: 12px 14px;
}

.agenda-panel-head h3 {
  font-size: 15px;
  margin: 0 0 2px;
}

.agenda-panel-head p {
  font-size: 11px;
  margin: 0;
}

.agenda-calendar-premium {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.agenda-cal-grid {
  height: 100%;
  min-height: 0;
}

.agenda-cal-day.premium {
  min-height: 82px;
  padding: 7px;
  border-radius: 14px;
}

.agenda-cal-event {
  font-size: 9px;
  padding: 3px 5px;
  border-radius: 7px;
}

.agenda-lista-dia.premium,
.agenda-movimento.premium {
  overflow-y: auto;
  min-height: 0;
  padding-right: 4px;
}

.agenda-lista-dia.premium {
  flex: 1;
}

.agenda-movimento.premium {
  max-height: 180px;
}

/* MODAIS */

.agenda-premium-modal.compact,
.agenda-recurso-modal.compact,
.agenda-import-modal {
  width: min(980px, 96vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.agenda-premium-head.slim {
  padding: 14px 18px;
}

.agenda-premium-head.slim h3 {
  font-size: 18px;
  margin: 3px 0;
}

.agenda-premium-head.slim p {
  font-size: 12px;
  margin: 0;
}

.agenda-premium-body.compact {
  padding: 14px 18px 0;
  overflow-y: auto;
  display: grid;
  gap: 10px;
}

.agenda-form-section.compact {
  padding: 12px;
  border-radius: 16px;
  gap: 8px;
}

.agenda-form-section.compact strong {
  font-size: 12px;
}

.agenda-form-section.compact label {
  font-size: 11px;
  gap: 5px;
}

.agenda-form-section.compact input,
.agenda-form-section.compact select,
.agenda-form-section.compact textarea {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 12px;
  border-radius: 10px;
}

.agenda-grid-2.compact,
.agenda-grid-3.compact,
.agenda-grid-4.compact {
  gap: 8px;
}

.agenda-grid-3.compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.agenda-grid-4.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.agenda-premium-actions.sticky {
  position: sticky;
  bottom: 0;
  background: #fff;
  padding: 10px 0 14px;
  margin-top: 4px;
  border-top: 1px solid #e5edf7;
}

.agenda-premium-actions.sticky .btn-primary,
.agenda-premium-actions.sticky .btn-secondary {
  min-height: 40px !important;
  padding: 10px 14px !important;
  border-radius: 12px !important;
  font-size: 12px !important;
}

/* CLIENTE */

.agenda-cliente-status {
  margin: -2px 0 6px;
  font-size: 11px;
}

.agenda-cliente-manual {
  color: #64748b;
}

.agenda-cliente-vinculado {
  color: #15803d;
  font-weight: 800;
}

.agenda-clientes-resultado {
  display: none;
  gap: 6px;
  margin-top: -4px;
}

.agenda-cliente-option {
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid #dbe6f6;
  background: #f8fbff;
  text-align: left;
  cursor: pointer;
}

.agenda-cliente-option strong {
  display: block;
  font-size: 12px;
  color: #0f172a;
}

.agenda-cliente-option small,
.agenda-cliente-empty {
  font-size: 11px;
  color: #64748b;
}

.agenda-mini-btn {
  width: auto;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid #c7d7fe;
  background: #eef4ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
}

/* RESPONSIVO */

@media (max-width: 1100px) {
  .agenda-premium-shell {
    grid-template-columns: 1fr;
    overflow-y: auto;
  }

  .agenda-day-panel {
    min-height: 420px;
  }
}

@media (max-width: 900px) {

  .agenda-grid-3.compact,
  .agenda-grid-4.compact {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {

  .agenda-grid-2.compact,
  .agenda-grid-3.compact,
  .agenda-grid-4.compact {
    grid-template-columns: 1fr;
  }

  .agenda-toolbar {
    align-items: stretch;
  }

  .agenda-toolbar button,
  .agenda-toolbar input[type="date"] {
    width: 100%;
  }
}

.login-lojas-more {
  padding: 10px 12px;
  text-align: center;
  font-size: 11px;
  font-weight: 800;
  color: #64748b;
  background: #f8fbff;
  border-top: 1px solid #e5edf7;
}

.planos-header-premium {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

#btnVoltarDashboardPlanos {
  width: auto !important;
  min-width: 150px;
  min-height: 38px !important;
  padding: 9px 14px !important;
  margin: 0 !important;
  border-radius: 12px !important;
  font-size: 12px !important;
  white-space: nowrap;
}

.planos-header-premium {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

#btnVoltarDashboardPlanos {
  width: auto !important;
  min-width: 150px !important;
  min-height: 38px !important;
  padding: 9px 14px !important;
  margin: 0 !important;
  border-radius: 12px !important;
  font-size: 12px !important;
  white-space: nowrap;
}