/* ============================================================
   Sistema de Compras — Digital.com  |  Redesign 2026
   Identidade visual: digitalnetmg.com.br
   © Afonso Junior — JR Solutions | jrsolutions.tec.br
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---------- Variáveis ---------------------------------------- */
:root {
  /* Verdes Digital.com */
  --cor-primaria:        #16824C;
  --cor-primaria-escura: #0d5c35;
  --cor-primaria-clara:  #4ade80;
  --cor-primaria-bg:     #EDF7F2;
  --cor-borda-verde:     #c3e6d3;

  /* Âmbar / acento */
  --cor-acento:          #F8BD3D;
  --cor-acento-hover:    #e5aa2a;

  /* Superfícies escuras (sidebar / header) */
  --dg-dark:             #1a2420;
  --dg-dark-2:           #1c2c24;
  --dg-dark-3:           #2b3d35;

  /* Superfícies claras */
  --cor-fundo:           #EDF7F2;
  --cor-superficie:      #ffffff;
  --cor-superficie-2:    #f6faf8;

  /* Bordas */
  --cor-borda:           #c3e6d3;
  --cor-borda-forte:     #a3d4bc;

  /* Texto */
  --cor-texto:           #1a2420;
  --cor-texto-suave:     #374a40;
  --cor-texto-fraco:     #6b7a72;

  /* Estado */
  --cor-sucesso:         #16a34a;
  --cor-sucesso-bg:      #dcfce7;
  --cor-aviso:           #d97706;
  --cor-aviso-bg:        #fef3c7;
  --cor-perigo:          #dc2626;
  --cor-perigo-bg:       #fee2e2;
  --cor-info:            #0369a1;
  --cor-info-bg:         #dbeafe;

  /* Sombras */
  --sombra-sm:           0 1px 3px rgba(22,130,76,.06), 0 1px 2px rgba(0,0,0,.04);
  --sombra:              0 2px 12px rgba(22,130,76,.10), 0 1px 4px rgba(0,0,0,.06);
  --sombra-md:           0 8px 32px rgba(22,130,76,.12), 0 2px 8px rgba(0,0,0,.08);

  /* Raios */
  --raio:                10px;
  --raio-pequeno:        6px;
  --raio-grande:         16px;

  /* Layout */
  --largura-sidebar:     252px;

  /* Fontes */
  --fonte-display:       'Inter', system-ui, sans-serif;
  --fonte-corpo:         'Inter', system-ui, sans-serif;
  --fonte-mono:          'JetBrains Mono', ui-monospace, Consolas, monospace;
}

/* ---------- Reset base --------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--fonte-corpo);
  background: var(--cor-fundo);
  color: var(--cor-texto);
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

h1, h2, h3, h4 {
  font-family: var(--fonte-display);
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--cor-texto);
  margin: 0 0 12px;
}
h1 { font-size: 1.5rem; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1rem; }

a {
  color: var(--cor-primaria);
  text-decoration: none;
  transition: color .15s;
}
a:hover { color: var(--cor-primaria-escura); text-decoration: underline; }

code, .mono { font-family: var(--fonte-mono); font-size: .92em; }

/* ============================================================
   LAYOUT GLOBAL
   ============================================================ */
.app {
  display: grid;
  grid-template-columns: var(--largura-sidebar) 1fr;
  min-height: 100vh;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar {
  background: linear-gradient(180deg, var(--dg-dark-2) 0%, var(--dg-dark) 100%);
  color: rgba(255,255,255,.75);
  padding: 0;
  position: fixed;
  width: var(--largura-sidebar);
  height: 100vh;
  overflow-y: auto;
  border-right: 3px solid var(--cor-primaria);
  display: flex;
  flex-direction: column;
}

.sidebar-header {
  padding: 22px 20px 16px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}

.logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: #fff;
}
.logo:hover { text-decoration: none; color: #fff; }

.logo-mark {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--cor-primaria-clara), var(--cor-primaria));
  display: grid;
  place-items: center;
  box-shadow: 0 4px 12px rgba(22,130,76,.35);
  flex-shrink: 0;
}
.logo-mark svg { width: 22px; height: 22px; color: #fff; }

.logo-texto {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  border-left: 1px solid rgba(255,255,255,.12);
  padding-left: 12px;
}
.logo-texto .logo-titulo {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  letter-spacing: .02em;
}
.logo-empresa {
  font-size: 10px;
  font-weight: 500;
  color: rgba(255,255,255,.42);
  letter-spacing: .07em;
  text-transform: uppercase;
  margin-top: 1px;
}

/* Menu */
.menu { list-style: none; padding: 14px 10px; margin: 0; flex: 1; }

.menu-grupo {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.28);
  padding: 14px 12px 5px;
  font-weight: 700;
}

