/* ktulla — diazovate.com dark tokens (Linear-style). Self-hosted; no CDN. */
@font-face { font-family: "Inter"; src: url("/static/fonts/inter.woff2") format("woff2"); font-weight: 400 700; font-display: swap; }
@font-face { font-family: "JetBrains Mono"; src: url("/static/fonts/jetbrains-mono.woff2") format("woff2"); font-weight: 400 500; font-display: swap; }

:root {
  --bg: #0b0c0e; --card: #15171b; --card-hover: #1c1f24;
  --text: #f0f0f0; --muted: #8a8f98;
  --border: #2c2e33; --border-hover: #3d4046;
  --accent: #5e6ad2; --accent-hover: #727de8;
  --green: #22c55e; --red: #ef4444;
  --radius-sm: 6px; --radius-md: 12px; --radius-lg: 16px;
  --ease: cubic-bezier(0.25,0.46,0.45,0.94);
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body { background: var(--bg); color: var(--text); font-family: var(--sans);
  font-size: 15px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }
.eyebrow { font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--muted); }

.btn { display: inline-flex; align-items: center; gap: 6px; height: 38px; padding: 0 16px;
  border-radius: var(--radius-sm); font: 500 14px var(--sans); cursor: pointer;
  border: 1px solid transparent; transition: all .2s var(--ease); }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-hover); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(94,106,210,.35); }
.btn-ghost { background: transparent; color: var(--muted); border-color: var(--border); }
.btn-ghost:hover { color: var(--text); border-color: var(--border-hover); }

input, textarea { background: var(--card); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 9px 12px; font: 400 14px var(--sans); width: 100%; }
input:focus, textarea:focus { outline: none; border-color: var(--accent); }
select { background: var(--card); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 8px 10px; font: 400 14px var(--sans); }
select:focus { outline: none; border-color: var(--accent); }
.ro-badge { margin-left: 8px; font-family: var(--mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: .06em; color: var(--muted); border: 1px solid var(--border); border-radius: 4px; padding: 1px 5px; }

.card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-md); }

/* login */
.login-wrap { display: grid; place-items: center; height: 100%; }
.login-card { width: 340px; padding: 32px; }
.login-card h1 { font-size: 20px; margin: 0 0 4px; letter-spacing: -.01em; }
.login-card p { color: var(--muted); margin: 0 0 20px; font-size: 13px; }
.login-card label { display: block; font-size: 13px; color: var(--muted); margin: 14px 0 6px; }

/* app shell */
.topbar { position: sticky; top: 0; z-index: 10; display: flex; align-items: center;
  justify-content: space-between; height: 56px; padding: 0 20px;
  background: rgba(11,12,14,.8); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.05); }
.topbar .brand { font-weight: 600; letter-spacing: -.01em; }
.topbar .right { display: flex; align-items: center; gap: 14px; font-size: 14px; }
.layout { display: grid; grid-template-columns: 280px 1fr; height: calc(100% - 56px); }
.sidebar { border-right: 1px solid var(--border); overflow: auto; padding: 12px; }
.filelink { display: block; padding: 9px 12px; border-radius: var(--radius-sm);
  color: var(--text); cursor: pointer; transition: background .15s var(--ease); }
.filelink:hover { background: var(--card-hover); }
.filelink.active { background: var(--card); border: 1px solid var(--border); }
.main { display: flex; flex-direction: column; overflow: hidden; }
.editor-head { display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; border-bottom: 1px solid var(--border); }
.editor-head h2 { font-size: 16px; margin: 0; }
.status { font-size: 13px; color: var(--muted); }
.status.saved { color: var(--green); } .status.error { color: var(--red); }
#editor { flex: 1; overflow: auto; padding: 24px 32px; }
.ProseMirror { outline: none; max-width: 820px; }
.ProseMirror table { border-collapse: collapse; }
.ProseMirror th, .ProseMirror td { border: 1px solid var(--border); padding: 6px 10px; }
.wikilink { background: rgba(94,106,210,.15); color: var(--accent); border-radius: 4px;
  padding: 1px 5px; font-family: var(--mono); font-size: .9em; white-space: nowrap; }

/* admin */
.admin-wrap { max-width: 760px; margin: 32px auto; padding: 0 20px; }
.admin-row { display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  border-bottom: 1px solid var(--border); }
.admin-row input[type=checkbox] { width: auto; }
.admin-row .path { font-family: var(--mono); font-size: 13px; flex: 1; }
.admin-row .title { width: 220px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }
