/* Light is the default; the theme script sets data-theme on <html>
   (defaulting to the OS preference) and the toggle flips it. */
:root {
  --bg: #ffffff; --fg: #1a1a1a; --muted: #6b7280;
  --sidebar: #f4f4f5; --border: #e4e4e7; --accent: #2563eb;
  --card: #fafafa; --error-bg: #fee2e2; --error-fg: #991b1b;
}
[data-theme="dark"] {
  --bg: #18181b; --fg: #e4e4e7; --muted: #a1a1aa;
  --sidebar: #111113; --border: #27272a; --accent: #60a5fa;
  --card: #1f1f23; --error-bg: #3f1d1d; --error-fg: #fca5a5;
}
* { box-sizing: border-box; }
/* `hidden` must beat component display rules (flex/grid) below. */
[hidden] { display: none !important; }
body {
  margin: 0; background: var(--bg); color: var(--fg);
  font: 15px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
.app { display: flex; min-height: 100vh; }
.sidebar {
  width: 220px; background: var(--sidebar); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; padding: 16px; gap: 4px;
}
.brand { font-weight: 700; font-size: 18px; margin-bottom: 20px; }
.sidebar nav { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.nav-item {
  display: flex; align-items: center; gap: 10px;
  color: var(--fg); text-decoration: none; padding: 8px 10px; border-radius: 6px;
}
.nav-item:hover { background: var(--border); }
.nav-item .ic { color: var(--muted); flex: 0 0 auto; }
.nav-item:hover .ic { color: var(--accent); }
.nav-sep { margin: 14px 0 4px; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); }

/* Main column + top bar */
.main-col { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  height: 56px; padding: 0 24px;
  background: var(--bg); border-bottom: 1px solid var(--border);
}
.topbar-right { display: flex; align-items: center; gap: 8px; }
.who { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: 13px; }
.iconbtn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  background: transparent; border: 1px solid var(--border); color: var(--fg);
  border-radius: 6px; padding: 6px 8px; cursor: pointer; text-decoration: none;
}
.iconbtn:hover { border-color: var(--accent); color: var(--accent); }
.ic { width: 18px; height: 18px; display: block; }

/* Theme button shows the icon for the mode you'd switch TO */
.ic-sun { display: none; }
.ic-moon { display: inline-flex; }
[data-theme="dark"] .ic-moon { display: none; }
[data-theme="dark"] .ic-sun { display: inline-flex; }

.content { flex: 1; padding: 28px 40px; width: 100%; max-width: 1400px; }
h1 { margin-top: 0; }
.muted { color: var(--muted); }
.cards { list-style: none; padding: 0; display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.cards li a {
  display: block; padding: 16px; background: var(--card);
  border: 1px solid var(--border); border-radius: 8px;
  text-decoration: none; color: var(--fg);
}
.cards li a:hover { border-color: var(--accent); }

/* Login */
.centered { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.card.login {
  width: 320px; padding: 28px; background: var(--card);
  border: 1px solid var(--border); border-radius: 12px;
  display: flex; flex-direction: column; gap: 14px;
}
.card.login label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; color: var(--muted); }
.card.login input {
  padding: 9px 10px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg); color: var(--fg); font-size: 14px;
}
.card.login button {
  margin-top: 6px; padding: 10px; border: 0; border-radius: 6px;
  background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
}
.error { background: var(--error-bg); color: var(--error-fg); padding: 8px 10px; border-radius: 6px; font-size: 13px; }

