/* ============ The Second Curve — reader (Claude Design system) ============
   One visual language with the landing page: dark cinematic, Newsreader /
   Space Grotesk / Space Mono, orange accent, three themes (dark/light/blueprint).
   Canonical tokens match the landing exactly; legacy reader var-names are aliased
   to them so existing class rules retint automatically. */
:root{
  /* --- canonical Claude Design tokens (dark = default) --- */
  --bg:#0a0d12; --bg2:#11151c; --fg:#ece6da; --fgdim:#8b8780;
  --line:#232a35; --line2:#2d3542; --c1:#6b7686; --c2:#e8552d;
  --glow:rgba(232,85,45,0.45); --grid:rgba(255,255,255,0.035);
  /* --- figure tokens (so inline SVG retints per theme) --- */
  --fa:#e8552d; --fah:#f0815f; --fad:#b8431f; --fb:#7d93b0; --fc:#e0664a;
  --figsurf:#161b23; --figon:#0a0d12; --fwash:rgba(232,85,45,0.16); --fbw:rgba(125,147,176,0.18);
  --fa3:#f4a07f; --fa4:#f8bfa6; --fa5:#fbd9c8;
  /* --- type --- */
  --serif:'Newsreader','Spectral',Georgia,'Songti SC',serif;
  --sans:'Space Grotesk',system-ui,-apple-system,'Segoe UI','PingFang SC',sans-serif;
  --mono:'Space Mono',ui-monospace,Menlo,monospace;
  --measure:40rem; --radius:8px;
  --shadow:0 12px 40px rgba(0,0,0,.45); --shadow-s:0 2px 14px rgba(0,0,0,.32);
  /* --- legacy aliases (reader class rules + app.js inline refs) --- */
  --paper:var(--bg); --surface:var(--bg2); --raised:var(--bg2);
  --ink:var(--fg); --ink2:var(--fgdim); --ink3:var(--fgdim);
  --gold:var(--c2); --gold-d:var(--c2); --gold-h:var(--fah); --gold-wash:var(--fwash);
  --teal:var(--fb); --teal-wash:var(--fbw); --red:var(--fc);
}
:root[data-theme="light"]{
  --bg:#f4f1ea; --bg2:#ffffff; --fg:#1a1712; --fgdim:#6b655b;
  --line:#ded8ca; --line2:#cfc7b6; --c1:#b3aa96; --c2:#c2410c;
  --glow:rgba(194,65,12,0.20); --grid:rgba(0,0,0,0.04);
  --fa:#c2410c; --fah:#db6a3f; --fad:#9a330a; --fb:#6b7d96; --fc:#b03a1e;
  --figsurf:#ffffff; --figon:#ffffff; --fwash:rgba(194,65,12,0.12); --fbw:rgba(107,125,150,0.14);
  --fa3:#d98a5f; --fa4:#e8b598; --fa5:#f3d8c4;
  --shadow:0 12px 40px rgba(80,60,20,.10); --shadow-s:0 2px 12px rgba(80,60,20,.07);
}
:root[data-theme="blueprint"]{
  --bg:#071021; --bg2:#0b1a33; --fg:#dbe7ff; --fgdim:#7689b3;
  --line:#1b3460; --line2:#244274; --c1:#46679c; --c2:#39e3cb;
  --glow:rgba(57,227,203,0.40); --grid:rgba(120,170,255,0.06);
  --fa:#39e3cb; --fah:#6fefdc; --fad:#1fb9a3; --fb:#5f86c4; --fc:#ff8a78;
  --figsurf:#0e2342; --figon:#04101f; --fwash:rgba(57,227,203,0.14); --fbw:rgba(95,134,196,0.16);
  --fa3:#7fe9d8; --fa4:#a9f0e4; --fa5:#cdf6ef;
}
*{box-sizing:border-box}
html{scroll-behavior:auto}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background .25s, color .25s}
a{color:inherit;text-decoration:none}
img{max-width:100%}
::selection{background:var(--c2);color:#fff}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:18px;
  height:60px;padding:0 22px;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:13px;cursor:pointer;white-space:nowrap}
