:root {
  --bg: #0f1115; --panel: #181b22; --panel2: #1f232c; --line: #2a2f3a;
  --text: #e6e8ec; --muted: #8a91a0; --accent: #6d8bff; --accent2: #9b6dff;
  --green: #43c97f; --amber: #e6b24a; --red: #f0606a;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--text);
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar { display: flex; justify-content: space-between; align-items: center;
  padding: 14px 28px; background: var(--panel); border-bottom: 1px solid var(--line); }
.brand { font-weight: 700; font-size: 17px; }
.phase { font-size: 11px; color: var(--bg); background: var(--accent); padding: 2px 7px;
  border-radius: 20px; margin-left: 6px; font-weight: 700; vertical-align: middle; }
.topbar .links a { margin-left: 22px; color: var(--text); font-weight: 500; }
.topbar .links a:hover { color: var(--accent); text-decoration: none; }

.container { max-width: 1150px; margin: 0 auto; padding: 26px 28px 60px; }
h1 { font-size: 24px; margin: 4px 0 20px; }
h2 { font-size: 15px; margin: 0 0 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.muted { color: var(--muted); }
.green { color: var(--green); } .amber { color: var(--amber); } .red { color: var(--red); }
.warn { color: var(--amber); }

.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.kpi { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 18px; }
.kpi-num { font-size: 28px; font-weight: 700; }
.kpi-label { color: var(--muted); font-size: 13px; margin-top: 4px; }

.banner { background: var(--panel2); border-left: 3px solid var(--amber); padding: 12px 16px;
  border-radius: 8px; margin-bottom: 14px; }
.banner.info { border-left-color: var(--accent); }

.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 18px; }

table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 9px 10px; border-bottom: 1px solid var(--line); font-size: 14px; }
th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .03em; }
table.grid { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }

.page-head { display: flex; justify-content: space-between; align-items: center; }
.btn { background: var(--accent); color: #fff; padding: 9px 16px; border-radius: 8px; border: 0;
  font-weight: 600; cursor: pointer; font-size: 14px; }
