.articles-shell{display:flex;min-height:100vh;padding-top:64px}.articles-sidebar{position:fixed;top:64px;left:0;bottom:0;width:260px;z-index:90;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg);overflow:hidden}.articles-sidebar-head{display:flex;align-items:center;gap:10px;padding:24px 24px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.articles-sidebar-nav{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:16px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}.articles-sidebar-footer{padding:16px 24px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px;flex-shrink:0}.articles-sidebar-logo{font-weight:700;font-size:1.15rem;letter-spacing:-.03em;color:var(--text-primary);text-decoration:none}.articles-sidebar-badge{font-family:IBM Plex Mono,Fira Code,monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;padding:2px 8px}.articles-nav-group{padding:0 16px;margin-bottom:4px}.articles-nav-group-title{font-family:IBM Plex Mono,Fira Code,monospace;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);padding:12px 8px 6px}.articles-nav-item{display:block;padding:6px 8px;border-radius:6px;font-size:.86rem;color:rgba(240,240,245,.55);transition:color .15s ease,background .15s ease;line-height:1.5;text-decoration:none;cursor:pointer}.articles-nav-item:hover{color:var(--text-primary);background:rgba(255,255,255,.04)}.articles-nav-item.active{color:var(--text-primary);background:rgba(255,255,255,.06);font-weight:500}.articles-sidebar-link{font-size:.82rem;color:var(--text-secondary);text-decoration:none;padding:4px 0;transition:color .15s ease}.articles-sidebar-link:hover{color:var(--green)}.articles-tag-pill{display:inline-block;font-family:IBM Plex Mono,Fira Code,monospace;font-size:.65rem;letter-spacing:.06em;color:var(--text-secondary);border:1px solid var(--border);border-radius:20px;padding:3px 10px;margin:3px 4px 3px 0}.articles-detail-meta{display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:var(--text-secondary);padding:4px 8px}.articles-main{margin-left:260px;flex:1;max-width:780px;padding:48px 56px 80px}.articles-overline{display:inline-block;font-family:IBM Plex Mono,Fira Code,monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:12px}.articles-h1{font-size:2.2rem;font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--text-primary);margin-bottom:8px}.articles-lead{font-size:1.05rem;line-height:1.75;color:var(--text-secondary);margin-bottom:40px}.articles-grid{gap:16px}.article-card,.articles-grid{display:flex;flex-direction:column}.article-card{gap:0;padding:0;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-decoration:none;overflow:hidden;transition:border-color .2s ease,background .2s ease}.article-card:hover{border-color:rgba(255,255,255,.12);background:var(--surface-2)}.article-card-thumb{width:100%;aspect-ratio:1200/630;overflow:hidden;border-bottom:1px solid var(--border)}.article-card-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.article-card:hover .article-card-thumb-img{transform:scale(1.03)}.article-card-inner{flex:1;min-width:0;padding:20px 24px 24px}.article-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.article-card-tag{font-family:IBM Plex Mono,Fira Code,monospace;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--green);border:1px solid rgba(255,115,0,.2);border-radius:4px;padding:2px 8px}.article-card-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;line-height:1.4;margin-bottom:6px}.article-card-desc{font-size:.88rem;line-height:1.6;color:var(--text-secondary);margin-bottom:10px}.article-card-meta{display:flex;align-items:center;gap:0;font-family:IBM Plex Mono,Fira Code,monospace;font-size:.68rem;color:rgba(240,240,245,.35)}.article-card-dot{margin:0 8px}.article-card-arrow{font-size:1.2rem;color:var(--text-secondary);flex-shrink:0;transition:transform .2s ease}.article-card:hover .article-card-arrow{transform:translateX(4px);color:var(--green)}.article-detail{max-width:700px}.article-hero-img{width:100%;aspect-ratio:1200/630;border-radius:12px;overflow:hidden;border:1px solid var(--border);margin-bottom:40px}.article-hero-img-el{width:100%;height:100%;object-fit:cover}.article-markdown h1{font-size:2.4rem;font-weight:700;letter-spacing:-.035em;line-height:1.15;color:var(--text-primary);margin:0 0 8px}.article-markdown h2{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;color:var(--text-primary);margin:56px 0 16px;padding-top:28px;border-top:1px solid var(--border)}.article-markdown h3{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:36px 0 10px}.article-markdown>p:first-of-type{font-size:1.15rem;line-height:1.75;color:rgba(240,240,245,.6);margin:0 0 32px}.article-markdown p{font-size:1.05rem;line-height:1.85;color:rgba(240,240,245,.55);margin:0 0 20px}.article-markdown blockquote{border-left:3px solid var(--green);padding:16px 24px;margin:32px 0;background:rgba(255,115,0,.04);border-radius:0 8px 8px 0}.article-markdown blockquote p{color:rgba(240,240,245,.7);font-style:italic;font-size:1.05rem;line-height:1.7;margin:0}.article-markdown ol,.article-markdown ul{padding-left:28px;margin:0 0 24px}.article-markdown li{font-size:1rem;line-height:1.75;color:rgba(240,240,245,.55);margin-bottom:6px}.article-markdown li:has(>input[type=checkbox]){list-style:none;margin-left:-24px;padding-left:0}.article-markdown input[type=checkbox]{appearance:none;-webkit-appearance:none;width:16px;height:16px;border-radius:4px;border:1px solid var(--border);background:rgba(255,255,255,.03);vertical-align:middle;margin-right:8px;position:relative;cursor:default}.article-markdown input[type=checkbox]:checked{background:rgba(52,211,153,.15);border-color:rgba(52,211,153,.4)}.article-markdown input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;color:#34d399;line-height:1}.article-markdown input[type=checkbox]:not(:checked){background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.3)}.article-markdown input[type=checkbox]:not(:checked):after{content:"✕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.6rem;color:#ef4444;line-height:1}.article-markdown li:has(>input[type=checkbox]:checked){color:var(--text-secondary)}.article-markdown li:has(>input[type=checkbox]:not(:checked)){color:rgba(240,240,245,.35)}.article-markdown strong{color:var(--text-primary);font-weight:600}.article-markdown code{font-family:IBM Plex Mono,Fira Code,monospace;font-size:.82rem;background:rgba(255,255,255,.06);border:1px solid var(--border);padding:2px 6px;border-radius:4px;color:var(--green)}.article-markdown pre{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px 24px;margin:20px 0;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.08) transparent}.article-markdown pre code{background:none;border:none;padding:0;font-size:.8rem;line-height:1.6;color:rgba(240,240,245,.7)}.article-markdown table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.85rem}.article-markdown th{text-align:left;font-weight:600;color:var(--text-primary);padding:10px 12px;border-bottom:1px solid var(--border);font-size:.78rem;letter-spacing:.04em}.article-markdown td{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary)}.article-markdown hr{border:none;height:0;margin:40px auto;text-align:center}.article-markdown hr:after{content:"...";font-size:1.5rem;letter-spacing:.6em;color:rgba(240,240,245,.2)}.article-markdown a{color:var(--green);text-decoration:none;transition:opacity .15s ease}.article-markdown a:hover{opacity:.8}@media (max-width:900px){.articles-sidebar{display:none}.articles-main{margin-left:0;padding:24px 20px 60px;max-width:100%}}@media (min-width:901px) and (max-width:1100px){.articles-main{padding:48px 36px 80px}}