.bb-logo{display:inline-flex;align-items:center;gap:8px}
.bb-mark{width:18px;height:18px;display:block;flex:none;color:var(--c2)}
.bb-word{font-family:var(--mono);font-size:13px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--fg)}
.bb-dot{color:var(--fgdim)}
.brand b,.brand .wm{font-family:var(--serif);font-weight:400;font-size:18px;letter-spacing:.01em;color:var(--fg)}
.brand .zh,.brand .eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--fgdim)}
.topnav{display:flex;gap:4px;margin-left:auto;align-items:center}
.topnav a{padding:7px 12px;border-radius:9px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:400;color:var(--fgdim);cursor:pointer}
.topnav a:hover{background:var(--gold-wash);color:var(--fg)}
.topnav a.on{color:var(--c2);background:var(--gold-wash)}
.swatches{display:flex;align-items:center;gap:9px;margin:0 4px 0 8px}
.sw{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--fg);cursor:pointer;padding:0;transition:transform .2s,opacity .2s}
.sw:hover{transform:scale(1.22)}
.iconbtn{width:36px;height:36px;border:1px solid var(--line2);border-radius:9px;background:var(--surface);
  cursor:pointer;color:var(--ink2);display:grid;place-items:center;font-size:15px}
.iconbtn:hover{color:var(--gold-d);border-color:var(--gold)}
.menu-toggle{display:none}

/* progress bar under topbar */
.progress{position:fixed;top:60px;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold-h),var(--gold-d));z-index:39;transition:width .1s}

/* ---------- layout ---------- */
.shell{display:grid;grid-template-columns:300px 1fr;min-height:calc(100vh - 60px)}
.sidebar{border-right:1px solid var(--line);padding:22px 14px 60px;position:sticky;top:60px;
  height:calc(100vh - 60px);overflow-y:auto;background:var(--paper)}
.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:var(--line2);border-radius:8px}
.side-h{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink3);margin:18px 12px 8px}
.side-link{display:flex;gap:9px;align-items:baseline;padding:7px 12px;border-radius:9px;font-size:14.5px;color:var(--ink2);cursor:pointer}
.side-link:hover{background:var(--gold-wash);color:var(--ink)}
.side-link.on{background:var(--gold-wash);color:var(--gold-d);font-weight:600}
.side-link .num{font-family:var(--serif);font-size:13px;color:var(--gold);min-width:18px;font-weight:600}
.side-part{margin-top:6px}
.side-part>.pt{display:flex;align-items:center;gap:8px;padding:8px 12px;font-family:var(--serif);font-weight:600;font-size:15px}
.side-part>.pt .rom{color:var(--gold);font-size:13px}

.main{min-width:0}
.wrap{max-width:920px;margin:0 auto;padding:42px 28px 96px}

/* ---------- home ---------- */
.hero{text-align:center;padding:38px 10px 12px}
.kicker{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--c2)}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(34px,6vw,58px);line-height:1.02;margin:14px 0 6px;letter-spacing:-.02em}
.hero .zh-title{font-family:var(--serif);color:var(--ink3);font-size:22px;margin-bottom:18px}
.hero .lede{max-width:42rem;margin:0 auto;color:var(--ink2);font-size:18px;line-height:1.6}
.hero .by{margin-top:16px;font-size:14.5px;color:var(--ink3)}
.hero .by b{color:var(--ink);font-weight:600}
.stats{display:flex;gap:30px;justify-content:center;margin:26px 0 8px;flex-wrap:wrap}
.stat{text-align:center}
.stat b{display:block;font-family:var(--serif);font-size:26px;color:var(--gold-d);line-height:1}
.stat span{font-family:var(--mono);font-size:10.5px;color:var(--fgdim);letter-spacing:.14em;text-transform:uppercase}
.cta{display:inline-flex;align-items:center;gap:8px;margin-top:22px;padding:13px 26px;border-radius:999px;
  background:var(--ink);color:var(--paper);font-weight:600;font-size:15px;cursor:pointer;box-shadow:var(--shadow-s);transition:transform .15s}
.cta:hover{transform:translateY(-2px)}
.cta.alt{background:transparent;color:var(--ink);border:1px solid var(--line2)}