.btn:hover { filter: brightness(1.1); text-decoration: none; }
.filters { display: flex; gap: 10px; align-items: center; margin: 16px 0; }
.filters select { background: var(--panel2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 10px; }
.filters .clear { color: var(--muted); font-size: 13px; }

.actions { white-space: nowrap; }
.actions form { display: inline; }
.link-btn { background: none; border: 0; color: var(--muted); cursor: pointer; font-size: 13px; padding: 0 4px; }
.link-btn:hover { color: var(--red); }
.link-btn.approve:hover { color: var(--green); }

.pill { padding: 3px 9px; border-radius: 20px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.pill-active { background: rgba(67,201,127,.15); color: var(--green); }
.pill-confirm-human { background: rgba(230,178,74,.15); color: var(--amber); }
.pill-limited-reach { background: rgba(230,140,74,.18); color: #e68c4a; }
.pill-shadowbanned { background: rgba(240,96,106,.15); color: var(--red); }
.pill-banned { background: rgba(240,96,106,.22); color: var(--red); }
.pill-deleted { background: rgba(138,145,160,.18); color: var(--muted); }
.pill-draft { background: rgba(138,145,160,.18); color: var(--muted); }
.pill-approved { background: rgba(67,201,127,.15); color: var(--green); }
.pill-queued { background: rgba(109,139,255,.18); color: var(--accent); }
.pill-posted { background: rgba(155,109,255,.18); color: var(--accent2); }

.form { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 22px; max-width: 900px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.form label { display: flex; flex-direction: column; font-size: 13px; color: var(--muted); gap: 5px; }
.form label.check { flex-direction: row; align-items: center; gap: 8px; }
.form label.full { margin-top: 14px; }
.form input, .form select, .form textarea { background: var(--panel2); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 9px 10px; font-size: 14px; font-family: inherit; }
.form-actions { margin-top: 18px; display: flex; gap: 14px; align-items: center; }
.cancel, .form .cancel { color: var(--muted); }
.inline-add { display: flex; gap: 10px; align-items: center; max-width: none; padding: 14px; margin-bottom: 18px; }

.dryrun-bar { background: rgba(67,201,127,.12); color: var(--green); padding: 9px 28px; font-size: 13px;
  border-bottom: 1px solid var(--line); }
.dryrun-bar.live { background: rgba(240,96,106,.12); color: var(--red); }
.dryrun-bar a { color: inherit; text-decoration: underline; }

.hint { font-size: 12px; color: var(--muted); margin-top: 2px; }
.check.big { display: flex; align-items: flex-start; gap: 12px; flex-direction: row; }
.check.big input { margin-top: 4px; transform: scale(1.3); }
.code { display: inline-block; background: var(--panel2); border: 1px solid var(--line); padding: 6px 10px;
  border-radius: 6px; font-family: ui-monospace, monospace; font-size: 13px; }
.sched { display: inline; }
.sched summary { cursor: pointer; list-style: none; }
.sched-form { display: flex; gap: 6px; margin-top: 6px; align-items: center; }
.sched-form select, .sched-form input { background: var(--panel2); color: var(--text); border: 1px solid var(--line);
  border-radius: 6px; padding: 5px 7px; font-size: 12px; }

.whoami { margin-left: 22px; color: var(--muted); font-size: 13px; }
.whoami .role { background: var(--panel2); color: var(--text); padding: 2px 7px; border-radius: 20px;
  font-size: 11px; margin-left: 6px; }
.logout { margin-left: 14px; color: var(--muted) !important; font-size: 13px; }

.login-wrap { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: 20px; }
.login-card { background: var(--panel); border: 1px solid var(--line); border-radius: 14px; padding: 32px;
  width: 100%; max-width: 360px; }
.login-card form { display: flex; flex-direction: column; gap: 12px; margin-top: 14px; }
.login-card label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; color: var(--muted); }
.login-card input { background: var(--panel2); color: var(--text); border: 1px solid var(--line);
  border-radius: 8px; padding: 10px; font-size: 14px; }
.login-error { background: rgba(240,96,106,.15); color: var(--red); padding: 9px 12px; border-radius: 8px;
  font-size: 13px; margin-bottom: 4px; }

.foot { text-align: center; color: var(--muted); font-size: 12px; padding: 30px; border-top: 1px solid var(--line); }
@media (max-width: 800px) { .kpi-grid { grid-template-columns: repeat(2,1fr); } .two-col, .form-grid, .stat-grid { grid-template-columns: 1fr; } }

/* ---- Mobile / phone ---- */
@media (max-width: 640px) {
  .topbar { flex-wrap: wrap; padding: 12px 16px; }
  .topbar .links { width: 100%; margin-top: 10px; display: flex; flex-wrap: wrap; gap: 10px 16px; align-items: center; }
  .topbar .links a { margin-left: 0; font-size: 15px; }
  .whoami, .logout { margin-left: 0; }
  .whoami { margin-left: auto; }

  .container { padding: 18px 16px 50px; }
  h1 { font-size: 21px; }
  .dryrun-bar { padding: 9px 16px; }

  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .kpi { padding: 14px; }
  .kpi-num { font-size: 23px; }

  .page-head { flex-wrap: wrap; gap: 10px; }
  .page-head .btn { width: 100%; text-align: center; }

  /* Wide tables scroll sideways instead of squishing */
  table.grid { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; }

  .filters { flex-wrap: wrap; }
  .filters select { flex: 1 1 45%; }

  .form { padding: 16px; }
  .form-grid { gap: 12px; }
  .btn, .form input, .form select, .form textarea { font-size: 16px; } /* 16px stops iOS zoom-on-focus */
  .form-actions { flex-wrap: wrap; }
}
