/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@layer theme{:root,:host{--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-400:oklch(70.4% .04 256.788);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--font-weight-medium:500;--font-weight-semibold:600;--radius-sm:.25rem;--radius-md:.375rem;--radius-xl:.75rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1)}}@layer base,components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.right-2{right:calc(var(--spacing) * 2)}.z-50{z-index:50}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.my-1{margin-block:calc(var(--spacing) * 1)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.size-3\.5{width:calc(var(--spacing) * 3.5);height:calc(var(--spacing) * 3.5)}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-4{height:calc(var(--spacing) * 4)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-px{height:1px}.max-h-\(--radix-select-content-available-height\){max-height:var(--radix-select-content-available-height)}.w-4{width:calc(var(--spacing) * 4)}.w-9{width:calc(var(--spacing) * 9)}.w-fit{width:fit-content}.w-full{width:100%}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.shrink-0{flex-shrink:0}.origin-\(--radix-select-content-transform-origin\){transform-origin:var(--radix-select-content-transform-origin)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-default{cursor:default}.scroll-my-1{scroll-margin-block:calc(var(--spacing) * 1)}.auto-rows-min{grid-auto-rows:min-content}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-6{gap:calc(var(--spacing) * 6)}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-transparent{border-color:#0000}.bg-transparent{background-color:#0000}.p-1{padding:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-6{padding-block:calc(var(--spacing) * 6)}.pr-8{padding-right:calc(var(--spacing) * 8)}.pl-2{padding-left:calc(var(--spacing) * 2)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-nowrap{white-space:nowrap}.text-slate-400{color:var(--color-slate-400)}.text-white{color:var(--color-white)}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline-hidden{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.outline-hidden{outline-offset:2px;outline:2px solid #0000}}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}@media (hover:hover){.hover\:border-slate-200:hover{border-color:var(--color-slate-200)}.hover\:bg-slate-100:hover{background-color:var(--color-slate-100)}.hover\:underline:hover{text-decoration-line:underline}}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[size\=default\]\:h-9[data-size=default]{height:calc(var(--spacing) * 9)}.data-\[size\=sm\]\:h-8[data-size=sm]{height:calc(var(--spacing) * 8)}:is(.\*\:data-\[slot\=select-value\]\:line-clamp-1>*)[data-slot=select-value]{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}:is(.\*\:data-\[slot\=select-value\]\:flex>*)[data-slot=select-value]{display:flex}:is(.\*\:data-\[slot\=select-value\]\:items-center>*)[data-slot=select-value]{align-items:center}:is(.\*\:data-\[slot\=select-value\]\:gap-2>*)[data-slot=select-value]{gap:calc(var(--spacing) * 2)}@media (min-width:48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}:is(.\*\:\[span\]\:last\:flex>*):is(span):last-child{display:flex}:is(.\*\:\[span\]\:last\:items-center>*):is(span):last-child{align-items:center}:is(.\*\:\[span\]\:last\:gap-2>*):is(span):last-child{gap:calc(var(--spacing) * 2)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f2f5;--surface:#fff;--border:#e2e8f0;--text:#1a1a2e;--text-secondary:#64748b;--text-muted:#94a3b8;--primary:#5d9b45;--primary-hover:#4d8638;--danger:#dc2626;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-lg:0 10px 40px #0000001f, 0 2px 8px #00000014;--shadow-xl:0 20px 60px #00000026, 0 4px 16px #0000001a}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;overflow:hidden}#root{z-index:0;position:relative}input,button,select,textarea{font-family:inherit}button{cursor:pointer;font-size:inherit;background:0 0;border:none}input{border:1px solid var(--border);border-radius:6px;outline:none;padding:6px 10px;font-size:13px;transition:border-color .15s}input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #5d9b451a}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app{z-index:0;flex-direction:column;width:100%;height:100%;display:flex;position:relative}.toolbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;align-items:center;gap:8px;height:52px;padding:8px 16px;display:flex}.toolbar-logo{color:var(--primary);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-right:8px;font-size:16px;font-weight:700;display:flex}.toolbar-logo svg{width:28px;height:28px}.toolbar-divider{background:var(--border);width:1px;height:28px;margin:0 4px}.toolbar-btn{border-radius:var(--radius-sm);color:var(--text-secondary);white-space:nowrap;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.toolbar-btn:hover{color:var(--text);background:#f1f5f9}.toolbar-btn.active{color:var(--primary);background:#f0f7ec}.toolbar-btn.primary{background:var(--primary);color:#fff}.toolbar-btn.primary:hover{background:var(--primary-hover)}.toolbar-btn.danger{color:#dc2626}.toolbar-btn.danger:hover{color:#b91c1c;background:#fef2f2}.context-menu-content{padding:5px 8px}.conn-color-row{align-items:center;gap:5px;display:flex}.conn-color-label{color:#94a3b8;flex-shrink:0;margin-right:2px;font-size:11px;font-weight:500}.conn-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:transform .1s}.conn-color-dot:hover{transform:scale(1.2)}.conn-color-dot.active{box-shadow:0 0 0 2px #fff,0 0 0 3.5px}.toolbar-btn svg{width:16px;height:16px}.toolbar-spacer{flex:1}.toolbar-zoom{color:var(--text-secondary);font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:12px;display:flex}.toolbar-zoom button{width:28px;height:28px;color:var(--text-secondary);border-radius:6px;justify-content:center;align-items:center;display:flex}.toolbar-zoom button:hover{background:#f1f5f9}.main-area{z-index:0;flex:1;display:flex;position:relative;overflow:hidden}.canvas-wrapper{cursor:grab;flex:1;position:relative;overflow:hidden}.modal-open .toolbar{pointer-events:none;opacity:.5}.canvas-wrapper.grabbing{cursor:grabbing}.canvas-wrapper.selecting{cursor:default}.canvas{transform-origin:0 0;width:100%;height:100%;position:absolute;top:0;left:0}.canvas-grid{pointer-events:none;background-image:radial-gradient(circle,#d1d5db 1px,#0000 1px);background-size:24px 24px;width:10000px;height:10000px;position:absolute;top:-5000px;left:-5000px}.canvas-3d{perspective:1400px}.canvas-3d .block{transition:transform .15s,box-shadow .15s;box-shadow:6px 10px 24px #0000002e,0 2px 6px #0000001a}.canvas-3d .block:hover{transform:translate(-2px,-3px);box-shadow:0 2px 4px #0000000f,0 8px 24px #0000001f,6px 11px #00000012,7px 12px #0000000a}.canvas-3d .group{box-shadow:2px 4px 12px #00000014}.canvas-content{transform-origin:50%;position:absolute;top:0;left:0}.canvas-layer{pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0}.canvas-layer>*{pointer-events:auto}.canvas-layer-groups{z-index:1}.canvas-connections{z-index:2}.canvas-layer-blocks{z-index:3}.block-port{background:var(--surface);border:2.5px solid var(--primary);cursor:crosshair;z-index:10;border-radius:50%;width:12px;height:12px;transition:background .12s,transform .12s;position:absolute}.block-port:hover{background:var(--primary);transform:translateY(-50%)scale(1.3)}.block-port-right{right:-2px}.block-port-left{left:-7px}.block{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--border);-webkit-user-select:none;user-select:none;min-width:220px;transition:box-shadow .15s,border-color .15s;position:absolute}.block:hover{box-shadow:var(--shadow-lg)}.block.selected{border-color:var(--primary);box-shadow:var(--shadow-lg),0 0 0 3px #5d9b4526}.block.dragging{box-shadow:var(--shadow-xl);opacity:.95;z-index:9999!important}.block-header{border-bottom:1px solid var(--border);cursor:move;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.block-header-left{align-items:center;gap:10px;display:flex}.block-title{color:var(--text);font-size:15px;font-weight:600}.block-badge{color:#fff;text-transform:uppercase;letter-spacing:.3px;border-radius:6px;align-items:center;gap:4px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.block-menu-btn{width:28px;height:28px;color:var(--text-muted);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.block-menu-btn:hover{color:var(--text);background:#f1f5f9}.block-accent{border-radius:var(--radius) var(--radius) 0 0;height:3px;position:absolute;top:-2px;left:-2px;right:-2px}.block-body{padding:8px 0}.block-property{align-items:center;gap:10px;min-height:32px;padding:6px 16px;font-size:13px;display:flex}.block-property:hover{background:#f8fafc}.block-property-icon{text-align:center;width:20px;height:20px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.block-property-icon svg{width:16px;height:16px}.block-property-label{color:var(--text-secondary);min-width:80px}.block-property-value{color:var(--text);text-align:right;margin-left:auto;font-weight:500}.block-property-status{align-items:center;gap:5px;margin-left:auto;font-size:12px;font-weight:600;display:inline-flex}.block-property-status .dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.block-add-property{color:var(--text-muted);text-align:left;align-items:center;gap:6px;width:100%;padding:6px 16px;font-size:12px;display:flex}.block-add-property:hover{color:var(--primary);background:#f8fafc}.block-resize{cursor:se-resize;opacity:0;width:16px;height:16px;transition:opacity .15s;position:absolute;bottom:0;right:0}.block:hover .block-resize,.block.selected .block-resize{opacity:1}.block-resize:after{content:"";border-bottom:2px solid #cbd5e1;border-right:2px solid #cbd5e1;border-bottom-right-radius:10px;width:8px;height:8px;position:absolute;bottom:4px;right:4px}.group{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);-webkit-user-select:none;user-select:none;background:#f4f8ff;border:2px dashed #cbd5e1;border-radius:16px;transition:border-color .15s,background-color .15s,box-shadow .15s;position:absolute}.group.selected{box-shadow:inset 0 0 0 1px #5d9b452e,0 0 0 3px #5d9b451f}.group-header{color:var(--text-secondary);cursor:move;align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:flex}.group-header-icon{font-size:14px}.group-header-title{flex:1;min-width:0;font-weight:500}.group-title-input{min-width:0;height:28px;color:var(--text);-webkit-user-select:text;user-select:text;background:#fffffff5;border:1px solid #d1d9e2;border-radius:8px;outline:none;flex:1;padding:0 10px;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s;box-shadow:0 0 #5d9b4500}.group-title-input:focus{border-color:#93c97a;box-shadow:0 0 0 3px #5d9b4524}.group-menu-btn{width:24px;height:24px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.group-menu-btn:hover{background:#0000000d}.group-resize{cursor:se-resize;opacity:0;width:20px;height:20px;transition:opacity .15s;position:absolute;bottom:0;right:0}.group:hover .group-resize,.group.selected .group-resize{opacity:1}.group-resize:after{content:"";border-bottom:2px solid #cbd5e1;border-right:2px solid #cbd5e1;border-bottom-right-radius:10px;width:9px;height:9px;position:absolute;bottom:5px;right:5px}.context-menu{z-index:10000;background:#fff;border:1px solid #e4eaf2;border-radius:12px;min-width:176px;padding:5px;animation:.1s fadeInScale;position:fixed;box-shadow:0 8px 28px #0f172a1c,0 2px 6px #0f172a0d}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}.context-menu-item{color:var(--text);text-align:left;cursor:pointer;border-radius:7px;align-items:center;gap:9px;width:100%;padding:7px 10px;font-size:13px;font-weight:450;transition:background 80ms;display:flex}.context-menu-item:hover{background:#f1f5f9}.context-menu-item.danger{color:#dc2626}.context-menu-item.danger:hover{background:#fef2f2}.context-menu-item svg{opacity:.5;flex-shrink:0;width:14px;height:14px}.context-menu-item.danger svg{opacity:.7}.context-menu-divider{background:#edf0f5;height:1px;margin:4px 0}.icon-picker-btn{width:42px;height:28px;color:var(--text-muted);cursor:pointer;background:#fff;border:1px solid #e4eaf2;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;gap:3px;transition:background 80ms,border-color 80ms;display:flex}.icon-picker-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.icon-picker-btn-icon{color:#64748b;width:14px;height:14px}.icon-picker-btn-chevron{color:#94a3b8;flex-shrink:0;width:8px;height:8px}.icon-picker-panel{z-index:10020;background:#fff;border:1px solid #e4eaf2;border-radius:12px;padding:6px;animation:.1s fadeInScale;position:fixed;box-shadow:0 8px 28px #0f172a1c,0 2px 6px #0f172a0d}.icon-picker-filters{background:#f1f5f9;border-radius:7px;gap:2px;margin-bottom:5px;padding:3px;display:flex}.icon-picker-filter{color:#64748b;cursor:pointer;border-radius:5px;flex:1;height:24px;font-size:12px;font-weight:500;transition:background 80ms,color 80ms}.icon-picker-filter.active{color:#0f172a;background:#fff;box-shadow:0 1px 3px #0f172a14}.icon-picker-filter:not(.active):hover{color:#334155}.icon-picker-grid{grid-template-columns:repeat(8,1fr);gap:2px;max-height:224px;display:grid;overflow-y:auto}.icon-picker-grid::-webkit-scrollbar{width:4px}.icon-picker-grid::-webkit-scrollbar-track{background:0 0}.icon-picker-grid::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}.icon-picker-item{aspect-ratio:1;color:#64748b;cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:background 80ms,color 80ms;display:flex}.icon-picker-item svg,.icon-picker-item .property-icon{width:15px;height:15px}.icon-picker-item:hover{color:#0f172a;background:#f1f5f9}.icon-picker-item.selected{color:#fff;background:#0f172a;border-radius:6px}.side-panel{background:var(--surface);border-left:1px solid var(--border);flex-shrink:0;width:320px;animation:.2s slideInRight;overflow-y:auto}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.panel-header h3{font-size:14px;font-weight:600}.panel-close{width:28px;height:28px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.panel-close:hover{color:var(--text);background:#f1f5f9}.panel-section{border-bottom:1px solid var(--border);padding:16px}.panel-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:11px;font-weight:600}.panel-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.panel-row label{color:var(--text-secondary);min-width:60px;font-size:13px}.color-picker-row{flex-wrap:wrap;gap:10px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:7px;width:20px;height:20px;transition:all .15s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--text)}.icon-picker-row{flex-wrap:wrap;gap:4px;display:flex}.icon-btn{cursor:pointer;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.icon-btn:hover{background:#f1f5f9}.icon-btn.active{box-shadow:inset 0 0 0 2px var(--primary);background:#f0f7ec}.sp-group-preview{background:#f4f8ff;border:2px dashed #cbd5e1;border-radius:16px;min-height:140px;padding:14px 16px}.sp-group-preview-title{color:var(--text-secondary);align-items:center;gap:8px;font-size:14px;font-weight:500;display:inline-flex}.sp-group-preview-icon{font-size:15px}.sp-input{height:32px;color:var(--text);background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s}.sp-input:focus{background:#fff;border-color:#94a3b8}.sp-input::placeholder{color:#aab4c4}.sp-input-number{width:80px}.sp-field{align-items:center;gap:8px;margin-bottom:8px;display:flex}.sp-field:last-child{margin-bottom:0}.sp-field label{color:var(--text-secondary);flex-shrink:0;min-width:44px;font-size:12px;font-weight:500}.sp-color-field{align-items:flex-start;padding-top:3px}.sp-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;overflow:hidden}.sp-empty{color:#b0bac8;padding:12px 14px;font-size:13px}.sp-prop{border-bottom:1px solid #f1f5f9}.sp-prop:last-child{border-bottom:none}.sp-prop-row{align-items:center;gap:6px;min-height:38px;padding:5px 6px 5px 5px;display:flex}.sp-ghost{background:0 0;border:none;border-radius:4px;outline:none;padding:2px 4px;font-family:inherit;font-size:13px;transition:background .1s}.sp-ghost:focus{background:#f1f5f9}.sp-label{color:#64748b;text-overflow:ellipsis;white-space:nowrap;cursor:text;flex:1;min-width:0;overflow:hidden}.sp-label::placeholder{color:#b0bac8}.sp-value{text-align:right;width:86px;color:var(--text)}.sp-value::placeholder{color:#d1d9e0}.sp-status-display{flex-shrink:0;align-items:center;gap:5px;display:flex}.sp-status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.sp-status-text{text-align:right;cursor:text;width:72px;font-size:13px}.sp-status-text::placeholder{color:#b0bac8}.sp-dot-btn{cursor:pointer;background:0 0;border:1.5px solid #d1d9e2;border-radius:50%;flex-shrink:0;width:14px;height:14px;transition:border-color .12s,transform .12s}.sp-dot-btn:hover{border-color:#94a3b8;transform:scale(1.2)}.sp-dot-btn.active{border-color:#0000}.sp-delete-btn{color:#b0bac8;opacity:0;cursor:pointer;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:opacity .1s,background .1s,color .1s;display:flex}.sp-prop:hover .sp-delete-btn{opacity:1}.sp-delete-btn:hover{color:#ef4444;background:#fee2e2}.sp-color-picker-row{align-items:center;gap:9px;padding:7px 12px 12px 13px;display:flex}.sp-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:17px;height:17px;transition:all .15s}.sp-swatch:hover{transform:scale(1.2)}.sp-swatch.active{box-shadow:0 0 0 2px #fff,0 0 0 3.5px}.sp-remove-status{color:#94a3b8;cursor:pointer;border-radius:4px;margin-left:auto;padding:2px 6px;font-family:inherit;font-size:11px;transition:background .1s,color .1s}.sp-remove-status:hover{color:#ef4444;background:#fee2e2}.sp-add-prop{color:#64748b;cursor:pointer;background:0 0;border:1.5px dashed #d1d9e2;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:7px 12px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s,color .15s;display:flex}.sp-add-prop:hover{color:#334155;background:#f1f5f9;border-color:#94a3b8}.prop-editor{border-radius:var(--radius-sm);background:#f8fafc;margin-bottom:8px;padding:10px;position:relative}.prop-editor-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.prop-editor-row:last-child{margin-bottom:0}.prop-editor-delete{width:28px;height:28px;color:var(--text-muted);background:#ffffffe6;border-radius:8px;justify-content:center;align-items:center;display:flex;position:absolute;top:10px;right:10px;box-shadow:0 1px 2px #0f172a14}.prop-editor-delete:hover{color:var(--danger);background:#fef2f2}.status-toggle{align-items:center;gap:6px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#0006;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);box-shadow:var(--shadow-xl);border-radius:16px;width:420px;max-width:90vw;animation:.2s modalIn}@keyframes modalIn{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h2{font-size:18px;font-weight:600}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.btn{border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s}.btn-secondary{color:var(--text);background:#f1f5f9}.btn-secondary:hover{background:#e2e8f0}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.export-option{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:12px;margin-bottom:8px;padding:12px;transition:all .15s;display:flex}.export-option:hover{border-color:var(--primary);background:#f8fafc}.export-option.active{border-color:var(--primary);background:#f0f7ec}.export-option-info h4{font-size:14px;font-weight:500}.export-option-info p{color:var(--text-secondary);margin-top:2px;font-size:12px}.export-scale{align-items:center;gap:12px;margin-top:16px;display:flex}.export-scale label{color:var(--text-secondary);font-size:13px}.export-scale select{border:1px solid var(--border);border-radius:6px;outline:none;padding:6px 10px;font-size:13px}.export-toggle{color:var(--text-secondary);align-items:center;gap:10px;margin-top:16px;font-size:13px;display:inline-flex}.export-toggle input{width:16px;height:16px;margin:0}.empty-state{pointer-events:none;color:var(--text-muted);z-index:4;justify-content:center;align-items:center;padding:32px 32px 96px;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.empty-state-inner{text-align:center;max-width:320px}.empty-state h2{color:var(--text-secondary);margin-bottom:8px;font-size:20px;font-weight:600}.empty-state p{font-size:14px;line-height:1.55}.keyboard-hint{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);z-index:50;white-space:nowrap;border-radius:16px;align-items:center;gap:6px;padding:8px;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}.keyboard-action-bar{pointer-events:auto}.keyboard-action-btn{color:#64748b;letter-spacing:-.01em;border-radius:10px;align-items:center;gap:10px;height:34px;padding:0 10px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.keyboard-action-btn:hover{color:#475569;background:#f8fafc}.keyboard-action-btn svg{flex-shrink:0;width:18px;height:18px}.keyboard-action-divider{background:linear-gradient(#0000,#d6deea 16%,#d6deea 84%,#0000);width:1px;height:26px}.view-controls{background:var(--surface);box-shadow:var(--shadow);border:1px solid var(--border);z-index:50;pointer-events:auto;border-radius:14px;align-items:center;gap:2px;padding:6px 8px;display:flex;position:fixed;bottom:16px;right:16px}.view-ctrl-btn{color:#64748b;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:5px;height:28px;padding:0 7px;font-size:12px;font-weight:500;transition:background .1s,color .1s;display:inline-flex}.view-ctrl-btn:hover{color:#334155;background:#f1f5f9}.view-ctrl-btn.active{color:#5d9b45;background:#f0f7ec}.view-ctrl-btn svg{flex-shrink:0;width:14px;height:14px}.view-ctrl-zoom{color:#64748b;text-align:center;min-width:36px;font-size:12px;font-weight:500}@media (max-width:1200px){.keyboard-hint{padding:8px}}@media (max-width:980px){.keyboard-hint{display:none}}.template-grid{grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;display:grid}.template-card{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:center;padding:14px;transition:all .15s}.template-card:hover{border-color:var(--primary);background:#f8fafc}.template-card-icon{margin-bottom:6px;font-size:24px}.template-card-name{font-size:12px;font-weight:500}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}