.menu li a {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 12px;
  color: rgba(255,255,255,.68);
  border-radius: var(--raio-pequeno);
  font-size: 13px;
  font-weight: 500;
  transition: all .15s;
  text-decoration: none;
}
.menu li a svg { width: 17px; height: 17px; flex-shrink: 0; opacity: .75; }
.menu li a:hover {
  background: rgba(22,130,76,.15);
  color: #fff;
  text-decoration: none;
}
.menu li a:hover svg { opacity: 1; }
.menu li a.ativo {
  background: rgba(22,130,76,.22);
  color: #4ade80;
  box-shadow: inset 3px 0 0 var(--cor-primaria);
  font-weight: 600;
}
.menu li a.ativo svg { opacity: 1; color: #4ade80; }

/* Rodapé da sidebar */
.sidebar-rodape {
  padding: 14px 20px 18px;
  border-top: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.sidebar-rodape-marca {
  font-size: 11px;
  color: rgba(255,255,255,.5);
  line-height: 1.6;
  margin-bottom: 8px;
}
.sidebar-rodape-marca strong { color: rgba(255,255,255,.7); display: block; font-size: 12px; }
.sidebar-rodape-marca a {
  color: rgba(255,255,255,.45);
  text-decoration: none;
  transition: color .15s;
}
.sidebar-rodape-marca a:hover { color: var(--cor-primaria-clara); text-decoration: none; }
.sidebar-rodape-social {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
}
.sidebar-social-icone {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.38);
  transition: all .15s;
  text-decoration: none;
}
.sidebar-social-icone:hover {
  border-color: var(--cor-primaria);
  color: #4ade80;
  background: rgba(22,130,76,.15);
  text-decoration: none;
}
.sidebar-social-icone svg { width: 13px; height: 13px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
           overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ============================================================
   CONTEÚDO PRINCIPAL
   ============================================================ */
.principal {
  grid-column: 2;
  padding: 0;
  min-height: 100vh;
  min-width: 0;          /* permite que a coluna encolha; tabelas largas rolam no .tabela-wrap em vez de estourar/cortar */
  display: flex;
  flex-direction: column;
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  background: var(--cor-superficie);
  border-bottom: 2px solid var(--cor-borda-verde);
  padding: 13px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 2px 8px rgba(22,130,76,.06);
}
.topbar .titulo-pagina {
  font-family: var(--fonte-display);
  font-weight: 700;
  font-size: 1.1rem;
  margin: 0;
  color: var(--cor-texto);
}
.topbar-direita {
  display: flex; align-items: center; gap: 14px;
}

/* Dropdown usuário */
.usuario-dropdown { position: relative; }
.usuario-bloco {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer; padding: 6px 10px; border-radius: 8px;
  transition: background .15s;
  user-select: none;
  border: 1px solid transparent;
}
.usuario-bloco:hover {
  background: var(--cor-primaria-bg);
  border-color: var(--cor-borda-verde);
}
.usuario-bloco-seta {
  width: 14px; height: 14px; flex-shrink: 0;
  opacity: .45;
  transition: transform .2s;
}
.usuario-dropdown.aberto .usuario-bloco-seta { transform: rotate(180deg); }

.dropdown-menu {
  display: none;
  position: absolute; right: 0; top: calc(100% + 6px);
  min-width: 210px;
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda-verde);
  border-radius: var(--raio);
  box-shadow: var(--sombra-md);
  z-index: 999;
  overflow: hidden;
}
.usuario-dropdown.aberto .dropdown-menu { display: block; }

.dropdown-cabecalho {
  padding: 12px 16px 10px;
  border-bottom: 1px solid var(--cor-borda-verde);
  background: var(--cor-superficie-2);
}
.dropdown-cabecalho strong { display: block; font-size: 13.5px; color: var(--cor-texto); font-weight: 600; }
.dropdown-cabecalho span   { font-size: 12px; color: var(--cor-texto-fraco); }

.dropdown-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--cor-texto);
  text-decoration: none;
  transition: background .12s;
}
.dropdown-item:hover { background: var(--cor-primaria-bg); color: var(--cor-texto); text-decoration: none; }
.dropdown-item svg   { flex-shrink: 0; opacity: .6; }
.dropdown-item.perigo       { color: #dc2626; }
.dropdown-item.perigo:hover { background: #fee2e2; }
.dropdown-divisor { height: 1px; background: var(--cor-borda-verde); margin: 4px 0; }

.avatar {
  width: 30px; height: 30px;
  background: linear-gradient(135deg, var(--cor-primaria), var(--cor-primaria-escura));
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 700; font-size: 12px;
  flex-shrink: 0;
}
.usuario-info { font-size: 13px; line-height: 1.25; }
.usuario-info strong { display: block; font-weight: 600; color: var(--cor-texto); }
.usuario-info span   { color: var(--cor-texto-fraco); font-size: 11px; }

/* Badge perfil admin */
.badge-admin {
  background: var(--cor-acento);
  color: #1a1e23;
  font-size: 9px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 20px;
  letter-spacing: .08em;
  text-transform: uppercase;
  line-height: 1.6;
}

/* Botão menu mobile */
.btn-menu-mobile {
  display: none;
  width: 36px; height: 36px;
  background: transparent;
  border: 1px solid var(--cor-borda-verde);
  border-radius: 8px;
  cursor: pointer;
  align-items: center; justify-content: center;
}
.btn-menu-mobile svg { width: 22px; height: 22px; color: var(--cor-texto); }

.btn-icone-topbar {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: transparent;
  border: 1px solid var(--cor-borda-verde);
  color: var(--cor-texto-suave);
  cursor: pointer;
  display: grid; place-items: center;
  transition: all .15s;
}
.btn-icone-topbar:hover {
  background: var(--cor-primaria-bg);
  color: var(--cor-primaria);
}

/* ============================================================
   CONTEÚDO
   ============================================================ */
.conteudo {
  padding: 26px 28px;
  flex: 1;
  max-width: 1400px;
  width: 100%;
  min-width: 0;          /* idem: evita que conteúdo largo (tabelas) estique o layout */
}

/* ============================================================
   ALERTAS / FLASH
   ============================================================ */
.alerta {
  padding: 11px 16px;
  border-radius: var(--raio-pequeno);
  border: 1px solid transparent;
  margin-bottom: 18px;
  font-size: 13.5px;
  font-weight: 500;
  display: flex; align-items: flex-start; gap: 10px;
}
.alerta svg { width: 17px; height: 17px; flex-shrink: 0; margin-top: 1px; }
.alerta.sucesso { background: #e8f5ee; border-color: #b7dfc7; color: var(--cor-primaria-escura); }
.alerta.erro    { background: #fdf1f1; border-color: #f5c6c6; color: #b91c1c; }
.alerta.aviso   { background: #fef9ec; border-color: #f9d97e; color: #92610a; }
.alerta.info    { background: var(--cor-primaria-bg); border-color: var(--cor-borda-verde); color: var(--cor-primaria-escura); }

/* ============================================================
   CHANGELOG / ENTRADAS PERMANENTES
   ============================================================ */
.changelog-entrada { padding: 11px 16px; border-radius: var(--raio-pequeno); border: 1px solid transparent; margin-bottom: 18px; font-size: 13.5px; font-weight: 500; }
.changelog-entrada.sucesso { background: #e8f5ee; border-color: #b7dfc7; color: var(--cor-primaria-escura); }
.changelog-entrada.erro    { background: #fdf1f1; border-color: #f5c6c6; color: #b91c1c; }
.changelog-entrada.aviso   { background: #fef9ec; border-color: #f9d97e; color: #92610a; }
.changelog-entrada.info    { background: var(--cor-primaria-bg); border-color: var(--cor-borda-verde); color: var(--cor-primaria-escura); }
.changelog-entrada:not(.sucesso):not(.erro):not(.aviso):not(.info) { background: var(--cor-superficie-2, rgba(0,0,0,.03)); border-color: var(--cor-borda); color: var(--cor-texto); }

/* ============================================================
   SUB-MENU DA SIDEBAR
   ============================================================ */
.menu-item-pai { position: relative; }
.menu-sub { list-style: none; margin: 0 0 4px 0; padding: 0; }
.menu-sub li a { padding-left: 36px !important; font-size: 12.5px !important; padding-top: 7px !important; padding-bottom: 7px !important; opacity: .88; }
.menu-sub li a svg { width: 14px !important; height: 14px !important; }
.menu-sub li a:hover { opacity: 1; }
.menu-sub li a.ativo { opacity: 1; }

/* ============================================================
   CARTÕES
   ============================================================ */
.cartao {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda-verde);
  border-radius: var(--raio);
  padding: 0;
  margin-bottom: 20px;
  box-shadow: var(--sombra-sm);
  overflow: hidden;
  min-width: 0;          /* em grids/flex (ex.: Dashboard), o card encolhe e a tabela rola no .tabela-wrap */
}

.cartao-cabecalho {
  display: flex; justify-content: space-between; align-items: center;
  padding: 13px 20px;
  background: var(--cor-superficie-2);
  border-bottom: 1px solid var(--cor-borda-verde);
  gap: 12px;
}
.cartao-cabecalho h2 {
  margin: 0;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--cor-primaria);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.cartao-cabecalho h3 {
  margin: 0;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--cor-primaria);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.cartao > .cartao-cabecalho + * { padding: 20px; }
.cartao > *:not(.cartao-cabecalho):not(.tabela-wrap):not(.tabela) { padding: 20px; }
.cartao > .tabela-wrap, .cartao > .tabela { padding: 0; }

/* Cartão sem header */
.cartao.cartao-padded { padding: 22px; }

/* ============================================================
   ESTATÍSTICAS
   ============================================================ */
.grade-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.stat {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda-verde);
  border-radius: var(--raio);
  padding: 18px 18px 16px;
  position: relative;
  overflow: hidden;
  transition: transform .15s, box-shadow .15s;
  box-shadow: var(--sombra-sm);
}
.stat::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--cor-primaria);
}
.stat.amarelo::before  { background: var(--cor-acento); }
.stat.verde::before    { background: var(--cor-sucesso); }
.stat.vermelho::before { background: var(--cor-perigo); }
.stat.azul::before     { background: var(--cor-info); }
.stat.roxo::before     { background: #7c3aed; }
.stat:hover { transform: translateY(-2px); box-shadow: var(--sombra); }

.stat-rotulo {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--cor-texto-fraco);
  font-weight: 700;
  margin-bottom: 6px;
}
.stat-valor {
  font-family: var(--fonte-mono);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--cor-texto);
  line-height: 1;
}
.stat-extra {
  font-size: 11.5px;
  color: var(--cor-texto-fraco);
  margin-top: 6px;
}

/* ============================================================
   BOTÕES
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 20px;
  background: var(--cor-primaria);
  color: #fff;
  border: 1.5px solid var(--cor-primaria);
  border-radius: var(--raio-pequeno);
  font-family: var(--fonte-corpo);
  font-weight: 600;
  font-size: 13.5px;
  cursor: pointer;
  text-decoration: none;
  transition: all .15s;
  line-height: 1.2;
  white-space: nowrap;
  letter-spacing: .01em;
  box-shadow: 0 2px 8px rgba(22,130,76,.20);
}
.btn:active { transform: translateY(1px); }
.btn:hover {
  background: var(--cor-primaria-escura);
  border-color: var(--cor-primaria-escura);
  color: #fff;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(22,130,76,.30);
  transform: translateY(-1px);
}
.btn svg { width: 15px; height: 15px; }

.btn-primario {
  background: var(--cor-primaria);
  border-color: var(--cor-primaria);
  box-shadow: 0 2px 8px rgba(22,130,76,.25);
}
.btn-primario:hover {
  background: var(--cor-primaria-escura);
  border-color: var(--cor-primaria-escura);
  box-shadow: 0 4px 14px rgba(22,130,76,.35);
}

.btn-secundario {
  background: var(--cor-superficie);
  color: var(--cor-primaria);
  border-color: var(--cor-borda-verde);
  box-shadow: none;
}
.btn-secundario:hover {
  background: var(--cor-primaria-bg);
  border-color: var(--cor-primaria);
  color: var(--cor-primaria-escura);
  box-shadow: none;
  transform: none;
}

.btn-perigo  { background: #dc2626; border-color: #dc2626; box-shadow: none; }
.btn-perigo:hover  { background: #b91c1c; border-color: #b91c1c; transform: none; }

.btn-sucesso { background: var(--cor-sucesso); border-color: var(--cor-sucesso); }
.btn-sucesso:hover { background: #15803d; border-color: #15803d; }

.btn-aviso   { background: var(--cor-acento); border-color: var(--cor-acento); color: #1a1e23; }
.btn-aviso:hover { background: var(--cor-acento-hover); border-color: var(--cor-acento-hover); color: #1a1e23; }

.btn-pequeno { padding: 5px 12px; font-size: 12px; }
.btn-bloco   { width: 100%; }
.btn-fantasma {
  background: transparent;
  color: var(--cor-texto-suave);
  border-color: var(--cor-borda-verde);
  box-shadow: none;
}
.btn-fantasma:hover {
  background: var(--cor-primaria-bg);
  color: var(--cor-primaria);
  border-color: var(--cor-primaria);
  box-shadow: none;
  transform: none;
}

/* ============================================================
   FORMULÁRIO
   ============================================================ */
.form-grupo { margin-bottom: 16px; }
.form-grupo label {
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
  font-size: 11px;
  color: var(--cor-texto-fraco);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.form-grupo .ajuda {
  display: block;
  font-size: 11.5px;
  color: var(--cor-texto-fraco);
  margin-top: 4px;
}

.form-controle,
input[type=text], input[type=email], input[type=password],
input[type=number], input[type=date], input[type=tel], input[type=url],
input[type=file], select, textarea {
  width: 100%;
  padding: 9px 12px;
  border: 1.5px solid var(--cor-borda-verde);
  border-radius: var(--raio-pequeno);
  background: var(--cor-superficie);
  font-family: var(--fonte-corpo);
  font-size: 14px;
  color: var(--cor-texto);
  transition: border-color .15s, box-shadow .15s;
  outline: none;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px rgba(22,130,76,.13);
}
input::placeholder, textarea::placeholder { color: var(--cor-texto-fraco); font-style: italic; }
textarea { resize: vertical; min-height: 80px; }
input[type=checkbox] { width: auto; margin-right: 6px; }

.linha-form {
  display: grid; gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.linha-form-2 { grid-template-columns: 1fr 1fr; }

.acoes-form {
  display: flex; gap: 10px;
  padding-top: 16px; margin-top: 16px;
  border-top: 1px solid var(--cor-borda-verde);
  flex-wrap: wrap;
}

/* ============================================================
   TABELAS
   ============================================================ */
.tabela-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 0 0 var(--raio) var(--raio);
}

.tabela {
  width: 100%;
  border-collapse: collapse;
  background: var(--cor-superficie);
  font-size: 13.5px;
}
.tabela th {
  background: var(--cor-superficie-2);
  color: var(--cor-primaria);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 11px 14px;
  border-bottom: 2px solid var(--cor-borda-verde);
  white-space: nowrap;
  text-align: left;
}
.tabela td {
  padding: 10px 14px;
  border-bottom: 1px solid #eef5f1;
  color: var(--cor-texto-suave);
  vertical-align: middle;
}
.tabela tr:last-child td { border-bottom: none; }
.tabela tbody tr:hover { background: var(--cor-primaria-bg); }
.tabela td.acoes { white-space: nowrap; text-align: right; }
.tabela td.numero { font-family: var(--fonte-mono); font-size: 12.5px; color: var(--cor-primaria-escura); }
.tabela td.dinheiro { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; font-family: var(--fonte-mono); }
.tabela th.centro, .tabela td.centro { text-align: center; }
.tabela th.direita, .tabela td.direita { text-align: right; }

/* ============================================================
   BADGES
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 9px;
  border-radius: 20px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  border: 1px solid transparent;
  line-height: 1.4;
}
.badge::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: .7;
}
.badge.cinza        { background: #f0f0f0;  color: #5a6472;  border-color: #e2e8f0; }
.badge.azul         { background: #dbeafe;  color: #1d4ed8;  border-color: #bfdbfe; }
.badge.amarelo      { background: #fef3cc;  color: #92610a;  border-color: #fde68a; }
.badge.verde        { background: #dcf5e9;  color: var(--cor-primaria-escura); border-color: var(--cor-borda-verde); }
.badge.vermelho     { background: #fee2e2;  color: #b91c1c;  border-color: #fecaca; }
.badge.roxo         { background: #ede9fe;  color: #6d28d9;  border-color: #ddd6fe; }
.badge.laranja      { background: #fed7aa;  color: #9a3412;  border-color: #fdba74; }
.badge.cinza-escuro { background: #cbd5e1;  color: #334155;  border-color: #94a3b8; }

/* ============================================================
   FILTROS
   ============================================================ */
.filtros {
  display: flex; flex-wrap: wrap;
  gap: 10px;
  background: var(--cor-superficie);
  padding: 14px;
  border-radius: var(--raio);
  border: 1px solid var(--cor-borda-verde);
  margin-bottom: 18px;
  align-items: end;
}
.filtros .form-grupo { margin-bottom: 0; flex: 1 1 160px; }
.filtros label { font-size: 11px; }

/* ============================================================
   LISTA RESUMO / STATS SIDE
   ============================================================ */
.lista-resumo { list-style: none; padding: 0; margin: 0; }
.lista-resumo li {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0;
  border-bottom: 1px dashed var(--cor-borda-verde);
  font-size: 13px;
}
.lista-resumo li:last-child { border-bottom: none; }
.lista-resumo li strong {
  font-family: var(--fonte-mono);
  color: var(--cor-primaria);
  font-size: 15px;
}

/* ============================================================
   DETALHE PEDIDO
   ============================================================ */
.cabecalho-pedido {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 22px;
}
.cabecalho-pedido h1 {
  font-family: var(--fonte-mono);
  font-size: 1.4rem;
  margin: 0;
}
.linhas-info {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}
.linha-info { font-size: 13px; }
.linha-info .rotulo {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--cor-texto-fraco);
  font-weight: 700;
  margin-bottom: 2px;
}
.linha-info .valor { color: var(--cor-texto); font-weight: 500; }

/* ============================================================
   TIMELINE / HISTÓRICO
   ============================================================ */
.timeline { list-style: none; padding: 0; margin: 0; position: relative; }
.timeline::before {
  content: ''; position: absolute; left: 8px; top: 0; bottom: 0;
  width: 2px; background: var(--cor-borda-verde);
}
.timeline li {
  padding: 8px 0 18px 28px;
  position: relative;
}
.timeline li::before {
  content: ''; position: absolute; left: 4px; top: 12px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--cor-primaria);
  box-shadow: 0 0 0 3px var(--cor-superficie);
}
.timeline-cabecalho {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 8px; flex-wrap: wrap;
}
.timeline-data    { font-size: 11px; color: var(--cor-texto-fraco); margin-bottom: 2px; }
.timeline-titulo  { font-weight: 600; font-size: 13.5px; }
.timeline-detalhes { font-size: 12.5px; color: var(--cor-texto-suave); margin-top: 3px; }

/* ============================================================
   ANEXOS
   ============================================================ */
.lista-anexos { list-style: none; padding: 0; margin: 0; }
.lista-anexos li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border: 1px solid var(--cor-borda-verde);
  border-radius: var(--raio-pequeno);
  margin-bottom: 6px;
  background: var(--cor-superficie-2);
  font-size: 13px;
}
.lista-anexos a { color: var(--cor-primaria); flex: 1; word-break: break-all; }

/* ============================================================
   TABELA DE ITENS
   ============================================================ */
.tabela-itens input { padding: 6px 8px; font-size: 13px; }
.tabela-itens td { padding: 6px 8px; }
.btn-remover-item {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--cor-borda-verde);
  color: var(--cor-perigo);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  transition: all .15s;
}
.btn-remover-item:hover { background: var(--cor-perigo-bg); border-color: var(--cor-perigo); }

