@font-face{font-family:Plus Jakarta Sans;font-style:normal;font-weight:200 800;font-display:swap;src:url(/fonts/plus-jakarta-sans-latin.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/fonts/jetbrains-mono-latin.woff2) format("woff2")}:root{--bg: #ffffff;--surface: #ffffff;--surface-2: #f6f7f9;--text: #0f172a;--text-muted: #5b6472;--text-soft: #6b7280;--border: #e7e9ee;--accent: #2563eb;--accent-weak: #eaf0ff;--accent-ink: #1646b8;--on-accent: #ffffff;--radius: 14px;--radius-sm: 10px;--shadow: 0 1px 2px rgba(16, 24, 40, .04), 0 6px 20px rgba(16, 24, 40, .06);--maxw: 1080px;--font: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}.cover-0{background:#eaf0ff}.cover-1{background:#e7f7ef}.cover-2{background:#fff3e0}.cover-3{background:#fdeaf0}.cover-4{background:#eef0f3}html[data-theme=dark] .cover-0{background:#1c2740}html[data-theme=dark] .cover-1{background:#16291f}html[data-theme=dark] .cover-2{background:#2c2417}html[data-theme=dark] .cover-3{background:#2c1b25}html[data-theme=dark] .cover-4{background:#1f2939}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6;font-size:16px}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:40px 0 18px}.section-head h2{font-size:20px;font-weight:600;margin:0}.section-head a{color:var(--accent);font-size:14px;font-weight:500}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}@media(max-width:860px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.grid{grid-template-columns:1fr}}.chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--accent-ink);background:var(--accent-weak);padding:4px 11px;border-radius:999px}.meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-soft)}.avatar{width:24px;height:24px;border-radius:50%;flex:0 0 24px;background:var(--accent-weak);color:var(--accent-ink);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.prose{font-size:17px;line-height:1.75;color:var(--text)}.prose h2{font-size:22px;font-weight:600;margin:1.8rem 0 .6rem}.prose h3{font-size:18px;font-weight:600;margin:1.4rem 0 .5rem}.prose p{margin:0 0 1rem}.prose ul,.prose ol{margin:0 0 1rem;padding-left:1.3rem}.prose li{margin:.3rem 0}.prose a{color:var(--accent);text-decoration:underline}.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88em;background:var(--surface-2);padding:.1em .35em;border-radius:6px}.prose pre{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;overflow-x:auto;margin:0 0 1rem}.prose pre code{background:none;padding:0;font-size:14px;line-height:1.6}.prose blockquote{margin:0 0 1rem;padding:2px 0 2px 16px;border-left:3px solid var(--accent);color:var(--text-muted);font-style:italic}.prose sup{font-size:.72em;line-height:0}.prose sup a{padding:0 3px}.prose .footnotes{margin-top:2.6rem;padding-top:1.2rem;border-top:1px solid var(--border);font-size:15px;color:var(--text-muted)}.prose .footnotes:before{content:"Referensi";display:block;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-soft);margin-bottom:12px}.prose .footnotes ol{padding-left:1.3rem;margin:0}.prose .footnotes li{margin:.9rem 0;line-height:1.8}.prose .footnotes li p{margin:0;overflow-wrap:anywhere}.prose .footnotes a[data-footnote-backref]{display:inline-block;margin-left:8px;padding:4px 10px;font-size:18px;line-height:1;text-decoration:none}.prose .callout{display:flex;gap:12px;margin:0 0 1.1rem;padding:13px 16px;border-radius:var(--radius-sm);background:var(--surface-2);border-left:3px solid var(--border)}.prose .callout-icon{font-size:18px;line-height:1.6;flex-shrink:0}.prose .callout-body{min-width:0;flex:1}.prose .callout-body>:first-child{margin-top:0}.prose .callout-body>:last-child{margin-bottom:0}.prose .callout-info{border-left-color:#3b82f6}.prose .callout-tip{border-left-color:#22c55e}.prose .callout-warning{border-left-color:#f59e0b}.prose .callout-note{border-left-color:var(--text-soft)}.prose .callout-danger{border-left-color:#ef4444}.prose .callout-cta{justify-content:center;text-align:center;border-left:0}.prose .callout-cta a{display:inline-block;padding:10px 22px;border-radius:var(--radius);background:var(--accent);color:var(--on-accent);font-weight:600;text-decoration:none}.prose .callout-cta a:hover{filter:brightness(1.05)}.prose .callout-quote{background:transparent;border-left:4px solid var(--accent);font-size:1.15em;font-style:italic;color:var(--text-muted)}.prose hr{border:0;height:1px;background:var(--border);margin:2.2rem 0}.prose .faq{margin:0 0 1.1rem;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.prose .faq-item{border-top:1px solid var(--border)}.prose .faq-item:first-child{border-top:0}.prose .faq-item>summary{cursor:pointer;padding:13px 16px;font-weight:600;list-style:none;background:var(--surface)}.prose .faq-item>summary::-webkit-details-marker{display:none}.prose .faq-item>summary:after{content:"+";float:right;color:var(--text-soft);font-weight:400}.prose .faq-item[open]>summary:after{content:"–"}.prose .faq-item[open]>summary{background:var(--surface-2)}.prose .faq-a{padding:4px 16px 14px}.prose .faq-a>:first-child{margin-top:0}.prose .faq-a>:last-child{margin-bottom:0}.prose .embed-frame{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);margin:0 0 1.2rem;display:block}.prose .embed-codepen{height:400px}.prose .embed-gist{height:360px;background:var(--surface)}.prose .twitter-tweet,.prose .instagram-media{margin-left:auto!important;margin-right:auto!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.theme-toggle[data-astro-cid-x3pjskd3]{background:none;border:0;padding:0;margin:0;color:var(--text-muted);font-size:17px;line-height:1;cursor:pointer;display:inline-flex;align-items:center}.theme-toggle[data-astro-cid-x3pjskd3]:hover{color:var(--text)}.theme-toggle[data-astro-cid-x3pjskd3] .ico[data-astro-cid-x3pjskd3]{display:none}html[data-theme=light] .theme-toggle[data-astro-cid-x3pjskd3] .ico-moon[data-astro-cid-x3pjskd3],html[data-theme=dark] .theme-toggle[data-astro-cid-x3pjskd3] .ico-sun[data-astro-cid-x3pjskd3]{display:inline}.nav[data-astro-cid-dmqpwcec]{border-bottom:1px solid var(--border);background:var(--surface)}.nav-inner[data-astro-cid-dmqpwcec]{display:flex;align-items:center;justify-content:space-between;height:62px}.brand[data-astro-cid-dmqpwcec]{display:inline-flex;align-items:center}.brand-logo[data-astro-cid-dmqpwcec]{height:25px;width:auto;display:block}.nav-links[data-astro-cid-dmqpwcec]{display:flex;align-items:center;gap:22px}.nav-links[data-astro-cid-dmqpwcec] a[data-astro-cid-dmqpwcec]{color:var(--text-muted);font-size:14px;font-weight:500}.nav-links[data-astro-cid-dmqpwcec] a[data-astro-cid-dmqpwcec]:hover{color:var(--text)}.nav-search[data-astro-cid-dmqpwcec]{display:inline-flex;align-items:center;color:var(--text-muted)}.nav-search[data-astro-cid-dmqpwcec]:hover{color:var(--text)}@media(max-width:560px){.nav-links[data-astro-cid-dmqpwcec]{gap:14px}}.footer[data-astro-cid-sz7xmlte]{border-top:1px solid var(--border);margin-top:56px}.footer-inner[data-astro-cid-sz7xmlte]{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px 18px;min-height:70px;padding:16px 0;font-size:13px;color:var(--text-soft)}.brand[data-astro-cid-sz7xmlte]{display:inline-flex;align-items:center;color:var(--text)}.brand-logo[data-astro-cid-sz7xmlte]{height:20px;width:auto;display:block}.footer-links[data-astro-cid-sz7xmlte]{display:flex;gap:16px}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--text-muted)}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--text)}.tagline[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--text-muted);text-decoration:underline}.tagline[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--text)}@media(max-width:620px){.footer-inner[data-astro-cid-sz7xmlte]{justify-content:center;text-align:center}}
