:root {
  --creme: #F5F3EE;
  --creme-carta: #FBFAF6;
  --tinta: #2B2A26;
  --tinta-suave: #6B675F;
  --linha: #E4E0D6;
  --verde: #6B8F5A;
  --ambar: #D9A441;
  --terracota: #C56A3D;
  --vermelho: #B4453B;
  --caju: #E08A3E;
  --sombra: 0 2px 10px rgba(43, 42, 38, 0.06);
  --sombra-forte: 0 12px 40px rgba(43, 42, 38, 0.18);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--creme);
  color: var(--tinta);
  font-family: 'Inter', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}

h1, h2 {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  margin: 0;
}

.oculto { display: none !important; }

/* ---------- LOGIN ---------- */
.tela-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background:
    radial-gradient(circle at 15% 10%, rgba(107,143,90,0.10), transparent 45%),
    radial-gradient(circle at 85% 90%, rgba(224,138,62,0.12), transparent 45%),
    var(--creme);
}
.login-card {
  background: var(--creme-carta);
  border: 1px solid var(--linha);
  border-radius: 20px;
  padding: 40px 36px;
  width: 100%;
  max-width: 380px;
  box-shadow: var(--sombra-forte);
  text-align: center;
}
.login-selo { margin-bottom: 12px; }
.login-card h1 { font-size: 26px; }
.login-sub { color: var(--tinta-suave); font-size: 14px; margin: 6px 0 28px; }
.login-card form { display: flex; flex-direction: column; gap: 10px; text-align: left; }
.login-card label { font-size: 13px; font-weight: 600; color: var(--tinta-suave); }
.login-card input {
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--linha);
  font-size: 15px;
  background: #fff;
}
.login-card button {
  margin-top: 8px;
  padding: 12px;
  border: none;
  border-radius: 10px;
  background: var(--verde);
  color: #fff;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: filter .15s;
}
.login-card button:hover { filter: brightness(1.08); }
.login-erro { color: var(--vermelho); font-size: 13px; min-height: 18px; margin: 4px 0 0; }

/* ---------- TOPO ---------- */
.topo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 28px;
  background: var(--creme-carta);
  border-bottom: 1px solid var(--linha);
  position: sticky;
  top: 0;
  z-index: 10;
}
.topo-marca { display: flex; align-items: center; gap: 12px; }
.topo-marca h1 { font-size: 20px; }
.topo-sub { font-size: 12.5px; color: var(--tinta-suave); font-family: 'IBM Plex Mono', monospace; }
.topo-acoes { display: flex; align-items: center; gap: 10px; }
.badge-papel {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 5px 10px;
  border-radius: 20px;
  background: #EFE9DB;
  color: var(--tinta-suave);
}

/* ---------- LEGENDA ---------- */
.legenda {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  padding: 12px 28px;
  font-size: 12.5px;
  color: var(--tinta-suave);
  border-bottom: 1px dashed var(--linha);
}
.legenda-item { display: flex; align-items: center; gap: 6px; }
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.dot-1 { background: var(--verde); }
.dot-2 { background: var(--ambar); }
.dot-3 { background: var(--terracota); }
.dot-4 { background: var(--vermelho); }

/* ---------- FILTROS ---------- */
.filtros { padding: 16px 28px 6px; display: flex; flex-direction: column; gap: 12px; }
.filtros-linha { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.filtros-linha--controles { justify-content: space-between; }

.pill {
  padding: 8px 16px;
  border-radius: 20px;
  border: 1px solid var(--linha);
  background: #fff;
  cursor: pointer;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--tinta-suave);
  transition: all .15s;
}
.pill.ativa {
  background: var(--tinta);
  border-color: var(--tinta);
  color: #fff;
}
.pill .uf {
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 500;
  opacity: .7;
  margin-left: 6px;
}

select, input[type=search], input[type=text], input[type=number], input[type=password], input[type=file] {
  font-family: inherit;
  font-size: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--linha);
  background: #fff;
  color: var(--tinta);
}
#filtro-busca { min-width: 240px; flex: 1; }