/* ============================================================
   PENDÊNCIAS / BLOCOS
   ============================================================ */
.bloco-pendencia {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda-verde);
  border-left: 4px solid var(--cor-aviso);
  border-radius: var(--raio-pequeno);
  padding: 14px 16px;
  margin-bottom: 10px;
}
.bloco-pendencia.critica { border-left-color: var(--cor-perigo); }

/* ============================================================
   DIFF AUDITORIA
   ============================================================ */
.diff-auditoria {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}
.diff-auditoria pre {
  font-family: var(--fonte-mono);
  font-size: 11.5px;
  background: var(--cor-superficie-2);
  border: 1px solid var(--cor-borda-verde);
  border-radius: var(--raio-pequeno);
  padding: 10px 12px;
  overflow-x: auto;
  color: var(--cor-texto-suave);
}

/* ============================================================
   PÁGINA DE ERRO
   ============================================================ */
.pagina-erro {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: var(--cor-fundo);
  padding: 24px;
  text-align: center;
}
.pagina-erro .codigo {
  font-family: var(--fonte-mono);
  font-size: 5rem;
  font-weight: 700;
  color: var(--cor-primaria);
  line-height: 1;
  margin-bottom: 8px;
}
.pagina-erro h1 { margin-bottom: 6px; }
.pagina-erro p { color: var(--cor-texto-suave); margin-bottom: 22px; }

