@font-face{font-family:Ranade Regular;src:url(/wiki/assets/Ranade-Regular-Djk7jf9E.woff2)format("woff2");font-weight:400;font-style:normal}@font-face{font-family:Ranade Bold;src:url(/wiki/assets/Ranade-Bold-D0F2wANm.woff2)format("woff2");font-weight:700;font-style:normal}:root{--accent:#c2603a;--ink:#1f1d1a;--paper:#f6f1e8;--reader-fs:17px;--paper-2:color-mix(in oklab, var(--paper) 92%, var(--ink));--paper-3:color-mix(in oklab, var(--paper) 84%, var(--ink));--ink-2:color-mix(in oklab, var(--ink) 70%, var(--paper));--ink-3:color-mix(in oklab, var(--ink) 45%, var(--paper));--ink-4:color-mix(in oklab, var(--ink) 22%, var(--paper));--rule:color-mix(in oklab, var(--ink) 12%, var(--paper));--rule-2:color-mix(in oklab, var(--ink) 20%, var(--paper));--accent-soft:color-mix(in oklab, var(--accent) 16%, var(--paper));--accent-softer:color-mix(in oklab, var(--accent) 8%, var(--paper));--accent-ink:color-mix(in oklab, var(--accent) 80%, var(--ink));--highlight-bg:color-mix(in oklab, var(--accent) 26%, var(--paper));--shadow-sm:0 1px 2px #0000000a, 0 1px 3px #0000000a;--shadow-md:0 2px 4px #0000000a, 0 8px 24px -8px #0000001f;--shadow-lg:0 4px 8px #0000000f, 0 24px 48px -16px #0000002e;--bx-surface:#fff;--bx-surface-on:#000;--bx-fill:#000;--bx-fill-on:#fff;--bx-border:#000;--bx-shadow:#000;--bx-accent-on:#000;--bx-muted:#888;--bx-highlight:#ffd84a;--bx-highlight-on:#000;--paper-card:var(--bx-surface);--paper-card-2:#fafafa;--paper-card-3:#f3eee3;--frame:var(--bx-border);--frame-soft:#1f1d1a;--stamp:var(--bx-fill);--shadow-stamp:var(--bx-shadow);--hi-amber:var(--bx-highlight);--hi-amber-ink:var(--bx-highlight-on);--hi-cobalt:#296fbb;--hi-emerald:#2a9d3a;--hi-rose:#d11919;--hi-grape:#7a3fbf}[data-theme=dark]{--paper:#15140f;--ink:#f3ede0;--paper-2:color-mix(in oklab, var(--paper) 88%, var(--ink));--paper-3:color-mix(in oklab, var(--paper) 78%, var(--ink));--rule:color-mix(in oklab, var(--ink) 18%, var(--paper));--rule-2:color-mix(in oklab, var(--ink) 28%, var(--paper));--accent-soft:color-mix(in oklab, var(--accent) 22%, var(--paper));--shadow-md:0 2px 4px #0000004d, 0 8px 24px -8px #00000080;--bx-surface:#1f1c17;--bx-surface-on:#e8e3d8;--bx-fill:#e8e3d8;--bx-fill-on:#15140f;--bx-border:#5a5550;--bx-shadow:#0009;--bx-accent-on:#15140f;--bx-muted:#807a70;--bx-highlight:#3d3520;--bx-highlight-on:#d4c896;--paper-card-2:#25221c;--paper-card-3:#2a2620;--frame-soft:#e8e3d8}[data-fontpair=fraunces]{--f-display:"Fraunces", Georgia, serif;--f-body:"Arial", system-ui, sans-serif;--f-mono:"JetBrains Mono", ui-monospace, monospace}[data-fontpair=chewy]{--f-display:"Chewy", "Fraunces", Georgia, serif;--f-body:"Arial", system-ui, sans-serif;--f-mono:"JetBrains Mono", ui-monospace, monospace}[data-fontpair=patrick-hand]{--f-display:"Patrick Hand", "Fraunces", cursive;--f-body:"Arial", system-ui, sans-serif;--f-mono:"JetBrains Mono", ui-monospace, monospace}[data-density=compact]{--gap:14px;--pad:18px;--line:1.55}[data-density=regular]{--gap:20px;--pad:28px;--line:1.7}[data-density=comfy]{--gap:28px;--pad:40px;--line:1.85}*{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden}body{background:var(--paper);color:var(--ink);font-family:var(--f-body);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:14px}::selection{background:var(--highlight-bg);color:var(--ink)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:color-mix(in oklab, var(--ink) 18%, transparent);background-clip:padding-box;border:2px solid #0000;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:color-mix(in oklab, var(--ink) 30%, transparent);background-clip:padding-box;border:2px solid #0000}.sidebar{border-right:4px solid var(--bx-border);background:var(--bx-surface);flex-direction:column;height:100vh;font-family:Arial,sans-serif;transition:transform .3s cubic-bezier(.3,.7,.4,1);display:flex;position:sticky;top:0;overflow:hidden}.sidebar-head{border-bottom:4px solid var(--bx-border);background:var(--accent);justify-content:space-between;align-items:center;padding:18px 18px 14px;display:flex}.brand{align-items:center;gap:10px;display:flex}.brand-mark{background:var(--bx-fill);width:36px;height:36px;color:var(--bx-fill-on);border:2px solid var(--bx-border);box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;place-items:center;display:grid}.brand-mark svg{width:18px;height:18px}.brand-title{letter-spacing:-.01em;text-transform:uppercase;color:var(--bx-accent-on);font-family:Arial,sans-serif;font-size:16px;font-weight:900}.brand-sub{color:var(--bx-accent-on);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:700}.icon-btn{appearance:none;border:2px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);cursor:pointer;width:32px;height:32px;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;place-items:center;transition:transform .15s,box-shadow .15s,background .15s;display:grid}.icon-btn:hover{background:var(--bx-fill);color:var(--bx-fill-on);box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.icon-btn:active{box-shadow:none;transform:translate(3px,3px)}.icon-btn svg{width:16px;height:16px}.course-card{border-bottom:4px solid var(--bx-border);background:var(--bx-surface);padding:18px}.course-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-surface-on);font-size:11px;font-weight:900}.course-title{letter-spacing:-.01em;text-wrap:balance;text-transform:uppercase;color:var(--bx-surface-on);margin:6px 0 4px;font-family:Arial,sans-serif;font-size:22px;font-weight:900;line-height:1.1}.course-author{color:var(--bx-surface-on);margin-bottom:14px;font-size:12px;font-weight:700}.progress-track{background:var(--bx-surface);border:3px solid var(--bx-border);border-radius:0;height:12px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:0;height:100%;transition:width .35s cubic-bezier(.3,.7,.4,1)}.progress-meta{color:var(--bx-surface-on);text-transform:uppercase;letter-spacing:.06em;justify-content:space-between;margin-top:8px;font-size:11px;font-weight:700;display:flex}.progress-meta strong{color:var(--bx-surface-on);font-weight:900}.search{border-bottom:4px solid var(--bx-border);background:var(--bx-surface);padding:14px 18px;position:relative}.search input{border:3px solid var(--bx-border);background:var(--bx-surface);width:100%;color:var(--bx-surface-on);box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;outline:none;padding:10px 10px 10px 32px;font-family:Arial,sans-serif;font-size:13px;font-weight:700;transition:box-shadow .15s}.search input::placeholder{color:var(--bx-muted);font-weight:500}.search input:focus{box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-1px,-1px)}.search-ic{width:14px;height:14px;color:var(--bx-surface-on);pointer-events:none;position:absolute;top:50%;left:28px;transform:translateY(-50%)}.toc{scrollbar-width:thin;background:var(--bx-surface);flex:1;padding:10px 10px 24px;overflow-y:auto}.toc-sec{margin:6px 0}.toc-sec-head{border:3px solid var(--bx-border);background:var(--bx-surface);cursor:pointer;text-align:left;width:100%;color:var(--bx-surface-on);box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:10px 12px;font-family:Arial,sans-serif;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s;display:grid}.toc-sec-head:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.toc-sec.is-active .toc-sec-head{background:var(--accent);color:var(--bx-accent-on)}.toc-num{font-feature-settings:"tnum";color:var(--bx-surface-on);letter-spacing:.04em;font-family:Arial,sans-serif;font-size:12px;font-weight:900}.toc-title{text-transform:uppercase;letter-spacing:.04em;font-size:13px;font-weight:900}.toc-count{color:var(--bx-surface-on);font-feature-settings:"tnum";background:var(--bx-surface);border:2px solid var(--bx-border);border-radius:0;padding:2px 6px;font-size:11px;font-weight:900}.toc-count.done{background:var(--bx-fill);color:var(--bx-fill-on);border-color:var(--bx-border)}.toc-chev{width:12px;height:12px;color:var(--bx-surface-on);transition:transform .2s}.toc-chev.open{transform:rotate(90deg)}.toc-notes{border-left:3px solid var(--bx-border);margin:4px 0 8px 22px;padding:0 0 0 10px;list-style:none}.toc-note{align-items:center;gap:6px;padding:4px 4px 4px 0;display:flex;position:relative}.toc-tick{appearance:none;border:2px solid var(--bx-border);background:var(--bx-surface);cursor:pointer;width:24px;height:24px;color:var(--bx-surface-on);box-shadow:2px 2px 0 var(--bx-shadow);border-radius:0;place-items:center;transition:transform .15s,box-shadow .15s,background .15s;display:grid}.toc-tick:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:3px 3px 0 var(--bx-shadow);transform:translate(-1px,-1px)}.toc-tick svg{width:13px;height:13px}.toc-note-btn{appearance:none;border:2px solid var(--bx-border);background:var(--bx-surface);text-align:left;cursor:pointer;color:var(--bx-surface-on);box-shadow:2px 2px 0 var(--bx-shadow);border-radius:0;flex-direction:column;flex:1;gap:2px;padding:7px 10px;font-family:Arial,sans-serif;transition:transform .15s,box-shadow .15s,background .15s;display:flex}.toc-note-btn:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:3px 3px 0 var(--bx-shadow);transform:translate(-1px,-1px)}.toc-note.current .toc-note-btn{background:var(--bx-fill);color:var(--bx-fill-on)}.toc-note-title{font-size:12.5px;font-weight:700}.toc-note-kind{color:var(--bx-surface-on);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:900}.toc-note.current .toc-note-kind{color:var(--accent)}.toc-mark{width:11px;height:11px;color:var(--bx-surface-on)}.toc-search-results{padding:6px}.toc-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-surface-on);padding:8px 10px;font-size:11px;font-weight:900}.toc-result{text-align:left;appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);cursor:pointer;width:100%;color:var(--bx-surface-on);box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;flex-direction:column;gap:2px;margin-bottom:6px;padding:8px 10px;font-family:Arial,sans-serif;transition:transform .15s,box-shadow .15s,background .15s;display:flex}.toc-result:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.toc-result-sec{color:var(--bx-surface-on);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:900}.toc-result-note{font-size:13px;font-weight:700}.toc-empty{text-align:center;color:var(--bx-surface-on);padding:14px;font-size:12px;font-weight:700}.sidebar-info{border-top:4px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);font-family:Arial,sans-serif}.info-toggle{appearance:none;background:var(--bx-surface);width:100%;color:var(--bx-surface-on);cursor:pointer;letter-spacing:.12em;text-transform:uppercase;border:0;justify-content:space-between;align-items:center;gap:10px;padding:12px 18px;font-family:Arial,sans-serif;font-size:11px;font-weight:900;transition:background .15s,color .15s;display:flex}.info-toggle:hover{background:var(--accent);color:var(--bx-accent-on)}.sidebar-info.is-open .info-toggle{background:var(--bx-fill);color:var(--bx-fill-on)}.info-toggle-chev{width:12px;height:12px;transition:transform .2s;transform:rotate(90deg)}.info-toggle-chev.open{transform:rotate(-90deg)}.info-body{border-top:2px solid var(--bx-border);flex-direction:column;gap:14px;padding:14px 18px 18px;animation:.2s ease-out infoSlide;display:flex}@keyframes infoSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.info-block{flex-direction:column;gap:4px;display:flex}.info-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--bx-surface-on);opacity:.7;margin-bottom:4px;font-size:10px;font-weight:900}.info-course{text-transform:uppercase;letter-spacing:.02em;font-size:12px;font-weight:900;line-height:1.25}.info-prof{color:var(--bx-surface-on);opacity:.85;font-size:11px;font-weight:700;line-height:1.3}.info-authors{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.info-author-link,.info-repo{border:2px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);box-shadow:2px 2px 0 var(--bx-shadow);align-items:center;gap:8px;padding:8px 10px;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s,background .15s,color .15s;display:flex}.info-author-link:hover,.info-repo:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:4px 4px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.info-author-link:active,.info-repo:active{box-shadow:0 0 0 var(--bx-shadow);transform:translate(2px,2px)}.info-gh{flex-shrink:0;width:16px;height:16px}.info-author-meta{flex-direction:column;min-width:0;line-height:1.15;display:flex}.info-author-name{text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:900;overflow:hidden}.info-author-user{opacity:.75;font-family:JetBrains Mono,ui-monospace,monospace;font-size:10.5px;font-weight:700}.info-repo{text-transform:uppercase;letter-spacing:.08em;justify-content:center;padding:10px;font-size:11px;font-weight:900}.dot,.dot-faint{background:var(--accent);border-radius:50%;width:6px;height:6px;display:inline-block}.dot{animation:2.4s ease-in-out infinite pulse}.dot-faint{background:var(--ink-4)}@keyframes pulse{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}@media (width<=880px){.sidebar{z-index:30;width:min(300px,86vw);position:fixed}.app:not(.sidebar-closed) .sidebar{box-shadow:0 0 40px #0003}.sidebar-head{padding:14px 16px 12px}.brand-title{font-size:14px}.brand-sub{font-size:10px}.course-card{padding:14px 16px}.course-eyebrow{font-size:10px}.course-title{margin:4px 0 2px;font-size:17px}.course-author{margin-bottom:10px;font-size:11px}.progress-track{height:8px}.progress-meta{font-size:10px}.search{padding:10px 16px}.search input{box-shadow:2px 2px 0 var(--bx-shadow);padding:8px 10px 8px 30px;font-size:12px}.search-ic{left:26px}.toc{padding:8px 10px 18px}.toc-sec-head{box-shadow:2px 2px 0 var(--bx-shadow);grid-template-columns:auto 1fr auto auto;gap:8px;padding:8px 10px}.toc-num{font-size:11px}.toc-title{font-size:12px;line-height:1.25}.toc-count{padding:2px 5px;font-size:10px}.toc-chev{width:10px;height:10px}.toc-notes{margin-left:18px;padding-left:8px}.toc-note{padding:3px 4px 3px 0}.toc-tick{width:20px;height:20px}.toc-tick svg{width:11px;height:11px}.toc-note-btn{box-shadow:2px 2px 0 var(--bx-shadow);padding:6px 8px}.toc-note-title{font-size:12px;line-height:1.3}.toc-note-kind{font-size:9px}.sidebar-foot{padding:10px 16px;font-size:10px}}@media (width<=480px){.sidebar{width:min(280px,84vw)}.course-title{font-size:16px}.toc-title{font-size:11.5px}}.twk-toggle-btn{z-index:100;appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);width:44px;height:44px;color:var(--bx-surface-on);cursor:pointer;box-shadow:4px 4px 0 var(--bx-shadow);border-radius:0;place-items:center;font-family:Arial,sans-serif;font-size:18px;font-weight:900;transition:transform .15s,box-shadow .15s,background .15s;display:grid;position:fixed;bottom:16px;right:16px}.twk-toggle-btn:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:6px 6px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.twk-toggle-btn:active{box-shadow:1px 1px 0 var(--bx-shadow);transform:translate(2px,2px)}.twk-panel{z-index:99;background:var(--bx-surface);border:4px solid var(--bx-border);width:280px;max-height:calc(100vh - 100px);box-shadow:8px 8px 0 var(--bx-shadow);border-radius:0;flex-direction:column;font-family:Arial,sans-serif;font-size:12px;display:flex;position:fixed;bottom:70px;right:16px;overflow:hidden}.twk-panel-head{border-bottom:3px solid var(--bx-border);letter-spacing:.1em;text-transform:uppercase;color:var(--bx-accent-on);background:var(--accent);justify-content:space-between;align-items:center;padding:12px 14px;font-size:11px;font-weight:900;display:flex}.twk-panel-body{flex-direction:column;gap:14px;padding:14px;display:flex;overflow-y:auto}.twk-section{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-surface-on);border-bottom:2px solid var(--bx-border);padding-bottom:4px;font-size:10px;font-weight:900}.twk-row{flex-direction:column;gap:6px;display:flex}.twk-row-h{flex-direction:row;justify-content:space-between;align-items:center}.twk-label{color:var(--bx-surface-on);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.twk-value{color:var(--bx-surface-on);font-feature-settings:"tnum";font-size:10.5px;font-weight:900}.twk-chips{gap:8px;display:flex}.twk-chip{border:3px solid var(--bx-border);cursor:pointer;height:34px;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;flex:1;padding:0;transition:transform .15s,box-shadow .15s;position:relative}.twk-chip:hover{box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.twk-chip[aria-checked=true]{box-shadow:1px 1px 0 var(--bx-shadow);border-width:4px;transform:translate(2px,2px)}.twk-toggle{border:3px solid var(--bx-border);background:var(--bx-surface);cursor:pointer;width:40px;height:22px;box-shadow:2px 2px 0 var(--bx-shadow);border-radius:0;padding:0;transition:background .15s;position:relative}.twk-toggle[data-on=true]{background:var(--accent)}.twk-toggle:after{content:"";background:var(--bx-fill);border-radius:0;width:12px;height:12px;transition:transform .15s;position:absolute;top:1px;left:1px}.twk-toggle[data-on=true]:after{transform:translate(18px)}.twk-select{appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);width:100%;height:32px;color:var(--bx-surface-on);font:inherit;box-shadow:3px 3px 0 var(--bx-shadow);cursor:pointer;border-radius:0;padding:0 10px;font-size:12px;font-weight:700}.twk-slider{width:100%;accent-color:var(--accent)}.twk-seg{background:0 0;border-radius:0;gap:4px;padding:0;display:flex}.twk-seg button{appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);font:inherit;cursor:pointer;text-transform:uppercase;letter-spacing:.04em;box-shadow:2px 2px 0 var(--bx-shadow);border-radius:0;flex:1;padding:6px 8px;font-size:11px;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s}.twk-seg button:hover{box-shadow:3px 3px 0 var(--bx-shadow);transform:translate(-1px,-1px)}.twk-seg button[aria-checked=true]{background:var(--bx-fill);color:var(--bx-fill-on);font-weight:900}@media (width<=640px){.twk-toggle-btn{width:40px;height:40px;bottom:12px;right:12px}.twk-panel{width:auto;max-height:70vh;bottom:60px;left:12px;right:12px}}.app{background:var(--paper);grid-template-columns:320px 1fr;height:100vh;transition:grid-template-columns .3s cubic-bezier(.3,.7,.4,1);display:grid}.app.sidebar-closed,.app.focus{grid-template-columns:0 1fr}.app.focus .sidebar,.app.sidebar-closed .sidebar{transform:translate(-100%)}.app-scrim{z-index:28;cursor:pointer;background:#00000059;border:0;padding:0;animation:.2s ease-out scrimIn;position:fixed;inset:0}@keyframes scrimIn{0%{opacity:0}to{opacity:1}}@media (width>=1280px){.app{grid-template-columns:340px 1fr}}@media (width<=1100px){.app{grid-template-columns:280px 1fr}}@media (width<=880px){.app,.app.sidebar-closed,.app.focus{grid-template-columns:1fr}}.minimap{background:var(--bx-surface);border:3px solid var(--bx-border);box-shadow:4px 4px 0 var(--bx-shadow);border-radius:0;align-items:center;gap:10px;padding:8px 14px;display:flex}.mm-sec{gap:5px;padding:0 6px;display:flex;position:relative}.mm-sec+.mm-sec:before{content:"";background:var(--bx-border);width:6px;height:3px;position:absolute;top:50%;left:-7px;transform:translateY(-50%)}.mm-dot{border:2px solid var(--bx-border);background:var(--bx-surface);appearance:none;cursor:pointer;border-radius:0;width:10px;height:10px;padding:0;transition:transform .15s,background .15s,width .2s}.mm-dot:hover{background:var(--accent);transform:scale(1.4)}.mm-dot.done{background:var(--accent)}.mm-dot.curr{background:var(--bx-fill);border-radius:0;width:22px}.mm-dot.done.curr{background:var(--accent);border-color:var(--bx-border)}@media (width<=1280px){.minimap{display:none}}.topbar{z-index:10;background:var(--bx-surface);border-bottom:4px solid var(--bx-border);grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:14px 32px;font-family:Arial,sans-serif;display:grid;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;min-width:0;display:flex}.topbar-right{justify-content:flex-end;align-items:center;gap:10px;display:flex}.crumbs{color:var(--bx-surface-on);text-transform:uppercase;letter-spacing:.04em;align-items:baseline;gap:8px;min-width:0;font-size:12.5px;font-weight:700;display:flex}.crumb-num{color:var(--bx-accent-on);background:var(--accent);border:2px solid var(--bx-border);padding:2px 6px;font-family:Arial,sans-serif;font-weight:900}.crumb-sec{color:var(--bx-surface-on);font-weight:900}.crumb-sep{color:var(--bx-surface-on)}.crumb-note{color:var(--bx-surface-on);white-space:nowrap;text-overflow:ellipsis;flex:0 auto;min-width:0;font-weight:900;overflow:hidden}.crumbs{flex-wrap:nowrap}.crumb-sec,.crumb-note{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.meta-pill{color:var(--bx-surface-on);background:var(--bx-surface);border:3px solid var(--bx-border);box-shadow:3px 3px 0 var(--bx-shadow);font-feature-settings:"tnum";text-transform:uppercase;letter-spacing:.06em;border-radius:0;align-items:center;gap:6px;padding:6px 10px;font-size:11.5px;font-weight:900;display:inline-flex}.meta-pill svg{width:12px;height:12px}.btn-ghost{appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);cursor:pointer;box-shadow:3px 3px 0 var(--bx-shadow);text-transform:uppercase;letter-spacing:.06em;border-radius:0;align-items:center;gap:6px;padding:6px 14px;font-family:Arial,sans-serif;font-size:12px;font-weight:900;transition:transform .15s,box-shadow .15s,background .15s,color .15s;display:inline-flex}.btn-ghost:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.btn-ghost:active{box-shadow:1px 1px 0 var(--bx-shadow);transform:translate(2px,2px)}.btn-ghost.active{background:var(--bx-fill);color:var(--bx-fill-on)}.btn-ghost svg{width:13px;height:13px}@media (width<=1280px){.topbar{grid-template-columns:1fr auto;gap:12px;padding:12px 22px}.crumb-sec{max-width:140px}.crumb-note{max-width:220px}}@media (width<=1100px){.topbar{grid-template-columns:1fr auto}.crumb-sec,.crumb-sep{display:none}}@media (width<=880px){.topbar{padding:12px 18px}.topbar-right{gap:6px}.btn-ghost{padding:6px 10px;font-size:11px}.meta-pill{padding:5px 8px;font-size:11px}}@media (width<=560px){.topbar{grid-template-columns:auto 1fr auto;gap:10px;padding:10px 14px}.crumbs{flex-wrap:wrap;gap:6px;font-size:11px}.crumb-num{padding:1px 5px}.topbar-right{gap:4px}.btn-ghost{padding:6px 8px;font-size:0}.btn-ghost svg{width:14px;height:14px}.btn-ghost svg+*{display:none}.meta-pill{padding:4px 7px;font-size:10px}}@media (width<=380px){.crumb-sec,.crumb-sep{display:none}}.hero{background:var(--accent);border:4px solid var(--bx-border);box-shadow:10px 10px 0 var(--bx-shadow);border-radius:0;grid-template-columns:auto 1fr;align-items:center;gap:60px;margin:16px 0 44px;padding:36px 32px;font-family:Arial,sans-serif;display:grid;position:relative;overflow:hidden}.hero-bg{pointer-events:none;z-index:0;position:absolute;inset:0}.hero-grid{background-image:linear-gradient(to right, color-mix(in oklab, var(--ink) 6%, transparent) 1px, transparent 1px), linear-gradient(to bottom, color-mix(in oklab, var(--ink) 6%, transparent) 1px, transparent 1px);background-size:32px 32px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 80% 30%,#000 30%,#0000 75%);mask-image:radial-gradient(at 80% 30%,#000 30%,#0000 75%)}.hero-glow{background:radial-gradient(circle, var(--accent-soft) 0%, transparent 60%);filter:blur(40px);opacity:.8;width:60%;height:200%;position:absolute;top:-40%;right:-10%}.hero-num{z-index:1;color:var(--bx-accent-on);letter-spacing:-.05em;font-feature-settings:"lnum";font-family:Arial,sans-serif;font-size:132px;font-weight:900;line-height:.85;position:relative}.hero-num-bg{color:#0000;-webkit-text-stroke:2.5px var(--bx-accent-on);opacity:.35;position:absolute;inset:0;transform:translate(6px,6px)}.hero-num-fg{position:relative}.hero-meta{z-index:1;min-width:0;position:relative}.hero-chips{flex-wrap:wrap;justify-content:space-between;gap:6px;margin-bottom:15px;display:flex}.chip{background:var(--bx-surface);border:3px solid var(--bx-border);color:var(--bx-surface-on);letter-spacing:.06em;text-transform:uppercase;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:900;display:inline-flex}.chip svg{width:12px;height:12px}.chip-sec{background:var(--bx-fill);color:var(--bx-fill-on);letter-spacing:.08em;font-family:Arial,sans-serif}.chip-time{color:var(--bx-surface-on)}.chip-prog{font-feature-settings:"tnum";color:var(--bx-surface-on);padding-left:8px}.chip-prog-track{background:var(--bx-surface);border:2px solid var(--bx-border);border-radius:0;width:40px;height:6px;margin-right:4px;display:inline-block;overflow:hidden}.chip-prog-fill{background:var(--bx-fill);border-radius:0;height:100%;display:block}.hero-title{font-family:var(--f-display);letter-spacing:-.025em;text-wrap:balance;text-transform:uppercase;color:var(--bx-accent-on);margin:0 0 12px;font-size:clamp(32px,4vw,48px);font-weight:900;line-height:1.02}.hero-sum{color:var(--bx-surface-on);background:var(--bx-surface);border:3px solid var(--bx-border);max-width:56ch;box-shadow:5px 5px 0 var(--bx-shadow);margin:0;padding:12px 14px;font-family:Arial,sans-serif;font-size:16px;font-weight:600;line-height:1.5}@media (width<=880px){.hero{box-shadow:6px 6px 0 var(--bx-shadow);grid-template-columns:1fr;gap:16px;padding:24px 20px}.hero-num{font-size:88px}.hero-title{font-size:30px}}@media (width<=480px){.hero{box-shadow:4px 4px 0 var(--bx-shadow);border-width:3px;margin:8px 0 28px;padding:18px 14px}.hero-num{font-size:64px}.hero-title{font-size:22px}.hero-sum{box-shadow:3px 3px 0 var(--bx-shadow);padding:10px 12px;font-size:13px}.hero-chips{justify-content:flex-start;gap:4px;margin-bottom:10px}.chip{box-shadow:2px 2px 0 var(--bx-shadow);padding:4px 8px;font-size:10px}}.note{margin-bottom:36px}.note-card{background:var(--bx-surface);border:4px solid var(--bx-border);box-shadow:10px 10px 0 var(--bx-shadow);font-family:var(--f-display);border-radius:0;position:relative;overflow:hidden}.note-ribbon{background:var(--bx-fill);color:var(--bx-fill-on);letter-spacing:.14em;text-transform:uppercase;border:3px solid var(--bx-border);box-shadow:5px 5px 0 var(--bx-shadow);z-index:2;border-left:0;align-items:center;gap:8px;padding:8px 18px;font-family:Arial,sans-serif;font-size:11px;font-weight:900;display:inline-flex;position:absolute;top:18px;left:-4px}.note-ribbon svg{width:14px;height:14px}.ribbon-concepto{background:var(--hi-cobalt);color:#fff}.ribbon-ejercicio{background:var(--hi-emerald);color:#fff}.ribbon-referencia{background:var(--hi-amber);color:var(--hi-amber-ink)}.ribbon-diagrama{background:var(--hi-grape);color:#fff}.ribbon-sintesis{background:var(--hi-rose);color:#fff}.note-head{background-color:var(--accent);border-bottom:4px solid var(--bx-border);grid-template-rows:auto auto;grid-template-columns:auto 1fr auto;align-items:center;gap:10px 22px;padding:70px 30px 26px;display:grid}.note-counter{font-family:var(--f-display);flex-direction:column;grid-area:1/1/span 2;align-self:start;align-items:center;padding-top:4px;line-height:1;display:flex}.counter-num{color:var(--bx-surface-on);letter-spacing:-.02em;font-feature-settings:"lnum";background:var(--bx-surface);border:3px solid var(--bx-border);box-shadow:4px 4px 0 var(--bx-shadow);padding:4px 10px;font-size:42px;font-weight:900}.counter-of{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-highlight-on);margin-top:8px;font-family:Arial,sans-serif;font-size:10px;font-weight:900}.note-title{color:var(--bx-highlight-on);font-family:var(--f-display);letter-spacing:-.02em;text-wrap:balance;text-transform:uppercase;grid-area:1/2/span 2;margin:0;font-size:32px;font-weight:900;line-height:1.05}.note-tools{grid-area:1/3/span 2;align-items:center;gap:8px;display:flex}.tool-btn{appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);cursor:pointer;width:38px;height:38px;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;place-items:center;transition:transform .15s,box-shadow .15s;display:grid}.tool-btn:hover{box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.tool-btn:active{box-shadow:none;transform:translate(3px,3px)}.tool-btn[aria-pressed=true]{background:var(--bx-fill);color:var(--bx-fill-on)}.tool-btn svg{width:16px;height:16px}.tool-done{appearance:none;border:3px solid var(--bx-border);background:var(--bx-surface);color:var(--bx-surface-on);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;height:38px;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;align-items:center;gap:8px;padding:0 16px;font-family:Arial,sans-serif;font-size:12px;font-weight:900;transition:transform .15s,box-shadow .15s,background .15s;display:inline-flex}.tool-done:hover{box-shadow:5px 5px 0 var(--bx-shadow);background:var(--accent);color:var(--paper);transform:translate(-2px,-2px)}.tool-done:active{box-shadow:none;transform:translate(3px,3px)}.tool-done.is-done{background:var(--bx-fill);color:var(--bx-fill-on);border-color:var(--bx-border)}.tool-done.is-done:hover{background:var(--hi-emerald);color:var(--paper);border-color:var(--bx-border)}.tool-done svg{width:14px;height:14px}.note-body{font-size:var(--reader-fs);line-height:var(--line);--rhythm:var(--gap);--rhythm-tight:calc(var(--gap) * .55);--rhythm-section:calc(var(--gap) * 1.5);--rhythm-block:calc(var(--gap) * 1.25);padding:36px 30px 18px}.note-body>*{margin:0}.note-body>*+*{margin-top:var(--rhythm)}.note-body>:first-child{margin-top:0}.note-body>.prose-title+*,.note-body>.prose-title-h2+*,.note-body>.prose-title-h3+*,.note-body>.prose-title-h4+*{margin-top:var(--rhythm-tight)}.note-body>*+.prose-title,.note-body>*+.prose-title-h2,.note-body>*+.prose-title-h3,.note-body>*+.prose-title-h4{margin-top:var(--rhythm-section)}.note-body>.quote-card-wrap,.note-body>.prose-table-wrap,.note-body>.thinkers,.note-body>.diagram,.note-body>.card-wrap,.note-body>.proc-fan,.note-body>.fork-tree,.note-body>.fan-wrap,.note-body>.wt-wrap,.note-body>.wpm-wrap,.note-body>.cow-wrap,.note-body>.code-explain,.note-body>.zf-wrap,.note-body>.quote-card-wrap+*,.note-body>.prose-table-wrap+*,.note-body>.thinkers+*,.note-body>.diagram+*,.note-body>.card-wrap+*,.note-body>.proc-fan+*,.note-body>.fork-tree+*,.note-body>.fan-wrap+*,.note-body>.wt-wrap+*,.note-body>.wpm-wrap+*,.note-body>.cow-wrap+*,.note-body>.code-explain+*,.note-body>.zf-wrap+*{margin-top:var(--rhythm-block)}.note-body>.prose-p+.prose-p{margin-top:calc(var(--rhythm) * .55)}.note-body>.prose-p:first-child:first-letter{font-family:var(--f-display);float:left;color:var(--accent);letter-spacing:-.02em;margin:.04em .12em -.08em 0;font-size:4.2em;font-weight:500;line-height:.88}.note-foot{border-top:4px solid var(--bx-border);background:var(--bx-surface);padding:18px 30px 26px}.own-prompt{appearance:none;background:var(--bx-surface);width:100%;color:var(--bx-surface-on);cursor:pointer;border:3px solid var(--bx-border);text-align:left;text-transform:uppercase;letter-spacing:.06em;box-shadow:5px 5px 0 var(--bx-shadow);border-radius:0;align-items:center;gap:12px;padding:14px 18px;font-family:Arial,sans-serif;font-size:13px;font-weight:900;transition:transform .2s,box-shadow .2s,background .2s,color .2s;display:flex}.own-prompt:hover{background:var(--accent);color:var(--paper);box-shadow:7px 7px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.own-prompt:active{box-shadow:none;transform:translate(5px,5px)}.own-prompt>span{flex:1}.own-prompt>svg:first-child{width:16px;height:16px}.own-prompt>svg:last-child{width:16px;height:16px;transition:transform .2s}.own-prompt:hover>svg:last-child{transform:translate(4px)}@media (width<=880px){.note-head{gap:8px 16px;padding:60px 20px 20px}.note-title{font-size:24px}.note-body,.note-foot{padding-left:20px;padding-right:20px}.note-card{box-shadow:6px 6px 0 var(--bx-shadow)}}@media (width<=640px){.note-head{grid-template-rows:auto auto auto;grid-template-columns:auto 1fr;gap:6px 12px;padding:56px 16px 18px}.note-counter{grid-area:1/1}.counter-num{padding:2px 8px;font-size:32px}.counter-of{margin-top:4px;font-size:9px}.note-title{grid-area:1/2;font-size:20px}.note-tools{flex-wrap:wrap;grid-area:2/1/auto/-1;gap:6px}.tool-btn{width:34px;height:34px}.tool-done{height:34px;padding:0 12px;font-size:11px}.note-body{padding:24px 16px 14px;font-size:15px}.note-foot{padding:14px 16px 20px}.own-prompt{padding:12px 14px;font-size:12px}.note-ribbon{padding:6px 14px;font-size:10px;top:14px}.note-card{box-shadow:4px 4px 0 var(--bx-shadow);border-width:3px}}@media (width<=380px){.note-title{font-size:18px}.counter-num{font-size:26px}.note-body>.prose-p:first-child:first-letter{font-size:3.4em}}.navrow{grid-template-columns:1fr 1fr;gap:14px;margin-top:36px;display:grid}.nav-btn{appearance:none;border:4px solid var(--bx-border);background:var(--bx-surface);cursor:pointer;text-align:left;color:var(--bx-surface-on);min-height:100px;box-shadow:6px 6px 0 var(--bx-shadow);border-radius:0;flex-direction:column;gap:6px;padding:18px 20px;font-family:Arial,sans-serif;transition:transform .2s,box-shadow .2s,background .2s;display:flex;position:relative;overflow:hidden}.nav-btn:not(:disabled):hover{box-shadow:9px 9px 0 var(--bx-shadow);background:var(--accent);color:var(--bx-accent-on);transform:translate(-3px,-3px)}.nav-btn:not(:disabled):active{box-shadow:none;transform:translate(4px,4px)}.nav-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:3px 3px 0 var(--bx-shadow);background:0 0}.nav-next{text-align:right;align-items:flex-end}.nav-dir{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-accent-on);background:var(--accent);border:2px solid var(--bx-border);align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:900;display:inline-flex;position:relative}.nav-dir svg{width:11px;height:11px}.nav-title{text-wrap:balance;text-transform:uppercase;font-family:Arial,sans-serif;font-size:18px;font-weight:900;line-height:1.18;position:relative}.nav-sec{color:var(--bx-surface-on);text-transform:uppercase;letter-spacing:.06em;font-size:11.5px;font-weight:700;position:relative}@media (width<=880px){.navrow{grid-template-columns:1fr}}@media (width<=480px){.navrow{gap:10px;margin-top:24px}.nav-btn{min-height:80px;box-shadow:4px 4px 0 var(--bx-shadow);border-width:3px;padding:14px 16px}.nav-title{font-size:15px}.nav-sec{font-size:11px}}.fab-rail{z-index:15;background:var(--bx-surface);border:4px solid var(--bx-border);box-shadow:6px 6px 0 var(--bx-shadow);border-radius:0;flex-direction:column;gap:10px;padding:10px;font-family:Arial,sans-serif;display:flex;position:fixed;bottom:90px;right:24px}.fab{appearance:none;background:var(--bx-surface);width:44px;height:44px;color:var(--bx-surface-on);border:3px solid var(--bx-border);cursor:pointer;box-shadow:3px 3px 0 var(--bx-shadow);border-radius:0;place-items:center;transition:transform .15s,box-shadow .15s,background .15s,color .15s;display:grid;position:relative}.fab:hover{background:var(--accent);color:var(--bx-accent-on);box-shadow:5px 5px 0 var(--bx-shadow);transform:translate(-2px,-2px)}.fab:active{box-shadow:none;transform:translate(3px,3px)}.fab svg{width:18px;height:18px}.fab-done{background:var(--bx-fill);color:var(--bx-fill-on)}.fab-done:hover,.fab-mark,.fab-has{background:var(--accent);color:var(--bx-accent-on)}.fab-pip{border:2px solid var(--bx-border);background:red;border-radius:0;width:12px;height:12px;position:absolute;top:-5px;right:-5px}@media (width<=880px){.fab-rail{border-radius:0;flex-direction:row;gap:8px;padding:8px;bottom:14px;left:14px;right:auto}}@media (width<=480px){.fab-rail{box-shadow:4px 4px 0 var(--bx-shadow);border-width:3px;gap:6px;padding:6px}.fab{width:38px;height:38px}.fab svg{width:16px;height:16px}}.notes-panel{z-index:25;background:var(--bx-surface);flex-direction:column;width:380px;height:100vh;font-family:Arial,sans-serif;animation:.25s cubic-bezier(.3,.7,.4,1) slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-10px 0 #0000001f,-18px 0 40px -10px #00000040}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.notes-head{background-color:var(--accent);justify-content:space-between;align-items:flex-start;gap:12px;padding:22px;display:flex;box-shadow:0 4px #00000026}.icon-btn{color:var(--bx-surface-on);background:var(--bx-surface);border-radius:12px;transition:transform .15s,box-shadow .15s,background .15s;box-shadow:3px 3px #00000040}.icon-btn:hover{background-color:var(--bx-surface);color:var(--bx-surface-on);transform:translate(-2px,-2px);box-shadow:5px 5px #0000004d}.icon-btn:active{transform:translate(2px,2px);box-shadow:1px 1px #0003}.notes-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--bx-accent-on);opacity:.65;font-size:11px;font-weight:900}.notes-on{letter-spacing:-.01em;text-wrap:balance;color:var(--bx-accent-on);text-transform:uppercase;margin-top:6px;font-family:Arial,sans-serif;font-size:22px;font-weight:900}.notes-area{resize:none;color:var(--bx-surface-on);background:0 0;border:0;outline:none;flex:1;padding:22px;font-family:Arial,sans-serif;font-size:15px;font-weight:600;line-height:1.6}.notes-area::placeholder{color:var(--bx-muted);font-style:italic;font-weight:500}.notes-foot{color:var(--bx-surface-on);background:var(--bx-surface);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:8px;padding:14px 22px;font-size:11px;font-weight:900;display:flex;box-shadow:0 -3px #0000001a}@media (width<=880px){.notes-panel{width:100%;box-shadow:none}}@media (width<=480px){.notes-head{padding:16px}.notes-on{font-size:18px}.notes-area{padding:16px;font-size:14px}.notes-foot{padding:10px 16px;font-size:10px}}.reader{scroll-behavior:smooth;flex-direction:column;min-width:0;height:100vh;display:flex;position:relative;overflow-y:auto}.read-progress{z-index:11;background:var(--bx-surface);border-bottom:3px solid var(--bx-border);pointer-events:none;height:6px;position:sticky;top:0}.read-progress-bar{height:100%;width:var(--p,0%);background:var(--accent);transition:width .15s linear}.article{width:100%;max-width:1200px;padding:var(--pad) 32px 120px;flex:1;margin:0 auto;animation:.3s cubic-bezier(.3,.7,.4,1) noteEnter}@keyframes noteEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app.focus .article{max-width:700px}@media (width<=880px){.article{padding:24px 22px 100px}}@media (width<=480px){.article{padding:18px 14px 110px}}
