:root {
  --reader-bg: var(--bg, #f6f2e9);
  --reader-fg: var(--ink, #222);
  --reader-paper: var(--paper, #fffef8);
  --reader-line: var(--line, #ddd2b8);
  --content-width: 720px;
  --font-size: 18px;
  --line-height: 1.7;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--reader-bg);
  color: var(--reader-fg);
  font-family: var(--font-body, "Palatino Linotype", Palatino, serif);
}
#reader-app { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.reader-sidebar {
  padding: 18px;
  border-right: 1px solid var(--reader-line);
  background: var(--reader-paper);
}
.reader-main { padding: 12px; }
#reader-frame { width: 100%; height: 96vh; border: 1px solid var(--reader-line); border-radius: 10px; background: var(--reader-paper); }
label { display: block; margin-bottom: 12px; font-size: 13px; }
#toc a { display: block; color: var(--accent, #126da8); text-decoration: none; margin: 4px 0; }
@media (max-width: 900px) { #reader-app { grid-template-columns: 1fr; } .reader-sidebar { border-right: 0; border-bottom: 1px solid #ddd2b8; } #reader-frame { height: 70vh; } }
