.r-side{position:sticky;top:72px;align-self:start;height:calc(100vh - 72px);overflow-y:auto;border-right:1px solid var(--line);padding:28px 20px 28px 24px}.r-side-search{margin-bottom:22px}.r-side-search input{width:100%;background:var(--surface-1);border:1px solid var(--line);color:var(--ink-1);font-family:var(--font-sans);font-size:12.5px;padding:10px 12px;border-radius:var(--r-sm);outline:none;transition:border-color .15s var(--ease),background .15s var(--ease)}.r-side-search input::-moz-placeholder{color:var(--ink-5)}.r-side-search input::placeholder{color:var(--ink-5)}.r-side-search input:focus{border-color:var(--line-strong);background:#fff}.r-side-label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-5);padding:0 10px 8px}.r-side-nav{display:flex;flex-direction:column;gap:4px}.r-side-link{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:13px;color:var(--ink-3);text-decoration:none;border:1px solid transparent;border-radius:var(--r-sm);transition:background .12s var(--ease),color .12s var(--ease),border-color .12s var(--ease);cursor:pointer}.r-side-link:hover{background:var(--surface-1);color:var(--ink-1)}.r-side-link.active{background:var(--surface-2);color:var(--ink-1);border-color:var(--line)}.r-side-num{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-5);letter-spacing:.1em;flex:0 0 auto}.r-side-link.active .r-side-num{color:var(--blue)}@media (max-width:900px){.r-side{position:static;height:auto;overflow:visible;border-right:0;border-bottom:1px solid var(--line);padding:16px 20px 20px;min-height:auto}.r-side-search{display:none}.r-side-nav{flex-direction:row;flex-wrap:wrap;gap:6px}.r-side-link{padding:7px 10px;font-size:12px}}:root{--line-grid:#f1f3f6;--border:#e4e7eb;--border-soft:#eef0f3;--border-strong:#d4d8de;--border-hover:#d4d8de;--blue-600:#2563eb;--blue-500:#3b82f6;--font-serif:"Source Serif 4",Georgia,serif;--r-xl:8px;--r-pill:999px;--shadow-md:0 6px 16px -8px rgba(15,23,42,0.08);--shadow-lg:0 18px 40px -16px rgba(15,23,42,0.14)}.nav-mark a{display:inline-flex}.nav-logo{height:28px}.nav-brand-fallback{font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.06em}.nav-links a.active,.nav-links a:hover{color:var(--ink-1);background:var(--surface-2)}footer.site-footer{padding:56px 0 32px;margin-top:80px}.footer-grid{grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:36px}.footer-col h4{margin-bottom:12px}.footer-col li{margin-bottom:8px}.footer-col a{transition:color .15s ease}.footer-bottom{padding-top:20px}@media (max-width:900px){.nav-links{display:none}.container,.container-narrow{padding:0 20px}.footer-grid{grid-template-columns:1fr;gap:24px}}.gd-hero{padding:64px 0 40px;border-bottom:1px solid var(--line)}.gd-hero:before{top:-10%;right:-8%;width:50%;background:radial-gradient(closest-side,rgba(37,99,235,.06),transparent 70%)}.gd-hero .container{position:relative}.gd-hero-thumb{background:#fff}@media (max-width:900px){.gd-hero.has-thumb .container{grid-template-columns:1fr;gap:0}.gd-hero-thumb{display:none}}.crumbs{display:flex;align-items:center;gap:6px;color:var(--ink-4);margin-bottom:16px}.crumbs span{color:var(--ink-5)}.gd-hero h1{font-size:clamp(34px,4.6vw,56px);line-height:1.05;letter-spacing:-.03em;margin:18px 0;max-width:18ch;text-wrap:balance}.gd-meta{gap:24px;padding-top:24px;border-top:1px solid var(--line);font-size:11.5px;letter-spacing:.06em}.gd-meta .sep{display:none}.gd-body{padding:64px 0 40px}.gd-intro{font-family:var(--font-serif);font-size:19px;line-height:1.7;color:var(--ink-2);max-width:760px;margin:0 auto 56px}.gd-intro p{margin-bottom:18px}.gd-intro p:last-child{margin-bottom:0}hr.section-divider{border:0;border-top:1px solid var(--line);margin:56px 0}.gd-layout{display:grid;grid-template-columns:248px minmax(0,1fr);gap:56px;align-items:start}.gd-content{min-width:0;max-width:760px;margin:0 auto}.gd-content>.gd-intro{margin-left:0;margin-right:0}.sec{padding:0;scroll-margin-top:88px}.sec-lede{font-size:18px;color:var(--ink-3)}.sec-main{font-family:var(--font-serif);font-size:17.5px;line-height:1.72;color:var(--ink-2)}.sec-main h2{font-family:var(--font-sans);font-size:clamp(26px,3vw,36px);line-height:1.15;letter-spacing:-.025em;color:var(--ink-1);margin:0 0 24px;text-wrap:balance}.sec-main h2 .step{display:block;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:8px}.sec-main h3{font-family:var(--font-sans);font-size:19px;font-weight:600;color:var(--ink-1);margin:32px 0 12px;letter-spacing:-.015em}.sec-main p{margin:0 0 18px}.sec-main p:last-child{margin-bottom:0}.sec-main strong{color:var(--ink-1);font-weight:600}.sec-main em{color:var(--ink-1);font-style:italic}.sec-main a{color:var(--blue);border-bottom:1px solid rgba(37,99,235,.3);transition:border-color .15s ease}.sec-main a:hover{border-bottom-color:var(--blue)}.sec-main code{font-family:var(--font-mono);font-size:.88em;background:var(--surface-2);color:var(--ink-1);padding:1px 6px;border-radius:3px;border:1px solid var(--line-soft)}.sec-main ol,.sec-main ul{margin:0 0 22px;padding-left:24px}.sec-main ul{list-style:disc}.sec-main ol{list-style:decimal}.sec-main li{margin-bottom:8px}.sec-main pre.code{background:#0b1220;color:#e2e8f0;font-family:var(--font-mono);font-size:13.5px;line-height:1.6;padding:18px 22px;border-radius:var(--r-md);overflow-x:auto;margin:22px 0;white-space:pre}.sec-main .pull{border-left:3px solid var(--blue);padding:4px 0 4px 22px;margin:28px 0;font-size:19px;line-height:1.55;color:var(--ink-1);font-style:italic}.sec-main .pull-attribution{display:block;margin-top:6px;font-family:var(--font-mono);font-size:11px;font-style:normal;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4)}.gd-callout{background:var(--blue-soft);border:1px solid #c7d8ff;border-radius:var(--r-md);padding:18px 22px;margin:22px 0;font-family:var(--font-sans);font-size:15.5px;line-height:1.6;color:var(--ink-2)}.gd-callout .lbl{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:6px}.gd-callout p{margin:0}.compare{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:22px 0;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;font-family:var(--font-sans);font-size:14.5px}.compare .col{padding:18px 22px}.compare .col+.col{border-left:1px solid var(--line)}.compare .col-label{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}.compare .col-label:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}.compare .col.human .col-label{color:var(--ink-3)}.compare .col.bot .col-label{color:var(--blue)}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;margin:22px 0;background:#fff}.stat-row .stat{padding:18px 22px}.stat-row .stat+.stat{border-left:1px solid var(--line)}.stat-row .num{font-family:var(--font-sans);font-size:26px;font-weight:600;letter-spacing:-.02em;color:var(--ink-1);line-height:1.1}.stat-row .lbl{letter-spacing:.1em;color:var(--ink-5);margin-top:6px}.badge-inline,.stat-row .lbl{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase}.badge-inline{display:inline-flex;align-items:center;font-weight:600;letter-spacing:.06em;padding:2px 8px;border-radius:var(--r-xs);margin-right:6px}.badge-inline.observed{background:var(--blue-soft);color:var(--blue);border:1px solid rgba(37,99,235,.28)}.badge-inline.inferred{background:#fff;color:var(--ink-3);border:1px solid var(--line)}.badge-inline.required{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.article-image{margin:28px 0;text-align:center}.article-image img{max-width:100%;height:auto;border:1px solid var(--line);border-radius:var(--r-md);display:inline-block}.article-image figcaption{font-family:var(--font-sans);font-size:13px;color:var(--ink-4);margin-top:12px;font-style:italic}.gd-cta{margin:80px 0 32px;padding:56px 48px;background:linear-gradient(135deg,#0b1220,#0a0f1f 60%,#1a1f3a);border-radius:var(--r-md);color:#fff;text-align:center;position:relative;overflow:hidden}.gd-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 30%,rgba(59,130,246,.32),transparent 55%),radial-gradient(circle at 20% 90%,rgba(139,92,246,.2),transparent 55%);pointer-events:none}.gd-cta>*{position:relative}.gd-cta h2{color:#fff;font-size:30px;line-height:1.15;letter-spacing:-.02em;margin-bottom:12px;font-weight:600}.gd-cta h2,.gd-cta p{font-family:var(--font-sans)}.gd-cta p{color:rgba(255,255,255,.78);max-width:540px;margin:0 auto 28px;font-size:15.5px;line-height:1.55}.gd-cta .discord-cta{background:#fff;color:var(--blue);border-color:#fff}.gd-cta .discord-cta:hover{background:var(--blue-soft);border-color:var(--blue-soft)}@media (max-width:900px){.gd-layout{grid-template-columns:1fr;gap:0}.gd-content{max-width:760px;margin:0 auto}}@media (max-width:600px){.gd-hero{padding:48px 0 28px}.gd-body{padding:48px 0 32px}.sec-main{font-size:16.5px}.sec-main h2{font-size:26px}.gd-cta{padding:40px 24px}.stat-row{grid-template-columns:1fr 1fr}}:root{--bg:#ffffff;--surface-1:#fafbfc;--surface-2:#f4f6f8;--surface-3:#eef1f4;--line:#e4e7eb;--line-soft:#eef0f3;--line-strong:#d4d8de;--ink-1:#0a0a0c;--ink-2:#1f2937;--ink-3:#475569;--ink-4:#64748b;--ink-5:#94a3b8;--blue:#2563eb;--blue-700:#1d4ed8;--blue-soft:#eff6ff;--blue-soft-2:#dbeafe;--success:#16a34a;--warn:#ca8a04;--warn-soft:#fef9e7;--warn-border:#f3e1a8;--tip-soft:#ecfaf0;--tip-border:#b9e7c5;--font-sans:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;--font-serif:"Source Serif 4",Georgia,"Times New Roman",serif;--r-xs:2px;--r-sm:3px;--r-md:4px;--r-lg:6px;--shadow-xs:0 1px 0 rgba(15,23,42,0.02);--shadow-sm:0 1px 2px rgba(15,23,42,0.03);--shadow-blue:0 6px 18px -8px rgba(37,99,235,0.30);--maxw:1240px;--maxw-narrow:920px;--maxw-wide:1360px;--ease:cubic-bezier(0.22,1,0.36,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body,html{background:var(--bg);color:var(--ink-2);font-family:var(--font-sans);font-size:15px;line-height:1.55;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01","cv11"}body{background-image:radial-gradient(circle,rgba(15,23,42,.06) 1px,transparent 0);background-size:22px 22px;background-position:0 0}a{color:inherit;text-decoration:none}ul{list-style:none}img{display:block;max-width:100%}::-moz-selection{background:var(--blue-soft-2);color:var(--ink-1)}::selection{background:var(--blue-soft-2);color:var(--ink-1)}h1,h2,h3,h4{color:var(--ink-1);font-weight:600;letter-spacing:-.025em;text-wrap:balance}.container{max-width:var(--maxw)}.container,.container-wide{margin:0 auto;padding:0 32px}.container-wide{max-width:var(--maxw-wide)}.container-narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 32px}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}.eyebrow:before{content:"";width:8px;height:8px;background:var(--blue)}.label-tag{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;background:#fff;border:1px solid var(--line);color:var(--ink-3);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border-radius:var(--r-xs)}.label-tag.blue{border-color:rgba(37,99,235,.28);background:var(--blue-soft);color:var(--blue)}.label-tag .dot{width:6px;height:6px;background:currentColor}nav.site-nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}.nav-inner{max-width:var(--maxw-wide);margin:0 auto;padding:14px 32px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}.nav-mark{justify-self:start}.nav-mark,.nav-mark a{display:flex;align-items:center}.nav-logo{height:36px;width:auto;display:block}.nav-brand-fallback{font-family:var(--font-sans);font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--ink-1)}.nav-links{gap:0;justify-self:center}.nav-links,.nav-links>li{display:flex;align-items:center}.nav-links>li+li:before{content:"";display:block;width:1px;height:14px;background:var(--line-strong);margin:0 6px}.nav-links a{display:inline-block;padding:8px 14px;font-size:13.5px;font-weight:500;color:var(--ink-3);border-radius:var(--r-xs);transition:color .18s var(--ease),background .18s var(--ease);white-space:nowrap}.nav-links a.active,.nav-links a:hover{color:var(--ink-1);background:var(--surface-2)}.nav-right{display:flex;align-items:center;justify-content:flex-end;gap:14px;justify-self:end}.nav-contact{display:inline-block;padding:8px 4px;font-size:13.5px;font-weight:500;color:var(--ink-3);white-space:nowrap}.nav-contact:hover{color:var(--ink-1)}.discord-cta{display:inline-flex;align-items:center;gap:9px;padding:10px 18px;background:var(--blue);color:#fff;font-size:13.5px;font-weight:600;border-radius:var(--r-sm);border:1px solid var(--blue);box-shadow:var(--shadow-blue);transition:transform .15s var(--ease),background .15s var(--ease);position:relative;overflow:hidden}.discord-cta:hover{background:var(--blue-700);border-color:var(--blue-700);transform:translateY(-1px)}.discord-cta svg{width:16px;height:16px}.discord-cta:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:translateX(-100%);animation:shimmer 3.4s ease-in-out infinite;pointer-events:none}@keyframes shimmer{0%{transform:translateX(-100%)}60%,to{transform:translateX(100%)}}.gd-hero{padding:80px 0 56px;border-bottom:1px solid var(--line-soft);position:relative;overflow:hidden}.gd-hero:before{content:"";position:absolute;top:-20%;right:-10%;width:60%;height:80%;background:radial-gradient(closest-side,rgba(37,99,235,.1),transparent 70%);pointer-events:none}.gd-hero.has-thumb .container{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:40px;align-items:center}.gd-hero-text{min-width:0}.gd-hero-thumb{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface-1,#fff);box-shadow:0 1px 3px rgba(15,23,42,.06);aspect-ratio:16/9}.gd-hero-thumb img{display:block;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gd-hero h1{font-size:clamp(34px,4.8vw,56px);line-height:1.08;letter-spacing:-.035em;font-weight:700;color:var(--ink-1);max-width:880px;margin:22px 0;overflow-wrap:break-word;word-break:break-word;hyphens:auto}.gd-hero .lead{max-width:720px;font-size:19px;line-height:1.55;color:var(--ink-3);margin-bottom:28px}.gd-meta{display:flex;gap:20px;flex-wrap:wrap;align-items:center;padding-top:22px;border-top:1px solid var(--line-soft);font-family:var(--font-mono);font-size:12px;color:var(--ink-4);letter-spacing:.04em}.gd-meta strong{color:var(--ink-1);font-weight:600}.gd-meta .sep{width:1px;height:14px;background:var(--line)}.crumbs{display:inline-flex;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-5);margin-bottom:24px}.crumbs a{color:var(--ink-4)}.crumbs a:hover{color:var(--ink-1)}.tut-steps{border-bottom:1px solid var(--line);background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);position:sticky;top:65px;z-index:50;display:none}.tut-steps-inner{max-width:var(--maxw);margin:0 auto;display:flex;gap:8px;align-items:center;padding:14px 20px;overflow-x:auto;scrollbar-width:thin}.tut-step-pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:#fff;border:1px solid var(--line);color:var(--ink-3);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.02em;border-radius:var(--r-xs);cursor:pointer;transition:border-color .15s var(--ease),color .15s var(--ease),background .15s var(--ease);white-space:nowrap}.tut-step-pill .pill-num{color:var(--ink-5);font-weight:600}.tut-step-pill:hover{border-color:var(--line-strong);color:var(--ink-1)}.tut-step-pill[data-active=true]{background:var(--blue-soft);border-color:rgba(37,99,235,.28);color:var(--blue)}.tut-step-pill[data-active=true] .pill-num{color:var(--blue)}.tut-progress{display:none;height:2px;background:var(--line-soft)}.tut-progress-fill{height:100%;background:var(--blue);transition:width .3s var(--ease);width:0}.tut-page-region{padding:56px 0 64px}.tut-layout-grid{max-width:var(--maxw);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:minmax(0,1fr) 300px;-moz-column-gap:56px;column-gap:56px;align-items:start}.tut-main{min-width:0}.tut-page{max-width:100%}.tut-page[hidden]{display:none}.tut-aside{position:sticky;top:88px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:18px 18px 14px;box-shadow:var(--shadow-xs)}.tut-aside-head{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:12px}.tut-aside-head .aside-count{color:var(--ink-1);font-weight:600}.tut-aside-bar{height:4px;background:var(--line-soft);border-radius:2px;overflow:hidden;margin-bottom:14px}.tut-aside-bar-fill{height:100%;background:var(--blue);border-radius:2px;transition:width .3s var(--ease);width:0}.tut-aside-list{display:flex;flex-direction:column;border-top:1px solid var(--line-soft);padding-top:8px}.tut-aside-row{display:grid;grid-template-columns:18px 1fr;align-items:flex-start;gap:12px;padding:9px 8px;cursor:pointer;border-radius:var(--r-sm);border:0;background:transparent;text-align:left;transition:background .12s var(--ease);font-family:var(--font-sans)}.tut-aside-row:hover{background:var(--surface-1)}.tut-aside-row .marker{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-strong);background:#fff;position:relative;margin-top:2px}.tut-aside-row[data-status=visited] .marker{background:var(--blue);border-color:var(--blue)}.tut-aside-row[data-status=visited] .marker:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3.5 8.5l3 3 6-7' stroke='white' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") 50%/12px no-repeat}.tut-aside-row[data-status=current] .marker{background:#fff;border-color:var(--blue);border-width:4px;box-shadow:0 0 0 4px var(--blue-soft)}.tut-aside-row[data-status=current]{background:var(--blue-soft)}.tut-aside-row>span:not(.marker){display:flex;flex-direction:column;min-width:0}.tut-aside-row .step-num{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.1em;color:var(--ink-5);display:block;margin-bottom:3px}.tut-aside-row .step-title{font-family:var(--font-sans);font-size:13px;font-weight:500;line-height:1.4;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.tut-aside-row[data-status=current] .step-num,.tut-aside-row[data-status=current] .step-title{color:var(--blue);font-weight:600}.tut-aside-row[data-status=visited] .step-title{color:var(--ink-3)}.intro-lede{font-family:var(--font-serif);font-size:19px;line-height:1.65;color:var(--ink-2);max-width:760px;margin:0 0 24px}.intro-time-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:14px 0;margin:16px 0 24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-5)}.intro-time-row strong{color:var(--ink-1);font-weight:600}.intro-time-row .sep{width:1px;height:14px;background:var(--line)}.intro-cards{display:grid;grid-template-columns:1fr;gap:24px;margin:28px 0}.intro-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md)}.intro-card-head{padding:14px 24px;border-bottom:1px solid var(--line);background:var(--surface-1);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}.intro-card-body{padding:26px 28px 24px}.intro-card-body ul{list-style:disc;padding-left:22px}.intro-card-body li{font-family:var(--font-serif);font-size:16px;line-height:1.7;color:var(--ink-2);margin:0 0 14px}.intro-card-body li:last-child{margin:0}.step-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px}.step-copy-btn{font:inherit;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:#fff;color:var(--ink-3);border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 12px;cursor:pointer;transition:border-color .12s var(--ease),color .12s var(--ease),background .12s var(--ease);white-space:nowrap;flex:0 0 auto}.step-copy-btn:hover{border-color:var(--blue);color:var(--blue)}.step-copy-btn[data-copied=true]{background:var(--success);color:#fff;border-color:var(--success)}.step-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.04em;color:var(--blue);margin-bottom:14px}.step-eyebrow:before{content:"";width:8px;height:8px;background:var(--blue)}.step-heading{font-size:clamp(26px,3.2vw,38px);line-height:1.15;letter-spacing:-.025em;font-weight:600;color:var(--ink-1);margin:0 0 14px;padding-left:16px;border-left:3px solid var(--blue);scroll-margin-top:90px;hyphens:auto}.step-heading,.step-intro{overflow-wrap:break-word;word-break:break-word}.step-intro{font-family:var(--font-serif);font-size:18.5px;line-height:1.7;color:var(--ink-2);margin:0 0 32px;max-width:760px;padding:22px 26px;background:#fff;border:1px solid var(--line-soft);border-left:3px solid var(--blue);border-radius:var(--r-md);box-shadow:var(--shadow-xs)}.step-intro strong{color:var(--ink-1);font-weight:600}.step-intro em{color:var(--ink-1);font-style:italic}.block-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));row-gap:40px;-moz-column-gap:22px;column-gap:22px;max-width:1180px}.block{min-width:0}.block.full{grid-column:span 2}.block.half{grid-column:span 1}.block.block-ai,.block.block-code,.block.block-video{grid-column:span 2}.block-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:10px}.block-prose{background:transparent;border:0;padding:4px 0 0;max-width:760px;font-family:var(--font-serif);font-size:17.5px;line-height:1.72;color:var(--ink-2);overflow-wrap:break-word;word-break:break-word}.block-prose h3{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-1);margin:4px 0 12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600}.block-prose p{margin:0 0 14px}.block-prose p:last-child{margin:0}.block-prose strong{color:var(--ink-1);font-weight:600}.block-prose em{color:var(--ink-1);font-style:italic}.block.half .block-prose{font-size:16.5px}code.ident{font-family:var(--font-mono);font-size:.86em;font-weight:500;color:var(--ink-1);background:#f1f5f9;border:1px solid #e2e8f0;padding:1px 6px;border-radius:4px;white-space:nowrap;word-break:keep-all}.block-callout code.ident{background:rgba(255,255,255,.7);border-color:rgba(11,18,32,.12)}.block-ai code.ident{background:#fff;border-color:#c7d8ff;color:var(--blue)}.block-ai-context code:not(.ident),.block-callout code:not(.ident),.block-prose code:not(.ident){font-family:var(--font-mono);font-size:.9em;color:var(--ink-1)}.block-ai{border:1px solid #c7d8ff;background:var(--blue-soft);border-radius:var(--r-md);padding:22px 26px 24px}.block-ai-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px}.block-ai-head-meta{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.block-ai-head-actions{gap:6px;flex:0 0 auto}.block-ai-head-actions,.block-ai-lbl{display:inline-flex;align-items:center}.block-ai-lbl{gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue)}.block-ai-lbl:before{content:"";width:8px;height:8px;background:var(--blue)}.block-ai-tool{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);padding:4px 9px;background:#fff;border:1px solid rgba(37,99,235,.28);border-radius:var(--r-xs)}.block-ai-title{display:block;font-size:17px;font-weight:600;color:var(--ink-1);margin:4px 0 8px;letter-spacing:-.01em;line-height:1.3}.block-ai-context,.block-ai-title{font-family:var(--font-sans);overflow-wrap:break-word}.block-ai-context{font-size:14.5px;line-height:1.6;color:var(--ink-3);margin:0 0 16px;max-width:720px}.block-ai-prompt{font-family:var(--font-mono);font-size:13.5px;line-height:1.75;background:#fff;border:1px solid rgba(37,99,235,.2);color:var(--ink-1);padding:22px 26px;border-radius:var(--r-sm);white-space:pre-wrap;word-break:break-word;overflow:auto;box-shadow:var(--shadow-xs);margin-top:12px}.block-ai-prompt.collapsed{display:none}.expand-btn{font:inherit;font-family:var(--font-mono);font-size:12px;background:transparent;color:var(--ink-3);border:1px solid var(--line);border-radius:var(--r-xs);width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s var(--ease),border-color .12s var(--ease),color .12s var(--ease);flex:0 0 auto}.expand-btn:hover{border-color:var(--blue);color:var(--blue)}.expand-btn[aria-expanded=true]{transform:rotate(180deg)}.copy-btn{font:inherit;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:#fff;color:var(--blue);border:1px solid rgba(37,99,235,.28);border-radius:var(--r-xs);padding:5px 10px;cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease),border-color .12s var(--ease);white-space:nowrap}.copy-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.copy-btn[data-copied=true]{background:var(--success);color:#fff;border-color:var(--success)}.block-ai-foot{display:flex;justify-content:flex-end;margin-top:14px}.block-ai .copy-btn{font-size:11px;padding:6px 12px}.block-code{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.block-code-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface-1);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}.block-code-head-meta{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.block-code-head-actions{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto}.block-code-head .filename{color:var(--ink-1);font-weight:600}.block-code-head .lang-chip{color:var(--blue);font-weight:600}.block-code-caption{padding:12px 16px 0;font-family:var(--font-sans);font-size:14px;color:var(--ink-3)}.block-code pre{margin:0;padding:18px 22px;background:#0b1220;color:#e2e8f0;font-family:var(--font-mono);font-size:13.5px;line-height:1.65;overflow-x:auto;white-space:pre}.block-code code{background:transparent;color:inherit;font:inherit}.block-code-head .copy-btn,.block-code-head .expand-btn{margin-left:4px}.block-code-body{position:relative}.block-code-body[data-state=preview]{max-height:124px;overflow:hidden}.block-code-body[data-state=preview] .block-code-blur{position:absolute;inset:0;pointer-events:none;backdrop-filter:blur(3.5px);-webkit-mask-image:linear-gradient(180deg,transparent 0,transparent 22%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.7) 60%,rgba(0,0,0,.95) 80%,black);mask-image:linear-gradient(180deg,transparent 0,transparent 22%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.7) 60%,rgba(0,0,0,.95) 80%,black)}.block-code-body[data-state=preview] .block-code-expand-bar{position:absolute;left:0;right:0;bottom:0;height:38px;display:flex;align-items:center;justify-content:center;font:inherit;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(226,232,240,.9);background:linear-gradient(180deg,rgba(11,18,32,0) 0,rgba(11,18,32,.9));border:0;cursor:pointer;z-index:2;transition:color .12s var(--ease)}.block-code-body[data-state=preview] .block-code-expand-bar:hover{color:#fff}.block-code-body[data-state=expanded] .block-code-blur,.block-code-body[data-state=expanded] .block-code-expand-bar{display:none}.block-video{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .15s var(--ease)}.block-video:hover{border-color:var(--blue)}.block-video .video-frame{position:relative;aspect-ratio:16/9;background:#000}.block-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.block-video .video-meta{padding:12px 16px 14px;display:flex;flex-direction:column;gap:4px}.block-video .video-label{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}.block-video .video-caption{font-family:var(--font-sans);font-size:14px;line-height:1.45;color:var(--ink-2)}.block-screenshot{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.block-screenshot-head{padding:12px 18px;border-bottom:1px solid var(--line);background:var(--surface-1);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}.block-screenshot img{display:block;width:100%;height:auto}.block-screenshot .placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-1);color:var(--ink-5);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;min-height:220px;padding:32px 24px;border-top:1px dashed var(--line-strong);text-align:center;gap:8px}.block-screenshot .placeholder .alt{font-family:var(--font-sans);font-size:13px;letter-spacing:normal;text-transform:none;color:var(--ink-4);max-width:360px;line-height:1.5}.block-screenshot-caption{padding:12px 18px 16px;font-family:var(--font-sans);font-size:14px;color:var(--ink-3);line-height:1.5}.block-embed{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.block-embed-head{padding:12px 18px;border-bottom:1px solid var(--line);background:var(--surface-1);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}.block-embed-frame{padding:18px}.block-embed-caption{padding:0 18px 16px;font-family:var(--font-sans);font-size:14px;color:var(--ink-3);line-height:1.5}.block-callout{padding:18px 22px;border-radius:var(--r-md);border:1px solid #c7d8ff;background:var(--blue-soft);font-family:var(--font-sans);font-size:15px;line-height:1.55;color:var(--ink-2);overflow-wrap:break-word;word-break:break-word}.block-callout .lbl{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}.block-callout .lbl:before{content:"";width:8px;height:8px;background:var(--blue)}.block-callout h4{margin:0 0 6px;font-size:15.5px;color:var(--ink-1);font-weight:600}.block-callout p{margin:0}.block-callout strong{color:var(--ink-1);font-weight:600}.block-callout.tone-warning{background:var(--warn-soft);border-color:var(--warn-border)}.block-callout.tone-warning .lbl{color:var(--warn)}.block-callout.tone-warning .lbl:before{background:var(--warn)}.block-callout.tone-success,.block-callout.tone-tip{background:var(--tip-soft);border-color:var(--tip-border)}.block-callout.tone-success .lbl,.block-callout.tone-tip .lbl{color:var(--success)}.block-callout.tone-success .lbl:before,.block-callout.tone-tip .lbl:before{background:var(--success)}.tut-pagenav{margin:48px 0 0;padding:24px 0 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:14px}.tut-pagenav-btn{font:inherit;display:inline-flex;align-items:center;gap:9px;padding:9px 16px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink-1);font-family:var(--font-sans);font-size:13.5px;font-weight:500;letter-spacing:-.005em;cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease),color .15s var(--ease);white-space:nowrap;max-width:320px}.tut-pagenav-btn:hover{border-color:var(--line-strong);background:var(--surface-1)}.tut-pagenav-btn[data-dir=next]{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:600;padding:10px 18px;box-shadow:var(--shadow-blue)}.tut-pagenav-btn[data-dir=next]:hover{background:var(--blue-700);border-color:var(--blue-700)}.tut-pagenav-btn .arrow{font-family:var(--font-mono);font-size:14px;font-weight:500;color:inherit;opacity:.85}.tut-pagenav-btn .meta{display:none}.tut-pagenav-btn>span:not(.arrow){display:inline-flex;align-items:center;min-width:0;max-width:220px}.tut-pagenav-btn .label{display:inline-block;font:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;vertical-align:middle}.tut-pagenav-btn[data-dir=next]>span:not(.arrow){max-width:240px}.tut-pagenav-btn[disabled]{opacity:.4;cursor:not-allowed;pointer-events:none}.tut-pagenav-btn[data-dir=prev][disabled]{visibility:hidden}.section-divider{border:0;border-top:1px solid var(--line);margin:0;height:0;width:100%}footer.site-footer{padding:56px 0 36px;border-top:1px solid var(--line);background:var(--surface-1);margin-top:56px}.footer-grid{max-width:var(--maxw);padding:0 32px;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin:0 auto 36px}.footer-brand p{font-size:13.5px;color:var(--ink-3);max-width:320px;line-height:1.6}.footer-col h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-5);font-weight:500;margin-bottom:14px}.footer-col ul li{margin-bottom:8px}.footer-col a{font-size:13.5px;color:var(--ink-3);transition:color .15s var(--ease)}.footer-col a:hover{color:var(--ink-1)}.footer-bottom{max-width:var(--maxw);margin:0 auto;padding:22px 32px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-5)}@media (min-width:901px){.tut-progress,.tut-steps{display:none}}@media (max-width:900px){.nav-contact,.nav-links{display:none}.nav-inner{padding:12px 20px;grid-template-columns:1fr auto}.container,.container-narrow,.container-wide{padding:0 20px}.tut-progress,.tut-steps{display:block}.tut-aside{display:none}.tut-layout-grid{grid-template-columns:1fr;-moz-column-gap:0;column-gap:0;padding:0 20px}.tut-steps-inner{padding:12px 20px}.gd-hero{padding:56px 0 36px}.gd-hero.has-thumb .container{grid-template-columns:1fr;gap:0}.gd-hero-thumb{display:none}.footer-grid{grid-template-columns:1fr 1fr;gap:28px;padding:0 20px}.footer-bottom{padding:22px 20px 0;flex-direction:column;gap:10px;align-items:flex-start}.tut-pagenav{padding:24px 20px 0}.tut-pagenav-btn .label{max-width:140px}.tut-pagenav-btn[data-dir=next] .label{max-width:160px}.block-grid{grid-template-columns:1fr}.block.half{grid-column:span 1}.intro-cards{grid-template-columns:1fr}}.no-js .tut-page[hidden]{display:block!important;padding-top:32px;padding-bottom:32px;border-top:1px solid var(--line-soft)}.no-js .tut-pagenav,.no-js .tut-progress,.no-js .tut-steps{display:none}