@media print{@page{margin:1.25cm}body:has(.tutorial-shell) footer,body:has(.tutorial-shell) #cookie-notice{display:none!important}body:has(.tutorial-shell) .toast{display:none!important}.tutorial-shell{min-height:0!important}.tutorial-shell>.navbar{display:none!important}.tutorial-layout{display:block!important}.tutorial-toc{display:none!important}.tutorial-content{max-width:100%!important;padding:0!important}.tutorial-content .prose pre,.tutorial-meta,.tutorial-content .prose .worth-knowing,.tutorial-content .prose .walkthrough-jump{-moz-column-break-inside:avoid;break-inside:avoid;page-break-inside:avoid}.tutorial-nav__card{-moz-column-break-inside:avoid;break-inside:avoid;page-break-inside:avoid;box-shadow:none!important}.tutorial-nav__card[href]:after{content:" (" attr(href) ")";display:block;margin-top:.35rem;font-size:.75rem;font-weight:400;color:#555}}.tutorial-layout[data-astro-cid-ds6ctzq3]{display:flex;flex:1;min-height:0}.tutorial-content[data-astro-cid-ds6ctzq3]{flex:1;min-width:0;max-width:52rem;padding:2.5rem 3rem}@media (max-width: 1023px){.tutorial-content[data-astro-cid-ds6ctzq3]{padding:2rem 1.25rem}}.tutorial-eyebrow[data-astro-cid-ds6ctzq3]{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ap-text-meta);margin-top:0;margin-bottom:.5rem}.tutorial-tldr[data-astro-cid-ds6ctzq3]{color:var(--ap-text-meta);border-left:3px solid var(--ap-gunmetal);padding:.75rem 1rem;margin-top:0;margin-bottom:2rem}.tutorial-tldr[data-astro-cid-ds6ctzq3] p[data-astro-cid-ds6ctzq3]{color:var(--ap-text-meta);margin:0}.tutorial-tldr[data-astro-cid-ds6ctzq3] p[data-astro-cid-ds6ctzq3]+p[data-astro-cid-ds6ctzq3]{margin-top:.5rem}.tutorial-tldr[data-astro-cid-ds6ctzq3] strong[data-astro-cid-ds6ctzq3]{color:var(--ap-text);font-weight:600}.tutorial-meta[data-astro-cid-ds6ctzq3]{margin-top:0;margin-bottom:3rem}.tutorial-meta[data-astro-cid-ds6ctzq3] th[data-astro-cid-ds6ctzq3]{width:12rem;vertical-align:top;text-align:left}.tutorial-meta[data-astro-cid-ds6ctzq3] td[data-astro-cid-ds6ctzq3]{vertical-align:top}@media (max-width: 639px){.tutorial-meta[data-astro-cid-ds6ctzq3] th[data-astro-cid-ds6ctzq3]{width:auto}}.tutorial-toc[data-astro-cid-ds6ctzq3]{display:none}@media (min-width: 1280px){.tutorial-toc[data-astro-cid-ds6ctzq3]{display:block;width:220px;flex-shrink:0}}.tutorial-toc__inner[data-astro-cid-ds6ctzq3]{position:sticky;top:5rem;padding:1.5rem 1rem 1.5rem 0;max-height:calc(100vh - 5rem);overflow-y:auto}.tutorial-toc__heading[data-astro-cid-ds6ctzq3]{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ap-text-meta);margin-bottom:.75rem}.tutorial-toc__list[data-astro-cid-ds6ctzq3]{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.125rem}.tutorial-toc__link[data-astro-cid-ds6ctzq3]{display:block;font-size:.75rem;line-height:1.5;color:var(--ap-text-meta);text-decoration:none;border-left:2px solid transparent;padding:.25rem 0 .25rem .75rem;transition:color .15s ease,border-color .15s ease}.tutorial-toc__link[data-astro-cid-ds6ctzq3]:hover{color:var(--ap-text);border-left-color:var(--ap-gunmetal)}.tutorial-toc__link--sub[data-astro-cid-ds6ctzq3]{padding-left:1.5rem;font-size:.6875rem}.tutorial-nav[data-astro-cid-ds6ctzq3]{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--ap-gunmetal)}.tutorial-nav__grid[data-astro-cid-ds6ctzq3]{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tutorial-nav__grid--single[data-astro-cid-ds6ctzq3]{grid-template-columns:1fr;max-width:24rem}.tutorial-nav__card--next[data-astro-cid-ds6ctzq3]{text-align:right}.tutorial-nav__card[data-astro-cid-ds6ctzq3]{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.25rem;border:1px solid var(--ap-gunmetal);border-radius:.5rem;text-decoration:none;color:inherit;transition:border-color .15s ease,background .15s ease}.tutorial-nav__card[data-astro-cid-ds6ctzq3]:hover{border-color:var(--ap-gold);background:oklch(var(--bc) / .02)}.tutorial-nav__eyebrow[data-astro-cid-ds6ctzq3]{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ap-text-meta)}.tutorial-nav__number[data-astro-cid-ds6ctzq3]{font-size:.75rem;color:var(--ap-text-meta)}.tutorial-nav__title[data-astro-cid-ds6ctzq3]{font-size:1rem;font-weight:600;line-height:1.35;color:var(--ap-text)}@media (max-width: 639px){.tutorial-nav__grid[data-astro-cid-ds6ctzq3]{grid-template-columns:1fr}.tutorial-nav__card--next[data-astro-cid-ds6ctzq3]{text-align:left}.tutorial-nav__grid--single[data-astro-cid-ds6ctzq3]{max-width:100%}}.tutorial-shell{--ap-bg: oklch(var(--b1));--ap-panel: oklch(var(--b2));--ap-panel-inner: oklch(var(--b3));--ap-glow: oklch(var(--p));--ap-text: oklch(var(--bc));--ap-text-meta: oklch(var(--bc) / .7);--ap-gunmetal: oklch(var(--n));--ap-gold: oklch(var(--a));background-color:var(--ap-bg);color:var(--ap-text)}.tutorial-shell h1,.tutorial-shell h2,.tutorial-shell h3,.tutorial-shell h4,.tutorial-shell h5,.tutorial-shell h6{color:var(--ap-text);opacity:1}.tutorial-content .prose{--tw-prose-body: var(--ap-text);--tw-prose-headings: var(--ap-text);--tw-prose-links: var(--ap-glow);--tw-prose-bold: var(--ap-text);--tw-prose-code: var(--ap-text);--tw-prose-counters: var(--ap-text-meta);--tw-prose-bullets: var(--ap-text-meta);--tw-prose-hr: var(--ap-gunmetal);--tw-prose-quotes: var(--ap-text-meta);--tw-prose-quote-borders: var(--ap-gunmetal);--tw-prose-captions: var(--ap-text-meta);--tw-prose-th-borders: var(--ap-gunmetal);--tw-prose-td-borders: oklch(var(--bc) / .15)}.tutorial-content .prose :where(h1){margin-top:0;margin-bottom:3rem}.tutorial-content .prose :where(h2){margin-top:3rem;margin-bottom:.5rem}.tutorial-content .prose :where(h3){margin-top:2rem;margin-bottom:.5rem}.tutorial-content .prose :where(h4,h5,h6){margin-top:1.5rem;margin-bottom:.5rem}.tutorial-content .prose :where(p){margin-top:0;margin-bottom:1rem}.tutorial-content .prose :where(ul,ol){margin-top:0;margin-bottom:1rem}.tutorial-content .prose :where(blockquote){margin-top:0;margin-bottom:1.5rem}.tutorial-content .prose :where(pre,hr){margin-top:0;margin-bottom:2rem}.tutorial-content .prose :where(code):not(:where(pre code)){color:var(--ap-glow);background:oklch(var(--bc) / .08);padding:.15em .35em;border-radius:.25rem;font-weight:500}.tutorial-content .prose pre{background:var(--ap-panel-inner);color:var(--ap-text)}.tutorial-content .prose table{margin-top:0;margin-bottom:2rem}.tutorial-content .prose table th,.tutorial-content .prose table td{opacity:1}.tutorial-content .prose .worth-knowing{margin-top:0;margin-bottom:1.5rem;padding:.75rem 1rem;border-left:4px solid var(--ap-gold);background:oklch(var(--a) / .06)}.tutorial-content .prose .worth-knowing>p:first-of-type{margin-top:0}.tutorial-content .prose .worth-knowing>p:last-of-type{margin-bottom:0}.tutorial-content .prose .walkthrough-jump{margin-top:0;margin-bottom:1.5rem;padding:.5rem 1rem;border-left:3px solid var(--ap-glow);background:oklch(var(--p) / .04)}.tutorial-content .prose .walkthrough-jump>p:first-of-type{margin-top:0}.tutorial-content .prose .walkthrough-jump>p:last-of-type{margin-bottom:0}.tutorial-content .prose .walkthrough-jump a{font-weight:600}
