@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#333;background-color:#f8f9fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary: #1e88e5;--primary-dark: #1565c0;--success: #4caf50;--warning: #ff9800;--danger: #f44336;--info: #00bcd4}html,body{margin:0;padding:0;height:100%;overflow:hidden}body{margin:0;min-width:320px;min-height:100vh}#root{height:100%}.dark{color-scheme:dark;color:#e5e7eb;background-color:#111827;--primary: #3b82f6;--primary-dark: #2563eb}.templates-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.templates-panel{background-color:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.dark .templates-panel{background-color:#1f2937}.templates-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0}.dark .templates-header{border-bottom-color:#374151}.templates-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.dark .templates-header h2{color:#e5e7eb}.close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:8px;cursor:pointer;color:#666;transition:background-color .15s}.close-btn:hover{background-color:#f0f0f0}.dark .close-btn{color:#9ca3af}.dark .close-btn:hover{background-color:#374151}.templates-description{padding:16px 24px 0;margin:0;color:#666;font-size:14px}.dark .templates-description{color:#9ca3af}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px;padding:20px 24px 24px}.template-card{display:flex;align-items:flex-start;gap:16px;padding:20px;background-color:#f8f9fa;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.template-card:hover{background-color:#e3f2fd;border-color:#90caf9;transform:translateY(-2px);box-shadow:0 4px 12px #1e88e526}.dark .template-card{background-color:#374151}.dark .template-card:hover{background-color:#4b5563;border-color:#60a5fa}.template-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background-color:#e3f2fd;border-radius:12px;color:#1e88e5;flex-shrink:0}.dark .template-icon{background-color:#1e3a5f;color:#60a5fa}.template-info{flex:1;min-width:0}.template-info h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.dark .template-info h3{color:#e5e7eb}.template-info p{margin:0;font-size:13px;color:#666;line-height:1.4}.dark .template-info p{color:#9ca3af}@media(max-width:600px){.templates-grid{grid-template-columns:1fr}.template-card{padding:16px}.template-icon{width:48px;height:48px}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:48px;background-color:#fff;border-bottom:1px solid #e0e0e0}.app-header.dark{background-color:#111827;border-bottom-color:#374151}.header-left{display:flex;align-items:center;gap:16px}.logo{display:flex;align-items:center;gap:8px;color:#1e88e5;font-weight:700;font-size:16px}.dark .logo{color:#60a5fa}.logo span{color:#333}.dark .logo span{color:#e5e7eb}.diagram-name button,.diagram-name input{font-size:14px;font-weight:500;border:none;background:transparent;padding:6px 12px;border-radius:6px;cursor:pointer;color:#333}.diagram-name button:hover{background-color:#f5f5f5}.diagram-name input{background-color:#f5f5f5;outline:none;cursor:text}.diagram-name input:focus{background-color:#e3f2fd;box-shadow:0 0 0 2px #1e88e5}.dark .diagram-name button,.dark .diagram-name input{color:#e5e7eb}.dark .diagram-name button:hover,.dark .diagram-name input{background-color:#374151}.dark .diagram-name input:focus{background-color:#1e3a5f;box-shadow:0 0 0 2px #3b82f6}.save-status{font-size:11px;color:#999;padding:4px 8px;background-color:#f5f5f5;border-radius:4px}.dark .save-status{color:#6b7280;background-color:#374151}.header-right{display:flex;align-items:center;gap:8px}.header-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:#666;transition:all .15s}.header-btn:hover{background-color:#f5f5f5;color:#333}.header-btn.icon-only{padding:8px}.header-btn.feature-btn{background-color:#f0f9ff;color:#0369a1}.header-btn.feature-btn:hover{background-color:#e0f2fe;color:#0284c7}.dark .header-btn.feature-btn{background-color:#1e3a5f;color:#7dd3fc}.dark .header-btn.feature-btn:hover{background-color:#1e4976;color:#bae6fd}.header-divider{width:1px;height:24px;background-color:#e5e7eb;margin:0 4px}.dark .header-divider{background-color:#374151}.dark .header-btn{color:#9ca3af}.dark .header-btn:hover{background-color:#374151;color:#e5e7eb}.developer-credit{display:flex;align-items:center;gap:6px;padding:6px 12px;margin-left:8px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;font-size:11px;color:#ffffffe6;white-space:nowrap}.developer-credit strong{color:#fff;font-weight:600}.developer-credit .credit-role{padding-left:6px;border-left:1px solid rgba(255,255,255,.3);color:#ffffffbf;font-size:10px}.developer-credit .linkedin-link{display:flex;align-items:center;justify-content:center;padding:4px;margin-left:4px;background:#fff3;border-radius:4px;color:#fff;transition:all .2s ease}.developer-credit .linkedin-link:hover{background:#0077b5;transform:scale(1.1)}.shortcuts-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.shortcuts-panel{background-color:#fff;border-radius:16px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.dark .shortcuts-panel{background-color:#1f2937}.shortcuts-panel h2{margin:0 0 20px;font-size:18px;color:#333}.dark .shortcuts-panel h2{color:#e5e7eb}.shortcuts-grid{display:grid;gap:12px}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f0}.dark .shortcut-item{border-bottom-color:#374151}.shortcut-keys{display:flex;align-items:center;gap:4px}.shortcut-keys kbd{display:inline-block;padding:4px 8px;background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:12px;color:#333}.dark .shortcut-keys kbd{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.shortcut-keys span{color:#999;font-size:12px}.shortcut-desc{color:#666;font-size:13px}.dark .shortcut-desc{color:#9ca3af}.close-shortcuts{display:block;width:100%;margin-top:20px;padding:12px;border:none;background-color:#1e88e5;color:#fff;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .15s}.close-shortcuts:hover{background-color:#1976d2}.dark .close-shortcuts{background-color:#3b82f6}.dark .close-shortcuts:hover{background-color:#2563eb}.toolbar{display:flex;align-items:center;padding:8px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0;gap:8px;flex-wrap:wrap;min-height:52px}.toolbar.dark{background-color:#1f2937;border-bottom-color:#374151}.toolbar-section{display:flex;align-items:center;gap:8px}.toolbar-group{display:flex;align-items:center;gap:4px;background-color:#f5f5f5;border-radius:8px;padding:4px}.dark .toolbar-group{background-color:#374151}.toolbar-divider{width:1px;height:24px;background-color:#e0e0e0;margin:0 4px}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#666;transition:all .15s ease}.toolbar-btn:hover:not(:disabled){background-color:#e0e0e0;color:#333}.toolbar-btn.active:hover{background-color:#1976d2;color:#fff}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn.danger:hover:not(:disabled){background-color:#ffebee;color:#f44336}.toolbar-btn.small{width:28px;height:28px}.dark .toolbar-btn:hover:not(:disabled){background-color:#4b5563;color:#e5e7eb}.dark .toolbar-btn.danger:hover:not(:disabled){background-color:#7f1d1d;color:#fca5a5}.connector-types{display:flex;gap:2px;padding-left:4px;border-left:1px solid #ddd;margin-left:4px}.dark .connector-types{border-left-color:#4b5563}.zoom-display{font-size:12px;font-weight:500;color:#666;min-width:45px;text-align:center}.dark .zoom-display{color:#9ca3af}.toolbar-btn.data-flow.active{background-color:#10b981;color:#fff;animation:pulse-glow 2s ease-in-out infinite}.toolbar-btn.data-flow.active:hover{background-color:#059669}@keyframes pulse-glow{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 6px #10b98100}}@media(max-width:900px){.toolbar{padding:6px 8px;gap:4px}.toolbar-section{gap:4px}.toolbar-btn{width:32px;height:32px}.toolbar-btn.small{width:24px;height:24px}}.sidebar{width:240px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;transition:width .2s ease}.sidebar.dark{background-color:#1f2937;border-right-color:#374151}.sidebar.collapsed{width:40px;min-width:40px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e0e0e0}.dark .sidebar-header{border-bottom-color:#374151}.sidebar-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.dark .sidebar-header h3{color:#e5e7eb}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#666;transition:all .15s ease}.sidebar-toggle:hover{background-color:#f0f0f0;color:#333}.dark .sidebar-toggle{color:#9ca3af}.dark .sidebar-toggle:hover{background-color:#374151;color:#e5e7eb}.collapsed .sidebar-toggle{margin:8px auto}.sidebar-search{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid #e0e0e0}.dark .sidebar-search{border-bottom-color:#374151}.sidebar-search svg{color:#999;flex-shrink:0}.dark .sidebar-search svg{color:#6b7280}.sidebar-search input{flex:1;border:none;background:transparent;font-size:13px;outline:none;color:#333}.sidebar-search input::placeholder{color:#999}.dark .sidebar-search input{color:#e5e7eb}.dark .sidebar-search input::placeholder{color:#6b7280}.sidebar-content{flex:1;overflow-y:auto;padding:8px 0}.shape-category{margin-bottom:4px}.category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 16px;border:none;background:transparent;cursor:pointer;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.category-header:hover{background-color:#f5f5f5}.dark .category-header{color:#9ca3af}.dark .category-header:hover{background-color:#374151}.shape-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px 8px}.shape-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 8px;border:1px solid transparent;background-color:#f8f9fa;border-radius:8px;cursor:pointer;transition:all .15s ease}.shape-item:hover{background-color:#e3f2fd;border-color:#90caf9}.shape-item.active{background-color:#1e88e5;color:#fff}.shape-item span{font-size:10px;text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark .shape-item{background-color:#374151;color:#9ca3af}.dark .shape-item:hover{background-color:#4b5563;border-color:#6b7280;color:#e5e7eb}.dark .shape-item.active{background-color:#3b82f6;color:#fff}.no-results{grid-column:1 / -1;text-align:center;color:#999;font-size:13px;padding:20px}.dark .no-results{color:#6b7280}.sidebar-footer{padding:12px 16px;border-top:1px solid #e0e0e0;font-size:11px;color:#999;text-align:center}.dark .sidebar-footer{border-top-color:#374151;color:#6b7280}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:transparent}.sidebar-content::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:3px}.dark .sidebar-content::-webkit-scrollbar-thumb{background-color:#4b5563}.context-menu{position:fixed;min-width:200px;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d;padding:6px;z-index:1000;animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu.dark{background-color:#1f2937;box-shadow:0 4px 20px #0006,0 0 0 1px #ffffff1a}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:none;border-radius:6px;font-size:13px;color:#333;cursor:pointer;text-align:left;transition:background-color .1s}.context-menu-item:hover{background-color:#f0f0f0}.context-menu-item:active{background-color:#e0e0e0}.context-menu-item.danger{color:#dc2626}.context-menu-item.danger:hover{background-color:#fef2f2}.dark .context-menu-item{color:#e5e7eb}.dark .context-menu-item:hover{background-color:#374151}.dark .context-menu-item:active{background-color:#4b5563}.dark .context-menu-item.danger{color:#f87171}.dark .context-menu-item.danger:hover{background-color:#dc262626}.context-menu-label{flex:1}.context-menu-shortcut{font-size:11px;color:#999;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.dark .context-menu-shortcut{color:#6b7280}.context-menu-divider{height:1px;background-color:#e5e7eb;margin:6px 0}.dark .context-menu-divider{background-color:#374151}.text-input-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;animation:overlayFadeIn .15s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.text-input-modal{background-color:#fff;border-radius:12px;padding:20px;min-width:320px;box-shadow:0 20px 40px #0003;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.text-input-modal.dark{background-color:#1f2937}.text-input-modal h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.dark .text-input-modal h3{color:#e5e7eb}.text-input-modal textarea{width:100%;min-height:100px;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s}.text-input-modal textarea:focus{border-color:#1e88e5;box-shadow:0 0 0 3px #1e88e526}.dark .text-input-modal textarea{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.dark .text-input-modal textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.text-input-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.text-input-modal-actions button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .15s}.text-input-modal-actions .cancel-btn{background-color:#f3f4f6;color:#374151}.text-input-modal-actions .cancel-btn:hover{background-color:#e5e7eb}.dark .text-input-modal-actions .cancel-btn{background-color:#374151;color:#e5e7eb}.dark .text-input-modal-actions .cancel-btn:hover{background-color:#4b5563}.text-input-modal-actions .save-btn{background-color:#1e88e5;color:#fff}.text-input-modal-actions .save-btn:hover{background-color:#1976d2}.color-picker-overlay{position:fixed;inset:0;z-index:1001}.color-picker-popup{position:fixed;background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 30px #0003;z-index:1002;animation:contextMenuFadeIn .15s ease-out}.color-picker-popup.dark{background-color:#1f2937}.color-picker-popup h4{margin:0 0 12px;font-size:13px;font-weight:600;color:#666}.dark .color-picker-popup h4{color:#9ca3af}.color-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.color-picker-swatch{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s}.color-picker-swatch:hover{transform:scale(1.15)}.color-picker-swatch.active{border-color:#1e88e5}.canvas-container{flex:1;position:relative;overflow:hidden;background-color:#f8f9fa;width:100%;height:100%;min-height:0}.canvas-container.dark{background-color:#1f2937}.canvas-container canvas{display:block;cursor:crosshair;width:100%;height:100%}.canvas-container canvas:active{cursor:grabbing}.zoom-controls{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:4px;background-color:#fffffff2;border-radius:8px;padding:4px;box-shadow:0 2px 12px #00000026;z-index:10}.zoom-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background-color:transparent;border-radius:6px;font-size:18px;font-weight:500;color:#333;cursor:pointer;transition:background-color .15s,color .15s}.zoom-btn:hover{background-color:#00000014}.zoom-btn:active{background-color:#0000001f}.zoom-btn.zoom-reset{width:auto;min-width:52px;padding:0 8px;font-size:12px;font-weight:600}.dark .zoom-controls{background-color:#374151f2}.dark .zoom-btn{color:#e5e7eb}.dark .zoom-btn:hover{background-color:#ffffff1a}.dark .zoom-btn:active{background-color:#ffffff26}.canvas-container[data-tool=select] canvas{cursor:default}.canvas-container[data-tool=pan] canvas{cursor:grab}.canvas-container[data-tool=pan] canvas:active{cursor:grabbing}.canvas-container[data-tool=draw] canvas,.canvas-container[data-tool=shape] canvas{cursor:crosshair}.canvas-container[data-tool=connector] canvas{cursor:crosshair}.canvas-container[data-tool=text] canvas{cursor:text}.canvas-container[data-tool=eraser] canvas{cursor:cell}.rich-text-editor{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background-color:#fff}.dark .rich-text-editor{border-color:#4b5563;background-color:#374151}.editor-toolbar{display:flex;align-items:center;gap:2px;padding:6px 8px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;flex-wrap:wrap}.dark .editor-toolbar{background-color:#1f2937;border-bottom-color:#4b5563}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#555;transition:all .15s ease}.toolbar-btn:hover{background-color:#e0e0e0;color:#333}.toolbar-btn.active{background-color:#1e88e5;color:#fff}.dark .toolbar-btn{color:#9ca3af}.dark .toolbar-btn:hover{background-color:#4b5563;color:#e5e7eb}.dark .toolbar-btn.active{background-color:#3b82f6;color:#fff}.toolbar-divider{width:1px;height:20px;background-color:#d0d0d0;margin:0 4px}.dark .toolbar-divider{background-color:#4b5563}.editor-textarea{width:100%;min-height:100px;max-height:200px;padding:10px 12px;font-size:13px;font-family:inherit;line-height:1.5;color:#333;background-color:#fff;border:none;resize:vertical;outline:none}.editor-textarea::placeholder{color:#9ca3af}.dark .editor-textarea{background-color:#374151;color:#e5e7eb}.dark .editor-textarea::placeholder{color:#6b7280}.editor-textarea::-webkit-scrollbar{width:6px}.editor-textarea::-webkit-scrollbar-track{background:transparent}.editor-textarea::-webkit-scrollbar-thumb{background-color:silver;border-radius:3px}.dark .editor-textarea::-webkit-scrollbar-thumb{background-color:#4b5563}.properties-panel{width:280px;background-color:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;height:100%;transition:width .2s ease}.properties-panel.dark{background-color:#1f2937;border-left-color:#374151}.properties-panel.collapsed{width:40px;min-width:40px}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e0e0e0}.dark .panel-header{border-bottom-color:#374151}.panel-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.dark .panel-header h3{color:#e5e7eb}.panel-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#666;transition:all .15s ease}.panel-toggle:hover{background-color:#f0f0f0;color:#333}.dark .panel-toggle{color:#9ca3af}.dark .panel-toggle:hover{background-color:#374151;color:#e5e7eb}.collapsed .panel-toggle{margin:8px auto}.panel-content{flex:1;overflow-y:auto;padding:12px}.no-selection,.multi-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#999;font-size:13px}.dark .no-selection,.dark .multi-selection{color:#6b7280}.multi-selection p,.property-section{margin-bottom:16px}.property-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}.dark .property-label{color:#9ca3af}.property-section input[type=text],.property-section input[type=number]{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;background-color:#fff;color:#333;outline:none;transition:border-color .15s}.property-section input[type=text]:focus,.property-section input[type=number]:focus{border-color:#1e88e5}.dark .property-section input[type=text],.dark .property-section input[type=number]{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.dark .property-section input[type=text]:focus,.dark .property-section input[type=number]:focus{border-color:#3b82f6}.content-textarea{width:100%;min-height:80px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;font-family:inherit;background-color:#fff;color:#333;outline:none;resize:vertical;transition:border-color .15s}.content-textarea:focus{border-color:#1e88e5}.dark .content-textarea{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.dark .content-textarea:focus{border-color:#3b82f6}.property-row{display:flex;align-items:center;gap:8px}.property-row input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:#e0e0e0;border-radius:2px;outline:none}.property-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#1e88e5;border-radius:50%;cursor:pointer}.dark .property-row input[type=range]{background:#4b5563}.dark .property-row input[type=range]::-webkit-slider-thumb{background:#3b82f6}.property-row input[type=number].small{width:60px;text-align:center;padding:6px 8px}.property-row span{font-size:12px;color:#999;min-width:16px}.dark .property-row span{color:#6b7280}.property-field{display:flex;align-items:center;gap:6px;flex:1}.property-field span{font-size:11px;color:#999;font-weight:500}.property-field input{flex:1}.color-picker{display:flex;flex-direction:column;gap:8px}.color-presets{display:grid;grid-template-columns:repeat(10,1fr);gap:3px}.color-swatch{width:100%;aspect-ratio:1;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:transform .1s,box-shadow .1s}.color-swatch:hover{transform:scale(1.1);box-shadow:0 2px 4px #0003}.color-swatch.active{box-shadow:0 0 0 2px #1e88e5}.dark .color-swatch{border-color:#4b5563}.dark .color-swatch.active{box-shadow:0 0 0 2px #3b82f6}.color-picker input[type=color]{width:100%;height:32px;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;padding:2px}.dark .color-picker input[type=color]{border-color:#4b5563}.button-group{display:flex;gap:4px}.style-btn{flex:1;padding:8px;border:1px solid #e0e0e0;background:#f8f9fa;border-radius:6px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:#666;transition:all .15s}.style-btn:hover{background-color:#e0e0e0}.style-btn.active{background-color:#1e88e5;border-color:#1e88e5;color:#fff}.dark .style-btn{background-color:#374151;border-color:#4b5563;color:#9ca3af}.dark .style-btn:hover{background-color:#4b5563}.dark .style-btn.active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.action-buttons{display:flex;gap:8px;margin-bottom:8px}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:1px solid #e0e0e0;background:#f8f9fa;border-radius:6px;cursor:pointer;font-size:12px;color:#666;transition:all .15s}.action-btn:hover{background-color:#e0e0e0;color:#333}.action-btn.danger:hover{background-color:#ffebee;border-color:#ffcdd2;color:#f44336}.dark .action-btn{background-color:#374151;border-color:#4b5563;color:#9ca3af}.dark .action-btn:hover{background-color:#4b5563;color:#e5e7eb}.dark .action-btn.danger:hover{background-color:#7f1d1d;border-color:#991b1b;color:#fca5a5}.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-track{background:transparent}.panel-content::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:3px}.dark .panel-content::-webkit-scrollbar-thumb{background-color:#4b5563}.presentation-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#1a1a2e,#16213e);z-index:10000;display:flex;flex-direction:column}.presentation-canvas{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.presentation-svg{width:100%;height:100%;max-width:90%;max-height:80%}.presentation-shape{transition:all .6s cubic-bezier(.4,0,.2,1)}.presentation-shape.hidden{opacity:.1;filter:grayscale(1)}.presentation-shape.visible{opacity:1;filter:none}.presentation-shape.current{animation:pulse 1.5s ease-in-out infinite}.presentation-shape.current .shape-rect{filter:drop-shadow(0 0 20px rgba(33,150,243,.5))}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.shape-label{fill:#e0e0e0;font-size:14px;font-family:Inter,sans-serif;font-weight:500}.presentation-connector{transition:all .5s ease;stroke-dasharray:1000;stroke-dashoffset:1000}.presentation-connector.hidden{opacity:.1}.presentation-connector.visible{opacity:1;stroke-dashoffset:0;animation:drawLine .8s ease forwards}@keyframes drawLine{to{stroke-dashoffset:0}}.step-info-card{position:absolute;bottom:120px;left:50%;transform:translate(-50%);background:#fffffff2;border-radius:16px;padding:20px 40px;box-shadow:0 10px 40px #0000004d;text-align:center;min-width:300px;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.step-number{font-size:12px;color:#666;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}.step-title{font-size:24px;font-weight:600;color:#1a1a2e;margin:0 0 8px}.step-description{font-size:14px;color:#666;margin:0}.presentation-controls{position:absolute;bottom:0;left:0;right:0;background:#1a1a2ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px 24px;display:flex;flex-direction:column;align-items:center;gap:12px}.progress-bar{width:100%;max-width:600px;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#00bcd4);border-radius:2px;transition:width .3s ease}.control-buttons{display:flex;align-items:center;gap:8px}.control-btn{background:#ffffff1a;border:none;color:#fff;width:44px;height:44px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.control-btn:hover{background:#fff3;transform:scale(1.05)}.control-btn.active{background:#2196f34d}.control-btn.play-btn{width:56px;height:56px;background:linear-gradient(135deg,#2196f3,#00bcd4);border-radius:50%}.control-btn.play-btn:hover{transform:scale(1.1);box-shadow:0 4px 20px #2196f366}.control-btn.close-btn:hover{background:#f443364d}.control-separator{width:1px;height:30px;background:#fff3;margin:0 8px}.settings-panel{position:absolute;bottom:100px;right:24px;background:#fffffff2;border-radius:12px;padding:16px;box-shadow:0 4px 20px #0003}.settings-panel label{display:flex;align-items:center;gap:12px;font-size:14px;color:#333}.settings-panel input[type=range]{width:120px;accent-color:#2196f3}.settings-panel span{min-width:40px;color:#666}.step-thumbnails{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:8px 16px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;max-width:80%;overflow-x:auto}.step-thumbnails::-webkit-scrollbar{display:none}.thumbnail{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ffffff1a;border:none;border-radius:16px;color:#fff9;font-size:12px;cursor:pointer;white-space:nowrap;transition:all .2s ease}.thumbnail:hover{background:#fff3;color:#fff}.thumbnail.active{background:linear-gradient(135deg,#2196f3,#00bcd4);color:#fff}.thumbnail.completed{color:#fffc}.thumbnail.completed .thumbnail-number{background:#4caf50}.thumbnail-number{width:20px;height:20px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:10px}.thumbnail.active .thumbnail-number{background:#ffffff4d}.thumbnail-label{max-width:80px;overflow:hidden;text-overflow:ellipsis}.data-flow-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;pointer-events:none}.data-flow-control{display:flex;align-items:center;gap:4px;position:relative}.data-flow-toggle{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:#555;transition:all .2s ease}.data-flow-toggle:hover{background:#e3f2fd;border-color:#90caf9;color:#1976d2}.data-flow-toggle.active{background:linear-gradient(135deg,#00bcd4,#00acc1);border-color:transparent;color:#fff;box-shadow:0 2px 8px #00bcd44d}.data-flow-toggle.active:hover{background:linear-gradient(135deg,#00acc1,#0097a7)}.data-flow-settings-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;color:#666;transition:all .2s ease}.data-flow-settings-btn:hover{background:#e0e0e0}.data-flow-settings{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:16px;min-width:220px;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.data-flow-settings h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.data-flow-settings label{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:13px;color:#555}.data-flow-settings label>span:first-child{min-width:60px}.data-flow-settings input[type=range]{flex:1;accent-color:#00bcd4}.data-flow-settings .value{min-width:30px;text-align:right;font-weight:500;color:#333}.color-options{display:flex;gap:6px}.color-btn{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s ease}.color-btn:hover{transform:scale(1.15)}.color-btn.active{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor}@keyframes particleGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}.code-generator-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.code-generator-modal{background:#1e1e2e;border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;animation:slideUp .3s ease;overflow:hidden}.cg-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #333}.cg-title{display:flex;align-items:center;gap:12px;color:#fff}.cg-title h2{margin:0;font-size:18px;font-weight:600}.cg-close{background:none;border:none;color:#888;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.cg-close:hover{background:#ffffff1a;color:#fff}.cg-tabs{display:flex;gap:8px;padding:16px 24px;background:#252536}.cg-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:transparent;border:1px solid #444;border-radius:8px;color:#aaa;font-size:14px;cursor:pointer;transition:all .2s ease}.cg-tab:hover{background:#ffffff0d;color:#fff}.cg-tab.active{background:#2196f3;border-color:#2196f3;color:#fff}.cg-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.cg-actions{display:flex;gap:8px;padding:12px 24px;background:#252536;border-bottom:1px solid #333}.cg-action-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#ffffff1a;border:none;border-radius:6px;color:#fff;font-size:13px;cursor:pointer;transition:all .2s ease}.cg-action-btn:hover{background:#ffffff26}.cg-action-btn:first-child:hover{background:#4caf50}.cg-action-btn:last-child:hover{background:#2196f3}.cg-code{flex:1;margin:0;padding:20px 24px;overflow:auto;background:#1a1a2e;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.6;color:#e0e0e0}.cg-code code{white-space:pre}.cg-footer{padding:12px 24px;background:#252536;border-top:1px solid #333}.cg-footer p{margin:0;display:flex;align-items:center;gap:8px;font-size:13px;color:#888}.cg-code .keyword{color:#c792ea}.cg-code .string{color:#c3e88d}.cg-code .comment{color:#656a7d}.cg-code .number{color:#f78c6c}.cg-code::-webkit-scrollbar{width:10px;height:10px}.cg-code::-webkit-scrollbar-track{background:#1a1a2e}.cg-code::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.cg-code::-webkit-scrollbar-thumb:hover{background:#555}.cost-estimator-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.cost-estimator-modal{background:#fff;border-radius:16px;width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.ce-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#1565c0,#1e88e5);color:#fff}.ce-title{display:flex;align-items:center;gap:12px}.ce-title h2{margin:0;font-size:18px;font-weight:600}.ce-close{background:#fff3;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.ce-close:hover{background:#ffffff4d}.ce-options{display:flex;gap:24px;padding:16px 24px;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.ce-option-group{display:flex;flex-direction:column;gap:6px}.ce-option-group label{font-size:12px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.ce-option-group select{padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;cursor:pointer}.ce-toggle{display:flex;background:#e0e0e0;border-radius:8px;overflow:hidden}.ce-toggle button{padding:8px 16px;border:none;background:transparent;font-size:14px;cursor:pointer;transition:all .2s ease}.ce-toggle button.active{background:#1e88e5;color:#fff}.ce-content{flex:1;overflow:auto;padding:0}.ce-table{width:100%;border-collapse:collapse}.ce-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;background:#fafafa;border-bottom:1px solid #e0e0e0;position:sticky;top:0}.ce-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;font-size:14px}.ce-table tr:hover{background:#fafafa}.ce-component{display:flex;flex-direction:column;gap:2px}.ce-component-name{font-weight:500;color:#333}.ce-component-type{font-size:12px;color:#999}.ce-service{display:flex;align-items:center;gap:8px;color:#666}.ce-cost{display:flex;align-items:center;gap:4px;font-weight:600;color:#333}.ce-cost input{width:80px;padding:4px 8px;border:2px solid #2e7d32;border-radius:4px;font-size:14px;font-weight:600}.ce-estimate-badge{font-size:10px;background:#fff3e0;color:#f57c00;padding:2px 6px;border-radius:4px;font-weight:500}.ce-period{color:#999;font-weight:400;font-size:12px}.ce-actions{width:40px}.ce-edit-btn{padding:6px;background:none;border:none;color:#999;cursor:pointer;border-radius:4px;transition:all .2s ease}.ce-edit-btn:hover{background:#e0e0e0;color:#333}.cost-tier-high .ce-cost{color:#d32f2f}.cost-tier-medium .ce-cost{color:#f57c00}.cost-tier-low .ce-cost{color:#2e7d32}.ce-summary{padding:20px 24px;background:#fafafa;border-top:1px solid #e0e0e0}.ce-summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#666}.ce-summary-row.total{padding-top:16px;margin-top:8px;border-top:2px solid #e0e0e0;font-size:16px;color:#333}.ce-total-amount{font-size:24px;font-weight:700;color:#2e7d32}.ce-projections{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.ce-projection{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.ce-projection strong{color:#333}.ce-footer{display:flex;align-items:flex-start;gap:12px;padding:16px 24px;background:#fff8e1;border-top:1px solid #ffe082;font-size:13px;color:#5d4037}.ce-footer p{margin:0;line-height:1.5}.ce-content::-webkit-scrollbar{width:8px}.ce-content::-webkit-scrollbar-track{background:#f5f5f5}.ce-content::-webkit-scrollbar-thumb{background:#ddd;border-radius:4px}.ce-content::-webkit-scrollbar-thumb:hover{background:#ccc}.failure-analysis-panel{position:absolute;right:16px;top:80px;width:320px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;z-index:1000;max-height:calc(100vh - 120px);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease}.fa-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#d32f2f,#f44336);color:#fff}.fa-title{display:flex;align-items:center;gap:10px}.fa-title h3{margin:0;font-size:16px;font-weight:600}.fa-close{background:#fff3;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:6px;transition:all .2s ease}.fa-close:hover{background:#ffffff4d}.fa-modes{display:flex;gap:4px;padding:12px;background:#fafafa;border-bottom:1px solid #e0e0e0}.fa-mode{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 6px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:11px;cursor:pointer;transition:all .2s ease;color:#666}.fa-mode:hover{background:#f5f5f5}.fa-mode.active{background:#f44336;border-color:#f44336;color:#fff}.fa-instructions{padding:12px 16px;background:#fff3e0;border-bottom:1px solid #ffe0b2}.fa-instructions p{margin:0;font-size:12px;color:#e65100;line-height:1.4}.fa-section{padding:12px 16px;border-bottom:1px solid #f0f0f0}.fa-section h4{display:flex;align-items:center;gap:8px;margin:0 0 10px;font-size:13px;font-weight:600;color:#333}.fa-spof-list{display:flex;flex-direction:column;gap:6px}.fa-spof-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#ffebee;border:1px solid #ffcdd2;border-radius:8px;cursor:pointer;transition:all .2s ease}.fa-spof-item:hover{background:#ffcdd2}.fa-spof-item.selected{background:#f44336;border-color:#d32f2f;color:#fff}.fa-spof-name{font-weight:500;font-size:13px}.fa-spof-impact{display:flex;align-items:center;gap:4px;font-size:11px;color:#d32f2f}.fa-spof-item.selected .fa-spof-impact{color:#fff}.fa-risk-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.fa-risk-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease}.fa-risk-item:hover{background:#f0f0f0}.fa-risk-item.selected{background:#e3f2fd;border-color:#2196f3}.fa-risk-indicator{width:10px;height:10px;border-radius:50%}.fa-risk-indicator.critical{background:#d32f2f;box-shadow:0 0 8px #d32f2f80}.fa-risk-indicator.high{background:#f57c00}.fa-risk-indicator.medium{background:#ffc107}.fa-risk-indicator.low{background:#4caf50}.fa-risk-info{flex:1;display:flex;justify-content:space-between;align-items:center}.fa-risk-name{font-size:13px;font-weight:500;color:#333}.fa-risk-stats{font-size:11px;color:#999;font-family:monospace}.fa-details{padding:16px;background:#e8f5e9;border-top:1px solid #c8e6c9}.fa-details h4{margin:0 0 12px;font-size:13px;font-weight:600;color:#2e7d32}.fa-detail-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:#555}.fa-detail-row strong{color:#2e7d32}.fa-clear-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:12px;padding:8px;background:#2e7d32;border:none;border-radius:6px;color:#fff;font-size:13px;cursor:pointer;transition:all .2s ease}.fa-clear-btn:hover{background:#1b5e20}.fa-risk-list::-webkit-scrollbar{width:6px}.fa-risk-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:3px}.fa-risk-list::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.diagram-validator-panel{position:absolute;right:16px;top:80px;width:340px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;z-index:1000;max-height:calc(100vh - 120px);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.dv-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff}.dv-title{display:flex;align-items:center;gap:10px}.dv-title h3{margin:0;font-size:16px;font-weight:600}.dv-header-actions{display:flex;gap:8px}.dv-refresh,.dv-close{background:#fff3;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:6px;transition:all .2s ease}.dv-refresh:hover,.dv-close:hover{background:#ffffff4d}.dv-refresh.spinning svg{animation:spin .5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dv-score{display:flex;align-items:center;gap:24px;padding:20px;background:#fafafa;border-bottom:1px solid #e0e0e0}.dv-score-circle{width:80px;height:80px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#e8f5e9;border:4px solid #4caf50}.dv-score-circle[data-score=fair]{background:#fff3e0;border-color:#ff9800}.dv-score-circle[data-score=poor]{background:#ffebee;border-color:#f44336}.dv-score-value{font-size:28px;font-weight:700;color:#333}.dv-score-label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.5px}.dv-score-summary{display:flex;flex-direction:column;gap:6px}.dv-score-row{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}.dv-score-row span:first-child{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;font-size:12px}.severity-error{background:#ffebee;color:#d32f2f}.severity-warning{background:#fff3e0;color:#f57c00}.severity-info{background:#e3f2fd;color:#1976d2}.dv-success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#4caf50}.dv-success h4{margin:16px 0 8px;font-size:18px;color:#333}.dv-success p{margin:0;font-size:14px;color:#666}.dv-issues{flex:1;overflow-y:auto}.dv-issue-group{border-bottom:1px solid #e0e0e0}.dv-issue-header{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;text-align:left;transition:background .2s ease}.dv-issue-header:hover{background:#f5f5f5}.dv-issue-group.error .dv-issue-header{color:#d32f2f}.dv-issue-group.warning .dv-issue-header{color:#f57c00}.dv-issue-group.info .dv-issue-header{color:#1976d2}.dv-issue-title{flex:1}.dv-issue-count{padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.dv-issue-group.error .dv-issue-count{background:#ffebee}.dv-issue-group.warning .dv-issue-count{background:#fff3e0}.dv-issue-group.info .dv-issue-count{background:#e3f2fd}.dv-issue-list{padding:0 16px 12px}.dv-issue-item{display:flex;gap:12px;padding:10px 12px;background:#fafafa;border-radius:8px;margin-bottom:6px}.dv-issue-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:6px;color:#666}.dv-issue-content{flex:1;display:flex;flex-direction:column;gap:2px}.dv-issue-name{font-size:13px;font-weight:500;color:#333}.dv-issue-message{font-size:12px;color:#666;line-height:1.4}.dv-tips{padding:16px;background:#f5f5f5;border-top:1px solid #e0e0e0}.dv-tips h4{margin:0 0 10px;font-size:13px;font-weight:600;color:#333}.dv-tips ul{margin:0;padding:0 0 0 20px}.dv-tips li{font-size:12px;color:#666;margin-bottom:4px;line-height:1.4}.dv-issues::-webkit-scrollbar{width:6px}.dv-issues::-webkit-scrollbar-track{background:#f5f5f5}.dv-issues::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.ai-chat-button{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;padding:14px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 4px 20px #6366f166;transition:all .3s ease;z-index:9999}.ai-chat-button:hover{transform:translateY(-2px);box-shadow:0 6px 30px #6366f180}.ai-chat-button.hidden{transform:scale(0);opacity:0}.ai-chat-button svg{animation:sparkle 2s ease infinite}@keyframes sparkle{0%,to{opacity:1}50%{opacity:.7}}.ai-chat-panel{position:fixed;bottom:24px;right:24px;width:380px;height:550px;background:#fff;border-radius:16px;box-shadow:0 10px 50px #0003;display:flex;flex-direction:column;overflow:hidden;z-index:10000;animation:slideUp .3s ease}.ai-chat-panel.expanded{width:500px;height:700px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ai-chat-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.ai-chat-title{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}.ai-chat-actions{display:flex;gap:6px}.ai-chat-actions button{background:#fff3;border:none;color:#fff;padding:6px;border-radius:6px;cursor:pointer;transition:all .2s ease}.ai-chat-actions button:hover{background:#ffffff4d}.ai-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px;background:#f8f9fa}.ai-message{display:flex;gap:10px;max-width:90%}.ai-message.user{align-self:flex-end;flex-direction:row-reverse}.ai-message-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-message.assistant .ai-message-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.ai-message.user .ai-message-avatar{background:#e0e0e0;color:#666}.ai-message-content{position:relative}.ai-message-text{padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.5}.ai-message.assistant .ai-message-text{background:#fff;color:#333;border-bottom-left-radius:4px;box-shadow:0 1px 3px #0000001a}.ai-message.user .ai-message-text{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:4px}.ai-message-text strong{color:#6366f1}.ai-message.user .ai-message-text strong{color:#fff}.ai-list-item{padding-left:8px;margin:4px 0}.ai-copy-btn{position:absolute;top:8px;right:8px;background:#f0f0f0;border:none;padding:4px;border-radius:4px;cursor:pointer;opacity:0;transition:all .2s ease}.ai-message-content:hover .ai-copy-btn{opacity:1}.ai-copy-btn:hover{background:#e0e0e0}.ai-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.ai-suggestion{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#f0f0f0;border:1px solid #e0e0e0;border-radius:16px;font-size:12px;color:#666;cursor:pointer;transition:all .2s ease}.ai-suggestion:hover{background:#6366f1;border-color:#6366f1;color:#fff}.ai-suggestion svg{color:#fbbf24}.ai-suggestion:hover svg{color:#fff}.ai-typing{display:flex;gap:4px;padding:12px 16px;background:#fff;border-radius:16px 16px 16px 4px}.ai-typing span{width:8px;height:8px;background:#6366f1;border-radius:50%;animation:typing 1.4s infinite ease-in-out both}.ai-typing span:nth-child(1){animation-delay:-.32s}.ai-typing span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.ai-chat-input{display:flex;gap:8px;padding:16px;background:#fff;border-top:1px solid #e0e0e0}.ai-chat-input textarea{flex:1;padding:12px 16px;border:1px solid #e0e0e0;border-radius:24px;font-size:14px;font-family:inherit;resize:none;outline:none;transition:all .2s ease}.ai-chat-input textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.ai-send-btn{width:44px;height:44px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.ai-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 15px #6366f166}.ai-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-chat-messages::-webkit-scrollbar{width:6px}.ai-chat-messages::-webkit-scrollbar-track{background:transparent}.ai-chat-messages::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.ai-chat-messages::-webkit-scrollbar-thumb:hover{background:#ccc}.dark .ai-chat-panel{background:#1e1e2e}.dark .ai-chat-messages{background:#252536}.dark .ai-message.assistant .ai-message-text{background:#2d2d3f;color:#e0e0e0}.dark .ai-chat-input{background:#1e1e2e;border-color:#333}.dark .ai-chat-input textarea{background:#2d2d3f;border-color:#444;color:#e0e0e0}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;width:100%;background-color:#f8f9fa;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.app.dark{background-color:#111827}.main-content{display:flex;flex:1;overflow:hidden;min-height:0;height:0}.canvas-wrapper{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%;min-height:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:silver;border-radius:4px}.dark ::-webkit-scrollbar-thumb{background-color:#4b5563}::selection{background-color:#1e88e5;color:#fff}:focus-visible{outline:2px solid #1e88e5;outline-offset:2px}.dark :focus-visible{outline-color:#3b82f6}button{font-family:inherit}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.copyright-footer{position:fixed;bottom:0;left:0;right:0;height:24px;display:flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fffffff2;font-size:11px;font-weight:500;letter-spacing:.5px;z-index:9999;user-select:none;-webkit-user-select:none}.copyright-close{position:absolute;right:8px;background:transparent;border:none;color:#ffffffb3;font-size:16px;cursor:pointer;padding:0 6px;line-height:1;transition:color .15s}.copyright-close:hover{color:#fff}.dark .copyright-footer{background:linear-gradient(135deg,#4c51bf,#6b21a8)}
