@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=DM+Serif+Display&family=DM+Mono:wght@300;400;500&display=swap");*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-10{z-index:10}.z-\[100\]{z-index:100}.z-\[200\]{z-index:200}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.table-caption{display:table-caption}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-full{height:100%}.min-h-0{min-height:0}.min-h-\[160px\]{min-height:160px}.w-full{width:100%}.max-w-\[200px\]{max-width:200px}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.select-none{user-select:none}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-\[5px\]{gap:5px}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-\[10px\]{border-radius:10px}.rounded-\[14px\]{border-radius:14px}.rounded-\[6px\]{border-radius:6px}.rounded-\[8px\]{border-radius:8px}.rounded-full{border-radius:9999px}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-\[var\(--line\)\]{border-color:var(--line)}.border-\[var\(--line2\)\]{border-color:var(--line2)}.bg-\[\#7F77DD\]{--tw-bg-opacity:1;background-color:rgb(127 119 221/var(--tw-bg-opacity,1))}.p-4{padding:1rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pt-8{padding-top:2rem}.text-center{text-align:center}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-\[1\.04\]{line-height:1.04}.tracking-\[-0\.03em\]{letter-spacing:-.03em}.text-\[rgba\(240\2c 237\2c 232\2c 0\.38\)\]{color:rgba(240,237,232,.38)}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg:#09090b;--bg2:#0f0f12;--bg3:#141418;--bg4:#1a1a1f;--bg5:#212128;--text:#f0ede8;--muted:rgba(240,237,232,0.45);--hint:rgba(240,237,232,0.2);--faint:rgba(240,237,232,0.07);--line:rgba(255,255,255,0.05);--line2:rgba(255,255,255,0.09);--line3:rgba(255,255,255,0.14);--font:"Inter",-apple-system,sans-serif;--font-display:"DM Serif Display",Georgia,serif;--mono:"DM Mono",monospace;--purple:#7f77dd;--blue:#378add;--red:#e24b4a;--amber:#ef9f27;--teal:#1d9e75;--pink:#d4537e;--yellow:#f5e642;--teal-light:#5dcaa5}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;max-width:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.5;overflow-x:hidden}*{scrollbar-width:thin;scrollbar-color:var(--bg5) transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:2px}.app{display:grid;grid-template-rows:48px 1fr;height:100vh;overflow:hidden}.topbar{padding:0 14px;border-bottom:1px solid var(--line);background:var(--bg2);z-index:200;gap:0}.logo,.topbar{display:flex;align-items:center}.logo{gap:9px;padding-right:16px;border-right:1px solid var(--line2);height:48px}.gem,.logo{flex-shrink:0}.gem{width:22px;height:22px;border-radius:6px;background:conic-gradient(from var(--ang),var(--red),var(--amber),var(--yellow),var(--teal),var(--blue),var(--purple),var(--pink),var(--red));animation:spin 4s linear infinite}.logo-name{font-size:14px;font-weight:500;letter-spacing:-.03em}.logo-tag{font-size:11px;color:var(--hint);font-weight:300}.page-tabs{display:flex;height:48px;margin-left:4px}.ptab{display:flex;align-items:center;gap:7px;padding:0 16px;font-size:12px;cursor:pointer;background:transparent;color:var(--muted);font-family:var(--font);border:none;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}.ptab svg{width:13px;height:13px;opacity:.5;flex-shrink:0}.ptab.active,.ptab:hover{color:var(--text)}.ptab.active{border-bottom-color:var(--purple)}.ptab.active svg{opacity:1}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px;padding-left:16px;border-left:1px solid var(--line2)}.ver{font-size:10px;color:var(--hint);font-family:var(--mono)}.tbtn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:6px;font-size:11px;cursor:pointer;border:1px solid var(--line2);background:transparent;color:var(--muted);font-family:var(--font);transition:all .15s;white-space:nowrap}.tbtn:hover{color:var(--text);background:var(--bg4)}.tbtn.accent{background:rgba(127,119,221,.1);border-color:rgba(127,119,221,.28);color:rgba(175,169,236,.9)}.tbtn.accent:hover{background:rgba(127,119,221,.18);border-color:rgba(127,119,221,.45)}.tbtn.ok{color:#5dcaa5;border-color:rgba(29,158,117,.3);background:rgba(29,158,117,.05)}.playground{display:grid;grid-template-columns:190px 1fr 258px;width:100%;height:100%;overflow:hidden}.sidebar{background:var(--bg2);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.sb-search{padding:8px;border-bottom:1px solid var(--line);flex-shrink:0}.sb-search input{width:100%;background:var(--bg3);border:1px solid var(--line2);border-radius:6px;padding:6px 10px;font-size:12px;color:var(--text);font-family:var(--font);outline:none}.sb-search input:focus{border-color:rgba(127,119,221,.35)}.sb-search input::placeholder{color:var(--hint)}.sb-list{flex:1;overflow-y:auto;padding:4px}.grp-lbl{font-size:9px;font-weight:500;color:var(--hint);letter-spacing:.1em;text-transform:uppercase;padding:9px 8px 3px;display:flex;justify-content:space-between;align-items:center}.grp-cnt{font-size:9px;color:var(--faint);font-family:var(--mono)}.ci{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:6px;cursor:pointer;border:1px solid transparent;color:var(--muted);font-size:12px;transition:all .12s;margin-bottom:1px}.ci.active,.ci:hover{color:var(--text);background:var(--bg4)}.ci.active{border-color:var(--line2)}.ci-ic{width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;background:var(--bg5);flex-shrink:0}.centre{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.prev-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--line);background:var(--bg2);flex-shrink:0}.pmodes{display:flex;gap:3px}.pm{padding:4px 9px;border-radius:5px;font-size:11px;cursor:pointer;border:1px solid transparent;background:transparent;color:var(--hint);font-family:var(--font);transition:all .12s}.pm:hover{color:var(--muted)}.pm.active{background:var(--bg4);border-color:var(--line2);color:var(--text)}.canvas{position:relative;overflow:hidden}.canvas,.motion-preview{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.motion-preview{padding:40px}.c-grid{background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 0),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 0);background-size:28px 28px}.c-dots{background-image:radial-gradient(rgba(255,255,255,.1) 1px,transparent 0);background-size:22px 22px}.c-dark{background:var(--bg)}.c-light{background:#f0ede8}.c-vig{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 35%,rgba(9,9,11,.7) 100%);pointer-events:none;z-index:1}.stage{position:relative;z-index:2;flex-direction:column;gap:14px;max-width:560px;width:100%;padding:20px}.c-hint,.stage{display:flex;align-items:center}.c-hint{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);font-size:10px;color:var(--hint);gap:6px;z-index:3;white-space:nowrap;pointer-events:none}.ch-dot{width:5px;height:5px;border-radius:50%;background:#5dcaa5;box-shadow:0 0 5px rgba(93,202,165,.5)}.cli-win{flex-shrink:0;border-top:1px solid var(--line);background:var(--bg2)}.cli-bar{justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--line)}.cli-bar,.cli-dots{display:flex;align-items:center}.cli-dots{gap:5px}.cli-dot{width:10px;height:10px;border-radius:50%}.cli-title{font-size:10px;color:var(--hint);letter-spacing:.06em;font-weight:500;text-transform:uppercase}.cli-actions{display:flex;gap:6px}.cli-btn{display:flex;align-items:center;gap:5px;padding:4px 11px;border-radius:5px;font-size:11px;cursor:pointer;border:1px solid var(--line2);background:transparent;color:var(--muted);font-family:var(--font);transition:all .12s;white-space:nowrap}.cli-btn:hover{color:var(--text);background:var(--bg4)}.cli-btn.primary{background:rgba(127,119,221,.1);border-color:rgba(127,119,221,.25);color:rgba(175,169,236,.9)}.cli-btn.primary:hover{background:rgba(127,119,221,.18)}.cli-btn.ok{color:#5dcaa5;border-color:rgba(29,158,117,.3);background:rgba(29,158,117,.06)}.cli-body{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.cli-row{display:flex;align-items:flex-start;gap:10px}.cli-prompt{color:rgba(127,119,221,.55);flex-shrink:0;margin-top:1px}.cli-cmd,.cli-prompt{font-family:var(--mono);font-size:12px;line-height:1.65}.cli-cmd{color:var(--text);word-break:break-all;flex:1}.t-base{color:#5dcaa5}.t-sub{color:rgba(240,237,232,.5)}.t-comp{color:#ef9f27}.t-key{color:#afa9ec}.t-val{color:var(--text)}.t-col-dot{width:9px;height:9px;border-radius:2px;margin-right:3px;position:relative;top:-1px}.t-col-dot,.t-cursor{display:inline-block;vertical-align:middle}.t-cursor{width:7px;height:13px;background:rgba(127,119,221,.65);margin-left:2px;animation:blink 1.1s ease-in-out infinite}.cli-out{font-family:var(--mono);font-size:11px;color:var(--hint);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.cli-arrow{color:rgba(127,119,221,.45)}.flag-new{animation:flag-pop .2s ease both}.props-col{background:var(--bg2);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.ph{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-bottom:1px solid var(--line);flex-shrink:0}.ph-lbl{font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase}.ph-lbl,.ph-name{color:var(--hint)}.ph-name{font-size:10px}.ps{flex:1;overflow-y:auto;padding-bottom:40px}.pg{border-bottom:1px solid var(--line);padding:11px}.pgt{font-size:9px;font-weight:500;color:var(--hint);letter-spacing:.12em;text-transform:uppercase;margin-bottom:9px}.pr{margin-bottom:7px}.pr:last-child{margin-bottom:0}.pl{font-size:11px;color:var(--muted);margin-bottom:4px}.pi{width:100%;background:var(--bg3);border:1px solid var(--line2);border-radius:5px;padding:6px 8px;font-size:12px;color:var(--text);font-family:var(--font);outline:none;transition:all .12s}.pi:focus{border-color:rgba(127,119,221,.4);box-shadow:0 0 0 2px rgba(127,119,221,.07)}.pi::placeholder{color:var(--hint)}select.pi{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(240,237,232,0.18)'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}textarea.pi{resize:vertical;min-height:54px;line-height:1.5}.rr{display:flex;align-items:center;gap:7px}.ri{flex:1;-webkit-appearance:none;height:3px;border-radius:2px;background:var(--bg5);outline:none;cursor:pointer}.ri::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text);border:2px solid var(--bg2);cursor:pointer;transition:transform .12s}.ri::-webkit-slider-thumb:hover{transform:scale(1.2)}.rn{font-size:10px;color:var(--hint);min-width:30px;text-align:right;font-family:var(--mono)}.ppg{display:flex;background:var(--bg3);border-radius:5px;padding:2px;border:1px solid var(--line);gap:2px}.pp{flex:1;text-align:center;padding:4px;border-radius:4px;font-size:11px;cursor:pointer;color:var(--muted);transition:all .12s;border:none;background:transparent;font-family:var(--font);white-space:nowrap}.pp.active{background:var(--bg5)}.pp.active,.pp:hover:not(.active){color:var(--text)}.og{grid-template-columns:1fr 1fr}.og,.og3{display:grid;gap:3px}.og3{grid-template-columns:1fr 1fr 1fr}.oo{padding:5px 6px;border-radius:4px;font-size:11px;cursor:pointer;border:1px solid var(--line);background:var(--bg3);color:var(--muted);transition:all .12s;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.oo:hover{color:var(--text);border-color:var(--line2)}.oo.active{border-color:rgba(127,119,221,.35);background:rgba(127,119,221,.07);color:var(--text)}.swatches{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}.sw{width:20px;height:20px;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .12s;position:relative}.sw:hover{transform:scale(1.12)}.sw.active{border-color:var(--text)}.sw.active:after{content:"";position:absolute;inset:2px;border-radius:2px;border:1.5px solid rgba(0,0,0,.4)}.hrow{display:flex;gap:5px;align-items:center}.hi{flex:1;background:var(--bg3);border:1px solid var(--line2);border-radius:5px;padding:5px 7px;font-size:11px;color:var(--text);font-family:var(--mono);outline:none;transition:all .12s}.hi:focus{border-color:rgba(127,119,221,.4)}input[type=color]{width:28px;height:28px;border:1px solid var(--line2);background:none;cursor:pointer;border-radius:5px;padding:2px}.ig{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}.io{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:13px;cursor:pointer;border:1px solid transparent;background:var(--bg3);transition:all .12s;color:var(--muted)}.io:hover{color:var(--text);border-color:var(--line2)}.io.active{border-color:rgba(127,119,221,.4);background:rgba(127,119,221,.08);color:var(--text)}.arl{flex-direction:column}.arl,.arl-row{display:flex;gap:4px}.arl-row{align-items:center}.arl-row .pi{flex:1;min-width:0}.arl-rm{flex-shrink:0;width:22px;height:22px;border-radius:4px;border:1px solid var(--line2);background:transparent;color:var(--muted);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .12s}.arl-rm:hover{border-color:rgba(226,75,74,.4);color:rgba(226,75,74,.8)}.arl-danger{flex-shrink:0;width:22px;height:22px;border-radius:4px;border:1px solid var(--line2);background:transparent;color:var(--muted);cursor:pointer;font-size:9px;font-weight:700;transition:all .12s}.arl-danger.active,.arl-danger:hover{border-color:rgba(226,75,74,.5);background:rgba(226,75,74,.12);color:rgba(226,75,74,.9)}.arl-add{align-self:flex-start;margin-top:4px;padding:4px 10px;border-radius:5px;border:1px solid var(--line2);background:transparent;color:var(--muted);cursor:pointer;font-size:11px;transition:all .12s}.arl-add:hover{border-color:var(--line);color:var(--text)}.ph-reset{font-size:10px;color:var(--hint);background:transparent;border:1px solid var(--line);border-radius:5px;padding:3px 8px;cursor:pointer;transition:all .12s}.ph-reset:hover{color:var(--text);border-color:var(--line2)}.docs-wrap{display:flex;flex-direction:row;width:100%;height:calc(100vh - 48px);overflow:hidden}.docs-nav{width:218px;border-right:1px solid var(--line);background:var(--bg2);overflow-y:auto;flex-shrink:0;padding:10px 0}.dn-section{font-size:9px;font-weight:500;color:var(--hint);letter-spacing:.1em;text-transform:uppercase;padding:10px 16px 3px}.dn-link{display:block;padding:7px 16px;font-size:12px;color:var(--muted);cursor:pointer;transition:all .12s;border-left:2px solid transparent;text-decoration:none}.dn-link:hover{color:var(--text);background:rgba(255,255,255,.02)}.dn-link.active{color:var(--text);border-left-color:var(--purple);background:rgba(127,119,221,.05)}.docs-body{flex:1;overflow-y:auto;height:100%;padding:48px 52px}.docs-body::-webkit-scrollbar{width:6px}.d-eyebrow{font-size:10px;font-weight:500;color:rgba(127,119,221,.7);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}.d-h1{font-size:32px;font-weight:300;letter-spacing:-.03em;margin-bottom:12px;line-height:1.15}.d-h1 em{font-style:normal}.d-h1 em,.d-lead{color:var(--muted)}.d-lead{font-size:15px;font-weight:300;line-height:1.7;margin-bottom:36px;max-width:540px}.d-h2{font-size:18px;font-weight:400;letter-spacing:-.02em;margin:36px 0 10px}.d-h3{font-size:14px;font-weight:500;margin:20px 0 7px}.d-p{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:14px;font-weight:300}.d-divider{border:none;border-top:1px solid var(--line);margin:36px 0}.d-table{width:100%;border-collapse:collapse;margin:14px 0}.d-table th{text-align:left;padding:8px 12px;font-size:10px;color:var(--hint);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line);font-weight:500}.d-table td{padding:10px 12px;font-size:12px;color:var(--muted);border-bottom:1px solid rgba(255,255,255,.03);vertical-align:top;line-height:1.5}.d-table tr:last-child td{border-bottom:none}.d-table tr:hover td{color:var(--text);background:rgba(255,255,255,.015)}.dt{color:var(--teal)}.dd,.dt{font-family:var(--mono);font-size:11px}.dd{color:var(--hint)}.d-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.d-card{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:18px;transition:all .2s}.d-card:hover{border-color:var(--line2);background:var(--bg3)}.d-card-num{font-size:10px;font-weight:500;color:var(--purple);font-family:var(--mono);margin-bottom:8px}.d-card-title{font-size:14px;font-weight:400;margin-bottom:6px;letter-spacing:-.01em}.d-card-desc{font-size:12px;color:var(--muted);font-weight:300;line-height:1.6}.code-block{background:var(--bg2);border:1px solid var(--line2);border-radius:10px;overflow:hidden;margin:16px 0}.cb-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--line);background:var(--bg3)}.cb-lang{font-family:var(--mono)}.cb-copy,.cb-lang{font-size:10px;color:var(--hint)}.cb-copy{cursor:pointer;padding:2px 8px;border-radius:4px;border:1px solid var(--line2);background:transparent;font-family:var(--font);transition:all .12s}.cb-copy:hover{color:var(--text);background:var(--bg5)}.cb-copy.ok{color:#5dcaa5;border-color:rgba(29,158,117,.3)}.cb-body{padding:16px;font-family:var(--mono);font-size:12px;line-height:1.78;color:rgba(240,237,232,.5);overflow-x:auto}.kw{color:#afa9ec}.fn{color:#ef9f27}.str{color:#5dcaa5}.tag{color:#e24b4a}.attr{color:#85b7eb}.cmt{color:rgba(240,237,232,.22);font-style:italic}.num{color:#d4537e}code{font-family:var(--mono);font-size:11px;color:#5dcaa5;background:rgba(93,202,165,.08);padding:1px 5px;border-radius:3px}.callout{border-radius:8px;padding:13px 16px;margin:16px 0;font-size:12px;line-height:1.65;display:flex;gap:10px;border:1px solid;font-weight:300}.callout-tip{background:rgba(29,158,117,.06);border-color:rgba(29,158,117,.2);color:rgba(240,237,232,.6)}.callout-info{background:rgba(55,138,221,.06);border-color:rgba(55,138,221,.2);color:rgba(240,237,232,.6)}.callout-warn{background:rgba(239,159,39,.06);border-color:rgba(239,159,39,.2);color:rgba(240,237,232,.6)}.callout-icon{flex-shrink:0;font-size:14px;margin-top:1px}.howto-page{overflow-y:auto;height:100%}.howto{padding:56px 48px;max-width:900px;margin:0 auto;width:100%}.ht-eyebrow{font-size:10px;font-weight:500;color:rgba(127,119,221,.7);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}.ht-h1{font-size:38px;font-weight:300;letter-spacing:-.03em;margin-bottom:14px;line-height:1.15}.ht-h1 em{font-style:normal;color:var(--muted)}.ht-lead{font-size:15px;color:var(--muted);font-weight:300;line-height:1.7;max-width:560px}.ht-lead,.steps{margin-bottom:48px}.steps{display:grid;grid-template-columns:1fr 1fr;gap:16px}.step{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:24px;position:relative;transition:all .2s;overflow:hidden}.step:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--purple);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.step:hover:before{transform:scaleX(1)}.step:hover{border-color:var(--line2);background:var(--bg3)}.step-num{font-size:11px;font-weight:500;color:var(--purple);letter-spacing:.04em;margin-bottom:10px;font-family:var(--mono)}.step-title{font-size:15px;font-weight:400;color:var(--text);margin-bottom:8px;letter-spacing:-.01em}.step-desc{font-size:12px;color:var(--muted);font-weight:300;line-height:1.65}.step-icon{position:absolute;top:20px;right:20px;font-size:20px;opacity:.15}.ht-divider{border:none;border-top:1px solid var(--line);margin:40px 0}.ht-h2{font-size:20px;letter-spacing:-.02em;margin-bottom:12px}.ht-h2,.ht-p{font-weight:300}.ht-p{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:14px}.stage{max-width:680px;min-height:260px;justify-content:center;border:1px solid rgba(255,255,255,.04);border-radius:18px;background:rgba(15,15,18,.35)}.ver{color:rgba(240,237,232,.14)}.grp-lbl{color:rgba(240,237,232,.32)}.pg{padding:16px 12px}.pgt{margin-bottom:12px}.cli-cmd{font-size:13px}.cli-title{color:rgba(240,237,232,.28)}@media (max-width:767px){body,html{overflow:auto}.app{height:auto;min-height:100dvh;grid-template-rows:48px auto}.centre,.motion-sidebar,.props-col,.sidebar{flex:1;min-height:0}.motion-sidebar{border-right:none!important}.motion-preview{padding:18px}.motion-preview>*{max-width:min(100%,360px)}.prev-bar{min-height:42px;gap:12px}.cli-win,.playground{display:none}.docs-wrap{height:auto;flex-direction:column}.docs-nav{width:100%;height:auto;border-right:none;border-bottom:1px solid var(--line);padding:8px 0}.docs-body{padding:32px 20px}.d-cards,.steps{grid-template-columns:1fr}.howto{padding:36px 20px}}@media (max-width:600px){.ver{display:none}.topbar-right{border-left:none;padding-left:8px}.tbtn:not(.accent){display:none}}@media (max-width:460px){.ptab-label{display:none}.ptab{padding:0 10px}}:root{--serif:"DM Serif Display",Georgia,serif;--sans:"Inter",-apple-system,sans-serif}.forge-site-page{font-size:15px;line-height:1.6;max-width:100%;overflow-x:clip}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 40px;min-width:0}.forge-site-page footer,.forge-site-page main,.forge-site-page section{max-width:100%;overflow-x:clip}.component-showcase-grid,.site-demo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.component-showcase-cell,.site-demo-cell{min-width:0}.component-showcase-cell--wide,.site-demo-cell--wide{grid-column:span 2}.forge-grid{background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 0),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 0);background-size:40px 40px}.forge-grid,.forge-vignette{position:fixed;inset:0;z-index:0;pointer-events:none}.forge-vignette{background:radial-gradient(ellipse at 50% 0,transparent 40%,rgba(9,9,11,.9) 100%)}@property --gem-angle{syntax:"<angle>";inherits:false;initial-value:0deg}@keyframes gem-spin{to{--gem-angle:360deg}}.section-tag{display:block;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;color:var(--hint);margin-bottom:20px;text-transform:uppercase}.spectrum-bar{width:100%;height:1px;position:relative;z-index:1;background:linear-gradient(90deg,transparent,var(--red),var(--amber),var(--yellow),var(--teal),var(--blue),var(--purple),var(--pink),transparent);opacity:.5}.tag-pill{display:inline-block;padding:3px 9px;border-radius:4px;font-size:11px;font-family:var(--mono);background:var(--faint);color:var(--hint);border:1px solid var(--line)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s!important}.reveal-delay-2{transition-delay:.2s!important}.reveal-delay-3{transition-delay:.3s!important}.pulse-dot{animation:pulse-dot 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3}50%{opacity:1}}.tool-card{background:var(--bg2);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:border-color .25s,transform .25s}.tool-card:hover{border-color:var(--line2);transform:translateY(-4px)}.tool-card-header{padding:32px 32px 24px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.tool-card-body{padding:24px 32px 32px}.tool-badge{font-size:10px;font-family:var(--mono);padding:4px 10px;border-radius:100px;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.badge-live{background:rgba(29,158,117,.1);border:1px solid rgba(29,158,117,.22);color:rgba(93,202,165,.85)}.badge-soon{background:rgba(239,159,39,.08);border:1px solid rgba(239,159,39,.2);color:rgba(239,159,39,.7)}.tool-name{font-size:22px;font-weight:500;letter-spacing:-.03em;color:var(--text);margin-bottom:6px}.tool-name span{color:var(--hint);font-weight:300}.tool-tagline{font-size:13px;line-height:1.6}.tool-desc,.tool-tagline{color:var(--muted);font-weight:300}.tool-desc{font-size:14px;line-height:1.75;margin-bottom:24px}.tool-tags{gap:6px;margin-bottom:24px}.tool-actions,.tool-tags{display:flex;flex-wrap:wrap}.tool-actions{gap:10px}.tool-stats{display:flex;gap:24px;margin-bottom:24px}.tool-stat{display:flex;flex-direction:column;gap:2px}.tool-stat-num{font-size:24px;font-weight:500;letter-spacing:-.03em;color:var(--text)}.tool-stat-label{font-size:11px;color:var(--hint);font-family:var(--mono)}.tool-featured{display:grid;grid-template-columns:1fr 1fr;gap:0}.tool-featured .tool-card-header{border-bottom:none;border-right:1px solid var(--line);padding:40px}.tool-featured .tool-card-body{padding:40px}.tools-secondary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}.cli-preview{background:var(--bg);border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:20px}.cli-preview-bar{padding:9px 14px;border-bottom:1px solid var(--line);background:var(--bg2);display:flex;align-items:center;gap:7px}.cli-preview-body{padding:14px 16px;font-family:var(--mono);font-size:11px}.cli-line{display:flex;align-items:center;gap:8px;margin-bottom:8px}.cli-preview-body .cli-out{font-size:10px;color:var(--hint);display:flex;gap:6px;margin-top:3px}.cli-cursor{display:inline-block;width:7px;height:12px;background:rgba(127,119,221,.6);vertical-align:middle;animation:blink 1.1s ease-in-out infinite}.oss-code{background:var(--bg2);border:1px solid var(--line2);border-radius:12px;overflow:hidden;font-family:var(--mono);font-size:12px}.oss-code-bar{padding:10px 16px;border-bottom:1px solid var(--line);background:var(--bg3);display:flex;align-items:center;justify-content:space-between}.oss-code-body{padding:20px;line-height:2}.code-comment{color:rgba(240,237,232,.2)}.code-key{color:#afa9ec}.code-val{color:#5dcaa5}.code-str{color:var(--amber)}.code-muted{color:var(--hint)}.manifesto-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.manifesto-left{position:sticky;top:100px}.tenet{padding:24px 0;border-bottom:1px solid var(--line);display:flex;gap:20px;align-items:flex-start;transition:padding-left .2s;cursor:default}.tenet:first-child{border-top:1px solid var(--line)}.tenet:hover{padding-left:8px}.oss-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.built-by-inner{justify-content:space-between;gap:40px;flex-wrap:wrap}.avatar,.built-by-inner{display:flex;align-items:center}.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink));justify-content:center;font-size:14px;font-weight:500;color:#f0ede8;flex-shrink:0}.cta-inner{background:var(--bg2);border:1px solid var(--line2);border-radius:20px;padding:72px 60px;text-align:center;position:relative;overflow:hidden}.cta-spectrum{position:absolute;inset:0;border-radius:20px;padding:1px;background:conic-gradient(from var(--gem-angle),var(--red),var(--amber),var(--yellow),var(--teal),var(--blue),var(--purple),var(--pink),var(--red));animation:gem-spin 8s linear infinite;opacity:.9;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude}@media (max-width:900px){.tool-featured{grid-template-columns:1fr}.tool-featured .tool-card-header{border-right:none;border-bottom:1px solid var(--line)}.tools-secondary{grid-template-columns:1fr}.manifesto-grid,.oss-inner{grid-template-columns:1fr;gap:48px}.manifesto-left{position:static}}@media (max-width:768px){.container{padding:0 20px}.forge-site-page{overflow-x:hidden}.component-showcase-grid,.site-demo-grid{grid-template-columns:1fr}.component-showcase-cell--wide,.site-demo-cell--wide{grid-column:auto}.component-showcase-cell{padding:18px!important;min-height:190px!important}.hide-mobile{display:none!important}.cta-inner{padding:48px 24px}.built-by-inner{flex-direction:column}}.hover\:opacity-80:hover{opacity:.8}@media (min-width:768px){.md\:hidden{display:none}}@property --ang{syntax:"<angle>";inherits:false;initial-value:0deg}@keyframes spin{to{--ang:360deg}}@keyframes FORGE-spin{to{transform:rotate(1turn)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes ripple-out{to{transform:scale(30);opacity:0}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes wave{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes morph{0%,to{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}50%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%}}@keyframes orbit{0%{transform:rotate(0deg) translateX(26px) rotate(0deg)}to{transform:rotate(1turn) translateX(26px) rotate(-1turn)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes bounce-keys{0%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-4px)}}@keyframes ticker{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes skeleton-shine{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes flag-pop{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}@keyframes count-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}