@import "https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Manrope:wght@400;500;600;700&family=Syne:wght@600;700&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--page:#f4f1ea;--page-deep:#ebe6dd;--surface:#fffdf8d1;--surface-solid:#fffdf8;--surface-muted:#f1ede5;--ink:#172226;--ink-muted:#5f6d70;--ink-soft:#8a9290;--line:#1722261c;--line-strong:#17222633;--cyan:#147f85;--cyan-soft:#dceeed;--orange:#db6737;--orange-strong:#b84b21;--green:#2f845e;--yellow:#a66f0e;--red:#b64c42;--canvas:#f7f5ef;--glass:#fffdf8d1;--shadow:0 28px 80px #242a2624;--shadow-soft:0 12px 34px #242a2614;--focus:#147f857a;--radius-xl:30px;--radius-lg:22px;--radius-md:16px;color:var(--ink);background:radial-gradient(circle at 8% 4%, #147f851c, transparent 26rem), radial-gradient(circle at 92% 12%, #db67371a, transparent 24rem), linear-gradient(180deg, #faf8f3 0%, var(--page) 44%, var(--page-deep) 100%);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font:15px/1.55 Manrope,Segoe UI Variable,sans-serif}:root[data-theme=midnight]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--page:#071014;--page-deep:#04090c;--surface:#0d191edb;--surface-solid:#0f1d22;--surface-muted:#12252b;--ink:#edf4f1;--ink-muted:#a9b9b8;--ink-soft:#718587;--line:#c2ddda1f;--line-strong:#c2ddda38;--cyan:#77d2d1;--cyan-soft:#24606261;--orange:#f29a6f;--orange-strong:#ffb083;--green:#79d2a1;--yellow:#e5bd63;--red:#ee8d83;--canvas:#0b171d;--glass:#081318d1;--shadow:0 30px 90px #00000075;--shadow-soft:0 14px 38px #00000047;--focus:#77d2d18f;background:radial-gradient(circle at 8% 4%, #77d2d11f, transparent 28rem), radial-gradient(circle at 92% 12%, #f29a6f1c, transparent 25rem), linear-gradient(180deg, #0a151a 0%, var(--page) 46%, var(--page-deep) 100%)}*{box-sizing:border-box}html{scroll-behavior:smooth;min-width:320px;min-height:100%}body{min-height:100%;margin:0;overflow-x:hidden}body:before{z-index:-1;background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);content:"";opacity:.28;pointer-events:none;background-size:64px 64px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000,#0000 75%);mask-image:linear-gradient(#000,#0000 75%)}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}button:focus-visible,input:focus-visible,a:focus-visible{outline:2px solid var(--focus);outline-offset:3px}a{color:inherit}#app{min-height:100vh}.shell{width:min(1520px,100vw - 48px);margin:0 auto;padding:40px 0 28px}.hero{justify-content:space-between;align-items:flex-start;gap:36px;padding:8px 4px 30px;display:flex}.hero__copy{align-items:flex-start;gap:24px;min-width:0;display:flex}.hero__copy>div:last-child,.stage__meta>div:last-child{min-width:0}.brand-mark{border:1px solid var(--line-strong);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:16px;flex:none;grid-template-columns:repeat(2,18px);gap:4px;padding:10px;display:grid}.brand-mark span{background:var(--cyan-soft);border-radius:5px;width:18px;height:18px}.brand-mark span:nth-child(2),.brand-mark span:nth-child(3){background:var(--cyan)}.brand-mark span:nth-child(4){background:var(--orange)}.eyebrow,.panel__kicker{color:var(--cyan);letter-spacing:.12em;text-transform:uppercase;font:500 11px/1.2 DM Mono,monospace}.eyebrow{align-items:center;gap:9px;display:inline-flex}.eyebrow:before{content:"";background:currentColor;width:18px;height:1px}.hero__meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.repo-badge{border:1px solid var(--line-strong);color:var(--ink-soft);border-radius:999px;padding:4px 8px;font:500 10px/1 DM Mono,monospace}.hero h1{letter-spacing:-.065em;max-width:820px;margin:12px 0 5px;font:700 clamp(3.2rem,5.7vw,5.8rem)/.9 Syne,sans-serif}.hero h1 span{color:var(--orange)}.hero__subtitle{color:var(--ink);margin-bottom:12px;font:500 clamp(.84rem,1.2vw,1rem)/1.4 DM Mono,monospace}.hero p{max-width:780px;color:var(--ink-muted);margin:0;font-size:clamp(.96rem,1.2vw,1.08rem)}.hero__proof{flex-wrap:wrap;gap:8px;margin-top:20px;display:flex}.hero__proof span,.pill{border:1px solid var(--line);background:var(--surface);color:var(--ink-muted);border-radius:999px;font:500 11px/1 DM Mono,monospace}.hero__proof span{align-items:center;gap:7px;padding:8px 11px;display:inline-flex}.language-dot{background:var(--ink-soft);border-radius:50%;width:8px;height:8px}.language-dot--typescript{background:#3178c6}.language-dot--webgl{background:#e44d26}.hero__actions{flex:none;justify-content:flex-end;align-items:center;gap:10px;min-width:0;padding-top:4px;display:flex}.pill{color:var(--ink);box-shadow:var(--shadow-soft);align-items:center;gap:9px;padding:12px 15px;display:inline-flex}.pill--live:before{background:var(--green);width:8px;height:8px;box-shadow:0 0 0 4px color-mix(in srgb, var(--green) 14%, transparent);content:"";border-radius:50%}.button{border:1px solid var(--line-strong);background:var(--surface);min-height:42px;color:var(--ink);border-radius:12px;justify-content:center;align-items:center;gap:9px;padding:10px 16px;font-weight:600;text-decoration:none;transition:transform .15s,border-color .15s,background .15s,box-shadow .15s;display:inline-flex;box-shadow:0 6px 18px #242a260d}.button:hover:not(:disabled){border-color:color-mix(in srgb, var(--orange) 46%, var(--line));background:var(--surface-solid);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.button--primary{background:var(--orange);color:#fffaf7;border-color:#0000}.button--primary:hover:not(:disabled){background:var(--orange-strong);border-color:#0000}.button--quiet{box-shadow:none;background:0 0}.button--theme{min-width:112px}.button--source{border-color:color-mix(in srgb, var(--cyan) 40%, var(--line))}.source-mark{color:var(--cyan);font:500 11px/1 DM Mono,monospace}.button--theme:before{border:2px solid var(--cyan);width:12px;height:12px;box-shadow:inset -4px 0 0 var(--cyan);content:"";border-radius:50%}.button__spark{background:linear-gradient(135deg, var(--cyan), var(--orange));border-radius:3px;width:10px;height:10px}.app-grid{grid-template-columns:minmax(0,2.15fr) minmax(330px,.85fr);align-items:start;gap:18px;display:grid}.app-grid>*{min-width:0}.stage,.panel,.pipeline{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.stage{border-radius:var(--radius-xl);min-width:0;padding:14px}.stage__toolbar{justify-content:space-between;align-items:center;gap:20px;padding:6px 6px 18px;display:flex}.stage__toolbar h2,.panel h3,.pipeline h2{margin:0}.stage__meta{align-items:center;gap:13px;min-width:0;display:flex}.stage__index{border:1px solid var(--line);background:var(--surface-muted);width:42px;height:42px;color:var(--cyan);border-radius:12px;place-items:center;font:500 12px/1 DM Mono,monospace;display:grid}.stage__path{color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px;font:500 9px/1.2 DM Mono,monospace}.stage__meta h2{font:700 1.15rem/1.2 Syne,sans-serif}.microcopy,.panel__hint,.metric__hint,.range-row__hint,.toggle__hint{color:var(--ink-soft);font-size:.76rem}.stage__actions{gap:8px;display:flex}.canvas-shell{aspect-ratio:1100/720;border:1px solid var(--line-strong);background:var(--canvas);width:100%;box-shadow:var(--shadow);isolation:isolate;border-radius:22px;position:relative;overflow:hidden}.canvas-shell:after{z-index:1;background:linear-gradient(180deg, #ffffff14, transparent 24%), radial-gradient(circle at 72% 16%, color-mix(in srgb, var(--orange) 10%, transparent), transparent 28%), radial-gradient(circle at 20% 70%, color-mix(in srgb, var(--cyan) 9%, transparent), transparent 30%);content:"";pointer-events:none;position:absolute;inset:0}.canvas-shell canvas{width:100%;height:100%;display:block;position:absolute;inset:0}#webgl-canvas{z-index:0;cursor:crosshair}#overlay-canvas{z-index:2;pointer-events:none}.canvas-shell__topline,.canvas-shell__hud,.canvas-shell__info,.visibility{z-index:3;border:1px solid var(--line);background:var(--glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:absolute}.canvas-shell.is-grid-active{border-color:color-mix(in srgb, var(--cyan) 64%, var(--line));box-shadow:0 0 0 3px color-mix(in srgb, var(--cyan) 10%, transparent), var(--shadow)}.canvas-shell.is-grid-active .canvas-shell__topline span:last-child{color:var(--cyan)}.canvas-shell__topline{color:var(--ink-soft);text-transform:uppercase;border-radius:10px;align-items:center;gap:16px;padding:8px 11px;font:500 10px/1 DM Mono,monospace;display:flex;top:14px;left:14px}.canvas-shell__topline span:first-child{color:var(--ink);align-items:center;gap:7px;display:flex}.canvas-shell__topline i{background:var(--green);border-radius:50%;width:7px;height:7px}.canvas-shell__hud{border-radius:14px;align-items:stretch;gap:14px;padding:11px 14px;display:flex;top:14px;right:14px}.hud-stat{min-width:62px}.canvas-shell__hud-label{color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px;font:500 9px/1.2 DM Mono,monospace}.canvas-shell__hud-value{color:var(--ink);font:500 15px/1.2 DM Mono,monospace}.hud-stat--accent .canvas-shell__hud-value{color:var(--orange)}.canvas-shell__hud-divider{background:var(--line);width:1px}.canvas-shell__info{color:var(--ink-muted);border-radius:10px;align-items:center;gap:9px;padding:9px 11px;font-size:.75rem;display:flex;bottom:14px;left:14px}.canvas-shell__cursor{border:1px dashed var(--orange);border-radius:50%;width:12px;height:12px}.visibility{border-radius:12px;width:min(330px,100% - 28px);padding:10px 12px;bottom:14px;right:14px}.visibility__copy{color:var(--ink-soft);text-transform:uppercase;justify-content:space-between;gap:14px;margin-bottom:7px;font:500 9px/1.2 DM Mono,monospace;display:flex}.visibility__copy strong{color:var(--ink);font-weight:500}.visibility__track{background:color-mix(in srgb, var(--ink) 10%, transparent);border-radius:99px;height:5px;overflow:hidden}.visibility__track span{border-radius:inherit;background:linear-gradient(90deg, var(--cyan), var(--orange));width:0;height:100%;transition:width .18s;display:block}.stage-foot{color:var(--ink-soft);justify-content:space-between;gap:16px;padding:14px 5px 1px;font:400 10px/1.5 DM Mono,monospace;display:flex}.stage-foot__target span{color:var(--cyan);text-transform:uppercase;margin-right:7px}.stage-foot__hotkeys{white-space:nowrap;gap:12px;display:flex}kbd{border:1px solid var(--line-strong);background:var(--surface-solid);color:var(--ink);font:inherit;border-bottom-width:2px;border-radius:5px;padding:2px 5px}.sidebar{gap:12px;display:grid}.panel{border-radius:var(--radius-lg);padding:18px}.panel--performance{position:relative;overflow:hidden}.panel--performance:before{background:linear-gradient(90deg, var(--cyan), var(--orange));content:"";height:3px;position:absolute;top:0;left:0;right:0}.panel__header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:15px;display:flex}.panel__kicker{margin-bottom:5px}.panel__title h3{font:700 1.08rem/1.2 Syne,sans-serif}.fps-badge{border:1px solid color-mix(in srgb, var(--green) 30%, var(--line));background:color-mix(in srgb, var(--green) 10%, transparent);color:var(--green);border-radius:9px;flex:none;padding:7px 10px;font:500 11px/1 DM Mono,monospace}.fps-badge--warn{border-color:color-mix(in srgb, var(--yellow) 34%, var(--line));background:color-mix(in srgb, var(--yellow) 10%, transparent);color:var(--yellow)}.fps-badge--bad{border-color:color-mix(in srgb, var(--red) 34%, var(--line));background:color-mix(in srgb, var(--red) 10%, transparent);color:var(--red)}.metrics,.control-stack,.toggle-stack{gap:12px;display:grid}.metric,.stat-card,.toggle{border:1px solid var(--line);background:color-mix(in srgb, var(--surface-solid) 74%, transparent);border-radius:14px}.metric--frame{justify-content:space-between;align-items:center;gap:14px;padding:13px 14px;display:flex}.metric__label{color:var(--ink);font-weight:600}.metric__reading{white-space:nowrap}.metric__value,.stat-card__value,.stats-grid dd,.range-row__value{font-family:DM Mono,monospace}.metric__value{font-size:1.45rem;font-weight:500}.metric__suffix,.stat-card__unit{color:var(--ink-soft);font:400 .7rem/1 DM Mono,monospace}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.stat-card{padding:12px 13px}.stat-card__eyebrow{letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;font:500 9px/1.2 DM Mono,monospace}.stat-card__eyebrow--physics{color:var(--cyan)}.stat-card__eyebrow--render{color:var(--orange)}.stat-card__value{font-size:1.2rem;font-weight:500}.control-stack{gap:18px}.range-row{gap:10px;display:grid}.range-row__top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.range-row__top>span:first-child,.toggle>span:first-child{display:grid}.range-row__label,.toggle__label{color:var(--ink);font-weight:600}.range-row__value{background:var(--surface-muted);color:var(--cyan);border-radius:6px;flex:none;padding:4px 7px;font-size:.7rem}.range{width:100%;height:4px;accent-color:var(--orange);cursor:pointer}.toggle-stack{gap:8px}.toggle{justify-content:space-between;align-items:center;gap:14px;padding:11px 12px;display:flex}.switch{flex:none;display:inline-flex;position:relative}.switch input{opacity:0;width:1px;height:1px;position:absolute}.switch span{border:1px solid var(--line-strong);background:var(--surface-muted);border-radius:99px;width:38px;height:22px;transition:background .15s,border-color .15s;position:relative}.switch span:after{background:var(--ink-soft);content:"";border-radius:50%;width:14px;height:14px;transition:transform .15s,background .15s;position:absolute;top:3px;left:3px}.switch input:checked+span{border-color:var(--cyan);background:var(--cyan-soft)}.switch input:checked+span:after{background:var(--cyan);transform:translate(16px)}.switch input:focus-visible+span{outline:2px solid var(--focus);outline-offset:3px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:0;display:grid}.stats-grid dt,.stats-grid dd{background:var(--surface-muted);margin:0;padding:10px}.stats-grid dt{color:var(--ink-soft);border-radius:10px 0 0 10px;font-size:.72rem}.stats-grid dd{color:var(--ink);text-align:right;border-radius:0 10px 10px 0;font-size:.75rem;font-weight:500}.pipeline{border-radius:var(--radius-xl);grid-template-columns:minmax(230px,.65fr) minmax(0,1.8fr);gap:36px;margin-top:18px;padding:28px;display:grid}.pipeline__intro h2{letter-spacing:-.04em;margin:9px 0 7px;font:700 2rem/1 Syne,sans-serif}.pipeline__intro p{max-width:390px;color:var(--ink-muted);margin:0}.pipeline__steps{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:0;padding:0;list-style:none;display:grid}.pipeline__steps li{border:1px solid var(--line);border-radius:var(--radius-md);background:color-mix(in srgb, var(--surface-solid) 70%, transparent);gap:12px;min-height:124px;padding:15px;display:flex}.pipeline__number{color:var(--orange);font:500 10px/1.5 DM Mono,monospace}.pipeline__steps li div{align-content:start;gap:7px;display:grid}.pipeline__steps strong{font:700 1rem/1.2 Syne,sans-serif}.pipeline__steps li span:last-child{color:var(--ink-muted);font-size:.78rem}.footer{color:var(--ink-soft);justify-content:space-between;gap:18px;padding:18px 5px 0;font:400 10px/1.5 DM Mono,monospace;display:flex}.footer a{color:var(--ink-muted);text-underline-offset:3px}.footer a:hover{color:var(--orange)}.dialog{border:1px solid var(--line-strong);background:var(--surface-solid);width:min(590px,100vw - 24px);box-shadow:var(--shadow);color:var(--ink);border-radius:24px;padding:0;overflow:hidden}.dialog::backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#030a0c80}.dialog__accent{background:linear-gradient(90deg, var(--cyan), var(--orange));height:5px}.dialog__body{padding:26px 26px 16px}.dialog__body h3{letter-spacing:-.04em;margin:8px 0 12px;font:700 2rem/1.05 Syne,sans-serif}.dialog__body p,.dialog__body li{color:var(--ink-muted)}.dialog__body ul{gap:8px;padding-left:20px;display:grid}.dialog__actions{justify-content:flex-end;padding:0 26px 26px;display:flex}@media (width<=1240px){.hero{align-items:stretch}.hero__actions{flex-wrap:wrap;align-content:flex-start;max-width:280px}.app-grid{grid-template-columns:1fr}.sidebar{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=860px){.shell{width:min(100vw - 24px,1520px);padding-top:24px}.hero{gap:22px;display:grid}.hero__actions{justify-content:flex-start;max-width:none}.hero h1{font-size:clamp(3.25rem,14vw,6rem)}.sidebar,.pipeline,.pipeline__steps{grid-template-columns:1fr}.pipeline{gap:22px}.pipeline__steps li{min-height:0}}@media (width<=640px){.shell{width:min(100vw - 16px,1520px);padding-top:16px}.hero{padding-bottom:24px}.hero__copy{width:100%;display:block}.brand-mark{border-radius:12px;grid-template-columns:repeat(2,12px);gap:3px;width:max-content;margin-bottom:14px;padding:8px}.brand-mark span{border-radius:3px;width:12px;height:12px}.hero h1{margin-top:9px;font-size:clamp(2.8rem,15vw,4.5rem)}.hero__actions{grid-template-columns:repeat(2,minmax(0,1fr));width:100%;display:grid}.hero__actions .button{min-width:0;padding-inline:10px}.hero__actions #study-notes{grid-column:1/-1}.hero__actions .pill{grid-column:1/-1;justify-content:center}.stage{border-radius:20px;padding:8px}.stage__toolbar{flex-direction:column;align-items:stretch;padding:7px 4px 13px}.stage__actions .button{flex:1}.canvas-shell{border-radius:16px}.canvas-shell__topline{display:none}.canvas-shell__hud{justify-content:space-between;gap:8px;padding:9px 10px;top:8px;left:8px;right:8px}.hud-stat{min-width:0}.canvas-shell__info{display:none}.visibility{width:calc(100% - 16px);bottom:8px;right:8px}.visibility__copy{font-size:8px}.stage-foot{flex-direction:column}.sidebar{grid-template-columns:1fr}.metric-grid{grid-template-columns:1fr 1fr}.pipeline{border-radius:20px;padding:20px}.footer{flex-direction:column;align-items:flex-start}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important}}
