:root{--mono: "Fira Code", ui-monospace, "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, "Liberation Mono", monospace}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:26px;margin-top:18px}.blog-empty{text-align:center;color:var(--muted);padding:48px 0}.blog-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.blog-card-cover{aspect-ratio:16 / 9;background-image:var(--cover, none);background-color:var(--bg-soft);background-size:cover;background-position:center;position:relative;border-bottom:1px solid var(--border)}.blog-card-cover:not([style]){background-image:radial-gradient(120% 140% at 0% 0%,var(--accent-soft),transparent 60%),linear-gradient(135deg,var(--bg-soft),var(--bg-card))}.blog-card-cat{position:absolute;top:12px;left:12px;background:#0000008c;color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.02em;padding:4px 11px;border-radius:999px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.blog-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:9px;flex:1}.blog-card-meta{margin:0;color:var(--muted);font-size:.82rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.blog-card-meta i{color:var(--accent);margin-right:3px}.blog-card-dot{opacity:.5}.blog-card-title{font-size:1.22rem;line-height:1.3;margin:0;color:var(--text-strong)}.blog-card-desc{margin:0;color:var(--muted);font-size:.94rem;line-height:1.55;flex:1}.blog-card-more{margin-top:4px;color:var(--accent);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:7px}.blog-card-more i{transition:transform var(--t-fast)}.blog-card:hover .blog-card-more i{transform:translate(3px)}.blog-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.blog-tags li{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-ring);padding:4px 11px;border-radius:999px}.blog-tags li i{font-size:.7em;opacity:.75}.blog-tags--sm li{font-size:.72rem;padding:3px 9px}.article{padding:116px 0 80px}.article .container{max-width:880px}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:600;font-size:.9rem;margin-bottom:24px;text-decoration:none;transition:color var(--t-fast)}.back-link:hover{color:var(--accent)}.back-link i{font-size:.85em}.article-byline{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px}.article-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--bg);box-shadow:0 0 0 2px var(--accent),0 0 18px var(--accent-ring)}.article-byline-text{min-width:0}.article-author{margin:0;font-weight:700;color:var(--text-strong)}.article-author a{color:var(--accent);text-decoration:none}.article-author a:hover{text-decoration:underline}.article-handle{color:var(--muted);font-weight:500}.article-dates{margin:4px 0 0;color:var(--muted);font-size:.9rem;display:flex;gap:10px;flex-wrap:wrap;align-items:center}.article-dates i{color:var(--accent);margin-right:4px}.article-dates-dot{opacity:.5}.article-tags{margin-left:auto}.article-kicker{display:inline-block;color:var(--accent);font-weight:700;font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;margin-bottom:8px}.article-title{font-size:clamp(1.95rem,4.6vw,2.95rem);line-height:1.14;margin:0 0 14px;color:var(--text-strong);letter-spacing:-.01em}.article-lead{font-size:1.18rem;line-height:1.6;color:var(--muted);margin:0 0 18px}.reading-badge{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-ring);padding:6px 14px;border-radius:999px;margin:0}.article-rule{border:0;border-top:1px solid var(--border);margin:28px 0}.article-foot{margin-top:44px;padding-top:24px;border-top:1px solid var(--border)}.article-foot .back-link{margin:0}.toc{background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 26px;margin:0 0 36px}.toc-title{display:flex;align-items:center;gap:10px;margin:0 0 10px;font-weight:700;font-size:1.15rem;color:var(--text-strong)}.toc-title i{color:var(--accent)}.toc-list{list-style:none;margin:0;padding:0}.toc-list a{display:flex;gap:12px;padding:10px;border-radius:var(--radius-sm);color:var(--muted);text-decoration:none;border-bottom:1px solid var(--border);transition:background var(--t-fast),color var(--t-fast)}.toc-list li:last-child a{border-bottom:0}.toc-list a:hover{background:var(--accent-soft);color:var(--text)}.toc-list a.active{color:var(--accent);font-weight:600}.toc-index{color:var(--accent);font-weight:700;flex:none}.article-body{font-size:1.02rem;line-height:1.75;color:var(--text)}.article-body>:first-child{margin-top:0}.article-body h2,.article-body h3,.article-body h4{color:var(--text-strong);scroll-margin-top:96px;line-height:1.25}.article-body h2{font-size:clamp(1.45rem,3vw,1.9rem);margin:46px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.article-body h3{font-size:1.32rem;margin:32px 0 10px}.article-body h4{font-size:1.1rem;margin:24px 0 8px}.article-body p{margin:0 0 16px}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.article-body a:hover{color:var(--accent-strong)}.article-body strong{color:var(--text-strong);font-weight:700}.article-body ul,.article-body ol{margin:0 0 16px;padding-left:1.4em}.article-body li{margin:6px 0}.article-body li::marker{color:var(--accent)}.article-body blockquote{margin:22px 0;padding:6px 18px;border-left:4px solid var(--accent);background:var(--accent-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text)}.article-body blockquote p:last-child{margin-bottom:0}.article-body img{max-width:100%;height:auto;display:block;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-md);margin:22px 0}.article-body hr{border:0;border-top:1px solid var(--border);margin:34px 0}.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:.95rem;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.article-body th,.article-body td{padding:10px 14px;border-bottom:1px solid var(--border);text-align:left}.article-body thead th{background:var(--bg-soft);color:var(--text-strong);font-weight:700}.article-body tbody tr:last-child td{border-bottom:0}.article-body.numbered{counter-reset:h2 -1}.article-body.numbered h2{display:flex;align-items:baseline;gap:.5em}.article-body.numbered h2:before{counter-increment:h2;content:counter(h2) ".";color:var(--accent);font-weight:800}.article-body :not(pre)>code{font-family:var(--mono);font-size:.88em;color:var(--tint-red);background:var(--tint-red-soft);border:1px solid var(--tint-red-soft);padding:.1em .4em;border-radius:6px;white-space:nowrap}.article-body pre{margin:24px 0;padding:16px 18px;border-radius:var(--radius);border:1px solid var(--border-strong);overflow-x:auto;box-shadow:var(--shadow-sm);font-size:.9rem;line-height:1.6}.article-body pre code{font-family:var(--mono)}.admonition{margin:24px 0;border:1px solid var(--border);border-left:4px solid var(--admon, var(--accent));background:var(--admon-soft, var(--bg-soft));border-radius:var(--radius-sm);padding:15px 18px}.admonition-title{display:flex;align-items:center;gap:10px;margin:0;font-weight:700;color:var(--admon, var(--accent));font-size:.98rem}.admonition-title i{font-size:1.05em}.admonition-body{color:var(--text)}.admonition-title+.admonition-body,.admonition-body{margin-top:6px}.admonition-body>:first-child{margin-top:0}.admonition-body>:last-child{margin-bottom:0}.admonition-note{--admon: var(--text-strong);--admon-soft: var(--bg-soft);border-left-color:var(--border-strong)}.admonition-info{--admon: var(--tint-blue);--admon-soft: var(--tint-blue-soft)}.admonition-tip{--admon: var(--tint-cyan);--admon-soft: var(--tint-cyan-soft)}.admonition-success{--admon: var(--tint-green);--admon-soft: var(--tint-green-soft)}.admonition-warning{--admon: var(--tint-amber);--admon-soft: var(--tint-amber-soft)}.admonition-danger{--admon: var(--tint-red);--admon-soft: var(--tint-red-soft)}.admonition-important{--admon: var(--tint-purple);--admon-soft: var(--tint-purple-soft)}details.admonition-collapsible>summary{cursor:pointer;list-style:none}details.admonition-collapsible>summary::-webkit-details-marker{display:none}.admonition-chevron{margin-left:auto;transition:transform var(--t);font-size:.85em!important;opacity:.7}details.admonition-collapsible[open] .admonition-chevron{transform:rotate(180deg)}.code-window{margin:26px 0;border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);background:#282c34}.code-window-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:9px 14px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08);font-size:.85rem}.code-window-lang{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:#e8eaed}.code-window-file{justify-self:center;font-family:var(--mono);font-size:.78rem;color:#9aa1ab;background:#ffffff0f;padding:3px 12px;border-radius:6px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-window-actions{justify-self:end;display:flex;gap:8px}.code-window-btn{display:inline-flex;align-items:center;gap:6px;background:#ffffff0f;color:#cfd3da;border:1px solid rgba(255,255,255,.12);border-radius:7px;padding:5px 11px;font-size:.78rem;font-family:inherit;cursor:pointer;transition:background var(--t-fast),color var(--t-fast)}.code-window-btn:hover{background:#ffffff24;color:#fff}.code-window-btn.is-done{color:#4ade80;border-color:#4ade8066}.code-window-body{overflow-x:auto}.code-window-body pre{margin:0;border:0;border-radius:0;box-shadow:none}.code-window:not(.code-window--nolines) .code-window-body pre code{counter-reset:ln}.code-window:not(.code-window--nolines) .code-window-body pre code .line{counter-increment:ln}.code-window:not(.code-window--nolines) .code-window-body pre code .line:before{content:counter(ln);display:inline-block;width:1.4em;margin-right:1.25em;text-align:right;color:#ffffff4d;user-select:none;-webkit-user-select:none}.code-window:not(.code-window--nolines) .code-window-body pre code .line:last-child:empty:before{content:""}.kbd{font-family:var(--mono);font-size:.8em;font-weight:600;color:var(--text-strong);background:var(--bg-soft);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:6px;padding:2px 7px;box-shadow:var(--shadow-sm);white-space:nowrap}@media(max-width:720px){.article{padding:96px 0 64px}.article-tags{margin-left:0;width:100%}.toc{padding:18px}}@media(max-width:560px){.code-window-file,.code-window-btn span{display:none}}.tp-guidelines{margin:8px 0 32px;border:1px solid var(--accent-ring);border-left:4px solid var(--accent);background:var(--accent-soft);border-radius:var(--radius);padding:18px 20px}.tp-guidelines-head{display:flex;align-items:center;gap:10px;margin:0 0 14px;font-weight:800;font-size:1.12rem;color:var(--accent-strong)}.tp-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px 18px;padding:14px 0;margin-bottom:6px;border-top:1px solid var(--accent-ring);border-bottom:1px solid var(--accent-ring)}.tp-meta-item{display:flex;align-items:flex-start;gap:10px}.tp-meta-item>i{color:var(--accent);margin-top:3px}.tp-meta-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.tp-meta-value{display:block;font-weight:700;color:var(--text-strong)}.tp-meta-value code{white-space:nowrap}.tp-rules{margin-top:12px}.tp-rules>:first-child{margin-top:0}.tp-rules>:last-child{margin-bottom:0}.tp-fold{margin:16px 0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);overflow:hidden}.tp-fold-summary{display:flex;align-items:center;gap:11px;padding:14px 16px;cursor:pointer;font-weight:700;color:var(--text-strong);list-style:none;background:var(--bg-soft);transition:background var(--t-fast)}.tp-fold-summary::-webkit-details-marker{display:none}.tp-fold-summary:hover{background:var(--accent-soft)}.tp-fold-summary>i:first-child{color:var(--accent)}.tp-fold-title{flex:1}.tp-fold-tag{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-ring);padding:2px 9px;border-radius:999px}.tp-fold-chev{color:var(--muted);font-size:.8em;transition:transform var(--t)}.tp-fold[open]>.tp-fold-summary .tp-fold-chev{transform:rotate(180deg)}.tp-fold-body{padding:4px 18px 16px}.tp-fold-body>:first-child{margin-top:14px}.tp-fold-body>:last-child{margin-bottom:0}.tp-fold--exercise{border-color:var(--tint-amber-soft)}.tp-fold--exercise>.tp-fold-summary{background:var(--tint-amber-soft)}.tp-fold--exercise>.tp-fold-summary>i:first-child,.tp-fold--exercise>.tp-fold-summary .tp-fold-tag{color:var(--tint-amber)}.tp-fold--exercise>.tp-fold-summary .tp-fold-tag{background:var(--tint-amber-soft);border-color:var(--tint-amber-soft)}.tp-fold--exercise>.tp-fold-summary:hover{filter:brightness(.98)}.tp-fold-body .tp-fold{background:var(--bg)}.read-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--accent);z-index:60;transition:width .1s linear}.steps ol{list-style:none;counter-reset:step;padding-left:0;margin:18px 0}.steps ol>li{position:relative;counter-increment:step;padding-left:54px;padding-bottom:22px;min-height:38px}.steps ol>li:before{content:counter(step);position:absolute;left:0;top:-2px;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;box-shadow:0 0 0 4px var(--accent-soft)}.steps ol>li:after{content:"";position:absolute;left:17px;top:38px;bottom:0;width:2px;background:var(--border)}.steps ol>li:last-child{padding-bottom:0}.steps ol>li:last-child:after{display:none}.steps ol>li>:first-child{margin-top:0}.tp-solution,.tp-hint{margin:18px 0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tp-solution{border-color:var(--accent-ring)}.tp-hint{border-color:var(--tint-amber-soft)}.tp-solution-summary,.tp-hint-summary{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;font-weight:700;list-style:none}.tp-solution-summary::-webkit-details-marker,.tp-hint-summary::-webkit-details-marker{display:none}.tp-solution-summary{background:var(--accent-soft);color:var(--accent-strong)}.tp-hint-summary{background:var(--tint-amber-soft);color:var(--tint-amber)}.tp-solution-chev,.tp-hint-chev{margin-left:auto;font-size:.8em;transition:transform var(--t);opacity:.7}.tp-solution[open] .tp-solution-chev,.tp-hint[open] .tp-hint-chev{transform:rotate(180deg)}.tp-solution-body,.tp-hint-body{padding:4px 18px 16px;background:var(--bg-card)}.tp-solution-body>:first-child,.tp-hint-body>:first-child{margin-top:14px}.tp-solution-body>:last-child,.tp-hint-body>:last-child{margin-bottom:0}.filetree,.filetree ul{list-style:none;margin:0;padding:0}.filetree-root{margin:18px 0;padding:16px 18px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--mono, ui-monospace, monospace);font-size:.92rem}.filetree ul{margin-left:14px;padding-left:14px;border-left:1px dashed var(--border-strong)}.filetree li{margin:3px 0}.ft-name{display:inline-flex;align-items:center;gap:8px}.ft-dir>.ft-name{font-weight:700;color:var(--text-strong)}.ft-dir>.ft-name i{color:var(--accent)}.ft-file>.ft-name{color:var(--text)}.ft-file>.ft-name i{color:var(--muted)}.quiz{margin:22px 0;padding:18px 20px;border:1px solid var(--border);border-left:4px solid var(--tint-blue);border-radius:var(--radius);background:var(--bg-card)}.quiz-q{margin:0 0 14px;font-weight:700;color:var(--text-strong);display:flex;gap:9px}.quiz-q i{color:var(--tint-blue);margin-top:3px}.quiz-opts{display:flex;flex-direction:column;gap:9px}.quiz-opt{display:flex;align-items:center;gap:11px;width:100%;text-align:left;font-family:inherit;font-size:.98rem;color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast)}.quiz-opt:hover:not(:disabled){border-color:var(--tint-blue)}.quiz-marker{width:18px;height:18px;flex:none;border-radius:50%;border:2px solid var(--border-strong)}.quiz-opt.is-correct{border-color:#1f9d57;background:#1f9d571a;color:var(--text-strong)}.quiz-opt.is-correct .quiz-marker{border-color:#1f9d57;background:#1f9d57 radial-gradient(circle,#fff 30%,transparent 32%)}.quiz-opt.is-wrong{border-color:#dc2626;background:#dc262614}.quiz-opt.is-wrong .quiz-marker{border-color:#dc2626}.quiz-opt:disabled{cursor:default}.quiz-feedback{margin:14px 0 0;font-size:.92rem;color:var(--muted)}.quiz-feedback.is-correct{color:#1f9d57}.quiz-feedback.is-wrong{color:var(--text)}.quiz-explanation{color:var(--muted)}.article-body .contains-task-list{list-style:none;padding-left:4px}.article-body .task-list-item{display:flex;align-items:flex-start;gap:10px;margin:6px 0}.article-body .task-list-item input[type=checkbox]{width:18px;height:18px;margin-top:4px;accent-color:var(--accent);flex:none}.article-body .task-list-item.task-done{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--border-strong)}.terminal{margin:22px 0;border-radius:var(--radius);overflow:hidden;border:1px solid #2a2f3a;background:#0d1117;box-shadow:var(--shadow-md);font-family:var(--mono, ui-monospace, monospace)}.terminal-bar{display:flex;align-items:center;gap:10px;padding:9px 14px;background:#161b22;border-bottom:1px solid #2a2f3a}.terminal-dots{display:inline-flex;gap:7px}.terminal-dots i{width:12px;height:12px;border-radius:50%;display:block}.terminal-dots i:nth-child(1){background:#ff5f56}.terminal-dots i:nth-child(2){background:#ffbd2e}.terminal-dots i:nth-child(3){background:#27c93f}.terminal-title{color:#8b949e;font-size:.82rem;flex:1;text-align:center}.terminal-copy{background:none;border:0;color:#8b949e;cursor:pointer;font-size:.9rem;padding:2px 6px;border-radius:6px;transition:color var(--t-fast),background var(--t-fast)}.terminal-copy:hover{color:#fff;background:#ffffff14}.terminal-copy.is-done{color:#27c93f}.terminal-body{padding:16px 18px;font-size:.92rem;line-height:1.65;overflow-x:auto}.t-cmd{color:#e6edf3;white-space:pre-wrap;word-break:break-word}.t-prompt{color:#27c93f;font-weight:700;margin-right:8px;user-select:none}.t-out{color:#9aa4b2;white-space:pre-wrap;word-break:break-word}.t-comment{color:#6e7681;font-style:italic}.code-copy-wrap{position:relative}.code-copy-btn{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#161b22d1;color:#c9d1d9;cursor:pointer;font-size:.85rem;opacity:0;transition:opacity var(--t-fast),color var(--t-fast),background var(--t-fast);backdrop-filter:blur(4px)}.code-copy-wrap:hover .code-copy-btn,.code-copy-btn:focus-visible{opacity:1}.code-copy-btn:hover{background:#282e38f2;color:#fff}.code-copy-btn.is-done{color:#27c93f;opacity:1}@media(hover:none){.code-copy-btn{opacity:.7}}
