:root{
  --ink:#0e1216; --panel:#151b22; --panel2:#1b232c; --line:#27313c;
  --text:#e7ebf0; --muted:#8b97a6;
  --brass:#c79a4b; --brass-soft:rgba(199,154,75,.14);
  --teal:#54b3a6; --rust:#d4795b;
  --r:10px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--ink);color:var(--text);font-family:var(--sans);
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* ---------- shell ---------- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.rail{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);
  background:var(--panel);padding:22px 18px;display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{font-family:var(--serif);color:var(--brass);font-size:26px;line-height:1}
.brand-name{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.2px}
.rail-sub{margin:8px 0 22px;color:var(--muted);font-size:12px}
.nav{display:flex;flex-direction:column;gap:3px}
.nav-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin:18px 6px 7px}
.nav-link{padding:8px 10px;border-radius:8px;color:#cdd5df;font-size:14px;
  border-left:2px solid transparent}
.nav-link:hover{background:var(--panel2);border-left-color:var(--line)}
.nav-link.accent{color:var(--brass)}
.nav-link.accent:hover{background:var(--brass-soft);border-left-color:var(--brass)}
.rail-foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;font-size:13px}
.who{font-family:var(--mono);color:var(--muted)}
.linkish{background:none;border:0;color:var(--teal);cursor:pointer;font:inherit;padding:0}

.main{padding:38px 44px;max-width:1040px}

/* ---------- flashes ---------- */
.flashes{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.flash{padding:11px 14px;border-radius:var(--r);font-size:14px;
  border:1px solid var(--line);background:var(--panel)}
.flash.success{border-color:rgba(84,179,166,.5);background:rgba(84,179,166,.1)}
.flash.error{border-color:rgba(212,121,91,.5);background:rgba(212,121,91,.12)}

/* ---------- headings / eyebrows ---------- */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brass)}
h1.page{font-family:var(--serif);font-weight:500;font-size:34px;
  margin:6px 0 4px;letter-spacing:.2px}
.lede{color:var(--muted);margin:0 0 30px;max-width:60ch}

/* ---------- catalogue counts ---------- */
.counts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:34px}
.count{border:1px solid var(--line);border-radius:var(--r);background:var(--panel);
  padding:18px 18px 16px;border-top:2px solid var(--brass)}
.count b{font-family:var(--serif);font-size:30px;font-weight:500;display:block}
.count span{font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted)}

/* ---------- panels / cards ---------- */
.section-head{display:flex;align-items:baseline;justify-content:space-between;
  margin:30px 0 14px;border-bottom:1px solid var(--line);padding-bottom:8px}
.section-head h2{font-family:var(--serif);font-weight:500;font-size:20px;margin:0}
.section-head a{color:var(--teal);font-size:13px;font-family:var(--mono)}

.card{display:block;border:1px solid var(--line);border-radius:var(--r);
  background:var(--panel);padding:16px 18px;margin-bottom:10px}
.card:hover{border-color:#34414f;background:var(--panel2)}
.card .row{display:flex;align-items:center;gap:10px;justify-content:space-between}
.card h3{font-family:var(--serif);font-weight:500;font-size:17px;margin:0}
.card .meta{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-top:4px}
.card p{color:var(--muted);margin:8px 0 0;font-size:14px}

/* ---------- type / tag chips ---------- */
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;padding:3px 8px;border-radius:999px;
  border:1px solid var(--line);color:var(--muted)}
.chip.t-source{color:var(--brass);border-color:rgba(199,154,75,.4)}
.chip.t-entity{color:var(--teal);border-color:rgba(84,179,166,.4)}
.chip.t-concept{color:#9d8bd6;border-color:rgba(157,139,214,.4)}
.chip.t-answer{color:#cdd5df}
.tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.tag{font-family:var(--mono);font-size:10.5px;color:var(--muted);
  background:var(--panel2);padding:2px 7px;border-radius:6px}

/* ---------- ledger (log) ---------- */
.ledger{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ledger .l-row{display:grid;grid-template-columns:120px 1fr;gap:14px;
  padding:11px 16px;border-bottom:1px solid var(--line);font-size:13.5px}
.ledger .l-row:last-child{border-bottom:0}
.ledger .when{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ---------- forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--mono);font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
input[type=text],input[type=password],textarea{width:100%;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--r);color:var(--text);
  font:inherit;padding:11px 13px}
textarea{min-height:150px;resize:vertical;line-height:1.6}
input:focus,textarea:focus{outline:none;border-color:var(--brass);
  box-shadow:0 0 0 3px var(--brass-soft)}

.dropzone{border:1.5px dashed var(--line);border-radius:var(--r);
  background:var(--panel);padding:34px;text-align:center;cursor:pointer;
  transition:border-color .15s,background .15s}
.dropzone:hover,.dropzone.over{border-color:var(--brass);background:var(--brass-soft)}
.dropzone .dz-big{font-family:var(--serif);font-size:19px}
.dropzone .dz-sub{color:var(--muted);font-size:13px;margin-top:6px;font-family:var(--mono)}
.dz-files{margin-top:12px;font-family:var(--mono);font-size:13px;color:var(--teal)}
.hr-or{display:flex;align-items:center;gap:14px;color:var(--muted);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;margin:26px 0}
.hr-or::before,.hr-or::after{content:"";flex:1;height:1px;background:var(--line)}

.btn{font:inherit;font-weight:500;background:var(--brass);color:#15110a;
  border:0;border-radius:var(--r);padding:11px 20px;cursor:pointer}
.btn:hover{filter:brightness(1.06)}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--brass);color:var(--brass)}
.actions{display:flex;gap:10px;align-items:center;margin-top:18px}
.note{color:var(--muted);font-size:13px}

