body {
  background: #f6f7f9;
}

.navbar {
  position: sticky;
  top: 0;
  z-index: 1030;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
}

.product-img {
  width: 50px;
  height: 50px;
  object-fit: cover;
  border: 1px solid #dee2e6;
  border-radius: 6px;
  background: #fff;
}

.sync-panel {
  border: 1px solid #dee2e6;
  border-radius: 8px;
  background: #fff;
  padding: 16px;
}

.login-body {
  min-height: 100vh;
  background: #eef3f8;
}

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

.login-card {
  width: 100%;
  max-width: 380px;
  padding: 24px;
  border: 1px solid #cbd8e6;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

.login-card .form-label {
  font-weight: 600;
  color: #1f2937;
}

.login-card .form-control {
  height: 42px;
  border: 1px solid #91abc8;
  background-color: #f7fbff;
  color: #0f172a;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
}

.login-card .form-control:hover {
  border-color: #5f86b3;
  background-color: #fff;
}

.login-card .form-control:focus {
  border-color: #0d6efd;
  background-color: #fff;
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.18);
}

th,
td {
  white-space: nowrap;
}

td:nth-child(3) {
  min-width: 280px;
  white-space: normal;
}

.table tbody tr.stock-low > * {
  background-color: #f8d7da;
  color: #842029;
  font-weight: 700;
}

.table tbody tr.stock-warning > * {
  background-color: #fff3cd;
  color: #664d03;
  font-weight: 700;
}
