:root{
  --bg:#0f1115; --panel:#1a1d23; --border:#2a2f37;
  --text:#e8eaed; --muted:#9aa0a6;
  --accent:#1f6feb; --accent-hover:#2a7cf2;
  --ok:#7ee787; --bad:#ff8585;
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.55}
a{color:#79c0ff;text-decoration:none}
a:hover{text-decoration:underline}

.site-header{background:#13161c;border-bottom:1px solid var(--border);padding:14px 20px}
.site-header .wrap{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:16px}
.brand{font-weight:700;font-size:1.25rem;color:var(--text)}
.brand .dot{color:var(--accent)}
.nav{margin-left:auto;display:flex;gap:14px;flex-wrap:wrap}
.nav a{color:var(--text);padding:6px 10px;border-radius:8px}
.nav a:hover{background:#22262e;text-decoration:none}

.site-main{max-width:1100px;margin:0 auto;padding:28px 20px}

.card{background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px}
.card + .card{margin-top:14px}
h1{margin:0 0 6px}
.tag{color:var(--muted);margin:0 0 18px}

.field{display:block;margin-bottom:14px}
.field span{display:block;color:var(--muted);font-size:.9rem;margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;padding:11px 13px;border-radius:9px;border:1px solid var(--border);
  background:#0f1115;color:var(--text);font:inherit;outline:none;
  transition:border-color .15s, box-shadow .15s}
.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6feb33}

.btn{display:inline-block;background:var(--accent);color:#fff;border:0;
  padding:11px 18px;border-radius:9px;font:inherit;font-weight:600;cursor:pointer}
.btn:hover{background:var(--accent-hover)}
.btn.secondary{background:#2a2f37}
.btn.secondary:hover{background:#343a44}

.flash{padding:12px 14px;border-radius:9px;margin-bottom:16px;border:1px solid}
.flash.ok{background:#0e2615;border-color:#1c4a2c;color:#bff5cc}
.flash.bad{background:#2a1414;border-color:#5a2222;color:#ffc7c7}
.flash.info{background:#102036;border-color:#22456d;color:#bcdcff}

.site-footer{max-width:1100px;margin:40px auto 24px;padding:0 20px;
  color:var(--muted);font-size:.875rem;text-align:center}

/* Breadcrumbs */
.crumbs{color:var(--muted);font-size:.9rem;margin-bottom:14px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--text)}

/* Subject list (homepage + realm view) */
.subject-list{margin-top:14px;display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:9px;overflow:hidden}
.subject-row{display:flex;justify-content:space-between;gap:1rem;padding:14px 16px;background:var(--panel);color:var(--text)}
.subject-row:hover{background:#22262e;text-decoration:none}
.subj-name{font-weight:600;margin-bottom:2px}
.subj-desc{color:var(--muted);font-size:.9rem}
.subj-stats{color:var(--muted);font-size:.85rem;text-align:right;display:flex;flex-direction:column;gap:2px;flex-shrink:0}

/* Recent activity list */
.recent{list-style:none;padding:0;margin:0}
.recent li{padding:10px 0;border-bottom:1px solid var(--border)}
.recent li:last-child{border-bottom:0}
.recent-meta{color:var(--muted);font-size:.85rem;display:block;margin-top:2px}

/* Subject view: scroll table */
.row-between{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.scroll-table{width:100%;border-collapse:collapse;margin-top:18px}
.scroll-table th,.scroll-table td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--border)}
.scroll-table th{color:var(--muted);font-weight:500;font-size:.85rem}
.scroll-table td.num,.scroll-table th.num{text-align:right;width:80px;color:var(--muted)}
.scroll-title{font-weight:600;color:var(--text)}
.scroll-meta{color:var(--muted);font-size:.85rem;margin-top:2px}

.pill{display:inline-block;font-size:.7rem;padding:2px 8px;border-radius:999px;margin-right:6px;text-transform:uppercase;letter-spacing:.5px}
.pill.sticky{background:#3a2e0a;color:#ffd97a}
.pill.announce{background:#0a2a3a;color:#7adcff}
.pill.locked{background:#3a0a0a;color:#ff8a8a}

/* Pagination */
.pager{display:flex;gap:6px;margin-top:18px;flex-wrap:wrap}
.pg{padding:6px 11px;border:1px solid var(--border);border-radius:7px;color:var(--text)}
.pg:hover{background:#22262e;text-decoration:none}
.pg.current{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}

/* Vora (Vo + Ra display) */
.vora{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:14px}
.vora.vo{border-left:3px solid var(--accent)}
.vora.ra{border-left:3px solid #444b56}
.vora-head{display:flex;align-items:center;gap:10px;font-size:.9rem;margin-bottom:12px;flex-wrap:wrap}
.vora-author{font-weight:600;color:var(--text)}
.vora-tag{font-size:.7rem;padding:2px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px}
.vora-tag.vo{background:#1f6feb33;color:#79c0ff}
.vora-tag.ra{background:#2a2f37;color:var(--muted)}
.vora-time{color:var(--muted)}
.vora-edited{color:var(--muted);font-style:italic}
.vora-body{line-height:1.65}
.vora-body p{margin:0 0 .8em}
.vora-body p:last-child{margin-bottom:0}
.vora-body a{color:#79c0ff}
.vora-body code{background:#0f1115;border:1px solid var(--border);padding:1px 6px;border-radius:5px;font-size:.92em}
.vora-body pre{background:#0f1115;border:1px solid var(--border);padding:12px;border-radius:8px;overflow-x:auto}
.vora-body pre code{background:transparent;border:0;padding:0}
.vora-body blockquote{border-left:3px solid var(--accent);margin:8px 0;padding:4px 12px;color:var(--muted);background:#0f1115;border-radius:0 8px 8px 0}
.vora-body ul,.vora-body ol{padding-left:1.4em}
.vora-foot{margin-top:14px;padding-top:10px;border-top:1px solid var(--border);font-size:.85rem}
.vora-foot a{color:var(--muted)}

textarea{width:100%;padding:12px;border-radius:9px;border:1px solid var(--border);background:#0f1115;color:var(--text);font:inherit;outline:none;resize:vertical;min-height:120px}
textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6feb33}