:root{--font-sans: "Inter", system-ui, -apple-system, sans-serif;--color-bg-primary: #ffffff;--color-bg-secondary: #f8f9fa;--color-text-primary: #1a1a1a;--color-text-secondary: #666666;--color-accent: #007aff;--color-accent-subtle: #e6f0ff;--color-border: #e6e6e6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100%}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit;border:none;outline:none;background:none}.messaging-toggle{position:fixed;bottom:32px;right:32px;width:60px;height:60px;background:#2563eb;border:1px solid rgba(255,255,255,.1);border-radius:0;color:#fff;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:9999;display:flex;align-items:center;justify-content:center}.messaging-toggle:hover{transform:translateY(-2px);background:#1d4ed8;box-shadow:0 10px 15px -3px #2563eb4d,0 4px 6px -2px #2563eb1a}.messaging-toggle:active{transform:translateY(0)}.messaging-widget{position:fixed;bottom:32px;right:32px;width:380px;height:600px;background:#fff;border-radius:12px;border:1px solid #E5E7EB;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;z-index:9999;overflow:hidden;animation:fadeSlideIn .3s ease-out;transform-origin:bottom right;font-family:Inter,system-ui,sans-serif}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.messaging-header{background:#0f172a;color:#fff;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #1e293b}.messaging-header-content{display:flex;align-items:center;gap:12px}.messaging-avatar{width:40px;height:40px;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.messaging-title h3{margin:0;font-size:16px;font-weight:600}.messaging-status{display:flex;align-items:center;gap:6px;font-size:11px;color:#64748b;font-family:Inter,sans-serif;margin-top:2px}.status-dot{width:6px;height:6px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.messaging-close{background:transparent;border:1px solid transparent;color:#64748b;width:28px;height:28px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.messaging-close:hover{background:#f1f5f9;color:#0f172a;border-color:#e2e8f0}.messaging-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:#fafafa}.messaging-body::-webkit-scrollbar{width:6px}.messaging-body::-webkit-scrollbar-track{background:transparent}.messaging-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.messaging-body::-webkit-scrollbar-thumb:hover{background:#9ca3af}.message{display:flex;flex-direction:column;gap:4px}.message.bot{align-items:flex-start}.message.user{align-items:flex-end}.message-bubble{max-width:75%;padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.5;animation:messageAppear .25s ease-out}@keyframes messageAppear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.bot .message-bubble{background:#fff;color:#1f2937;border-bottom-left-radius:4px;box-shadow:0 1px 2px #0000000d}.message.user .message-bubble{background:#f1f5f9;color:#0f172a;border:1px solid #E5E7EB;border-bottom-right-radius:0}.message-time{font-size:11px;color:#94a3b8;padding:0 4px}.messaging-footer{padding:16px 20px;background:#fff;border-top:1px solid #E5E7EB;display:flex;gap:12px;align-items:center}.messaging-input{flex:1;padding:10px 14px;border:1px solid #E5E7EB;border-radius:0;font-size:13px;font-family:Inter,system-ui,sans-serif;transition:all .2s;background:#f8f9fa}.messaging-input:focus{outline:none;border-color:#0f172a;background:#fff;box-shadow:none}.messaging-send{width:36px;height:36px;background:#fff;border:1px solid #E5E7EB;border-radius:0;color:#0f172a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.messaging-send:hover:not(:disabled){background:#0f172a;color:#fff;border-color:#0f172a;transform:none}.messaging-send:active:not(:disabled){transform:none}.messaging-send:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.messaging-widget{width:calc(100vw - 32px);height:calc(100vh - 100px);bottom:16px;right:16px}.messaging-toggle{bottom:16px;right:16px}}body{background-color:var(--lab-bg-main);color:var(--lab-text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;background-image:radial-gradient(#E5E7EB 1px,transparent 1px);background-size:24px 24px}.bento-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--space-md);margin-bottom:var(--space-md)}.bento-card{background:var(--lab-bg-card);border:1px solid var(--lab-border);padding:var(--space-lg);display:flex;flex-direction:column;position:relative;box-shadow:4px 4px #0000000d}.tech-h1{font-family:var(--font-sans);font-weight:600;font-size:3rem;letter-spacing:-.03em;line-height:1.1;color:var(--lab-text-primary);margin-bottom:var(--space-md)}.tech-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;color:var(--lab-highlight);letter-spacing:.05em;margin-bottom:var(--space-sm);display:block;font-weight:600}.data-val{font-family:var(--font-mono);font-weight:500;color:var(--lab-text-primary)}.lab-nav{position:relative;height:60px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--lab-border);background:var(--lab-bg-card);padding:0 var(--space-lg);font-family:var(--font-mono);font-size:.85rem}.nav-brand{display:flex;align-items:center;gap:12px;font-weight:700;font-family:var(--font-sans);letter-spacing:-.02em;font-size:1rem;color:var(--lab-text-primary);cursor:pointer}.nav-status{display:flex;align-items:center;gap:8px;color:var(--lab-text-secondary)}.status-dot{width:8px;height:8px;background:#10b981;border-radius:50%}.cmd-input-wrapper{border:1px solid var(--lab-border);background:var(--lab-bg-main);padding:var(--space-xs)}.chip-grid{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-md)}.tech-chip{font-family:var(--font-mono);font-size:.75rem;background:var(--lab-bg-card);border:1px solid var(--lab-border);padding:6px 12px;cursor:pointer;transition:all .2s ease;color:var(--lab-text-secondary)}.tech-chip:hover{border-color:var(--lab-text-primary);color:var(--lab-text-primary)}.hero-actions{display:flex;gap:var(--space-md);margin-top:var(--space-xl)}.hero-btn-primary{display:flex;align-items:center;gap:8px;background:var(--lab-accent);color:#fff;border:1px solid var(--lab-accent);padding:14px 24px;font-family:var(--font-mono);font-weight:500;font-size:.9rem;cursor:pointer;transition:all .1s cubic-bezier(.4,0,.2,1);letter-spacing:.05em;box-shadow:4px 4px #0f172a33;transform:none}.hero-btn-primary:hover{background:var(--lab-highlight);border-color:var(--lab-highlight);box-shadow:6px 6px #2563eb40;transform:translate(-2px,-2px)}.nav-login-btn.active{background:transparent;color:var(--lab-text-primary);border-color:var(--lab-text-primary);font-weight:500}.hero-btn-secondary{display:flex;align-items:center;justify-content:center;background:var(--lab-bg-card);color:var(--lab-text-primary);border:1px solid var(--lab-border);padding:14px 24px;font-family:var(--font-mono);font-weight:500;font-size:.9rem;cursor:pointer;transition:all .1s cubic-bezier(.4,0,.2,1);letter-spacing:.05em;box-shadow:4px 4px #0f172a1a;transform:none}.hero-btn-secondary:hover{border-color:var(--lab-text-primary);background:var(--lab-bg-card);box-shadow:6px 6px #0f172a26;transform:translate(-2px,-2px)}.hero-btn-secondary:active{transform:translate(1px,1px);box-shadow:2px 2px #0f172a26}.video-frame{width:100%;height:100%;object-fit:cover}.video-overlay{position:absolute;bottom:var(--space-md);left:var(--space-md);font-family:var(--font-mono);font-size:.7rem;color:#fff;background:#000c;padding:4px 8px}.media-carousel{position:relative}.media-carousel:hover .carousel-nav{opacity:1}.image-slide{position:absolute;inset:0}.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#fff9;width:40px;height:80px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10;opacity:0}.carousel-nav:hover{color:#fff;background:#0000004d}.carousel-prev{left:0}.carousel-next{right:0}.carousel-dots{position:absolute;bottom:var(--space-md);right:var(--space-md);display:flex;gap:8px;z-index:10}.carousel-dot{width:8px;height:8px;background:#fff6;border:none;cursor:pointer;transition:all .2s}.carousel-dot:hover{background:#ffffffb3}.carousel-dot.active{background:#fff}.spec-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.85rem;margin-top:var(--space-md)}.spec-table td{padding:var(--space-sm) 0;border-bottom:1px solid var(--lab-border)}.spec-table td:first-child{color:var(--lab-text-secondary)}.spec-table td:last-child{text-align:right;font-weight:500}.col-span-12{grid-column:span 12}.col-span-8{grid-column:span 8}.col-span-6{grid-column:span 6}.col-span-4{grid-column:span 4}.col-span-3{grid-column:span 3}.h-full{height:100%}.min-h-video{min-height:400px}@media(max-width:1024px){.bento-grid{display:flex;flex-direction:column}.col-span-8,.col-span-4,.col-span-6,.col-span-3{width:100%}}.lab-modal-backdrop{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.lab-modal{background:var(--lab-bg-card);border:1px solid var(--lab-border);width:100%;max-width:400px;box-shadow:0 20px 40px -10px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);border-bottom:1px solid var(--lab-border);background:var(--lab-bg-main)}.close-btn{background:none;border:none;cursor:pointer;color:var(--lab-text-secondary)}.close-btn:hover{color:var(--lab-text-primary)}.modal-body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.input-group{display:flex;flex-direction:column}.input-icon{position:absolute;left:12px;color:var(--lab-text-secondary);pointer-events:none}.lab-input{width:100%;padding:10px 10px 10px 40px;border:1px solid var(--lab-border);font-family:var(--font-mono);font-size:.9rem;color:var(--lab-text-primary);background:var(--lab-bg-card);outline:none;transition:border-color .2s}.lab-input:focus{border-color:var(--lab-highlight);outline:none;box-shadow:0 0 0 1px var(--lab-highlight)}.lab-btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--lab-accent);color:#fff;border:none;padding:12px;font-family:var(--font-mono);font-weight:500;cursor:pointer;margin-top:var(--space-sm);transition:opacity .2s}.lab-btn-secondary{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:var(--lab-text-primary);border:1px solid var(--lab-border);padding:10px;font-family:var(--font-mono);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.lab-btn-secondary:hover{background:var(--lab-bg-main);border-color:var(--lab-text-primary)}.lab-divider{display:flex;align-items:center;text-align:center;color:var(--lab-text-secondary);font-size:.7rem;font-family:var(--font-mono);margin:4px 0}.lab-divider:before,.lab-divider:after{content:"";flex:1;border-bottom:1px solid var(--lab-border)}.lab-divider span{padding:0 10px}.success-msg{font-family:var(--font-mono);font-size:.8rem;color:var(--lab-text-primary);padding:8px;background:#0080000d;border:1px solid rgba(0,128,0,.1)}.lab-btn-primary:hover{opacity:.9}.lab-btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-msg{font-family:var(--font-mono);font-size:.8rem;color:var(--lab-text-primary);padding:8px;background:#ff00000d;border:1px solid rgba(255,0,0,.1)}.modal-footer{padding:var(--space-md);background:var(--lab-bg-main);border-top:1px solid var(--lab-border);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.7rem;color:var(--lab-text-secondary)}.text-link{color:var(--lab-text-primary);text-decoration:none;font-weight:600}.text-link:hover{text-decoration:underline}.lab-footer{border-top:1px solid var(--lab-border);background:var(--lab-bg-card);padding:var(--space-lg) var(--space-lg);margin-top:var(--space-xl)}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:var(--space-md);font-family:var(--font-mono);font-size:.7rem;color:var(--lab-text-secondary);text-transform:uppercase;letter-spacing:.05em}.footer-divider{color:var(--lab-border)}.fluid-input-container{width:100%;max-width:650px;background:#fff;border-radius:0;border:1px solid #E5E7EB;padding:.5rem .75rem .5rem 1rem;display:flex;flex-direction:column;gap:0;position:relative;transition:border-color .2s ease-out;z-index:50;min-height:52px}.fluid-input-container.focused{border-radius:0;border-color:#0f172a}.fluid-input-container.compact{max-width:100%;width:100%;border-radius:12px;background:#1e1e1ed9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 12px #0003;border:1px solid rgba(255,255,255,.1);min-height:48px;padding:0 1rem;gap:0}.fluid-input-container.compact.focused{border-radius:12px;background:#1e1e1ef2;border-color:#fff3;transform:none}.input-wrapper{display:flex;align-items:flex-end;gap:.75rem;width:100%;min-height:36px}.icon-wrapper{color:#8e8e93;display:flex;align-items:center;height:36px;flex-shrink:0}.fluid-input-container.compact .icon-wrapper{color:#30d158}.input-wrapper textarea{flex:1;font-size:1rem;font-weight:400;resize:none;border:none;background:transparent;padding:7px 0;line-height:1.4;min-height:36px;max-height:200px;color:#1d1d1f;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}.fluid-input-container.compact .input-wrapper textarea{color:#f5f5f7;font-family:SF Mono,Menlo,Monaco,Courier New,monospace;font-size:.9rem;padding:12px 0}.input-wrapper textarea::placeholder{color:#86868b;opacity:1;font-weight:400}.action-buttons{display:flex;align-items:center;gap:.25rem;flex-shrink:0;height:36px}.attach-btn{background:transparent;color:#86868b;width:32px;height:32px;border-radius:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer;border:none}.attach-btn:hover{background:#f5f5f7;color:#1d1d1f}.submit-btn{background:#e5e5ea;color:#aeaeb2;width:32px;height:32px;border-radius:0;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.34,1.56,.64,1);cursor:default;border:none}.fluid-input-container.compact .submit-btn{background:#ffffff1a;color:#fff6}.submit-btn.visible{background:#1d1d1f;color:#fff;cursor:pointer;transform:scale(1)}.fluid-input-container.compact .submit-btn.visible{background:#fff;color:#000}.submit-btn.visible:hover{transform:scale(1.08);background:#000}.attached-files{display:flex;flex-wrap:wrap;gap:.75rem;padding:0 0 .5rem 2.5rem;width:100%}.file-chip{display:flex;align-items:center;gap:.5rem;background:#f5f5f7;padding:.4rem .75rem;border-radius:10px;font-size:.8rem;color:#1d1d1f;border:1px solid transparent;font-weight:500}.file-chip svg{color:#86868b}.remove-file{background:#e5e5ea;border:none;color:#86868b;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:2px;border-radius:50%;width:16px;height:16px;margin-left:4px;transition:all .2s}.remove-file:hover{background:#d1d1d6;color:#1d1d1f}.input-wrapper textarea:focus{outline:none}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}#toolbar-wrapper[data-v-febaa31f]{z-index:3;position:fixed;top:95px;left:5px}.channelSegnemtLength[data-v-d8b70892],.channelSegnemtLength[data-v-1a3c37ce]{font-size:300px;fill:#000;text-anchor:middle;cursor:pointer}.pointer[data-v-9bc1cfb8]{cursor:pointer}.svg_canvas{position:absolute;opacity:.7}.crtLayerElm:hover{cursor:pointer;filter:brightness(1.5)}.flash[data-v-3c9eeb77]{animation:flash-3c9eeb77 1s ease-in-out}@keyframes flash-3c9eeb77{50%{background-color:#90ee90}}.layer-label[data-v-3ae01314]{padding:0 3px;color:#fff;border:none;border-radius:5px;text-align:center}[data-v-0affbb46] .popper{background:green;color:#fff;border-width:0px;border-radius:6px;padding:20px;box-shadow:0 6px 30px -6px #00000040}[data-v-0affbb46] .popper #arrow:before{background:green}[data-v-0affbb46] .popper:hover,[data-v-0affbb46] .popper:hover>#arrow:before{background:green}:root{--popper-theme-background-color: white;--popper-theme-background-color-hover: white;--popper-theme-border-width: 0px;--popper-theme-border-style: solid;--popper-theme-border-color: #333333;--popper-theme-border-radius: 6px;--popper-theme-padding: 10px;--popper-theme-box-shadow: 0 6px 30px -6px rgba(0, 0, 0, .25)}#module-name-input[data-v-23c5f491]{border:1px solid #0d6efd;border-radius:15px;text-align:center;width:100%}#module-name-wrapper[data-v-23c5f491]{border:1px solid #0d6efd;border-radius:15px;overflow:hidden;white-space:nowrap}#module-name-wrapper[data-v-23c5f491]:before{float:left;content:"Title:";color:#0d6efd;margin:4px 0 0 10px;font-size:small}#header-wrapper[data-v-23c5f491]{z-index:1046}.ruler[data-v-b6560e85],.ruler[data-v-e17386d1]{-webkit-user-select:none;user-select:none}#zoom_range[data-v-5cd58312]{align-self:center;width:30px;height:100px;-moz-appearance:slider-vertical;-webkit-appearance:slider-vertical}.zoom_icon[data-v-5cd58312]{box-sizing:border-box;padding:5px;margin:5px;cursor:pointer}.zoom_icon[data-v-5cd58312]:hover{color:#1e90ff}#zoom[data-v-5cd58312]{color:#555;text-align:center;position:fixed;bottom:20px;left:10px;display:flex;flex-direction:column}#grid[data-v-5cd58312]{position:fixed;bottom:30px;left:100px;font-size:.9rem}#module-preview[data-v-56f026ef]{width:100%;height:200px;overflow:auto}li[data-v-71f71764]:before{margin:5px 5px 0 0}.chat-window[data-v-6f429daf]{font-size:.9em}.panel-item-height{max-height:300px;overflow:auto}html{overflow:hidden}body{background-color:#fff;margin:0 auto;-webkit-user-select:none;-moz-user-select:none;-khtml-user-select:none;-ms-user-select:none;user-select:none}#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#545f69;font-size:.9rem}#main{min-width:950px;width:100%;height:100%;position:relative}#workarea{width:100%;height:100%;outline:none}#background_grid{position:absolute;background:#fff;background-image:none;width:500%;height:500%;z-index:-1}.default_cursor,#workarea.default_cursor *{cursor:default}.drawing_cursor{cursor:crosshair}.rotateButton,#workarea.rotating_cursor *{cursor:url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20width='15px'%20height='15px'%20viewBox='0%200%2015%2015'%20version='1.1'%3e%3cg%20id='surface1'%3e%3cpath%20style='%20stroke:none;fill-rule:nonzero;fill:rgb(0%25,0%25,0%25);fill-opacity:1;'%20d='M%204.1875%204.1875%20C%206.007812%202.363281%208.953125%202.355469%2010.789062%204.15625%20L%209.578125%205.359375%20C%209.378906%205.5625%209.320312%205.867188%209.429688%206.128906%20C%209.535156%206.390625%209.792969%206.5625%2010.078125%206.5625%20L%2013.828125%206.5625%20C%2014.21875%206.5625%2014.53125%206.25%2014.53125%205.859375%20L%2014.53125%202.109375%20C%2014.53125%201.824219%2014.359375%201.566406%2014.097656%201.460938%20C%2013.835938%201.351562%2013.53125%201.410156%2013.328125%201.609375%20L%2012.109375%202.828125%20C%209.542969%200.296875%205.410156%200.304688%202.859375%202.859375%20C%202.144531%203.574219%201.628906%204.414062%201.3125%205.3125%20C%201.140625%205.804688%201.398438%206.335938%201.882812%206.507812%20C%202.371094%206.683594%202.90625%206.425781%203.078125%205.9375%20C%203.304688%205.300781%203.671875%204.699219%204.1875%204.1875%20Z%20M%200.46875%209.140625%20L%200.46875%2012.890625%20C%200.46875%2013.175781%200.640625%2013.433594%200.902344%2013.539062%20C%201.164062%2013.648438%201.46875%2013.589844%201.671875%2013.390625%20L%202.890625%2012.171875%20C%205.453125%2014.703125%209.589844%2014.695312%2012.140625%2012.140625%20C%2012.855469%2011.425781%2013.375%2010.585938%2013.691406%209.6875%20C%2013.863281%209.199219%2013.605469%208.664062%2013.117188%208.492188%20C%2012.632812%208.320312%2012.097656%208.578125%2011.921875%209.0625%20C%2011.699219%209.703125%2011.332031%2010.304688%2010.816406%2010.816406%20C%208.992188%2012.640625%206.050781%2012.648438%204.214844%2010.84375%20L%205.421875%209.640625%20C%205.621094%209.4375%205.679688%209.132812%205.570312%208.871094%20C%205.464844%208.609375%205.207031%208.4375%204.921875%208.4375%20L%201.171875%208.4375%20C%200.78125%208.4375%200.46875%208.75%200.46875%209.140625%20Z%20M%200.46875%209.140625%20'/%3e%3c/g%3e%3c/svg%3e"),grab}.moving_cursor,#workarea.moveing_cursor *{cursor:move}.builder-layout.friendly-theme{display:flex;flex-direction:column;height:100vh;width:100vw;background:#fff;color:#1d1d1f;font-size:14px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;overflow:hidden}.top-bar{height:60px;background:#fff;border-bottom:1px solid #e5e7eb;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}.left-section{display:flex;align-items:center;gap:1rem}.logo-mark{width:32px;height:32px;background:#1d1d1f;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}.file-meta{display:flex;flex-direction:column}.filename{font-weight:600;color:#1d1d1f}.status-tag{font-size:11px;color:#6e6e73;font-weight:500}.center-section{flex:1;display:flex;justify-content:center}.view-toggle{background:#f5f5f7;padding:4px;border-radius:12px;display:flex;gap:4px}.toggle-option{padding:8px 16px;border-radius:10px;font-size:13px;font-weight:500;color:#6e6e73;transition:all .2s;cursor:pointer}.toggle-option.active{background:#fff;color:#1d1d1f;box-shadow:0 1px 3px #0000000d}.toggle-option:hover:not(.active){color:#1d1d1f}.right-section{display:flex;gap:.75rem;align-items:center}.dfm-status{display:flex;align-items:center;gap:.5rem;padding:8px 14px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.dfm-status.pass{background:#ecfdf5;color:#065f46}.dfm-status.warn{background:#fef3c7;color:#92400e}.dfm-status.fail{background:#fee2e2;color:#991b1b}.text-btn{font-weight:500;color:#6e6e73;padding:8px 12px;border-radius:10px;cursor:pointer;border:none;background:transparent}.text-btn:hover{background:#f5f5f7;color:#1d1d1f}.primary-btn-sm{background:#1d1d1f;color:#fff;padding:8px 16px;border-radius:10px;font-weight:500;transition:opacity .2s;cursor:pointer;border:none}.primary-btn-sm:hover{opacity:.9}.workspace-body{flex:1;display:flex;overflow:hidden}.left-toolbar{width:240px;background:#fff;border-right:1px solid #e5e7eb;padding:1.5rem;display:flex;flex-direction:column;gap:2rem}.tool-category{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.tool-category label{font-size:11px;text-transform:uppercase;color:#86868b;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem}.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.tool-btn{display:flex;align-items:center;justify-content:center;height:40px;background:#f5f5f7;border-radius:8px;border:none;color:#1d1d1f;cursor:pointer;transition:all .15s}.tool-btn:hover{background:#e5e5ea}.tool-btn.active{background:#1d1d1f;color:#fff}.tool-btn-wide{display:flex;align-items:center;gap:.75rem;width:100%;padding:0 1rem;height:40px;background:#f5f5f7;border-radius:8px;border:none;color:#6e6e73;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.tool-btn-wide:hover{background:#e5e5ea;color:#1d1d1f}.component-list{display:flex;flex-direction:column;gap:.25rem}.component-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:10px;background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s;text-align:left}.component-item:hover{background:#f5f5f7}.component-item.active{background:#eff6ff;border-color:#dbeafe}.component-item svg{color:#6e6e73;flex-shrink:0}.component-item.active svg{color:#2563eb}.comp-info{display:flex;flex-direction:column;gap:1px}.comp-info .name{font-size:13px;font-weight:500;color:#1d1d1f}.component-item.active .comp-info .name{color:#1e40af}.comp-info .desc{font-size:11px;color:#86868b}.component-item.active .comp-info .desc{color:#60a5fa}.icon-resistor{transform:rotate(-90deg)}.icon-inlet{color:#10b981}.main-viewport{flex:1;position:relative;background:#fafafa;display:flex;justify-content:center;align-items:center;padding:1.5rem}.canvas-wrapper{width:100%;height:100%;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000000f;background:#fff}.assistant-bar{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);width:600px;z-index:50}.right-inspector{width:300px;background:#fff;border-left:1px solid #e5e7eb;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.panel-header{display:flex;justify-content:space-between;align-items:center}.panel-header h3{font-size:1.1rem;font-weight:600;color:#1d1d1f}.icon-only:hover{background:#f5f5f7}.property-group{margin-bottom:1.5rem}.property-group label{display:block;font-size:12px;font-weight:500;color:#6e6e73;margin-bottom:.5rem}.input-row{display:flex;gap:.75rem}.input-field{flex:1;display:flex;align-items:center;border:1px solid #e5e7eb;border-radius:10px;padding:0 10px;background:#fafafa}.input-field span{font-size:11px;color:#86868b;font-weight:600;margin-right:6px}.input-field input{width:100%;padding:10px 0;font-size:13px;font-weight:500;background:transparent;border:none;color:#1d1d1f}.styled-select{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px;font-size:13px;color:#1d1d1f;background:#fff;font-weight:500;cursor:pointer}.estimate-card{margin-top:auto;background:#fafafa;padding:1.25rem;border-radius:16px;border:1px solid #e5e7eb}.est-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:600;color:#1d1d1f}.est-header .price{font-size:1.25rem;font-weight:700;color:#1d1d1f}.estimate-card p{font-size:12px;color:#6e6e73;margin-bottom:.5rem;line-height:1.5}.estimate-card .lead-time{font-weight:600;color:#1d1d1f}.estimate-card .disclaimer{font-size:10px;color:#86868b;margin-top:.5rem;margin-bottom:0;line-height:1.4}.buy-btn{width:100%;padding:12px;background:#1d1d1f;color:#fff;border-radius:12px;font-weight:600;transition:opacity .2s;cursor:pointer;border:none;margin-top:.75rem}.buy-btn:hover{opacity:.9}.format-selector-row{display:flex;gap:.75rem;margin-bottom:1.5rem}.format-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;background:#fafafa}.format-card:hover{border-color:#d1d5db;background:#f5f5f7}.format-card.active{border-color:#007aff;background:#f0f7ff}.format-card svg{color:#6e6e73}.format-card.active svg{color:#007aff}.format-label{font-size:13px;font-weight:600;color:#1d1d1f}.format-desc{font-size:10px;color:#86868b}.export-info-card{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem;background:#f0f7ff;border-radius:10px;margin-bottom:1rem;font-size:11px;color:#1d1d1f;line-height:1.4}.export-info-card i{color:#007aff;flex-shrink:0;margin-top:1px}.export-download-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:#007aff;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.export-download-btn:hover:not(:disabled){background:#06d}.export-download-btn:disabled{opacity:.6;cursor:not-allowed}.export-divider{height:1px;background:#e5e7eb;margin:1rem 0}.export-secondary-row{display:flex;gap:.5rem}.export-secondary-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem .75rem;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font-size:12px;font-weight:500;color:#6e6e73;cursor:pointer;transition:all .15s ease}.export-secondary-btn:hover:not(:disabled){background:#f5f5f7;color:#1d1d1f;border-color:#d1d5db}.export-secondary-btn.accent{background:#10b981;border-color:#10b981;color:#fff}.export-secondary-btn.accent:hover:not(:disabled){background:#059669;border-color:#059669}.export-secondary-btn:disabled{opacity:.5;cursor:not-allowed}.builder-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:#fff}.top-bar{position:relative;z-index:1001}.center-section{position:absolute;left:50%;transform:translate(-50%);width:auto;display:flex;justify-content:center}.workspace-body{display:grid;grid-template-columns:1fr 300px;gap:0;flex:1;overflow:hidden;background:#fff;position:relative;z-index:0}.workspace-body:has(.ai-sidebar){grid-template-columns:300px 1fr 300px}.ai-sidebar{width:300px;min-width:300px;max-width:300px;background:#fcfcfc;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;z-index:10;overflow:hidden}.sidebar-header{padding:16px;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;background:#fff;gap:4px}.sidebar-header h3{margin:0;font-size:16px;font-weight:600;color:#1a1a1a;letter-spacing:-.01em}.chat-history{flex:1;padding:16px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:12px;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:13px;min-height:0}.message-content{padding:4px 0;border-radius:0;font-size:13px;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap;max-width:100%}.chat-message.ai .message-content{background:transparent;color:#1a1a1a}.chat-message.user .message-content{background:transparent;color:#444}.chat-message.system-log .message-content{color:#666;font-style:italic;border-bottom:1px dashed #eee;padding-bottom:8px;margin-bottom:8px;width:100%}.console-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px;margin-top:4px;width:100%;box-shadow:0 1px 2px #0000000d}.card-header{font-size:12px;font-weight:700;margin-bottom:8px;color:#212529;letter-spacing:.3px;text-transform:uppercase}.card-bullets{padding-left:16px;margin:0 0 12px;font-size:11px;color:#495057;line-height:1.5}.card-bullets li{margin-bottom:4px}.card-actions{display:flex;gap:8px}.btn-action{font-size:10px;padding:3px 10px;border:1px solid #dee2e6;background:#fff;border-radius:4px;font-weight:500;color:#495057;cursor:pointer;transition:all .2s}.btn-action:hover{background:#f8f9fa;border-color:#ced4da;color:#212529}.quick-commands{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.cmd-chip{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:4px 10px;font-size:11px;color:#495057;cursor:pointer;transition:all .2s;white-space:nowrap}.cmd-chip:hover{background:#e9ecef;border-color:#dee2e6;color:#212529}.chat-input-area{padding:20px;background:#fcfcfc;background:#fff;border-top:1px solid #f0f0f0}.input-wrapper{position:relative;display:flex;align-items:center}.ai-input{width:100%;padding:10px 40px 10px 12px;border:1px solid #dee2e6;border-radius:6px;font-size:13px;outline:none;transition:all .2s;background:#fff;color:#212529;font-family:inherit}.ai-input:focus{border-color:#86b7fe;box-shadow:0 0 0 2px #0d6efd26}.send-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:4px;background:transparent;color:#6c757d;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.send-btn:hover{background:#e9ecef;color:#212529;transform:translateY(-50%)}.left-toolbar{display:none}.flui3d-center-col{display:flex;flex-direction:column;flex-grow:1;min-width:0;height:100%;position:relative;background:#fff!important}.main-viewport{background:#fff!important;padding:0!important}.canvas-wrapper{background:#fff!important;box-shadow:none!important;border-radius:0!important}.bottom-toolbar{position:absolute;bottom:50px;left:50%;transform:translate(-50%);background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.06);box-shadow:0 2px 8px #0000000a,0 8px 24px #00000014;display:flex;padding:8px 12px;align-items:center;gap:2px;z-index:1000}.toolbar-group{display:flex;gap:2px;padding:0 8px}.toolbar-group:first-child{padding-left:4px}.toolbar-group:last-child{padding-right:4px}.toolbar-divider{width:1px;height:24px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.08),transparent);margin:0 4px}.toolbar-btn{width:40px;height:40px;border-radius:10px;border:none;background:transparent;color:#6e6e73;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s ease,color .15s ease,transform .15s ease;position:relative}.toolbar-btn:hover{background:#0000000a;color:#1d1d1f}.toolbar-btn:active{transform:scale(.95)}.toolbar-btn.active{background:#007aff1f;color:#007aff}.toolbar-btn.active:hover{background:#007aff2e}.toolbar-btn svg{display:block;margin:0 auto;transition:transform .15s ease}.toolbar-btn:hover svg{transform:scale(1.05)}.flui3d-footer{height:36px;background:#fff;border-top:1px solid #f0f0f0;display:flex;align-items:stretch;justify-content:stretch;padding:0;font-size:13px;color:#6e6e73;flex-shrink:0;z-index:100;-webkit-user-select:none;user-select:none;overflow:visible}.flui3d-footer>div{width:100%;display:flex;align-items:center;padding:0 20px}.elevation-bar-container{display:flex;align-items:center;background:#f5f5f7;padding:2px 10px;border-radius:12px;gap:8px;flex-shrink:0}.elevation-bar-container span{font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;white-space:nowrap}.right-inspector{width:300px;background:#fff;border-left:1px solid #e5e7eb;padding:0 1.5rem;display:flex;flex-direction:column;gap:.75rem;height:100%;overflow:hidden}.inspector-content{flex:1;overflow-y:auto;padding-right:5px;padding-bottom:1.5rem;min-height:0;scrollbar-width:none;-ms-overflow-style:none}.inspector-content::-webkit-scrollbar{display:none}.inspector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0}.inspector-header h3{font-size:20px;font-weight:700;color:#1d1d1f;margin:0}.section-title{font-size:13px;font-weight:600;color:#86868b;margin-bottom:.75rem;text-transform:none}.viewport-info-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:0;overflow:hidden}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}.info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #f0f0f0;border-right:1px solid #f0f0f0;font-size:13px}.info-item:nth-child(2n){border-right:none}.info-item:nth-child(n+3){border-bottom:none}.info-label{color:#86868b;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.3px}.info-value{color:#1d1d1f;font-weight:600;font-family:var(--font-sans);font-size:13px;font-variant-numeric:tabular-nums}.stat-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:14px}.stat-label{color:#6e6e73}.stat-value{font-weight:500;color:#1d1d1f;font-variant-numeric:tabular-nums}.total-row .stat-label{color:#1d1d1f;font-weight:500}.total-row .stat-value{color:#007aff!important;font-weight:600}.component-library{display:flex;flex-direction:column;gap:12px;padding-top:8px}.component-card{display:flex;flex-direction:row;background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s;padding:12px;gap:12px;align-items:center;flex-shrink:0}.component-card:hover{border-color:#007aff;box-shadow:0 2px 8px #007aff1a}.component-preview{flex-shrink:0;width:80px;height:60px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:6px;overflow:visible}.component-preview svg{max-width:100%;max-height:100%;width:auto;height:auto;display:block;object-fit:contain}.component-details{flex:1;display:flex;flex-direction:column;gap:6px}.component-name{font-size:14px;font-weight:600;color:#1d1d1f;margin:0}.component-desc{font-size:11px;color:#6e6e73;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.btn-create-component{padding:4px 16px;background:#fff;border:1.5px solid #28a745;border-radius:12px;color:#28a745;font-weight:500;font-size:12px;cursor:pointer;transition:all .2s;align-self:flex-start}.btn-create-component:hover{background:#28a745;color:#fff}.icon-only{padding:6px;border-radius:8px;color:#6e6e73;cursor:pointer;border:none;background:transparent}.fabrication-panel{background:#fff;z-index:10}.empty-state-start{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;display:flex;justify-content:center;align-items:center;pointer-events:none;width:100%}.empty-state-card{pointer-events:auto;background:#fff;padding:32px;border-radius:20px;box-shadow:0 10px 40px #00000014;text-align:center;max-width:340px;border:1px solid #f0f0f0;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px) translate(-50%,-50%)}0%{opacity:0;margin-top:10px}to{opacity:1;margin-top:0}}.empty-state-card h5{font-size:18px;font-weight:700;margin-bottom:8px;color:#1a1a1a}.empty-state-card p{font-size:14px;color:#666;margin-bottom:24px;line-height:1.5}.toolbar-group:not(:last-child){border-right:1px solid #e9ecef;padding-right:12px;margin-right:8px}.layers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px}.layers-title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:#86868b}.btn-add-layer{background:none;border:none;color:#007aff;font-size:11px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s;background:#007aff0d}.btn-add-layer:hover{background:#007aff1a}.layer-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;transition:transform .2s cubic-bezier(.25,.46,.45,.94),box-shadow .2s cubic-bezier(.25,.46,.45,.94),border-color .2s cubic-bezier(.25,.46,.45,.94);position:relative;box-shadow:0 1px 3px #00000005;margin:2px}.layer-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000000f;border-color:#d1d5db}.layer-card.active{border-color:#007aff;box-shadow:0 0 0 1px #007aff,0 4px 12px #007aff26}.layer-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.layer-identity{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.layer-color-dot{width:10px;height:10px;border-radius:50%;box-shadow:inset 0 0 0 1px #0000001a}.layer-name{font-size:14px;font-weight:600;color:#1d1d1f}.btn-delete-layer{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:none;background:#ff3b301a;color:#ff3b30;border-radius:50%;cursor:pointer;opacity:0;transform:scale(.9);transition:all .2s}.layer-card:hover .btn-delete-layer{opacity:1;transform:scale(1)}.btn-delete-layer:hover{background:#ff3b30;color:#fff}.layer-elevation-row{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid #f5f5f7}.elevation-label{font-size:11px;color:#86868b;font-weight:500}.elevation-input-group{display:flex;align-items:center;gap:4px;background:#f5f5f7;padding:2px 6px;border-radius:6px;transition:all .2s}.elevation-input-group:focus-within{background:#fff;box-shadow:0 0 0 2px #007aff}.input-elevation-val{border:none;background:transparent;width:48px;text-align:right;font-family:inherit;font-size:12px;font-weight:600;color:#1d1d1f;outline:none;padding:2px 0}.unit-label{font-size:11px;color:#86868b;font-weight:500;-webkit-user-select:none;user-select:none}html,body{margin:0;padding:0;min-height:100%;overflow-y:auto!important}.app-container{width:100vw;height:100vh;position:relative;overflow:hidden;display:flex;flex-direction:column}.page-layer{width:100%;height:100%;overflow-y:auto;overflow-x:hidden;position:relative}:root{--lab-bg-main: #F8F9FA;--lab-bg-card: #FFFFFF;--lab-border: #E5E7EB;--lab-text-primary: #0F172A;--lab-text-secondary: #64748B;--lab-accent: #0F172A;--lab-highlight: #2563EB;--font-sans: "Inter", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Roboto Mono", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 48px}body{background-color:var(--lab-bg-main);color:var(--lab-text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased}.lab-nav{position:relative;height:60px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--lab-border);background:var(--lab-bg-card);padding:0 var(--space-lg);font-family:var(--font-mono);font-size:.85rem;position:sticky;top:0;z-index:100}.nav-brand{font-weight:700;font-family:var(--font-sans);letter-spacing:-.02em;font-size:1rem;color:var(--lab-text-primary);cursor:pointer}.nav-center{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:12px}.nav-login-btn{background:transparent;color:var(--lab-text-primary);border:1px solid var(--lab-border);padding:6px 16px;border-radius:0;font-family:var(--font-mono);font-weight:500;font-size:.75rem;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.nav-login-btn:hover{background:var(--lab-text-primary);color:#fff;border-color:var(--lab-text-primary)}.nav-login-btn.active{background:transparent;color:var(--lab-text-primary);border-color:var(--lab-border);font-weight:500}.nav-status{display:flex;align-items:center;gap:8px;color:var(--lab-text-secondary);font-size:.75rem}.lab-container{max-width:1400px;margin:0 auto;padding:0 var(--space-lg)}.tech-h1{font-family:var(--font-sans);font-weight:600;font-size:2rem;letter-spacing:-.03em;line-height:1.1;color:var(--lab-text-primary)}.tech-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;color:var(--lab-text-secondary);letter-spacing:.05em;margin-bottom:var(--space-sm);display:block}.hero-btn-primary{display:flex;align-items:center;gap:8px;background:var(--lab-accent);color:#fff;border:none;padding:10px 18px;font-family:var(--font-mono);font-weight:500;font-size:.8rem;cursor:pointer;transition:all .2s;letter-spacing:.05em;text-transform:uppercase}.hero-btn-primary:hover{background:var(--lab-highlight);transform:translateY(-1px)}.dashboard-panel{background:var(--lab-bg-card);border:1px solid var(--lab-border);margin-bottom:var(--space-md);box-shadow:4px 4px #0000000d;display:flex;flex-direction:column}.dashboard-header{display:flex;justify-content:space-between;align-items:end;padding:var(--space-lg);border-bottom:1px dashed var(--lab-border)}.dashboard-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);gap:var(--space-md);background:var(--lab-bg-main)}.search-box{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--lab-bg-card);border:1px solid var(--lab-border);flex:1;max-width:360px;transition:all .2s}.search-box:focus-within{border-color:var(--lab-text-primary)}.search-box svg{color:var(--lab-text-secondary);flex-shrink:0}.search-box input{background:none;border:none;outline:none;color:var(--lab-text-primary);font-size:.85rem;font-family:var(--font-mono);width:100%}.search-box input::placeholder{color:var(--lab-text-secondary)}.view-toggle{display:flex;background:var(--lab-bg-main);padding:2px;border:1px solid var(--lab-border);border-radius:6px;gap:2px}.view-toggle button{padding:6px 10px;background:transparent;border:none;border-radius:4px;color:var(--lab-text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.view-toggle button.active{background:var(--lab-bg-card);color:var(--lab-text-primary);box-shadow:0 1px 2px #0000000d;font-weight:500}.view-toggle button:hover:not(.active){background:#00000008;color:var(--lab-text-primary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.project-card{background:var(--lab-bg-card);border:1px solid var(--lab-border);padding:0;display:flex;flex-direction:column;position:relative;transition:all .2s;cursor:pointer;min-height:280px;box-shadow:4px 4px #0000000d}.project-card:hover{border-color:var(--lab-text-primary);transform:translate(-2px,-2px);box-shadow:6px 6px #0000001a}.project-thumbnail{height:160px;background:var(--lab-bg-main);border-bottom:1px solid var(--lab-border);display:flex;align-items:center;justify-content:center;overflow:hidden}.project-thumbnail img{width:100%;height:100%;object-fit:cover}.project-info{padding:var(--space-md);flex:1;display:flex;flex-direction:column}.project-info h3{margin:0 0 6px;font-size:.9rem;font-weight:600;color:var(--lab-text-primary);font-family:var(--font-sans);text-transform:none;letter-spacing:.02em}.project-desc{font-family:var(--font-mono);font-size:.75rem;color:#475569;margin:0 0 auto;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-meta{margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--lab-border);display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.65rem;color:var(--lab-text-secondary);text-transform:uppercase;letter-spacing:.05em}.project-menu-btn{position:absolute;top:0;right:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--lab-bg-card);border-left:1px solid var(--lab-border);border-bottom:1px solid var(--lab-border);color:var(--lab-text-secondary);cursor:pointer;opacity:0;transition:all .2s;z-index:10}.project-card:hover .project-menu-btn{opacity:1}.project-menu-btn:hover{background:var(--lab-text-primary);color:#fff;border-color:var(--lab-text-primary)}.project-dropdown{position:absolute;top:34px;right:0;background:var(--lab-bg-card);border:1px solid var(--lab-text-primary);display:flex;flex-direction:column;min-width:140px;z-index:20;box-shadow:0 4px 12px #0000001a}.project-dropdown button{display:flex;align-items:center;gap:8px;padding:10px 12px;background:transparent;border:none;text-align:left;font-family:var(--font-mono);font-size:.75rem;color:var(--lab-text-primary);cursor:pointer;transition:background .1s;text-transform:uppercase}.project-dropdown button:hover{background:var(--lab-bg-main)}.project-dropdown .dropdown-divider{height:1px;background:var(--lab-border);margin:0}.project-dropdown button.danger{color:#ef4444}.projects-grid.list-view{grid-template-columns:1fr;gap:var(--space-sm)}.projects-grid.list-view .project-card{flex-direction:row;min-height:auto;height:60px;align-items:center}.projects-grid.list-view .project-thumbnail{width:60px;height:100%;border-bottom:none;border-right:1px solid var(--lab-border)}.projects-grid.list-view .project-info{flex-direction:row;align-items:center;gap:var(--space-md);padding:0 var(--space-md)}.projects-grid.list-view .project-desc{margin:0;-webkit-line-clamp:1;line-clamp:1;flex:1}.projects-grid.list-view .project-meta{margin:0;padding:0;border:none;width:120px;justify-content:flex-end}.projects-grid.list-view .project-menu-btn{position:static;opacity:0;margin-right:12px;border:1px solid var(--lab-border);width:28px;height:28px}.projects-grid.list-view .project-card:hover .project-menu-btn{opacity:1}.empty-state{text-align:center;padding:80px 0;color:var(--lab-text-secondary);font-family:var(--font-mono);font-size:.85rem;border:1px dashed var(--lab-border);background:var(--lab-bg-main)}.resources-panel{background:var(--lab-bg-card);border:1px solid var(--lab-border);margin-top:0;box-shadow:4px 4px #0000000d;display:flex;flex-direction:column}.resources-header{padding:var(--space-lg);border-bottom:1px dashed var(--lab-border)}.resources-header .tech-label{margin-bottom:0}.resources-content{padding:var(--space-md);background:var(--lab-bg-main)}.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.news-card{background:var(--lab-bg-card);border:1px solid var(--lab-border);padding:0;display:flex;flex-direction:column;gap:0;transition:all .2s ease;cursor:pointer;box-shadow:4px 4px #0000000d}.news-visual{height:100px;background:var(--lab-bg-main);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--lab-border);overflow:hidden}.news-content{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);flex:1}.news-card:hover{border-color:var(--lab-text-primary);transform:translate(-2px,-2px);box-shadow:6px 6px #0000001a}.news-tag{font-family:var(--font-mono);font-size:.65rem;font-weight:600;color:var(--lab-text-primary);background:var(--lab-bg-main);padding:2px 6px;align-self:flex-start;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--lab-border)}.news-card h3{font-family:var(--font-mono);font-size:.9rem;font-weight:600;color:var(--lab-text-primary);margin:0;line-height:1.3}.news-card p{font-family:var(--font-sans);font-size:.85rem;color:var(--lab-text-secondary);margin:0;line-height:1.5;flex:1}.news-meta{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--lab-border)}.news-meta span{font-family:var(--font-mono);font-size:.65rem;color:var(--lab-text-secondary);text-transform:uppercase}.news-meta a{font-family:var(--font-mono);font-size:.65rem;color:var(--lab-text-primary);text-decoration:none;letter-spacing:.02em;border-bottom:1px solid transparent;transition:border-color .2s;cursor:pointer}.news-meta a:hover{border-color:var(--lab-text-primary)}.dashboard-footer{border-top:1px solid var(--lab-border);background:var(--lab-bg-card);padding:var(--space-lg);margin-top:auto}.dashboard-footer .footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:var(--space-md);font-family:var(--font-mono);font-size:.7rem;color:var(--lab-text-secondary);text-transform:uppercase;letter-spacing:.05em}.dashboard-footer .footer-divider{color:var(--lab-border)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-modal{background:var(--lab-bg-card);border:1px solid var(--lab-border);padding:var(--space-lg);width:100%;max-width:480px;box-shadow:8px 8px #0000001a}.edit-modal h2{font-family:var(--font-sans);font-size:1.25rem;font-weight:600;margin:0 0 var(--space-lg);color:var(--lab-text-primary)}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--lab-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.form-group input,.form-group textarea{width:100%;padding:10px 12px;font-family:var(--font-sans);font-size:.9rem;border:1px solid var(--lab-border);background:var(--lab-bg-main);color:var(--lab-text-primary);transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--lab-text-primary)}.form-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.btn-cancel{padding:10px 16px;font-family:var(--font-mono);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;background:transparent;border:1px solid var(--lab-border);color:var(--lab-text-secondary);cursor:pointer;transition:all .2s}.btn-cancel:hover{border-color:var(--lab-text-primary);color:var(--lab-text-primary)}.btn-save{padding:10px 16px;font-family:var(--font-mono);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;background:var(--lab-accent);border:none;color:#fff;cursor:pointer;transition:all .2s;box-shadow:3px 3px #00000026}.btn-save:hover{background:var(--lab-highlight);transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}
