/* Paleta y base */
:root {
  --bg: #f3eadc;          /* beige claro */
  --bg-2: #efe3d3;        /* beige sutil para capas */
  --brown: #5a3a2e;       /* acento marrón */
  --brown-700: #472c22;   /* marrón más oscuro para texto fuerte */
  --brown-200: #c9a892;   /* borde/acento suave */
  --shadow: 0 12px 28px rgba(90, 58, 46, 0.12), 0 4px 12px rgba(90, 58, 46, 0.08);
  --radius: 16px;
}

* { box-sizing: border-box; }
html, body {
  height: 100%;
  margin: 0;
  background: var(--bg);
  color: var(--brown-700);
  font-family: "Noto Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Vistas y transición */
.view {
  position: fixed;
  inset: 0;
  display: grid;
  grid-template-rows: 1fr;
  opacity: 0;
  pointer-events: none;
  transform: translateX(16px);
  transition: opacity 380ms ease, transform 380ms ease;
}
.view--active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.view-toggle { display:flex; gap:8px; align-items:center; }
.toggle-btn.toggle-active { background:#f6ebde; border-color: var(--brown); }

/* LOGIN */
.login-wrapper {
  display: grid;
  place-items: center;
  min-height: 100%;
  padding: 24px;
}
.login-card {
  width: 100%;
  max-width: 440px;
  background: #fffaf3; /* beige muy claro para la tarjeta */
  border: 1px solid var(--brown-200);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 28px;
}

.login-header {
  margin-bottom: 18px;
}
.login-title {
  margin: 0 0 6px 0;
  font-weight: 700;
  font-size: 32px;
  color: var(--brown-700);
}
.login-subtitle {
  margin: 0;
  font-size: 14px;
  color: var(--brown);
  opacity: 0.9;
}

.login-fields {
  display: grid;
  gap: 14px;
  margin: 12px 0 18px;
}
.field-label {
  font-size: 13px;
  color: var(--brown-700);
}
.field-input {
  width: 100%;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--brown-200);
  background: var(--bg-2);
  color: var(--brown-700);
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.field-input:focus {
  border-color: var(--brown);
  box-shadow: 0 0 0 3px rgba(90, 58, 46, 0.12);
  background: #f8efe2;
}

.field-error{color:#8b2e2e;font-size:12px;margin-top:4px;}

.login-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 8px;
}

.login-error {
  margin-top: 14px;
  color: #8b2e2e;
  font-size: 13px;
  text-align: center;
  min-height: 18px;
}

/* Botones */
.btn {
  appearance: none;
  border: 1px solid transparent;
  padding: 12px 14px;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 180ms ease, background 160ms ease, color 160ms ease, border-color 160ms ease;
}
.btn:active { transform: translateY(0.5px); }
.btn--primary {
  background: var(--brown);
  color: #fff;
  box-shadow: 0 8px 18px rgba(90, 58, 46, 0.18);
}
.btn--primary:hover {
  box-shadow: 0 10px 22px rgba(90, 58, 46, 0.22);
  background: #4f3328;
}
.btn--ghost {
  background: transparent;
  color: var(--brown-700);
  border-color: var(--brown-200);
}
.btn--ghost:hover {
  background: #f6ebde;
  border-color: var(--brown);
}

/* DASHBOARD */
.dash-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: #6a4b3b; /* suave marrón */
  color: #fffaf3;       /* texto claro */
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100px;
  padding: 0 24px;
}
.dash-brand {
  font-weight: 700;
  font-size: 18px;
  color: var(--brown-700);
}

.dash-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.brand-logo {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #8a5c47; /* logo placeholder */
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}
.dash-brand { color: #fffaf3; }

.dash-menu {
  position: relative;
  display: inline-block;
}
.menu-toggle {
  appearance: none;
  border: 1px solid var(--brown-200);
  background: var(--bg-2);
  color: var(--brown-700);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 160ms ease, box-shadow 180ms ease, border-color 160ms ease;
}
.menu-toggle:hover {
  background: #f6ebde;
  border-color: var(--brown);
  box-shadow: 0 6px 14px rgba(90, 58, 46, 0.14);
}
.chev { margin-left: 6px; }

.menu-list {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  width: 200px;
  background: #fffaf3;
  border: 1px solid var(--brown-200);
  border-radius: 14px;
  box-shadow: var(--shadow);
  list-style: none;
  margin: 0;
  padding: 6px;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}
.menu-list--open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.menu-list li {
  padding: 10px 10px;
  border-radius: 10px;
  background: var(--bg-2);
  border: 1px solid var(--brown-200);
  color: var(--brown-700);
  cursor: pointer;
}
.menu-list li:hover {
  background: #f6ebde;
  border-color: var(--brown);
}

.dash-content {
  padding: 24px 24px;
  min-height: calc(100% - 64px);
  position: relative;
}

.float-new-btn {
  position: absolute;
  top: 8px;
  right: 24px;
  z-index: 5;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--brown-200);
  background: var(--bg-2);
  color: var(--brown-700);
  font-weight: 600;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, box-shadow 180ms ease;
}
.float-new-btn:hover {
  background: #f6ebde;
  border-color: var(--brown);
  box-shadow: 0 6px 14px rgba(90, 58, 46, 0.14);
}

.table-card {
  margin: 0 auto;
  max-width: 980px;
  background: #fffaf3;
  border: 1px solid var(--brown-200);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.table-scroll { max-height: 60vh; overflow: auto; }
.data-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.data-table thead th {
  position: sticky; top: 0; background: #f0e6d8; font-weight: 700;
  color: var(--brown-700); border-bottom: 1px solid var(--brown-200);
}
.data-table th, .data-table td { padding: 12px 14px; color: var(--brown-700); }
.data-table tbody tr:hover { background: #f6ebde; }
.data-table tbody tr.row-highlight{animation:rowGreen 2s ease; background:#e8f5e9;}
@keyframes rowGreen{0%{background:#e8f5e9;}100%{background:transparent;}}

.panel-card {
  margin: 0 auto;
  max-width: 980px;
  background: #fffaf3;
  border: 1px solid var(--brown-200);
  border-radius: 16px;
  box-shadow: var(--shadow);
}
.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--brown-200);
}
.panel-title {
  margin: 0;
  font-weight: 700;
  font-size: 18px;
  color: var(--brown-700);
}
.panel-body { padding: 16px; }

.pagination {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-top: 1px solid var(--brown-200);
}
.page-label { font-weight: 600; color: var(--brown-700); }
.action-btn {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--brown-200);
  background: var(--bg-2);
  color: var(--brown-700);
  cursor: pointer;
}
.action-btn:hover { background: #f6ebde; border-color: var(--brown); }

.detalle-btn {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--brown-200);
  background: var(--bg-2);
  color: var(--brown-700);
  font-weight: 600;
  cursor: pointer;
}
.detalle-btn:hover { background: #f6ebde; border-color: var(--brown); }

.neutral-message {
  margin: 20px auto;
  max-width: 980px;
  background: #fffaf3;
  border: 1px solid var(--brown-200);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 18px;
  text-align: center;
  color: var(--brown-700);
}

.cards-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap:16px; }
.product-card { background:#fffaf3; border:1px solid var(--brown-200); border-radius:16px; box-shadow: var(--shadow); overflow:hidden; }
.product-img { width:100%; height:140px; object-fit:cover; display:block; }
.product-info { padding:12px; } .card-title{ margin:0 0 8px; font-weight:700; font-size:16px; } .card-meta{ display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.card-price{ font-weight:700; color: var(--brown-700); } .stock-badge{ padding:4px 8px; border-radius:999px; border:1px solid var(--brown-200); background: var(--bg-2); color: var(--brown-700); } .stock-badge--low{ background:#f8d9d6; border-color:#d08a82; color:#8b2e2e; }

.sync-indicator {
  margin-left: 8px;
  font-size: 16px;
  vertical-align: middle;
}

.status-update-select {
  max-width: 220px;
  width: 100%;
  box-shadow: 0 4px 12px rgba(90, 58, 46, 0.10);
}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:1000;transition: opacity 180ms ease;}
.modal{width:min(640px,92vw);background:#fffaf3;border:1px solid var(--brown-200);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;transition: transform 180ms ease, opacity 180ms ease;}
.modal-overlay.closing .modal{transform:scale(0.98);opacity:0;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--brown-200);}
.modal-title{margin:0;font-weight:700;font-size:18px;color:var(--brown-700);}
.modal-close{appearance:none;background:transparent;border:1px solid var(--brown-200);border-radius:999px;width:32px;height:32px;cursor:pointer;color:var(--brown-700);}
.modal-close:hover{background:#f6ebde;border-color:var(--brown);}
.modal-body{min-height:140px;padding:16px;max-height:60vh;overflow:auto;}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--brown-200);}
.modal-form { display: grid; gap: 12px; }
.modal-field-group { display: flex; flex-direction: column; gap: 6px; }

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(8px);background:#fffaf3;border:1px solid var(--brown-200);border-radius:999px;box-shadow:var(--shadow);padding:10px 14px;color:var(--brown-700);z-index:1100;opacity:0;animation:toastIn .2s ease forwards,toastOut .2s ease 2.6s forwards;}
@keyframes toastIn{to{opacity:1;transform:translateX(-50%) translateY(0);}}
@keyframes toastOut{to{opacity:0;transform:translateX(-50%) translateY(8px);}}

.orders-top { display: flex; justify-content: center; margin-top: 8px; }
.pedidos-table thead th { background: #e3d3bf; font-weight: 700; }
.pedidos-table th, .pedidos-table td { padding: 14px 20px; }
.pedidos-table th:nth-child(4),
.pedidos-table td:nth-child(4) { min-width: 140px; }
.pedidos-table tbody tr { height: 48px; }
.pedidos-table td:nth-child(4) { padding: 0 14px; display: flex; align-items: center; justify-content: center; }
.pedidos-table td:nth-child(4) .status-tag { display: inline-flex; align-items: center; justify-content: center; height: 100%; padding: 0 12px; border-radius: 999px; }

.status-tag { display:inline-block; padding:4px 8px; border-radius:999px; font-weight:700; font-size:12px; color:#fff; }
.status--pendiente { background:#e6a23c; }
.status--entregado { background:#67c23a; }

.orders-filter-wrap { display:flex; justify-content:flex-end; align-items:center; margin: 0 24px 16px; }
.filter-box { display:flex; align-items:center; gap:10px; background:#fffaf3; border:1px solid var(--brown-200); border-radius:999px; padding:8px 12px; box-shadow: var(--shadow); }
.filter-label { font-weight:600; color: var(--brown-700); }
.filter-select { padding:6px 8px; border-radius:10px; border:1px solid var(--brown-200); background: var(--bg-2); color: var(--brown-700); }

.info-row{display:flex;gap:10px;margin-bottom:8px;flex-wrap:wrap;align-items:baseline;}
.info-label{font-weight:700;color:var(--brown-700);min-width:160px;}
.info-value{font-weight:400;color:var(--brown-700);}

.orders-actions { position:absolute; top:8px; right:24px; display:flex; gap:8px; align-items:center; }