:root {
  --ink: #14181D; --paper: #F2F3F1; --raised: #FAFAF8; --oxblood: #7A2E2E;
  --line: #C9CDC9; --mist: #6A727C; --graphite: #1E242B;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: -apple-system, "Segoe UI", Roboto, Arial, sans-serif; color: var(--graphite); background: var(--paper); line-height: 1.5; }
.bar { background: var(--ink); color: #E8EAE6; display: flex; justify-content: space-between; align-items: center; padding: 12px 24px; }
.brand { font-family: "Palatino Linotype", Georgia, serif; font-size: 1.15rem; }
.logout { color: #C99; text-decoration: none; font-size: 0.9rem; }
.wrap { max-width: 1000px; margin: 0 auto; padding: 28px 24px; }
h1 { font-family: "Palatino Linotype", Georgia, serif; font-weight: 500; margin-bottom: 18px; }
h2 { font-family: "Palatino Linotype", Georgia, serif; font-weight: 500; margin: 28px 0 12px; font-size: 1.2rem; }
.card { background: var(--raised); border: 1px solid var(--line); padding: 28px; }
.card.narrow { max-width: 380px; margin: 40px auto; }
label { display: block; margin-bottom: 14px; font-size: 0.85rem; color: var(--mist); }
input { display: block; width: 100%; margin-top: 5px; padding: 10px 12px; font-size: 1rem; border: 1px solid var(--line); background: #fff; }
input:focus { outline: 2px solid var(--oxblood); }
button { background: var(--oxblood); color: #F5EFEA; border: 0; padding: 11px 20px; font-size: 0.95rem; cursor: pointer; }
button:hover { background: #5E2222; }
.error { color: var(--oxblood); margin-bottom: 12px; font-size: 0.9rem; }
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.stat { background: var(--raised); padding: 16px; text-align: center; }
.stat .n { display: block; font-size: 1.6rem; font-family: "Palatino Linotype", Georgia, serif; }
.stat .l { display: block; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--mist); margin-top: 4px; }
table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
th, td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--line); }
th { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--mist); }

/* ---------- Management UI ---------- */
.mainnav { display: flex; gap: 20px; margin-left: auto; margin-right: 20px; }
.mainnav a { color: #9AA3AC; text-decoration: none; font-size: 0.9rem; }
.mainnav a:hover, .mainnav a.on { color: #E8EAE6; }
.rowhead { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.rowhead h1 { margin: 0; }
.badge { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; padding: 4px 10px; border: 1px solid; }
.badge.warn { color: #8a6d00; border-color: #d8c17a; background: #fbf4dd; }
.badge.live { color: #7A2E2E; border-color: #c79b9b; background: #f7e9e9; }
.count { font-size: 0.85rem; color: var(--mist); font-family: -apple-system, sans-serif; }
.actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.hint { font-size: 0.82rem; color: var(--mist); margin: 10px 0 4px; max-width: 80ch; }
.hint code { background: #eceeec; padding: 1px 5px; font-size: 0.9em; }
button.ghost { background: transparent; color: var(--graphite); border: 1px solid var(--line); }
button.ghost:hover { border-color: var(--mist); background: #fff; }
button.danger { background: transparent; color: #7A2E2E; border: 1px solid #c79b9b; }
button.danger:hover { background: #7A2E2E; color: #fff; }
button.small { padding: 5px 12px; font-size: 0.82rem; }
form.inline { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; }
form.inline.tight { gap: 8px; align-items: center; }
form.inline label { margin: 0; }
form.inline input, form.inline select { margin-top: 4px; }
form.tight input { margin-top: 0; }
.chk { display: inline-flex; align-items: center; gap: 5px; font-size: 0.85rem; color: var(--graphite); text-transform: none; }
.chk input { width: auto; margin: 0; }
.searchbar { display: flex; gap: 8px; margin: 18px 0; max-width: 420px; }
.searchbar input { margin: 0; }
textarea { width: 100%; margin-top: 5px; padding: 10px 12px; font-family: "SF Mono", Consolas, monospace; font-size: 0.85rem; border: 1px solid var(--line); }
td.right, th.right { text-align: right; }

/* ---------- UX pass ---------- */
.flash { padding: 12px 16px; margin-bottom: 18px; border: 1px solid; font-size: 0.92rem; }
.flash.ok { background: #eef5ee; border-color: #b9d4b9; color: #2c5a2c; }
.flash.err { background: #f7e9e9; border-color: #c79b9b; color: #7A2E2E; }
.seelink, .btnlink { font-size: 0.85rem; text-decoration: none; color: var(--oxblood); }
.rowhead .seelink { margin-left: auto; }
.btnlink { border: 1px solid var(--line); padding: 5px 12px; }
.btnlink:hover { border-color: var(--mist); }
.sub { color: var(--mist); font-size: 0.82rem; }
.empty { color: var(--mist); text-align: center; padding: 22px; }
.nowrap { white-space: nowrap; }
.tablewrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.pill { display: inline-block; font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.05em; padding: 2px 8px; border-radius: 2px; background: #eceeec; color: #555; }
.pill.sent, .pill.active { background: #e4efe4; color: #2c5a2c; }
.pill.dry_run { background: #fbf4dd; color: #8a6d00; }
.pill.error, .pill.bounce { background: #f7e2e2; color: #7A2E2E; }
.pill.ramp { background: #e6edf5; color: #2f5580; }
.usage { font-family: "SF Mono", Consolas, monospace; font-size: 0.9rem; }
.onboard .checklist { list-style: none; counter-reset: step; }
.onboard .checklist li { counter-increment: step; padding: 8px 0 8px 34px; position: relative; border-bottom: 1px solid var(--line); }
.onboard .checklist li:last-child { border-bottom: 0; }
.onboard .checklist li::before { content: counter(step); position: absolute; left: 0; top: 8px; width: 22px; height: 22px; border: 1px solid var(--line); border-radius: 50%; text-align: center; font-size: 0.8rem; line-height: 22px; color: var(--mist); }
.onboard .checklist li.done::before { content: "✓"; background: #2c5a2c; color: #fff; border-color: #2c5a2c; }
.onboard .checklist li.done a { color: var(--mist); text-decoration: line-through; }
.onboard .checklist .hint { display: inline; margin-left: 6px; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.filter { text-decoration: none; font-size: 0.85rem; padding: 6px 12px; border: 1px solid var(--line); color: var(--graphite); }
.filter.on { background: var(--ink); color: #E8EAE6; border-color: var(--ink); }
.filter .c { opacity: 0.7; }
.chk.full { display: flex; width: 100%; }
.emailbox { border: 1px solid var(--line); background: #fff; }
.emailhead { padding: 10px 14px; border-bottom: 1px solid var(--line); background: var(--raised); font-size: 0.92rem; }
.emailbody { padding: 14px; margin: 0; white-space: pre-wrap; font-family: -apple-system, "Segoe UI", sans-serif; font-size: 0.9rem; line-height: 1.55; }
.card.preview { padding: 18px; }
.navtoggle { display: none; }

/* Responsive: collapse nav on small screens */
@media (max-width: 720px) {
  .bar { flex-wrap: wrap; }
  .navtoggle { display: block; background: none; border: 1px solid var(--line-dark); color: #E8EAE6; padding: 6px 12px; font-size: 0.85rem; margin-left: auto; }
  .mainnav { display: none; flex-direction: column; width: 100%; gap: 0; margin: 8px 0 0; }
  .mainnav.open { display: flex; }
  .mainnav a { padding: 12px 4px; border-top: 1px solid var(--line-dark); }
  .wrap { padding: 20px 16px; }
  form.inline { flex-direction: column; align-items: stretch; }
  form.inline label { width: 100%; }
  .stats { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- UX pass 2 ---------- */
.stat.fail { background: #f7e9e9; }
.stat.fail .n { color: #7A2E2E; }
.pill.paused { background: #eceadf; color: #6a5a2a; }
.pill.stopped_manual, .pill.stopped_error, .pill.stopped_unsub, .pill.stopped_bounce, .pill.stopped_reply, .pill.stopped_suppressed { background: #ece7e7; color: #7a5555; }
.pill.stopped_error { background: #f7e2e2; color: #7A2E2E; }
.pill.completed { background: #e6edf5; color: #2f5580; }
.pill.unsubscribe, .pill.reply, .pill.bounce, .pill.dry_run, .pill.skip_suppressed { }
.inlineform { display: inline; }
form.inlineform button { margin-left: 4px; }
td .small + .small, .nowrap button + button, .nowrap .btnlink + form { margin-left: 4px; }
