@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";*,: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}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-9{height:2.25rem}.h-px{height:1px}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-9{width:2.25rem}.w-full{width:100%}.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-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 spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.p-1\.5{padding:.375rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.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-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pl-5{padding-left:1.25rem}.pr-10{padding-right:2.5rem}.pt-3{padding-top:.75rem}.pt-5{padding-top:1.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.ordinal{--tw-ordinal: ordinal;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-relaxed{line-height:1.625}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.text-neutral-500{--tw-text-opacity: 1;color:rgb(115 115 115 / var(--tw-text-opacity, 1))}.text-neutral-600{--tw-text-opacity: 1;color:rgb(82 82 82 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-50{opacity:.5}.outline-none{outline:2px solid transparent;outline-offset:2px}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--sidebar-width: 320px;--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-tertiary: #181818;--bg-panel: #141414;--border-primary: #222222;--border-secondary: #2a2a2a;--text-primary: #e8e8e8;--text-secondary: #999999;--text-muted: #555555;--accent: #00c8ff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh}#root{height:100vh}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border-primary)}.sidebar-section{flex:1;overflow-y:auto;padding:12px}.sidebar-section::-webkit-scrollbar{width:4px}.sidebar-section::-webkit-scrollbar-track{background:transparent}.sidebar-section::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:2px}.section-title{display:flex;align-items:center;justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px;padding:0 2px}.wall-panel{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:6px;padding:10px 12px;transition:border-color .15s ease}.wall-panel:hover{border-color:var(--border-secondary)}.wall-name-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;letter-spacing:.05em;width:100%}.wall-name-input:focus{color:#fff}.field-label{display:block;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:500;letter-spacing:.05em;color:var(--text-muted);text-transform:uppercase;margin-bottom:3px}.field-input{width:100%;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:12px;padding:5px 8px;outline:none;transition:border-color .15s ease}.field-input:focus{border-color:var(--accent)}.add-wall-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:8px;padding:8px;background:transparent;border:1px dashed var(--border-secondary);border-radius:6px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:11px;cursor:pointer;transition:all .15s ease}.add-wall-btn:hover{border-color:var(--accent);color:var(--accent);background:#00c8ff0a}.stat-grid{display:flex;flex-direction:column;gap:6px}.stat-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:4px}.stat-label{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-primary);font-weight:500}.sidebar-footer{padding:12px;border-top:1px solid var(--border-primary)}.export-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:#00c8ff14;border:1px solid rgba(0,200,255,.2);border-radius:6px;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all .15s ease}.export-btn:hover{background:#00c8ff24;border-color:var(--accent)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.section-tabs{display:flex;align-items:center;gap:0;padding:0 16px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.section-tab{display:flex;align-items:center;gap:6px;padding:10px 18px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:all .15s ease}.section-tab:hover{color:var(--text-secondary)}.section-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.section-tab-spacer{flex:1}.output-view-tabs{display:flex;align-items:center;gap:2px;padding:4px}.view-tab-mini{padding:4px 10px;background:transparent;border:1px solid var(--border-primary);border-radius:4px;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease}.view-tab-mini:hover{color:var(--text-secondary);border-color:var(--border-secondary)}.view-tab-mini.active{color:var(--accent);border-color:var(--accent);background:#00c8ff0f}.view-tabs{display:flex;gap:0;padding:0 16px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.view-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;letter-spacing:.05em;cursor:pointer;transition:all .15s ease}.view-tab:hover{color:var(--text-secondary)}.view-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.view-container{flex:1;display:flex;overflow:hidden}.view-container.split{flex-direction:column}.split-top{flex:1;border-bottom:1px solid var(--border-primary);overflow:hidden;min-height:0}.split-bottom{flex:1;overflow:hidden;min-height:0}.full-view{flex:1;overflow:hidden}.composite-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;position:relative;background:repeating-conic-gradient(#0e0e0e,#0e0e0e 25%,#0a0a0a 0%,#0a0a0a 50%) 0 0 / 20px 20px}.composite-label{position:absolute;top:12px;left:16px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.1em;color:var(--text-muted)}.composite-canvas-wrapper{border:1px solid var(--border-secondary);box-shadow:0 0 40px #00000080,0 0 80px #00c8ff08}.composite-canvas-wrapper canvas{display:block}.composite-info{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;justify-content:center}.wall-tag{font-family:JetBrains Mono,monospace;font-size:9px;font-weight:500;letter-spacing:.05em;padding:3px 8px;border:1px solid;border-radius:3px;background:#0006}.output-preview-container{width:100%;height:100%;position:relative;overflow:hidden;cursor:grab}.output-preview-container:active{cursor:grabbing}.output-preview-container canvas{display:block;position:absolute;top:0;left:0}.output-preview-info{position:absolute;bottom:10px;left:50%;transform:translate(-50%);display:flex;gap:6px;flex-wrap:wrap;z-index:5;pointer-events:none}.scene3d-container{width:100%;height:100%;position:relative;background:var(--bg-primary)}.scene3d-label{position:absolute;top:12px;left:16px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500;letter-spacing:.1em;color:var(--text-muted);z-index:10;pointer-events:none}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:44px;min-height:44px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.editor-toolbar-left{display:flex;align-items:center;gap:10px}.editor-toolbar-right{display:flex;align-items:center;gap:8px}.editor-toolbar-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:transparent;border:1px solid var(--border-primary);border-radius:5px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.editor-toolbar-btn:hover:not(:disabled){border-color:var(--border-secondary);color:var(--text-primary)}.editor-toolbar-btn:disabled{cursor:default}.editor-toolbar-divider{width:1px;height:20px;background:var(--border-primary)}.editor-project-name{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;color:var(--text-primary);letter-spacing:.02em}.editor-unsaved-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.editor-save-btn{display:flex;align-items:center;gap:5px;padding:5px 14px;background:#00c8ff1f;border:1px solid rgba(0,200,255,.25);border-radius:5px;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease}.editor-save-btn:hover:not(:disabled){background:#00c8ff33;border-color:var(--accent)}.editor-save-btn:disabled{cursor:default}.import-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:stretch;justify-content:stretch;padding:0;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.import-dialog{background:var(--bg-secondary);border:none;border-radius:0;width:100%;height:100%;max-width:none;max-height:none;display:flex;flex-direction:column;box-shadow:none;animation:fadeIn .2s ease}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.import-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary)}.import-dialog-title{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--text-primary)}.import-dialog-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s ease;display:flex;align-items:center}.import-dialog-close:hover{color:var(--text-primary);background:#ffffff0f}.import-dialog-body{padding:24px 32px;flex:1;overflow-y:auto;display:flex;flex-direction:column}.import-dropzone{border:2px dashed var(--border-secondary);border-radius:10px;padding:48px 32px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .2s ease;background:#ffffff03}.import-dropzone:hover,.import-dropzone.active{border-color:var(--accent);background:#00c8ff08}.import-dropzone-icon{color:var(--text-muted);transition:color .2s ease}.import-dropzone:hover .import-dropzone-icon,.import-dropzone.active .import-dropzone-icon{color:var(--accent)}.import-dropzone-title{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:500;color:var(--text-secondary)}.import-dropzone-subtitle{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.import-error{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-top:16px;background:#ff386014;border:1px solid rgba(255,56,96,.2);border-radius:6px;color:#ff3860;font-family:JetBrains Mono,monospace;font-size:11px}.import-hint{margin-top:20px;padding:12px 16px;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:6px;font-family:Inter,sans-serif;font-size:12px;line-height:1.6;color:var(--text-muted)}.import-analyzing{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px}.import-analyzing-title{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:600;color:var(--text-primary)}.import-analyzing-subtitle{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.import-review-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0}.import-comparison{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-primary);border-bottom:1px solid var(--border-primary)}.import-comparison-panel{display:flex;flex-direction:column;background:var(--bg-primary);padding:12px}.import-comparison-label{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;padding:0 4px}.import-comparison-count{background:var(--accent);color:#000;font-size:9px;font-weight:700;padding:1px 6px;border-radius:8px}.import-comparison-canvas{flex:1;display:flex;align-items:center;justify-content:center;min-height:220px;max-height:320px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;overflow:hidden;padding:0;cursor:grab;touch-action:none;position:relative}.import-comparison-canvas:active{cursor:grabbing}.import-comparison-canvas canvas{display:block;width:100%;height:100%}.import-toolbar{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.import-toolbar-group{display:flex;align-items:center;gap:4px}.import-toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--border-primary);border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.import-toolbar-btn:hover{border-color:var(--border-secondary);color:var(--text-primary);background:#ffffff0a}.import-toolbar-zoom{font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:var(--text-secondary);min-width:40px;text-align:center}.import-toolbar-btn-ocr{width:auto;padding:0 10px;gap:5px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500}.import-toolbar-btn-ocr:disabled{opacity:.5;cursor:not-allowed}.import-toolbar-hint{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted)}.import-ocr-progress{width:200px;margin-top:12px}.import-ocr-progress-bar{height:3px;background:var(--border-primary);border-radius:2px;overflow:hidden}.import-ocr-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.import-mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.import-mode-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;text-align:left}.import-mode-btn:hover{border-color:var(--border-secondary);background:#ffffff05}.import-mode-btn.active{border-color:var(--accent);background:#00c8ff0a;color:var(--text-primary)}.import-mode-btn.active svg{color:var(--accent)}.import-mode-btn-text{display:flex;flex-direction:column;gap:2px}.import-mode-btn-title{font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.import-mode-btn-desc{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--text-muted)}.import-toolbar-btn-vision{border-color:#00c8ff33;color:var(--accent)}.import-toolbar-btn-vision:hover:not(:disabled){border-color:var(--accent);background:#00c8ff14}.llm-settings-panel{margin-bottom:12px;border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.llm-settings-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:var(--bg-panel);border:none;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.llm-settings-toggle:hover{background:#ffffff08}.llm-settings-toggle-left{display:flex;align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500}.llm-settings-toggle-right{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.llm-status-icon.llm-status-ok{color:#23d160}.llm-status-icon.llm-status-error{color:#ff3860}.llm-settings-body{padding:12px 14px;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:10px}.llm-field{display:flex;flex-direction:column;gap:3px}.llm-field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23999'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}.llm-test-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;background:transparent;border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease}.llm-test-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.llm-test-btn:disabled{opacity:.5;cursor:not-allowed}.llm-status-msg{display:flex;align-items:flex-start;gap:6px;padding:8px 10px;border-radius:5px;font-family:JetBrains Mono,monospace;font-size:10px;line-height:1.4}.llm-status-msg.ok{background:#23d16014;border:1px solid rgba(35,209,96,.2);color:#23d160}.llm-status-msg.error{background:#ff386014;border:1px solid rgba(255,56,96,.2);color:#ff3860}.llm-status-msg svg{flex-shrink:0;margin-top:1px}.llm-settings-hint{font-family:JetBrains Mono,monospace;font-size:10px;line-height:1.6;color:var(--text-muted);padding:8px 0 0}.llm-settings-hint code{display:inline-block;background:var(--bg-primary);padding:2px 6px;border-radius:3px;font-size:10px;color:var(--accent);margin:2px 0}.llm-settings-warning{margin-top:8px;padding:6px 8px;background:#f5a6231f;border:1px solid rgba(245,166,35,.3);border-radius:4px;color:#f5a623;font-size:10px;line-height:1.5}.import-comparison-info{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted);text-align:center;margin-top:6px}.import-slices-list{padding:12px 16px;flex:1}.import-slices-header{display:flex;align-items:center;justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;padding:0 4px}.import-slices-count{color:var(--accent);font-weight:500}.import-slices-scroll{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.import-slices-scroll::-webkit-scrollbar{width:4px}.import-slices-scroll::-webkit-scrollbar-track{background:transparent}.import-slices-scroll::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:2px}.import-slice-item{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:6px;transition:border-color .15s ease}.import-slice-item:hover{border-color:var(--border-secondary)}.import-slice-item.expanded{border-color:var(--accent);background:#00c8ff05}.import-slice-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer}.import-slice-color{width:14px;height:14px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.import-slice-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.import-slice-name{font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;color:var(--text-primary)}.import-slice-dims{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text-muted)}.import-slice-actions{color:var(--text-muted);display:flex;align-items:center}.import-slice-edit{padding:8px 12px 12px;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:8px}.import-slice-edit-row{display:flex;flex-direction:column;gap:3px}.import-slice-edit-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:6px}.import-color-picker{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;padding:0;background:none}.import-color-picker::-webkit-color-swatch-wrapper{padding:0}.import-color-picker::-webkit-color-swatch{border:1px solid rgba(255,255,255,.15);border-radius:3px}.import-remove-slice{display:flex;align-items:center;gap:5px;align-self:flex-start;background:none;border:none;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px;cursor:pointer;padding:4px 0;transition:color .15s ease}.import-remove-slice:hover{color:#ff3860}.import-no-slices{padding:24px;text-align:center;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.import-dialog-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-primary);background:var(--bg-secondary);border-radius:0 0 12px 12px}.import-footer-left,.import-footer-right{display:flex;align-items:center;gap:8px}.import-btn-secondary{display:flex;align-items:center;gap:6px;padding:7px 14px;background:transparent;border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.import-btn-secondary:hover{border-color:var(--text-muted);color:var(--text-primary)}.import-btn-primary{display:flex;align-items:center;gap:6px;padding:7px 16px;background:#00c8ff1f;border:1px solid rgba(0,200,255,.3);border-radius:6px;color:var(--accent);font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease}.import-btn-primary:hover:not(:disabled){background:#00c8ff33;border-color:var(--accent)}.import-btn-primary:disabled{opacity:.4;cursor:default}@media (max-width: 768px){.app-layout{flex-direction:column}.sidebar{width:100%;min-width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-primary)}.main-content{flex:1}}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover,.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width: 640px){.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
