:root {
  --accent: #2563eb;
  --bg: #f1f5f9;
  --card: #fff;
  --text: #1e293b;
  --muted: #64748b;
  --border: #e2e8f0;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, sans-serif; background: var(--bg); color: var(--text); }

.topbar {
  display: flex; align-items: center; gap: 1.5rem;
  background: #0f172a; color: #fff; padding: 0.7rem 1.5rem;
}
.brand { font-weight: 800; font-size: 1.1rem; }
.topbar nav { display: flex; gap: 1rem; flex: 1; }
.topbar a { color: #cbd5e1; text-decoration: none; }
.topbar a:hover { color: #fff; }
.logout button { background: none; border: 1px solid #475569; color: #cbd5e1; border-radius: 6px; padding: 0.3rem 0.8rem; cursor: pointer; }

.wrap { max-width: 1080px; margin: 0 auto; padding: 1.5rem; }
h1 { font-size: 1.5rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
h2 { font-size: 1.1rem; margin-top: 2rem; }
.muted { color: var(--muted); }
.small { font-size: 0.85rem; }
.mono { font-family: ui-monospace, monospace; font-size: 0.85rem; }
.error { color: #dc2626; }
.notice { background: #fef3c7; border: 1px solid #fbbf24; padding: 0.7rem 1rem; border-radius: 8px; margin: 1rem 0; }

.stats { display: flex; gap: 1rem; flex-wrap: wrap; margin: 1rem 0; }
.stat { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 0.8rem 1.2rem; }
.stat .num { font-size: 1.5rem; font-weight: 800; color: var(--accent); margin-right: 0.4rem; }
.stat.bad .num { color: #dc2626; }

table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 10px; overflow: hidden; }
th, td { text-align: left; padding: 0.55rem 0.8rem; border-bottom: 1px solid var(--border); }
th { background: #f8fafc; font-size: 0.8rem; text-transform: uppercase; color: var(--muted); }
td a { color: var(--accent); text-decoration: none; }

.badge { font-size: 0.75rem; padding: 0.15rem 0.5rem; border-radius: 999px; background: #e2e8f0; }
.badge.active, .badge.done, .badge.published { background: #dcfce7; color: #166534; }
.badge.pending, .badge.review, .badge.draft { background: #fef3c7; color: #92400e; }
.badge.running, .badge.approved { background: #dbeafe; color: #1e40af; }
.badge.failed, .badge.archived { background: #fee2e2; color: #991b1b; }

.btn {
  display: inline-block; background: var(--accent); color: #fff; border: none;
  border-radius: 8px; padding: 0.55rem 1.1rem; font-size: 0.95rem;
  cursor: pointer; text-decoration: none;
}
.btn.small { padding: 0.3rem 0.7rem; font-size: 0.85rem; }
.btn.ghost { background: transparent; color: var(--accent); border: 1px solid var(--accent); }
.btn:disabled { background: #94a3b8; cursor: not-allowed; }
.inline { display: inline; }
.actions { display: flex; gap: 0.6rem; align-items: center; flex-wrap: wrap; margin: 1rem 0; }
.small-input { padding: 0.3rem 0.5rem; border: 1px solid var(--border); border-radius: 6px; }

.card { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 1.2rem 1.5rem; }
.form label { display: block; margin-bottom: 0.8rem; font-size: 0.9rem; font-weight: 600; }
.form input, .form textarea, .form select {
  display: block; width: 100%; margin-top: 0.25rem; padding: 0.5rem 0.7rem;
  border: 1px solid var(--border); border-radius: 8px; font: inherit; font-weight: 400;
}
.form .check { display: flex; align-items: center; gap: 0.5rem; font-weight: 400; }
.form .check input { width: auto; display: inline; margin: 0; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.login-page { display: grid; place-items: center; min-height: 100vh; }
.login-box {
  background: var(--card); border: 1px solid var(--border); border-radius: 12px;
  padding: 2rem 2.5rem; width: 320px; text-align: center;
}
.login-box h1 { justify-content: center; }
.login-box input { width: 100%; padding: 0.6rem; margin: 1rem 0; border: 1px solid var(--border); border-radius: 8px; }
.login-box button { width: 100%; background: var(--accent); color: #fff; border: none; border-radius: 8px; padding: 0.6rem; cursor: pointer; }
