:root{--color-primary: 99 102 241;--color-secondary: 139 92 246;--color-accent: 14 165 233;--color-text: 30 30 30;--color-muted: 115 115 130;--color-border: 200 200 208;--color-background: 246 246 250;--color-surface: 255 255 255;--color-success: 34 197 94;--color-error: 239 68 68;--color-warning: 245 158 11;--color-info: 6 182 212;--cl: #eee;--cd: #ddd}[data-mode=dark]{--color-primary: 129 140 248;--color-secondary: 167 139 250;--color-accent: 56 189 248;--color-text: 228 228 234;--color-muted: 130 130 150;--color-border: 55 55 70;--color-background: 16 16 22;--color-surface: 24 24 32;--color-success: 74 222 128;--color-error: 252 129 129;--color-warning: 251 191 36;--color-info: 34 211 238;--cl: #2a2a2a;--cd: #222}*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-size:14px;line-height:1.5;background-color:rgb(var(--color-background));color:rgb(var(--color-text));transition:background-color .2s,color .2s}#app{min-height:100vh}img{max-width:100%;height:auto}button{cursor:pointer;font-family:inherit}:focus-visible{outline:2px solid rgb(var(--color-primary)/60%);outline-offset:2px}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:rgb(var(--color-border)/40%);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:rgb(var(--color-primary));cursor:pointer;transition:transform .15s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:rgb(var(--color-primary));cursor:pointer;border:none}.panel{border:1px solid rgb(var(--color-border)/15%);background-color:rgb(var(--color-surface)/50%);border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.panel-title{font-size:.875rem;font-weight:600;display:flex;align-items:center;gap:.375rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:500;border:1px solid rgb(var(--color-border)/15%);background:rgb(var(--color-surface));color:rgb(var(--color-text));transition:background-color .1s,transform .1s;white-space:nowrap}.btn:hover{background:rgb(var(--color-primary)/10%)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;pointer-events:none}.btn.btn-sm{padding:.25rem .5rem;font-size:.6875rem}.btn.btn-primary{background:rgb(var(--color-primary));color:#fff;border-color:transparent}.btn.btn-primary:hover{opacity:.9}.btn.btn-danger{background:rgb(var(--color-error)/10%);color:rgb(var(--color-error));border-color:rgb(var(--color-error)/20%)}.btn.btn-danger:hover{background:rgb(var(--color-error)/20%)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:.5rem;border:none;background:transparent;color:rgb(var(--color-text));transition:background-color .1s,color .1s,transform .1s}.btn-icon:hover{background:rgb(var(--color-primary)/10%);color:rgb(var(--color-primary))}.btn-icon:active{transform:scale(.92)}.input{width:100%;padding:.375rem .5rem;border-radius:.5rem;background:rgb(var(--color-background));border:1px solid rgb(var(--color-border)/15%);font-size:.875rem;font-family:inherit;color:rgb(var(--color-text));transition:border-color .15s}.input:focus{border-color:rgb(var(--color-primary));outline:none}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1rem;cursor:pointer;border-radius:.5rem;border:2px dashed rgb(var(--color-border)/30%);transition:all .2s}.upload-zone:hover,.upload-zone.dragging{border-color:rgb(var(--color-primary)/50%);background:rgb(var(--color-primary)/5%)}.hint{font-size:.6875rem;color:rgb(var(--color-text)/70%);background:rgb(var(--color-background));border-radius:.5rem;padding:.375rem .5rem}.canvas-container{border-radius:.5rem;overflow:auto;border:1px solid rgb(var(--color-border)/15%);background-color:var(--cd);background-image:linear-gradient(45deg,var(--cl) 25%,transparent 25%),linear-gradient(-45deg,var(--cl) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--cl) 75%),linear-gradient(-45deg,transparent 75%,var(--cl) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;min-height:200px;max-height:70vh;position:relative}@media(pointer:coarse){.canvas-container{touch-action:pan-x pan-y pinch-zoom}}.canvas-render{display:block;max-width:none}.bg-checkerboard{background-color:var(--cd);background-image:linear-gradient(45deg,var(--cl) 25%,transparent 25%),linear-gradient(-45deg,var(--cl) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--cl) 75%),linear-gradient(-45deg,transparent 75%,var(--cl) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0}@keyframes fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .15s ease-out}.animate-spin{animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sticky{position:sticky}.top-0{top:0}.z-10,.hover\:z-10:hover{z-index:10}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.block{display:block}.hidden{display:none}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.max-h-36{max-height:9rem}.max-h-48{max-height:12rem}.max-h-56{max-height:14rem}.max-w-7xl{max-width:80rem}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.w-10{width:2.5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.flex{display:flex}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-wrap{flex-wrap:wrap}.hover\:scale-150:hover{--un-scale-x:1.5;--un-scale-y:1.5;transform:translate(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skew(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}.transform{transform:translate(var(--un-translate-x)) translateY(var(--un-translate-y)) translateZ(var(--un-translate-z)) rotate(var(--un-rotate)) rotateX(var(--un-rotate-x)) rotateY(var(--un-rotate-y)) rotate(var(--un-rotate-z)) skew(var(--un-skew-x)) skewY(var(--un-skew-y)) scaleX(var(--un-scale-x)) scaleY(var(--un-scale-y)) scaleZ(var(--un-scale-z))}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fade-in 1s linear 1}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.cursor-crosshair{cursor:crosshair}.select-none{-webkit-user-select:none;user-select:none}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-y-1\.5>:not([hidden])~:not([hidden]){--un-space-y-reverse:0;margin-top:calc(.375rem * calc(1 - var(--un-space-y-reverse)));margin-bottom:calc(.375rem * var(--un-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--un-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--un-space-y-reverse)));margin-bottom:calc(.5rem * var(--un-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--un-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--un-space-y-reverse)));margin-bottom:calc(.75rem * var(--un-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-black\/10{border-color:#0000001a}.border-border{--un-border-opacity:15%;border-color:rgb(var(--color-border) / var(--un-border-opacity))}.border-primary\/30{border-color:rgb(var(--color-primary) / .3)}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.bg-background{--un-bg-opacity:1;background-color:rgb(var(--color-background) / var(--un-bg-opacity))}.bg-background\/80{background-color:rgb(var(--color-background) / .8)}.bg-error\/10{background-color:rgb(var(--color-error) / .1)}.bg-primary\/10{background-color:rgb(var(--color-primary) / .1)}.hover\:bg-background:hover{--un-bg-opacity:1;background-color:rgb(var(--color-background) / var(--un-bg-opacity))}.object-contain{object-fit:contain}.p-1{padding:.25rem}.p-10{padding:2.5rem}.p-2{padding:.5rem}.p-4{padding:1rem}.px,.px-4{padding-left:1rem;padding-right:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.py{padding-top:1rem;padding-bottom:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pt-1{padding-top:.25rem}.text-center{text-align:center}.text-left{text-align:left}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-error{--un-text-opacity:1;color:rgb(var(--color-error) / var(--un-text-opacity))}.text-primary{--un-text-opacity:1;color:rgb(var(--color-primary) / var(--un-text-opacity))}.text-text,.text-text-secondary{--un-text-opacity:1;color:rgb(var(--color-text) / var(--un-text-opacity))}.hover\:text-primary:hover{--un-text-opacity:1;color:rgb(var(--color-primary) / var(--un-text-opacity))}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.font-mono{font-family:JetBrains Mono,Fira Code,ui-monospace,sfmono-regular,monospace}.font-sans{font-family:Inter,ui-sans-serif,system-ui,-apple-system,blinkmacsystemfont,Segoe UI,roboto,sans-serif}.tabular-nums{--un-numeric-spacing:tabular-nums;font-variant-numeric:var(--un-ordinal) var(--un-slashed-zero) var(--un-numeric-figure) var(--un-numeric-spacing) var(--un-numeric-fraction)}.hover\:underline:hover{text-decoration-line:underline}.ring-2{--un-ring-width:2px;--un-ring-offset-shadow:var(--un-ring-inset) 0 0 0 var(--un-ring-offset-width) var(--un-ring-offset-color);--un-ring-shadow:var(--un-ring-inset) 0 0 0 calc(var(--un-ring-width) + var(--un-ring-offset-width)) var(--un-ring-color);box-shadow:var(--un-ring-offset-shadow),var(--un-ring-shadow),var(--un-shadow)}.ring-primary{--un-ring-opacity:1;--un-ring-color:rgb(var(--color-primary) / var(--un-ring-opacity)) }.backdrop-blur-md{--un-backdrop-blur:blur(12px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-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}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}@media(min-width:640px){.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:inline{display:inline}}@media(min-width:768px){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}@media(min-width:1024px){.lg\:col-span-4{grid-column:span 4/span 4}.lg\:col-span-8{grid-column:span 8/span 8}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}}@media(min-width:1280px){.xl\:col-span-3{grid-column:span 3/span 3}.xl\:col-span-9{grid-column:span 9/span 9}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}}
