*,: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,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align: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}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-0{left:0;right:0}.bottom-0{bottom:0}.left-10{left:2.5rem}.left-3{left:.75rem}.right-3{right:.75rem}.top-1\/2{top:50%}.top-10{top:2.5rem}.top-3{top:.75rem}.z-10{z-index:10}.mx-1{margin-left:.25rem;margin-right:.25rem}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.ml-1{margin-left:.25rem}.mt-1{margin-top:.25rem}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.size-10{width:2.5rem;height:2.5rem}.size-12{width:3rem;height:3rem}.size-3{width:.75rem;height:.75rem}.size-4{width:1rem;height:1rem}.size-5{width:1.25rem;height:1.25rem}.size-6{width:1.5rem;height:1.5rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-48{height:12rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-auto{height:auto}.h-px{height:1px}.min-h-4{min-height:1rem}.min-h-dvh{min-height:100dvh}.w-full{width:100%}.max-w-\[430px\]{max-width:430px}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-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))}.transform{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 auth-fade{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-auth-fade{animation:auth-fade .26s ease-out both}.animate-spin{animation:spin 1s linear infinite}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.place-items-center{place-items:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded-2xl{border-radius:1rem}.rounded-lg{border-radius:.75rem}.rounded-md{border-radius:.55rem}.rounded-sm{border-radius:.4rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-border{border-color:#191f2c}.border-input{border-color:#0d111b}.bg-background{background-color:#010101}.bg-border{background-color:#191f2c}.bg-card{background-color:#030407}.bg-primary{background-color:#516ce9}.bg-secondary{background-color:#060910}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-primary{--tw-gradient-from: oklch(.58 .19 270) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-\[oklch\(0\.62_0\.19_252\)\]{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), oklch(.62 .19 252) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-\[oklch\(0\.72_0\.16_212\)\]{--tw-gradient-to: oklch(.72 .16 212) var(--tw-gradient-to-position)}.p-0{padding:0}.p-1{padding:.25rem}.p-7{padding:1.75rem}.px-0{padding-left:0;padding-right:0}.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-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pb-2{padding-bottom:.5rem}.pl-10{padding-left:2.5rem}.pr-10{padding-right:2.5rem}.pt-5{padding-top:1.25rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.68rem\]{font-size:.68rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-tight{line-height:1.25}.tracking-normal{letter-spacing:0em}.text-accent-foreground{color:#86e2f2}.text-card-foreground{color:#e3e8f0}.text-current{color:currentColor}.text-destructive{color:#d5584d}.text-foreground{color:#e3e8f0}.text-muted-foreground{color:#9099a5}.text-primary-foreground{color:#f7f8fb}.text-secondary-foreground{color:#d9dee6}.underline-offset-4{text-underline-offset:4px}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-auth-card{--tw-shadow: 0 24px 80px oklch(0 0 0 / .42), 0 0 0 1px oklch(.34 .06 268 / .22);--tw-shadow-colored: 0 24px 80px var(--tw-shadow-color), 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-auth-glow{--tw-shadow: 0 12px 38px oklch(.58 .19 270 / .28);--tw-shadow-colored: 0 12px 38px 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)}.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-xl{--tw-backdrop-blur: blur(24px);-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-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}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);--bg: oklch(.075 0 0);--panel: oklch(.115 .014 270);--panel-strong: oklch(.15 .018 270);--panel-soft: oklch(.105 .01 250);--line: oklch(.27 .028 265);--line-soft: oklch(.2 .022 265);--text: oklch(.93 .012 260);--muted: oklch(.68 .02 255);--quiet: oklch(.5 .02 255);--primary: oklch(.58 .19 270);--primary-strong: oklch(.64 .2 268);--cyan: oklch(.72 .16 212);--warm: oklch(.79 .13 74);--danger: oklch(.62 .16 28);--success: oklch(.74 .14 154);--radius: 8px;--radius-small: 6px;--topbar: 58px;--left: 300px;--right: 342px}*{box-sizing:border-box}html,body,#root{height:100%;min-height:100%;margin:0}body{min-width:320px;overflow:hidden;background:radial-gradient(circle at 52% 8%,oklch(.16 .06 268 / .22),transparent 32rem),linear-gradient(180deg,oklch(.082 .002 260),var(--bg) 32rem)}button,input,select,textarea{font:inherit}button{border:0}button:not(:disabled){cursor:pointer}button:disabled{cursor:not-allowed;opacity:.64}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}.auth-screen{isolation:isolate}.auth-drift-layer{background:radial-gradient(circle at 22% 18%,oklch(.72 .16 212 / .2) 0 1px,transparent 2px),radial-gradient(circle at 74% 24%,oklch(.64 .2 268 / .2) 0 1px,transparent 2px),radial-gradient(circle at 60% 72%,oklch(.79 .13 74 / .14) 0 1px,transparent 2px),radial-gradient(circle at 50% 8%,oklch(.22 .08 268 / .46),transparent 34rem),linear-gradient(180deg,#010203,#000);background-size:auto,auto,auto,auto,auto;animation:light-drift 16s ease-in-out infinite}.auth-drift-layer:before,.auth-drift-layer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.auth-drift-layer:before{background:linear-gradient(115deg,transparent 12%,rgb(56 189 248 / .08) 42%,transparent 68%),radial-gradient(circle at 78% 72%,oklch(.58 .19 270 / .18),transparent 20rem);filter:blur(1px);opacity:.72}.auth-drift-layer:after{background-image:radial-gradient(circle,oklch(.78 .13 74 / .38) 0 1px,transparent 1.6px),radial-gradient(circle,oklch(.72 .16 212 / .28) 0 1px,transparent 1.6px);background-position:12% 34%,82% 18%;background-size:112px 112px,156px 156px;-webkit-mask-image:linear-gradient(180deg,transparent,black 24%,black 78%,transparent);mask-image:linear-gradient(180deg,transparent,black 24%,black 78%,transparent);opacity:.5}.auth-skyline{background:linear-gradient(180deg,transparent 0 36%,oklch(.055 .006 260 / .72) 36% 100%),linear-gradient(90deg,transparent 0 5%,oklch(.12 .02 265 / .7) 5% 8%,transparent 8% 13%,oklch(.095 .012 260 / .8) 13% 18%,transparent 18% 24%,oklch(.13 .018 260 / .72) 24% 31%,transparent 31% 38%,oklch(.1 .012 255 / .75) 38% 43%,transparent 43% 50%,oklch(.12 .018 268 / .74) 50% 56%,transparent 56% 63%,oklch(.09 .012 260 / .78) 63% 69%,transparent 69% 77%,oklch(.13 .02 268 / .7) 77% 84%,transparent 84% 100%);-webkit-mask-image:linear-gradient(180deg,transparent,black 26%);mask-image:linear-gradient(180deg,transparent,black 26%);opacity:.5;animation:city-glow 7s ease-in-out infinite}h1,h2,p{margin:0}.app-shell{height:100vh;height:100dvh;min-height:0;display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar);display:grid;grid-template-columns:minmax(236px,1fr) auto;gap:16px;align-items:center;padding:0 18px;border-bottom:1px solid var(--line-soft);background:#020305f0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:sticky;top:0;z-index:20}.brand-block,.project-name,.top-actions,.canvas-meta,.prompt-actions,.section-title.with-icon{display:flex;align-items:center}.brand-block{gap:11px;min-width:0}.brand-mark{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--primary),oklch(.46 .16 292)),var(--primary)}.brand-name{font-size:.96rem;font-weight:750;color:var(--text)}.project-name{gap:5px;margin-top:1px;color:var(--muted);font-size:.76rem;white-space:nowrap}.tab,.ghost-button,.icon-button,.tool-button,.view-fit-button,.fixture-pill,.export-button,.recent-row{color:var(--muted);background:transparent;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.tab{flex:1 0 auto;min-height:31px;padding:0 13px;border-radius:6px;font-size:.82rem;white-space:nowrap}.tab.is-active,.tab:hover{color:var(--text);background:var(--panel-strong)}.top-actions{gap:7px;justify-content:flex-end;min-width:0}.ghost-button,.primary-button,.icon-button,.export-button{min-height:32px;border-radius:7px;align-items:center;justify-content:center}.ghost-button,.primary-button,.export-button{display:inline-flex;gap:7px;padding:0 10px;font-size:.82rem}.ghost-button{border:1px solid var(--line-soft);background:#06070b}.ghost-button:hover,.ghost-button:focus-visible{color:var(--text);border-color:var(--line);background:#0c0f16}.ghost-button.wide{flex:1 1 auto}.primary-button{color:#fff;border:1px solid oklch(.68 .18 270);background:linear-gradient(180deg,var(--primary-strong),var(--primary));font-weight:720}.primary-button:hover{background:linear-gradient(180deg,oklch(.68 .19 268),var(--primary))}.icon-button{width:34px;display:inline-grid;place-items:center;border:1px solid var(--line-soft);color:var(--muted);background:#06070b}.icon-button:hover{color:var(--text);border-color:var(--line)}.project-status{min-height:34px;display:inline-flex;align-items:center;gap:7px;padding:0 10px;border:1px solid var(--line-soft);border-radius:8px;color:var(--muted);background:#0b1324;font-size:.76rem;white-space:nowrap}.project-status svg{color:var(--quiet)}.project-status.is-ready{color:#86e2f2;border-color:#004554;border-color:oklch(.36 .08 218);background:#00151cb8;background:oklch(.18 .045 220 / .72)}.project-status.is-ready svg{color:var(--primary)}.icon-button.compact{width:30px;min-height:30px}.account-menu-wrap{position:relative;display:inline-flex;align-items:center}.account-trigger{min-height:34px;display:inline-flex;align-items:center;gap:8px;padding:3px 8px 3px 4px;border:1px solid var(--line-soft);border-radius:8px;color:var(--text);background:#05060b;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.account-trigger:hover,.account-trigger[aria-expanded=true]{border-color:var(--line);background:#080c14}.account-trigger:active{transform:translateY(1px)}.account-trigger svg{color:var(--muted);transition:transform .16s ease}.account-trigger svg.is-open{transform:rotate(180deg)}.account-avatar,.account-profile-avatar{display:grid;place-items:center;color:#fff;background:radial-gradient(circle at 35% 24%,oklch(.72 .16 212 / .92),transparent 36%),linear-gradient(135deg,var(--primary),oklch(.42 .13 292))}.account-avatar{width:26px;height:26px;border-radius:7px;font-size:.77rem;font-weight:750}.account-trigger-copy{display:grid;gap:1px;min-width:86px;text-align:left;line-height:1.12}.account-trigger-copy strong{max-width:118px;overflow:hidden;color:var(--text);font-size:.76rem;font-weight:720;text-overflow:ellipsis;white-space:nowrap}.account-trigger-copy span{color:var(--muted);font-size:.68rem}.account-menu{position:fixed;top:62px;right:14px;z-index:50;width:min(342px,calc(100vw - 28px));padding:10px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#070a12fa,#020305fa),var(--panel);box-shadow:0 8px 8px #00000042}.account-profile{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center;padding:4px 4px 10px}.account-profile-avatar{width:42px;height:42px;border-radius:10px;font-size:1rem;font-weight:780}.account-profile-main{min-width:0}.account-profile-name{display:flex;align-items:center;gap:8px;min-width:0}.account-profile-name strong{overflow:hidden;color:var(--text);font-size:.92rem;font-weight:760;text-overflow:ellipsis;white-space:nowrap}.account-profile-name span{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;min-height:22px;padding:0 7px;border:1px solid oklch(.35 .08 265);border-radius:999px;color:var(--cyan);background:#050d1c;font-size:.7rem}.account-id{margin-top:3px;overflow:hidden;color:var(--quiet);font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.68rem;text-overflow:ellipsis;white-space:nowrap}.account-info-grid{display:grid;gap:6px;padding:8px;border:1px solid var(--line-soft);border-radius:9px;background:#030305}.account-info-row{display:flex;align-items:center;gap:8px;min-width:0;color:var(--muted);font-size:.76rem}.account-info-row svg{flex:0 0 auto;color:var(--cyan)}.account-info-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-credit-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;padding:12px;border-radius:10px;color:var(--text);background:radial-gradient(circle at 86% 20%,oklch(.72 .16 212 / .2),transparent 7rem),linear-gradient(135deg,#0c1325,#03080f)}.account-credit-panel span{color:var(--muted);font-size:.72rem}.account-credit-panel strong{display:block;margin-top:1px;color:#fff;font-size:1.55rem;font-weight:800;line-height:1}.account-credit-panel svg{color:var(--warm)}.account-recharge{display:grid;gap:8px;margin-top:10px}.account-section-head{display:grid;gap:1px}.account-section-head span{color:var(--text);font-size:.82rem;font-weight:700}.account-section-head small{color:var(--muted);font-size:.7rem}.recharge-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.recharge-option{display:grid;gap:2px;min-height:56px;padding:8px 6px;border:1px solid var(--line-soft);border-radius:8px;color:var(--text);background:#040509;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.recharge-option:hover,.recharge-option:focus-visible{border-color:#354b7e;background:#060b16;transform:translateY(-1px)}.recharge-option strong{font-size:.88rem;line-height:1.05}.recharge-option span{color:var(--muted);font-size:.66rem}.account-primary-action{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid oklch(.68 .18 270);border-radius:8px;color:#fff;background:linear-gradient(180deg,var(--primary-strong),var(--primary));font-size:.82rem;font-weight:720;transition:filter .16s ease,transform .16s ease}.account-primary-action:hover,.account-primary-action:focus-visible{filter:brightness(1.08);transform:translateY(-1px)}.account-feedback{min-height:18px;color:var(--muted);font-size:.72rem}.account-menu-actions{display:grid;gap:5px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line-soft)}.account-menu-row{min-height:34px;display:flex;align-items:center;gap:8px;padding:0 9px;border-radius:8px;color:var(--muted);background:transparent;font-size:.8rem;text-align:left;transition:background-color .16s ease,color .16s ease}.account-menu-row:hover,.account-menu-row:focus-visible{color:var(--text);background:#07090f}.account-menu-row.danger:hover,.account-menu-row.danger:focus-visible{color:#f49286;background:#1a070573}.account-detail-box{display:grid;gap:7px;padding:8px 9px;border:1px solid var(--line-soft);border-radius:8px;background:#020305}.account-detail-box div{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.account-detail-box span{flex:0 0 auto;color:var(--quiet);font-size:.7rem}.account-detail-box strong{overflow:hidden;color:var(--text);font-size:.72rem;font-weight:650;text-overflow:ellipsis;white-space:nowrap}.global-toast{position:fixed;top:70px;left:50%;z-index:45;max-width:min(560px,calc(100vw - 28px));min-height:36px;display:inline-flex;align-items:center;padding:0 14px;border:1px solid var(--line);border-radius:999px;color:var(--text);background:#0b1324f5;box-shadow:0 8px 8px #00000038;transform:translate(-50%);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:.78rem}.global-toast.state-loading{color:#bfdbfe;border-color:#38bdf86b}.global-toast.state-success{color:#86e2f2;border-color:#004554;border-color:oklch(.36 .08 218)}.global-toast.state-error{color:#fecaca;border-color:#ef444480}.workspace{flex:1;display:grid;grid-template-columns:var(--left) minmax(0,1fr) var(--right);grid-template-rows:minmax(0,1fr);grid-template-areas:"left canvas inspector";gap:10px;min-height:0;padding:10px}.panel,.canvas-shell{border:1px solid var(--line-soft);border-radius:var(--radius);background:linear-gradient(180deg,#06070cfa,#020304fa),var(--panel)}.left-panel{grid-area:left;min-height:0;overflow:hidden auto;padding:13px}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}.panel-head h2{color:var(--text);font-size:.95rem;line-height:1.2}.panel-head p,.canvas-head p{color:var(--muted);font-size:.78rem}.upload-list{display:grid;gap:8px;margin-top:12px}.upload-card{min-height:78px;display:grid;grid-template-columns:68px minmax(0,1fr) auto;align-items:center;gap:10px;padding:9px;border:1px solid var(--line-soft);border-radius:var(--radius);background:#020203}.upload-card label{cursor:pointer}.upload-card:hover{border-color:#2e4362;background:#03050a}.upload-card.is-drop-target{border-color:var(--cyan);background:#000b14}.upload-preview{width:68px;height:50px;display:grid;place-items:center;overflow:hidden;border:1px solid var(--line-soft);border-radius:7px;color:var(--cyan);background:linear-gradient(135deg,#02060d,#010101),var(--panel-soft)}.upload-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.upload-copy{display:grid;gap:2px;min-width:0}.upload-copy strong{color:var(--text);font-size:.86rem;font-weight:650}.upload-copy span{color:var(--muted);font-size:.73rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-actions{display:grid;justify-items:end;gap:6px}.upload-action{min-width:48px;min-height:26px;display:inline-grid;place-items:center;border:1px solid var(--line-soft);border-radius:6px;color:var(--muted);font-size:.7rem;background:#040609}.upload-remove-button{width:28px;min-height:28px;display:inline-grid;place-items:center;border:1px solid oklch(.32 .06 34);border-radius:6px;color:#ffac98;color:oklch(.82 .11 34);background:#100403c2}.upload-remove-button:hover{color:#fff;border-color:#9c4535;background:#340904}.status-ready .upload-action{color:#96dead;border-color:#104929;background:#02110694}.style-reference-panel,.scene-mode-panel,.generation-history-panel,.control-section{margin-top:12px}.section-title{margin-bottom:8px;color:var(--muted);font-size:.74rem;font-weight:650}.section-title.with-icon{gap:6px}.scene-mode-panel{display:grid;gap:10px;padding:12px;border:1px solid var(--line-soft);border-radius:8px;background:linear-gradient(180deg,#040710c7,#010203f0),var(--panel-soft)}.scene-mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.scene-mode-button{min-width:0;min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line-soft);border-radius:8px;color:var(--muted);font-size:.78rem;font-weight:720;background:#010203;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,box-shadow .16s ease}.scene-mode-button:hover,.scene-mode-button.is-active{color:var(--text);border-color:#5f6ed7;background:linear-gradient(180deg,#131742d1,#040817e6),var(--panel-soft)}.scene-mode-button.is-active{box-shadow:inset 0 0 0 1px #7783fe80,0 10px 26px #03002238;box-shadow:inset 0 0 0 1px #7783fe80,0 10px 26px oklch(.12 .09 276 / .22)}.scene-mode-options{display:grid;gap:11px}.mode-option-group{display:grid;gap:7px}.mode-option-group>span{color:var(--quiet);font-size:.72rem;font-weight:650}.mode-chip-list{display:flex;flex-wrap:wrap;gap:6px}.mode-chip{min-height:29px;border:1px solid var(--line-soft);border-radius:7px;padding:0 10px;color:var(--muted);font-size:.73rem;background:#010102;transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.mode-chip:hover,.mode-chip.is-active{color:#fff;border-color:#6e7ae5;background:linear-gradient(180deg,var(--primary-strong),var(--primary))}.indoor-pending{min-height:70px;display:grid;place-items:center;border:1px dashed oklch(.36 .06 270);border-radius:8px;padding:12px;color:var(--muted);text-align:center;font-size:.76rem;line-height:1.6;background:#010102b8}.generation-history-panel{display:grid;gap:10px;padding:12px;border:1px solid var(--line-soft);border-radius:8px;background:linear-gradient(180deg,#04060bc2,#010102eb),var(--panel-soft)}.generation-history-list{display:grid;gap:8px}.history-card{min-width:0;display:grid;grid-template-columns:58px minmax(0,1fr);align-items:center;gap:9px;min-height:58px;border:1px solid var(--line-soft);border-radius:8px;padding:7px;color:var(--muted);text-align:left;background:#010102;transition:border-color .15s ease,background-color .15s ease,transform .15s ease}.history-card:hover,.history-card.is-active{color:var(--text);border-color:#515fb8;background:#040613}.history-card.is-active{box-shadow:inset 0 0 0 1px #7783fe6b}.history-thumb{position:relative;display:block;width:58px;height:42px;overflow:hidden;border-radius:6px;background:var(--panel-soft)}.history-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.history-copy{min-width:0;display:grid;gap:3px}.history-copy strong,.history-copy small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-copy strong{color:inherit;font-size:.78rem;font-weight:740}.history-copy small,.history-empty{color:var(--muted);font-size:.72rem}.history-empty{display:grid;place-items:center;min-height:58px;border:1px dashed oklch(.32 .05 270);border-radius:8px;padding:10px;text-align:center;line-height:1.5;background:#010102b3}.style-reference-grid{display:grid;grid-template-columns:1fr;gap:8px}.style-reference-card{min-width:0;display:grid;grid-template-columns:82px minmax(0,1fr);align-items:center;gap:10px;padding:8px;border:1px solid var(--line-soft);border-radius:8px;text-align:left;color:var(--muted);background:#020203;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.style-reference-card:hover,.style-reference-card.is-active{color:var(--text);border-color:#3e5092;background:#040711}.style-reference-card.is-active{box-shadow:inset 0 0 0 1px #516bd18c}.style-thumb{position:relative;height:52px;overflow:hidden;border-radius:7px;isolation:isolate;background:var(--panel-soft)}.style-thumb:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.scene-thumb span{position:absolute;display:block}.scene-sky{top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(circle at 78% 18%,oklch(.72 .14 78 / .18),transparent 18%),linear-gradient(180deg,#001534,#010918,#010102 78%)}.scene-ground{left:0;right:0;bottom:0;z-index:2;height:18px;background:linear-gradient(90deg,transparent,oklch(.72 .14 212 / .18),transparent),#010203eb}.scene-mass{z-index:1;border:1px solid oklch(.58 .08 232 / .28);background:#03060be0}.scene-light{z-index:3;border-radius:999px;background:var(--warm);box-shadow:0 0 10px #ecad52a3}.scene-outdoor .scene-mass-a{width:42px;height:32px;left:14px;bottom:13px;clip-path:polygon(0 36%,52% 0,100% 34%,100% 100%,0 100%)}.scene-outdoor .scene-mass-b{width:76px;height:14px;right:12px;bottom:16px;border-radius:999px 999px 2px 2px;background:#000d04c7;background:oklch(.14 .04 155 / .78)}.scene-outdoor .scene-light-a{width:5px;height:5px;left:24px;bottom:19px}.scene-outdoor .scene-light-b{width:44px;height:3px;right:28px;bottom:23px}.scene-indoor .scene-sky{background:linear-gradient(90deg,#010304,#080d1a,#010304)}.scene-indoor .scene-mass-a{left:12px;right:12px;top:9px;height:36px;border-radius:2px;background:linear-gradient(90deg,transparent 0 18%,oklch(.76 .1 74 / .3) 18% 20%,transparent 20% 36%,oklch(.76 .1 74 / .26) 36% 38%,transparent 38% 58%,oklch(.76 .1 74 / .3) 58% 60%,transparent 60%),#04060af0}.scene-indoor .scene-mass-b{left:24px;right:24px;bottom:16px;height:6px;border-radius:999px;background:#ecad5280}.scene-indoor .scene-light-a,.scene-indoor .scene-light-b{top:16px;width:20px;height:3px}.scene-indoor .scene-light-a{left:28px}.scene-indoor .scene-light-b{right:28px}.scene-facade .scene-mass-a{left:18px;bottom:12px;width:72px;height:38px;background:linear-gradient(90deg,transparent 0 22%,oklch(.68 .1 212 / .28) 22% 24%,transparent 24% 48%,oklch(.68 .1 212 / .24) 48% 50%,transparent 50% 74%,oklch(.68 .1 212 / .24) 74% 76%,transparent 76%),linear-gradient(180deg,#0e111a,#020305)}.scene-facade .scene-mass-b{left:10px;bottom:44px;width:94px;height:6px;transform:skew(-18deg);background:#0f1622}.scene-facade .scene-light-a{left:18px;bottom:14px;width:72px;height:3px}.scene-facade .scene-light-b{right:22px;bottom:24px;width:4px;height:18px}.scene-commercial .scene-sky{background:radial-gradient(circle at 18% 28%,oklch(.72 .18 318 / .28),transparent 20%),radial-gradient(circle at 80% 20%,oklch(.72 .16 212 / .22),transparent 18%),linear-gradient(180deg,#05091c,#010102)}.scene-commercial .scene-mass-a{left:9px;bottom:13px;width:54px;height:34px}.scene-commercial .scene-mass-b{right:12px;bottom:13px;width:42px;height:29px}.scene-commercial .scene-light-a{left:17px;bottom:34px;width:36px;height:7px;border-radius:3px;background:#01b9d2;background:oklch(.72 .16 212)}.scene-commercial .scene-light-b{right:18px;bottom:25px;width:26px;height:18px;border-radius:3px;background:#ecad52db}.scene-commercial .style-thumb:after{background:linear-gradient(135deg,oklch(.64 .18 270 / .18),transparent 58%),linear-gradient(180deg,transparent 65%,oklch(.72 .16 212 / .12))}.style-copy{display:grid;gap:3px;min-width:0}.style-copy strong{color:var(--text);font-size:.82rem}.style-copy small{color:var(--muted);font-size:.7rem;line-height:1.35}.recent-row{width:100%;min-height:34px;display:flex;align-items:center;gap:8px;padding:0 9px;border-radius:6px;color:var(--muted);text-align:left}.recent-row:hover{color:var(--text);background:var(--panel-strong)}.recent-row{justify-content:space-between;gap:12px}.recent-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-row small{flex:0 0 auto;color:var(--quiet)}.canvas-shell{grid-area:canvas;display:flex;flex-direction:column;min-width:0;min-height:0;padding:11px;overflow:hidden}.canvas-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:3px 3px 11px}.canvas-head h1{color:var(--text);font-size:1.24rem;line-height:1.22;font-weight:740;text-wrap:balance}.canvas-board{position:relative;flex:1;min-height:360px;display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:linear-gradient(180deg,#040508,#010101),var(--bg)}.canvas-control-row{position:relative;z-index:6;display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.canvas-control-cluster,.canvas-zoom-controls{display:flex;align-items:center;gap:7px}.canvas-control-cluster{flex:0 0 auto;justify-content:flex-end}.canvas-zoom-controls{min-height:42px;padding:5px;border:1px solid var(--line-soft);border-radius:var(--radius);color:var(--muted);background:#020204e0}.zoom-value{min-width:42px;color:var(--text);font-size:.74rem;font-variant-numeric:tabular-nums;text-align:center}.view-fit-button{min-height:30px;display:inline-flex;align-items:center;gap:5px;padding:0 8px;border-radius:6px;color:var(--muted);font-size:.74rem}.view-fit-button:hover:not(:disabled){color:var(--text);background:#0f1526}.canvas-toolbar{display:flex;gap:4px;flex-wrap:wrap;max-width:min(100%,620px);padding:4px;border:1px solid var(--line-soft);border-radius:var(--radius);background:#020204e0}.tool-button{min-height:30px;display:inline-flex;align-items:center;gap:5px;padding:0 7px;border-radius:6px;font-size:.74rem}.tool-button.is-active,.tool-button:hover{color:#fff;background:#162455;font-weight:700}.tool-button.danger:not(:disabled){color:#ffc0ac;color:oklch(.86 .1 38)}.tool-button.danger:not(:disabled):hover{background:#3a0f08}.canvas-time-control{flex:0 0 auto;min-height:42px;display:inline-flex;align-items:center;gap:7px;padding:5px 7px;border:1px solid var(--line-soft);border-radius:var(--radius);color:var(--muted);background:#020204e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.canvas-time-control select{width:144px;height:30px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:6px;padding:0 8px;color:var(--text);font-size:.76rem;background:#05070c}.image-frame{position:relative;flex:1 1 auto;min-height:260px;overflow:hidden;touch-action:none;border:1px solid oklch(.19 .02 260);border-radius:var(--radius);background:radial-gradient(circle at 50% 42%,oklch(.14 .026 256 / .72),transparent 32rem),#000}.canvas-viewport-content{position:absolute;top:0;right:0;bottom:0;left:0;transform-origin:center center;transition:transform .12s ease-out;will-change:transform}.image-frame.is-empty{display:grid;place-items:center;padding:28px;background:linear-gradient(oklch(.3 .03 250 / .16) 1px,transparent 1px),linear-gradient(90deg,oklch(.3 .03 250 / .14) 1px,transparent 1px),radial-gradient(circle at 52% 38%,oklch(.24 .08 270 / .45),transparent 24rem),#010101;background-size:32px 32px,32px 32px,auto,auto}.empty-canvas-state{width:min(520px,86%);display:grid;justify-items:center;gap:12px;padding:26px;border:1px solid oklch(.31 .04 260);border-radius:10px;color:inherit;text-align:center;background:#020204e6}.empty-canvas-state:hover{border-color:#485996;background:#04060cf0}.empty-canvas-mark{width:52px;height:52px;display:grid;place-items:center;border:1px solid oklch(.42 .08 270);border-radius:10px;color:var(--cyan);background:#021224cc}.empty-canvas-state h2{color:var(--text);font-size:1rem;line-height:1.2}.empty-canvas-state p{max-width:44ch;color:var(--muted);font-size:.78rem}.empty-canvas-steps{display:flex;flex-wrap:wrap;justify-content:center;gap:7px}.empty-canvas-steps span{min-height:27px;display:inline-flex;align-items:center;padding:0 9px;border:1px solid var(--line-soft);border-radius:999px;color:var(--muted);font-size:.72rem;background:#040609}.render-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center center;object-position:center center}.source-image{z-index:1;filter:saturate(.92) contrast(.98)}.generated{z-index:2;filter:none}.night-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;display:none}.before-layer{z-index:3;filter:none}.compare-line{position:absolute;top:0;bottom:0;z-index:7;width:34px;transform:translate(-50%);border:0;border-radius:999px;background:transparent;cursor:ew-resize;outline:none;touch-action:none}.compare-line:before{content:"";position:absolute;top:50%;left:50%;width:36px;height:36px;border:1px solid white;border-radius:999px;transform:translate(-50%,-50%);background:#030407eb;box-shadow:0 0 24px #8ea4ff57;box-shadow:0 0 24px oklch(.74 .16 272 / .34)}.compare-line:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translate(-50%);background:#fff;box-shadow:0 0 0 1px #01020380,0 0 18px #8ea4ff5c;box-shadow:0 0 0 1px #01020380,0 0 18px oklch(.74 .16 272 / .36);pointer-events:none}.compare-line:hover:before,.compare-line:focus-visible:before,.compare-line.is-dragging:before{border-color:#c4ceff;border-color:oklch(.86 .1 276);background:linear-gradient(135deg,#060b20f5,#010204f5),var(--panel-soft);box-shadow:0 0 0 3px #6c76f038,0 0 26px #8c9bff80;box-shadow:0 0 0 3px #6c76f038,0 0 26px oklch(.72 .16 276 / .5)}.result-pending{position:relative;z-index:6;align-self:flex-end;min-height:31px;display:inline-flex;align-items:center;gap:7px;padding:0 10px;border:1px solid oklch(.4 .06 220);border-radius:7px;color:#86e2f2;font-size:.75rem;background:#010203db;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.annotation-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;width:100%;height:100%;pointer-events:auto;touch-action:none}.annotation-layer.is-marking,.annotation-layer.is-box-selecting{cursor:crosshair}.annotation-node{cursor:grab;pointer-events:auto}.annotation-node:active{cursor:grabbing}.annotation-area-rect{fill:#01b9d221;fill:oklch(.72 .16 212 / .13);stroke:#01b9d2;stroke:oklch(.72 .16 212);stroke-width:2;pointer-events:all}.area-repaint .annotation-area-rect{fill:#ecad522e;stroke:var(--warm)}.area-mask .annotation-area-rect{fill:#01b9d224;fill:oklch(.72 .16 212 / .14);stroke:var(--cyan)}.area-avoid .annotation-area-rect{fill:#d5584d29;stroke:#fe9979}.annotation-draft .annotation-area-rect{stroke-dasharray:10 8;opacity:.92}.fixture-point{fill:var(--warm);stroke:#fff;stroke-width:2.5;pointer-events:all}.fixture-point-pulse{fill:#ecad522e;stroke:#ecad526b;stroke-width:1;pointer-events:all}.fixture-line-hit,.fixture-direction-hit{stroke:transparent;stroke-width:22;pointer-events:stroke}.fixture-line-path{fill:none;stroke:var(--warm);stroke-linecap:round;stroke-width:6;pointer-events:none}.fixture-line-wash .fixture-line-path{stroke:var(--warm);stroke-dasharray:18 12}.fixture-line-linear .fixture-line-path{stroke:var(--cyan);stroke-width:5}.fixture-direction-line{fill:none;stroke:var(--warm);stroke-linecap:round;stroke-width:3;pointer-events:none}.fixture-arrow-head{fill:var(--warm)}.fixture-direction-target{fill:#010203;stroke:var(--warm);stroke-width:1.5;pointer-events:none}.annotation-node.is-selected .fixture-point{stroke:var(--cyan);stroke-width:3}.annotation-node.is-selected .annotation-area-rect,.annotation-node.is-selected .fixture-line-path,.annotation-node.is-selected .fixture-direction-line{filter:drop-shadow(0 0 8px oklch(.72 .16 212 / .45))}.annotation-fixture-line.is-selected .fixture-line-path,.annotation-fixture-direction.is-selected .fixture-direction-line{stroke-width:5}.annotation-fixture-area .annotation-area-rect{fill:#ecad5224;stroke:#ecad52}.annotation-fixture-point .fixture-point{fill:#01b9d2;fill:oklch(.72 .16 212)}.annotation-fixture-area .annotation-text-bg,.annotation-fixture-point .annotation-text-bg{stroke:#01b9d2b8;stroke:oklch(.72 .16 212 / .72)}.annotation-selection-outline{fill:none;stroke:var(--cyan);stroke-width:1.5;stroke-dasharray:8 8;pointer-events:none}.annotation-handle{fill:var(--cyan);stroke:#010203;stroke-width:2;pointer-events:none}.annotation-text-bg{fill:#010203db;stroke:#e9aa4eb8;stroke-width:1}.area-mask .annotation-text-bg{stroke:#01b9d2b8;stroke:oklch(.72 .16 212 / .72)}.area-avoid .annotation-text-bg{stroke:#fe9979b8}.annotation-node.is-selected .annotation-text-bg{stroke:var(--cyan)}.fixture-line-linear .annotation-text-bg{stroke:#01b9d2b8;stroke:oklch(.72 .16 212 / .72)}.annotation-draft .fixture-line-path,.annotation-draft .fixture-direction-line{opacity:.82;stroke-dasharray:10 8}.annotation-svg-label{fill:#fff;font-size:11px;font-weight:620;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.compare-control{position:relative;z-index:6;display:grid;grid-template-columns:auto minmax(120px,1fr) auto;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line-soft);border-radius:var(--radius);color:var(--muted);font-size:.76rem;background:#010203db}.compare-control.is-disabled{opacity:.58;pointer-events:none}input[type=range]{width:100%;accent-color:var(--primary-strong)}.inspector{grid-area:inspector;min-height:0;overflow:hidden auto;padding:13px}.setup-section,.fixture-section,.prompt-section,.output-section,.generate-section,.negative-section{display:grid;gap:10px;padding:12px;border:1px solid var(--line-soft);border-radius:8px;background:linear-gradient(180deg,#04060bd1,#020203eb),var(--panel-soft)}.prompt-section{border-color:#1f283f;background:linear-gradient(180deg,#05070fc7,#020203e6),var(--panel-soft)}.select-field{position:relative;display:grid;gap:6px;color:var(--muted);font-size:.75rem}.select-field select{width:100%;height:38px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line-soft);border-radius:7px;padding:0 34px 0 10px;color:var(--text);background:var(--panel-soft)}.select-field svg{position:absolute;right:10px;bottom:10px;color:var(--muted)}.selected-style-summary{display:grid;gap:4px;margin-top:0;padding:11px 12px;border:1px solid oklch(.32 .06 270);border-radius:8px;background:linear-gradient(135deg,oklch(.2 .06 270 / .52),transparent 72%),#020204}.selected-style-summary span,.selected-style-summary small{color:var(--muted);font-size:.72rem}.selected-style-summary strong{color:var(--text);font-size:.86rem;font-weight:690}.fixture-pill{min-height:30px;border:1px solid var(--line-soft);border-radius:6px;padding:0 9px;font-size:.75rem;background:var(--panel-soft)}.fixture-pill:hover,.fixture-pill.is-active{color:var(--text);border-color:#3f4d7c;background:#0f1630b8}.fixture-group{display:grid;gap:7px}.fixture-group+.fixture-group{padding-top:10px;border-top:1px solid var(--line-soft)}.fixture-group>span{display:block;color:var(--quiet);font-size:.72rem}.fixture-list{display:flex;flex-wrap:wrap;gap:6px}.prompt-box{width:100%;resize:vertical;min-height:132px;border:1px solid var(--line-soft);border-radius:8px;padding:10px;color:var(--text);background:var(--panel-soft)}.prompt-actions{gap:8px;margin-top:8px;display:grid;grid-template-columns:minmax(0,1fr) auto}.output-size-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.output-size-grid .export-button{width:100%;min-height:36px;padding:0 8px;justify-content:center}.export-primary{width:100%;min-height:38px}.generate-section{border-color:#2c3361;background:radial-gradient(circle at 18% 0%,oklch(.42 .16 278 / .15),transparent 40%),linear-gradient(180deg,#040711d1,#020203f0),var(--panel-soft)}.generate-primary{width:100%;min-height:44px;justify-content:center;font-size:.9rem;font-weight:780}.negative-list{display:grid;grid-template-columns:1fr;gap:6px}.check-row{min-height:27px;display:flex;align-items:center;gap:6px;color:var(--muted);font-size:.72rem}.check-row input{accent-color:var(--primary-strong)}.api-status{display:flex;align-items:flex-start;gap:7px;margin-top:12px;padding:9px;border:1px solid var(--line-soft);border-radius:8px;color:var(--muted);font-size:.75rem;background:var(--panel-soft)}.api-status.state-error{color:#ffb299;color:oklch(.83 .1 38);border-color:#8d4636;background:#200a06ad}.api-status.state-success{color:#96e7b0;border-color:#0d5c33;background:#011407ad}.export-button{border:1px solid var(--line-soft);color:var(--text);background:#0a0d15}.export-button:hover{border-color:#475585;background:#121932}.output-size-grid .export-button:not(.is-active){color:var(--text);background:#05070c}.output-size-grid .export-button.is-active{color:#fff;border-color:#718fff;border-color:oklch(.68 .18 270);background:linear-gradient(180deg,var(--primary-strong),var(--primary));font-weight:760}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1240px){:root{--left: 250px;--right: 320px}.topbar{grid-template-columns:minmax(210px,1fr) auto}.top-actions .ghost-button span,.account-trigger-copy,.tool-button span{display:none}.account-trigger{padding-right:6px}.tool-button{width:31px;justify-content:center;padding:0}}@media (min-width: 761px){.canvas-board{flex:1 1 auto;aspect-ratio:auto;min-height:0}}@media (max-width: 1060px){.topbar{height:auto;min-height:var(--topbar);grid-template-columns:1fr;align-items:stretch;padding:10px 12px}.top-actions{justify-content:flex-start;overflow-x:auto}.account-menu{top:106px;right:12px}.workspace{grid-template-columns:260px minmax(0,1fr);grid-template-rows:auto minmax(520px,1fr);grid-template-areas:"left canvas" "inspector canvas"}.left-panel,.inspector{max-height:none}}@media (max-width: 760px){body{overflow-x:hidden;overflow-y:auto}.app-shell{height:auto;min-height:100vh;min-height:100dvh;overflow:visible}.workspace{display:flex;flex-direction:column;height:auto;min-height:calc(100vh - var(--topbar));padding:8px}.canvas-shell{order:2}.left-panel{order:1}.inspector{order:3}.canvas-head{flex-direction:column}.canvas-board{min-height:410px}.negative-list{grid-template-columns:1fr}.canvas-toolbar{max-width:100%}.canvas-control-row{flex-direction:column}.canvas-time-control select{width:158px}.account-menu{top:108px;right:8px;width:calc(100vw - 16px)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:1ms!important;scroll-behavior:auto!important;transition-duration:1ms!important}}.placeholder\:text-transparent::-moz-placeholder{color:transparent}.placeholder\:text-transparent::placeholder{color:transparent}.hover\:scale-\[1\.015\]:hover{--tw-scale-x: 1.015;--tw-scale-y: 1.015;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))}.hover\:scale-\[1\.018\]:hover{--tw-scale-x: 1.018;--tw-scale-y: 1.018;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))}.hover\:bg-muted:hover{background-color:#05070d}.hover\:text-foreground:hover{color:#e3e8f0}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-auth-glow:hover{--tw-shadow: 0 12px 38px oklch(.58 .19 270 / .28);--tw-shadow-colored: 0 12px 38px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--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-visible\:ring-ring:focus-visible{--tw-ring-color: oklch(.72 .16 212)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: oklch(.075 0 0)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-55:disabled{opacity:.55}.peer:focus~.peer-focus\:top-3{top:.75rem}.peer:focus~.peer-focus\:text-\[0\.68rem\]{font-size:.68rem}.peer:focus~.peer-focus\:text-accent-foreground{color:#86e2f2}.peer:focus~.peer-focus\:text-destructive{color:#d5584d}.data-\[invalid\=true\]\:border-destructive[data-invalid=true]{border-color:#d5584d}.data-\[state\=checked\]\:border-primary[data-state=checked]{border-color:#516ce9}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#516ce9}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:#f7f8fb}.data-\[invalid\=true\]\:focus-visible\:ring-destructive:focus-visible[data-invalid=true]{--tw-ring-color: oklch(.62 .16 28)}@media (min-width: 768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:p-8{padding:2rem}}