/* ============================================================
   LOGIN
   ============================================================ */
body.tela-login {
  background:
    radial-gradient(ellipse at 20% 60%, rgba(22,130,76,.22) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(22,130,76,.14) 0%, transparent 55%),
    linear-gradient(160deg, var(--dg-dark-2) 0%, #0f1a14 100%);
}

.login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.login-cartao {
  width: 100%;
  max-width: 400px;
  background: var(--cor-superficie);
  padding: 40px 36px 34px;
  border-radius: var(--raio-grande);
  box-shadow: 0 20px 60px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.2);
  border: 1px solid rgba(22,130,76,.18);
}

.login-marca {
  text-align: center;
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--cor-borda-verde);
}
.login-marca .logo-mark {
  width: 60px; height: 60px;
  border-radius: 14px;
  margin: 0 auto 14px;
  box-shadow: 0 8px 24px rgba(22,130,76,.35);
}
.login-marca .logo-mark svg { width: 34px; height: 34px; }
.login-marca h1 {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 5px;
  color: var(--cor-texto);
}
.login-marca p {
  color: var(--cor-texto-fraco);
  font-size: 13px;
  margin: 0;
}

.login-cartao .form-grupo label {
  font-size: 11px;
  font-weight: 700;
  color: var(--cor-texto-fraco);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.login-cartao .btn { width: 100%; margin-top: 6px; padding: 11px; font-size: 15px; }

.login-rodape {
  text-align: center;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--cor-borda-verde);
  font-size: 11.5px;
  color: var(--cor-texto-fraco);
  line-height: 1.7;
}
.login-rodape a {
  color: var(--cor-primaria);
  font-weight: 500;
}
.login-rodape a:hover { text-decoration: underline; }
.login-rodape-social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 10px;
}
.login-social-icone {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--cor-borda-verde);
  color: var(--cor-texto-fraco);
  transition: all .15s;
  text-decoration: none;
}
.login-social-icone:hover {
  border-color: var(--cor-primaria);
  color: var(--cor-primaria);
  background: var(--cor-primaria-bg);
  text-decoration: none;
}
.login-social-icone svg { width: 13px; height: 13px; }

