@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial;--tw-space-x-reverse:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-black:#000;--spacing:.25rem;--container-lg:32rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--ease-out:cubic-bezier(0,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:hsl(var(--background));--color-popover:hsl(var(--popover));--color-popover-foreground:hsl(var(--popover-foreground));--color-primary:hsl(var(--primary));--color-primary-foreground:hsl(var(--primary-foreground));--color-secondary:hsl(var(--secondary));--color-secondary-foreground:hsl(var(--secondary-foreground));--color-muted:hsl(var(--muted));--color-muted-foreground:hsl(var(--muted-foreground));--color-accent:hsl(var(--accent));--color-accent-foreground:hsl(var(--accent-foreground));--color-destructive:hsl(var(--destructive));--color-destructive-foreground:hsl(var(--destructive-foreground));--color-border:hsl(var(--border));--color-input:hsl(var(--input));--color-ring:hsl(var(--ring))}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing)*0)}.top-4{top:calc(var(--spacing)*4)}.top-\[50\%\]{top:50%}.right-4{right:calc(var(--spacing)*4)}.left-2{left:calc(var(--spacing)*2)}.left-\[50\%\]{left:50%}.isolate{isolation:isolate}.z-50{z-index:50}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.-mx-1{margin-inline:calc(var(--spacing)*-1)}.my-1{margin-block:calc(var(--spacing)*1)}.ml-auto{margin-left:auto}.\!inline{display:inline!important}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-2{height:calc(var(--spacing)*2)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-11{height:calc(var(--spacing)*11)}.h-px{height:1px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.w-2{width:calc(var(--spacing)*2)}.w-3\.5{width:calc(var(--spacing)*3.5)}.w-4{width:calc(var(--spacing)*4)}.w-10{width:calc(var(--spacing)*10)}.w-full{width:100%}.max-w-lg{max-width:var(--container-lg)}.max-w-none{max-width:none}.min-w-\[8rem\]{min-width:8rem}.grow{flex-grow:1}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:--radix-dropdown-menu-content-transform-origin}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x)var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-default{cursor:default}.resize{resize:both}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1.5)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1.5)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.border-input{border-color:var(--color-input)}.bg-background{background-color:var(--color-background)}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black)80%,transparent)}}.bg-destructive{background-color:var(--color-destructive)}.bg-muted{background-color:var(--color-muted)}.bg-popover{background-color:var(--color-popover)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.fill-current{fill:currentColor}.p-1{padding:calc(var(--spacing)*1)}.p-6{padding:calc(var(--spacing)*6)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.pr-2{padding-right:calc(var(--spacing)*2)}.pl-8{padding-left:calc(var(--spacing)*8)}.text-center{text-align:center}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.text-destructive-foreground{color:var(--color-destructive-foreground)}.text-muted-foreground{color:var(--color-muted-foreground)}.text-popover-foreground{color:var(--color-popover-foreground)}.text-primary{color:var(--color-primary)}.text-primary-foreground{color:var(--color-primary-foreground)}.text-secondary-foreground{color:var(--color-secondary-foreground)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.underline-offset-4{text-underline-offset:4px}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--color-background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--color-accent)}.hover\:bg-destructive\/90:hover{background-color:color-mix(in srgb,hsl(var(--destructive))90%,transparent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--color-destructive)90%,transparent)}}.hover\:bg-primary\/90:hover{background-color:color-mix(in srgb,hsl(var(--primary))90%,transparent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--color-primary)90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:color-mix(in srgb,hsl(var(--secondary))80%,transparent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--color-secondary)80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:bg-accent:focus{background-color:var(--color-accent)}.focus\:text-accent-foreground:focus{color:var(--color-accent-foreground)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--color-ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-accent)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--color-muted-foreground)}@media(min-width:40rem){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}:where(.sm\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*2)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:var(--radius-lg)}.sm\:text-left{text-align:left}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}}:root{--background:0 0% 100%;--foreground:222.2 84% 4.9%;--card:0 0% 100%;--card-foreground:222.2 84% 4.9%;--popover:0 0% 100%;--popover-foreground:222.2 84% 4.9%;--primary:222.2 47.4% 11.2%;--primary-foreground:210 40% 98%;--secondary:210 40% 96.1%;--secondary-foreground:222.2 47.4% 11.2%;--muted:210 40% 96.1%;--muted-foreground:215.4 16.3% 46.9%;--accent:210 40% 96.1%;--accent-foreground:222.2 47.4% 11.2%;--destructive:0 84.2% 60.2%;--destructive-foreground:210 40% 98%;--border:214.3 31.8% 91.4%;--input:214.3 31.8% 91.4%;--ring:222.2 84% 4.9%;--radius:.5rem}.dark{--background:222.2 84% 4.9%;--foreground:210 40% 98%;--card:222.2 84% 4.9%;--card-foreground:210 40% 98%;--popover:222.2 84% 4.9%;--popover-foreground:210 40% 98%;--primary:210 40% 98%;--primary-foreground:222.2 47.4% 11.2%;--secondary:217.2 32.6% 17.5%;--secondary-foreground:210 40% 98%;--muted:217.2 32.6% 17.5%;--muted-foreground:215 20.2% 65.1%;--accent:217.2 32.6% 17.5%;--accent-foreground:210 40% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:210 40% 98%;--border:217.2 32.6% 17.5%;--input:217.2 32.6% 17.5%;--ring:212.7 26.8% 83.9%}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground));margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.app-root{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-root>main.workspace-page-layout{flex:1;min-height:0;overflow:hidden}.app-root>main:not(.workspace-page-layout){flex:1;min-height:0;overflow-y:auto}.authenticated-header{z-index:1000;pointer-events:auto;background:hsl(var(--background));border-bottom:1px solid hsl(var(--border));flex-shrink:0;padding:.75rem 1.5rem}.header-nav{justify-content:space-between;align-items:center;gap:1rem;display:flex}.header-left{align-items:center;gap:1.5rem;display:flex}.header-left .logo{font-size:1.125rem;font-weight:600}.header-right{align-items:center;gap:1rem;display:flex}.nav-links{align-items:center;gap:.5rem;display:flex}.nav-link{border-radius:var(--radius);color:hsl(var(--muted-foreground));padding:.5rem .75rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link:hover{background:hsl(var(--accent));color:hsl(var(--foreground))}.nav-link.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.credits-text{color:hsl(var(--muted-foreground));font-size:.875rem}.nav-btn{border-radius:var(--radius);cursor:pointer;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.secondary-btn{border:1px solid hsl(var(--border));color:hsl(var(--foreground));background:0 0}.secondary-btn:hover{background:hsl(var(--accent))}.authenticated-header nav{align-items:center;gap:1rem;display:flex}.authenticated-header a{color:hsl(var(--foreground));border-radius:var(--radius);padding:.5rem .75rem;font-weight:500;text-decoration:none;transition:background-color .2s}.authenticated-header a:hover{background:hsl(var(--accent))}.authenticated-header a.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.projects-container{max-width:80rem;margin:0 auto;padding:2rem}.projects-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.projects-header h2{color:hsl(var(--foreground));font-size:1.875rem;font-weight:700}.projects-grid{grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem;display:grid}@media(min-width:768px){.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.projects-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.project-card{background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:var(--radius);padding:1.5rem;transition:box-shadow .2s,transform .2s}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.project-card-header{margin-bottom:1rem}.project-title{color:hsl(var(--card-foreground));margin-bottom:.75rem;font-size:1.25rem;font-weight:600}.project-badges{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.project-badge{border-radius:calc(var(--radius) - 2px);background:hsl(var(--secondary));color:hsl(var(--secondary-foreground));align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.tier-badge{color:#7c3bed;background:#7c3bed26}.framework-badge{color:#21c45d;background:#21c45d26}.deployment-badge{color:#0da2e7;background:#0da2e726}.project-repo{margin-bottom:.5rem}.project-repo a{color:#3c83f6;font-size:.875rem;text-decoration:none}.project-repo a:hover{text-decoration:underline}.project-activity,.project-stats{color:hsl(var(--muted-foreground));margin-bottom:.25rem;font-size:.875rem}.project-card-actions{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.project-card-actions-row{gap:.5rem;display:flex}.open-project-btn{width:100%}.empty-state{text-align:center;color:hsl(var(--muted-foreground));padding:4rem 2rem}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem;display:flex}.loading-spinner{border:2px solid hsl(var(--border));border-top-color:hsl(var(--primary));border-radius:50%;width:2rem;height:2rem;animation:1s linear infinite spin}.loading-text{color:hsl(var(--muted-foreground))}.workspace-page-layout{flex-direction:column;flex:1;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.workspace-split-full{z-index:1;flex:1;width:100%;min-height:0;margin:0;padding:0;display:flex;position:relative;overflow:hidden}.workspace-chat-panel{border-right:1px solid hsl(var(--border));color:#fff;background:#020817;flex-direction:column;flex:0 0 50%;width:50%;min-width:0;max-width:50%;height:100%;display:flex;position:relative;overflow:hidden}.workspace-chat-header{box-sizing:border-box;background:#151c29;border-bottom:1px solid #1e293b;flex-shrink:0;align-items:center;height:56px;padding:.75rem 1rem;display:flex}.workspace-chat-title-section{flex-wrap:nowrap;align-items:center;gap:.75rem;width:100%;min-width:0;display:flex;overflow:hidden}.workspace-project-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0;font-size:.75rem;font-weight:600;overflow:hidden}.workspace-badges{flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:.5rem;display:flex}.workspace-repo-link{white-space:nowrap;text-overflow:ellipsis;color:#85b2f9;max-width:180px;font-size:.75rem;overflow:hidden}.workspace-chat-banners{flex-shrink:0;overflow:hidden}.workspace-chat-content{color:#e0e0e0;background:#020817;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.workspace-chat-content .chat-main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.workspace-chat-content .chat-wrapper{flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.workspace-chat-content .chat-messages{flex:1;min-height:0;padding:1rem 1.5rem;overflow-y:auto}.workspace-chat-content .chat-input-container{background:#020817;border-top:1px solid #1e293b;flex-shrink:0;padding:1rem 1.5rem}.workspace-chat-content .chat-input-wrapper{border-radius:var(--radius);background:#151c29;align-items:flex-end;gap:.5rem;padding:.5rem;display:flex}.workspace-chat-content .chat-input{color:#fff;resize:none;background:0 0;border:none;outline:none;flex:1;min-height:24px;max-height:200px;padding:.5rem .75rem;font-size:.9375rem;line-height:1.5}.workspace-chat-content .chat-input:focus{outline:none}.workspace-chat-content .chat-input::-moz-placeholder{color:#888}.workspace-chat-content .chat-input::placeholder{color:#888}.workspace-chat-content .send-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:#3c83f6;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;padding:0;display:flex}.workspace-chat-content .send-btn:hover:not(:disabled){background:#0b64f4}.workspace-chat-content .send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-input-disclaimer{color:#888;text-align:center;box-sizing:border-box;background:0 0;width:100%;margin-top:.5rem;padding:0;font-size:.75rem;line-height:1.4;display:block}.workspace-right-panel{background:hsl(var(--background));flex-direction:column;flex:1;min-width:0;height:100%;display:flex;overflow:hidden}.vnc-viewer-container{background:#1a1a1a;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.vnc-toolbar{color:#fff;box-sizing:border-box;background:#151c29;border-bottom:1px solid #1e293b;align-items:center;gap:1rem;height:56px;padding:.75rem 1rem;font-size:.875rem;display:flex}.vnc-status-indicator{font-weight:500}.vnc-connection-info{color:hsl(var(--muted-foreground));font-size:.75rem}.vnc-toolbar-actions{gap:.5rem;margin-left:auto;display:flex}.vnc-btn{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-radius:var(--radius);cursor:pointer;border:none;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:background-color .2s}.vnc-btn:hover{opacity:.9}.vnc-error{color:#ef4444;background:#ef44441a;padding:.5rem 1rem;font-size:.875rem}.vnc-canvas-container{flex:1;overflow:hidden}.vnc-status{color:hsl(var(--muted-foreground));justify-content:center;align-items:center;display:flex}.chat-message{margin-bottom:1rem}.chat-message-user{text-align:right}.chat-message-ai{text-align:left}.chat-message-content{border-radius:var(--radius);max-width:80%;padding:.75rem 1rem;display:inline-block}.chat-message-user .chat-message-content{color:#fff;background:#3c83f6}.chat-message-ai .chat-message-content{color:#e0e0e0;background:#1e293b}.welcome-message{color:#fff}.welcome-message h2{color:#fff;margin-bottom:.5rem;font-size:1.25rem}.welcome-message p{color:#b0b0b0}.welcome-message ul{margin-top:.5rem;padding-left:1.5rem}.welcome-message li{color:#e0e0e0;margin-bottom:.25rem}.workspace-tabs{background:#111822;border-bottom:1px solid #1e293b;flex-shrink:0;gap:0;padding:0 1rem;display:flex}.workspace-tab{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.workspace-tab:hover{color:#fff;background:#18212f}.workspace-tab.active{color:#fff;background:#151c29;border-bottom-color:#3c83f6}.workspace-tab svg{opacity:.7}.workspace-tab.active svg{opacity:1}.workspace-tab-badge{color:#fff;background:#21c45d;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.625rem;font-weight:700;display:inline-flex}.prd-chat{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.prd-chat-wrapper{flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.prd-chat-messages{flex:1;min-height:0;padding:1rem 1.5rem;overflow-y:auto}.prd-chat-message{margin-bottom:1rem}.prd-chat-message-user{text-align:right}.prd-chat-message-assistant{text-align:left}.prd-chat-message-content{border-radius:var(--radius);text-align:left;max-width:85%;padding:.75rem 1rem;display:inline-block}.prd-chat-message-user .prd-chat-message-content{color:#fff;background:#3c83f6}.prd-chat-message-assistant .prd-chat-message-content{color:#e0e0e0;background:#1e293b}.prd-chat-message-content ul{margin:.5rem 0;padding-left:1.25rem}.prd-chat-message-content li{margin-bottom:.25rem}.prd-chat-message-content .prose{color:inherit}.prd-chat-message-content .prose p{margin:.5rem 0}.prd-chat-message-content .prose p:first-child{margin-top:0}.prd-chat-message-content .prose p:last-child{margin-bottom:0}.prd-chat-message-content .prose code{background:#ffffff1a;border-radius:.25rem;padding:.125rem .25rem;font-size:.875em}.prd-chat-message-content .prose pre{border-radius:var(--radius);background:#0000004d;margin:.5rem 0;padding:.75rem;overflow-x:auto}.prd-chat-message-content .prose pre code{background:0 0;padding:0}.prd-chat-input-container{background:#020817;border-top:1px solid #1e293b;flex-direction:column;flex-shrink:0;padding:1rem 1.5rem;display:flex}.prd-chat-input-container .chat-input-disclaimer{color:#888;text-align:center;box-sizing:border-box;background:0 0;width:100%;margin-top:.5rem;padding:0;font-size:.75rem;line-height:1.4;display:block}.prd-welcome-message{text-align:center;color:#b0b0b0;padding:2rem}.prd-welcome-message h2{color:#fff;margin-bottom:.75rem;font-size:1.25rem}.prd-welcome-message p{margin-bottom:.5rem}.prd-chat-error{color:#ef4444;border-radius:var(--radius);background:#ef444426;margin:.5rem 1.5rem;padding:.75rem 1rem;font-size:.875rem}.prd-typing{gap:.25rem;display:flex;padding:1rem!important}.prd-typing-dot{background:#888;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite both prdTyping}.prd-typing-dot:first-child{animation-delay:-.32s}.prd-typing-dot:nth-child(2){animation-delay:-.16s}.prd-typing-dot:nth-child(3){animation-delay:0s}@keyframes prdTyping{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.prd-viewer{color:#e0e0e0;background:#020817;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.prd-viewer-header{box-sizing:border-box;background:#151c29;border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;height:56px;padding:.75rem 1rem;display:flex}.prd-viewer-title{color:#fff;margin:0;font-size:.875rem;font-weight:600}.prd-viewer-progress{background:#111822;border-bottom:1px solid #1e293b;padding:1rem}.prd-viewer-content{flex:1;min-height:0;padding:1.5rem;overflow-y:auto}.prd-viewer-actions{text-align:center;background:#111822;border-top:1px solid #1e293b;padding:1rem}.prd-document{font-size:.9rem;line-height:1.6}.prd-document h1{color:#fff;margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.prd-document h2{color:#fff;margin-top:1.5rem;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.prd-document h3{color:#e0e0e0;margin-top:1rem;margin-bottom:.5rem;font-size:1rem;font-weight:600}.prd-document hr{border:none;border-top:1px solid #2b3b55;margin:1rem 0}.prd-document table{border-collapse:collapse;width:100%;margin:.75rem 0}.prd-document th,.prd-document td{text-align:left;border:1px solid #2b3b55;padding:.5rem}.prd-document th{background:#1a2333;font-weight:600}.prd-progress-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.prd-progress-count{color:#888;font-size:.75rem}.prd-progress-complete{color:#21c45d;font-size:.75rem;font-weight:600}.prd-progress-phases{gap:.25rem;margin-bottom:1rem;display:flex}.prd-phase{flex-direction:column;flex:1;align-items:center;gap:.25rem;display:flex}.prd-phase-indicator{color:#888;background:#222f44;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.625rem;font-weight:600;display:flex}.prd-phase.filled .prd-phase-indicator{color:#fff;background:#21c45d}.prd-phase.current .prd-phase-indicator{color:#fff;background:#3c83f6}.prd-phase-label{color:#888;text-align:center;font-size:.625rem}.prd-phase.filled .prd-phase-label,.prd-phase.current .prd-phase-label{color:#e0e0e0}.prd-sections-list{flex-wrap:wrap;gap:.5rem;display:flex}.prd-section-item{border-radius:calc(var(--radius) - 2px);color:#888;background:#1a2333;align-items:center;gap:.375rem;padding:.25rem .5rem;font-size:.6875rem;display:flex}.prd-section-item.filled{color:#21c45d;background:#21c45d26}.prd-section-check{font-size:.625rem}.prd-export{gap:.5rem;display:flex}.prd-export-btn{border-radius:var(--radius);color:#e0e0e0;cursor:pointer;background:#1e293b;border:1px solid #2b3b55;align-items:center;gap:.375rem;padding:.375rem .625rem;font-size:.6875rem;font-weight:500;transition:all .2s;display:flex}.prd-export-btn:hover{background:#26344a;border-color:#344765}.prd-export-btn svg{opacity:.7}.prd-start-building-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:#21c45d;border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;transition:background-color .2s;display:inline-flex}.prd-start-building-btn:hover{background:#1eae53}.prd-start-building-hint{color:#888;margin-top:.5rem;font-size:.75rem}.workspace-chat-panel.prd-mode{background:#020817}.workspace-right-panel.prd-mode{background:#020817;border-left:1px solid #1e293b}.prd-saving-indicator{color:#3c83f6;margin-left:.75rem;font-size:.75rem;animation:1.5s ease-in-out infinite prd-saving-pulse}@keyframes prd-saving-pulse{0%,to{opacity:.5}50%{opacity:1}}.prd-context-banner{background:#22c55e1a;border-bottom:1px solid #22c55e33;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.prd-context-label{color:#22c55e;font-size:14px;font-weight:500}.prd-context-clear{color:#888;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:4px;padding:4px 8px;font-size:12px;transition:background-color .2s}.prd-context-clear:hover{color:#fff;background:#ffffff1a}.landing-page{background:hsl(var(--background));flex-direction:column;min-height:100vh;display:flex;overflow-y:auto}.landing-header{border-bottom:1px solid hsl(var(--border));padding:1.5rem 2rem}.header-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.header-left .logo{color:hsl(var(--foreground));margin:0;font-size:1.5rem;font-weight:700}.header-right{align-items:center;display:flex}.login-button{border:1px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));color:hsl(var(--foreground));cursor:pointer;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;transition:all .2s}.login-button:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--accent))}.login-button:disabled{opacity:.5;cursor:not-allowed}.hero{flex:1;justify-content:center;align-items:flex-start;min-height:0;padding:2rem;display:flex}.hero-content-wrapper{text-align:center;width:100%;max-width:800px}.hero-title{color:hsl(var(--foreground));margin-bottom:1rem;font-size:3rem;font-weight:700}.hero-subtitle{color:hsl(var(--muted-foreground));margin-bottom:2rem;font-size:1.25rem}.quick-start-form{margin-top:1.5rem}.error-message{background:hsl(var(--destructive)/.1);border:1px solid hsl(var(--destructive));border-radius:var(--radius);color:hsl(var(--destructive));margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.info-message{background:hsl(var(--primary)/.1);border:1px solid hsl(var(--primary));border-radius:var(--radius);color:hsl(var(--primary));margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.landing-chat-input-container{margin-bottom:1.5rem}.landing-chat-input-wrapper{border-radius:var(--radius);background:#151c29;flex-direction:column;padding:.75rem;display:flex}.prompt-action-buttons{border-top:1px solid hsl(var(--border)/.3);justify-content:space-between;align-items:center;margin-top:.5rem;padding:.5rem .25rem 0;display:flex}.prompt-action-buttons-left,.prompt-action-buttons-right{align-items:center;gap:.5rem;display:flex}.prompt-action-btn{border-radius:var(--radius);color:hsl(var(--muted-foreground));cursor:pointer;opacity:.6;background:0 0;border:none;padding:.375rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s}.prompt-action-btn:hover:not(:disabled){background:hsl(var(--accent));color:hsl(var(--accent-foreground));opacity:1}.prompt-action-btn:disabled{cursor:default}.prompt-action-btn-icon{border-radius:var(--radius);color:hsl(var(--muted-foreground));cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:.375rem;transition:all .2s;display:flex}.prompt-action-btn-icon:hover:not(:disabled){background:hsl(var(--accent));color:hsl(var(--accent-foreground));opacity:1}.prompt-action-btn-icon:disabled{cursor:default}.landing-chat-input-wrapper .chat-input-wrapper{background:0 0;border-radius:0;align-items:flex-end;gap:.5rem;max-width:100%;padding:0;display:flex}.landing-chat-input-container .chat-input{color:#fff;resize:none;background:0 0;border:none;outline:none;flex:1;min-height:60px;max-height:200px;padding:.5rem .75rem;font-size:1rem;line-height:1.5}.landing-chat-input-container .chat-input:focus{outline:none}.landing-chat-input-container .chat-input::-moz-placeholder{color:#888}.landing-chat-input-container .chat-input::placeholder{color:#888}.landing-chat-input-container .send-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:#3c83f6;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;padding:0;display:flex}.landing-chat-input-container .send-btn:hover:not(:disabled){background:#0b64f4}.landing-chat-input-container .send-btn:disabled{opacity:.5;cursor:not-allowed}.landing-chat-input-container .chat-input-disclaimer{color:#888;text-align:center;box-sizing:border-box;background:0 0;width:100%;margin-top:.5rem;padding:0;font-size:.75rem;line-height:1.4;display:block}.auth-buttons-container{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:1.5rem;display:flex}.auth-modal-content{max-width:28rem;padding:2rem}.auth-modal-content [data-radix-dialog-title]{margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.auth-modal-content [data-radix-dialog-description]{margin-bottom:1.5rem;font-size:.875rem}.auth-modal-buttons{flex-direction:column;gap:.75rem;display:flex}.auth-modal-buttons .auth-btn{width:100%;min-width:unset;border:1px solid hsl(var(--border));background:hsl(var(--background));color:hsl(var(--foreground));cursor:pointer;border-radius:.5rem;justify-content:center;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9375rem;font-weight:500;transition:all .2s;display:flex;position:relative}.auth-modal-buttons .auth-icon{flex-shrink:0;position:absolute;left:1rem}.auth-modal-buttons .auth-btn:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--ring))}.auth-modal-buttons .email-btn{background:hsl(var(--foreground));color:hsl(var(--background))}.auth-modal-buttons .email-btn:hover:not(:disabled){background:hsl(var(--foreground)/.9)}.auth-modal-separator{align-items:center;gap:.75rem;margin:.5rem 0;display:flex}.auth-modal-separator-line{background:hsl(var(--border));flex:1;height:1px}.auth-modal-separator-text{color:hsl(var(--muted-foreground));padding:0 .5rem;font-size:.875rem}.auth-modal-disclaimer{color:hsl(var(--muted-foreground));text-align:center;margin-top:1.5rem;font-size:.75rem;line-height:1.5}.holding-page{background:hsl(var(--background));justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.holding-page-content{text-align:center;width:100%;max-width:500px}.holding-page-title{color:hsl(var(--foreground));margin-bottom:1rem;font-size:2rem;font-weight:700}.holding-page-description{color:hsl(var(--muted-foreground));margin-bottom:2rem;font-size:1rem;line-height:1.5}.holding-page-error{background:hsl(var(--destructive)/.1);border:1px solid hsl(var(--destructive));border-radius:var(--radius);color:hsl(var(--destructive));margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem}.holding-page-button{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-radius:var(--radius);cursor:pointer;border:none;min-width:200px;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .2s}.holding-page-button:hover:not(:disabled){background:hsl(var(--primary)/.9);transform:translateY(-1px)}.holding-page-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-btn{border:2px solid hsl(var(--border));border-radius:var(--radius);background:hsl(var(--background));min-width:200px;color:hsl(var(--foreground));cursor:pointer;flex:1;justify-content:center;align-items:center;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.auth-btn:hover:not(:disabled){background:hsl(var(--accent));border-color:hsl(var(--ring))}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.google-btn:hover:not(:disabled){background:#f8f9fa;border-color:#4285f4}.microsoft-btn:hover:not(:disabled){background:#f8f9fa;border-color:#0078d4}.github-btn:hover:not(:disabled){background:#f8f9fa;border-color:#24292e}.loading-indicator{flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;display:flex}.loading-indicator .loading-spinner{border:3px solid hsl(var(--border));border-top-color:hsl(var(--primary));border-radius:50%;width:2rem;height:2rem;animation:1s linear infinite spin}.loading-indicator p{color:hsl(var(--muted-foreground));font-size:.875rem}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}.generation-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.loader-title{font-size:1.25rem;font-weight:600;color:#f0f0f0;margin-bottom:.75rem}.loader-stage{min-height:1.5rem;margin-bottom:1.5rem;transition:opacity .15s ease}.loader-stage.transitioning{opacity:.5}.stage-text{font-size:1rem;color:#9ca3af;font-weight:400}.shimmer{background:linear-gradient(90deg,#9ca3af 0% 40%,#e0e0e0 50%,#9ca3af 60% 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.loader-progress{margin-top:.5rem}.progress-dots{display:flex;gap:6px;justify-content:center}.progress-dot{width:6px;height:6px;border-radius:50%;background:#374151;transition:all .3s ease}.progress-dot.completed{background:hsl(var(--foreground));opacity:.6}.progress-dot.active{background:hsl(var(--foreground));opacity:1;transform:scale(1.3);box-shadow:0 0 8px hsla(var(--foreground),.3)}.generation-result{background:#1e293b;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #0003;max-width:100%}.result-header{padding:1.5rem 2rem;border-bottom:1px solid #334155}.result-title{font-size:1.5rem;font-weight:700;color:#f1f5f9;margin:0 0 .5rem}.result-description{font-size:1rem;color:#94a3b8;margin:0;line-height:1.5}.result-content{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid #334155}.result-preview{padding:2rem;display:flex;align-items:center;justify-content:center;border-right:1px solid #334155;background:#0f172a}.device-frame{width:100%;max-width:260px}.device-bezel{background:linear-gradient(145deg,#1e293b,#0f172a);border-radius:16px;padding:12px;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0d}.device-screen{background:#020617;border-radius:10px;aspect-ratio:800 / 480;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.device-screen:before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 20%,rgba(59,130,246,.03) 40%,rgba(59,130,246,.06) 50%,rgba(59,130,246,.03) 60%,transparent 80%);background-size:200% 100%;animation:shimmer-screen 3s ease-in-out infinite}@keyframes shimmer-screen{0%{background-position:100% 0}to{background-position:-100% 0}}.screen-loading,.screen-ready,.screen-error{display:flex;flex-direction:column;align-items:center;gap:.75rem;z-index:1}.loading-spinner{width:36px;height:36px;border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#3b82f6;font-size:.875rem;font-weight:500}.ready-icon{width:48px;height:48px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.ready-text{color:#10b981;font-size:.875rem;font-weight:500}.screen-error span{color:#ef4444;font-size:.875rem}.device-branding{padding-top:10px;text-align:center}.unloop-logo{font-family:system-ui,-apple-system,sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.25em;color:#94a3b866;text-transform:uppercase}.result-config{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.config-section{display:flex;flex-direction:column;gap:.75rem}.config-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin:0;padding-bottom:.5rem;border-bottom:1px solid #334155}.config-grid{display:flex;flex-direction:column;gap:.625rem}.config-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.config-label{font-size:.875rem;color:#64748b;flex-shrink:0}.config-value{font-size:.875rem;color:#e2e8f0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;text-align:right}.config-value strong{color:#f1f5f9}.config-value.capitalize{text-transform:capitalize}.config-detail{color:#64748b;font-size:.8125rem}.config-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700;letter-spacing:.05em}.config-badge.tier{background:#3b0764;color:#c084fc}.config-badge.framework{background:#1e3a5f;color:#60a5fa}.config-badge.language{background:#7c2d12;color:#fb923c}.result-actions{padding:1.25rem 2rem;display:flex;justify-content:space-between;gap:1rem}.btn-secondary,.btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:.875rem 1.5rem;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s ease;border:none}.btn-secondary{background:#334155;border:1px solid #475569;color:#e2e8f0}.btn-secondary:hover{background:#475569;border-color:#64748b}.btn-primary{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.btn-secondary svg,.btn-primary svg{flex-shrink:0}@media(max-width:768px){.result-content{grid-template-columns:1fr}.result-preview{border-right:none;border-bottom:1px solid #334155;padding:1.5rem}.device-frame{max-width:220px}.result-config{padding:1.5rem}.result-actions{flex-direction:column}.btn-secondary,.btn-primary{width:100%}}.generation-result.compact{background:#1e293b;border-radius:12px;overflow:hidden;box-shadow:0 4px 24px #0003;max-width:100%}.compact .result-header{padding:1rem 1.5rem;border-bottom:1px solid #334155}.compact .result-title{font-size:1.125rem;font-weight:600;color:#f1f5f9;margin:0;display:flex;align-items:baseline;flex-wrap:wrap;gap:.5rem;line-height:1.4}.compact .title-separator{color:#475569;font-weight:400}.compact .result-description{font-weight:400;color:#94a3b8;font-size:1rem}.compact .result-content{display:grid;grid-template-columns:auto 1fr;border-bottom:1px solid #334155}.compact .result-preview{padding:1.25rem;display:flex;align-items:center;justify-content:center;border-right:1px solid #334155;background:#0f172a}.compact .device-frame{width:200px}.compact .device-bezel{background:linear-gradient(145deg,#1e293b,#0f172a);border-radius:12px;padding:8px;box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff0d}.compact .device-screen{background:#020617;border-radius:8px;aspect-ratio:800 / 480;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.compact .device-screen:before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 20%,rgba(59,130,246,.03) 40%,rgba(59,130,246,.06) 50%,rgba(59,130,246,.03) 60%,transparent 80%);background-size:200% 100%;animation:shimmer-screen 3s ease-in-out infinite}.compact .screen-loading,.compact .screen-ready,.compact .screen-error{display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:1}.compact .loading-spinner{width:28px;height:28px;border:2px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.compact .loading-text{color:#3b82f6;font-size:.75rem;font-weight:500}.compact .ready-icon{width:36px;height:36px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.compact .ready-text{color:#10b981;font-size:.75rem;font-weight:500}.compact .screen-error span{color:#ef4444;font-size:.75rem}.compact .device-branding{padding-top:6px;text-align:center}.compact .unloop-logo{font-family:system-ui,-apple-system,sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.25em;color:#94a3b859;text-transform:uppercase}.compact .result-config{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.compact .config-section{display:flex;flex-direction:column;gap:.5rem}.compact .config-section-title{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin:0}.compact .config-grid{display:flex;flex-direction:column;gap:.375rem}.compact .config-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.compact .config-label{font-size:.8125rem;color:#64748b;flex-shrink:0}.compact .config-value{font-size:.8125rem;color:#e2e8f0;display:flex;align-items:center;gap:.375rem;flex-wrap:wrap;justify-content:flex-end}.compact .config-text-muted{color:#94a3b8;font-size:.8125rem}.compact .config-badge{display:inline-block;padding:.125rem .375rem;border-radius:3px;font-size:.625rem;font-weight:700;letter-spacing:.03em}.compact .config-badge.tier{background:#3b0764;color:#c084fc}.compact .config-badge.framework{background:#1e3a5f;color:#60a5fa}.compact .config-badge.language{background:#7c2d12;color:#fb923c}.compact .app-summary{font-size:.875rem;color:#e2e8f0;margin:0;display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}.compact .app-summary strong{color:#f1f5f9}.compact .summary-dot{color:#475569;margin:0 .25rem}.compact .capitalize{text-transform:capitalize}.compact .result-actions{padding:1rem 1.5rem;display:flex;justify-content:space-between;gap:1rem}.compact .btn-secondary,.compact .btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;border:none}.compact .btn-secondary{background:#334155;border:1px solid #475569;color:#e2e8f0}.compact .btn-secondary:hover{background:#475569;border-color:#64748b}.compact .btn-primary{background:#3b82f6;border:1px solid #3b82f6;color:#fff}.compact .btn-primary:hover{background:#2563eb;border-color:#2563eb}@media(max-width:640px){.compact .result-content{grid-template-columns:1fr}.compact .result-preview{border-right:none;border-bottom:1px solid #334155;padding:1rem}.compact .device-frame{width:180px}.compact .result-config{padding:1rem}.compact .result-title{flex-direction:column;gap:.25rem}.compact .title-separator{display:none}.compact .result-actions{flex-direction:column;padding:1rem}}.prd-detail-viewer{padding:1.5rem;color:#e0e0e0}.prd-header{margin-bottom:2rem}.prd-header h1{font-size:1.75rem;margin-bottom:.5rem}.prd-meta{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.status-badge,.phase-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:uppercase}.status-draft{background:#374151;color:#9ca3af}.status-review{background:#1e3a5f;color:#60a5fa}.status-approved{background:#14532d;color:#4ade80}.phase-poc{background:#3b0764;color:#c084fc}.phase-mvp{background:#1e3a8a;color:#60a5fa}.phase-production{background:#14532d;color:#4ade80}.phase-manufacturing{background:#7c2d12;color:#fb923c}.completeness{color:#9ca3af;font-size:.875rem}.prd-description{color:#9ca3af;margin-bottom:.5rem}.category-tag{display:inline-block;padding:.125rem .5rem;background:#1f2937;border-radius:4px;font-size:.75rem;color:#9ca3af}.prd-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #374151}.prd-section h2{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;margin-bottom:1rem}.prd-section h2 .icon{font-size:1.25rem}.prd-section h2 .count{background:#374151;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:400}.screens-list{display:flex;flex-direction:column;gap:.75rem}.screen-card{background:#1f2937;border-radius:8px;overflow:hidden}.screen-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .15s}.screen-header:hover{background:#374151}.screen-icon{font-size:1.25rem}.screen-title{flex:1;font-weight:500}.screen-template{padding:.125rem .5rem;background:#374151;border-radius:4px;font-size:.75rem;color:#9ca3af}.expand-icon{color:#6b7280;font-size:.75rem}.screen-content{padding:1rem;border-top:1px solid #374151;background:#111827}.template-params{display:flex;flex-direction:column;gap:1rem}.param-group h4{font-size:.875rem;color:#9ca3af;margin-bottom:.5rem}.metrics-grid,.status-grid{display:flex;flex-wrap:wrap;gap:.5rem}.metric-chip,.status-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#1f2937;border-radius:6px}.metric-label,.status-label{font-weight:500}.metric-key,.status-key{font-size:.75rem;color:#60a5fa}.metric-unit{color:#6b7280;font-size:.875rem}.status-level{padding:.125rem .375rem;border-radius:4px;font-size:.625rem;text-transform:uppercase}.level-ok{background:#14532d;color:#4ade80}.level-warning{background:#713f12;color:#fbbf24}.level-error{background:#7f1d1d;color:#f87171}.actions-list{display:flex;flex-wrap:wrap;gap:.5rem}.action-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#1f2937;border-radius:6px;border:1px solid #374151}.action-chip.primary{border-color:#3b82f6;background:#1e3a5f}.action-label{font-weight:500}.action-id{font-size:.75rem;color:#60a5fa}.control-config{display:flex;flex-direction:column;gap:.5rem}.config-row{display:flex;align-items:center;gap:.75rem}.config-row label{width:80px;color:#9ca3af;font-size:.875rem}.config-row code{font-size:.75rem;color:#60a5fa;background:#1f2937;padding:.125rem .375rem;border-radius:4px}.config-row .step{color:#6b7280;font-size:.875rem}.modes-list{display:flex;flex-wrap:wrap;gap:.5rem}.mode-chip{padding:.375rem .75rem;background:#1f2937;border-radius:9999px;font-size:.875rem}.settings-section{margin-bottom:1rem}.settings-section h4{font-size:.875rem;color:#e0e0e0;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid #374151}.settings-items{display:flex;flex-direction:column;gap:.375rem}.settings-item{display:flex;align-items:center;gap:.5rem;padding:.375rem 0}.item-type{width:24px;text-align:center}.item-label{flex:1}.item-key{font-size:.75rem;color:#60a5fa}.item-config{color:#6b7280;font-size:.75rem}.data-table{background:#1f2937;border-radius:8px;overflow:hidden}.data-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:1rem;padding:.75rem 1rem;background:#374151;font-size:.75rem;font-weight:500;text-transform:uppercase;color:#9ca3af}.data-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:1rem;padding:.5rem 1rem;border-bottom:1px solid #374151;align-items:center}.data-row:last-child{border-bottom:none}.data-key{color:#60a5fa;font-size:.875rem}.data-type{font-size:.75rem;padding:.125rem .375rem;border-radius:4px}.type-number{background:#1e3a5f;color:#60a5fa}.type-string{background:#14532d;color:#4ade80}.type-boolean{background:#3b0764;color:#c084fc}.data-source{font-size:.75rem}.source-sensor{color:#4ade80}.source-user{color:#60a5fa}.source-api{color:#fbbf24}.source-computed{color:#c084fc}.data-default{color:#9ca3af;font-size:.875rem}.data-description{cursor:help}.nav-config{display:flex;gap:1rem;margin-bottom:.75rem}.nav-type{padding:.25rem .75rem;background:#1f2937;border-radius:4px;font-weight:500}.default-screen{color:#9ca3af;font-size:.875rem}.nav-items{display:flex;flex-wrap:wrap;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#1f2937;border-radius:6px}.nav-icon{font-size:1.125rem}.nav-label{font-weight:500}.nav-target{color:#6b7280;font-size:.875rem}.features-list{display:flex;flex-direction:column;gap:.75rem}.feature-card{background:#1f2937;border-radius:8px;padding:1rem}.feature-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.feature-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#3b82f6;border-radius:9999px;font-size:.75rem;font-weight:500}.feature-name{font-weight:500}.feature-description{color:#9ca3af;font-size:.875rem}.target-system-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1rem;background:#1f2937;border-radius:8px}.system-item{display:flex;flex-direction:column;gap:.25rem}.system-item label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.system-item span{font-weight:500}.tier-badge{display:inline-block;padding:.25rem .75rem;background:#3b0764;color:#c084fc;border-radius:4px;font-weight:600}.framework-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.875rem}.framework-badge.slint{background:#1e3a5f;color:#60a5fa}.language-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.875rem}.language-badge.rust{background:#7c2d12;color:#fb923c}.design-badge{display:inline-block;padding:.25rem .75rem;background:#14532d;color:#4ade80;border-radius:4px}.color-swatch{display:flex;align-items:center;gap:.5rem}.prd-empty{padding:2rem;text-align:center;color:#9ca3af}.prd-document-view{padding:2rem;background:#111827;border-radius:8px;color:#e0e0e0;font-size:.9375rem;line-height:1.7;max-height:calc(100vh - 300px);overflow-y:auto}.prd-document-view .doc-h1{font-size:1.75rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:2px solid #3b82f6;color:#f0f0f0}.prd-document-view .doc-h2{font-size:1.25rem;margin-top:2rem;margin-bottom:1rem;color:#60a5fa;border-bottom:1px solid #374151;padding-bottom:.5rem}.prd-document-view .doc-h3{font-size:1.1rem;margin-top:1.5rem;margin-bottom:.75rem;color:#e0e0e0}.prd-document-view .doc-h4{font-size:1rem;margin-top:1rem;margin-bottom:.5rem;color:#9ca3af}.prd-document-view hr{border:none;border-top:1px solid #374151;margin:1.5rem 0}.prd-document-view p{margin-bottom:1rem}.prd-document-view ul,.prd-document-view ol{margin-bottom:1rem;padding-left:1.5rem}.prd-document-view li{margin-bottom:.375rem}.prd-document-view strong{color:#f0f0f0}.prd-document-view .table-wrapper{overflow-x:auto;margin:1rem 0;border-radius:8px;border:1px solid #374151}.prd-document-view table{width:100%;border-collapse:collapse;font-size:.875rem}.prd-document-view th{text-align:left;padding:.75rem 1rem;background:#1f2937;border-bottom:2px solid #374151;font-weight:600;color:#9ca3af;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.prd-document-view td{padding:.75rem 1rem;border-bottom:1px solid #374151}.prd-document-view tr:last-child td{border-bottom:none}.prd-document-view tr:hover td{background:#1f2937}.prd-document-view .inline-code{padding:.125rem .375rem;background:#1f2937;border-radius:4px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85em;color:#60a5fa}.prd-document-view .code-block{padding:1rem;background:#1f2937;border-radius:6px;overflow-x:auto;margin:1rem 0;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem}.prd-document-view::-webkit-scrollbar{width:8px}.prd-document-view::-webkit-scrollbar-track{background:#1f2937;border-radius:4px}.prd-document-view::-webkit-scrollbar-thumb{background:#374151;border-radius:4px}.prd-document-view::-webkit-scrollbar-thumb:hover{background:#4b5563}.prd-view-controls{display:flex;align-items:center;gap:1rem}.view-toggle{display:flex;background:#1f2937;border-radius:8px;padding:.25rem;gap:.25rem}.toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s ease}.toggle-btn:hover{background:#374151;color:#e0e0e0}.toggle-btn.active{background:#3b82f6;color:#fff}.toggle-btn svg{opacity:.7}.toggle-btn.active svg{opacity:1}.prd-content{flex:1;overflow:hidden}
