:root{
  --bg:#faf9f7; --panel:#fff; --ink:#23201c; --muted:#6f6a62;
  --accent:#9a6b3f; --accent-soft:#f0e6da; --line:#e7e1d8;
  --code-bg:#2b2722; --code-ink:#f4ede2; --link:#8a5a2b; --sidebar-w:330px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Sarabun","Segoe UI",Tahoma,sans-serif;font-size:17px;line-height:1.75}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

.layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);position:sticky;top:0;height:100vh;
  overflow-y:auto;background:var(--panel);border-right:1px solid var(--line);padding:20px 16px 60px}
.brand{margin-bottom:8px}
.home-link{font-size:13px;color:var(--muted)}
.brand-title{font-weight:700;font-size:17px;color:var(--accent);line-height:1.4;margin-top:8px}
.brand small{display:block;color:var(--muted);font-size:12.5px;margin-top:4px}
.nav-group{margin-top:14px}
.nav-group-title{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--accent);margin:12px 0 5px;padding-left:8px}
.nav-item{display:block;padding:6px 10px;border-radius:8px;color:var(--ink);font-size:13.5px;
  line-height:1.4;margin:1px 0;border-left:3px solid transparent}
.nav-item:hover{background:var(--accent-soft);text-decoration:none}
.nav-item.active{background:var(--accent-soft);border-left-color:var(--accent);font-weight:600}

.content{flex:1 1 auto;min-width:0;padding:0 0 120px}
.content.full{width:100%}
.main{max-width:880px;margin:0 auto;padding:0 28px}
.main.reading{max-width:900px}
.topbar{position:sticky;top:0;z-index:20;background:rgba(250,249,247,.92);backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);padding:10px 28px;display:flex;align-items:center;gap:12px}
.menu-btn{display:none;border:1px solid var(--line);background:var(--panel);border-radius:8px;
  padding:6px 12px;font-size:15px;cursor:pointer;color:var(--ink)}
.crumb{color:var(--muted);font-size:14px}

.hero{margin:30px 0 10px;padding:26px 30px;background:linear-gradient(135deg,#f4ece0,#fbf6ef);
  border:1px solid var(--line);border-radius:16px}
.hero.big h1{font-size:30px}
.hero h1{margin:0 0 8px;font-size:26px;color:var(--accent)}
.hero p{margin:4px 0;color:#524c43;font-size:15.5px}
.hero p.muted{color:var(--muted);font-size:14px}
.ref-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.ref-link{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:9px 14px;
  font-size:14px;font-weight:600;color:var(--accent)}
.ref-link:hover{background:#fff;border-color:var(--accent);text-decoration:none}
.ref-link span{margin-right:4px}

.section-h{margin:34px 0 8px;font-size:18px;color:var(--accent)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;color:var(--ink);transition:.15s;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.card:hover{border-color:var(--accent);box-shadow:0 4px 14px rgba(154,107,63,.13);text-decoration:none;transform:translateY(-2px)}
.card-top{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);margin-bottom:6px}
.card-count{background:var(--accent-soft);color:var(--accent);border-radius:20px;padding:1px 9px;font-weight:600}
.card-title{font-weight:700;font-size:16.5px;color:var(--accent);line-height:1.35;margin-bottom:7px}
.card-desc{font-size:13.5px;color:#524c43;margin:0 0 12px;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.chips{display:flex;flex-wrap:wrap;gap:5px}
.chip{font-size:11px;background:#f3efe9;color:#6f6a62;border-radius:6px;padding:2px 7px}

.note{background:var(--panel);border:1px solid var(--line);border-radius:16px;
  padding:30px 34px;margin:24px 0;scroll-margin-top:70px;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.note h1{font-size:25px;color:var(--accent);margin:.2em 0 .6em;padding-bottom:.3em;border-bottom:2px solid var(--accent-soft)}
.note h2{font-size:21px;margin:1.4em 0 .5em}
.note h3{font-size:18px;margin:1.3em 0 .4em}
.note h4{font-size:16px;margin:1.1em 0 .3em;color:var(--muted)}
.note p{margin:.7em 0}
.note ul,.note ol{padding-left:1.4em;margin:.6em 0}
.note li{margin:.25em 0}
.note li.task{list-style:none;margin-left:-1.2em;display:flex;align-items:flex-start;gap:8px}
.cb{display:inline-block;width:16px;height:16px;border:1.5px solid var(--accent);border-radius:4px;flex:0 0 16px;margin-top:5px}
.cb.checked{background:var(--accent)}
.cb.checked::after{content:"\2713";color:#fff;font-size:12px;display:block;text-align:center;line-height:14px}

blockquote{margin:1em 0;padding:.6em 1em;border-left:4px solid var(--accent);
  background:var(--accent-soft);border-radius:0 10px 10px 0;color:#4a443c}
blockquote p{margin:.3em 0}
code{background:var(--accent-soft);padding:.1em .4em;border-radius:5px;font-size:.88em;
  font-family:"Cascadia Code",Consolas,monospace}
pre{background:var(--code-bg);color:var(--code-ink);padding:16px 18px;border-radius:12px;
  overflow-x:auto;line-height:1.5;font-size:13.5px}
pre code{background:none;padding:0;color:inherit;font-size:inherit}
table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14.5px}
th,td{border:1px solid var(--line);padding:8px 11px;text-align:left;vertical-align:top}
th{background:var(--accent-soft);font-weight:700}
tr:nth-child(even) td{background:#fbf8f4}
hr{border:none;border-top:1px solid var(--line);margin:1.6em 0}
.wikilink{color:var(--link);border-bottom:1px dotted var(--link)}
.wikilink.ext{color:var(--muted);border-bottom:1px dotted var(--line);cursor:help}
.to-top{margin-top:24px;text-align:right;font-size:13px}
.to-top a{color:var(--muted)}

@media(max-width:920px){
  .menu-btn{display:inline-block}
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);
    transition:transform .25s ease;box-shadow:2px 0 16px rgba(0,0,0,.15)}
  .sidebar.open{transform:translateX(0)}
  .main{padding:0 16px}
  .note{padding:22px 18px}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:40}
  .scrim.show{display:block}
}
