pi-deck 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +122 -0
- package/bin/pi-deck.js +86 -0
- package/dist/server.js +7295 -0
- package/dist/server.js.map +7 -0
- package/package.json +76 -0
- package/packages/client/dist/assets/MarkdownContent-BP8uvTu3.js +2 -0
- package/packages/client/dist/assets/index-1WD5ZoeL.css +1 -0
- package/packages/client/dist/assets/index-BIGMLGdI.js +422 -0
- package/packages/client/dist/index.html +17 -0
- package/packages/client/dist/pi.svg +4 -0
package/package.json
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "pi-deck",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "A full-featured web UI for Pi coding agent",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"bin": {
|
|
7
|
+
"pi-deck": "./bin/pi-deck.js"
|
|
8
|
+
},
|
|
9
|
+
"files": [
|
|
10
|
+
"bin/",
|
|
11
|
+
"dist/",
|
|
12
|
+
"packages/client/dist/"
|
|
13
|
+
],
|
|
14
|
+
"workspaces": [
|
|
15
|
+
"packages/*"
|
|
16
|
+
],
|
|
17
|
+
"scripts": {
|
|
18
|
+
"dev": "concurrently \"npm run dev:server\" \"npm run dev:client\"",
|
|
19
|
+
"dev:server": "npm run dev -w @pi-deck/server",
|
|
20
|
+
"dev:client": "npm run dev -w @pi-deck/client",
|
|
21
|
+
"build": "npm run build -w @pi-deck/shared && npm run build -w @pi-deck/server && npm run build -w @pi-deck/client && node scripts/bundle-server.js",
|
|
22
|
+
"start": "npm run start -w @pi-deck/server",
|
|
23
|
+
"lint": "npm run lint --workspaces",
|
|
24
|
+
"typecheck": "npm run typecheck --workspaces",
|
|
25
|
+
"test": "npm run test --workspaces --if-present",
|
|
26
|
+
"test:client": "npm run test -w @pi-deck/client",
|
|
27
|
+
"test:server": "npm run test -w @pi-deck/server",
|
|
28
|
+
"test:e2e": "playwright test -c ./playwright.config.ts",
|
|
29
|
+
"test:coverage": "npm run test:coverage --workspaces --if-present",
|
|
30
|
+
"profile": "./scripts/profile-client.sh",
|
|
31
|
+
"profile:quick": "npx tsx scripts/quick-profile.ts",
|
|
32
|
+
"profile:streaming": "npx tsx scripts/quick-profile.ts --streaming",
|
|
33
|
+
"profile:baseline": "./scripts/profile-client.sh baseline",
|
|
34
|
+
"profile:memory": "./scripts/profile-client.sh memory",
|
|
35
|
+
"service:install": "./scripts/install-service.sh",
|
|
36
|
+
"service:uninstall": "./scripts/uninstall-service.sh",
|
|
37
|
+
"deploy": "./scripts/deploy.sh",
|
|
38
|
+
"background:start": "./scripts/start-background.sh start",
|
|
39
|
+
"background:stop": "./scripts/start-background.sh stop",
|
|
40
|
+
"background:status": "./scripts/start-background.sh status",
|
|
41
|
+
"background:logs": "./scripts/start-background.sh logs"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@playwright/test": "^1.58.1",
|
|
45
|
+
"@testing-library/jest-dom": "^6.9.1",
|
|
46
|
+
"@testing-library/react": "^16.3.2",
|
|
47
|
+
"@testing-library/user-event": "^14.6.1",
|
|
48
|
+
"@types/better-sqlite3": "^7.6.13",
|
|
49
|
+
"@types/cors": "^2.8.19",
|
|
50
|
+
"@types/express": "^5.0.6",
|
|
51
|
+
"@types/node": "^22.19.7",
|
|
52
|
+
"@types/react-dom": "^19.2.3",
|
|
53
|
+
"@types/react-syntax-highlighter": "^15.5.13",
|
|
54
|
+
"@types/ws": "^8.18.1",
|
|
55
|
+
"@vitest/coverage-v8": "^4.0.18",
|
|
56
|
+
"concurrently": "^9.2.1",
|
|
57
|
+
"@vitejs/plugin-react": "^5.1.2",
|
|
58
|
+
"autoprefixer": "^10.4.24",
|
|
59
|
+
"esbuild": "^0.27.3",
|
|
60
|
+
"happy-dom": "^20.5.0",
|
|
61
|
+
"postcss": "^8.5.6",
|
|
62
|
+
"jsdom": "^28.0.0",
|
|
63
|
+
"tailwindcss": "^3.4.17",
|
|
64
|
+
"typescript": "^5.7.3",
|
|
65
|
+
"vite": "^7.3.1",
|
|
66
|
+
"vitest": "^4.0.18"
|
|
67
|
+
},
|
|
68
|
+
"dependencies": {
|
|
69
|
+
"@mariozechner/pi-coding-agent": "^0.52.6",
|
|
70
|
+
"better-sqlite3": "^12.6.2",
|
|
71
|
+
"cors": "^2.8.5",
|
|
72
|
+
"express": "^4.21.2",
|
|
73
|
+
"ws": "^8.18.0",
|
|
74
|
+
"yaml": "^2.8.2"
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{r as f,j as s,h as w,o as d,M as j,a as y}from"./index-BIGMLGdI.js";const N=new Set(["ts","tsx","js","jsx","json","md","py","go","rs","java","c","cpp","h","css","html","yml","yaml","sh","zsh","toml","txt"]);function g(n){return n?/^www\./i.test(n)?!0:/^(https?:|mailto:|tel:)/i.test(n):!1}function h(n){var e;if(!n||n.startsWith("#")||g(n))return!1;const r=n.replace(/^file:\/\//i,"").split(/[?#]/)[0],a=r.includes(".")?(e=r.split(".").pop())==null?void 0:e.toLowerCase():"",t=!!(a&&N.has(a));return r.startsWith("/")||r.startsWith("./")||r.startsWith("../")||r.startsWith("~")||r.includes("/")||t}const k=/(?:\.\.?\/[\w./@-]+(?:\/[\w./@-]+)*|~\/[\w./@-]+(?:\/[\w./@-]+)*|\/[\w./@-]+(?:\/[\w./@-]+)+)/g;function m(n){if(typeof n=="string"){const i=[];let r=0,a;const t=new RegExp(k.source,"g");for(;(a=t.exec(n))!==null;){let e=a[0];for(;/[.,;:!?)}\]>]$/.test(e)&&e.length>1;)e=e.slice(0,-1);a.index>r&&i.push(n.slice(r,a.index));const o=e;i.push(s.jsx("button",{type:"button",className:"text-pi-accent hover:underline cursor-pointer bg-transparent border-none p-0 font-inherit text-inherit text-left inline",onClick:()=>window.dispatchEvent(new CustomEvent("pi:openFile",{detail:{path:o}})),title:`Open ${o}`,children:e},`fp-${a.index}`)),r=a.index+e.length}return i.length===0?n:(r<n.length&&i.push(n.slice(r)),i)}return Array.isArray(n)?n.map((i,r)=>{const a=m(i);return Array.isArray(a)?s.jsx("span",{children:a},r):a}):n}const v={...d,'pre[class*="language-"]':{...d['pre[class*="language-"]'],background:"#161b22",margin:0,padding:"12px",borderRadius:"4px",fontSize:"13px"},'code[class*="language-"]':{...d['code[class*="language-"]'],background:"transparent",fontSize:"13px"}},F=f.memo(function({content:i,className:r=""}){const a=f.useMemo(()=>({pre({children:t,...e}){return s.jsx("div",{className:"my-2",...e,children:t})},code({node:t,className:e,children:o,...l}){const p=/language-(\w+)/.exec(e||""),c=p?p[1]:"",b=String(o).replace(/\n$/,"");if(c||b.includes(`
|
|
2
|
+
`))return c?s.jsx(w,{style:v,language:c,PreTag:"div",...l,children:b}):s.jsx("pre",{className:"bg-[#161b22] p-3 rounded overflow-x-auto text-[13px]",children:s.jsx("code",{className:"text-pi-text",children:o})});const u=String(o);return h(u)?s.jsx("code",{className:"bg-[#161b22] px-1.5 py-0.5 rounded text-[13px] text-pi-accent hover:underline cursor-pointer",role:"button",tabIndex:0,title:`Open ${u}`,onClick:()=>{window.dispatchEvent(new CustomEvent("pi:openFile",{detail:{path:u}}))},onKeyDown:x=>{(x.key==="Enter"||x.key===" ")&&(x.preventDefault(),window.dispatchEvent(new CustomEvent("pi:openFile",{detail:{path:u}})))},...l,children:o}):s.jsx("code",{className:"bg-[#161b22] px-1.5 py-0.5 rounded text-[13px] text-pi-text",...l,children:o})},a({href:t,children:e,...o}){const l=g(t),p=h(t);return s.jsx("a",{href:t,target:l?"_blank":void 0,rel:l?"noopener noreferrer":void 0,className:"text-pi-accent hover:underline",onClick:c=>{!p||!t||(c.preventDefault(),window.dispatchEvent(new CustomEvent("pi:openFile",{detail:{path:t}})))},...o,children:e})},p({children:t,...e}){return s.jsx("p",{className:"mb-2 last:mb-0",...e,children:m(t)})},h1({children:t,...e}){return s.jsx("h1",{className:"text-lg font-semibold mb-2 mt-3 first:mt-0",...e,children:t})},h2({children:t,...e}){return s.jsx("h2",{className:"text-base font-semibold mb-2 mt-3 first:mt-0",...e,children:t})},h3({children:t,...e}){return s.jsx("h3",{className:"text-[14px] font-semibold mb-1 mt-2 first:mt-0",...e,children:t})},ul({children:t,...e}){return s.jsx("ul",{className:"list-disc pl-5 mb-2 space-y-0.5",...e,children:t})},ol({children:t,...e}){return s.jsx("ol",{className:"list-decimal pl-5 mb-2 space-y-0.5",...e,children:t})},li({children:t,...e}){return s.jsx("li",{className:"text-pi-text pl-1",...e,children:m(t)})},blockquote({children:t,...e}){return s.jsx("blockquote",{className:"border-l-2 border-pi-border pl-3 my-2 text-pi-muted italic",...e,children:t})},hr({...t}){return s.jsx("hr",{className:"border-pi-border my-3",...t})},table({children:t,...e}){return s.jsx("div",{className:"overflow-x-auto my-2",children:s.jsx("table",{className:"min-w-full border-collapse text-[13px]",...e,children:t})})},th({children:t,...e}){return s.jsx("th",{className:"border border-pi-border px-3 py-1.5 bg-pi-surface text-left font-semibold",...e,children:t})},td({children:t,...e}){return s.jsx("td",{className:"border border-pi-border px-3 py-1.5",...e,children:t})}}),[]);return s.jsx("div",{className:`markdown-content text-pi-text text-[14px] leading-relaxed ${r}`,children:s.jsx(j,{remarkPlugins:[y],components:a,children:i})})});export{F as MarkdownContent};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
*,:before,:after{--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 / .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: }::backdrop{--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 / .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: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-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]){-webkit-text-decoration:underline dotted;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,samp,pre{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,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:baseline}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:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-3{top:.75rem;right:.75rem;bottom:.75rem;left:.75rem}.inset-4{top:1rem;right:1rem;bottom:1rem;left:1rem}.-right-1{right:-.25rem}.-right-1\.5{right:-.375rem}.-top-1{top:-.25rem}.-top-1\.5{top:-.375rem}.bottom-full{bottom:100%}.left-0{left:0}.left-1\/2{left:50%}.left-2{left:.5rem}.left-3{left:.75rem}.right-0{right:0}.right-0\.5{right:.125rem}.right-1{right:.25rem}.right-3{right:.75rem}.top-0{top:0}.top-0\.5{top:.125rem}.top-1{top:.25rem}.top-1\/2{top:50%}.top-full{top:100%}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.-m-2{margin:-.5rem}.-mx-2{margin-left:-.5rem;margin-right:-.5rem}.-mx-4{margin-left:-1rem;margin-right:-1rem}.mx-\[8\.5px\]{margin-left:8.5px;margin-right:8.5px}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.-mb-\[1px\]{margin-bottom:-1px}.-mt-px{margin-top:-1px}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-3{margin-right:.75rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-3{margin-top:.75rem}.mt-\[2px\]{margin-top:2px}.mt-\[5px\]{margin-top:5px}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-full{height:100%}.max-h-48{max-height:12rem}.max-h-64{max-height:16rem}.max-h-80{max-height:20rem}.max-h-\[120px\]{max-height:120px}.max-h-\[200px\]{max-height:200px}.max-h-\[300px\]{max-height:300px}.max-h-\[420px\]{max-height:420px}.max-h-\[60px\]{max-height:60px}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.min-h-0{min-height:0px}.min-h-8{min-height:2rem}.min-h-\[21px\]{min-height:21px}.min-h-\[44px\]{min-height:44px}.w-0\.5{width:.125rem}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-72{width:18rem}.w-8{width:2rem}.w-\[120px\]{width:120px}.w-\[180px\]{width:180px}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[100px\]{min-width:100px}.min-w-\[120px\]{min-width:120px}.min-w-\[300px\]{min-width:300px}.min-w-\[44px\]{min-width:44px}.min-w-\[80px\]{min-width:80px}.min-w-full{min-width:100%}.max-w-2xl{max-width:42rem}.max-w-\[120px\]{max-width:120px}.max-w-\[140px\]{max-width:140px}.max-w-\[160px\]{max-width:160px}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-5{--tw-translate-x: 1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-col-resize{cursor:col-resize}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.cursor-row-resize{cursor:row-resize}.cursor-wait{cursor:wait}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.select-text{-webkit-user-select:text;-moz-user-select:text;user-select:text}.resize-none{resize:none}.resize{resize:both}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.gap-y-0\.5{row-gap:.125rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-pi-border>:not([hidden])~:not([hidden]){border-color:var(--pi-border)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-hidden{overflow-y:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.break-all{word-break:break-all}.rounded{border-radius:4px}.rounded-full{border-radius:9999px}.rounded-lg,.rounded-md{border-radius:4px}.rounded-sm{border-radius:2px}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-2{border-left-width:2px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-\[\#b5bd68\]{--tw-border-opacity: 1;border-color:rgb(181 189 104 / var(--tw-border-opacity, 1))}.border-green-500\/20{border-color:#22c55e33}.border-green-500\/40{border-color:#22c55e66}.border-green-500\/50{border-color:#22c55e80}.border-pi-accent{border-color:var(--pi-accent)}.border-pi-border{border-color:var(--pi-border)}.border-pi-border-focus{border-color:var(--pi-border-focus)}.border-pi-warning{border-color:var(--pi-warning)}.border-red-500\/20{border-color:#ef444433}.border-transparent{border-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-\[\#161b22\]{--tw-bg-opacity: 1;background-color:rgb(22 27 34 / var(--tw-bg-opacity, 1))}.bg-\[\#283a28\]{--tw-bg-opacity: 1;background-color:rgb(40 58 40 / var(--tw-bg-opacity, 1))}.bg-\[\#3a2828\]{--tw-bg-opacity: 1;background-color:rgb(58 40 40 / var(--tw-bg-opacity, 1))}.bg-\[\#b5bd68\]\/40{background-color:#b5bd6866}.bg-\[\#ff5c57\]\/40{background-color:#ff5c5766}.bg-amber-500\/20{background-color:#f59e0b33}.bg-amber-500\/60{background-color:#f59e0b99}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-green-500\/10{background-color:#22c55e1a}.bg-green-500\/20{background-color:#22c55e33}.bg-green-500\/5{background-color:#22c55e0d}.bg-green-500\/60{background-color:#22c55e99}.bg-orange-500\/20{background-color:#f9731633}.bg-pi-accent{background-color:var(--pi-accent)}.bg-pi-bg{background-color:var(--pi-bg)}.bg-pi-border{background-color:var(--pi-border)}.bg-pi-error{background-color:var(--pi-error)}.bg-pi-idle{background-color:var(--pi-idle)}.bg-pi-muted{background-color:var(--pi-muted)}.bg-pi-success{background-color:var(--pi-success)}.bg-pi-surface{background-color:var(--pi-surface)}.bg-pi-user-bg{background-color:var(--pi-user-bg)}.bg-pi-warning{background-color:var(--pi-warning)}.bg-purple-500\/10{background-color:#a855f71a}.bg-purple-500\/20{background-color:#a855f733}.bg-purple-500\/60{background-color:#a855f799}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/20{background-color:#ef444433}.bg-sky-500\/10{background-color:#0ea5e91a}.bg-sky-500\/20{background-color:#0ea5e933}.bg-sky-500\/60{background-color:#0ea5e999}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-\[3px\]{padding-top:3px;padding-bottom:3px}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pl-1{padding-left:.25rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.pl-6{padding-left:1.5rem}.pl-9{padding-left:2.25rem}.pl-\[18px\]{padding-left:18px}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-\[16px\]{font-size:16px}.text-\[20px\]{font-size:20px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.normal-case{text-transform:none}.italic{font-style:italic}.not-italic{font-style:normal}.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-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.tracking-normal{letter-spacing:0em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-\[\#00d7ff\]{--tw-text-opacity: 1;color:rgb(0 215 255 / var(--tw-text-opacity, 1))}.text-\[\#b5bd68\]{--tw-text-opacity: 1;color:rgb(181 189 104 / var(--tw-text-opacity, 1))}.text-\[\#b5bd68\]\/60{color:#b5bd6899}.text-\[\#ff5c57\]{--tw-text-opacity: 1;color:rgb(255 92 87 / var(--tw-text-opacity, 1))}.text-\[\#ff5c57\]\/60{color:#ff5c5799}.text-\[\#fff200\]{--tw-text-opacity: 1;color:rgb(255 242 0 / var(--tw-text-opacity, 1))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-inherit{color:inherit}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity, 1))}.text-pi-accent{color:var(--pi-accent)}.text-pi-bg{color:var(--pi-bg)}.text-pi-error{color:var(--pi-error)}.text-pi-muted{color:var(--pi-muted)}.text-pi-success{color:var(--pi-success)}.text-pi-text{color:var(--pi-text)}.text-pi-warning{color:var(--pi-warning)}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-400\/60{color:#f8717199}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/80{color:#fffc}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity, 1))}.line-through{text-decoration-line:line-through}.placeholder-pi-muted::-moz-placeholder{color:var(--pi-muted)}.placeholder-pi-muted::placeholder{color:var(--pi-muted)}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-30{opacity:.3}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px 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-none{outline:2px solid transparent;outline-offset:2px}.ring-1{--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(1px + 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)}.ring-2{--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(2px + 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)}.ring-inset{--tw-ring-inset: inset}.ring-pi-accent{--tw-ring-color: var(--pi-accent)}.ring-white\/10{--tw-ring-color: rgb(255 255 255 / .1)}.blur{--tw-blur: blur(8px);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)}.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)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.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-\[width\]{transition-property:width;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}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}:root{--pi-bg: #0a0f14;--pi-surface: #0d1117;--pi-border: #21262d;--pi-border-focus: #3b82f6;--pi-text: #e6edf3;--pi-muted: #7d8590;--pi-accent: #4a9eff;--pi-accent-hover: #79b8ff;--pi-success: #4ade80;--pi-warning: #facc15;--pi-error: #f87171;--pi-idle: #52525b;--pi-user: #79c0ff;--pi-user-bg: #1a3a4a;--pi-user-border: #2a3544;--pi-tool-bg: #12171d;--pi-tool-border: #1e2630;--pi-assistant-bg: transparent;--pi-thinking-bg: transparent;--pi-code-keyword: #ff7b72;--pi-code-string: #a5d6ff;--pi-code-comment: #8b949e;--pi-code-function: #d2a8ff;--pi-code-number: #79c0ff;--pi-code-operator: #79c0ff;--pi-code-variable: #ffa657;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--pi-text);background-color:var(--pi-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-secondary{font-size:11px}body{margin:0;height:100vh;height:100dvh;height:var(--viewport-height, 100dvh);overflow:hidden;background-color:var(--pi-bg);color:var(--pi-text)}#root{height:100vh;height:100dvh;height:var(--viewport-height, 100dvh);overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--pi-muted)}pre{margin:0;padding:0}code{font-family:inherit}.markdown-content h1,.markdown-content h2,.markdown-content h3{margin-top:.5em;margin-bottom:.25em;font-weight:600}.markdown-content p{margin-bottom:.25em}.markdown-content ul,.markdown-content ol{margin-left:1em;margin-bottom:.25em}.markdown-content li{margin-bottom:0}.markdown-content a{color:var(--pi-accent);text-decoration:underline}.markdown-content blockquote{border-left:1px solid var(--pi-border);padding-left:.5em;margin:.25em 0;color:var(--pi-muted)}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.cursor-blink{animation:cursor-blink 1s step-end infinite}@keyframes status-pulse{0%,to{opacity:.6}50%{opacity:1}}.status-running{animation:status-pulse 2s ease-in-out infinite}.pane-focused{border-color:var(--pi-border-focus)}.gap-grid{gap:8px}.p-grid{padding:8px}.m-grid{margin:8px}.p-pane{padding:12px}@media(max-width:768px){::-webkit-scrollbar{width:4px;height:4px}.scrollbar-thin::-webkit-scrollbar{height:2px}button[class*=w-full]{min-height:44px}input,textarea,select{font-size:16px}}html{-webkit-text-size-adjust:100%}@supports (padding-top: env(safe-area-inset-top)){.safe-area-top{padding-top:env(safe-area-inset-top)}}@supports (padding-bottom: env(safe-area-inset-bottom)){.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom)}}@media(hover:none){button:active{opacity:.7}}body{overscroll-behavior-y:contain}::-moz-selection{background-color:var(--pi-accent);color:var(--pi-bg)}::selection{background-color:var(--pi-accent);color:var(--pi-bg)}input::-moz-placeholder,textarea::-moz-placeholder{color:#484f58}input::placeholder,textarea::placeholder{color:#484f58}.placeholder\:text-pi-muted::-moz-placeholder{color:var(--pi-muted)}.placeholder\:text-pi-muted::placeholder{color:var(--pi-muted)}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-bottom-\[1px\]:after{content:var(--tw-content);bottom:-1px}.after\:left-0:after{content:var(--tw-content);left:0}.after\:right-0:after{content:var(--tw-content);right:0}.after\:h-\[2px\]:after{content:var(--tw-content);height:2px}.after\:bg-pi-accent:after{content:var(--tw-content);background-color:var(--pi-accent)}.first\:mt-0:first-child{margin-top:0}.last\:mb-0:last-child{margin-bottom:0}.last\:border-0:last-child{border-width:0px}.hover\:border-pi-accent:hover{border-color:var(--pi-accent)}.hover\:border-pi-muted:hover{border-color:var(--pi-muted)}.hover\:bg-green-500\/20:hover{background-color:#22c55e33}.hover\:bg-pi-accent:hover{background-color:var(--pi-accent)}.hover\:bg-pi-accent-hover:hover{background-color:var(--pi-accent-hover)}.hover\:bg-pi-bg:hover{background-color:var(--pi-bg)}.hover\:bg-pi-border:hover{background-color:var(--pi-border)}.hover\:bg-pi-surface:hover{background-color:var(--pi-surface)}.hover\:bg-purple-500\/20:hover{background-color:#a855f733}.hover\:bg-red-500\/10:hover{background-color:#ef44441a}.hover\:bg-red-500\/20:hover{background-color:#ef444433}.hover\:bg-sky-500\/20:hover{background-color:#0ea5e933}.hover\:text-pi-accent:hover{color:var(--pi-accent)}.hover\:text-pi-accent-hover:hover{color:var(--pi-accent-hover)}.hover\:text-pi-bg:hover{color:var(--pi-bg)}.hover\:text-pi-error:hover{color:var(--pi-error)}.hover\:text-pi-muted:hover{color:var(--pi-muted)}.hover\:text-pi-text:hover{color:var(--pi-text)}.hover\:text-red-400:hover{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:border-pi-accent:focus{border-color:var(--pi-accent)}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{--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(1px + 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)}.focus\:ring-2:focus{--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(2px + 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)}.focus\:ring-pi-accent:focus{--tw-ring-color: var(--pi-accent)}.active\:bg-pi-accent:active{background-color:var(--pi-accent)}.active\:bg-pi-surface:active{background-color:var(--pi-surface)}.active\:text-pi-accent:active{color:var(--pi-accent)}.active\:text-pi-bg:active{color:var(--pi-bg)}.active\:text-pi-text:active{color:var(--pi-text)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}@media(min-width:640px){.sm\:-m-1{margin:-.25rem}.sm\:m-0{margin:0}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:hidden{display:none}.sm\:h-10{height:2.5rem}.sm\:h-3{height:.75rem}.sm\:h-3\.5{height:.875rem}.sm\:h-5{height:1.25rem}.sm\:max-h-48{max-height:12rem}.sm\:w-3{width:.75rem}.sm\:w-3\.5{width:.875rem}.sm\:w-4{width:1rem}.sm\:w-5{width:1.25rem}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-1{gap:.25rem}.sm\:gap-2{gap:.5rem}.sm\:p-0{padding:0}.sm\:p-1{padding:.25rem}.sm\:p-1\.5{padding:.375rem}.sm\:px-2{padding-left:.5rem;padding-right:.5rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-\[14px\]{padding-left:14px;padding-right:14px}.sm\:py-1{padding-top:.25rem;padding-bottom:.25rem}.sm\:py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.sm\:py-2{padding-top:.5rem;padding-bottom:.5rem}.sm\:pl-\[14px\]{padding-left:14px}.sm\:pr-1{padding-right:.25rem}.sm\:text-\[10px\]{font-size:10px}.sm\:text-\[11px\]{font-size:11px}.sm\:text-\[12px\]{font-size:12px}.sm\:text-\[13px\]{font-size:13px}.sm\:text-\[14px\]{font-size:14px}.sm\:opacity-0{opacity:0}.group:hover .sm\:group-hover\:opacity-100{opacity:1}}@media(min-width:768px){.md\:inset-6{top:1.5rem;right:1.5rem;bottom:1.5rem;left:1.5rem}.md\:inset-auto{inset:auto}.md\:left-1\/2{left:50%}.md\:top-1\/2{top:50%}.md\:block{display:block}.md\:h-4{height:1rem}.md\:max-h-\[80vh\]{max-height:80vh}.md\:w-4{width:1rem}.md\:w-full{width:100%}.md\:max-w-lg{max-width:32rem}.md\:-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.md\:-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.md\:p-4{padding:1rem}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}.md\:px-4{padding-left:1rem;padding-right:1rem}.md\:py-1{padding-top:.25rem;padding-bottom:.25rem}.md\:py-2{padding-top:.5rem;padding-bottom:.5rem}.md\:opacity-0{opacity:0}.group:hover .md\:group-hover\:opacity-100{opacity:1}}@media(min-width:1024px){.lg\:inset-10{top:2.5rem;right:2.5rem;bottom:2.5rem;left:2.5rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:px-16{padding-left:4rem;padding-right:4rem}}.\[\&_p\]\:m-0 p{margin:0}.\[\&_p\]\:inline p{display:inline}
|