/* ============================================================
   SEÇÃO TÍTULO
   ============================================================ */
.secao-titulo {
  margin: 24px 0 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--cor-borda-verde);
  font-size: 11px;
  font-weight: 700;
  color: var(--cor-primaria);
  text-transform: uppercase;
  letter-spacing: .07em;
}

/* ============================================================
   INDICADORES DOCUMENTO
   ============================================================ */
.doc-ok, .doc-pend {
  display: inline-block;
  width: 22px; height: 22px;
  border-radius: 50%;
  text-align: center;
  line-height: 22px;
  font-size: 10px;
  font-weight: 700;
  margin: 0 1px;
}
.doc-ok   { background: var(--cor-sucesso-bg); color: var(--cor-sucesso); }
.doc-pend { background: var(--cor-superficie-2); color: var(--cor-texto-fraco); }

/* ============================================================
   UTILITÁRIOS
   ============================================================ */
.texto-suave  { color: var(--cor-texto-suave); }
.texto-fraco  { color: var(--cor-texto-fraco); }
.texto-mono   { font-family: var(--fonte-mono); }
.texto-sucesso { color: #16a34a; }
.texto-perigo  { color: #dc2626; }
.texto-direita { text-align: right; }
.texto-centro  { text-align: center; }
.mt-12 { margin-top: 12px; } .mt-18 { margin-top: 18px; } .mt-24 { margin-top: 24px; }
.mb-0  { margin-bottom: 0; }
.gap-8 { gap: 8px; } .gap-12 { gap: 12px; }
.flex { display: flex; align-items: center; }
.flex-quebrar { flex-wrap: wrap; }
.flex-entre { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.escondido { display: none !important; }
.vazio { text-align: center; padding: 36px 16px; color: var(--cor-texto-fraco); }
.vazio p { margin-bottom: 14px; }

/* Paginação */
.paginacao {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: 16px;
  flex-wrap: wrap;
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    transform: translateX(-100%);
    transition: transform .25s ease;
    z-index: 200;
    box-shadow: 0 0 40px rgba(0,0,0,.4);
  }
  .sidebar.aberta { transform: translateX(0); }
  .principal { grid-column: 1; }
  .topbar { padding: 12px 16px; }
  .conteudo { padding: 18px 16px; }
  .btn-menu-mobile { display: inline-flex; }
  .topbar-direita { gap: 10px; }
  .usuario-info { display: none; }
  .acoes-form { flex-direction: column; }
  .acoes-form .btn { width: 100%; }
  .linha-form, .linha-form-2 { grid-template-columns: 1fr; }
  .diff-auditoria { grid-template-columns: 1fr; }
}

.sidebar-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 150;
}
.sidebar-overlay.ativo { display: block; }

@media (max-width: 540px) {
  .login-cartao { padding: 30px 22px 26px; }
  .login-marca h1 { font-size: 17px; }
  .grade-stats { grid-template-columns: 1fr 1fr; }
  .stat-valor { font-size: 1.45rem; }
  .cartao-cabecalho { flex-direction: column; align-items: flex-start; gap: 4px; }
}
