@font-face{font-family:Source Code Pro;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/source-code-pro-400.ttf) format("truetype")}@font-face{font-family:Source Code Pro;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/source-code-pro-500.ttf) format("truetype")}@font-face{font-family:Source Code Pro;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/source-code-pro-600.ttf) format("truetype")}@font-face{font-family:Source Code Pro;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/source-code-pro-700.ttf) format("truetype")}@font-face{font-family:Source Code Pro;font-style:normal;font-weight:900;font-display:swap;src:url(/fonts/source-code-pro-900.ttf) format("truetype")}:root{--bg: #0c0c0c;--bg-elevated: #161616;--bg-surface: #1a1a1a;--bg-hover: rgba(255, 255, 255, .04);--bg-card: #161616;--text-primary: #d4d4d4;--text-secondary: rgba(212, 212, 212, .65);--text-muted: rgba(212, 212, 212, .5);--text-dim: rgba(212, 212, 212, .4);--text-inverse: #0c0c0c;--text-faint: rgba(212, 212, 212, .35);--text-ghost: rgba(212, 212, 212, .25);--primary: #3b82f6;--primary-light: #60a5fa;--primary-dark: #2563eb;--accent-prompt: #6366f1;--accent-success: #10b981;--accent-warn: #f59e0b;--accent-error: #ef4444;--accent-string: #e0a060;--border: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .02);--border-medium: rgba(255, 255, 255, .1);--border-heavy: rgba(255, 255, 255, .12);--border-subtle: rgba(255, 255, 255, .04);--text-separator: rgba(255, 255, 255, .08);--bg-active: rgba(255, 255, 255, .04);--bg-interactive: rgba(255, 255, 255, .06);--bg-code-inline: rgba(255, 255, 255, .04);--bg-tint-success: rgba(16, 185, 129, .06);--bg-tint-primary: rgba(59, 130, 246, .05);--bg-tint-warn: rgba(245, 158, 11, .06);--bg-tint-error: rgba(239, 68, 68, .06);--border-tint-success: rgba(16, 185, 129, .25);--border-tint-warn: rgba(245, 158, 11, .2);--border-tint-error: rgba(239, 68, 68, .25);--dot-red: #ff5f56;--dot-yellow: #ffbd2e;--dot-green: #27c93f;--radius: 4px;--radius-lg: 8px;--space-1: 8px;--space-2: 16px;--space-3: 24px;--space-4: 32px;--space-5: 40px;--space-6: 48px;--space-7: 64px;--space-8: 96px;--space-9: 128px;--max-width: 780px;--nav-height: 40px;--font-mono: "Source Code Pro", "SF Mono", "Menlo", "Monaco", "Consolas", "Liberation Mono", monospace;--font-body: "Source Code Pro", "SF Mono", "Menlo", "Monaco", "Consolas", monospace;--font-display: "Source Code Pro", "SF Mono", "Menlo", monospace}:root[data-theme=light]{color-scheme:light;--bg: #f8f6f2;--bg-elevated: #efede8;--bg-surface: #e8e6e1;--bg-hover: rgba(0, 0, 0, .04);--bg-card: #efede8;--text-primary: #1a1a1a;--text-secondary: rgba(26, 26, 26, .7);--text-muted: rgba(26, 26, 26, .55);--text-dim: rgba(26, 26, 26, .45);--text-inverse: #f8f6f2;--text-faint: rgba(26, 26, 26, .38);--text-ghost: rgba(26, 26, 26, .28);--primary: #2563eb;--primary-light: #3b82f6;--primary-dark: #1d4ed8;--accent-prompt: #6366f1;--accent-success: #059669;--accent-warn: #d97706;--accent-error: #dc2626;--accent-string: #b45309;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .03);--border-medium: rgba(0, 0, 0, .12);--border-heavy: rgba(0, 0, 0, .15);--border-subtle: rgba(0, 0, 0, .05);--text-separator: rgba(0, 0, 0, .1);--bg-active: rgba(0, 0, 0, .04);--bg-interactive: rgba(0, 0, 0, .06);--bg-code-inline: rgba(0, 0, 0, .04);--bg-tint-success: rgba(5, 150, 105, .06);--bg-tint-primary: rgba(37, 99, 235, .05);--bg-tint-warn: rgba(217, 119, 6, .06);--bg-tint-error: rgba(220, 38, 38, .06);--border-tint-success: rgba(5, 150, 105, .25);--border-tint-warn: rgba(217, 119, 6, .2);--border-tint-error: rgba(220, 38, 38, .25)}:root{color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip;font-size:14px}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}body{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;overflow-x:clip;overscroll-behavior:none}::selection{background:var(--bg-tint-success)}a{color:var(--primary);text-decoration:none;transition:opacity .2s ease}a:hover{opacity:.8}a:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px;opacity:1}.topbar{height:40px;background:var(--bg-elevated);border-bottom:1px solid var(--border-medium);display:flex;align-items:center;padding:0 1.25rem;padding-top:env(safe-area-inset-top,0px);gap:.85rem;position:fixed;top:0;left:0;right:0;z-index:100}.topbar-dots{display:flex;gap:.45rem;flex-shrink:0}.topbar-dot{width:11px;height:11px;border-radius:50%}.topbar-dot--r{background:var(--dot-red)}.topbar-dot--y{background:var(--dot-yellow)}.topbar-dot--g{background:var(--dot-green)}.topbar-path{font-size:.75rem;color:var(--text-secondary);margin-left:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-path .sep{color:var(--text-separator);margin:0 .25rem}.topbar-path .current{color:var(--text-secondary)}.topbar-right{margin-left:auto;display:flex;gap:.75rem;align-items:center;flex-shrink:0}.topbar-btn{font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary);background:transparent;border:1px solid var(--border-medium);padding:.25rem .65rem;cursor:pointer;transition:color .2s,border-color .2s;text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.topbar-btn:hover{color:var(--text-secondary);border-color:var(--border-heavy);opacity:1}.topbar-btn:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}.topbar-clock{font-size:.75rem;color:var(--text-dim);font-variant-numeric:tabular-nums}.nav{display:flex;gap:.15rem;align-items:center}.nav a{font-family:var(--font-mono);font-size:.82rem;color:var(--text-secondary);text-decoration:none;padding:.3rem .65rem;transition:color .15s,background .15s,border-color .15s;border-left:2px solid transparent}.nav a:hover{color:var(--text-primary);background:var(--bg-hover);opacity:1}.nav a:focus-visible{outline:2px solid var(--primary-light);outline-offset:-2px}.nav a.active{color:var(--text-primary);background:var(--bg-active);border-left-color:var(--primary);opacity:1}#main-content{margin-top:var(--nav-height);flex:1;display:flex;flex-direction:column;padding-bottom:24px}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;width:100%}.status-bar{height:24px;background:var(--bg-elevated);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 1rem;padding-bottom:env(safe-area-inset-bottom,0px);font-size:.72rem;color:var(--text-muted);flex-shrink:0;gap:1.5rem;position:fixed;bottom:0;left:0;right:0;z-index:100}.status-item{display:flex;align-items:center;gap:.3rem}.status-version{margin-left:auto}.status-dot{width:5px;height:5px;background:var(--accent-success);border-radius:50%}@media(prefers-reduced-motion:no-preference){.status-dot{animation:blink 2s ease infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}}.terminal-home{padding:1.5rem 1.5rem 0;max-width:780px;margin:0 auto;min-height:calc(100vh - 64px);display:flex;flex-direction:column}.ascii-art{color:var(--primary);font-size:.58rem;line-height:1.15;margin-bottom:.75rem;overflow-x:auto;white-space:pre}.term-line{font-size:.85rem;line-height:1.75;margin-bottom:.08rem}.term-welcome{margin-bottom:1.5rem;flex-shrink:0}.term-output-area{margin-bottom:1rem;flex-shrink:0}.term-articles{margin-bottom:1rem;flex:1;overflow-y:auto}.term-input-line{display:flex;align-items:center;gap:.5rem;padding:.75rem 0;border-top:1px solid var(--border-medium);background:var(--bg);margin-top:auto;flex-shrink:0}.term-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:.85rem;outline:none;caret-color:var(--accent-success)}.term-input::placeholder{color:var(--text-dim)}.term-input:focus-visible{outline:none}.reading-progress{position:fixed;top:var(--nav-height);left:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent-success));z-index:101;width:0%;transition:width .1s}.term-output{font-size:.82rem;line-height:1.7}.term-prompt{color:var(--accent-prompt);font-weight:600}.term-cmd{color:var(--accent-success)}.term-path{color:var(--primary)}.term-str{color:var(--accent-string)}.term-dim{color:var(--text-muted)}.term-highlight{color:var(--text-primary);font-weight:500}.term-accent{color:var(--primary)}.term-success{color:var(--accent-success)}.term-warn{color:var(--accent-warn)}.term-error{color:var(--accent-error)}.term-comment{color:var(--text-muted);font-style:italic}.article-entry{padding:var(--space-2, 16px) 0;cursor:pointer;transition:border-color .2s cubic-bezier(.23,1,.32,1),background .2s cubic-bezier(.23,1,.32,1),transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1);border-left:2px solid transparent;margin:0;display:block;text-decoration:none;color:inherit;border-bottom:1px solid var(--border);padding-left:var(--space-1, 8px);padding-right:var(--space-1, 8px);background:transparent}.article-entry:hover{border-left-color:var(--primary);background:var(--bg-elevated);opacity:1}.article-entry:active{background:var(--bg-surface)}.article-entry:hover .entry-title{color:var(--primary-light)}@media(hover:hover){.article-entry:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 20px #0000004d}}.entry-num{color:var(--text-muted);font-size:.75rem;font-weight:500;margin-right:.5rem;font-variant-numeric:tabular-nums}.entry-tag{color:var(--accent-warn);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;margin-right:.5rem}.entry-title{color:var(--text-primary);font-size:1rem;font-weight:600;line-height:1.45;transition:color .15s;display:block;margin-top:.2rem}.entry-excerpt{color:var(--text-secondary);font-size:.9rem;margin-top:.2rem;line-height:1.45;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:2.61rem}.entry-meta{float:right;text-align:right;white-space:nowrap;margin-top:.05rem;margin-left:1rem}.entry-date{font-size:.75rem;color:var(--text-muted);display:inline;font-variant-numeric:tabular-nums}.entry-time{font-size:.72rem;color:var(--text-dim);margin-left:.35rem;font-variant-numeric:tabular-nums}.article-container{max-width:var(--max-width);margin:0 auto;padding:2.5rem 1.5rem 4rem}.article-back{font-size:.78rem;color:var(--accent-prompt);text-decoration:none;display:inline-flex;align-items:center;gap:.35rem;margin-bottom:1.75rem;transition:color .2s}.article-back:hover{color:var(--primary-light);opacity:1}.article-tag-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;color:var(--accent-warn);margin-bottom:.65rem;font-weight:600}.article-title{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;letter-spacing:-.04em;line-height:1.1;color:var(--text-primary);margin-bottom:.85rem;text-wrap:balance}.article-meta-row{display:flex;gap:1.25rem;align-items:center;margin-bottom:1.75rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.meta-item{font-size:.78rem;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.meta-label{color:var(--text-muted)}.article-body{font-size:1rem;line-height:1.8;color:var(--text-primary)}.article-body h1{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,1.85rem);font-weight:700;color:var(--text-primary);margin:2.5rem 0 1rem;letter-spacing:-.02em;padding-top:1.5rem;border-top:1px solid var(--border);text-wrap:balance}.article-body h2{font-family:var(--font-display);font-size:clamp(1.25rem,2.5vw,1.45rem);font-weight:600;color:var(--text-primary);margin:2rem 0 .85rem;letter-spacing:-.01em;text-wrap:balance}.article-body h3{font-family:var(--font-display);font-size:clamp(1.05rem,1.8vw,1.2rem);font-weight:500;color:var(--text-primary);margin:1.5rem 0 .65rem;text-wrap:balance}.article-body p{margin-bottom:1.1rem;text-wrap:pretty}.article-body strong{color:var(--text-primary);font-weight:600}.article-body a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}.article-body a:hover{color:var(--primary);opacity:1}.article-body ul,.article-body ol{margin:.65rem 0 1.1rem 1.25rem}.article-body li{margin-bottom:.35rem}.article-body li::marker{color:var(--text-muted)}.article-body blockquote{border-left:3px solid var(--primary);padding:.65rem 1.1rem;margin:1.25rem 0;background:var(--bg-tint-primary);font-style:italic;color:var(--text-secondary)}.tldr-box{border:1px solid var(--border-tint-success);border-left:3px solid var(--accent-success);background:var(--bg-tint-success);padding:.85rem 1.1rem;margin:1.25rem 0;font-size:.85rem;line-height:1.65;color:var(--text-secondary)}.tldr-box strong{color:var(--accent-success)}.disclaimer-box{border:1px solid var(--border-tint-warn);border-left:3px solid var(--accent-warn);background:var(--bg-tint-warn);padding:.85rem 1.1rem;margin:1.25rem 0;font-size:.8rem;line-height:1.6;color:var(--text-muted)}.disclaimer-box strong{color:var(--accent-warn)}.article-body pre,.article-body .astro-code{background:var(--bg-elevated)!important;border:1px solid var(--border-medium);padding:.85rem 1.1rem;margin:1.25rem 0;overflow-x:auto;font-family:var(--font-mono);font-size:.88rem;line-height:1.6;color:var(--text-secondary)!important;position:relative;max-width:100%;box-sizing:border-box}.article-body .astro-code .line span{color:var(--text-secondary)!important}.article-body pre:before{content:"$";position:absolute;top:.65rem;left:.65rem;color:var(--text-dim);font-size:.82rem}.article-body pre code{padding-left:.85rem;display:block}.article-body code{font-family:var(--font-mono);font-size:.82em;background:var(--bg-code-inline);padding:.12rem .35rem;color:var(--accent-string)}.article-body pre code{background:none;padding:0;color:inherit}.code-block-wrap{position:relative}.code-copy-btn{position:absolute;top:.4rem;right:.4rem;background:var(--bg-active);border:1px solid var(--border-medium);color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;padding:.15rem .45rem;cursor:pointer;transition:opacity .2s,color .2s,background .2s;opacity:0}.code-block-wrap:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{color:var(--text-secondary);background:var(--bg-interactive)}.article-body table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.82rem;overflow-x:auto;display:block}.article-body thead{border-bottom:2px solid var(--border-heavy)}.article-body th{text-align:left;padding:.5rem .75rem;font-weight:600;color:var(--text-primary);font-size:.84rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.article-body td{padding:.5rem .75rem;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.article-body tr:hover td{background:var(--border-light)}.article-hero{margin-bottom:1.75rem;border-radius:var(--radius);overflow:hidden}.article-hero img,.hero-img{width:100%;height:auto;display:block}.article-footer{margin-top:2.5rem;padding-top:1.75rem;border-top:1px solid var(--border)}.tags-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:2rem;margin-bottom:1.5rem}.tag-chip{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--border-light);border:1px solid var(--border);padding:.25rem .5rem;transition:color .2s,border-color .2s;cursor:pointer;text-decoration:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.tag-chip:hover{border-color:var(--primary);color:var(--primary-light);opacity:1}.tag-chip:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}.share-section{margin-top:1.5rem;display:flex;gap:.75rem;align-items:center}.share-label{font-size:.6rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.related-section h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);margin-bottom:.85rem}.related-item{display:flex;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border-light);cursor:pointer;transition:padding-left .2s,color .2s;text-decoration:none;color:inherit}.related-item:hover{padding-left:.4rem;opacity:1}.related-item:hover .related-title{color:var(--primary-light)}.related-num{font-size:.72rem;color:var(--text-dim);flex-shrink:0;font-variant-numeric:tabular-nums}.related-tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-warn);margin-bottom:.15rem}.related-title{font-size:.85rem;font-weight:500;color:var(--text-primary);transition:color .2s;line-height:1.35}.related-date{font-size:.72rem;color:var(--text-dim);margin-top:.15rem;font-variant-numeric:tabular-nums}.article-nav{max-width:var(--max-width);margin:0 auto;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border)}.article-nav a{font-size:.78rem;color:var(--accent-prompt);text-decoration:none;transition:opacity .2s}.article-nav a:hover{opacity:.7}.scroll-top-btn{position:fixed;bottom:calc(2rem + env(safe-area-inset-bottom,0px));right:1.5rem;width:32px;height:32px;background:var(--bg-elevated);border:1px solid var(--border-medium);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s,border-color .2s,color .2s;z-index:90;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.scroll-top-btn.visible{opacity:1;visibility:visible}.scroll-top-btn:hover{border-color:var(--primary);color:var(--primary-light)}.scroll-top-btn:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}.skip-link{position:absolute;top:-100%;left:0;background:var(--bg-elevated);color:var(--text-primary);padding:.5rem 1rem;z-index:200;font-size:.72rem}.skip-link:focus{top:0}.footer{background:var(--bg-elevated);border-top:1px solid var(--border-medium);padding:1.75rem 0 2.5rem;margin-bottom:24px}.footer-inner{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start}.footer-brand p{font-size:.88rem;color:var(--text-secondary);line-height:1.5;max-width:320px;margin-top:.35rem}.footer-logo{font-size:.85rem;font-weight:700;color:var(--text-primary);text-decoration:none}.footer-logo:hover{opacity:1}.footer-links{display:grid;grid-template-columns:repeat(3,120px);gap:1.5rem;justify-content:end}.footer-col h4,.footer-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-bottom:.7rem;font-weight:600;font-family:var(--font-mono)}.footer-col a{display:block;font-size:.84rem;color:var(--text-secondary);margin-bottom:.45rem;transition:color .2s;text-decoration:none;line-height:1.5}.footer-col a:hover{color:var(--text-primary);opacity:1}.footer-bottom{display:flex;justify-content:space-between;padding-top:1.25rem;margin-top:1.25rem;border-top:1px solid var(--border-subtle);font-size:.72rem;color:var(--text-muted)}.logo{font-family:var(--font-mono);font-size:.85rem;font-weight:700;color:var(--text-primary);text-decoration:none}.logo:hover{opacity:1}.logo-accent{color:var(--primary-light)}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-elevated);border-bottom:1px solid var(--border-medium);padding:.75rem 1rem;display:none;z-index:50}.search-dropdown.open{display:block}.search-dropdown-input-wrap{display:flex;align-items:center;gap:.5rem;background:var(--bg);border:1px solid var(--border-medium);padding:.5rem .75rem}.search-dropdown-icon{color:var(--text-muted);flex-shrink:0}.search-dropdown-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:.78rem;outline:none}.search-dropdown-input::placeholder{color:var(--text-dim)}.search-dropdown-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.15rem}.search-dropdown-results{max-height:300px;overflow-y:auto;margin-top:.5rem}.search-result-item{display:block;padding:.5rem .65rem;color:var(--text-primary);text-decoration:none;font-size:.78rem;transition:background .15s,border-color .15s;border-left:2px solid transparent}.search-result-item:hover{background:var(--bg-hover);border-left-color:var(--primary);opacity:1}.search-result-item .result-tag{font-size:.72rem;color:var(--accent-warn);text-transform:uppercase;letter-spacing:.08em}.search-result-item .result-title{display:block;margin-top:.1rem}.menu-toggle{display:none;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.menu-toggle:hover{color:var(--text-secondary)}.menu-toggle:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}@media(max-width:768px){.menu-toggle{display:flex}.topbar{padding:0 .75rem}.topbar-path{display:none}.topbar-right .topbar-btn:not(.menu-toggle):not(#themeToggle){display:none}.nav{display:none;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--bg-elevated);border-bottom:1px solid var(--border-medium);padding:.5rem 0;flex-direction:column}.nav.open{display:flex}.nav a{padding:.6rem 1rem;font-size:.78rem;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s,border-color .15s;border-left:2px solid transparent}.nav a:hover,.nav a.active{color:var(--text-primary);background:var(--bg-hover);border-left-color:var(--primary);opacity:1}.footer-inner{grid-template-columns:1fr;gap:1.5rem}.footer-links{flex-direction:column;gap:1.25rem}.footer-bottom{flex-direction:column;gap:.35rem}.terminal-home{padding:1rem 1rem 8rem}.ascii-art{font-size:.42rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.term-input-line{display:flex;padding:.5rem 0;font-size:.78rem}.term-input-line .term-prompt,.term-input{font-size:.78rem}.quick-actions{display:flex!important;position:fixed;bottom:24px;left:0;right:0;background:var(--bg-elevated);border-top:1px solid var(--border-heavy);padding:0;overflow-x:auto;-webkit-overflow-scrolling:touch;z-index:100;gap:0;padding-bottom:env(safe-area-inset-bottom,0px)}.quick-actions::-webkit-scrollbar{display:none}.qa-btn{flex:1;min-width:0;padding:.75rem .35rem;font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-elevated);-webkit-appearance:none;appearance:none;border:none;border-right:1px solid var(--border);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;text-align:center;min-height:44px}.qa-btn:last-child{border-right:none}.qa-btn:active{background:var(--bg-interactive);color:var(--accent-success)}.qa-btn:focus-visible{outline:2px solid var(--primary-light);outline-offset:-2px}.qa-icon{display:block;font-size:.9rem;margin-bottom:.15rem;pointer-events:none}.article-container{padding:1.25rem .85rem 3rem;overflow-x:hidden;width:100%;box-sizing:border-box}.article-hero{max-width:100%;margin-bottom:1.25rem}.article-hero img{max-width:100%;height:auto}.article-tag-label{font-size:.88rem;letter-spacing:.08em;word-break:break-all;overflow-wrap:break-word;max-width:100%}.article-title{font-size:clamp(1.2rem,5vw,1.8rem);line-height:1.15;word-break:break-word;overflow-wrap:break-word;max-width:100%}.article-meta-row{gap:.5rem .85rem;max-width:100%;overflow-wrap:break-word}.article-body{font-size:.84rem;line-height:1.75;overflow-wrap:break-word;word-break:break-word}.article-body p{overflow-wrap:break-word}.article-body code{word-break:break-all}.article-body h1{font-size:clamp(1.1rem,4vw,1.25rem);margin:1.75rem 0 .75rem;padding-top:1rem}.article-body h2{font-size:clamp(1rem,3.5vw,1.1rem);margin:1.5rem 0 .65rem}.article-body h3{font-size:clamp(.9rem,3vw,1rem);margin:1.25rem 0 .5rem}.article-body pre,.article-body .astro-code{font-size:.84rem;padding:.65rem .75rem;margin:1rem 0;border-radius:var(--radius);max-width:100%}.article-body table{font-size:.84rem;margin:1rem 0;max-width:100%}.article-body th,.article-body td{padding:.4rem .5rem}.tldr-box,.disclaimer-box{padding:.65rem .85rem;margin:1rem 0;font-size:.88rem;max-width:100%;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box}.share-section{flex-wrap:wrap;gap:.4rem!important}.tags-row{gap:.3rem}.tag-chip{font-size:.88rem;padding:.2rem .4rem}.article-nav{flex-direction:column;gap:.75rem;text-align:center}.article-entry{padding:.75rem .35rem}.entry-meta{display:none}.term-articles .term-line:has(.term-dim){display:none}.entry-num{display:inline;margin-right:.35rem}.entry-tag{display:inline;margin-right:.35rem;font-size:.72rem}.entry-title{font-size:.82rem;line-height:1.4;margin-top:.15rem;word-break:break-word;overflow-wrap:break-word}.entry-excerpt{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.84rem}.term-welcome .term-line{font-size:.88rem}.term-welcome .term-highlight{font-size:.82rem}.term-welcome .term-dim{font-size:.84rem;line-height:1.5}.related-item{gap:.6rem}}.section{padding:var(--space-7, 64px) 0}.section-sm{padding:var(--space-5, 40px) 0}@media(prefers-reduced-motion:no-preference){.article-entry{opacity:0;animation:article-reveal .3s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--j, 0) * .04s)}@keyframes article-reveal{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-up{opacity:0;transform:translateY(10px);transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1)}.fade-up.visible{opacity:1;transform:translateY(0)}.reveal,.scroll-reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.23,1,.32,1),transform .6s cubic-bezier(.23,1,.32,1)}.reveal.visible,.scroll-reveal.visible{opacity:1;transform:translateY(0)}.scroll-reveal[data-delay="1"],.reveal[data-delay="1"]{transition-delay:80ms}.scroll-reveal[data-delay="2"],.reveal[data-delay="2"]{transition-delay:.16s}.scroll-reveal[data-delay="3"],.reveal[data-delay="3"]{transition-delay:.24s}.scroll-reveal[data-delay="4"],.reveal[data-delay="4"]{transition-delay:.32s}.scroll-reveal[data-delay="5"],.reveal[data-delay="5"]{transition-delay:.4s}.scroll-reveal[data-delay="6"],.reveal[data-delay="6"]{transition-delay:.48s}.img-reveal{clip-path:inset(0 0 100% 0);transition:clip-path .8s cubic-bezier(.23,1,.32,1)}.img-reveal.loaded,.img-reveal[src]{clip-path:inset(0)}}.btn-ripple{position:relative;overflow:hidden}.btn-ripple:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx, 50%) var(--my, 50%),rgba(255,255,255,.25) 0%,transparent 60%);opacity:0;transition:opacity .3s;pointer-events:none}.btn-ripple:active:after{opacity:1}.nav a{position:relative}@media(hover:hover){.nav a:after{content:"";position:absolute;bottom:4px;left:.65rem;width:0;height:1.5px;background:var(--primary);transition:width .35s cubic-bezier(.23,1,.32,1);border-radius:1px}.nav a:hover:after{width:calc(100% - 1.3rem)}}:root[data-theme=light] .btn-ripple:after{background:radial-gradient(circle at var(--mx, 50%) var(--my, 50%),rgba(0,0,0,.1) 0%,transparent 60%)}.theme-icon-sun,.theme-icon-moon{pointer-events:none}[data-theme=dark] .theme-icon-sun{display:inline}[data-theme=dark] .theme-icon-moon,[data-theme=light] .theme-icon-sun{display:none}[data-theme=light] .theme-icon-moon{display:inline}html.theme-transition,html.theme-transition *,html.theme-transition *:before,html.theme-transition *:after{transition:background-color .25s ease,border-color .25s ease,color .25s ease!important}.topbar-btn{transition:color .2s,border-color .2s,transform .25s cubic-bezier(.23,1,.32,1),box-shadow .25s cubic-bezier(.23,1,.32,1)}.topbar-btn:active{background:var(--bg-interactive)}@media(hover:hover){.topbar-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}}.article-entry{transition:border-color .2s cubic-bezier(.23,1,.32,1),background .2s cubic-bezier(.23,1,.32,1),transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1)}@media(hover:hover){.article-entry{padding-left:var(--space-1, 8px);transition:border-color .2s cubic-bezier(.23,1,.32,1),background .2s cubic-bezier(.23,1,.32,1),padding-left .25s cubic-bezier(.23,1,.32,1),transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1)}.article-entry:hover{padding-left:.75rem}}.tag-chip{transition:color .2s cubic-bezier(.23,1,.32,1),border-color .2s cubic-bezier(.23,1,.32,1),transform .2s cubic-bezier(.23,1,.32,1)}.tag-chip:active{background:var(--bg-interactive)}@media(hover:hover){.tag-chip:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}}.scroll-top-btn{transition:opacity .3s,visibility .3s,border-color .2s,color .2s,transform .25s cubic-bezier(.23,1,.32,1)}@media(hover:hover){.scroll-top-btn:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000040}}.search-dropdown-results.loading:after{content:"Memuat index...";display:block;padding:.5rem .65rem;font-size:.78rem;color:var(--text-muted);animation:search-load-pulse 1.5s ease infinite}@keyframes search-load-pulse{0%,to{opacity:.6}50%{opacity:1}}.article-hero img{opacity:0;transition:opacity .5s ease}.article-hero img[src]{opacity:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.content-narrow{max-width:800px;margin:0 auto}.content-medium{max-width:720px;margin:0 auto}.term-border{color:var(--border)}.term-cat-link{text-decoration:none;margin-right:.5rem}.title-inherit{font-size:inherit;font-weight:inherit;margin:0;line-height:inherit}.icon-inline{vertical-align:middle;margin-right:6px}.icon-status{vertical-align:-2px;margin-right:4px}.icon-btn{vertical-align:-3px;margin-right:4px}.hidden{display:none}.last-updated{margin-top:3rem;color:var(--text-muted);font-size:.9rem}@media print{.topbar,.status-bar,.scroll-top-btn,.reading-progress{display:none}body{background:#fff;color:#000}.article-body{color:#333}a{color:#1e40af}}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