/* ---------- prose (rendered markdown) ---------- */
.prose{font-size:15.5px;line-height:1.72}
.prose h1,.prose h2,.prose h3{font-family:var(--serif);font-weight:500;
  line-height:1.3;margin:1.5em 0 .5em}
.prose h2{font-size:21px;border-bottom:1px solid var(--line);padding-bottom:6px}
.prose h3{font-size:17px}
.prose ul,.prose ol{padding-left:1.3em}
.prose li{margin:.3em 0}
.prose a.wikilink{color:var(--teal);border-bottom:1px solid rgba(84,179,166,.35)}
.prose a.wikilink:hover{border-bottom-color:var(--teal)}
.prose .wikilink-bare{color:#cdd5df;border-bottom:1px dotted var(--line)}
.prose code{font-family:var(--mono);font-size:.88em;background:var(--panel2);
  padding:1px 6px;border-radius:5px}
.prose blockquote{border-left:2px solid var(--brass);margin:1em 0;padding-left:14px;
  color:var(--muted)}

/* ---------- page detail backlinks ---------- */
.backbar{display:flex;gap:34px;margin:26px 0;flex-wrap:wrap}
.backbar h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin:0 0 8px}
.reflist a{display:inline-block;font-family:var(--mono);font-size:12.5px;
  color:var(--teal);margin:0 8px 6px 0}

/* ---------- filters ---------- */
.filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.filters a{font-family:var(--mono);font-size:12px;padding:6px 12px;border-radius:8px;
  border:1px solid var(--line);color:var(--muted)}
.filters a.on{border-color:var(--brass);color:var(--brass);background:var(--brass-soft)}
.searchbar{display:flex;gap:8px;margin-bottom:20px}
.searchbar input{flex:1}

/* ---------- lint report ---------- */
.lint-group{border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;
  background:var(--panel);overflow:hidden}
.lint-group h4{margin:0;padding:12px 16px;font-family:var(--mono);font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.lint-group.clean h4{color:var(--teal)}
.lint-group.issues h4{color:var(--rust)}
.lint-group ul{margin:0;padding:12px 16px 14px 32px}
.lint-group li{margin:5px 0}

.empty{border:1px dashed var(--line);border-radius:var(--r);padding:40px;
  text-align:center;color:var(--muted)}
.empty .serif{font-family:var(--serif);font-size:19px;color:var(--text);display:block;margin-bottom:6px}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:380px;border:1px solid var(--line);
  border-radius:14px;background:var(--panel);padding:34px;border-top:3px solid var(--brass)}
.login-card .brand-mark{font-size:34px}
.login-card h1{font-family:var(--serif);font-weight:500;font-size:24px;margin:14px 0 2px}
.login-card p{color:var(--muted);margin:0 0 24px;font-size:13.5px}
.login-card .btn{width:100%;margin-top:6px}

@media(max-width:820px){
  .shell{grid-template-columns:1fr}
  .rail{position:static;height:auto;flex-direction:row;flex-wrap:wrap;
    align-items:center;gap:10px}
  .rail .nav{flex-direction:row;flex-wrap:wrap}
  .nav-eyebrow{display:none}.rail-sub{display:none}.rail-foot{margin:0}
  .main{padding:24px 18px}
  .counts{grid-template-columns:repeat(2,1fr)}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---------- sidebar search ---------- */
.rail-search{margin:0 0 4px}
.rail-search input{width:100%;background:var(--ink);border:1px solid var(--line);
  border-radius:8px;color:var(--text);font:inherit;font-size:13.5px;padding:9px 11px}
.rail-search input::placeholder{color:var(--muted)}
.rail-search input:focus{outline:none;border-color:var(--brass);
  box-shadow:0 0 0 3px var(--brass-soft)}

/* ---------- search results ---------- */
.search-hit .snippet{color:#c4ccd6;font-size:14px;line-height:1.6;margin:9px 0 8px}
.search-hit mark{background:var(--brass-soft);color:var(--brass);
  border-radius:3px;padding:0 2px;font-weight:500}
.allmatch{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--teal);border:1px solid rgba(84,179,166,.4);
  padding:1px 6px;border-radius:5px}
.chip.t-document{color:var(--brass);border-color:rgba(199,154,75,.4)}
