.post-meta{flex-direction:column;width:100%;margin-bottom:24px;display:flex}.post-detail__title{font-size:28px;font-weight:var(--font-weight-bold);text-align:left;margin-bottom:16px;line-height:1.3}.post-detail__tags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.post-detail__meta{font-size:var(--font-size-xs);color:var(--text-muted);align-items:center;gap:6px;display:flex}.post-detail__meta .sep{color:var(--border-hover)}.post-detail .prompt{font-size:var(--font-size-base);word-break:break-word;overflow-wrap:anywhere;max-width:100%;line-height:1.8;overflow:hidden}.post-detail .prompt span{margin-right:8px}.post-detail .prompt .args{color:var(--text-secondary);margin-right:0}.post-detail .prompt .path{color:var(--blue)}.post-detail .prompt .dollar{color:var(--text-muted)}.post-detail .prompt .cmd{color:var(--green)}.post-detail .dashed-divider{margin:24px 0}
.detail-body{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.85}.detail-body h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text);text-align:left;margin:40px 0 16px}.detail-body h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semi-bold);color:var(--text);text-align:left;margin:32px 0 12px}.detail-body h4{font-size:15px;font-weight:var(--font-weight-semi-bold);color:var(--text);text-align:left;margin:28px 0 8px}.detail-body p{word-break:keep-all;text-align:left;margin-bottom:20px}.detail-body strong{color:var(--text);font-weight:var(--font-weight-semi-bold)}.detail-body code{font-family:var(--font);background:var(--surface);font-size:var(--font-size-base);color:var(--orange);border:1px solid var(--border);border-radius:3px;padding:2px 7px}.detail-body blockquote{background:var(--surface);border-left:2px solid var(--text-muted);border-radius:0 var(--radius)var(--radius)0;color:var(--text-secondary);font-size:var(--font-size-sm);margin:16px 0;padding:12px 16px;font-style:italic}.detail-body blockquote>p{margin:0}.detail-body .callout{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);font-size:var(--font-size-sm);margin:20px 0;padding:14px 16px;line-height:1.7}.detail-body .callout__header{font-weight:var(--font-weight-semi-bold);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:6px;margin-bottom:6px;display:flex}.detail-body .callout__body>p{margin:0}.detail-body .callout--tip{border-left:2px solid var(--green)}.detail-body .callout--tip .callout__header{color:var(--green)}.detail-body .callout--warn{border-left:2px solid var(--yellow)}.detail-body .callout--warn .callout__header{color:var(--yellow)}.detail-body .callout--info{border-left:2px solid var(--blue)}.detail-body .callout--info .callout__header{color:var(--blue)}.detail-body hr{border:none;border-top:1px dashed var(--border);margin:32px 0}.detail-body ol>li,.detail-body ul>li{margin-top:4px;margin-bottom:8px;margin-left:16px}.detail-body ul{list-style:none}.detail-body ul>li{list-style:none;position:relative}.detail-body ul>li:before{content:"▸";color:var(--green);position:absolute;left:-16px}.detail-body ol,.detail-body ol>li{list-style-type:decimal}.detail-body>ol,.detail-body>ul{padding-left:24px}.detail-body img{border-radius:var(--radius);border:1px solid var(--border);content-visibility:auto;max-width:100%;height:auto;margin:24px 0;display:block}.detail-body picture{min-height:200px;display:block}.post-detail__code{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);margin:24px 0;overflow:hidden}.post-detail__code-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 20px;display:flex}.post-detail__code-language{font-family:var(--font);font-size:var(--font-size-xs);color:var(--text-muted)}.post-detail__code-copy{font-family:var(--font);font-size:var(--font-size-2xs);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;transition:var(--transition);background:0 0;border-radius:3px;padding:2px 8px}.post-detail__code-copy:hover{border-color:var(--border-hover);color:var(--text-secondary)}.post-detail__code-block{font-family:var(--font);font-size:var(--font-size-sm);color:var(--text);margin:0;padding:20px 24px;line-height:1.75;overflow-x:auto}.post-detail__code-block>code{font-size:var(--font-size-sm);white-space:pre-wrap;word-break:break-all;color:inherit;background:0 0;border:none;margin:0;padding:0;display:block}.highlighted-code-line{background-color:var(--green-dim);border-left:3px solid var(--green);box-sizing:border-box;width:100%;padding-left:3px;display:inline-block}.detail-body table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);margin:20px 0}.detail-body th{background:var(--surface);text-align:left;font-weight:var(--font-weight-semi-bold);border-bottom:1px solid var(--border);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.3px;color:var(--text);padding:8px 12px}.detail-body td{border-bottom:1px dashed var(--border);padding:8px 12px}.detail-body tr:hover td{background:var(--surface)}.detail-body--skeleton{flex-direction:column;gap:12px;padding:20px 0;display:flex}.skeleton-line{background:var(--surface);border-radius:4px;height:14px;animation:1.5s ease-in-out infinite skeleton-pulse}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}@media (max-width:768px){.detail-body{font-size:13px}.detail-body h2{margin:32px 0 12px;font-size:18px}.detail-body h3{margin:24px 0 10px;font-size:15px}.detail-body table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.detail-body img{max-width:100%;height:auto}.post-detail__code{border-left:none;border-right:none;border-radius:0;margin:16px -16px}.post-detail__code-block{padding:16px;font-size:12px}.post-detail__title{font-size:22px}}
.related-posts{border-top:1px dashed var(--border);margin-top:64px;padding-top:28px}.related-posts__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);letter-spacing:.5px;margin-bottom:16px}.related-posts__list{padding:0;list-style:none}.related-posts__item{font-size:var(--font-size-sm);color:var(--text-secondary);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:8px;padding:6px 8px;text-decoration:none;display:flex}.related-posts__item:hover{background:var(--green-dim);color:var(--green)}.related-posts__item .connector{color:var(--text-muted);font-size:var(--font-size-base);flex-shrink:0}.comments-section{margin-top:40px}
.post-detail__toc{top:calc(var(--header-height) + 16px);align-self:start;position:sticky}.toc__title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semi-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.toc__list{font-size:var(--font-size-xs);border-left:1px solid var(--border);scrollbar-width:thin;max-height:calc(100vh - 100px);position:relative;overflow-y:auto}.toc__list::-webkit-scrollbar{width:3px}.toc__list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.post-detail__toc.has-overflow .toc__list:after{content:"";background:linear-gradient(transparent,var(--surface,var(--bg)));pointer-events:none;height:32px;display:block;position:sticky;bottom:0;left:0;right:0}.toc__item{color:var(--text-muted);transition:color var(--transition),border-color var(--transition);cursor:pointer;border-left:2px solid #0000;margin-left:-1px;padding:5px 10px;line-height:1.5;text-decoration:none;display:block;position:relative}.toc__item:hover{color:var(--text-secondary)}.toc__item:focus-visible{outline:2px solid var(--green);outline-offset:-2px;border-radius:var(--radius)}.toc__item.active{color:var(--green);border-left-color:var(--green)}.toc-mobile-fab{background:var(--green);width:44px;height:44px;color:var(--bg);cursor:pointer;z-index:1000;border-radius:50%;font-size:20px;line-height:1;transition:transform .2s,opacity .2s;display:none;position:fixed;bottom:24px;right:24px;box-shadow:0 2px 8px #0000004d}.toc-mobile-fab:active{transform:scale(.9)}.toc-mobile-backdrop{z-index:1001;opacity:0;background:#00000080;transition:opacity .25s;display:none;position:fixed;inset:0}.toc-mobile-backdrop.open{opacity:1}.toc-mobile-panel{background:var(--surface,var(--bg));border-top:1px solid var(--border);z-index:1002;border-radius:12px 12px 0 0;max-height:60vh;transition:transform .3s;display:none;position:fixed;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%)}.toc-mobile-panel.open{transform:translateY(0)}.toc-mobile-panel__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.toc-mobile-panel__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semi-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.toc-mobile-panel__close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:color var(--transition);padding:4px 8px;font-size:18px}.toc-mobile-panel__close:hover{color:var(--text)}.toc-mobile-panel__body{max-height:calc(60vh - 60px);padding:8px 0;overflow-y:auto}.toc-mobile-panel__body .toc__item{font-size:var(--font-size-sm);border-left:none;margin-left:0;padding:10px 16px}.toc-mobile-panel__body .toc__item.active{color:var(--green);background:var(--surface-hover)}@media (max-width:768px){.post-detail__toc{display:none}.toc-mobile-fab,.toc-mobile-backdrop,.toc-mobile-panel{display:block}.toc-mobile-backdrop{display:none}.toc-mobile-backdrop.open{display:block}}@media (min-width:769px){.toc-mobile-fab,.toc-mobile-backdrop,.toc-mobile-panel{display:none!important}}
.post-detail{grid-template-columns:minmax(0,720px) 180px;gap:48px;max-width:960px;margin:0 auto;padding:32px 24px 64px;display:grid}.post-detail__article{overflow-wrap:anywhere;min-width:0}.post-heading{scroll-margin-top:80px}@media (min-width:769px) and (max-width:1024px){.post-detail{grid-template-columns:minmax(0,1fr) 160px;gap:32px;padding:24px 16px 48px}}@media (max-width:768px){.post-detail{grid-template-columns:1fr;gap:0;padding:16px 16px 48px}.post-detail__article{min-width:0;overflow-x:hidden}.post-detail__sidebar{display:none}}
.hljs{color:var(--text);background:0 0}:root,[data-theme=dracula]{--hljs-keyword:#ff79c6;--hljs-string:#f1fa8c;--hljs-number:#bd93f9;--hljs-literal:#bd93f9;--hljs-type:#8be9fd;--hljs-built-in:#8be9fd;--hljs-function:#50fa7b;--hljs-title:#50fa7b;--hljs-attr:#50fa7b;--hljs-variable:#f8f8f2;--hljs-comment:#6272a4;--hljs-meta:#6272a4;--hljs-tag:#ff79c6;--hljs-name:#ff79c6;--hljs-selector:#50fa7b;--hljs-property:#66d9ef;--hljs-operator:#ff79c6;--hljs-punctuation:#f8f8f2;--hljs-addition:#50fa7b;--hljs-deletion:#f55}[data-theme=nord]{--hljs-keyword:#81a1c1;--hljs-string:#a3be8c;--hljs-number:#b48ead;--hljs-literal:#81a1c1;--hljs-type:#8fbcbb;--hljs-built-in:#8fbcbb;--hljs-function:#88c0d0;--hljs-title:#88c0d0;--hljs-attr:#8fbcbb;--hljs-variable:#d8dee9;--hljs-comment:#616e88;--hljs-meta:#5e81ac;--hljs-tag:#81a1c1;--hljs-name:#81a1c1;--hljs-selector:#a3be8c;--hljs-property:#88c0d0;--hljs-operator:#81a1c1;--hljs-punctuation:#eceff4;--hljs-addition:#a3be8c;--hljs-deletion:#bf616a}[data-theme=tokyo-night]{--hljs-keyword:#bb9af7;--hljs-string:#9ece6a;--hljs-number:#ff9e64;--hljs-literal:#ff9e64;--hljs-type:#2ac3de;--hljs-built-in:#7dcfff;--hljs-function:#7aa2f7;--hljs-title:#7aa2f7;--hljs-attr:#73daca;--hljs-variable:#c0caf5;--hljs-comment:#565f89;--hljs-meta:#565f89;--hljs-tag:#f7768e;--hljs-name:#f7768e;--hljs-selector:#9ece6a;--hljs-property:#7dcfff;--hljs-operator:#89ddff;--hljs-punctuation:#a9b1d6;--hljs-addition:#9ece6a;--hljs-deletion:#f7768e}[data-theme=github-light]{--hljs-keyword:#cf222e;--hljs-string:#0a3069;--hljs-number:#0550ae;--hljs-literal:#0550ae;--hljs-type:#953800;--hljs-built-in:#953800;--hljs-function:#8250df;--hljs-title:#8250df;--hljs-attr:#116329;--hljs-variable:#24292f;--hljs-comment:#6e7781;--hljs-meta:#6e7781;--hljs-tag:#116329;--hljs-name:#116329;--hljs-selector:#1a7f37;--hljs-property:#0550ae;--hljs-operator:#cf222e;--hljs-punctuation:#24292f;--hljs-addition:#1a7f37;--hljs-deletion:#cf222e}[data-theme=catppuccin-latte]{--hljs-keyword:#8839ef;--hljs-string:#40a02b;--hljs-number:#fe640b;--hljs-literal:#fe640b;--hljs-type:#df8e1d;--hljs-built-in:#df8e1d;--hljs-function:#1e66f5;--hljs-title:#1e66f5;--hljs-attr:#179299;--hljs-variable:#4c4f69;--hljs-comment:#9ca0b0;--hljs-meta:#9ca0b0;--hljs-tag:#d20f39;--hljs-name:#d20f39;--hljs-selector:#40a02b;--hljs-property:#04a5e5;--hljs-operator:#8839ef;--hljs-punctuation:#4c4f69;--hljs-addition:#40a02b;--hljs-deletion:#d20f39}.hljs-keyword,.hljs-selector-tag{color:var(--hljs-keyword)}.hljs-string,.hljs-doctag,.hljs-template-variable,.hljs-template-tag{color:var(--hljs-string)}.hljs-number{color:var(--hljs-number)}.hljs-literal,.hljs-symbol,.hljs-bullet{color:var(--hljs-literal)}.hljs-type,.hljs-class .hljs-title{color:var(--hljs-type)}.hljs-built_in{color:var(--hljs-built-in)}.hljs-function .hljs-title,.hljs-title.function_,.hljs-title{color:var(--hljs-title)}.hljs-attr{color:var(--hljs-attr)}.hljs-variable,.hljs-params{color:var(--hljs-variable)}.hljs-comment{color:var(--hljs-comment);font-style:italic}.hljs-meta,.hljs-meta .hljs-keyword,.hljs-meta .hljs-string{color:var(--hljs-meta)}.hljs-tag{color:var(--hljs-tag)}.hljs-name{color:var(--hljs-name)}.hljs-selector-id,.hljs-selector-class{color:var(--hljs-selector)}.hljs-property{color:var(--hljs-property)}.hljs-operator{color:var(--hljs-operator)}.hljs-punctuation{color:var(--hljs-punctuation)}.hljs-addition{color:var(--hljs-addition);background:#50fa7b1a}.hljs-deletion{color:var(--hljs-deletion);background:#ff55551a}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{color:var(--hljs-built-in);text-decoration:underline}.hljs-regexp{color:var(--hljs-string)}.hljs-section{color:var(--hljs-title);font-weight:700}.hljs-subst{color:var(--hljs-variable)}.code-line-number{color:var(--text-muted);opacity:.5;-webkit-user-select:none;user-select:none;margin-right:16px}
.series-nav{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:var(--radius);margin-bottom:32px;overflow:hidden}.series-nav__header{cursor:pointer;width:100%;font-size:var(--font-size-sm);transition:background var(--transition);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.series-nav__header:hover{background:var(--surface-hover)}.series-nav__header .label{color:var(--green);font-family:var(--font-mono);font-size:var(--font-size-2xs);font-weight:var(--font-weight-bold);letter-spacing:1.5px;text-transform:uppercase;background:color-mix(in srgb,var(--green)12%,transparent);border-radius:3px;padding:2px 6px}.series-nav__header .title{color:var(--text);font-weight:var(--font-weight-semi-bold);margin-left:10px}.series-nav__header .count{color:var(--text-muted);font-weight:var(--font-weight-regular);font-size:var(--font-size-xs);margin-left:6px}.series-nav__header .arrow{color:var(--text-muted);font-size:var(--font-size-xs);flex-shrink:0;transition:transform .2s}.series-nav.collapsed .series-nav__header .arrow{transform:rotate(-90deg)}.series-nav__body{transition:max-height .25s;overflow:hidden}.series-nav__list{padding:4px 12px 12px}.series-nav__item{border-radius:var(--radius);color:var(--text-secondary);font-size:var(--font-size-sm);transition:background var(--transition),color var(--transition);align-items:flex-start;gap:8px;padding:6px 10px;line-height:1.5;text-decoration:none;display:flex}.series-nav__item:hover{background:var(--surface-hover);color:var(--text)}.series-nav__item .num{color:var(--text-muted);font-family:var(--font-mono);font-size:var(--font-size-xs);text-align:right;flex-shrink:0;min-width:20px;line-height:1.5}.series-nav__item .check{color:var(--green);opacity:.6;flex-shrink:0;min-width:16px;line-height:1.5}.series-nav__item .current-marker{color:var(--green);min-width:16px;line-height:1.5;font-weight:var(--font-weight-bold);flex-shrink:0}.series-nav__item.active{color:var(--green);font-weight:var(--font-weight-medium);background:color-mix(in srgb,var(--green)8%,transparent);border-radius:var(--radius)}.series-nav__item.active .num{color:var(--green)}.series-nav__item.future{color:var(--text-muted);opacity:.7}.series-nav__ellipsis{color:var(--text-muted);font-size:var(--font-size-xs);text-align:center;letter-spacing:3px;opacity:.5;padding:4px 10px}.series-nav__toggle{width:100%;font-size:var(--font-size-xs);font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;text-align:center;border:none;border-top:1px dashed var(--border);transition:color var(--transition),background var(--transition);background:0 0;padding:8px 18px;display:block}.series-nav__toggle:hover{color:var(--green);background:var(--surface-hover)}.series-nav__footer{border-top:1px solid var(--border);font-size:var(--font-size-xs);background:color-mix(in srgb,var(--surface)60%,var(--bg));justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.series-nav__footer a{color:var(--text-secondary);font-family:var(--font-mono);border-radius:var(--radius);transition:color var(--transition),background var(--transition);padding:4px 10px;text-decoration:none}.series-nav__footer a:hover{color:var(--green);background:var(--surface-hover)}.series-nav__footer .disabled{opacity:.25;pointer-events:none;color:var(--text-muted);padding:4px 10px}@media (max-width:768px){.series-nav__list{max-height:200px;overflow-y:auto}.series-nav__header{padding:12px 14px}.series-nav__footer{padding:8px 14px}}
.detail-breadcrumb{font-family:var(--font);font-size:var(--font-size-xs);color:var(--text-muted);flex-wrap:wrap;align-items:center;margin-bottom:12px;display:flex}.detail-breadcrumb .sep{color:var(--border-hover)}.detail-breadcrumb a{color:var(--text-secondary);transition:var(--transition);text-decoration:none}.detail-breadcrumb a:hover,.detail-breadcrumb .current{color:var(--green)}
