:root {
  --bg: #0f1115;
  --panel: #181b22;
  --panel2: #1f232c;
  --border: #2a2f3a;
  --text: #e8eaed;
  --muted: #9aa3b2;
  --accent: #1d9bf0;
  --ok: #1f9d55;
  --warn: #d9822b;
  --err: #e0245e;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}
.hidden { display: none !important; }
.muted { color: var(--muted); font-size: 0.85em; }
.error { color: var(--err); min-height: 1.2em; }
button { cursor: pointer; font: inherit; border-radius: 8px; border: 1px solid var(--border);
  background: var(--panel2); color: var(--text); padding: 0.5em 1em; }
button.primary { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
button.link { background: none; border: none; color: var(--muted); text-decoration: underline; padding: 0.4em; }
button:disabled { opacity: 0.5; cursor: default; }
input, textarea, select {
  width: 100%; background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px; padding: 0.6em; font: inherit;
}
textarea { resize: vertical; }
label { display: block; margin: 0.6em 0 0.2em; font-size: 0.9em; }

.card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
  padding: 1.2em; margin-bottom: 1em; }

/* Login */
.login { min-height: 100vh; display: grid; place-items: center; padding: 1em; }
.login-card { max-width: 360px; width: 100%; }
.login-card h1 { margin: 0 0 0.2em; }
.login-card button.primary { width: 100%; margin-top: 0.8em; }

/* Topbar */
.topbar { display: flex; align-items: center; justify-content: space-between;
  padding: 0.8em 1.2em; border-bottom: 1px solid var(--border); position: sticky; top: 0;
  background: var(--bg); z-index: 5; }
.topbar-actions { display: flex; gap: 0.6em; align-items: center; }
.wrap { max-width: 720px; margin: 0 auto; padding: 1.2em; }

/* Settings */
summary { cursor: pointer; font-weight: 600; }
.settings-body { margin-top: 1em; display: flex; flex-direction: column; gap: 0.3em; }
.switch { display: flex; align-items: center; gap: 0.6em; }
.switch input { width: auto; }
.settings-body select { width: auto; display: inline-block; margin-left: 0.4em; }

/* Posts */
.post { }
.post-head { display: flex; align-items: center; justify-content: space-between; gap: 0.6em; }
.badge { font-size: 0.72em; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em;
  padding: 0.2em 0.6em; border-radius: 999px; }
.badge.draft { background: #243; color: #9fe3b8; }
.badge.published { background: #123a52; color: #7fd0ff; }
.badge.failed { background: #3a1220; color: #ff9ab5; }
.topic { font-weight: 600; margin: 0.6em 0; }
.field-label { font-size: 0.8em; color: var(--muted); margin-top: 0.8em; text-transform: uppercase; letter-spacing: 0.03em; }
.charcount { float: right; font-size: 0.8em; color: var(--muted); }
.charcount.over { color: var(--err); }
.post img { max-width: 100%; border-radius: 10px; margin-top: 0.6em; border: 1px solid var(--border); }
.why { background: var(--panel2); border-radius: 8px; padding: 0.6em 0.8em; margin-top: 0.6em; font-size: 0.9em; }
.actions { display: flex; flex-wrap: wrap; gap: 0.5em; margin-top: 0.9em; }
.actions .spacer { flex: 1; }
.tweet-link { color: var(--accent); font-size: 0.85em; align-self: center; }
details.ideas summary { font-weight: 400; color: var(--muted); font-size: 0.85em; }
details.ideas ol { margin: 0.4em 0; padding-left: 1.4em; color: var(--muted); font-size: 0.9em; }
.spin { opacity: 0.6; }

/* Replik-varianter */
.variant { display: block; width: 100%; text-align: left; margin: 0.4em 0;
  white-space: normal; line-height: 1.4; border-color: var(--border); }
.variant:hover { border-color: var(--accent); }

/* Följ-lista */
.target-row { display: flex; align-items: center; justify-content: space-between;
  gap: 0.6em; padding: 0.5em 0; border-bottom: 1px solid var(--border); }
.target-row:last-child { border-bottom: none; }

/* Statistik */
.metrics { margin-top: 0.6em; padding: 0.5em 0.7em; background: var(--panel2);
  border-radius: 8px; font-size: 0.9em; color: var(--text); }
#stats-totals { margin-top: 0.5em; }

/* Vad går varmt */
.trend-row { display: flex; align-items: flex-start; justify-content: space-between;
  gap: 0.8em; padding: 0.6em 0; border-bottom: 1px solid var(--border); }
.trend-row:last-child { border-bottom: none; }
.trend-row button { white-space: nowrap; }

/* Citatbank */
.quote-row { padding: 0.6em 0; border-bottom: 1px solid var(--border); }
.quote-row:last-child { border-bottom: none; }
.src-badge { font-size: 0.72em; padding: 0.1em 0.5em; border-radius: 999px; margin-left: 0.3em; }
.src-badge.primary { background: #123a52; color: #7fd0ff; }
.src-badge.reputable_secondary { background: #243; color: #9fe3b8; }
.src-badge.forum_hint, .src-badge.unknown { background: #3a2e12; color: #e3c98f; }
.vstatus { font-size: 0.72em; text-transform: uppercase; letter-spacing: 0.03em; }
.vstatus.verified { color: #7fd0ff; }
.vstatus.needs_review { color: #e3c98f; }
.vstatus.rejected { color: #ff9ab5; }