.map-card{margin:40px 0;background:var(--raised);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.map-card .dia{background:var(--figsurf);border-radius:10px}

.parts{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:14px}
.part-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}
.part-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.part-card .rom{font-family:var(--serif);font-size:40px;color:var(--gold);opacity:.5;line-height:1}
.part-card h3{font-family:var(--serif);font-size:21px;margin:6px 0 8px}
.part-card p{font-size:14px;color:var(--ink2);margin:0 0 14px;line-height:1.55}
.part-card .chs{display:flex;flex-direction:column;gap:5px}
.part-card .chs span{font-size:13.5px;color:var(--ink2);display:flex;gap:8px}
.part-card .chs i{color:var(--gold);font-style:normal;font-family:var(--serif);min-width:16px}

.section-title{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.3em;
  text-transform:uppercase;color:var(--ink3);margin:48px 0 4px}
.rule{height:1px;background:var(--line);margin:10px 0 26px}

/* ---------- reader ---------- */
.reader-head{margin-bottom:8px}
.reader-head .crumb{font-family:var(--mono);font-size:11px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--c2)}
.reader-head h1{font-family:var(--serif);font-weight:400;font-size:clamp(30px,5vw,46px);line-height:1.06;margin:10px 0 4px;letter-spacing:-.02em}
.reader-head .sub{font-family:var(--serif);font-style:italic;color:var(--ink3);font-size:21px;font-weight:400}
.reader-head .metae{display:flex;gap:18px;margin-top:16px;color:var(--ink3);font-size:13px}
.reader-head .metae b{color:var(--gold-d)}
.reader-hr{display:flex;align-items:center;gap:14px;margin:22px 0 30px;color:var(--gold)}
.reader-hr::before,.reader-hr::after{content:"";height:1px;background:var(--line2);flex:1}
.reader-hr span{font-size:18px}

.toc-inline{background:var(--raised);border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin:0 0 34px}
.toc-inline .th{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--fgdim);margin-bottom:8px}
.toc-inline ol{margin:0;padding-left:20px;columns:2;column-gap:30px}
.toc-inline li{margin:5px 0;font-size:14px}
.toc-inline a{color:var(--ink2)}.toc-inline a:hover{color:var(--gold-d)}

.prose{font-family:var(--serif);font-size:19.5px;line-height:1.78;max-width:var(--measure);color:var(--ink)}
.prose p{margin:0 0 1.15em}
.prose .enum{padding-left:2px}
.prose .chapter-body>p:first-of-type::first-letter{font-family:var(--serif);float:left;font-size:3.4em;
  line-height:.82;padding:8px 10px 0 0;color:var(--gold-d);font-weight:600}
.prose h2.sub{font-family:var(--serif);font-weight:600;font-size:25px;margin:1.7em 0 .5em;line-height:1.2;
  scroll-margin-top:80px;position:relative;padding-top:14px}
.prose h2.sub::before{content:"";position:absolute;top:0;left:0;width:40px;height:3px;background:var(--gold);border-radius:2px}
.prose em{font-style:italic;color:var(--ink)}
.prose .fnref a{color:var(--gold-d);font-weight:600;font-family:var(--sans);font-size:.62em;padding:0 1px;text-decoration:none;cursor:pointer}
.prose .fnref a:hover{color:var(--gold)}

/* figures */
.fig{margin:34px 0;text-align:center}
.fig-dia .dia,.fig-dia>svg{background:var(--figsurf);border:1px solid var(--line);border-radius:12px;padding:14px;box-shadow:var(--shadow-s)}
.fig .dia-svg{width:100%;height:auto;max-height:440px;display:block}
.fig-img img{border:1px solid var(--line);border-radius:10px;background:var(--figsurf);box-shadow:var(--shadow-s);max-height:440px}
.fig figcaption{margin-top:10px;font-family:var(--sans);font-size:13.5px;color:var(--ink2);line-height:1.5;max-width:36rem;margin-left:auto;margin-right:auto}
.fig .fignum{font-family:var(--mono);color:var(--c2);font-weight:700;letter-spacing:.04em}

