:root{--bg:#faf9f6;--surface:#fff;--surface-2:#f3f1ea;--surface-3:#ece8df;--border:#e7e3da;--border-strong:#d8d2c6;--ink:#1c1a17;--ink-2:#5f594f;--ink-3:#908a7e;--ink-4:#b3ad9f;--accent:#c96442;--accent-ink:#a84c2d;--accent-soft:#f6e8e1;--accent-line:#ecccbe;--hl:#c9644233;--hl-strong:#c9644257;--code-bg:#f6f4ed;--code-border:#e7e2d6;--code-ink:#2b2926;--code-comment:#9a9488;--code-string:#3f7d54;--code-keyword:#b15533;--code-number:#9a7320;--code-fn:#2f6a8f;--radius:14px;--radius-sm:9px;--radius-lg:22px;--shadow-sm:0 1px 2px #1c1a170a, 0 1px 3px #1c1a170d;--shadow-md:0 4px 14px #1c1a1712, 0 1px 4px #1c1a170d;--shadow-lg:0 18px 50px #1c1a1721;--font-sans:"Hanken Grotesk", ui-sans-serif, system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--font-serif:"Source Serif 4", Georgia, "Times New Roman", serif;--maxw:1320px;--prose-size:17.5px;--prose-font:var(--font-sans);--read-col:720px}[data-tone=cool]{--bg:#f6f7f9;--surface:#fff;--surface-2:#eef0f3;--surface-3:#e4e7ec;--border:#e6e8ec;--border-strong:#d3d7dd;--ink:#1a1c1f;--ink-2:#565a61;--ink-3:#878c94;--ink-4:#b0b5bd;--code-bg:#f2f4f7;--code-border:#e4e7ec}.code-midnight .codeblock{background:#211f1b;border-color:#322f29}.code-midnight .codeblock .cb-bar{background:#1a1815;border-color:#322f29}.code-midnight .codeblock .cb-lang{color:#8a8378}.code-midnight .codeblock .cb-file{color:#b3ad9f}.code-midnight .codeblock pre{color:#e7e1d6}.code-midnight .cb-copy{color:#b3ad9f}.code-midnight .cb-copy:hover{color:#fff;background:#2c2925}.code-midnight .tok-comment{color:#7d776c}.code-midnight .tok-string{color:#98c9a3}.code-midnight .tok-keyword{color:#e08a63}.code-midnight .tok-number{color:#d6b06a}.code-midnight .tok-fn{color:#7eb3d6}.code-midnight .tryit .codeblock{background:#211f1b}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;padding:0}body{overflow-x:hidden}::selection{background:var(--hl-strong)}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input{font-family:inherit}a{color:inherit;cursor:pointer;text-decoration:none}.eyebrow{letter-spacing:.13em;text-transform:uppercase;color:var(--accent-ink);font-size:12px;font-weight:700;font-family:var(--font-mono)}.btn{white-space:nowrap;border-radius:999px;align-items:center;gap:9px;padding:11px 18px;font-size:15px;font-weight:600;transition:transform .12s,background .15s,box-shadow .15s,border-color .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px #a84c2d40}.btn-primary:hover{background:var(--accent-ink)}.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--border-strong)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--ink-4)}.btn-quiet{color:var(--ink-2);border-radius:8px;padding:8px 12px}.btn-quiet:hover{background:var(--surface-2);color:var(--ink)}.topbar{z-index:60;background:color-mix(in srgb, var(--bg) 86%, transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);align-items:center;gap:18px;height:62px;padding:0 26px;display:flex;position:sticky;top:0}.brand{letter-spacing:-.01em;align-items:center;gap:11px;font-size:17px;font-weight:800;display:flex}.brand-mark{background:var(--accent);color:#fff;border-radius:9px;flex:none;place-items:center;width:30px;height:30px;display:grid;box-shadow:inset 0 0 0 1px #ffffff1f}.brand-mark svg{width:18px;height:18px}.topbar-spacer{flex:1}.topbar-nav{align-items:center;gap:4px;display:flex}.topbar-nav a{color:var(--ink-2);border-radius:8px;padding:8px 13px;font-size:14.5px;font-weight:600;transition:background .14s,color .14s}.topbar-nav a:hover{background:var(--surface-2);color:var(--ink)}.topbar-nav a.active{color:var(--accent-ink)}.search{align-items:center;display:flex;position:relative}.search input{border:1px solid var(--border-strong);background:var(--surface);width:230px;color:var(--ink);border-radius:999px;outline:none;padding:9px 14px 9px 38px;font-size:14px;transition:border-color .14s,box-shadow .14s,width .18s}.search input:focus{border-color:var(--accent-line);box-shadow:0 0 0 4px var(--accent-soft);width:260px}.search .search-icon{color:var(--ink-3);pointer-events:none;position:absolute;left:13px}.home{max-width:var(--maxw);margin:0 auto;padding:0 26px 90px}.hero{grid-template-columns:1.1fr .9fr;align-items:center;gap:60px;padding:78px 0 56px;display:grid}.hero h1{letter-spacing:-.03em;text-wrap:balance;margin:18px 0 0;font-size:60px;font-weight:800;line-height:1.02}.hero h1 .accent{color:var(--accent)}.hero p{color:var(--ink-2);max-width:30em;margin:22px 0 30px;font-size:20px;line-height:1.55}.hero-cta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.hero-stats{border-top:1px solid var(--border);gap:30px;margin-top:40px;padding-top:28px;display:flex}.hero-stat .n{letter-spacing:-.02em;font-size:28px;font-weight:800}.hero-stat .l{color:var(--ink-3);margin-top:2px;font-size:13.5px}.hero-art{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:22px;position:relative;transform:rotate(1.4deg)}.hero-art .ha-line{background:var(--surface-2);border-radius:5px;height:11px;margin:13px 0}.hero-art .ha-line.short{width:55%}.hero-art .ha-line.title{background:var(--ink);opacity:.85;width:70%;height:17px;margin-bottom:20px}.hero-art .ha-mark{background:var(--hl);box-shadow:0 0 0 3px var(--hl)}.hero-art .ha-note{background:var(--surface);border:1px solid var(--border-strong);width:168px;box-shadow:var(--shadow-md);color:var(--ink-2);border-radius:12px;padding:12px 13px;font-size:12.5px;line-height:1.45;position:absolute;top:120px;right:-26px;transform:rotate(-3deg)}.hero-art .ha-note .ha-note-h{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);align-items:center;gap:6px;margin-bottom:6px;font-size:10px;font-weight:700;display:flex}.section-head{justify-content:space-between;align-items:flex-end;gap:20px;margin:14px 0 26px;display:flex}.section-head h2{letter-spacing:-.02em;margin:6px 0 0;font-size:27px;font-weight:800}.section-head p{color:var(--ink-2);margin:6px 0 0;font-size:15.5px}.hb-grid{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.hb-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;min-height:246px;padding:26px 24px 22px;transition:transform .16s,box-shadow .18s,border-color .16s;display:flex;position:relative;overflow:hidden}.hb-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-4px)}.hb-card .hb-icon{border-radius:12px;place-items:center;width:46px;height:46px;margin-bottom:18px;display:grid}.hb-card .hb-icon svg{width:24px;height:24px}.hb-card h3{letter-spacing:-.02em;margin:0 0 8px;font-size:21px;font-weight:800}.hb-card p{color:var(--ink-2);flex:1;margin:0;font-size:14.5px;line-height:1.5}.hb-card .hb-meta{border-top:1px solid var(--border);color:var(--ink-3);align-items:center;gap:14px;margin-top:18px;padding-top:16px;font-size:13px;font-weight:600;display:flex}.hb-card .hb-meta .dot{background:var(--ink-4);border-radius:50%;width:4px;height:4px}.hb-card .hb-arrow{color:var(--ink-4);transition:transform .18s,color .18s;position:absolute;top:26px;right:24px}.hb-card:hover .hb-arrow{color:var(--accent);transform:translate(3px,-3px)}.tag{font-size:11.5px;font-weight:700;font-family:var(--font-mono);letter-spacing:.02em;border-radius:999px;align-items:center;padding:3px 9px;display:inline-flex}.tag-soft{background:var(--surface-2);color:var(--ink-2)}.tag-accent{background:var(--accent-soft);color:var(--accent-ink)}.features{grid-template-columns:repeat(3,1fr);gap:22px;margin-top:64px;display:grid}.feature{border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);padding:24px}.feature .f-ic{background:var(--surface);border:1px solid var(--border);width:38px;height:38px;color:var(--accent);border-radius:10px;place-items:center;margin-bottom:14px;display:grid}.feature h4{margin:0 0 6px;font-size:16.5px;font-weight:700}.feature p{color:var(--ink-2);margin:0;font-size:14px;line-height:1.5}.hbview{max-width:1080px;margin:0 auto;padding:44px 26px 90px}.breadcrumb{color:var(--ink-3);align-items:center;gap:9px;margin-bottom:22px;font-size:13.5px;font-weight:600;display:flex}.breadcrumb a:hover{color:var(--accent-ink)}.breadcrumb .crumb-cur{color:var(--ink)}.hb-hero{border-bottom:1px solid var(--border);align-items:flex-start;gap:22px;margin-bottom:34px;padding-bottom:30px;display:flex}.hb-hero .hb-bigicon{border-radius:16px;flex:none;place-items:center;width:66px;height:66px;display:grid}.hb-hero .hb-bigicon svg{width:34px;height:34px}.hb-hero h1{letter-spacing:-.03em;margin:4px 0 0;font-size:38px;font-weight:800}.hb-hero p{color:var(--ink-2);max-width:44em;margin:12px 0 0;font-size:17px;line-height:1.55}.hb-hero-meta{color:var(--ink-3);flex-wrap:wrap;gap:18px;margin-top:18px;font-size:13.5px;font-weight:600;display:flex}.hb-hero-meta span{align-items:center;gap:6px;display:inline-flex}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:18px;margin-bottom:30px;padding:18px 20px;display:flex}.progress-card .pc-text{flex:1}.progress-card .pc-text .pc-h{font-size:15px;font-weight:700}.progress-card .pc-text .pc-s{color:var(--ink-3);margin-top:2px;font-size:13px}.progress-bar{background:var(--surface-3);border-radius:99px;flex:1.4;max-width:340px;height:8px;overflow:hidden}.progress-bar>span{background:var(--accent);border-radius:99px;height:100%;transition:width .4s;display:block}.progress-pct{text-align:right;min-width:42px;font-size:15px;font-weight:800}.chapter-list{flex-direction:column;gap:12px;display:flex}.ch-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:flex-start;gap:18px;padding:20px 22px;transition:border-color .15s,box-shadow .16s,transform .12s;display:flex}.ch-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.ch-num{width:40px;height:40px;font-family:var(--font-mono);background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border);border-radius:11px;flex:none;place-items:center;font-size:15px;font-weight:700;display:grid}.ch-row.done .ch-num{background:var(--accent);color:#fff;border-color:#0000}.ch-body{flex:1}.ch-body h3{letter-spacing:-.01em;margin:0;font-size:18.5px;font-weight:700}.ch-body p{color:var(--ink-2);margin:6px 0 0;font-size:14.5px;line-height:1.5}.ch-body .ch-tags{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.ch-side{flex-direction:column;flex:none;align-items:flex-end;gap:8px;display:flex}.ch-side .ch-time{color:var(--ink-3);white-space:nowrap;font-size:12.5px;font-weight:600}.ch-side .ch-go{color:var(--ink-4)}.ch-row:hover .ch-go{color:var(--accent)}.reader{max-width:var(--maxw);grid-template-columns:286px minmax(0,1fr) 286px;align-items:start;margin:0 auto;display:grid}.r-nav{border-right:1px solid var(--border);height:calc(100vh - 62px);padding:28px 16px 40px 26px;position:sticky;top:62px;overflow-y:auto}.r-nav .rn-back{color:var(--ink-2);border-radius:8px;align-items:center;gap:7px;margin-bottom:20px;padding:6px 9px;font-size:13px;font-weight:600;display:inline-flex}.r-nav .rn-back:hover{background:var(--surface-2);color:var(--ink)}.r-nav .rn-title{font-size:12px;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px;padding:0 9px;font-weight:700}.rn-item{color:var(--ink-2);cursor:pointer;border-radius:9px;align-items:center;gap:11px;padding:9px 10px;font-size:14px;line-height:1.35;transition:background .13s,color .13s;display:flex}.rn-item:hover{background:var(--surface-2);color:var(--ink)}.rn-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:700}.rn-item .rn-check{border:1.6px solid var(--border-strong);color:#0000;border-radius:50%;flex:none;place-items:center;width:19px;height:19px;font-size:11px;display:grid}.rn-item.done .rn-check{background:var(--accent);border-color:var(--accent);color:#fff}.rn-item .rn-n{font-family:var(--font-mono);color:var(--ink-4);min-width:16px;font-size:12px}.rn-item.active .rn-n{color:var(--accent)}.r-main{min-width:0;padding:40px 56px 120px}.r-content{max-width:var(--read-col,720px);margin:0 auto}.r-head{margin-bottom:34px}.r-head .r-eyebrow{align-items:center;gap:10px;margin-bottom:14px;display:flex}.r-head h1{letter-spacing:-.03em;text-wrap:balance;margin:0;font-size:42px;font-weight:800;line-height:1.07}.r-head .r-sub{color:var(--ink-2);margin:16px 0 0;font-size:18.5px;line-height:1.55}.outcomes{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin:30px 0 8px;padding:22px 24px}.outcomes .o-h{align-items:center;gap:9px;margin-bottom:14px;font-size:15px;font-weight:800;display:flex}.outcomes .o-h svg{color:var(--accent)}.outcomes ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.outcomes li{color:var(--ink);gap:11px;font-size:15px;line-height:1.5;display:flex}.outcomes li .o-tick{color:var(--accent);flex:none;margin-top:2px}.prose{font-size:var(--prose-size,17.5px);color:#2a2722;line-height:1.75}.prose h2{letter-spacing:-.02em;margin:48px 0 4px;scroll-margin-top:80px;font-size:26px;font-weight:800;line-height:1.2}.prose h2 .h2-rule{background:var(--accent);border-radius:2px;width:34px;height:3px;margin-bottom:14px;display:block}.prose h3{letter-spacing:-.01em;margin:34px 0 2px;scroll-margin-top:80px;font-size:20px;font-weight:700}.prose p{margin:16px 0}.prose p,.prose li,.outcomes li,.takeaways li{font-family:var(--prose-font,var(--font-sans))}.prose ul,.prose ol{margin:16px 0;padding-left:4px}.prose li{margin:9px 0;padding-left:26px;list-style:none;position:relative}.prose ul>li:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;position:absolute;top:11px;left:4px}.prose ol{counter-reset:li}.prose ol>li{counter-increment:li}.prose ol>li:before{content:counter(li);background:var(--accent-soft);width:21px;height:21px;color:var(--accent-ink);font-family:var(--font-mono);border-radius:50%;place-items:center;font-size:11.5px;font-weight:700;display:grid;position:absolute;top:1px;left:0}.prose strong{color:var(--ink);font-weight:700}.prose code.inline{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--accent-ink);border-radius:6px;padding:1px 6px;font-size:.86em}.prose a.link{color:var(--accent-ink);text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1.5px}.hl-text{cursor:text}mark.hl{background:var(--hl);color:inherit;cursor:pointer;-webkit-box-decoration-break:clone;box-decoration-break:clone;border-radius:3px;padding:.5px 1px;transition:background .14s}mark.hl:hover{background:var(--hl-strong)}mark.hl.has-note{background:var(--hl);border-bottom:2px solid var(--accent)}mark.hl.active-note{background:var(--hl-strong)}.codeblock{border:1px solid var(--code-border);background:var(--code-bg);border-radius:12px;margin:24px 0;overflow:hidden}.codeblock .cb-bar{background:color-mix(in srgb, var(--code-bg) 70%, var(--surface-3));border-bottom:1px solid var(--code-border);align-items:center;gap:10px;padding:9px 12px 9px 15px;display:flex}.codeblock .cb-lang{font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);font-size:11.5px;font-weight:700}.codeblock .cb-file{font-family:var(--font-mono);color:var(--ink-2);font-size:12px}.codeblock .cb-bar .cb-sp{flex:1}.cb-copy{color:var(--ink-2);border-radius:7px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:600;transition:background .13s,color .13s;display:inline-flex}.cb-copy:hover{background:var(--surface);color:var(--ink)}.cb-copy.copied{color:var(--code-string)}.codeblock pre{font-family:var(--font-mono);color:var(--code-ink);margin:0;padding:16px 18px;font-size:13.5px;line-height:1.65;overflow-x:auto}.codeblock pre code{font-family:inherit}.tok-comment{color:var(--code-comment);font-style:italic}.tok-string{color:var(--code-string)}.tok-keyword{color:var(--code-keyword);font-weight:600}.tok-number{color:var(--code-number)}.tok-fn{color:var(--code-fn)}.code-cap{color:var(--ink-3);text-align:center;margin-top:9px;font-size:13px;font-style:italic}.callout{border:1px solid var(--border);background:var(--surface);border-radius:12px;gap:14px;margin:24px 0;padding:17px 19px;font-size:15.5px;line-height:1.6;display:flex}.callout .co-ic{flex:none;width:22px;height:22px;margin-top:1px}.callout .co-body{color:var(--ink)}.callout .co-body strong{margin-bottom:3px;display:block}.callout.tip{background:#f1f6f0;border-color:#d8e6d4}.callout.tip .co-ic{color:#3f7d54}.callout.note{background:var(--surface-2)}.callout.note .co-ic{color:var(--accent)}.callout.warning{background:#fbf2ea;border-color:#f0dcc8}.callout.warning .co-ic{color:#b5852a}.tryit{border:1.5px dashed var(--accent-line);border-radius:var(--radius);background:var(--accent-soft);margin:30px 0;padding:22px 24px}.tryit .ti-h{color:var(--accent-ink);align-items:center;gap:10px;margin-bottom:4px;font-size:16px;font-weight:800;display:flex}.tryit .ti-h .ti-badge{font-family:var(--font-mono);letter-spacing:.1em;background:var(--accent);color:#fff;text-transform:uppercase;border-radius:6px;padding:3px 8px;font-size:10px}.tryit .ti-desc{color:var(--ink);margin:8px 0 0;font-size:15px;line-height:1.55}.tryit ol{margin:14px 0 0}.tryit .codeblock{background:var(--surface)}.diagram{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin:28px 0;padding:26px 22px}.diagram .dg-cap{text-align:center;color:var(--ink-3);margin-top:18px;font-size:13px;font-style:italic}.flowrow{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:0;display:flex}.flownode{background:var(--surface-2);border:1px solid var(--border-strong);text-align:center;border-radius:11px;flex:1;min-width:0;padding:14px 12px}.flownode .fn-t{font-size:14.5px;font-weight:700}.flownode .fn-s{color:var(--ink-3);margin-top:3px;font-size:12px;line-height:1.4}.flownode.accent{background:var(--accent-soft);border-color:var(--accent-line)}.flownode.accent .fn-t{color:var(--accent-ink)}.flowarrow{color:var(--ink-4);flex:none;place-items:center;padding:0 6px;display:grid}.stackdiagram{flex-direction:column;gap:10px;display:flex}.stacklayer{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;align-items:center;gap:14px;padding:13px 16px;display:flex}.stacklayer .sl-tag{font-family:var(--font-mono);color:#fff;background:var(--accent);text-align:center;border-radius:6px;flex:none;min-width:64px;padding:4px 9px;font-size:11px;font-weight:700}.stacklayer .sl-tag.muted{background:var(--ink-4)}.stacklayer .sl-t{font-size:14.5px;font-weight:600}.stacklayer .sl-d{color:var(--ink-3);font-size:13px}.takeaways{border-radius:var(--radius);background:var(--ink);color:#f3efe7;margin:44px 0 10px;padding:28px 30px}.takeaways .tk-h{color:#fff;align-items:center;gap:10px;margin-bottom:18px;font-size:18px;font-weight:800;display:flex}.takeaways .tk-h svg{color:var(--accent)}.takeaways ul{gap:14px;margin:0;padding:0;list-style:none;display:grid}.takeaways li{color:#e7e1d6;gap:13px;font-size:15.5px;line-height:1.55;display:flex}.takeaways li .tk-n{font-family:var(--font-mono);color:var(--accent);flex:none;margin-top:1px;font-size:13px;font-weight:700}.chap-foot{border-top:1px solid var(--border);gap:14px;margin-top:50px;padding-top:30px;display:flex}.chap-foot button{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);flex:1;padding:16px 18px;transition:border-color .15s,box-shadow .15s}.chap-foot button:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.chap-foot .cf-dir{color:var(--ink-3);font-size:12px;font-weight:600;font-family:var(--font-mono)}.chap-foot .cf-t{margin-top:3px;font-size:15.5px;font-weight:700}.chap-foot .next{text-align:right}.complete-btn-wrap{justify-content:center;margin-top:36px;display:flex}.r-rail{height:calc(100vh - 62px);padding:32px 24px 40px 18px;position:sticky;top:62px;overflow-y:auto}.rail-tabs{background:var(--surface-2);border-radius:10px;gap:4px;margin-bottom:18px;padding:3px;display:flex}.rail-tabs button{color:var(--ink-3);border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:7px 8px;font-size:13px;font-weight:700;transition:background .13s,color .13s;display:inline-flex}.rail-tabs button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.rail-tabs .rt-count{font-size:11px;font-family:var(--font-mono);background:var(--accent);color:#fff;border-radius:99px;min-width:16px;padding:1px 6px}.toc-h{font-size:11.5px;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px;font-weight:700}.toc-item{color:var(--ink-3);border-left:2px solid var(--border);cursor:pointer;padding:6px 12px;font-size:13.5px;line-height:1.4;transition:color .13s,border-color .13s;display:block}.toc-item:hover{color:var(--ink)}.toc-item.h3{padding-left:24px;font-size:13px}.toc-item.active{color:var(--accent-ink);border-color:var(--accent);font-weight:600}.notes-empty{text-align:center;color:var(--ink-3);padding:30px 14px}.notes-empty .ne-ic{color:var(--ink-4);margin-bottom:12px}.notes-empty .ne-h{color:var(--ink-2);font-size:14.5px;font-weight:700}.notes-empty .ne-p{margin-top:6px;font-size:13px;line-height:1.5}.note-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:11px;margin-bottom:11px;padding:13px 14px;transition:border-color .14s,box-shadow .14s}.note-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.note-card .nc-quote{color:var(--ink-2);border-left:3px solid var(--accent);-webkit-line-clamp:2;-webkit-box-orient:vertical;padding-left:10px;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.note-card .nc-note{color:var(--ink);margin-top:9px;font-size:14px;line-height:1.5}.note-card .nc-foot{justify-content:space-between;align-items:center;margin-top:10px;display:flex}.note-card .nc-date{color:var(--ink-4);font-size:11px;font-family:var(--font-mono)}.note-card .nc-del{color:var(--ink-4);border-radius:6px;padding:3px}.note-card .nc-del:hover{color:var(--accent);background:var(--surface-2)}.sel-pop{z-index:200;background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);border-radius:10px;align-items:center;gap:2px;padding:4px;display:flex;position:fixed;transform:translate(-50%,-100%)}.sel-pop:after{content:"";background:var(--ink);border-radius:1px;width:10px;height:10px;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)rotate(45deg)}.sel-pop button{color:#fff;white-space:nowrap;border-radius:7px;align-items:center;gap:6px;padding:7px 11px;font-size:13px;font-weight:600;display:inline-flex}.sel-pop button:hover{background:#ffffff24}.sel-pop .sp-div{background:#ffffff2e;width:1px;height:18px}.note-pop{z-index:210;background:var(--surface);border:1px solid var(--border-strong);width:290px;box-shadow:var(--shadow-lg);border-radius:13px;padding:14px;position:fixed;transform:translate(-50%)}.note-pop .np-quote{color:var(--ink-2);border-left:3px solid var(--accent);max-height:54px;margin-bottom:11px;padding-left:10px;font-size:12.5px;line-height:1.45;overflow:hidden}.note-pop textarea{border:1px solid var(--border-strong);width:100%;color:var(--ink);resize:vertical;background:var(--surface-2);border-radius:9px;outline:none;min-height:78px;padding:10px 11px;font-family:inherit;font-size:14px;line-height:1.5}.note-pop textarea:focus{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}.note-pop .np-foot{justify-content:space-between;align-items:center;margin-top:11px;display:flex}.note-pop .np-foot .np-actions{gap:8px;display:flex}.np-btn{border-radius:8px;padding:7px 13px;font-size:13px;font-weight:600}.np-btn.save{background:var(--accent);color:#fff}.np-btn.save:hover{background:var(--accent-ink)}.np-btn.cancel{color:var(--ink-2)}.np-btn.cancel:hover{background:var(--surface-2)}.np-del{color:var(--ink-3);border-radius:7px;align-items:center;gap:5px;padding:6px;font-size:12.5px;display:inline-flex}.np-del:hover{color:var(--accent);background:var(--surface-2)}.read-progress{background:var(--accent);z-index:55;height:2.5px;transition:width .1s linear;position:fixed;top:62px;left:0}.toast{background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;z-index:300;border-radius:11px;align-items:center;gap:9px;padding:12px 18px;font-size:14px;font-weight:600;transition:opacity .2s,transform .2s;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast svg{color:#7ec48f}.handbook-toolbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;display:flex}.handbook-toolbar .ht-label{color:var(--ink-2);font-size:15px;font-weight:700}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;gap:3px;padding:3px;display:flex}.view-toggle button{color:var(--ink-3);border-radius:8px;align-items:center;gap:7px;padding:7px 14px;font-size:13.5px;font-weight:700;transition:background .14s,color .14s;display:inline-flex}.view-toggle button.active{background:var(--surface);color:var(--accent-ink);box-shadow:var(--shadow-sm)}.roadmap{margin-bottom:14px}.rm-legend{flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:26px;display:flex}.rm-lg{color:var(--ink-3);align-items:center;gap:7px;font-size:12.5px;font-weight:600;display:inline-flex}.rm-swatch{border-radius:50%;flex:none;width:11px;height:11px}.rm-swatch.done{background:var(--accent)}.rm-swatch.current{background:var(--surface);border:2px solid var(--accent)}.rm-swatch.future{background:var(--surface);border:2px solid var(--border-strong)}.rm-track{padding:6px 0 4px;position:relative}.rm-track:before{content:"";background:var(--border-strong);background-image:linear-gradient(var(--border-strong) 60%, transparent 0);background-size:2px 11px;width:2px;margin-left:-1px;position:absolute;top:16px;bottom:16px;left:50%}.rm-cap{z-index:2;color:var(--ink-2);justify-content:center;align-items:center;gap:10px;padding:4px 0;font-size:14px;font-weight:700;display:flex;position:relative}.rm-cap.finish{margin-top:6px}.rm-cap-dot{background:var(--accent);color:#fff;width:30px;height:30px;box-shadow:0 0 0 5px var(--bg);border-radius:50%;place-items:center;display:grid}.rm-cap.start .rm-cap-dot{background:var(--ink)}.rm-node{box-sizing:border-box;width:50%;margin:14px 0;position:relative}.rm-node.right{margin-left:50%;padding-left:42px}.rm-node.left{text-align:left;margin-right:50%;padding-right:42px}.rm-dot{z-index:2;width:40px;height:40px;font-family:var(--font-mono);background:var(--surface);border:2px solid var(--border-strong);color:var(--ink-3);box-shadow:0 0 0 5px var(--bg);border-radius:50%;place-items:center;font-size:13px;font-weight:700;display:grid;position:absolute;top:16px}.rm-node.right .rm-dot{left:-20px}.rm-node.left .rm-dot{right:-20px}.rm-node.done .rm-dot{background:var(--accent);color:#fff;border-color:#0000}.rm-node.current .rm-dot{border-color:var(--accent);color:var(--accent-ink);box-shadow:0 0 0 5px var(--bg), 0 0 0 9px var(--accent-soft)}.rm-node:before{content:"";background:var(--border-strong);width:30px;height:2px;position:absolute;top:35px}.rm-node.right:before{left:12px}.rm-node.left:before{right:12px}.rm-node.done:before{background:var(--accent-line)}.rm-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px 18px;transition:transform .15s,box-shadow .16s,border-color .15s;position:relative}.rm-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.rm-node.current .rm-card{border-color:var(--accent-line);box-shadow:0 0 0 1px var(--accent-line)}.rm-node.future .rm-card{background:color-mix(in srgb, var(--surface) 70%, var(--bg))}.rm-node.future h4{color:var(--ink-2)}.rm-card-top{justify-content:space-between;align-items:center;gap:10px;margin-bottom:7px;display:flex}.rm-eyebrow{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-size:10.5px;font-weight:700}.rm-node.current .rm-eyebrow,.rm-node.done .rm-eyebrow{color:var(--accent-ink)}.rm-mins{color:var(--ink-4);align-items:center;gap:4px;font-size:11.5px;font-weight:600;display:inline-flex}.rm-card h4{letter-spacing:-.01em;margin:0 0 11px;font-size:17px;font-weight:700;line-height:1.25}.rm-skills{flex-wrap:wrap;gap:6px;display:flex}.rm-chip{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border);white-space:nowrap;border-radius:999px;flex:none;padding:3px 9px;font-size:11.5px;font-weight:600}.rm-node.current .rm-chip{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent-ink)}.rm-open{color:var(--ink-4);opacity:0;transition:opacity .15s,transform .15s,color .15s;position:absolute;top:14px;right:15px;transform:translate(-3px)}.rm-card:hover .rm-open{opacity:1;color:var(--accent);transform:translate(0)}.rm-note{text-align:center;color:var(--ink-3);max-width:40em;margin:28px auto 0;font-size:13px;line-height:1.5}.twk-panel{z-index:2147483646;color:#29261b;-webkit-backdrop-filter:blur(24px)saturate(160%);backdrop-filter:blur(24px)saturate(160%);background:#faf9f7c7;border:.5px solid #fff9;border-radius:14px;flex-direction:column;width:280px;max-height:calc(100vh - 32px);font:11.5px/1.4 ui-sans-serif,system-ui,-apple-system,sans-serif;display:flex;position:fixed;bottom:16px;right:16px;overflow:hidden;box-shadow:inset 0 1px #ffffff80,0 12px 40px #0000002e}.twk-hd{cursor:move;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 8px 10px 14px;display:flex}.twk-hd b{letter-spacing:.01em;font-size:12px;font-weight:600}.twk-x{appearance:none;color:#29261b8c;cursor:pointer;background:0 0;border:0;border-radius:6px;width:22px;height:22px;font-size:13px;line-height:1}.twk-x:hover{color:#29261b;background:#0000000f}.twk-body{scrollbar-width:thin;scrollbar-color:#00000026 transparent;flex-direction:column;gap:10px;min-height:0;padding:2px 14px 14px;display:flex;overflow:hidden auto}.twk-body::-webkit-scrollbar{width:8px}.twk-body::-webkit-scrollbar-track{background:0 0;margin:2px}.twk-body::-webkit-scrollbar-thumb{background:#00000026 padding-box content-box;border:2px solid #0000;border-radius:4px}.twk-body::-webkit-scrollbar-thumb:hover{background:#00000040 padding-box content-box;border:2px solid #0000}.twk-row{flex-direction:column;gap:5px;display:flex}.twk-row-h{flex-direction:row;justify-content:space-between;align-items:center;gap:10px}.twk-lbl{color:#29261bb8;justify-content:space-between;align-items:baseline;display:flex}.twk-lbl>span:first-child{font-weight:500}.twk-val{color:#29261b80;font-variant-numeric:tabular-nums}.twk-sect{letter-spacing:.06em;text-transform:uppercase;color:#29261b73;padding:10px 0 0;font-size:10px;font-weight:600}.twk-sect:first-child{padding-top:0}.twk-field{appearance:none;box-sizing:border-box;width:100%;min-width:0;height:26px;color:inherit;font:inherit;background:#fff9;border:.5px solid #0000001a;border-radius:7px;outline:none;padding:0 8px}.twk-field:focus{background:#ffffffd9;border-color:#00000040}select.twk-field{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='rgba(0,0,0,.5)' d='M0 0h10L5 6z'/></svg>");background-position:right 8px center;background-repeat:no-repeat;padding-right:22px}.twk-slider{appearance:none;background:#0000001f;border-radius:999px;outline:none;width:100%;height:4px;margin:6px 0}.twk-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#fff;border:.5px solid #0000001f;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 3px #0003}.twk-slider::-moz-range-thumb{cursor:pointer;background:#fff;border:.5px solid #0000001f;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 3px #0003}.twk-seg{-webkit-user-select:none;user-select:none;background:#0000000f;border-radius:8px;padding:2px;display:flex;position:relative}.twk-seg-thumb{background:#ffffffe6;border-radius:6px;transition:left .15s cubic-bezier(.3,.7,.4,1),width .15s;position:absolute;top:2px;bottom:2px;box-shadow:0 1px 2px #0000001f}.twk-seg.dragging .twk-seg-thumb{transition:none}.twk-seg button{appearance:none;z-index:1;color:inherit;font:inherit;cursor:pointer;overflow-wrap:anywhere;background:0 0;border:0;border-radius:6px;flex:1;min-height:22px;padding:4px 6px;font-weight:500;line-height:1.2;position:relative}.twk-toggle{cursor:pointer;background:#00000026;border:0;border-radius:999px;width:32px;height:18px;padding:0;transition:background .15s;position:relative}.twk-toggle[data-on="1"]{background:#34c759}.twk-toggle i{background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #00000040}.twk-toggle[data-on="1"] i{transform:translate(14px)}.twk-chips{gap:6px;display:flex}.twk-chip{appearance:none;cursor:pointer;border:0;border-radius:6px;flex:1;min-width:0;height:46px;padding:0;transition:transform .12s cubic-bezier(.3,.7,.4,1),box-shadow .12s;position:relative;overflow:hidden;box-shadow:0 0 0 .5px #0000001f,0 1px 2px #0000000f}.twk-chip:hover{transform:translateY(-1px);box-shadow:0 0 0 .5px #0000002e,0 4px 10px #0000001f}.twk-chip[data-on="1"]{box-shadow:0 0 0 1.5px #000000d9,0 2px 6px #00000026}.twk-chip>span{flex-direction:column;width:34%;display:flex;position:absolute;top:0;bottom:0;right:0;box-shadow:-1px 0 #0000001a}.twk-chip>span>i{flex:1;box-shadow:0 -1px #0000001a}.twk-chip>span>i:first-child{box-shadow:none}.twk-chip svg{filter:drop-shadow(0 1px 1px #0000004d);width:13px;height:13px;position:absolute;top:6px;left:6px}@media (width<=1180px){.reader{grid-template-columns:250px minmax(0,1fr)}.r-rail{display:none}.r-main{padding:36px 40px 100px}}@media (width<=860px){.hero{grid-template-columns:1fr;gap:30px;padding:44px 0 30px}.hero h1{font-size:44px}.hero-art{display:none}.hb-grid,.features,.reader{grid-template-columns:1fr}.r-nav{display:none}.r-main{padding:28px 22px 80px}.topbar-nav{display:none}.search input{width:150px}.search input:focus{width:170px}}@media (width<=740px){.rm-node,.rm-node.right,.rm-node.left{width:100%;margin-left:0;margin-right:0;padding-left:52px;padding-right:0}.rm-node.right .rm-dot,.rm-node.left .rm-dot{left:-1px;right:auto}.rm-node.right:before,.rm-node.left:before{left:39px;right:auto}.rm-cap{justify-content:flex-start;padding-left:4px}.rm-track:before{left:19px}}
