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

body { font-family: system-ui, -apple-system, sans-serif; background: #f5f5f5; color: #1a1a1a; }

/* LOGIN */
.login-wrap {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #c0392b 0%, #8e1a10 100%);
}
.login-card {
  background: #fff; border-radius: 12px; padding: 2.5rem 2rem; width: 360px;
  box-shadow: 0 8px 32px rgba(0,0,0,.2);
}
.login-card h1 { color: #c0392b; font-size: 1.8rem; margin-bottom: .3rem; }
.login-card .subtitle { color: #888; margin-bottom: 1.5rem; font-size: .9rem; }
.login-card input {
  display: block; width: 100%; padding: .7rem 1rem; margin-bottom: .8rem;
  border: 1px solid #ddd; border-radius: 6px; font-size: 1rem;
}
.login-card button {
  width: 100%; padding: .8rem; background: #c0392b; color: #fff;
  border: none; border-radius: 6px; font-size: 1rem; cursor: pointer;
}
.login-card button:hover { background: #a93226; }
.login-card .error { color: #c0392b; margin-top: .8rem; font-size: .85rem; }

/* LAYOUT */
#app { display: flex; min-height: 100vh; }

.sidebar {
  width: 220px; background: #1a1a1a; color: #fff;
  display: flex; flex-direction: column; padding: 1.5rem 1rem;
  flex-shrink: 0;
}
.sidebar .logo { font-size: 1.2rem; font-weight: bold; color: #e74c3c; margin-bottom: 2rem; }
.sidebar ul { list-style: none; flex: 1; }
.sidebar ul li {
  padding: .65rem .8rem; border-radius: 6px; cursor: pointer; margin-bottom: .3rem;
  display: flex; align-items: center; gap: .5rem; transition: background .15s;
}
.sidebar ul li:hover, .sidebar ul li.active { background: #333; }
.sidebar .badge {
  margin-left: auto; background: #c0392b; border-radius: 10px;
  padding: 0 .5rem; font-size: .75rem;
}
.run-btn {
  background: #27ae60; color: #fff; border: none; border-radius: 6px;
  padding: .7rem 1rem; cursor: pointer; font-size: .9rem; margin-top: 1rem;
}
.run-btn:hover { background: #1e8449; }
.run-btn:disabled { background: #555; cursor: not-allowed; }
.logout-btn {
  background: none; border: 1px solid #555; color: #aaa; border-radius: 6px;
  padding: .5rem; cursor: pointer; font-size: .8rem; margin-top: .5rem;
}
.logout-btn:hover { border-color: #aaa; color: #fff; }

.content { flex: 1; padding: 2rem; overflow-y: auto; }
.content h2 { font-size: 1.4rem; margin-bottom: 1.2rem; }
.empty { color: #888; font-style: italic; }

/* Product card */
.product-card {
  display: flex; gap: 1rem; background: #fff; border: 1px solid #ddd;
  border-radius: 8px; padding: 1rem; margin-bottom: 1rem;
}
.product-img img { width: 110px; height: 110px; object-fit: contain; border-radius: 4px; }
.no-img {
  width: 110px; height: 110px; background: #f0f0f0; display: flex;
  align-items: center; justify-content: center; border-radius: 4px; color: #999; font-size: .8rem;
}
.product-info { flex: 1; }
.product-info strong { font-size: 1.05rem; }
.product-info .meta { font-size: .82rem; color: #666; margin: .3rem 0 .6rem; }
.product-info .desc { font-size: .88rem; line-height: 1.5; margin-bottom: .7rem; }
.actions { display: flex; gap: .6rem; }
.btn-approve {
  background: #27ae60; color: #fff; border: none; border-radius: 5px;
  padding: .45rem 1.1rem; cursor: pointer; font-size: .9rem;
}
.btn-approve:hover { background: #1e8449; }
.btn-reject {
  background: #e74c3c; color: #fff; border: none; border-radius: 5px;
  padding: .45rem 1.1rem; cursor: pointer; font-size: .9rem;
}
.btn-reject:hover { background: #c0392b; }

/* Notifications */
.notif {
  display: flex; gap: 1rem; padding: .6rem .8rem; border-radius: 5px;
  margin-bottom: .4rem; font-size: .88rem;
}
.notif.info { background: #eaf4ff; }
.notif.warn { background: #fff8e1; }
.notif.error { background: #fdecea; }
.notif .ts { color: #888; flex-shrink: 0; }

/* Runs table */
table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 8px; overflow: hidden; }
th, td { padding: .55rem .8rem; border-bottom: 1px solid #eee; text-align: left; font-size: .9rem; }
th { background: #f7f7f7; font-weight: 600; }
a { color: #c0392b; }
