.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width var(--transition),transform var(--transition)}.sidebar.is-closed{width:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo{font-size:14px;font-weight:600;white-space:nowrap}.sidebar-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:4px 6px;border-radius:var(--radius);line-height:1;transition:color var(--transition)}.sidebar-close:hover{color:var(--text)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0 16px}.sidebar-group{margin-bottom:4px}.sidebar-group-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:10px 16px 4px;white-space:nowrap}.sidebar-group ul{list-style:none}.sidebar-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;border-left:2px solid transparent;color:var(--text-muted);cursor:pointer;padding:5px 16px 5px 14px;font-size:13px;text-align:left;line-height:1.35;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sidebar-item:hover{background:var(--surface-2);color:var(--text)}.sidebar-item.visited{color:var(--text)}.sidebar-item.active{background:var(--accent-dim);color:var(--text);border-left-color:var(--tc, var(--accent))}.sidebar-dot{width:7px;height:7px;border-radius:50%;border:1.5px solid;flex-shrink:0;transition:background var(--transition)}.sidebar-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar{height:var(--topbar-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:16px;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.topbar-menu{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:17px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);flex-shrink:0;transition:color var(--transition),background var(--transition);line-height:1}.topbar-menu:hover{color:var(--text);background:var(--surface-2)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;min-width:0}.bc-tier{font-weight:600;flex-shrink:0}.bc-sep{color:var(--border);flex-shrink:0}.bc-page{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar-count{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap}.progress-track{width:90px;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .5s ease}.progress-pct{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:30px;text-align:right}.topbar-reset{background:none;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:15px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);flex-shrink:0;transition:color var(--transition),border-color var(--transition),background var(--transition);line-height:1}.topbar-reset:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.reader-scroll{flex:1;overflow-y:auto}.reader-content{max-width:800px;margin:0 auto;padding:40px 36px 80px}.reader-content h1{font-size:1.85em;font-weight:700;line-height:1.25;margin-bottom:.35em;padding-bottom:.35em;border-bottom:1px solid var(--border)}.reader-content h2{font-size:1.4em;font-weight:600;margin-top:2.2em;margin-bottom:.5em;padding-bottom:.25em;border-bottom:1px solid var(--border)}.reader-content h3{font-size:1.1em;font-weight:600;color:var(--text);margin-top:1.6em;margin-bottom:.4em}.reader-content h4{font-size:.82em;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:1.4em;margin-bottom:.3em}.reader-content p{margin-bottom:1em}.reader-content ul,.reader-content ol{padding-left:1.6em;margin-bottom:1em}.reader-content li{margin-bottom:.3em}.reader-content li>p{margin-bottom:.3em}.reader-content strong{font-weight:600}.reader-content a{color:#58a6ff;text-decoration:none}.reader-content a:hover{text-decoration:underline}.reader-content hr{border:none;border-top:1px solid var(--border);margin:2em 0}.reader-content blockquote{border-left:3px solid var(--accent);padding:.6em 1.1em;margin:1.2em 0;background:var(--accent-dim);border-radius:0 var(--radius) var(--radius) 0}.reader-content blockquote p{color:var(--text-muted);margin-bottom:0}.reader-content blockquote p+p{margin-top:.4em}.inline-code{background:var(--surface-2);color:#f0883e;padding:.15em .38em;border-radius:3px;font-family:var(--font-mono);font-size:.875em;border:1px solid var(--border)}.code-block-wrap{position:relative;margin:1.3em 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.code-lang{position:absolute;top:0;right:0;background:#21262de6;color:var(--text-muted);font-family:var(--font-mono);font-size:10.5px;padding:3px 10px;border-bottom-left-radius:var(--radius);border-left:1px solid var(--border);border-bottom:1px solid var(--border);text-transform:lowercase;pointer-events:none}.reader-content pre{margin:1.3em 0;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.code-block-wrap+pre,.code-block-wrap pre{margin:0;border:none}.reader-content pre code{display:block;padding:16px 18px;font-family:var(--font-mono);font-size:13.5px;line-height:1.58;overflow-x:auto;white-space:pre}.reader-content pre code:not(.hljs){background:var(--surface-2);color:var(--text)}.table-scroll{overflow-x:auto;margin:1.3em 0;border-radius:var(--radius);border:1px solid var(--border)}.reader-content table{width:100%;border-collapse:collapse;font-size:13.5px}.reader-content th{background:var(--surface-2);font-weight:600;padding:9px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.reader-content td{padding:7px 14px;border-bottom:1px solid var(--border);vertical-align:top}.reader-content tr:last-child td{border-bottom:none}.reader-content tr:nth-child(2n) td{background:#ffffff05}.bottomnav{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;padding:10px 0}.bottomnav-inner{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 36px;gap:16px}.nav-btn{display:flex;align-items:center;gap:10px;background:none;border:1px solid var(--border);color:var(--text);cursor:pointer;padding:9px 14px;border-radius:var(--radius);transition:background var(--transition),border-color var(--transition);text-align:left;max-width:46%;min-width:0}.nav-btn:hover{background:var(--surface-2);border-color:var(--text-muted)}.nav-next{margin-left:auto}.nav-arrow{font-size:15px;color:var(--text-muted);flex-shrink:0}.nav-labels{display:flex;flex-direction:column;min-width:0}.nav-labels-right{text-align:right}.nav-direction{font-size:10.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;line-height:1;margin-bottom:2px}.nav-title{font-size:12.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.app-shell{display:flex;height:100dvh;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}:root{--bg: #0d1117;--surface: #161b22;--surface-2: #21262d;--border: #30363d;--text: #e6edf3;--text-muted: #8b949e;--accent: #e05c4b;--accent-dim: rgba(224, 92, 75, .12);--tier-beginner: #3fb950;--tier-intermediate: #d29922;--tier-advanced: #f85149;--sidebar-width: 288px;--topbar-height: 52px;--bottomnav-height: 68px;--radius: 6px;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", Consolas, monospace;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--transition: .16s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
