:root{--color-primary: 214 51 132;--color-secondary: 156 106 222;--color-accent: 230 167 0;--color-text: 30 30 30;--color-muted: 80 80 80;--color-border: 0 0 0;--color-background: 245 245 240;--color-surface: 255 255 255;--color-success: 16 185 129;--color-error: 239 68 68;--color-warning: 245 158 11;--color-info: 6 182 212;--cl: #e8e8e3;--cd: #ddd}[data-mode=dark]{--color-primary: 255 107 157;--color-secondary: 199 146 234;--color-accent: 253 235 139;--color-text: 228 228 231;--color-muted: 180 180 180;--color-border: 255 255 255;--color-background: 14 14 30;--color-surface: 24 24 42;--color-success: 114 241 184;--color-error: 255 107 107;--color-warning: 253 235 139;--color-info: 110 231 239;--cl: #1a1a2e;--cd: #16162a}*,*:before,*:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:rgb(var(--color-border)/15%)}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 .3s,color .3s}*{scrollbar-width:thin;scrollbar-color:rgba(var(--color-text)/20%) transparent}*::-webkit-scrollbar{width:5px;height:5px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:rgba(var(--color-text)/20%);border-radius:10px}*::-webkit-scrollbar-thumb:hover{background:rgba(var(--color-text)/35%)}#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;border-radius:.5rem}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 .3s}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:1.25rem;padding:1rem;display:flex;flex-direction:column;gap:.75rem}@media(max-width:639px){.panel{padding:.75rem;gap:.5rem;border-radius:1rem}}.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:1rem;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 .3s,transform .3s;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}@media(max-width:639px){.btn.btn-sm{padding:.375rem .5rem;font-size:.75rem;min-height:36px}}.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%)}@media(max-width:639px){.btn{min-height:36px}}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:1rem;border:none;background:transparent;color:rgb(var(--color-text));transition:background-color .3s,color .3s,transform .3s}.btn-icon:hover{background:rgb(var(--color-primary)/10%);color:rgb(var(--color-primary))}.btn-icon:active{transform:scale(.92)}@media(max-width:639px){.btn-icon{width:36px;height:36px}}.input{width:100%;padding:.375rem .5rem;border-radius:1rem;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 .3s}.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:1rem;border:2px dashed rgb(var(--color-border)/30%);transition:all .3s}.upload-zone:hover,.upload-zone.dragging{border-color:rgb(var(--color-primary)/50%);background:rgb(var(--color-primary)/5%)}@media(max-width:639px){.upload-zone{padding:1.5rem 1rem}}.hint{font-size:.6875rem;color:rgb(var(--color-text)/70%);background:rgb(var(--color-background));border-radius:1rem;padding:.375rem .5rem}.canvas-container{border-radius:1.25rem;overflow:hidden;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;-webkit-user-select:none;user-select:none}@media(max-width:639px){.canvas-container{min-height:150px;max-height:50vh}}@media(pointer:coarse){.canvas-container{touch-action:none}}.canvas-container.canvas-fill{min-height:unset;max-height:none;flex:1 1 0}.canvas-transform-layer{position:absolute;left:0;top:0}.sb-track{position:absolute;z-index:5;background:rgba(var(--color-border)/6%)}.sb-track.sb-h{bottom:0;left:0;height:10px}.sb-track.sb-v{right:0;top:0;width:10px}.sb-thumb{position:absolute;border-radius:5px;background:rgba(var(--color-text)/25%);transition:background .3s}.sb-thumb:hover,.sb-thumb:active{background:rgba(var(--color-text)/40%)}.sb-h .sb-thumb{top:2px;height:6px}.sb-v .sb-thumb{left:2px;width:6px}.minimap-box{position:absolute;z-index:4;border:1px solid rgba(var(--color-border)/25%);border-radius:6px;overflow:hidden;background:rgba(var(--color-surface)/85%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #00000026;cursor:crosshair}.canvas-render{display:block;max-width:none}.switch{position:relative;display:inline-block;width:32px;height:18px;border-radius:9px;background:rgb(var(--color-border)/30%);border:none;cursor:pointer;transition:background .3s;flex-shrink:0}.switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .3s}.switch.active{background:rgb(var(--color-primary))}.switch.active:after{transform:translate(14px)}.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}.drawer-layout{display:flex;gap:.75rem;align-items:flex-start}.drawer-panel{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;overflow-x:hidden}@media(max-width:1023px){.drawer-panel{position:fixed;top:0;bottom:0;width:min(320px,85vw);z-index:30;background:rgb(var(--color-background));padding:1rem;transition:transform .3s cubic-bezier(.4,0,.2,1)}.drawer-panel.dp-l{left:0;transform:translate(-100%);border-right:1px solid rgb(var(--color-border)/15%)}.drawer-panel.dp-l.open{transform:translate(0)}}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:.5rem;border-bottom:1px solid rgb(var(--color-border)/10%)}@media(min-width:1024px){.drawer-head{display:none}}.drawer-toggle{position:fixed;top:50%;transform:translateY(-50%);z-index:20;width:24px;height:48px;display:flex;align-items:center;justify-content:center;background:rgb(var(--color-surface)/90%);border:1px solid rgb(var(--color-border)/15%);color:rgb(var(--color-text)/50%);cursor:pointer;transition:all .3s}@media(min-width:1024px){.drawer-toggle{display:none}}.drawer-toggle:hover{background:rgb(var(--color-surface));color:rgb(var(--color-primary));border-color:rgb(var(--color-primary)/30%)}.drawer-toggle.dt-l{left:0;border-radius:0 .5rem .5rem 0;border-left:none}.drawer-toggle.dt-r{right:0;border-radius:.5rem 0 0 .5rem;border-right:none}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:29;background:#00000040}@media(min-width:1024px){.drawer-backdrop{display:none}}@keyframes fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .3s ease-out}.animate-spin{animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.about-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease,visibility .3s}.about-overlay.about-visible{opacity:1;visibility:visible}.about-overlay.about-hidden{opacity:0;visibility:hidden;pointer-events:none}.about-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000004d}.about-dialog{position:relative;z-index:50;width:min(400px,90vw);background:rgb(var(--color-surface));border:1px solid rgb(var(--color-border)/15%);border-radius:1.25rem;box-shadow:0 8px 32px #0000002e;overflow:hidden}.about-dialog .about-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid rgb(var(--color-border)/10%)}.about-dialog .about-dialog-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;font-size:.8125rem;line-height:1.6}.about-dialog .about-dialog-divider{height:1px;background:rgb(var(--color-border)/10%);margin:.25rem 0}.about-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:rgb(var(--color-primary));text-decoration:none;transition:opacity .3s}.about-link:hover{opacity:.8;text-decoration:underline}.fixed{position:fixed}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-y-0{top:0;bottom:0}.left-0{left:0}.top-0{top:0}.z-\[29\]{z-index:29}.z-10{z-index:10}.z-30{z-index:30}.hover\:z-10:hover{z-index:10}.order-1{order:1}.order-2{order:2}.grid{display:grid}.mx{margin-left:1rem;margin-right:1rem}.my{margin-top:1rem;margin-bottom:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.block{display:block}.hidden{display:none}.h-\[100dvh\]{height:100dvh}.h-3{height:.75rem}.h-4{height:1rem}.h-full{height:100%}.min-h-0{min-height:0}.min-h-screen{min-height:100vh}.w-\[85vw\]{width:85vw}.w-10{width:2.5rem}.w-3{width:.75rem}.w-4{width:1rem}.w-80{width:20rem}.w-full{width:100%}.flex{display:flex}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-col{flex-direction:column}.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}}.animate-fade-in{animation:fade-in 1s linear 1}.select-none{-webkit-user-select:none;user-select:none}.items-center{align-items:center}.justify-center{justify-content: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-3{gap:.75rem}.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-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.b,.border{border-width:1px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-t{border-top-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-border\/10{border-color:rgb(var(--color-border) / .1)}.border-border\/30{border-color:rgb(var(--color-border) / .3)}.border-border\/40{border-color:rgb(var(--color-border) / .4)}.border-primary\/30{border-color:rgb(var(--color-primary) / .3)}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.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-black\/25{background-color:#00000040}.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))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px,.px-4{padding-left:1rem;padding-right:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.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}.pb-2{padding-bottom:.5rem}.pr-3{padding-right:.75rem}.pt-2{padding-top:.5rem}.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{--un-text-opacity:1;color:rgb(var(--color-text) / var(--un-text-opacity))}.text-text-secondary{--un-text-opacity:1;color:rgb(var(--color-muted) / var(--un-text-opacity))}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-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-200{transition-duration:.2s}@media(min-width:640px){.sm\:inline{display:inline}}@media(min-width:1024px){.lg\:order-1{order:1}.lg\:order-2{order:2}.lg\:grid{display:grid}.lg\:grid-cols-\[320px_1fr\]{grid-template-columns:320px 1fr}.lg\:\!hidden{display:none!important}.lg\:hidden{display:none}.lg\:flex{display:flex}}
