:root{--font-body: "Inter var", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, sans-serif;--font-mono: "SF Mono", ui-monospace, Menlo, Consolas, monospace;--primary: #6c47ff;--primary-pressed: #5838dd;--primary-deep: #4a26b8;--link-blue: #2383e2;--brand-navy: #0f1b2d;--brand-navy-deep: #091322;--brand-navy-mid: #16243a;--brand-pink: #ec5cb5;--brand-pink-deep: #c93f93;--brand-orange: #e87c47;--brand-orange-deep: #c45d2c;--brand-purple-300: #b8a2ff;--brand-purple-800: #432a99;--brand-teal: #2fbfa6;--brand-green: #2fb344;--brand-yellow: #f6d365;--brand-brown: #8b6c4a;--tint-peach: #fdebd3;--tint-rose: #fde2e7;--tint-mint: #dff4e8;--tint-lavender: #eee6ff;--tint-sky: #dff0ff;--tint-yellow: #fff5cf;--tint-yellow-bold: #ffd966;--tint-cream: #f8efe2;--tint-gray: #f3f2ef;--canvas: #ffffff;--surface: #f7f6f3;--surface-soft: #fbfaf8;--hairline: rgba(15, 15, 15, .1);--hairline-soft: rgba(15, 15, 15, .06);--hairline-strong: rgba(15, 15, 15, .18);--ink-deep: #0f0f0f;--ink: #191919;--charcoal: #2c2a25;--slate: #4f4d48;--steel: #6f6d68;--stone: #8a8881;--muted: #b3b1ab;--on-dark: #ffffff;--on-dark-muted: rgba(255, 255, 255, .72);--on-dark-soft: rgba(255, 255, 255, .55);--on-primary: #ffffff;--success: #2fb344;--warning: #c47315;--error: #d83434;--elev-1: 0 1px 2px rgba(15, 15, 15, .04);--elev-2: 0 4px 12px rgba(15, 15, 15, .08);--elev-3: 0 24px 48px -8px rgba(15, 15, 15, .2);--elev-4: 0 16px 48px -8px rgba(15, 15, 15, .16);--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-xxl: 20px;--r-xxxl: 24px;--r-full: 9999px;--s-xxs: 4px;--s-xs: 8px;--s-sm: 12px;--s-md: 16px;--s-lg: 24px;--s-xl: 32px;--s-xxl: 40px;--s-3xl: 56px;--s-section-sm: 64px;--s-section: 80px;--s-section-lg: 96px;--s-hero: 120px;--t-hero: clamp(48px, 7vw, 80px);--t-display-lg: clamp(40px, 5.5vw, 56px);--t-h1: clamp(34px, 4.4vw, 48px);--t-h2: clamp(26px, 3.2vw, 36px);--t-h3: clamp(22px, 2.4vw, 28px);--t-h4: 22px;--t-h5: 18px;--t-subtitle: 18px;--t-body-md: 16px;--t-body-sm: 14px;--t-caption: 13px;--t-button: 14px}@media (prefers-color-scheme: dark){:root{--canvas: #191919;--surface: #202020;--surface-soft: #1a1a1a;--hairline: rgba(255, 255, 255, .1);--hairline-soft: rgba(255, 255, 255, .06);--hairline-strong: rgba(255, 255, 255, .2);--tint-peach: #3b2a1d;--tint-rose: #3a2128;--tint-mint: #1f3526;--tint-lavender: #2a2342;--tint-sky: #1d2c3f;--tint-yellow: #3a2f12;--tint-yellow-bold: #c5972c;--tint-cream: #2d271f;--tint-gray: #232323;--ink-deep: #ffffff;--ink: #f5f4f1;--charcoal: #ebe9e4;--slate: #c9c7c0;--steel: #a7a59f;--stone: #8a8881;--muted: #6c6a64;--primary: #9b7cff;--primary-pressed: #8868f1;--link-blue: #5aa8ff;--brand-navy: #07111f;--brand-navy-deep: #04080f;--elev-1: none;--elev-2: none;--elev-3: 0 24px 48px -8px rgba(0, 0, 0, .6);--elev-4: 0 16px 48px -8px rgba(0, 0, 0, .5)}}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%}@media (min-width: 1024px) and (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}body{min-height:100dvh;background:var(--canvas);color:var(--ink);font-family:var(--font-body);font-feature-settings:"cv02","cv03","cv04","cv11";font-size:var(--t-body-md);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}img,svg{max-width:100%;height:auto;display:block}img{object-fit:cover}a{color:var(--link-blue);text-decoration:none}@media (hover: hover) and (pointer: fine){a:hover{text-decoration:underline}}:where(a,button,summary,[role=button],input,textarea,select):focus{outline:none}:where(a,button,summary,[role=button],input,textarea,select):focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-sm)}.btn:focus-visible{outline-offset:3px}.btn--secondary-on-dark:focus-visible{outline-color:var(--on-dark)}.page__toc a:focus-visible{outline-offset:0}.skip-link{position:fixed;top:8px;left:8px;z-index:9999;padding:10px 14px;background:var(--ink);color:var(--on-dark);font-weight:600;font-size:var(--t-body-sm);border-radius:var(--r-md);box-shadow:var(--elev-3);transform:translateY(-200%);transition:transform .12s ease-out}.skip-link:focus,.skip-link:focus-visible{transform:translateY(0);text-decoration:none;outline:2px solid var(--on-dark);outline-offset:2px}h1,h2,h3,h4,h5,h6,p,li,td,th{overflow-wrap:break-word}code,pre{font-family:var(--font-mono)}code{font-size:.92em;background:var(--tint-lavender);color:var(--brand-purple-800);padding-block:.4em;padding-inline:.6em;border-radius:var(--r-xs);line-height:1.4;-webkit-box-decoration-break:clone;box-decoration-break:clone}@media (prefers-color-scheme: dark){code{color:var(--brand-purple-300)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-delay:0ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.topnav{position:sticky;top:0;z-index:30;background:var(--canvas);border-bottom:1px solid var(--hairline)}@media (min-width: 1024px){.topnav{-webkit-backdrop-filter:saturate(140%) blur(8px);backdrop-filter:saturate(140%) blur(8px)}}.topnav__inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:var(--s-lg);padding:0 var(--s-xl);height:64px}.topnav__brand{display:inline-flex;align-items:center;gap:10px;color:var(--ink);font-weight:600;font-size:16px}.topnav__logo{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:var(--r-sm);background:#1f1f1f;color:#fff;font-weight:700;font-size:16px}@media (prefers-color-scheme: dark){.topnav__logo{background:#f5f4f1;color:#0f0f0f}}.topnav__links{display:flex;gap:var(--s-lg);align-items:center;margin-left:auto;min-width:0}.topnav__links a{color:var(--steel);font-size:var(--t-body-sm);font-weight:500;white-space:nowrap}@media (hover: hover) and (pointer: fine){.topnav__brand:hover{text-decoration:none}.topnav__links a:hover{color:var(--ink);text-decoration:none}}.topnav__actions{display:flex;align-items:center;gap:10px;min-width:0}.topnav__menu{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--r-sm);color:var(--ink);cursor:pointer}.topnav__menu-icon .topnav__menu-close,.topnav__menu[aria-expanded=true] .topnav__menu-open{display:none}.topnav__menu[aria-expanded=true] .topnav__menu-close{display:inline}@media (hover: hover) and (pointer: fine){.topnav__menu:hover{background:var(--surface)}}@media (max-width: 1023px){.topnav__links{display:none}.topnav__inner{padding:0 var(--s-md);gap:var(--s-md)}.topnav__menu{display:inline-flex}.topnav__actions .btn{display:none}.topnav__actions{margin-left:auto}.topnav__menu{margin-right:-8px}}@media (max-width: 479px){.topnav__brand-name{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:var(--t-button);font-weight:500;line-height:1.3;padding:10px 18px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;min-height:40px;transition:background .15s ease,color .15s ease,border-color .15s ease}.btn--primary{background:var(--primary);color:var(--on-primary)}.btn--secondary{background:var(--canvas);color:var(--ink);border-color:var(--hairline-strong)}.btn--secondary-on-dark{background:transparent;color:var(--on-dark);border-color:#fff6}.btn--ghost{background:transparent;color:var(--ink);padding:8px 12px;border-radius:var(--r-sm);min-height:36px}@media (hover: hover) and (pointer: fine){.btn:hover{text-decoration:none}.btn--primary:hover{background:var(--primary-pressed)}.btn--secondary:hover{background:var(--surface)}.btn--secondary-on-dark:hover{background:#ffffff14}.btn--ghost:hover{background:var(--surface)}}.hero{position:relative;background:var(--brand-navy);color:var(--on-dark);overflow:hidden}.hero__dots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero__dots .dot{position:absolute;width:18px;height:18px;border-radius:var(--r-full);left:var(--x);top:var(--y);opacity:.85;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}.dot--peach{background:var(--tint-peach)}.dot--rose{background:var(--tint-rose)}.dot--mint{background:var(--tint-mint)}.dot--sky{background:var(--tint-sky)}.dot--lavender{background:var(--tint-lavender)}.dot--yellow{background:var(--tint-yellow-bold)}.hero__wire{position:absolute;inset:auto 0 0 0;width:100%;height:50%;opacity:.7}.hero__inner{position:relative;max-width:1100px;margin:0 auto;padding:clamp(64px,9vw,var(--s-hero)) var(--s-xl) var(--s-3xl);text-align:center}.hero__eyebrow{display:inline-block;font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-muted);margin-bottom:var(--s-md)}.hero__title{font-size:var(--t-hero);font-weight:600;line-height:1.05;letter-spacing:-2px;text-wrap:balance;max-width:16ch;margin:0 auto var(--s-md)}.hero__lead{font-size:18px;font-weight:400;line-height:1.55;text-wrap:pretty;color:var(--on-dark-muted);max-width:60ch;margin:0 auto var(--s-xl)}.hero__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.tag{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;padding:2px 8px;border-radius:var(--r-sm);white-space:nowrap}.tag--lavender{background:var(--tint-lavender);color:var(--brand-purple-800)}.tag--peach{background:var(--tint-peach);color:var(--brand-orange-deep)}.tag--mint{background:var(--tint-mint);color:#1f6f37}.tag--sky{background:var(--tint-sky);color:#1f4d8b}.tag--yellow{background:var(--tint-yellow);color:#84672a}.tag--rose{background:var(--tint-rose);color:#952d4c}@media (prefers-color-scheme: dark){.tag--lavender{color:var(--brand-purple-300)}.tag--peach{color:#f7a87b}.tag--mint{color:#7bd88f}.tag--sky{color:#93c5fd}.tag--yellow{color:#ffdf7e}.tag--rose{color:#ff8a98}}.preamble{border-bottom:1px solid var(--hairline);background:var(--canvas)}.preamble__inner{max-width:1100px;margin:0 auto;padding:clamp(48px,7vw,96px) var(--s-xl)}.preamble__eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);margin-bottom:var(--s-sm)}.preamble__title{font-size:var(--t-h2);font-weight:600;line-height:1.15;letter-spacing:-.5px;color:var(--ink);max-width:28ch;margin-bottom:var(--s-xl);text-wrap:balance}.preamble__cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-xl);border-top:1px solid var(--hairline);padding-top:var(--s-xl)}.preamble__heading{font-size:var(--t-body-md);font-weight:600;color:var(--ink);margin-bottom:8px}.preamble__cols p{color:var(--slate);font-size:var(--t-body-md);line-height:1.6;max-width:42ch}@media (max-width: 767px){.preamble__cols{grid-template-columns:1fr;gap:var(--s-lg)}.preamble__inner{padding:var(--s-xxl) var(--s-md)}}.page{max-width:1280px;margin:0 auto;padding:var(--s-section-lg) var(--s-xl);display:grid;grid-template-columns:200px minmax(0,1fr);gap:var(--s-xxl)}.page__toc{position:sticky;top:88px;align-self:start;max-height:calc(100dvh - 120px);overflow-y:auto;scrollbar-gutter:stable}.page__toc-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s-sm);margin-bottom:var(--s-sm);padding-bottom:var(--s-xs);border-bottom:1px solid var(--hairline)}.page__toc-title{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);margin:0}.page__toc-close{display:none;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--r-sm);color:var(--ink);cursor:pointer}@media (hover: hover) and (pointer: fine){.page__toc-close:hover{background:var(--surface)}}.page__toc nav{display:grid;gap:2px}.page__toc a{color:var(--steel);font-size:var(--t-body-sm);padding:6px 10px;border-radius:var(--r-sm);line-height:1.4}@media (hover: hover) and (pointer: fine){.page__toc a:hover{color:var(--ink);text-decoration:none}}.page__toc a.is-active{color:var(--ink);background:var(--surface);font-weight:600}.page__main{min-width:0;display:grid;gap:var(--s-section)}@media (max-width: 1023px){.page{grid-template-columns:1fr;padding:var(--s-section) var(--s-md);gap:var(--s-xl)}.page__toc{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);z-index:60;background:var(--canvas);border-left:1px solid var(--hairline);box-shadow:var(--elev-3);padding:var(--s-md) var(--s-md) var(--s-xl);margin:0;max-height:100dvh;overflow-y:auto;overscroll-behavior:contain;transform:translate(100%);transition:transform .22s ease-out,visibility 0s linear .22s;visibility:hidden}.page__toc[data-open=true]{transform:translate(0);visibility:visible;transition:transform .22s ease-out}.page__toc-close{display:inline-flex}.page__toc nav{display:grid;gap:4px;padding:0}.page__toc a{padding:10px 12px;border-radius:var(--r-sm);font-size:var(--t-body-md);white-space:normal}.page__main{gap:var(--s-xxl)}}.toc-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0f0f80;z-index:50;opacity:0;visibility:hidden;transition:opacity .18s ease-out,visibility 0s linear .18s}body[data-toc-open=true] .toc-scrim{opacity:1;visibility:visible;transition:opacity .18s ease-out}@media (min-width: 1024px){.toc-scrim{display:none}}.group{display:grid;grid-template-columns:minmax(80px,120px) minmax(0,1fr);grid-template-areas:".       eyebrow" "numeral title";column-gap:var(--s-xl);row-gap:var(--s-xs);align-items:start;padding-top:var(--s-xxl);padding-bottom:var(--s-xl);border-bottom:1px solid var(--ink);margin-bottom:var(--s-xl)}.group__inner{display:contents}.group:before{content:attr(data-chapter);grid-area:numeral;font-family:var(--font-mono);font-size:clamp(40px,5vw,64px);font-weight:500;line-height:1;color:var(--ink);letter-spacing:-.04em;font-variant-numeric:tabular-nums}.group__eyebrow{grid-area:eyebrow;font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);line-height:1;margin:0}.group__title{grid-area:title;font-size:var(--t-display-lg);font-weight:500;line-height:1.05;letter-spacing:-1.2px;color:var(--ink);text-wrap:balance;max-width:22ch;margin:0}@media (max-width: 640px){.group{grid-template-columns:1fr;grid-template-areas:"eyebrow" "numeral" "title";row-gap:var(--s-sm);padding-top:var(--s-xl)}.group:before{font-size:40px}}.module{scroll-margin-top:88px;display:grid;grid-template-columns:minmax(80px,120px) minmax(0,1fr);gap:var(--s-md) var(--s-xl);padding:var(--s-xxl) 0}.module>:not(.module__num){grid-column:2}.module+.module{border-top:1px solid var(--hairline)}.module__num{grid-column:1;grid-row:1 / span 2;font-family:var(--font-mono);font-size:18px;font-weight:500;letter-spacing:0;color:var(--stone);font-variant-numeric:tabular-nums;text-transform:none;margin-top:6px}.module__title{font-size:var(--t-h2);font-weight:500;line-height:1.15;letter-spacing:-.5px;color:var(--ink);text-wrap:balance;max-width:28ch}.module__note{color:var(--slate);max-width:62ch;font-size:var(--t-body-md);line-height:1.65;text-wrap:pretty;overflow-wrap:break-word}@media (max-width: 767px){.module{grid-template-columns:1fr;gap:var(--s-sm);padding:var(--s-xl) 0}.module>:not(.module__num){grid-column:1}.module__num{grid-column:1;grid-row:auto;font-size:14px;margin-top:0}}.module--capstone{padding:var(--s-3xl) 0}.module--capstone .module__title{font-size:var(--t-display-lg);font-weight:500;letter-spacing:-1px;max-width:24ch}.module--teardown{padding:var(--s-3xl) 0;border-top:2px solid var(--error)!important;margin-top:var(--s-xl)}.module--teardown .module__num{color:var(--error);font-weight:600}.module--teardown .module__title{color:var(--ink)}.module--teardown .module__note{color:var(--ink);font-weight:500}@media (prefers-color-scheme: dark){.module--teardown{border-top-color:#ff6b6b!important}.module--teardown .module__num{color:#ff6b6b}}.grid{display:grid;gap:var(--s-md);min-width:0;align-items:stretch}.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid--top{grid-template-columns:1fr;gap:var(--s-md)}@media (max-width: 1023px){.grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.grid--2,.grid--3{grid-template-columns:1fr}}.card{background:var(--canvas);color:var(--charcoal);border-radius:var(--r-lg);border:1px solid transparent;padding:var(--s-lg);display:grid;gap:10px;align-content:start;min-width:0}.card :is(h3,h4){font-size:var(--t-h4);font-weight:600;line-height:1.3;letter-spacing:-.01em;color:var(--ink)}.card p{color:var(--slate);font-size:var(--t-body-md);line-height:1.55;max-width:58ch}.card ul,.card ol{list-style:none;padding:0;display:grid;gap:8px;color:var(--slate);font-size:var(--t-body-md)}.card ul li{position:relative;padding-left:18px}.card ul li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:var(--r-full);background:var(--charcoal);opacity:.45}.card__label{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--steel)}.card--peach{background:var(--tint-peach)}.card--rose{background:var(--tint-rose)}.card--mint{background:var(--tint-mint)}.card--sky{background:var(--tint-sky)}.card--lavender{background:var(--tint-lavender)}.card--yellow{background:var(--tint-yellow)}.card--cream{background:var(--tint-cream)}@media (prefers-color-scheme: dark){.card--yellow{background:#4a3a14}.card--yellow p,.card--yellow ul li,.card--yellow code{color:#fef3c7}.card--yellow .card__label{color:#fcd34d}.card--yellow :is(h3,h4){color:#fff7d6}.card--yellow ul li:before{background:#fcd34d;opacity:.7}}.card--yellow-bold{background:var(--tint-yellow);color:var(--charcoal);border:1px solid var(--hairline-strong)}.card--yellow-bold :is(h3,h4){font-weight:600}@media (prefers-color-scheme: dark){.card--yellow-bold{background:#4a3a14;border-color:#ffffff2e}.card--yellow-bold p,.card--yellow-bold ul li,.card--yellow-bold code{color:#fef3c7}.card--yellow-bold .card__label{color:#fcd34d}.card--yellow-bold :is(h3,h4){color:#fff7d6}.card--yellow-bold ul li:before{background:#fcd34d;opacity:.7}}.codecard{position:relative;background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-rows:auto 1fr;min-width:0}.codecard__copy{position:absolute;top:6px;right:8px;display:inline-flex;align-items:center;gap:6px;padding:5px 10px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--steel);background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-sm);cursor:pointer;box-shadow:var(--elev-1);opacity:0;transition:opacity .14s ease-out,color .14s ease-out,border-color .14s ease-out}.codecard__copy-icon{display:inline-block;width:12px;height:12px;flex:0 0 auto}.codecard:hover .codecard__copy,.codecard:focus-within .codecard__copy,.codecard__copy:focus-visible{opacity:1}@media (hover: none) and (pointer: coarse){.codecard__copy{opacity:1}}@media (hover: hover) and (pointer: fine){.codecard__copy:hover{color:var(--ink);border-color:var(--hairline-strong)}}.codecard__copy[data-state=copied]{opacity:1;color:var(--success);border-color:var(--success)}.codecard__copy[data-state=error]{opacity:1;color:var(--error);border-color:var(--error)}@media (prefers-color-scheme: dark){.codecard__copy{background:var(--surface);color:var(--on-dark-muted);border-color:var(--hairline)}@media (hover: hover) and (pointer: fine){.codecard__copy:hover{color:var(--on-dark)}}}.codecard__header{display:flex;align-items:center;justify-content:space-between;gap:var(--s-sm);padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--hairline);font-family:var(--font-mono);font-size:var(--t-body-sm);color:var(--steel)}.codecard__body{margin:0;padding:18px 20px;font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--ink);background:var(--surface-soft);white-space:pre-wrap;overflow-wrap:anywhere;word-break:normal;-moz-tab-size:2;tab-size:2;overflow:visible;scrollbar-width:thin;scrollbar-color:var(--hairline-strong) transparent}.codecard__body code{background:none;color:inherit;padding:0;font-size:inherit}.codecard__body code,.codecard__body code *{font-size:inherit}.codecard__body::-webkit-scrollbar{width:8px;height:8px}.codecard__body::-webkit-scrollbar-track{background:transparent}.codecard__body::-webkit-scrollbar-thumb{background:var(--hairline-strong);border-radius:var(--r-full)}.hljs{background:transparent;color:var(--ink);font-family:inherit}.hljs-comment,.hljs-quote{color:var(--steel);font-style:italic}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:#6c47ff}.hljs-built_in,.hljs-type{color:#1e6f63}.hljs-string,.hljs-symbol,.hljs-bullet,.hljs-addition,.hljs-attr,.hljs-attribute{color:#c45d2c}.hljs-number,.hljs-meta,.hljs-regexp{color:#b57614}.hljs-title,.hljs-name,.hljs-class .hljs-title{color:#2371b3}.hljs-tag,.hljs-params,.hljs-variable,.hljs-template-variable,.hljs-property{color:var(--charcoal)}.hljs-deletion{color:var(--error)}@media (prefers-color-scheme: dark){.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-section,.hljs-link{color:#b8a2ff}.hljs-built_in,.hljs-type{color:#5eead4}.hljs-string,.hljs-symbol,.hljs-attr,.hljs-attribute,.hljs-bullet,.hljs-addition{color:#fbbf24}.hljs-number,.hljs-meta,.hljs-regexp{color:#f6d365}.hljs-title,.hljs-name{color:#93c5fd}}.data-table{width:100%;border-collapse:collapse;font-size:var(--t-body-sm)}.data-table thead{position:sticky;top:0}.data-table th{white-space:nowrap;font-family:var(--font-body);font-weight:600;font-size:var(--t-body-sm);text-align:left;color:var(--ink);padding:12px 16px;background:var(--canvas);border-bottom:1px solid var(--hairline)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--hairline-soft);color:var(--slate);vertical-align:top;white-space:normal}@media (hover: hover) and (pointer: fine){.data-table tbody tr:hover td{background:var(--surface-soft)}}.data-table code{white-space:nowrap}.badge{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;padding:3px 8px;border-radius:var(--r-full);white-space:nowrap}.badge--green{background:#2fb34429;color:#226e30}.badge--gold{background:#f6d3654d;color:#7a5810}.badge--rose{background:#e2556329;color:#952d4c}@media (prefers-color-scheme: dark){.badge--green{color:#7bd88f}.badge--gold{color:#ffdf7e}.badge--rose{color:#ff8a98}}.phases{list-style:none;padding:0;display:grid;gap:var(--s-sm)}.phase{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--s-lg);display:grid;grid-template-columns:56px 1fr;gap:var(--s-md);align-items:start}.phase__num{font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.06em;width:40px;height:40px;display:grid;place-items:center;border-radius:var(--r-sm);background:var(--tint-lavender);color:var(--brand-purple-800)}@media (prefers-color-scheme: dark){.phase__num{color:var(--brand-purple-300)}}.phase :is(h3,h4){font-size:var(--t-h5);font-weight:600;margin-bottom:4px;color:var(--ink)}.phase p{color:var(--slate);max-width:58ch}.callout{border-radius:var(--r-lg);padding:var(--s-lg) var(--s-xl);display:grid;gap:var(--s-xs)}.callout p{max-width:58ch}.callout__label{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase}.callout--yellow{background:var(--tint-yellow);color:var(--charcoal);border:1px solid var(--hairline-strong)}.callout--yellow .callout__label{color:var(--charcoal);opacity:.7}.callout--yellow code{color:var(--charcoal);background:#0000000f}@media (prefers-color-scheme: dark){.callout--yellow{background:#4a3a14;border-color:#ffffff2e;color:#fef3c7}.callout--yellow .callout__label{color:#fcd34d;opacity:1}.callout--yellow code{color:#fef3c7;background:#ffffff1a}}.accordion{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--r-md);padding:0;overflow:hidden}.accordion summary{cursor:pointer;list-style:none;padding:14px 18px;font-weight:600;font-size:var(--t-body-md);color:var(--ink);display:flex;align-items:center;justify-content:space-between}.accordion summary::-webkit-details-marker{display:none}.accordion summary:after{content:"+";font-family:var(--font-mono);color:var(--steel);font-size:18px}.accordion[open] summary{border-bottom:1px solid var(--hairline);background:var(--surface)}.accordion[open] summary:after{content:"−"}.accordion ul{list-style:none;padding:var(--s-lg);display:grid;gap:8px;color:var(--slate)}.accordion ul li{position:relative;padding-left:18px}.accordion ul li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:var(--r-full);background:var(--steel);opacity:.6}.trouble{margin:var(--s-xl) 0 0;display:grid;gap:var(--s-xl)}.trouble dt{font-size:var(--t-body);font-weight:600;color:var(--ink);margin-bottom:var(--s-sm);max-width:70ch;text-wrap:balance}.trouble dt:before{content:"→";display:inline-block;margin-right:.5em;color:var(--brand-purple);font-weight:500}.trouble dd{margin:0;color:var(--slate);max-width:70ch;display:grid;gap:var(--s-md);padding-bottom:var(--s-xl);border-bottom:1px solid var(--hairline)}.trouble dd:last-of-type{border-bottom:0;padding-bottom:0}.trouble dd p{margin:0}.trouble dd .codecard{max-width:100%;margin-top:var(--s-xs)}.trouble dd code{color:var(--ink)}@media (prefers-color-scheme: dark){.trouble dd{border-color:#ffffff14}.trouble dt:before{color:var(--brand-purple-300)}}.footer{background:var(--canvas);border-top:1px solid var(--hairline)}.footer__inner{max-width:1280px;margin:0 auto;padding:var(--s-section) var(--s-xl);display:grid;grid-template-columns:240px 1fr;gap:var(--s-xxl)}.footer__brand{display:grid;gap:var(--s-sm);color:var(--steel)}.footer__brand p{color:var(--steel);font-size:var(--t-body-sm)}.footer__cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--s-xxl)}.footer__heading{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:10px}.footer ul{list-style:none;padding:0;display:grid;gap:4px}.footer__cols a{color:var(--steel);font-size:var(--t-body-sm)}@media (hover: hover) and (pointer: fine){.footer__cols a:hover{color:var(--ink);text-decoration:none}}@media (max-width: 1023px){.footer__inner{grid-template-columns:1fr;padding:var(--s-section-sm) var(--s-md);gap:var(--s-xl)}.footer__cols{grid-template-columns:repeat(2,1fr);gap:var(--s-lg)}}.-mx-4{margin-left:-16px;margin-right:-16px}.-my-2{margin-top:-8px;margin-bottom:-8px}.overflow-x-auto{overflow-x:auto}.whitespace-nowrap{white-space:nowrap}.inline-block{display:inline-block}.min-w-full{min-width:100%}.align-middle{vertical-align:middle}.px-4{padding-left:16px;padding-right:16px}.py-2{padding-top:8px;padding-bottom:8px}@media (min-width: 640px){.sm\:-mx-6{margin-left:-24px;margin-right:-24px}.sm\:px-6{padding-left:24px;padding-right:24px}}@media (min-width: 1024px){.lg\:-mx-8{margin-left:-32px;margin-right:-32px}.lg\:px-8{padding-left:32px;padding-right:32px}}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (max-width: 640px){body{padding:24px}.hero__inner{padding:clamp(40px,8vw,64px) var(--s-md) var(--s-xl)}.hero__lead{margin-bottom:var(--s-lg)}.page{padding:var(--s-xxl) var(--s-md)}.page__main{gap:var(--s-xl)}.module__title{letter-spacing:-.3px}.codecard__body{padding:14px 16px;font-size:12.5px}.codecard__header{padding:8px 12px}.phase{padding:var(--s-md);grid-template-columns:44px 1fr;gap:12px}.phase__num{width:36px;height:36px;font-size:12px}.group__title{font-size:var(--t-h2);letter-spacing:-.5px}}@media (max-width: 380px){body{padding:16px}.topnav__inner{padding:0 12px;gap:10px}.topnav__brand{gap:8px;font-size:14px}.btn{padding:8px 14px;min-height:36px;font-size:13px}}@media (hover: none) and (pointer: coarse){.page__toc a{padding:8px 12px}.page__toc nav{gap:6px}}
