:root{--bg: #ffffff;--bg-band: #fbfbfd;--surface: #ffffff;--rule: #e4e4ea;--rule-soft: #eeeef2;--text: #1d1d1f;--text-2: #4b4b51;--text-3: #86868b;--accent: #0066cc;--brand: #f0552f;--code-bg: #f5f5f7;--code-text: #1d1d1f;--ok: #1d7a3e;--ok-bg: #e9f6ee;--new: #1d7a3e;--new-bg: #e9f6ee;--pill-bg: #f0f0f3;--pill-text: #6e6e73;--shadow: 0 1px 2px rgba(0,0,0,.04), 0 8px 24px -16px rgba(0,0,0,.18);--tok-key: #ad3da4;--tok-type: #0b6e8f;--tok-num: #2d54c8;--tok-str: #c3221b;--tok-com: #8a8a8e;--tok-meta: #6f5cd6;--max: 1120px;--font-text: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono: "SF Mono", ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, Consolas, monospace}@media(prefers-color-scheme:dark){:root{--bg: #161617;--bg-band: #1c1c1e;--surface: #1f1f21;--rule: #303034;--rule-soft: #28282b;--text: #f5f5f7;--text-2: #c3c3c8;--text-3: #8d8d93;--accent: #4aa3ff;--brand: #ff6a45;--code-bg: #111113;--code-text: #e9e9ee;--ok: #46d36a;--ok-bg: rgba(48,209,88,.14);--new: #46d36a;--new-bg: rgba(48,209,88,.14);--pill-bg: #2a2a2e;--pill-text: #adadb4;--shadow: 0 1px 2px rgba(0,0,0,.4), 0 10px 30px -18px rgba(0,0,0,.8);--tok-key: #ff7ab2;--tok-type: #6bdbff;--tok-num: #b3c2ff;--tok-str: #ff8170;--tok-com: #7e7e85;--tok-meta: #b497ff}}*{box-sizing:border-box}html{scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-text);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--accent)}.wn-nav{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 82%,transparent);-webkit-backdrop-filter:saturate(1.6) blur(14px);backdrop-filter:saturate(1.6) blur(14px);border-bottom:1px solid var(--rule)}.wn-nav-inner{max-width:var(--max);margin:0 auto;padding:0 32px;height:52px;display:flex;align-items:center;gap:22px}.wn-brand{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:16px;color:var(--text);text-decoration:none;letter-spacing:-.01em}.wn-brand img{width:20px;height:20px}.wn-brand span{color:var(--brand)}.wn-nav-links{display:flex;gap:18px;margin-left:6px}.wn-nav-links a{font-size:14px;color:var(--text-2);text-decoration:none}.wn-nav-links a:hover{color:var(--text)}.wn-nav-links a.is-active{color:var(--text);font-weight:600}.wn-cta{margin-left:auto;font-size:13.5px;font-weight:600;color:#fff;background:var(--brand);padding:8px 15px;border-radius:980px;text-decoration:none;white-space:nowrap}.wn-cta:hover{filter:brightness(1.06)}@media(max-width:720px){.wn-nav-links{display:none}.wn-nav-inner{padding:0 18px}}.band{border-bottom:1px solid var(--rule);background:var(--bg-band)}.band-inner{max-width:var(--max);margin:0 auto;padding:52px 32px 40px}.crumb{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);margin:0 0 22px}.crumb a{color:var(--text-3);text-decoration:none}.crumb a:hover{color:var(--accent)}.crumb span{opacity:.5;margin:0 .55em}h1{font-size:clamp(32px,5.4vw,52px);line-height:1.05;font-weight:700;letter-spacing:-.022em;margin:0}h1 .accent{color:var(--accent)}.counts{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 0}.count{display:inline-flex;align-items:baseline;gap:7px;font-size:13px;font-weight:600;padding:6px 13px;border-radius:980px;color:var(--text-2);background:var(--pill-bg)}.count b{font-size:15px;font-variant-numeric:tabular-nums;color:var(--text)}.lede{max-width:760px;margin:30px 0 0}.lede p{margin:0 0 16px;color:var(--text-2);font-size:18px;line-height:1.55}.lede p:first-child{color:var(--text)}.lede p:last-child{margin-bottom:0}.lede code{font-size:.9em;padding:1px 5px;border-radius:5px;background:var(--code-bg);color:var(--code-text)}.sectionwrap{max-width:var(--max);margin:0 auto;padding:0 32px 60px}@media(max-width:920px){.sectionwrap{padding:0 22px 48px}.band-inner{padding:40px 22px 30px}}.tools{position:sticky;top:52px;z-index:9;background:color-mix(in srgb,var(--bg) 90%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--rule)}.tools-inner{max-width:var(--max);margin:0 auto;padding:12px 32px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}.search{flex:1 1 280px;position:relative;min-width:0}.search input{width:100%;font:inherit;font-size:15px;padding:9px 14px 9px 38px;border:1px solid var(--rule);border-radius:10px;background:var(--surface);color:var(--text)}.search input:focus{outline:none;border-color:var(--accent)}.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-3);pointer-events:none}.pfilter{display:flex;gap:6px;flex-wrap:wrap}.pf{font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:980px;border:1px solid var(--rule);background:var(--surface);color:var(--text-2);cursor:pointer;user-select:none}.pf:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--rule))}.pf.is-on{background:var(--accent);border-color:var(--accent);color:#fff}.empty{display:none;padding:40px 0;text-align:center;color:var(--text-3);font-size:15px}@media(max-width:920px){.tools-inner{padding:12px 22px}}.area{margin:40px 0 0;scroll-margin-top:120px}.area-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;border-bottom:1px solid var(--rule);padding-bottom:12px;margin-bottom:18px}.area-name{font-size:23px;font-weight:700;letter-spacing:-.018em;margin:0}.area-name a{color:inherit;text-decoration:none}.area-name a:hover{color:var(--accent)}.area-n{font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--text-3);background:var(--pill-bg);padding:3px 9px;border-radius:980px}.area-intro{flex:1 1 100%;font-size:15px;line-height:1.55;color:var(--text-2);margin:6px 0 0;max-width:820px}.fw-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:12px}.fw-card{display:flex;flex-direction:column;gap:9px;background:var(--surface);border:1px solid var(--rule);border-radius:13px;padding:15px 16px;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:transform .14s ease,border-color .14s ease}.fw-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 45%,var(--rule))}.fw-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.fw-name{font-size:15.5px;font-weight:650;color:var(--text);letter-spacing:-.01em;word-break:break-word}.fw-name .ov{color:var(--text-3);font-weight:500}.fw-tcount{flex:none;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-3)}.fw-sum{font-size:12.5px;color:var(--text-3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.plats{display:flex;gap:4px;flex-wrap:wrap;margin-top:auto}.pb{font-size:10.5px;font-weight:600;letter-spacing:.01em;padding:2px 7px;border-radius:980px;background:var(--ok-bg);color:var(--ok)}.pb.off{background:var(--pill-bg);color:var(--text-3);opacity:.55}.wrap{max-width:var(--max);margin:0 auto;padding:0 32px 96px;display:grid;grid-template-columns:minmax(0,1fr) 248px;gap:48px}@media(max-width:920px){.wrap{grid-template-columns:1fr;gap:0;padding:0 22px 72px}.aside{display:none}}.availbar{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0 0}.av{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:980px;background:var(--ok-bg);color:var(--ok)}.av.off{background:var(--pill-bg);color:var(--text-3)}.av:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.overview{max-width:760px;margin:30px 0 0}.overview p{font-size:17px;line-height:1.6;color:var(--text-2);margin:0 0 16px}.overview p:first-child{color:var(--text)}.overview code{font-family:var(--font-mono);font-size:.9em;padding:1px 5px;border-radius:5px;background:var(--code-bg)}.topic{margin:40px 0 0}.topic-h{font-size:19px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px;padding-bottom:10px;border-bottom:1px solid var(--rule)}.topic-sum{font-size:14px;line-height:1.55;color:var(--text-2);margin:12px 0 2px;max-width:760px}.topic-note{font-size:15px;line-height:1.6;color:var(--text-2);margin:14px 0 4px;max-width:760px}pre.code{margin:16px 0 4px;padding:16px 18px;background:var(--code-bg);border:1px solid var(--rule);border-radius:12px;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.65;color:var(--code-text)}pre.code code{font:inherit}.hl-k{color:var(--tok-key)}.hl-t{color:var(--tok-type)}.hl-n{color:var(--tok-num)}.hl-s{color:var(--tok-str)}.hl-c{color:var(--tok-com);font-style:italic}.hl-a{color:var(--tok-meta)}.getstarted .topic-h{margin-bottom:2px}.concepts{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:16px}.concept{border:1px solid var(--rule);border-radius:12px;background:var(--surface);padding:15px 16px;box-shadow:var(--shadow)}.concept h3{font-size:15px;font-weight:650;margin:0 0 6px;letter-spacing:-.01em}.concept p{font-size:13.5px;line-height:1.55;color:var(--text-2);margin:0}.concept code{font-family:var(--font-mono);font-size:.88em;padding:1px 5px;border-radius:5px;background:var(--code-bg)}.ex-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:9px 0 0}.ex-run,.ex-open{font:inherit;font-size:12px;font-weight:600;padding:4px 11px;border-radius:8px;cursor:pointer;border:1px solid var(--rule);background:var(--surface);color:var(--accent)}.ex-run:hover,.ex-open:hover{border-color:color-mix(in srgb,var(--accent) 50%,var(--rule));background:color-mix(in srgb,var(--accent) 7%,var(--surface))}.ex-open{color:var(--text-2)}.ex-code{margin-left:2px}.ex-code>summary{cursor:pointer;font-size:12px;font-weight:600;color:var(--text-3);list-style:none}.ex-code>summary::-webkit-details-marker{display:none}.ex-code>summary:before{content:"{ } ";font-family:var(--font-mono)}.ex-code[open]>summary{color:var(--text-2)}.ex-code pre.code{margin:10px 0 0;font-size:12px}.ex-preview{display:flex;justify-content:center;align-items:flex-start;padding:16px;margin:10px 0 2px;border:1px dashed var(--rule);border-radius:12px;background:var(--code-bg);min-height:60px}.ex-preview svg{max-width:230px;height:auto;border-radius:14px;box-shadow:var(--shadow)}.ex-err{font-family:var(--font-mono);font-size:12px;line-height:1.5;color:var(--rem);white-space:pre-wrap}.ex-badge{font-size:11px;font-weight:700;letter-spacing:.01em;padding:2px 8px;border-radius:980px;margin-left:9px;vertical-align:1px}.ex-badge.ok{color:var(--ok);background:var(--ok-bg)}.ex-badge.warn{color:var(--dep, #9a4a00);background:color-mix(in srgb,#ff9f0a 16%,transparent)}.ex-badge.bad{color:var(--rem);background:var(--rem-bg)}.sym-link{color:var(--text);text-decoration:none}.sym-link:hover{color:var(--accent)}.sym-ex-link{display:inline-block;margin-top:7px;font-size:12.5px;font-weight:600;color:var(--accent);text-decoration:none}.sym-ex-link:hover{text-decoration:underline}.ex-kind{font-size:.4em;font-weight:600;letter-spacing:.02em;text-transform:lowercase;color:var(--text-3);background:var(--pill-bg);padding:4px 10px;border-radius:980px;vertical-align:middle}.ex-split{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0 4px;align-items:stretch}@media(max-width:880px){.ex-split{grid-template-columns:1fr}}.ex-pane{display:flex;flex-direction:column;border:1px solid var(--rule);border-radius:14px;overflow:hidden;min-height:480px;background:var(--surface);box-shadow:var(--shadow)}.ex-pane-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--rule);background:var(--bg-band)}.code-dot{width:11px;height:11px;border-radius:50%;flex:none}.code-dot.r{background:#ff5f57}.code-dot.y{background:#febc2e}.code-dot.g{background:#28c840}.ex-file{font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--text-2);margin-left:5px}.ex-edit-hint{font-family:var(--font-mono);font-size:11px;color:var(--text-3);margin-left:auto}.ex-pane-title{font-size:13px;font-weight:600;color:var(--text-2)}.ex-led{width:8px;height:8px;border-radius:50%;background:var(--new-rail);flex:none}.ex-live-status{margin-left:auto;font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}.ex-code-static{flex:1;overflow:auto}.ex-code-static pre.code{margin:0;border:none;border-radius:0;min-height:100%}.ex-code-editor{display:none;flex:1;min-height:430px}.ex-code-editor.on{display:block}.ex-code-editor .monaco-editor,.ex-code-editor .monaco-editor .margin,.ex-code-editor .monaco-editor-background{background:#0f1112!important}.ex-preview-pane .ex-preview{flex:1;position:relative;display:flex;justify-content:center;align-items:center;padding:20px;background:var(--bg-band);cursor:pointer}.ex-preview-pane .ex-preview svg{max-width:250px;width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow);background:var(--surface)}.ex-preview svg,.ex-preview svg *{cursor:inherit;user-select:none;-webkit-user-select:none;pointer-events:none}.ex-preview:not(.is-live):after{content:"\25b6  Run live";position:absolute;bottom:12px;right:14px;font:600 12px/1 var(--font-text);color:#fff;background:#0000009e;padding:6px 12px;border-radius:980px;opacity:0;transition:opacity .14s ease;pointer-events:none}.ex-preview:not(.is-live):hover:after{opacity:1}.ex-preview.is-live{background:#0b0b0c;cursor:default}.ex-preview.is-live canvas{max-width:290px;height:auto!important;border-radius:16px;box-shadow:var(--shadow);cursor:default;pointer-events:auto}.ex-svg.dark{display:none}@media(prefers-color-scheme:dark){.ex-svg.light{display:none}.ex-svg.dark{display:block}}.su-pipe{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}.su-pipe b{color:var(--text-2)}.ex-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:16px 0 0}.ex-tut{margin-top:4px}.ex-tut+.ex-live-section{margin-top:44px;padding-top:36px;border-top:1px solid var(--rule)}.ex-tut-intro{font-size:16px;line-height:1.6;color:var(--text);margin:14px 0 0;max-width:780px}.ex-tut-steps{counter-reset:tut;list-style:none;margin:22px 0 0;padding:0;max-width:820px}.ex-tut-steps li{position:relative;padding:0 0 20px 46px}.ex-tut-steps li:before{counter-increment:tut;content:counter(tut);position:absolute;left:0;top:1px;width:28px;height:28px;border-radius:50%;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center}.ex-tut-steps li:not(:last-child):after{content:"";position:absolute;left:13.5px;top:32px;bottom:4px;width:1px;background:var(--rule)}.ex-tut-steps h4{font-size:15px;font-weight:650;margin:3px 0 4px;letter-spacing:-.01em}.ex-tut-steps p{font-size:14.5px;line-height:1.6;color:var(--text-2);margin:0}.ex-tut-steps code,.ex-tut-intro code,.ex-tut-try code{font-family:var(--font-mono);font-size:.86em;padding:1px 5px;border-radius:5px;background:var(--code-bg);color:var(--code-text)}.ex-tut-try{margin:8px 0 0;padding:14px 16px;border-radius:12px;background:var(--new-bg);color:var(--text-2);font-size:14.5px;line-height:1.55;max-width:820px}.ex-tut-try b{color:var(--new)}.ex-run-live{font:inherit;font-size:14px;font-weight:600;padding:9px 18px;border-radius:10px;border:none;cursor:pointer;background:var(--brand);color:#fff}.ex-run-live:hover{filter:brightness(1.06)}.ex-run-live:disabled{opacity:.6;cursor:default}.ex-live-status{font-size:13px;color:var(--text-3);font-variant-numeric:tabular-nums}.ex-studio{margin-left:auto;font-size:13.5px;font-weight:600;color:var(--accent);text-decoration:none}.ex-studio:hover{text-decoration:underline}.ex-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:36px 0 0;padding-top:18px;border-top:1px solid var(--rule);font-size:14px;font-weight:600}.ex-nav a{color:var(--accent);text-decoration:none;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ex-nav a:hover{text-decoration:underline}.ex-nav-up{color:var(--text-3)!important}.since{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--text-3);background:var(--pill-bg);padding:1px 7px;border-radius:980px;margin-left:9px;vertical-align:1px}.sym-key{display:block;padding:18px 0}.sym-key .sym-name{font-size:16px}.sym-key .sym-kind{float:left;margin:3px 12px 0 0}.sym-detail{font-size:14.5px;line-height:1.6;color:var(--text-2);margin:6px 0 0;max-width:720px}.members{display:flex;flex-wrap:wrap;gap:7px;margin:12px 0 0}.mem{font-family:var(--font-mono);font-size:12px;padding:3px 9px;border-radius:7px;background:var(--code-bg);color:var(--accent);border:1px solid var(--rule)}.sym-key pre.code{margin-top:12px}.symlist{list-style:none;margin:0;padding:0}.sym{display:flex;align-items:baseline;gap:12px;padding:13px 2px;border-bottom:1px solid var(--rule-soft)}.sym:last-child{border-bottom:none}.sym-kind{flex:none;width:26px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-family:var(--font-mono);font-size:10.5px;font-weight:700;background:var(--pill-bg);color:var(--pill-text);margin-top:1px}.sym-kind.cl{color:#8c5cff;background:color-mix(in srgb,#8c5cff 14%,transparent)}.sym-kind.st{color:var(--tok-type);background:color-mix(in srgb,var(--tok-type) 14%,transparent)}.sym-kind.en{color:var(--brand);background:color-mix(in srgb,var(--brand) 14%,transparent)}.sym-kind.pr{color:var(--ok);background:var(--ok-bg)}.sym-kind.ac{color:var(--tok-key);background:color-mix(in srgb,var(--tok-key) 14%,transparent)}.sym-main{min-width:0}.sym-name{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text)}.sym-doc{font-size:13px;color:var(--text-3);line-height:1.5;margin-top:2px}.morewrap{margin-top:14px}.morewrap>summary{cursor:pointer;font-size:13.5px;font-weight:600;color:var(--accent);list-style:none}.morewrap>summary::-webkit-details-marker{display:none}.morewrap>summary:before{content:"+ "}.morewrap[open]>summary:before{content:"\2212  "}.taglist{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0 0}.tag{font-family:var(--font-mono);font-size:12px;padding:4px 9px;border-radius:7px;background:var(--code-bg);color:var(--text-2)}.aside{position:sticky;top:76px;align-self:start;font-size:13.5px}.aside h3{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);margin:0 0 10px}.aside .box{border:1px solid var(--rule);border-radius:12px;background:var(--surface);padding:16px;margin-bottom:14px}.aside dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:8px 12px}.aside dt{color:var(--text-3)}.aside dd{margin:0;text-align:right;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.aside .wnlink{display:block;text-align:center;font-weight:600;text-decoration:none;padding:11px;border-radius:10px;background:var(--new-bg);color:var(--new)}.aside .wnlink:hover{filter:brightness(1.04)}.backlink{display:inline-block;margin:24px 0 0;font-size:14px;font-weight:600;text-decoration:none}footer{max-width:var(--max);margin:0 auto;padding:28px 32px 64px;border-top:1px solid var(--rule);color:var(--text-3);font-size:13px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}footer a{color:var(--text-2);text-decoration:none}footer a:hover{color:var(--text)}footer .sep{opacity:.5}.su-showcase-container{--bg: #0c0b0b;--surface: #131211;--surface2: #191816;--surface3: #201e1c;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--border-faint: rgba(255, 255, 255, .04);--amber: #f0552f;--amber-hi: #ff6f4d;--amber-dim: #c2461f;--t1: #ededf0;--t2: #a4a09a;--t3: #6f6a64;--t4: #4d4945;--green: #4cc77d;--blue: #4aa3e8;--purple: #b08af0;--red: #e5574a;--dot-r: #f25f57;--dot-y: #f7bd2e;--dot-g: #5fc451;--mono: "JetBrains Mono", "SF Mono", "Menlo", monospace;--sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", "Segoe UI", sans-serif;--r: 12px;--ease: cubic-bezier(.32, .72, .24, 1);--shadow-card: inset 0 1px 0 rgba(255, 255, 255, .03), 0 14px 36px -24px rgba(0, 0, 0, .7);--shadow-pop: inset 0 1px 0 rgba(255, 255, 255, .04), 0 24px 70px -30px rgba(0, 0, 0, .7);margin:28px 0;color:var(--t1);font-family:var(--sans)}.su-showcase-container .su-tabs{display:flex;justify-content:flex-start;flex-wrap:wrap;gap:8px;margin-bottom:22px}.su-showcase-container .su-tab{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 16px;border-radius:9px;background:var(--surface);border:1px solid var(--border);color:var(--t2);font-family:inherit;cursor:pointer;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease),transform .15s var(--ease),box-shadow .15s var(--ease);text-align:left}.su-showcase-container .su-tab:hover{border-color:var(--border-strong);color:var(--t1);transform:translateY(-1px)}.su-showcase-container .su-tab:active{transform:translateY(0)}.su-showcase-container .su-tab.is-active{background:var(--surface3);border-color:color-mix(in srgb,var(--amber) 40%,transparent);color:var(--t1);box-shadow:0 0 0 3px color-mix(in srgb,var(--amber) 8%,transparent)}.su-showcase-container .su-tab-name{font-size:13px;font-weight:600;letter-spacing:-.01em}.su-showcase-container .su-tab-meta{font-size:10.5px;color:var(--t3);font-family:var(--mono);text-transform:lowercase;letter-spacing:.02em}.su-showcase-container .su-tab.is-active .su-tab-meta{color:var(--amber)}.su-showcase-container .su-stage-wrap{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);gap:18px;align-items:stretch}@media(max-width:768px){.su-showcase-container .su-stage-wrap{grid-template-columns:1fr}}.su-showcase-container .su-code-panel,.su-showcase-container .su-preview-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-card)}.su-showcase-container .su-code-head{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface2);border-bottom:1px solid var(--border)}.su-showcase-container .su-code-head .code-dot{width:10px;height:10px;border-radius:50%}.su-showcase-container .su-code-head .code-dot.r{background:var(--dot-r)}.su-showcase-container .su-code-head .code-dot.y{background:var(--dot-y)}.su-showcase-container .su-code-head .code-dot.g{background:var(--dot-g)}.su-showcase-container .su-code-file{margin-left:8px;font-family:var(--mono);font-size:12px;color:var(--t1);font-weight:500}.su-showcase-container .su-code-edit-hint{margin-left:10px;display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:10px;font-family:var(--mono);font-size:9.5px;color:var(--amber);background:var(--surface3);border:1px solid color-mix(in srgb,var(--amber) 28%,transparent);text-transform:uppercase;letter-spacing:.08em}.su-showcase-container .su-code-edit-hint:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--amber)}.su-showcase-container .su-code-tag{margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.08em}.su-showcase-container .su-code-editor{flex:1;min-height:380px;max-height:520px;background:var(--surface)}.su-showcase-container .su-code-editor .monaco-editor,.su-showcase-container .su-code-editor .monaco-editor-background,.su-showcase-container .su-code-editor .margin{background:var(--surface)!important}.su-showcase-container .su-code-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 16px;background:var(--surface2);border-top:1px solid var(--border);font-family:var(--mono);font-size:10.5px;color:var(--t3);letter-spacing:.04em}.su-showcase-container .su-pipe b{color:var(--amber);font-weight:600}.su-showcase-container .su-code-status{font-family:var(--mono);font-size:10px;letter-spacing:.04em;transition:color .2s var(--ease)}.su-showcase-container .su-code-status[data-state=ok]{color:var(--green)}.su-showcase-container .su-code-status[data-state=err]{color:var(--red)}.su-showcase-container .su-code-status[data-state=busy]{color:var(--amber)}.su-showcase-container .su-preview-head{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--surface2);border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;color:var(--t2)}.su-showcase-container .su-led{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px color-mix(in srgb,var(--green) 50%,transparent);animation:su-pulse 2.6s ease-in-out infinite}@keyframes su-pulse{0%,to{opacity:.45}50%{opacity:1}}.su-showcase-container .su-preview-label{font-weight:600;color:var(--t1)}.su-showcase-container .su-preview-hint{margin-left:auto;color:var(--t3);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em}.su-showcase-container .su-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg);min-height:380px}.su-showcase-container .su-stage canvas{max-width:100%;height:auto}.su-showcase-container .su-stage .su-loading,.su-showcase-container .su-stage .su-error{font-family:var(--mono);font-size:11.5px;color:var(--t3);text-align:center;line-height:1.6}.su-showcase-container .su-stage .su-loading{animation:su-pulse 2.2s ease-in-out infinite}.su-showcase-container .su-stage .su-error{color:var(--red);white-space:pre-wrap}.su-showcase-container .showcase-note{text-align:center;margin-top:28px;font-size:13px;color:var(--t2);max-width:720px;margin-left:auto;margin-right:auto}.su-showcase-container .showcase-note a{color:var(--amber);font-weight:500}.su-showcase-container .showcase-note a:hover{text-decoration:underline;text-underline-offset:3px}.wrap.solo{display:block;padding-bottom:80px}