.btn-primario, .btn-fantasma, .btn-perigo {
  font-family: inherit;
  font-weight: 600;
  font-size: 13.5px;
  padding: 10px 18px;
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: filter .15s, background .15s;
}
.btn-primario { background: var(--caju); color: #fff; }
.btn-primario:hover { filter: brightness(1.06); }
.btn-fantasma { background: transparent; border-color: var(--linha); color: var(--tinta); }
.btn-fantasma:hover { background: #fff; }
.btn-perigo { background: transparent; border-color: var(--vermelho); color: var(--vermelho); }
.btn-perigo:hover { background: rgba(180,69,59,0.08); }

/* ---------- GRID ---------- */
.grid-produtos {
  padding: 12px 28px 60px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
  gap: 16px;
}
.estado-vazio { text-align: center; color: var(--tinta-suave); padding: 60px 20px; }

.card-produto {
  background: var(--creme-carta);
  border: 1px solid var(--linha);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--sombra);
  display: flex;
  flex-direction: column;
  transition: transform .15s;
}
.card-produto:hover { transform: translateY(-2px); }

.card-foto {
  width: 100%;
  height: 140px;
  background: #EFE9DB;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.card-foto img { width: 100%; height: 100%; object-fit: cover; }
.card-foto .placeholder { color: #B9B2A0; font-size: 12px; font-family: 'IBM Plex Mono', monospace; }

.card-corpo { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.card-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--tinta-suave);
}
.card-nome { font-family: 'Fraunces', serif; font-weight: 600; font-size: 16px; line-height: 1.25; }

.card-marcas { display: flex; flex-direction: column; gap: 5px; margin-top: 4px; }
.linha-marca {
  display: flex;
  align-items: baseline;
  gap: 7px;
  font-size: 13px;
}
.linha-marca .marca-nome { font-weight: 500; }
.linha-marca.vazia { display: none; }

.card-rodape {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 8px;
  border-top: 1px dashed var(--linha);
}
.card-custo { font-family: 'IBM Plex Mono', monospace; font-size: 12.5px; color: var(--tinta-suave); }
.card-editar {
  font-size: 12px;
  font-weight: 600;
  color: var(--caju);
  cursor: pointer;
  background: none;
  border: none;
  font-family: inherit;
}

/* ---------- MODAL ---------- */
.modal {
  position: fixed; inset: 0;
  background: rgba(43,42,38,0.45);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  z-index: 100;
}
.modal-caixa {
  background: var(--creme-carta);
  border-radius: 18px;
  padding: 28px 30px;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--sombra-forte);
}
.modal-caixa h2 { font-size: 20px; margin-bottom: 18px; }
#form-produto, #form-restaurante { display: flex; flex-direction: column; gap: 4px; }
#form-produto label, #form-restaurante label {
  font-size: 12.5px; font-weight: 600; color: var(--tinta-suave); margin-top: 10px;
}
.grade-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.linha-inline { display: flex; gap: 8px; }
.linha-inline select { flex: 1; }
.linha-inline input { flex: 1; }

.foto-preview {
  margin-top: 8px;
  width: 100%;
  max-height: 160px;
  object-fit: cover;
  border-radius: 10px;
}

.modal-acoes {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 22px;
}
.modal-acoes-direita { display: flex; gap: 8px; }

.lista-restaurantes { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.item-restaurante {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--linha);
  border-radius: 10px;
  background: #fff;
  font-size: 14px;
}
.item-restaurante .uf {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 11px;
  color: var(--tinta-suave);
  margin-left: 6px;
}
.item-restaurante button {
  background: none; border: none; color: var(--vermelho); cursor: pointer; font-size: 12px; font-weight: 600;
}

@media (max-width: 640px) {
  .topo { padding: 14px 16px; }
  .filtros, .legenda, .grid-produtos { padding-left: 16px; padding-right: 16px; }
  .grade-2 { grid-template-columns: 1fr; }
}
