.tut-fw-logo{display:inline-block;flex:0 0 auto;color:var(--foreground);vertical-align:middle}.tut-fw-logo--js{color:#ffd60a}.tut-fw-logo--react{color:#60a5fa}.tut-fw-logo--vue{color:#8df0cc}.tut-hub{width:100%;max-width:var(--max-width, 1200px);margin:0 auto;padding:28px 0 96px;display:flex;flex-direction:column;gap:32px}.tut-hub-band{display:block;padding:0;border-bottom:1px solid var(--border);position:relative}@keyframes tut-band-pulse{0%,to{opacity:1}50%{opacity:.35}}.tut-hub-band-title{position:relative;margin:28px 0 0;font-family:var(--font-sans);font-size:clamp(72px,11vw,144px);font-variation-settings:"opsz" 60,"wght" 720;letter-spacing:-.045em;line-height:.82;color:var(--foreground);padding-bottom:14px;border-bottom:4px solid var(--accent)}.tut-hub-band-title:after{content:"";position:absolute;left:0;right:0;bottom:-18px;height:10px;background:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--accent) 32%,transparent) 0 2px,transparent 2px 10px);pointer-events:none}.tut-hub-band-desc{margin:36px 0 0;max-width:52ch;font-family:var(--font-sans);font-size:14px;line-height:1.45;color:var(--foreground-feint);text-wrap:balance}.tut-hub-band--spec{padding:50px 0 18px;border-top:none;border-bottom:1px solid color-mix(in srgb,var(--foreground) 20%,transparent)}.tut-band-spec-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:32px;align-items:start;padding:14px 0 18px;border-bottom:1px dashed color-mix(in srgb,var(--foreground-feint) 40%,transparent)}.tut-band-spec-col--annotations{display:flex;flex-direction:column;gap:10px;max-width:52ch}.tut-band-spec-row{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground);line-height:1.55}.tut-band-spec-row-label{color:var(--foreground-feint);font-variation-settings:"wght" 560}.tut-band-spec-row-body{color:var(--foreground);text-transform:none;letter-spacing:.04em;font-size:11px}.tut-band-spec-col--stamp{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:160px}.tut-band-spec-stamp{display:inline-flex;align-items:baseline;gap:10px;padding:8px 14px 10px;border:1.5px solid var(--foreground);background:var(--background);font-family:var(--font-mono);line-height:1}.tut-band-spec-stamp-name{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-variation-settings:"wght" 640;color:var(--foreground)}.tut-band-spec-stamp-ver{font-family:var(--font-sans);font-size:26px;font-variation-settings:"opsz" 40,"wght" 720;letter-spacing:-.03em;color:var(--accent);font-variant-numeric:tabular-nums}.tut-band-spec-stamp-bar{display:inline-flex;align-items:center;gap:8px;padding:4px 10px 5px;background:var(--foreground);color:var(--background);font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;font-variation-settings:"wght" 600;line-height:1}.tut-band-spec-stamp-dot{width:5px;height:5px;background:var(--accent);display:inline-block;flex:0 0 auto}.tut-band-spec-caption{display:inline-flex;align-items:baseline;gap:10px;margin-top:18px;padding:0;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--foreground-feint)}.tut-band-spec-title{margin:0;padding:0;font-size:clamp(64px,9vw,120px);font-variation-settings:"opsz" 60,"wght" 680;letter-spacing:-.045em;line-height:.84;border-bottom:0;flex:0 0 auto}.tut-band-spec-title:after{display:none}.tut-band-spec-title-wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);align-items:end;gap:14px;margin-top:14px;padding-top:20px;padding-bottom:10px;border-bottom:2px solid var(--accent);position:relative}.tut-band-spec-title-wrap:after{content:"";position:absolute;left:0;right:0;bottom:-12px;height:6px;background:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--accent) 30%,transparent) 0 2px,transparent 2px 8px);pointer-events:none}.tut-wf-framed{flex:1 1 0;min-width:0;height:calc(clamp(64px,9vw,120px)*.84);align-self:flex-end;pointer-events:none;position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) 32px;grid-template-rows:auto minmax(0,1fr);column-gap:4px}.tut-wf-framed-canvas{grid-column:1;grid-row:2;display:block;width:100%;height:100%;min-width:0;min-height:0}.tut-wf-framed-label{grid-column:1 / 3;grid-row:1;padding:4px 0 6px;font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--foreground-feint);font-variation-settings:"wght" 600;display:inline-flex;align-items:baseline;gap:6px}.tut-wf-framed-prefix{color:var(--accent)}.tut-wf-framed-ticks{grid-column:2;grid-row:2;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;padding:0 4px 2px 0;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.08em;color:var(--foreground-feint);font-variant-numeric:tabular-nums}@media(max-width:640px){.tut-wf-framed{display:none}}.tut-band-spec-easing{display:block;width:100%;height:auto;margin:0;padding:0;color:var(--foreground-feint);font-family:var(--font-mono);overflow:visible}.tut-band-spec-easing-grid line{stroke:color-mix(in srgb,var(--accent) 22%,transparent);stroke-width:.5;stroke-dasharray:2 3;vector-effect:non-scaling-stroke}.tut-band-spec-easing-axes line{stroke:color-mix(in srgb,var(--foreground-feint) 80%,transparent);stroke-width:1;stroke-linecap:square;vector-effect:non-scaling-stroke}.tut-band-spec-easing-ticks text{fill:var(--foreground-feint);font-family:var(--font-mono);font-size:8px;font-variation-settings:"wght" 500;font-variant-numeric:tabular-nums;letter-spacing:.04em}.tut-band-spec-easing-curve{stroke:var(--accent);stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round;fill:none;vector-effect:non-scaling-stroke;pointer-events:none}.tut-band-spec-easing-curve-group,.tut-band-spec-easing-legend-item{transition:opacity .2s cubic-bezier(.22,.8,.32,1)}.tut-band-spec-easing-curve-hit{stroke:transparent;stroke-width:14;fill:none;pointer-events:stroke;cursor:pointer}.tut-band-spec-easing-legend-hit{fill:transparent;pointer-events:fill;cursor:pointer}.tut-band-spec-easing[data-hovered=true] [data-ease][data-active=false]{opacity:.12}.tut-band-spec-easing-reveal{stroke-dasharray:1;stroke-dashoffset:1;stroke-linecap:butt}.tut-band-spec-easing[data-in-view=true] .tut-band-spec-easing-reveal{animation:tut-ease-draw .76s cubic-bezier(.22,.8,.32,1) forwards;animation-delay:var(--tut-ease-delay, 0ms)}@keyframes tut-ease-draw{to{stroke-dashoffset:0}}.tut-band-spec-easing-legend-reveal{transform-box:fill-box;transform-origin:left center;transform:scaleX(0)}.tut-band-spec-easing[data-in-view=true] .tut-band-spec-easing-legend-reveal{animation:tut-ease-legend-sweep .56s cubic-bezier(.22,.8,.32,1) forwards;animation-delay:var(--tut-ease-delay, 0ms)}@keyframes tut-ease-legend-sweep{to{transform:scaleX(1)}}.tut-band-spec-easing-legend-line{stroke:var(--accent);stroke-width:1.25;stroke-linecap:butt;fill:none;vector-effect:non-scaling-stroke}.tut-band-spec-easing-legend-text{fill:var(--foreground-feint);font-family:var(--font-mono);font-size:8.5px;letter-spacing:.08em;font-variation-settings:"wght" 600}@media(prefers-reduced-motion:reduce){.tut-band-spec-easing-reveal{animation:none;stroke-dashoffset:0}.tut-band-spec-easing-legend-reveal{animation:none;transform:scaleX(1)}}.tut-band-spec-footer{display:flex;flex-wrap:wrap;gap:0;margin-top:22px;border-top:1px solid var(--foreground);border-bottom:1px solid var(--foreground)}.tut-band-spec-footer-item{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-right:1px solid color-mix(in srgb,var(--foreground) 40%,transparent);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--foreground);font-variation-settings:"wght" 640;font-variant-numeric:tabular-nums;line-height:1}.tut-band-spec-footer-item:first-child{padding-left:0}.tut-band-spec-footer-item:last-child{border-right:0}.tut-band-spec-footer-label{color:var(--foreground-feint);font-variation-settings:"wght" 500;margin-right:2px}.tut-band-spec-footer-dot{width:6px;height:6px;background:var(--accent);display:inline-block;animation:tut-band-pulse 1.8s ease-in-out infinite}.tut-hub-band--spec .tut-hub-band-desc{margin-top:24px;max-width:56ch;font-size:16px;line-height:1.5}.tut-band-spec-rail{position:static;display:flex;flex-direction:row;align-items:center;gap:10px;padding:7px 0;border-bottom:1px dashed color-mix(in srgb,var(--foreground-feint) 40%,transparent);font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--foreground-feint);line-height:1;pointer-events:none;-webkit-user-select:none;user-select:none}.tut-band-spec-rail-cross{font-family:var(--font-sans);font-size:13px;color:var(--accent);font-variation-settings:"wght" 640;line-height:1}.tut-band-spec-rail-rule{height:1px;flex:1 1 auto;min-width:40px;background:color-mix(in srgb,var(--foreground-feint) 35%,transparent)}.tut-band-spec-rail-sep{color:color-mix(in srgb,var(--foreground-feint) 45%,transparent)}.tut-band-spec-rail-ver{font-family:var(--font-sans);font-variation-settings:"opsz" 14,"wght" 620;font-size:10px;letter-spacing:.04em;color:var(--accent);margin-left:auto}.tut-band-spec-dots{display:grid;grid-template-columns:repeat(16,4px);gap:3px;margin-top:14px;padding:0;color:color-mix(in srgb,var(--foreground-feint) 60%,transparent)}.tut-band-spec-dot{width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.25;animation:tut-band-dot 2.8s ease-in-out infinite}@keyframes tut-band-dot{0%,70%,to{opacity:.2;transform:scale(.85)}35%{opacity:.9;transform:scale(1);color:var(--accent)}}.tut-band-spec-waveform{display:inline-flex;align-items:flex-end;gap:2px;height:22px;margin-top:10px;padding:2px 6px;border:1px solid color-mix(in srgb,var(--foreground-feint) 35%,transparent)}.tut-band-spec-wave-bar{display:block;width:2px;height:30%;background:var(--accent);transform-origin:bottom;animation:tut-band-wave 1.4s ease-in-out infinite}@keyframes tut-band-wave{0%,to{transform:scaleY(.25);opacity:.5}30%{transform:scaleY(1);opacity:1}60%{transform:scaleY(.55);opacity:.75}}@media(prefers-reduced-motion:reduce){.tut-band-spec-dot,.tut-band-spec-wave-bar,.tut-band-spec-footer-dot,.tut-band-spec-stamp-dot{animation:none}}@media(max-width:900px){.tut-hub-band-title{margin-top:22px}.tut-band-spec-rail{flex-wrap:wrap;gap:6px 10px}.tut-band-spec-rail-rule{flex-basis:100%;min-width:0}.tut-band-spec-grid{grid-template-columns:1fr;gap:20px}.tut-band-spec-col--stamp{align-items:flex-start}.tut-band-spec-footer-item{padding:8px 10px}.tut-band-spec-dots{grid-template-columns:repeat(20,4px)}}.tut-feature{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:0;text-decoration:none;color:inherit;position:relative;isolation:isolate}.tut-feature-media{position:relative;aspect-ratio:4 / 3;overflow:hidden;background:var(--layer);border:1.5px solid var(--border)}.tut-feature-media img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .4s cubic-bezier(.2,.8,.2,1)}.tut-feature:hover .tut-feature-media img{transform:scale(1.03)}.tut-feature-media-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,transparent),transparent),var(--layer)}.tut-feature-media-badge{position:absolute;top:14px;left:14px;z-index:2}.tut-feature-media-rail{position:absolute;top:14px;right:14px;z-index:2;display:flex;flex-direction:column;gap:6px;align-items:flex-end}.tut-feature-media-ticker{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:8px 14px;background:color-mix(in srgb,var(--background) 78%,transparent);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;gap:12px;border-top:1px solid color-mix(in srgb,var(--accent) 40%,transparent);overflow:hidden;white-space:nowrap}.tut-feature-media-ticker>span{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--foreground-feint);font-variant-numeric:tabular-nums}.tut-feature-media-ticker-dot{width:4px;height:4px;background:var(--accent);display:inline-block;flex:0 0 auto}.tut-feature-block{background:var(--accent);color:var(--background);display:flex;flex-direction:column;padding:28px 32px 26px;gap:18px;position:relative;min-width:0}.tut-feature-block>*{position:relative}.tut-feature-eyebrow{display:inline-flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid color-mix(in srgb,var(--background) 30%,transparent);font-family:var(--font-sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-variation-settings:"opsz" 14,"wght" 600;color:color-mix(in srgb,var(--background) 82%,transparent)}.tut-feature-eyebrow-sep{opacity:.45}.tut-feature-title{margin:0;font-family:var(--font-sans);font-size:clamp(30px,3.6vw,48px);font-variation-settings:"opsz" 60,"wght" 780;text-transform:uppercase;letter-spacing:-.035em;line-height:.92;color:var(--background);text-wrap:balance;overflow-wrap:anywhere;-webkit-hyphens:auto;hyphens:auto}.tut-feature-desc{margin:0;max-width:52ch;font-family:var(--font-sans);font-size:15px;line-height:1.55;color:color-mix(in srgb,var(--background) 88%,transparent);text-wrap:pretty;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.tut-feature-stamps{display:flex;flex-wrap:wrap;gap:0;margin-top:auto;padding-top:16px;border-top:1px solid color-mix(in srgb,var(--background) 30%,transparent)}.tut-feature-stamp{display:inline-flex;flex-direction:column;gap:3px;padding:2px 14px;background:transparent;border-left:1px solid color-mix(in srgb,var(--background) 30%,transparent);color:var(--background);font-family:var(--font-mono);line-height:1;text-transform:uppercase}.tut-feature-stamp:first-child{padding-left:0;border-left:0}.tut-feature-stamp-label{font-size:9px;letter-spacing:.2em;color:color-mix(in srgb,var(--background) 75%,transparent)}.tut-feature-stamp-value{font-size:12px;letter-spacing:.04em;font-variation-settings:"wght" 600;font-variant-numeric:tabular-nums;color:var(--background);display:inline-flex;align-items:center;gap:6px}.tut-feature-footer{display:flex;align-items:stretch;justify-content:space-between;gap:12px;margin-top:auto}.tut-feature-framework-punch{display:inline-flex;align-items:center;justify-content:center;aspect-ratio:1;background:var(--background);color:var(--accent);flex:0 0 auto}.tut-feature-cta.btn-caps-stripe.btn-caps-stripe-primary{--foreground: var(--background);margin-top:4px;padding:12px 18px;gap:8px;color:var(--background);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-variation-settings:"wght" 600}.tut-feature-cta.btn-caps-stripe-primary:hover{color:var(--accent)}.tut-feature-cta-arrow{display:inline-flex;align-items:center;justify-content:center;color:inherit;font-size:13px}.tut-feature:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media(max-width:900px){.tut-feature{grid-template-columns:1fr}.tut-feature-block{padding:24px 22px 22px}}@media(max-width:480px){.tut-feature-block{padding:20px 18px;gap:14px}.tut-feature-media-rail{display:none}}.tut-partner{--tut-partner-accent: #facc15;display:block;padding:0;border:1.5px solid var(--border);text-decoration:none;color:inherit;position:relative}.tut-partner:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.tut-partner-inner{display:grid;grid-template-columns:220px minmax(0,1fr);grid-template-areas:"brand body" "brand cta";border:0;padding:0;gap:0;background:var(--background)}.tut-partner-brand{grid-area:brand;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 22px 20px;background:var(--tut-partner-accent);background-image:repeating-linear-gradient(-45deg,color-mix(in srgb,#111 6%,transparent) 0 1.5px,transparent 1.5px 12px);color:#111;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;line-height:1;font-variation-settings:"wght" 560;min-height:100%;position:relative}.tut-partner-brand-tile{width:64px;height:64px;display:inline-flex;align-items:center;justify-content:center;background:#111;color:var(--tut-partner-accent);font-family:var(--font-sans);font-size:44px;line-height:1;font-variation-settings:"opsz" 60,"wght" 720;letter-spacing:-.04em}.tut-partner-brand-name{font-size:13px;color:#111;font-variation-settings:"wght" 600;letter-spacing:.04em;overflow-wrap:anywhere;min-width:0}.tut-partner-body{grid-area:body;display:flex;flex-direction:column;gap:10px;min-width:0;padding:22px 26px 14px}.tut-partner-kicker{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--foreground-feint);font-variation-settings:"wght" 560;line-height:1}.tut-partner-kicker-prefix{color:var(--tut-partner-accent);font-variation-settings:"wght" 640}.tut-partner-title{margin:0;font-family:var(--font-sans);font-size:clamp(18px,1.6vw,22px);font-variation-settings:"opsz" 40,"wght" 640;letter-spacing:-.015em;line-height:1.2;color:var(--foreground);text-wrap:balance;overflow-wrap:anywhere}.tut-partner-desc{margin:0;max-width:58ch;font-family:var(--font-sans);font-size:13px;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5;color:var(--foreground-feint)}.tut-partner-cta-wrap{grid-area:cta;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;flex:0 0 auto;padding:14px 26px 18px;border-top:1px dashed color-mix(in srgb,var(--foreground-feint) 40%,transparent)}.tut-partner-stamp{display:inline-flex;flex-direction:row;align-items:baseline;gap:10px;font-family:var(--font-mono);line-height:1;text-align:left;min-width:0;max-width:100%;overflow-wrap:anywhere}.tut-partner-stamp-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--foreground-feint);font-variation-settings:"wght" 560}.tut-partner-stamp-value{font-family:var(--font-sans);font-size:13px;font-variation-settings:"opsz" 14,"wght" 600;letter-spacing:0;color:var(--foreground)}.tut-partner-cta{display:inline-flex;align-items:center;gap:8px;padding:8px 14px 9px;border:1.5px solid var(--foreground);background:var(--foreground);color:var(--background);font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-variation-settings:"wght" 600;line-height:1;transition:background .12s ease,color .12s ease}.tut-partner:hover .tut-partner-cta{background:var(--tut-partner-accent);border-color:var(--tut-partner-accent);color:#111}.tut-partner-cta-arrow{display:inline-flex;align-items:center;justify-content:center;line-height:1}.tut-partner-cta-arrow svg{width:12px;height:12px}@media(max-width:900px){.tut-partner-inner{grid-template-columns:minmax(0,1fr);grid-template-areas:"brand" "body" "cta"}.tut-partner-brand{flex-direction:row;align-items:center;min-height:0;padding:16px 20px}.tut-partner-brand-tile{width:44px;height:44px;font-size:28px;font-variation-settings:"opsz" 40,"wght" 720}.tut-partner-body{padding:18px 22px 6px}.tut-partner-cta-wrap{padding:12px 22px 16px}}@media(max-width:560px){.tut-partner-cta-wrap{flex-wrap:wrap;gap:12px}}.tut-hub-controls{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.tut-filters{display:flex;flex-wrap:wrap;align-items:stretch;gap:22px;border-bottom:1px solid var(--border)}.tut-filter{position:relative;display:inline-flex;align-items:center;gap:8px;padding:4px 0 10px;border:0;background:transparent;color:var(--foreground-feint);font-family:var(--font-sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-variation-settings:"opsz" 14,"wght" 600;text-decoration:none;line-height:1}.tut-filter:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1.5px;background:transparent}.tut-filter:hover,.tut-filter[aria-current=page]{color:var(--foreground)}.tut-filter[aria-current=page]:after{background:var(--foreground)}.tut-filter-icon{flex:none;display:block}.tut-search{position:relative;display:flex;align-items:center;flex:0 1 360px;border:1.5px solid var(--border);background:var(--layer)}.tut-search:focus-within{border-color:var(--accent)}.tut-search-prompt{flex:0 0 auto;padding:0 10px 0 12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-variation-settings:"wght" 600;-webkit-user-select:none;user-select:none;pointer-events:none}.tut-search-label{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0;white-space:nowrap}.tut-search-input{flex:1;min-width:0;padding:10px 10px 10px 0;border:0;outline:0;background:transparent;color:var(--foreground);font-family:var(--font-sans);font-size:13px;line-height:1.2}.tut-search-input::placeholder{color:var(--foreground-feint)}.tut-search-input::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.tut-search-shortcut{flex:0 0 auto;margin-right:8px;padding:2px 6px 3px;border:1px solid var(--border);background:var(--background);color:var(--foreground-feint);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;line-height:1}.tut-search:focus-within .tut-search-shortcut,.tut-search:not(:has(.tut-search-input:placeholder-shown)) .tut-search-shortcut{display:none}.tut-search-count{flex:0 0 auto;padding:0 12px 0 10px;margin-left:2px;border-left:1.5px solid var(--border);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground);font-variant-numeric:tabular-nums}.tut-list{display:flex;flex-direction:column;padding:0;list-style:none;border-top:1px solid var(--border)}.tut-chapter{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:26px 0 10px;border-bottom:1px solid var(--border)}.tut-chapter-stamp{display:inline-flex;align-items:baseline;gap:10px;padding:6px 12px 8px;background:var(--accent);color:var(--background);font-family:var(--font-sans);text-transform:uppercase;line-height:1}.tut-chapter-stamp-num{font-family:var(--font-sans);font-size:20px;font-variation-settings:"opsz" 32,"wght" 720;letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--background)}.tut-chapter-stamp-label{font-size:11px;letter-spacing:.2em;font-variation-settings:"opsz" 14,"wght" 600;color:var(--background)}.tut-chapter-rule{height:1px;background:color-mix(in srgb,var(--accent) 40%,transparent)}.tut-row{position:relative;display:grid;grid-template-columns:72px minmax(0,1fr) auto auto;align-items:center;gap:18px;padding:12px 14px;color:var(--foreground);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent);min-height:76px;transition:background .14s ease}.tut-row:before{display:none}.tut-row:hover{background:color-mix(in srgb,var(--foreground) 3%,transparent)}.tut-row-index{font-family:var(--font-sans);font-size:40px;font-variation-settings:"opsz" 48,"wght" 560;letter-spacing:-.02em;line-height:.9;color:var(--foreground-feint);font-variant-numeric:tabular-nums;text-align:left;padding-left:8px}.tut-row:hover .tut-row-index{color:var(--accent)}.tut-row-thumb-wrap{position:relative;width:72px;height:54px;flex:0 0 auto}.tut-row-thumb{display:block;width:100%;height:100%;object-fit:cover;background:var(--layer);border:1.5px solid var(--border)}.tut-row-thumb--placeholder{display:block;width:100%;height:100%;background-color:color-mix(in srgb,var(--foreground) 6%,transparent);border:1px solid var(--border)}.tut-row-thumb-badge{position:absolute;top:4px;left:4px;right:auto;bottom:auto;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--background) 85%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:0px solid var(--accent);color:var(--foreground);font-size:9px}.tut-row-body{display:flex;flex-direction:column;gap:5px;min-width:0}.tut-row-title{margin:0;font-family:var(--font-sans);font-size:15px;line-height:1.25;font-variation-settings:"opsz" 20,"wght" 540;letter-spacing:-.005em;color:var(--foreground);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-wrap:pretty;overflow-wrap:anywhere}.tut-row-meta{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;font-family:var(--font-sans);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-variation-settings:"opsz" 14,"wght" 560;color:var(--foreground-feint);line-height:1}.tut-row-meta-fw{color:var(--foreground)}.tut-row-meta-sep{opacity:.4}.tut-row-gauge{justify-self:end;display:inline-flex;align-items:center;padding:0;border:none;background:transparent}.tut-row-gauge-track{display:inline-flex;align-items:stretch;gap:3px;height:6px}.tut-row-gauge-cell{width:6px;background:color-mix(in srgb,var(--foreground) 14%,transparent);display:inline-block}.tut-row-gauge-cell.is-on{background:var(--foreground)}.tut-row-plus{justify-self:end;display:inline-flex;align-items:center;padding:4px 8px 5px;background:#8df0cc;color:#0a1410;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-variation-settings:"wght" 600;line-height:1;white-space:nowrap}.tut-row-arrow{justify-self:end;color:var(--foreground-feint);font-size:16px;line-height:1;transition:transform .16s ease,color .12s ease}.tut-row:hover .tut-row-arrow{color:var(--accent);transform:translate(3px)}.tut-row--featured{grid-template-columns:120px minmax(0,1fr) auto auto;background:transparent;border-bottom:0;min-height:96px;margin:8px 0;padding:20px 22px;isolation:isolate}.tut-row--featured:before{display:block;content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--accent) 28%,transparent) 0 1.5px,transparent 1.5px 9px);z-index:-2;pointer-events:none}.tut-row--featured:after{display:block;content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;background:var(--background);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);z-index:-1;transition:border-color .16s ease;pointer-events:none}.tut-row--featured:hover{background:transparent}.tut-row--featured:hover:after{border-color:var(--accent)}.tut-row--featured .tut-row-thumb-wrap{width:120px;height:84px}.tut-row--featured .tut-row-title{font-size:19px;font-variation-settings:"opsz" 30,"wght" 640;letter-spacing:-.012em}.tut-row-featured-stamp{position:absolute;top:8px;right:24px;transform:translateY(-50%);display:inline-flex;align-items:baseline;gap:6px;padding:3px 9px 4px;background:var(--background);color:var(--accent);border:1px solid var(--accent);font-family:var(--font-sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-variation-settings:"opsz" 14,"wght" 680;line-height:1;pointer-events:none}.tut-row-featured-stamp-num{font-family:var(--font-sans);font-size:11px;font-variation-settings:"wght" 720;font-variant-numeric:tabular-nums;color:var(--accent)}.tut-empty{display:flex;flex-direction:column;gap:10px;padding:54px 12px 56px;border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);background-image:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--accent) 8%,transparent) 0 1.5px,transparent 1.5px 12px)}.tut-empty-stamp{align-self:flex-start;display:inline-flex;align-items:baseline;gap:10px;padding:6px 12px 8px;background:var(--background);border:1.5px solid var(--accent);font-family:var(--font-sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-variation-settings:"opsz" 14,"wght" 680;color:var(--accent);line-height:1}.tut-empty-title{margin:6px 0 0;font-family:var(--font-sans);font-size:clamp(28px,4vw,40px);font-variation-settings:"opsz" 48,"wght" 720;text-transform:uppercase;letter-spacing:-.03em;line-height:.92;color:var(--foreground);text-wrap:balance}.tut-empty-desc{margin:0;max-width:56ch;font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--foreground-feint);text-wrap:pretty;overflow-wrap:anywhere}.tut-empty-actions{display:flex;flex-wrap:wrap;gap:8px 20px;margin-top:10px}.tut-empty-action{display:inline-flex;align-items:center;gap:8px;padding:0;border:0;background:transparent;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-variation-settings:"wght" 600;color:var(--foreground);text-decoration:none;line-height:1;cursor:pointer;transition:color .12s ease}.tut-empty-action:hover,.tut-empty-action:focus-visible{color:var(--accent)}.tut-empty-action:focus-visible{outline:2px solid var(--accent);outline-offset:4px}.tut-empty-action-prefix{color:var(--accent);font-variation-settings:"wght" 640}@media(max-width:900px){.tut-row{grid-template-columns:72px minmax(0,1fr) auto;gap:16px;min-height:80px}.tut-row-thumb-wrap{width:72px;height:56px}.tut-row-gauge{display:none}.tut-row--featured{grid-template-columns:96px minmax(0,1fr) auto;padding:18px}.tut-row--featured .tut-row-thumb-wrap{width:96px;height:72px}}@media(max-width:600px){.tut-hub{padding:20px 0 72px;gap:24px}.tut-hub-band{padding:18px 0 0}.tut-hub-band--spec .tut-hub-band-desc{margin-top:18px;font-size:14px;line-height:1.45}.tut-band-spec-rail{gap:4px 8px;font-size:9px;letter-spacing:.18em}.tut-band-spec-rail-cross{font-size:12px}.tut-band-spec-rail-ver{font-size:9px}.tut-row{grid-template-columns:60px minmax(0,1fr) auto;gap:12px;padding:12px;min-height:72px}.tut-row-thumb-wrap{width:60px;height:48px}.tut-row-thumb-badge{width:18px;height:18px;right:-4px;bottom:-4px}.tut-row-title{font-size:15px}.tut-row-meta{font-size:10px;letter-spacing:.12em}.tut-row-featured-stamp{right:28px;font-size:9px}.tut-row--featured{grid-template-columns:84px minmax(0,1fr) auto;min-height:84px;padding:16px 14px}.tut-row--featured .tut-row-thumb-wrap{width:84px;height:64px}.tut-row--featured .tut-row-title{font-size:16px}}.tut-callout{width:100%;margin:40px 0;padding:22px 24px;display:flex;flex-direction:column;align-items:flex-start;gap:16px;border:1px solid var(--border);background:var(--layer)}.tut-callout-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground-feint);white-space:nowrap}.tut-callout-kicker-caret{color:var(--accent);font-variation-settings:"wght" 560}.tut-callout-text{margin:0;font-size:15px;line-height:1.55;color:var(--foreground)}@media(max-width:600px){.tut-callout{padding:18px 20px;gap:14px}}.tut-gate-fade{position:relative;height:220px;margin-top:-220px;margin-bottom:8px;pointer-events:none;z-index:2;background:linear-gradient(to bottom,color-mix(in srgb,var(--background) 0%,transparent) 0%,color-mix(in srgb,var(--background) 50%,transparent) 45%,color-mix(in srgb,var(--background) 90%,transparent) 75%,var(--background) 100%)}.tut-gate{width:100%;max-width:680px;margin:0 0 40px;padding:14px;background-image:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--foreground) 10%,transparent) 0px,color-mix(in srgb,var(--foreground) 10%,transparent) 1.5px,transparent 1.5px,transparent 8px);position:relative;isolation:isolate}.tut-gate-inner{background:var(--background);padding:32px 36px;display:flex;flex-direction:column;gap:16px;min-width:0}.tut-gate-kicker{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground-feint)}.tut-gate-kicker-caret{color:var(--accent);font-variation-settings:"wght" 560}.tut-gate-title{margin:0;font-family:var(--font-sans);font-size:clamp(24px,3vw,32px);font-variation-settings:"opsz" 48,"wght" 680;letter-spacing:-.025em;line-height:1.08;color:var(--foreground)}.tut-gate-desc{margin:0;max-width:520px;font-size:15px;line-height:1.55;color:var(--foreground-feint)}.tut-gate-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px;line-height:1.5;color:var(--foreground)}.tut-gate-list li{position:relative;padding-left:18px}.tut-gate-list li:before{content:">";position:absolute;left:0;top:0;color:var(--accent);font-family:var(--font-mono);font-variation-settings:"wght" 560}.tut-gate-cta{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:4px}.tut-gate-link{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground-feint);text-decoration:none}.tut-gate-link:hover{color:var(--foreground)}@media(max-width:600px){.tut-gate{padding:10px}.tut-gate-inner{padding:24px 22px}}.tut-gate-steps{margin:4px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;border-top:1px solid var(--border)}.tut-gate-step{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:10px 2px;border-bottom:1px solid var(--border);font-size:14px;color:var(--foreground)}.tut-gate-step-index{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--foreground-feint)}.tut-gate-step-title{color:var(--foreground)}.tut-gate-step-lock{color:var(--accent);font-size:10px;line-height:1}.docs--tutorial{--tut-hero-max: 1200px;max-width:var(--tut-hero-max);margin:0 auto}.docs--tutorial .tut-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:14px;width:100%;max-width:var(--tut-hero-max);margin:0 auto;padding:0;background:transparent;border:0;text-decoration:none;color:inherit;transform:none;transition:none}.docs--tutorial .tut-hero--stacked{grid-template-columns:minmax(0,1fr);gap:28px}.docs--tutorial .tut-hero--stacked .tut-hero-dossier{max-width:var(--max-width);margin:0}.docs--tutorial .tut-hero--stacked .tut-hero-desc{max-width:68ch}.docs--tutorial .tut-hero--stacked .tut-example-surface{min-height:480px}.docs--tutorial .tut-hero:hover{transform:none}.tut-hero-dossier{padding:0;background-image:none;position:relative;isolation:isolate;min-width:0}.tut-hero-dossier-inner{background:transparent;padding:4px 0 0;display:flex;flex-direction:column;gap:20px;min-width:0;height:100%;position:relative}.docs--tutorial .tut-hero-rail{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px dashed color-mix(in srgb,var(--foreground-feint) 40%,transparent);font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--foreground-feint);line-height:1}.tut-hero-rail-cross{color:var(--accent);font-family:var(--font-sans);font-size:13px;font-variation-settings:"wght" 640;line-height:1}.tut-hero-rail-rule{height:1px;flex:1 1 auto;min-width:20px;background:color-mix(in srgb,var(--foreground-feint) 35%,transparent)}.tut-hero-rail-sep{color:color-mix(in srgb,var(--foreground-feint) 45%,transparent)}.tut-hero-rail-link{color:var(--foreground-feint);text-decoration:none}.tut-hero-rail-link:hover,.tut-hero-rail-category{color:var(--foreground)}.tut-hero-rail-ver{color:var(--accent);font-family:var(--font-sans);font-variation-settings:"opsz" 14,"wght" 620;font-size:10px;letter-spacing:.04em;font-variant-numeric:tabular-nums;text-transform:none}.docs--tutorial .tut-hero-title{position:relative;margin:0;font-family:var(--font-sans);font-size:clamp(44px,6vw,78px);font-variation-settings:"opsz" 60,"wght" 720;letter-spacing:-.045em;line-height:.9;color:var(--foreground);padding-top:40px;padding-bottom:15px;border-bottom:3px solid var(--accent);text-wrap:balance}.docs--tutorial .tut-hero-title:after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:6px;background:repeating-linear-gradient(-45deg,color-mix(in srgb,var(--accent) 30%,transparent) 0 2px,transparent 2px 8px);pointer-events:none}.docs--tutorial .tut-hero-desc{margin:0;max-width:58ch;font-size:15px;line-height:1.5;color:var(--foreground-feint);text-wrap:balance}.tut-meta{display:flex;flex-wrap:wrap;gap:0;margin:4px 0 0;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.tut-meta-item{display:flex;flex-direction:column;gap:6px;padding:0 18px;border-right:1px solid var(--border);min-width:0}.tut-meta-item:first-child{padding-left:0}.tut-meta-item:last-child{border-right:0;padding-right:0}.tut-meta-label{margin:0;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 70%,var(--foreground-feint))}.tut-meta-value{margin:0;font-family:var(--font-mono);font-size:13px;color:var(--foreground);display:inline-flex;align-items:center;gap:8px}.tut-meta-difficulty .tut-meta-value{gap:10px}.tut-difficulty-dots{display:inline-flex;align-items:center;gap:4px}.tut-difficulty-dot{width:6px;height:6px;border:1px solid color-mix(in srgb,var(--foreground) 30%,transparent);background:transparent}.tut-difficulty-dot.is-filled{background:var(--accent);border-color:var(--accent)}.tut-difficulty-label{color:var(--foreground)}.tut-plus-badge{display:inline-flex;align-items:center;padding:3px 8px;background:#8df0cc;color:#0a1410;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-variation-settings:"wght" 600}.tut-hero-byline{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:4px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--foreground-feint)}.tut-byline-author{display:inline-flex;align-items:center;gap:8px;color:var(--foreground)}.tut-byline-author a{color:inherit;text-decoration:none}.tut-byline-author a:hover{color:var(--accent)}.tut-byline-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;display:block}.tut-byline-date{color:var(--foreground-feint)}.tut-example{margin:0;padding:0;display:flex;min-width:0}.tut-example-frame{width:100%;padding:0;background-image:none;position:relative;isolation:isolate;aspect-ratio:auto;border:0;background-color:transparent;overflow:visible;display:flex}.tut-example-frame-inner{display:flex;flex-direction:column;width:100%;background:var(--background);min-width:0;border:1px solid var(--border);position:relative}.tut-example-frame-inner:before{content:"";position:absolute;top:0;left:0;width:32px;height:1px;background:var(--accent)}.tut-example-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 14px;border-bottom:1px solid var(--border)}.tut-example-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground-feint)}.tut-example-eyebrow-caret{color:var(--accent);font-variation-settings:"wght" 560}.tut-example-open{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--foreground-feint);text-decoration:none}.tut-example-open:hover{color:var(--foreground)}.tut-example-open-arrow{display:inline-block}.tut-example-open-arrow-shaft{transition:transform .16s ease}.tut-example-open:hover .tut-example-open-arrow-shaft{transform:translate(2px,-2px)}.tut-example-surface{position:relative;flex:1;min-height:360px;background:var(--layer)}.tut-example-surface iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;display:block}.tut-article-layout{margin-top:48px;padding:0}.tut-sidebar{position:sticky;top:88px;align-self:start}.tut-easing-dock{width:200px;flex-shrink:0;position:sticky;bottom:24px;align-self:flex-end}.tut-content{max-width:720px;min-width:0}.tut-content>:first-child{margin-top:0}.tut-content h2{font-family:var(--font-sans);font-size:24px;font-variation-settings:"opsz" 40,"wght" 680;letter-spacing:-.02em;margin:48px 0 16px;scroll-margin-top:96px}.tut-content h3{font-family:var(--font-sans);font-size:18px;font-variation-settings:"opsz" 32,"wght" 640;margin:32px 0 12px}.tut-content p{font-size:15px;line-height:1.65;margin:0 0 16px;color:var(--foreground-feint)}.tut-related{margin:72px auto 0;padding:40px 24px 80px;max-width:var(--tut-hero-max)}@media(max-width:960px){.docs--tutorial .tut-hero{grid-template-columns:minmax(0,1fr)}.tut-hero-dossier{min-width:0}.tut-example-surface{min-height:280px}.docs--tutorial .tut-hero--stacked .tut-example-surface{min-height:320px}.tut-easing-dock{display:none}}@media(max-width:600px){.docs--tutorial .tut-hero{padding:0 16px}.tut-hero-dossier-inner{padding:22px 20px}.tut-meta{gap:14px 0}.tut-meta-item{padding:0 14px}.tut-article-layout{padding:0 16px}.tut-related{padding:0 16px 60px}}.tut-plus-feature-wrap{margin-top:40px;--accent: #8df0cc}.tut-plus-feature-wrap .tut-feature-media video{display:block;width:100%;height:100%;object-fit:cover;background:var(--layer);transition:transform .4s cubic-bezier(.2,.8,.2,1)}.tut-plus-feature-wrap .tut-feature:hover .tut-feature-media video{transform:scale(1.03)}.tut-plus-feature-wrap .tut-feature-footer{justify-content:flex-end}