/* Admin */
.row-between { display: flex; align-items: center; justify-content: space-between; }
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border: 1px solid transparent; border-radius: 6px;
  background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
  text-decoration: none; font-size: 14px; white-space: nowrap;
}
.btn .ic { width: 16px; height: 16px; }
.btn:hover { filter: brightness(1.05); }
.btn.danger { background: #dc2626; }
.btn.ghost {
  background: transparent; color: var(--fg); border-color: var(--border);
  font-weight: 500;
}
.btn.ghost:hover { border-color: var(--accent); color: var(--accent); filter: none; }
table.grid { width: 100%; border-collapse: collapse; margin-top: 16px; }
table.grid th, table.grid td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border); }
table.grid th { color: var(--muted); font-weight: 600; font-size: 13px; }
table.grid td.right, table.grid .right { text-align: right; }
/* Sortable headers + pager (content review buckets) */
table.grid th.sorted { color: var(--fg); }
table.grid th .sort { display: inline-flex; align-items: center; gap: 4px; color: inherit; text-decoration: none; }
table.grid th .sort:hover { color: var(--accent); }
table.grid th .arrow { font-size: 11px; line-height: 1; }
.pager { display: flex; align-items: center; justify-content: center; gap: 14px; margin: 16px 0 4px; }
.pager .pager-info { font-size: 13px; }
.pager .btn.ghost.disabled { opacity: .45; pointer-events: none; }
.field { display: flex; flex-direction: column; gap: 4px; max-width: 360px; margin: 14px 0; font-size: 13px; color: var(--muted); }
.field input, .field select {
  padding: 9px 10px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg); color: var(--fg); font-size: 14px;
}
.check { display: flex; align-items: center; gap: 8px; margin: 8px 0; color: var(--fg); font-size: 14px; }
fieldset.views { border: 1px solid var(--border); border-radius: 8px; margin: 18px 0; padding: 12px 16px; }
fieldset.views legend { padding: 0 6px; color: var(--muted); }
form.inline { display: flex; gap: 8px; align-items: center; max-width: 420px; }
form.inline input { flex: 1; padding: 9px 10px; border: 1px solid var(--border); border-radius: 6px; background: var(--bg); color: var(--fg); }
hr { border: 0; border-top: 1px solid var(--border); margin: 28px 0; }
.hint { font-size: 12px; color: var(--muted); }

/* Theme toggle on the login page (no top bar there) */
.login-theme { position: fixed; top: 16px; right: 16px; z-index: 20; }