/* endnotes */
.endnotes{margin-top:50px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--sans)}
.endnotes .sub{font-size:13px!important;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);font-family:var(--mono)!important;margin-bottom:14px!important}
.endnotes .sub::before{display:none}
.endnote{display:flex;gap:12px;margin:9px 0;font-size:13.5px;color:var(--ink2);line-height:1.55;scroll-margin-top:80px}
.endnote .fn-num{color:var(--gold-d);font-weight:700;min-width:20px;text-align:right}
.endnote .fn-back{color:var(--gold);margin-left:4px}
.endnote em{font-style:italic}

/* prev/next */
.pager{display:flex;gap:14px;margin-top:54px;border-top:1px solid var(--line);padding-top:26px}
.pager a{flex:1;border:1px solid var(--line);border-radius:12px;padding:16px 18px;cursor:pointer;transition:border-color .15s,transform .15s;background:var(--surface)}
.pager a:hover{border-color:var(--gold);transform:translateY(-2px)}
.pager .dir{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fgdim)}
.pager .pt{font-family:var(--serif);font-size:16px;margin-top:3px}
.pager a.nx{text-align:right}

/* ---------- glossary ---------- */
.tool{display:flex;gap:12px;align-items:center;margin:8px 0 24px;flex-wrap:wrap}
.search{flex:1;min-width:220px;display:flex;align-items:center;gap:9px;background:var(--surface);
  border:1px solid var(--line2);border-radius:11px;padding:11px 15px}
.search input{border:0;background:none;outline:none;font-size:15px;width:100%;color:var(--ink);font-family:var(--sans)}
.search input::placeholder{color:var(--ink3)}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{padding:7px 13px;border:1px solid var(--line2);border-radius:999px;font-size:13px;color:var(--ink2);cursor:pointer;background:var(--surface)}
.chip.on{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:600}
.gloss{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px}
.gcard{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:box-shadow .15s,transform .12s}
.gcard .gcta{margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c2);opacity:.65;transition:opacity .2s}
.gcard:hover .gcta{opacity:1}
.gcard:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.gcard .gt{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.gcard h3{font-family:var(--serif);font-size:19px;margin:0}
.gcard .zh{color:var(--ink3);font-size:14px}
.gcard .ref{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--c2);background:var(--gold-wash);padding:3px 9px;border-radius:999px;white-space:nowrap}
.gcard p{margin:10px 0 0;font-size:14.5px;color:var(--ink2);line-height:1.62}
.empty{color:var(--ink3);text-align:center;padding:50px;font-style:italic}

/* ---------- thinkers ---------- */
.think{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.tcard{display:flex;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px;transition:box-shadow .15s,transform .12s}
.tcard:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.tcard .av{width:52px;height:52px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-family:var(--serif);font-size:22px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--gold-h),var(--gold-d))}
.tcard h3{font-family:var(--serif);font-size:18px;margin:0}
.tcard .zh{color:var(--ink3);font-size:13.5px}
.tcard .role{font-size:12px;color:var(--gold-d);font-weight:600;margin:3px 0 7px}
.tcard p{margin:0;font-size:13.8px;color:var(--ink2);line-height:1.58}

/* ---------- about ---------- */
.about{max-width:46rem}
.about p{font-size:16.5px;line-height:1.7;color:var(--ink2)}
.about h2{font-family:var(--serif);font-size:24px;margin:30px 0 10px}
.about ul{font-size:15.5px;color:var(--ink2);line-height:1.7}
.legend{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:14px}
.legend .li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink2);background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.swatch{width:14px;height:14px;border-radius:4px;flex:none}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;top:60px;left:0;width:300px;transform:translateX(-100%);transition:transform .22s;z-index:35;box-shadow:var(--shadow)}
  .sidebar.open{transform:none}
  .menu-toggle{display:grid}
  .topnav a.lbl{display:none}
  .scrim{position:fixed;inset:60px 0 0;background:rgba(20,15,5,.4);z-index:34;display:none}
  .scrim.open{display:block}
}
@media(max-width:560px){
  body{font-size:16px}
  .wrap{padding:26px 18px 80px}
  .prose{font-size:18.5px}
  .toc-inline ol{columns:1}
  .stats{gap:20px}
  .pager{flex-direction:column}
}
