.tutorial-article[data-astro-cid-amgwr4wo]{max-width:740px;margin:0 auto}.tut-meta-boxes[data-astro-cid-amgwr4wo]{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.75rem}@media (max-width: 560px){.tut-meta-boxes[data-astro-cid-amgwr4wo]{grid-template-columns:1fr}}.tut-learn-box[data-astro-cid-amgwr4wo],.tut-prereq-box[data-astro-cid-amgwr4wo]{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.375rem}.tut-learn-box[data-astro-cid-amgwr4wo]{border-top:3px solid var(--cat-color, var(--color-primary));border-color:color-mix(in srgb,var(--cat-color, var(--color-primary)) 15%,var(--color-border));border-top-color:var(--cat-color, var(--color-primary))}.tut-prereq-box[data-astro-cid-amgwr4wo]{border-top:3px solid var(--color-border-2);border-color:color-mix(in srgb,var(--color-muted-2) 12%,var(--color-border));border-top-color:var(--color-border-2)}.tut-box-label[data-astro-cid-amgwr4wo]{display:flex;align-items:center;gap:.375rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted-2);margin:0 0 .625rem}.tut-learn-box[data-astro-cid-amgwr4wo] .tut-box-label[data-astro-cid-amgwr4wo]{color:var(--cat-color, var(--color-primary))}.tut-learn-list[data-astro-cid-amgwr4wo],.tut-prereq-list[data-astro-cid-amgwr4wo]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.tut-learn-list[data-astro-cid-amgwr4wo] li[data-astro-cid-amgwr4wo]{display:flex;align-items:flex-start;gap:.4rem;font-size:.8375rem;color:var(--color-text-2);line-height:1.5}.tut-learn-list[data-astro-cid-amgwr4wo] li[data-astro-cid-amgwr4wo] svg[data-astro-cid-amgwr4wo]{flex-shrink:0;margin-top:.2rem;stroke:var(--cat-color, var(--color-primary))}.tut-prereq-list[data-astro-cid-amgwr4wo] li[data-astro-cid-amgwr4wo]{font-size:.8375rem;color:var(--color-muted);padding-left:1rem;position:relative;line-height:1.5}.tut-prereq-list[data-astro-cid-amgwr4wo] li[data-astro-cid-amgwr4wo]:before{content:"–";position:absolute;left:0;color:var(--color-muted-2)}.colab-btn[data-astro-cid-amgwr4wo]{display:inline-flex;align-items:center;gap:.4rem;margin-top:.875rem;padding:.3rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.78rem;font-weight:600;color:var(--color-text-2);background:var(--color-bg);text-decoration:none;transition:border-color .15s,background .15s}.colab-btn[data-astro-cid-amgwr4wo]:hover{border-color:var(--cat-color, var(--color-primary));background:var(--color-surface);text-decoration:none}.tut-prevnext[data-astro-cid-amgwr4wo]{margin-top:2.5rem;border-top:1px solid var(--color-border);padding-top:1.75rem}.prevnext-inner[data-astro-cid-amgwr4wo]{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 480px){.prevnext-inner[data-astro-cid-amgwr4wo]{grid-template-columns:1fr}}.prevnext-card[data-astro-cid-amgwr4wo]{display:flex;flex-direction:column;gap:.375rem;padding:1rem 1.125rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);text-decoration:none;transition:border-color .15s,background .15s}.prevnext-card[data-astro-cid-amgwr4wo]:hover{border-color:var(--cat-color, var(--color-primary));background:var(--color-bg-alt);text-decoration:none}.prevnext-next[data-astro-cid-amgwr4wo]{text-align:right}.prevnext-dir[data-astro-cid-amgwr4wo]{display:flex;align-items:center;gap:.375rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted-2)}.prevnext-next[data-astro-cid-amgwr4wo] .prevnext-dir[data-astro-cid-amgwr4wo]{justify-content:flex-end}.prevnext-title[data-astro-cid-amgwr4wo]{font-size:.875rem;font-weight:600;color:var(--color-text-2);line-height:1.4}.prevnext-empty[data-astro-cid-amgwr4wo]{display:block}.tut-series-pos[data-astro-cid-amgwr4wo]{font-size:.73rem;font-weight:600;color:var(--cat-color, var(--color-primary));background:color-mix(in srgb,var(--cat-color, var(--color-primary)) 10%,transparent);border:1px solid color-mix(in srgb,var(--cat-color, var(--color-primary)) 25%,transparent);border-radius:999px;padding:.15rem .5rem;white-space:nowrap}.tut-feedback[data-astro-cid-amgwr4wo]{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding:1rem 1.25rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.tut-feedback-label[data-astro-cid-amgwr4wo]{font-size:.875rem;font-weight:600;color:var(--color-text-2);margin:0;flex-shrink:0}.tut-feedback-actions[data-astro-cid-amgwr4wo]{display:flex;gap:.5rem;margin-right:auto}.tut-feedback-btn[data-astro-cid-amgwr4wo]{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-muted);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s}.tut-feedback-btn[data-astro-cid-amgwr4wo]:hover{border-color:var(--cat-color, var(--color-primary));color:var(--cat-color, var(--color-primary))}.tut-feedback[data-astro-cid-amgwr4wo][data-submitted=yes] .tut-feedback-btn[data-astro-cid-amgwr4wo][data-value=yes],.tut-feedback[data-astro-cid-amgwr4wo][data-submitted=no] .tut-feedback-btn[data-astro-cid-amgwr4wo][data-value=no]{background:color-mix(in srgb,var(--cat-color, var(--color-primary)) 12%,transparent);border-color:var(--cat-color, var(--color-primary));color:var(--cat-color, var(--color-primary))}.tut-feedback[data-astro-cid-amgwr4wo][data-submitted] .tut-feedback-btn[data-astro-cid-amgwr4wo]{cursor:default}.tut-share-btn[data-astro-cid-amgwr4wo]{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-muted);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0}.tut-share-btn[data-astro-cid-amgwr4wo]:hover{border-color:var(--color-border-2);color:var(--color-text-2)}.tutorial-toc[data-astro-cid-amgwr4wo]{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:2rem;font-size:.875rem}.tutorial-toc-label[data-astro-cid-amgwr4wo]{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-muted-2);margin-bottom:.5rem;display:block}.tutorial-toc-list[data-astro-cid-amgwr4wo]{display:flex;flex-direction:column;gap:.25rem}.tutorial-toc-link[data-astro-cid-amgwr4wo]{color:var(--color-muted);text-decoration:none;font-weight:500;transition:color .15s;display:block;padding:.1rem 0}.tutorial-toc-link[data-astro-cid-amgwr4wo]:hover{color:var(--color-primary);text-decoration:none}.tutorial-toc-link[data-astro-cid-amgwr4wo].active{color:var(--color-primary);font-weight:600}.breadcrumb-current[data-astro-cid-amgwr4wo]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;color:var(--color-text-2);font-weight:500}.tutorial-h1[data-astro-cid-amgwr4wo]{font-size:2rem;font-weight:800;letter-spacing:-.025em;line-height:1.2;color:var(--color-text);margin:.75rem 0 0}.tutorial-desc[data-astro-cid-amgwr4wo]{font-size:1.0625rem;color:var(--color-muted);line-height:1.7;margin:.75rem 0 0}.topic-chip-list[data-astro-cid-amgwr4wo]{display:flex;flex-wrap:wrap;gap:.5rem .5rem;margin-top:1.25rem}.topic-chip[data-astro-cid-amgwr4wo]{display:inline-flex;align-items:center;gap:.2rem;padding:.35rem .875rem .35rem .625rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg);background-image:linear-gradient(90deg,#fbbf24 0% 100%);background-size:0% 100%;background-repeat:no-repeat;background-position:left center;font-size:.775rem;font-weight:600;color:var(--color-text-2);letter-spacing:.01em;transition:background-size .25s ease,border-color .2s,color .2s,box-shadow .2s;text-decoration:none;box-shadow:0 1px 2px #0000000a,inset 0 1px #ffffff0f}.topic-chip[data-astro-cid-amgwr4wo]:hover{background-size:100% 100%;border-color:#d97706;color:#78350f;text-decoration:none;box-shadow:0 2px 6px #fbbf2440}.tutorial-header[data-astro-cid-amgwr4wo]{position:relative;margin-bottom:3rem;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border);box-shadow:0 2px 12px #0000000a,0 0 0 1px #00000008}html.dark .tutorial-header[data-astro-cid-amgwr4wo]{box-shadow:0 2px 16px #0003,0 0 0 1px #ffffff0a}.tut-header-accent[data-astro-cid-amgwr4wo]{position:absolute;top:0;left:0;right:0;height:4px;background:var(--cat-color, var(--color-primary))}.tut-header-glow[data-astro-cid-amgwr4wo]{position:absolute;inset:0;background:linear-gradient(90deg,var(--cat-color, var(--color-primary)) 0%,transparent 100%);opacity:.6;border-radius:0}.tut-header-body[data-astro-cid-amgwr4wo]{padding:2rem;background:var(--color-surface)}.tut-framework-row[data-astro-cid-amgwr4wo]{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:0}.tut-framework-badge[data-astro-cid-amgwr4wo]{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:5px;font-size:.75rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.tut-meta-sep[data-astro-cid-amgwr4wo]{color:var(--color-muted);font-size:.8rem}.circuit-gallery[data-astro-cid-amgwr4wo]{background:var(--color-bg-alt);border:1px solid var(--color-border);border-top:3px solid var(--cat-color, var(--color-primary));border-radius:var(--radius-lg);padding:1.375rem 1.375rem 1.125rem}.circuit-gallery-label[data-astro-cid-amgwr4wo]{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--cat-color, var(--color-primary));margin-bottom:1rem;display:flex;align-items:center;gap:.4rem}.circuit-gallery-label[data-astro-cid-amgwr4wo]:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cat-color, var(--color-primary));flex-shrink:0}.circuit-grid[data-astro-cid-amgwr4wo]{display:grid;gap:1rem;align-items:stretch}.circuit-grid-1[data-astro-cid-amgwr4wo]{grid-template-columns:1fr}.circuit-grid-2[data-astro-cid-amgwr4wo]{grid-template-columns:1fr 1fr}@media (max-width: 640px){.circuit-grid-2[data-astro-cid-amgwr4wo]{grid-template-columns:1fr}}.circuit-fig[data-astro-cid-amgwr4wo]{margin:0;display:flex;flex-direction:column;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.circuit-fig[data-astro-cid-amgwr4wo] img[data-astro-cid-amgwr4wo]{width:100%;height:200px;object-fit:contain;display:block;background:#fff;padding:.75rem;flex:1}.circuit-fig[data-astro-cid-amgwr4wo] figcaption[data-astro-cid-amgwr4wo]{font-size:.75rem;color:var(--color-muted);line-height:1.5;text-align:center;padding:.625rem .875rem .75rem;border-top:1px solid var(--color-border)}.prose[data-astro-cid-amgwr4wo]{line-height:1.85}.prose[data-astro-cid-amgwr4wo] h2{font-size:1.375rem;font-weight:700;color:var(--color-text);margin:2.75rem 0 .875rem;letter-spacing:-.015em;padding-left:.875rem;border-left:3px solid var(--cat-color, var(--color-primary));padding-top:.125rem;padding-bottom:.125rem}.prose[data-astro-cid-amgwr4wo] h3{font-size:1.0625rem;font-weight:700;color:var(--color-text);margin:1.75rem 0 .5rem;letter-spacing:-.01em;padding-left:1rem}.prose[data-astro-cid-amgwr4wo] p{font-size:.9375rem;color:var(--color-text-2);margin-bottom:1.25rem;padding-left:1rem}.prose[data-astro-cid-amgwr4wo] ul{padding-left:2.5rem;margin-left:1rem;margin-bottom:1.25rem}.prose[data-astro-cid-amgwr4wo] li{font-size:.9375rem;color:var(--color-text-2);margin-bottom:.4rem}.prose[data-astro-cid-amgwr4wo] :not(pre)>code{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:4px;padding:.1em .4em;font-size:.875em;color:var(--color-primary);font-family:Fira Code,Cascadia Code,monospace}.prose[data-astro-cid-amgwr4wo] a{color:var(--color-primary);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--color-primary) 35%,transparent);text-underline-offset:3px;transition:text-decoration-color .15s,color .15s}.prose[data-astro-cid-amgwr4wo] a:hover{color:var(--color-primary-hover, var(--color-primary));text-decoration-color:var(--color-primary)}.prose[data-astro-cid-amgwr4wo] strong{color:var(--color-text-2);font-weight:600}.prose[data-astro-cid-amgwr4wo] img{max-width:100%;border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:0 2px 12px #00000014,0 0 0 1px #0000000a;margin:1.75rem auto;display:block;background:#fff;padding:.5rem}html.dark .prose[data-astro-cid-amgwr4wo] img{box-shadow:0 2px 16px #00000059,0 0 0 1px #ffffff0f;padding:.5rem}.prose[data-astro-cid-amgwr4wo] table{width:100%;border-collapse:collapse;font-size:.875rem;margin-bottom:1.5rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border)}.prose[data-astro-cid-amgwr4wo] th{background:var(--color-bg-alt);padding:.65rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:1px solid var(--color-border)}.prose[data-astro-cid-amgwr4wo] td{padding:.6rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-2);font-size:.875rem}.prose[data-astro-cid-amgwr4wo] tr:last-child td{border-bottom:none}.prose[data-astro-cid-amgwr4wo] tr:hover td{background:var(--color-bg-alt)}.prose[data-astro-cid-amgwr4wo] blockquote{border-left:3px solid var(--color-primary);background:var(--color-bg-alt);padding:.875rem 1.25rem;border-radius:0 var(--radius) var(--radius) 0;margin:1.5rem 0}.prose[data-astro-cid-amgwr4wo] blockquote p{margin-bottom:0}.cta-box-inner[data-astro-cid-amgwr4wo]{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.cta-box-title[data-astro-cid-amgwr4wo]{font-size:1rem;font-weight:700;color:var(--color-text)}.related-tutorials[data-astro-cid-amgwr4wo]{border-top:1px solid var(--color-border);padding-top:2rem}.related-tutorials-heading[data-astro-cid-amgwr4wo]{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0 0 .25rem;letter-spacing:-.015em}.related-tutorials-subtitle[data-astro-cid-amgwr4wo]{font-size:.875rem;color:var(--color-muted);margin:0 0 1.25rem}.related-tutorials-grid[data-astro-cid-amgwr4wo]{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem;list-style:none;padding:0;margin:0}.related-tutorials-grid[data-astro-cid-amgwr4wo]>li[data-astro-cid-amgwr4wo]{display:contents}@media (max-width: 640px){.related-tutorials-grid[data-astro-cid-amgwr4wo]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 400px){.related-tutorials-grid[data-astro-cid-amgwr4wo]{grid-template-columns:1fr}}.related-card[data-astro-cid-amgwr4wo]{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:border-color .15s,box-shadow .15s}.related-card[data-astro-cid-amgwr4wo]:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00000014;text-decoration:none}.related-card-title[data-astro-cid-amgwr4wo]{font-size:.875rem;font-weight:600;color:var(--color-text);line-height:1.4}.related-card-meta[data-astro-cid-amgwr4wo]{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.related-card-duration[data-astro-cid-amgwr4wo]{font-size:.75rem;color:var(--color-muted)}.related-card-link[data-astro-cid-amgwr4wo]{font-size:.8125rem;font-weight:600;color:var(--color-primary);margin-top:auto}#reading-progress[data-astro-cid-amgwr4wo]{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--cat-color, var(--color-primary));z-index:99;transition:width .1s linear;pointer-events:none}@media print{nav[data-astro-cid-amgwr4wo],footer[data-astro-cid-amgwr4wo],.breadcrumb[data-astro-cid-amgwr4wo],#reading-progress[data-astro-cid-amgwr4wo],.tutorial-toc[data-astro-cid-amgwr4wo],.related-section[data-astro-cid-amgwr4wo],.circuit-gallery[data-astro-cid-amgwr4wo],.code-copy-btn[data-astro-cid-amgwr4wo]{display:none!important}.tutorial-article[data-astro-cid-amgwr4wo]{max-width:100%}a[data-astro-cid-amgwr4wo]{color:inherit;text-decoration:none}pre[data-astro-cid-amgwr4wo]{white-space:pre-wrap;border:1px solid #ccc;page-break-inside:avoid}}.code-block-wrapper{position:relative;margin-bottom:1.75rem;border-radius:12px;overflow:hidden;box-shadow:0 0 0 1px #ffffff0f,0 4px 16px #0006,0 1px 3px #0000004d}.code-block-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:#161b22;border-bottom:1px solid #30363d}.code-block-dots{display:flex;gap:5px;margin-right:.25rem}.code-block-dot{width:11px;height:11px;border-radius:50%}.code-block-dot.red{background:#ff5f57}.code-block-dot.yellow{background:#febc2e}.code-block-dot.green{background:#28c840}.code-lang-label{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#8b949e;font-family:Fira Code,monospace;line-height:1;flex:1}.tutorial-article .prose pre.code-notation{background:var(--color-bg-alt)!important;border:1px solid var(--color-border)!important;border-left:3px solid color-mix(in srgb,var(--cat-color, var(--color-primary)) 45%,var(--color-border))!important;border-radius:var(--radius)!important;padding:.875rem 1.125rem!important;margin-bottom:1.5rem!important;color:var(--color-text-2)!important;font-size:.84rem!important;line-height:1!important;letter-spacing:0!important;font-family:DejaVu Sans Mono,Menlo,Consolas,Courier New,monospace!important;box-shadow:none!important;overflow-x:auto;tab-size:4}.tutorial-article .prose .code-block-wrapper pre,.tutorial-article .prose pre:not(.code-notation){background:#0d1117!important;border:none!important;border-radius:0!important;padding:1.125rem 1.375rem!important;overflow-x:auto;margin-bottom:0!important;font-size:.84rem!important;line-height:1.75!important;font-family:Fira Code,Cascadia Code,DejaVu Sans Mono,Consolas,monospace!important}.tutorial-article .prose .code-block-wrapper pre code,.tutorial-article .prose pre:not(.code-notation) code{background:none!important;border:none!important;padding:0!important;font-size:inherit!important;font-family:inherit!important}.code-copy-btn{display:flex;align-items:center;gap:.3rem;padding:.2rem .5rem;background:#ffffff0f;border:1px solid #30363d;border-radius:5px;color:#7d8590;cursor:pointer;transition:all .15s;font-size:.68rem;font-family:Fira Code,monospace;white-space:nowrap}.code-copy-btn:hover{background:#ffffff1f;color:#e6edf3;border-color:#6e7681}.code-copy-btn.copied{color:#3fb950;border-color:#238636;background:#23863626}.code-output-wrapper .code-block-header{background:#161b22;border-bottom-color:#21262d}.code-output-label{flex:1;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#484f58;font-family:Fira Code,monospace}.code-output-wrapper pre{background:#090d12!important;line-height:1.4!important;letter-spacing:0!important;font-family:DejaVu Sans Mono,Menlo,Consolas,Courier New,monospace!important;tab-size:4}.code-copy-btn-output{color:#484f58!important;border-color:#21262d!important;background:transparent!important}.code-copy-btn-output:hover{color:#8b949e!important;border-color:#30363d!important;background:#ffffff0a!important}.tutorial-toc-list{list-style:none!important;padding:0;margin:0}