/* Shared toast notifications */
.toast-wrap {
  position: fixed; right: 18px; bottom: 18px; z-index: 100;
  display: flex; flex-direction: column; gap: 8px; pointer-events: none;
}
.toast {
  min-width: 150px; max-width: 360px; padding: 11px 14px; border-radius: 8px;
  background: var(--fg); color: var(--bg); font-size: 14px; font-weight: 500;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
  opacity: 0; transform: translateY(8px); transition: opacity .2s, transform .2s;
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast.ok { background: #16a34a; color: #fff; }
.toast.err { background: #dc2626; color: #fff; }

/* ── content_machine review view ───────────────────────────────── */
.mode-pill {
  font-size: 12px; padding: 4px 10px; border-radius: 999px;
  border: 1px solid var(--border); color: var(--muted); background: var(--card);
}
.mode-pill.mode-live { color: #fff; background: #16a34a; border-color: #16a34a; }

.tabs { display: flex; gap: 6px; margin: 18px 0 4px; border-bottom: 1px solid var(--border); }
.tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 14px; text-decoration: none; color: var(--muted);
  border: 1px solid transparent; border-bottom: 0; border-radius: 8px 8px 0 0;
}
.tab:hover { color: var(--fg); }
.tab.active { color: var(--fg); background: var(--card); border-color: var(--border); }
.tab .ic { width: 16px; height: 16px; }
.badge {
  font-size: 12px; min-width: 20px; text-align: center; padding: 1px 7px;
  border-radius: 999px; background: var(--border); color: var(--fg);
}
.badge.status-in_review { background: #fde68a; color: #92400e; }
.badge.status-approved { background: #bfdbfe; color: #1e40af; }
.badge.status-published { background: #bbf7d0; color: #166534; }
.badge.status-rejected { background: var(--error-bg); color: var(--error-fg); }

.rowlink { display: inline-flex; align-items: center; gap: 6px; text-decoration: none; color: var(--accent); }
.back { display: inline-flex; align-items: center; gap: 4px; color: var(--muted); text-decoration: none; }
.back .ic { width: 16px; height: 16px; }
.back:hover { color: var(--accent); }

/* Article review page: sticky action bar + centered reading column */
.review-bar {
  position: sticky; top: 56px; z-index: 5;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap;
  margin: -28px -40px 0; padding: 12px 40px;
  background: var(--bg); border-bottom: 1px solid var(--border);
}
.review-bar-main { display: flex; align-items: center; gap: 12px; min-width: 0; }
.review-title {
  margin: 0; font-size: 18px; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 46vw;
}
.review-bar-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.published-tag { display: inline-flex; align-items: center; gap: 6px; color: #16a34a; font-weight: 600; }

.review-body { max-width: 860px; margin: 0 auto; }
.review-meta { margin: 18px 0 6px; }
.article-render {
  border: 1px solid var(--border); border-radius: 10px; background: var(--card);
  padding: 28px 32px; margin: 10px 0 40px; max-width: 100%;
}
.article-render img { max-width: 100%; height: auto; }
.article-render h2 { margin-top: 1.4em; }
/* Mirrors the published page's <h1 class="page-title"> (content_heading). */
.article-render .article-title { font-size: 28px; line-height: 1.2; margin: 0 0 20px; }
.mage-block {
  margin: 18px 0; padding: 10px 14px; border: 1px dashed var(--border);
  border-radius: 8px; background: var(--card); color: var(--muted);
  font-size: 13px; text-align: center;
}

/* Feedback modal */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.modal {
  width: 560px; max-width: 100%; background: var(--bg);
  border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,.35); padding: 20px 22px;
}
.modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.modal-head h2 { display: flex; align-items: center; gap: 8px; font-size: 17px; margin: 0; }
.modal textarea {
  width: 100%; padding: 11px 12px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg); color: var(--fg); font: inherit; resize: vertical;
}
.modal input[type="file"] {
  width: 100%; padding: 10px 12px; border: 1px dashed var(--border); border-radius: 8px;
  background: var(--bg); color: var(--fg); font: inherit;
}
.modal-foot { display: flex; justify-content: flex-end; gap: 8px; margin-top: 14px; }

.fb-progress {
  display: flex; flex-direction: column; gap: 10px; margin-top: 14px;
  padding: 12px 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--card);
}
.fb-feed-head { display: flex; align-items: center; gap: 10px; }
.fb-feed-head .hint { margin-left: auto; }
.fb-feed {
  list-style: none; margin: 0; padding: 0; max-height: 168px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 4px;
}
.fb-feed li {
  font-size: 13px; color: var(--muted); line-height: 1.4;
  padding: 5px 9px; border-radius: 6px; background: var(--bg);
  border: 1px solid var(--border); word-break: break-word;
}
.fb-feed li:last-child { color: var(--fg); }
.spinner {
  width: 22px; height: 22px; flex: 0 0 auto; border-radius: 50%;
  border: 3px solid var(--border); border-top-color: var(--accent);
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Publish result payload */
.published-ok { display: flex; align-items: center; gap: 8px; color: #16a34a; font-weight: 600; }
.payload {
  background: var(--card); border: 1px solid var(--border); border-radius: 8px;
  padding: 14px; overflow: auto; font-size: 13px;
}

/* Account / self-service forms */
.form-card {
  max-width: 460px; margin-top: 18px; padding: 20px 22px;
  background: var(--card); border: 1px solid var(--border); border-radius: 10px;
}
.form-card h2 { display: flex; align-items: center; gap: 8px; font-size: 16px; margin: 0 0 14px; }
.form-card label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; color: var(--muted); margin-bottom: 12px; }
.form-card input {
  padding: 9px 11px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg); color: var(--fg); font: inherit;
}
.form-actions { display: flex; justify-content: flex-end; margin-top: 6px; }

/* System dashboard */
.sys-grid {
  display: grid; gap: 16px; margin-top: 18px;
  grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
}
.sys-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px 18px; min-width: 0;
}
.sys-card.wide { grid-column: 1 / -1; }
.sys-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.sys-card-head h2 { display: flex; align-items: center; gap: 8px; font-size: 14px; margin: 0; }
.sys-card-tools { display: flex; align-items: center; gap: 8px; }
.sys-rows { display: flex; flex-direction: column; }
.sys-row { padding: 9px 0; border-bottom: 1px solid var(--border); }
.sys-row:last-child { border-bottom: 0; }
.sys-row-main { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sys-row-meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 3px; padding-left: 16px; font-size: 12px; color: var(--muted); }
.sys-row-meta .warn { color: #b45309; }
.dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; display: inline-block; background: var(--muted); }
.dot.ok { background: #22c55e; }
.dot.bad { background: #ef4444; }
.dot.idle { background: #9ca3af; }
.chip { font-size: 11px; padding: 1px 8px; border-radius: 999px; background: var(--border); color: var(--fg); }
.kv { display: flex; justify-content: space-between; gap: 12px; font-size: 12px; padding: 3px 0; }

/* Services table */
.table-wrap { overflow-x: auto; }
.sys-table { margin-top: 4px; }
.sys-table th, .sys-table td { padding: 8px 12px; font-size: 13px; }
.sys-table td.nowrap { white-space: nowrap; }
.sys-table td .dot { vertical-align: middle; margin-right: 6px; }

/* Claude usage meters (% of subscription window) */
.meter { padding: 9px 0; }
.meter + .meter { border-top: 1px solid var(--border); }
.meter-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.meter-pct { font-variant-numeric: tabular-nums; font-weight: 600; font-size: 13px; }
.bar { height: 8px; border-radius: 999px; background: var(--border); overflow: hidden; margin: 6px 0 4px; }
.bar-fill { height: 100%; border-radius: 999px; background: var(--accent); transition: width .3s; }
.bar-fill.sev-warning, .meter-pct.sev-warning { color: #b45309; }
.bar-fill.sev-warning { background: #f59e0b; }
.bar-fill.sev-critical, .meter-pct.sev-critical { color: #dc2626; }
.bar-fill.sev-critical { background: #dc2626; }
.usage-vol { margin-top: 12px; border-top: 1px solid var(--border); padding-top: 8px; }
.usage-vol summary { cursor: pointer; font-size: 13px; color: var(--muted); }
.vol-win { display: flex; justify-content: space-between; gap: 12px; font-size: 12px; padding: 5px 0; }
.select {
  padding: 5px 8px; border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg); color: var(--fg); font: inherit; font-size: 13px;
}
.logbox {
  margin: 0; background: #0b0b0d; color: #d4d4d8;
  font: 12px/1.55 ui-monospace, SFMono-Regular, Menlo, monospace;
  padding: 12px 14px; border-radius: 8px; border: 1px solid var(--border);
  max-height: 360px; overflow: auto; white-space: pre-wrap; word-break: break-word;
}
.iconbtn.spin .ic { animation: spin .8s linear infinite; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1000px) {
  .content { padding: 22px 24px; }
  .review-bar { margin: -22px -24px 0; padding: 12px 24px; }
  .review-title { max-width: 40vw; }
}
@media (max-width: 760px) {
  /* Collapse the sidebar to an icon rail — no JS hamburger needed */
  .sidebar { width: 60px; padding: 16px 8px; align-items: center; }
  .sidebar .brand { font-size: 0; }
  .sidebar .brand::first-letter { font-size: 18px; }
  .nav-item { justify-content: center; padding: 10px; }
  .nav-item span { display: none; }
  .nav-sep { font-size: 0; margin: 10px 0; }
  .who span { display: none; }
  .topbar { padding: 0 14px; }
  .content { padding: 18px 16px; }
  .review-bar { margin: -18px -16px 0; padding: 10px 16px; }
  .review-title { max-width: 100%; white-space: normal; font-size: 16px; }
  .review-bar { gap: 10px; }
  .review-bar-actions { width: 100%; }
  .article-render { padding: 18px 16px; }
  .tabs { overflow-x: auto; }
}
