.sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background-color:var(--color-bg-alt);border-right:1px solid var(--color-border);overflow-y:auto;z-index:100}.sidebar-content{padding:1.5rem}.sidebar-section{margin-bottom:2rem}.sidebar-section-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);margin-bottom:.75rem}.sidebar-list{list-style:none}.sidebar-item{margin-bottom:.25rem}.sidebar-link{display:block;padding:.5rem .75rem;border-radius:4px;color:var(--color-text);font-size:.95rem;transition:all .2s}.sidebar-link:hover{background-color:var(--color-bg);color:var(--color-primary)}.sidebar-link.active{background-color:var(--color-primary);color:#fff;font-weight:500}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform .3s ease-in-out;box-shadow:2px 0 8px #00000026;z-index:200}.sidebar.open{transform:translate(0)}.sidebar-link{padding:.75rem 1rem;font-size:1rem;min-height:44px;display:flex;align-items:center}.sidebar-content{padding:2rem 1.5rem}}.layout-container{margin-left:var(--sidebar-width)}@media (max-width: 768px){.layout-container{margin-left:0}}.search-box{position:relative;flex:1;max-width:500px;margin:0 2rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:var(--color-text-light);pointer-events:none}.search-input{width:100%;padding:.5rem 2.5rem;font-size:.875rem;color:var(--color-text);background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:8px;outline:none;transition:all .2s}.search-input::placeholder{color:var(--color-text-light)}.search-input:focus{border-color:var(--color-primary);background-color:var(--color-bg);box-shadow:0 0 0 3px #3451b21a}.search-clear{position:absolute;right:.75rem;display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;font-size:20px;color:var(--color-text-light);background:none;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.search-clear:hover{color:var(--color-text);background-color:var(--color-border)}.search-results{position:absolute;top:calc(100% + .5rem);left:0;right:0;max-height:400px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 8px 24px #00000026;overflow-y:auto;z-index:1000}.search-result-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;transition:all .2s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item.selected{background-color:var(--color-bg-alt)}.search-result-content{flex:1;min-width:0}.search-result-title{font-size:.9rem;font-weight:500;color:var(--color-text);margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-category{font-size:.75rem;color:var(--color-text-light)}.search-result-arrow{flex-shrink:0;margin-left:.5rem;color:var(--color-text-light);opacity:0;transition:opacity .2s}.search-result-item:hover .search-result-arrow,.search-result-item.selected .search-result-arrow{opacity:1}.search-no-results{padding:2rem 1rem;text-align:center;color:var(--color-text-light);font-size:.875rem}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-track{background:transparent}.search-results::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.search-results::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}@media (max-width: 768px){.search-box{margin:0 1rem;max-width:none}.search-input{font-size:16px}.search-input::placeholder{font-size:.875rem}.search-results{max-height:300px}}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:1000}.header-content{display:flex;align-items:center;gap:1rem;height:100%;padding:0 2rem;max-width:1600px;margin:0 auto}.menu-button{display:none;background:none;border:none;cursor:pointer;padding:.5rem;margin-right:.5rem;position:relative;width:2.5rem;height:2.5rem;flex-shrink:0}.menu-icon{display:block;position:relative;width:1.5rem;height:2px;background-color:var(--color-text);transition:background-color .3s}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0;width:100%;height:2px;background-color:var(--color-text);transition:transform .3s,top .3s}.menu-icon:before{top:-6px}.menu-icon:after{top:6px}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:var(--color-text);text-decoration:none;flex-shrink:0}.logo:hover{color:var(--color-primary)}.logo-icon{font-size:1.5rem}.nav{display:flex;gap:1.5rem;flex-shrink:0;margin-left:auto}.nav a{color:var(--color-text-light);font-size:.95rem;transition:color .2s}.nav a:hover{color:var(--color-primary)}.logout-button{background:none;border:1px solid var(--color-border);color:var(--color-text-light);padding:.4rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer;transition:all .2s}.logout-button:hover{color:var(--color-primary);border-color:var(--color-primary);background-color:#667eea0d}@media (max-width: 768px){.menu-button{display:flex;align-items:center;justify-content:center}.header-content{padding:0 1rem;gap:.5rem}.logo-text{display:none}.nav{gap:1rem}.nav a{font-size:.875rem}}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-container{display:flex;flex:1;padding-top:var(--header-height)}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.sidebar-overlay{display:none}@media (max-width: 768px){.main-content{padding:1rem}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:150;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.home-page{padding:2rem 0}.hero{text-align:center;padding:4rem 2rem}.hero-title{font-size:3rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(120deg,var(--color-primary),#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.25rem;color:var(--color-text-light);margin-bottom:2rem}.hero-actions{display:flex;gap:1rem;justify-content:center}.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;transition:all .2s;cursor:pointer;border:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #3451b24d}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:4rem;padding:0 1rem}.feature-card{padding:2rem;background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:12px;text-align:center;transition:all .3s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--color-text)}.feature-card p{color:var(--color-text-light);line-height:1.6}.sections{margin-top:5rem;padding:0 1rem 2rem}.sections-title{text-align:center;font-size:2rem;margin-bottom:2rem;color:var(--color-text)}.sections-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.section-card{display:block;padding:1.75rem;border-radius:16px;background:linear-gradient(135deg,#3451b214,#00d4ff14);border:1px solid var(--color-border);color:inherit;text-decoration:none;transition:transform .3s,box-shadow .3s,border-color .3s}.section-card:hover{transform:translateY(-6px);border-color:#3451b266;box-shadow:0 12px 24px #0000001f}.section-tag{display:inline-flex;align-items:center;padding:.35rem .75rem;border-radius:999px;background-color:#3451b21f;color:var(--color-primary);font-size:.85rem;font-weight:600;margin-bottom:.75rem}.section-card h3{margin-bottom:.5rem;font-size:1.2rem;color:var(--color-text)}.section-card p{color:var(--color-text-light);line-height:1.6}@media (max-width: 768px){.hero{padding:3rem 1rem}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.hero-actions{flex-direction:column;align-items:stretch}.btn{min-height:44px;width:100%}.features{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:1.5rem}.sections-title{font-size:1.5rem}.sections-grid{grid-template-columns:1fr}}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}.practice-block{margin:1.5rem 0;background:#0d1117;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden}.practice-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff05}.practice-label{font-size:.85rem;color:#ffffffb3}.practice-run{background:var(--color-primary);color:#fff;border:none;padding:.35rem .9rem;border-radius:8px;cursor:pointer;font-size:.85rem}.practice-run:hover{background:var(--color-primary-hover)}.practice-hint{padding:.75rem 1rem;color:#ffffffb3;font-size:.85rem}.practice-editor{width:100%;min-height:200px;padding:1rem;background:transparent;color:#e6edf3;border:none;resize:vertical;font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9rem;line-height:1.6;outline:none}.practice-running{padding:.75rem 1rem 1rem;color:#fffc;font-size:.85rem;display:flex;flex-direction:column;gap:.5rem}.practice-progress{height:6px;background:#ffffff1a;border-radius:999px;overflow:hidden}.practice-progress span{display:block;width:40%;height:100%;background:linear-gradient(90deg,#3451b266,#00d4ffcc);animation:practice-run .9s ease-in-out infinite}@keyframes practice-run{0%{transform:translate(-60%)}to{transform:translate(220%)}}.practice-error{padding:.75rem 1rem 1rem;color:#ff8b8b;font-size:.85rem}.practice-results{padding:.75rem 1rem 1rem;color:#fffc;font-size:.85rem}.practice-results-title{font-weight:600;margin-bottom:.5rem}.practice-results ul{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}.practice-results li{display:flex;gap:.5rem;align-items:center}.practice-results li.passed{color:#7ee787}.practice-results li.failed{color:#ff9b9b}.practice-details{color:#fff9;margin-left:auto;font-size:.75rem}.viz-container{margin:1.25rem 0;background:#0d1117;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden}.viz-canvas{width:100%;display:block}.viz-fallback{padding:1rem;border-radius:12px;background:#ffffff0a;color:#ffffffb3}.markdown-body{line-height:1.8;color:var(--color-text)}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin-top:2rem;margin-bottom:1rem;font-weight:600;line-height:1.25;color:var(--color-text)}.markdown-body h1{font-size:2rem;padding-bottom:.3rem;border-bottom:1px solid var(--color-border)}.markdown-body h2{font-size:1.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--color-border)}.markdown-body h3{font-size:1.25rem}.markdown-body h4{font-size:1.1rem}.markdown-body p{margin-bottom:1rem}.markdown-body ul,.markdown-body ol{margin-bottom:1rem;padding-left:2rem}.markdown-body li{margin-bottom:.25rem}.markdown-body code{background-color:var(--color-bg-alt);padding:.2em .4em;border-radius:3px;font-size:.9em}.markdown-body pre{background-color:#0d1117;padding:1rem;border-radius:6px;overflow-x:auto;margin-bottom:1rem}.markdown-body pre code{background-color:transparent;padding:0;font-size:.875rem;line-height:1.6}.markdown-body blockquote{margin:1rem 0;padding-left:1rem;border-left:4px solid var(--color-border);color:var(--color-text-light)}.markdown-body table{width:100%;border-collapse:collapse;margin-bottom:1rem}.markdown-body th,.markdown-body td{padding:.75rem;border:1px solid var(--color-border)}.markdown-body th{background-color:var(--color-bg-alt);font-weight:600}.markdown-body a{color:var(--color-primary);text-decoration:none}.markdown-body a:hover{text-decoration:underline}.markdown-body img{max-width:100%;height:auto;border-radius:6px}.markdown-body hr{border:none;border-top:1px solid var(--color-border);margin:2rem 0}@media (max-width: 768px){.markdown-body h1{font-size:1.75rem}.markdown-body h2{font-size:1.35rem}.markdown-body h3{font-size:1.15rem}.markdown-body h4{font-size:1rem}.markdown-body pre{padding:.75rem;font-size:.85rem}.markdown-body table{display:block;overflow-x:auto;white-space:nowrap}.markdown-body th,.markdown-body td{padding:.5rem;font-size:.9rem}.markdown-body ul,.markdown-body ol{padding-left:1.5rem}}.table-of-contents{position:sticky;top:100px;width:280px;max-height:calc(100vh - 150px);overflow-y:auto;padding:1.5rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:8px;margin-left:2rem;flex-shrink:0}.toc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.toc-title{font-size:1rem;font-weight:600;margin:0;color:var(--color-text);border-bottom:2px solid var(--color-primary);padding-bottom:.5rem;flex:1}.toc-close{display:none;background:none;border:none;font-size:1.5rem;color:var(--color-text-light);cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.toc-close:hover{color:var(--color-text)}.toc-mobile-toggle{display:none}.toc-nav{display:flex;flex-direction:column;gap:.5rem}.toc-item{display:block;padding:.4rem .75rem;color:var(--color-text-light);text-decoration:none;border-left:2px solid transparent;transition:all .2s ease;font-size:.875rem;line-height:1.4}.toc-item:hover{color:var(--color-primary);background:#3b82f60d;border-left-color:var(--color-primary)}.toc-item.active{color:var(--color-primary);font-weight:600;background:#3b82f61a;border-left-color:var(--color-primary)}.toc-level-2{padding-left:.75rem}.toc-level-3{padding-left:1.5rem;font-size:.8125rem}.table-of-contents::-webkit-scrollbar{width:6px}.table-of-contents::-webkit-scrollbar-track{background:transparent}.table-of-contents::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.table-of-contents::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}.toc-overlay{display:none}@media (max-width: 1200px){.toc-mobile-toggle{display:flex;align-items:center;justify-content:center;position:fixed;bottom:2rem;right:1rem;width:3.5rem;height:3.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;cursor:pointer;z-index:100;transition:all .3s}.toc-mobile-toggle:hover{background:var(--color-primary-hover);transform:scale(1.05);box-shadow:0 6px 16px #0003}.toc-mobile-toggle:active{transform:scale(.95)}.toc-icon{font-size:1.5rem}.toc-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:150;animation:fadeIn .3s}.table-of-contents{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:70vh;margin:0;border-radius:16px 16px 0 0;z-index:200;transform:translateY(100%);transition:transform .3s ease-in-out;box-shadow:0 -4px 20px #0003}.table-of-contents.open{transform:translateY(0)}.toc-header{border-bottom:1px solid var(--color-border);padding-bottom:.75rem}.toc-title{border-bottom:none;padding-bottom:0}.toc-close{display:block}.toc-nav{gap:.25rem}.toc-item{padding:.75rem 1rem;font-size:.95rem;min-height:44px;display:flex;align-items:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.document-page-container{display:flex;gap:2rem;max-width:1400px;margin:0 auto}.document-page{flex:1;max-width:900px;min-width:0}.document-back{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:1rem;color:var(--color-text-light);text-decoration:none;font-weight:500}.document-back:hover{color:var(--color-primary)}.document-title{font-size:2.5rem;font-weight:700;margin-bottom:2rem;color:var(--color-text);border-bottom:1px solid var(--color-border);padding-bottom:1rem}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.25rem;color:var(--color-text-light)}@media (max-width: 1200px){.document-page-container{max-width:900px}}@media (max-width: 768px){.document-title{font-size:2rem}}.category-page{padding:2.5rem 1rem 4rem}.category-hero{max-width:720px;margin-bottom:2.5rem}.category-title{font-size:2.5rem;margin-bottom:.75rem;color:var(--color-text)}.category-description{color:var(--color-text-light);font-size:1.05rem;line-height:1.6}.subcategory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.subcategory-card{padding:1.5rem;border-radius:16px;background:var(--color-bg-alt);border:1px solid var(--color-border);box-shadow:0 10px 20px #00000014;display:flex;flex-direction:column;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.subcategory-card:hover{transform:translateY(-4px);box-shadow:0 14px 28px #0000001f}.subcategory-header h2{font-size:1.25rem;margin-bottom:.35rem}.subcategory-header p{color:var(--color-text-light);line-height:1.5}.subcategory-list{list-style:none;display:grid;gap:.5rem}.subcategory-list a{color:var(--color-text);text-decoration:none;padding:.4rem .6rem;border-radius:8px;background:#3451b214;display:inline-block;transition:color .2s ease,background .2s ease}.subcategory-list a:hover{color:var(--color-primary);background:#3451b229}@media (max-width: 768px){.category-page{padding:1.5rem .5rem 2rem}.category-title{font-size:2rem}.category-description{font-size:1rem}.subcategory-grid{grid-template-columns:1fr;gap:1rem}.subcategory-card{padding:1.25rem}.subcategory-list a{min-height:40px;display:flex;align-items:center}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-title{text-align:center;margin-bottom:30px;font-size:28px;color:#333;font-weight:600}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#555}.form-group input{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{color:#e74c3c;font-size:14px;padding:10px;background-color:#fee;border-radius:6px;text-align:center}.login-button{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active{transform:translateY(0)}.app{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #ffffff;--color-bg-alt: #f6f6f7;--color-border: #e2e2e3;--color-text: #213547;--color-text-light: #476582;--color-primary: #3451b2;--color-primary-hover: #3a5ccc;--sidebar-width: 280px;--header-height: 60px}@media (prefers-color-scheme: dark){:root{--color-bg: #1b1b1f;--color-bg-alt: #161618;--color-border: #2e2e32;--color-text: #e4e4e7;--color-text-light: #a1a1aa;--color-primary: #3451b2;--color-primary-hover: #3a5ccc}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.6;color:var(--color-text);background-color:var(--color-bg)}code{font-family:Courier New,Courier,monospace}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}
