:root{--bg:#111;--bg-surface:#1a1a1a;--bg-hover:#222;--border:#333;--text:#e0e0e0;--text-muted:#888;--text-heading:#fff;--font-mono:"JetBrains Mono", "Fira Code", monospace;--font-sans:"Inter", -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-mono);color:var(--text-heading)}a{color:inherit;text-decoration:none}a:hover{color:#fff}.header{border-bottom:1px solid var(--border);background:var(--bg-surface);align-items:center;gap:1rem;padding:1rem 2rem;display:flex}.header img{object-fit:contain;height:48px}.header .title{font-family:var(--font-mono);color:#fff;font-size:1.25rem;font-weight:600}.header nav{font-family:var(--font-mono);color:var(--text-muted);margin-left:auto;font-size:.85rem}.main{max-width:1600px;margin:0 auto;padding:2rem}.project-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;transition:border-color .2s;display:block}.project-card:hover{border-color:#555}.project-card h2{margin-bottom:.5rem;font-size:1.1rem}.project-card p{color:var(--text-muted);font-size:.9rem;line-height:1.5}.project-lead{color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.project-lead strong{color:#ccc}.project-lead a{color:#6ea8fe}.page-link{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:1rem 1.25rem;font-size:.95rem;display:block}.page-link:hover{border-color:#555}.page-link-desc{color:var(--text-muted);margin-top:.25rem;font-size:.8rem;line-height:1.4}.page-link .type{color:#555;font-size:.8rem}.page-layout{gap:2rem;display:flex}.page-nav{border-right:1px solid var(--border);flex-shrink:0;align-self:flex-start;width:200px;max-height:calc(100vh - 6rem);padding-right:1.5rem;font-size:.85rem;position:sticky;top:2rem;overflow-y:auto}.page-nav a{color:var(--text-muted);padding:.4rem 0;display:block}.page-nav a.active{color:#fff;font-weight:600}.page-content{flex:1;min-width:0}.markdown-body h1{margin:0 0 1rem;font-size:1.75rem}.markdown-body h2{margin:1.5rem 0 .75rem;font-size:1.25rem}.markdown-body h3{margin:1.25rem 0 .5rem;font-size:1.05rem}.markdown-body a{color:#6ea8fe;text-underline-offset:2px;text-decoration:underline}.markdown-body a:hover{color:#9ec5fe}.markdown-body p{color:#ccc;margin-bottom:1rem;line-height:1.7}.markdown-body ul,.markdown-body ol{color:#ccc;margin:0 0 1rem 1.5rem}.markdown-body li{margin-bottom:.25rem;line-height:1.6}.markdown-body strong{color:#fff}.markdown-body code{font-family:var(--font-mono);background:#222;border-radius:3px;padding:.15rem .4rem;font-size:.9em}.markdown-body pre{background:var(--bg-surface);border-radius:6px;margin-bottom:1rem;padding:1rem;overflow:auto}.markdown-body table{border-collapse:collapse;width:100%;margin-bottom:1rem}.markdown-body th,.markdown-body td{border:1px solid var(--border);text-align:left;padding:.5rem .75rem}.markdown-body th{background:var(--bg-surface);color:#fff;font-family:var(--font-mono);font-size:.85rem}.markdown-body td{color:#ccc;font-size:.9rem}.comments-sidebar{border-left:1px solid var(--border);flex-shrink:0;align-self:flex-start;width:300px;max-height:calc(100vh - 6rem);padding-left:1.5rem;position:sticky;top:2rem;overflow-y:auto}.comments-sidebar.collapsed{border:none;width:auto;padding:0}.comments-toggle{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:.8rem;font-family:var(--font-mono);border-radius:4px;align-items:center;gap:.3rem;padding:.3rem .5rem;display:flex}.comments-toggle:hover{color:#fff}.comments-inner h3{margin:.75rem 0;font-size:.95rem}.comment-filters{flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem;display:flex}.filter-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:.7rem;font-family:var(--font-mono);background:0 0;border-radius:4px;padding:.2rem .5rem}.filter-btn:hover{color:#fff;border-color:#555}.filter-active{color:#fff;background:var(--bg-hover);border-color:#888}.comment-scope{color:#6ea8fe;padding:.25rem 0;font-size:.75rem}.comment-section-tag{color:#6ea8fe;margin-right:.5rem;font-size:.65rem}.comments-list{flex-direction:column;gap:1rem;max-height:50vh;margin-bottom:1.5rem;display:flex;overflow-y:auto}.comment{border-bottom:1px solid #222;padding-bottom:.75rem}.comment-resolved{opacity:.6}.comment-header{cursor:pointer;align-items:flex-start;gap:.4rem;display:flex}.comment-header:hover{opacity:.9}.comment-collapse-icon{color:var(--text-muted);flex-shrink:0;margin-top:.1rem;font-size:.9rem}.comment-actions{align-items:center;gap:.75rem;display:flex}.resolved-badge{color:#63e6be;background:#63e6be1a;border-radius:3px;margin-right:.25rem;padding:.1rem .4rem;font-size:.65rem}.comment-meta{color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem}.comment-meta strong{color:#ccc;margin-right:.5rem;font-weight:600}.comment p{color:var(--text);font-size:.85rem;line-height:1.5}.comment-reply{border-left:2px solid #333;margin-top:.5rem;margin-left:1rem;padding-left:.75rem}.reply-btn{color:var(--text-muted);cursor:pointer;font-size:.75rem;font-family:var(--font-mono);background:0 0;border:none;margin-top:.25rem;padding:0}.reply-btn:hover{color:#fff}.delete-btn:hover{color:#f66}.delete-confirm{color:var(--text-muted);align-items:center;gap:.5rem;margin-left:.75rem;font-size:.75rem;display:inline-flex}.comment-form{flex-direction:column;gap:.5rem;display:flex}.comment-form input,.comment-form textarea{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);font-family:var(--font-sans);resize:vertical;border-radius:4px;padding:.5rem;font-size:.85rem}.comment-form input:focus,.comment-form textarea:focus{border-color:#555;outline:none}.comment-form button{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:.8rem;font-family:var(--font-mono);border-radius:4px;align-self:flex-start;padding:.4rem .75rem}.comment-form button:hover{background:var(--bg-hover);color:#fff}.comment-form-actions{gap:.5rem;display:flex}.reply-form{margin-top:.5rem;margin-left:1rem}.comment-type-badge{margin-right:.5rem;font-size:.7rem}.comment-type-selector{display:flex}.type-btn{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;margin-left:-1px;padding:.3rem .6rem;font-size:.75rem}.type-btn:first-child{border-radius:4px 0 0 4px;margin-left:0}.type-btn:last-child{border-radius:0 4px 4px 0}.type-btn:hover{color:#fff}.type-btn-active{color:#fff;z-index:1;background:#333;border-color:#555;position:relative}.comment-form .type-btn-active{color:#fff;background:#333;border-color:#555}.comment-form .type-btn-active:hover{color:#fff;background:#333}.hero{text-align:center;border-bottom:1px solid var(--border);margin-bottom:2rem;padding:3rem 1rem 2.5rem}.hero-logo{object-fit:contain;height:64px;margin-bottom:1rem}.hero h1{font-size:2.75rem;font-family:var(--font-mono);color:#fff;margin-bottom:.5rem}.hero p{color:var(--text-muted);font-size:1.05rem;font-style:italic}.md-section{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.5rem}.md-section summary{cursor:pointer;border-radius:4px;align-items:center;gap:.5rem;padding:.25rem 0;list-style:none;transition:background .2s,box-shadow .2s;display:flex}.md-section summary::-webkit-details-marker{display:none}.md-section summary:before{content:"▸";color:var(--text-muted);font-size:1rem;transition:transform .15s}.md-section[open] summary:before{transform:rotate(90deg)}.md-section summary:hover{background:#6ea8fe0f;box-shadow:0 0 12px #6ea8fe26}.md-section summary h2{flex:1;margin:0}.md-section-content{padding-top:.5rem}.section-comment-btn{cursor:pointer;opacity:0;background:0 0;border:none;flex-shrink:0;padding:.2rem .4rem;font-size:1rem;transition:opacity .2s}.md-section summary:hover .section-comment-btn{opacity:.7}.section-comment-btn:hover{opacity:1!important}.nav-section{margin-top:1.5rem}.nav-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;font-size:.7rem;display:block}.toc-item{color:var(--text-muted);padding:.2rem 0;font-size:.8rem;transition:color .15s;display:block}.toc-item:hover{color:#fff}.toc-active{color:#fff;font-weight:600}.page-nav a.toc-active{color:#fff}.toc-nested{border-left:1px solid #444;margin-top:.25rem;margin-bottom:.25rem;margin-left:.4rem;padding-left:.75rem}.toc-nested .toc-item{position:relative}.toc-nested .toc-item:before{content:"";border-top:1px solid #444;width:.5rem;position:absolute;top:50%;left:-.75rem}.toc-nested>:last-child{position:relative}.toc-nested>:last-child:after{content:"";background:var(--bg);width:2px;position:absolute;top:50%;bottom:0;left:-.75rem}.toc-h1,.toc-h2{padding-left:0}.page-nav .toc-h3{font-size:.75rem}.page-nav .toc-h4{font-size:.7rem}
