@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap";.App{width:100%;min-height:100vh;background-color:var(--gray-50)}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg)}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--gradient-primary);opacity:0;transition:opacity .4s ease}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--glass-border);transform:translateY(-4px)}.card:hover:before{opacity:1}.profile-button{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:transparent;border:1px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.profile-button:hover{background:var(--gray-50);border-color:var(--gray-300);box-shadow:var(--shadow-sm)}.profile-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);box-shadow:var(--shadow-sm)}.profile-name{font-weight:500;color:var(--gray-700);font-size:var(--text-sm)}.dropdown-arrow{color:var(--gray-400);font-size:16px;font-weight:700;transition:color .3s ease}.profile-button:hover .dropdown-arrow{color:var(--gray-600)}.profile-dropdown{position:absolute;bottom:calc(100% + var(--space-sm));right:0;min-width:280px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;padding:var(--space-sm);animation:fadeInDown .3s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;justify-content:flex-start;width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:all .3s ease;color:var(--gray-700);font-size:var(--text-sm)}.dropdown-item:hover{background:var(--gray-50);color:var(--gray-900)}.dropdown-item.profile-info{cursor:default;padding:var(--space-md);background:var(--gray-50);margin-bottom:var(--space-sm)}.dropdown-item.profile-info:hover{background:var(--gray-50)}.profile-email{font-weight:500;color:var(--gray-900)}.profile-plan{font-size:var(--text-xs);color:var(--gray-500);margin-top:2px}.dropdown-item.danger{color:var(--error)!important;font-weight:600!important}.dropdown-item.danger:hover{background:var(--error)!important;color:var(--text-primary)!important}.dropdown-item.logout{color:var(--red-600)}.dropdown-item.logout:hover{background:var(--red-50);color:var(--red-700)}.dropdown-divider{margin:var(--space-sm) 0;border:none;height:1px;background:var(--gray-200)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;height:100vh;background:var(--gray-50);color:#fff;display:flex;flex-direction:column;border-right:1px solid var(--gray-200);position:relative;transition:all .3s ease;z-index:100}.sidebar.closed{width:60px;min-width:60px;overflow:visible;border-right:1px solid var(--gray-200)}.sidebar.closed .sidebar-footer-collapsed{overflow:visible}.sidebar.closed .user-profile-collapsed .profile-dropdown{right:0}.sidebar.closed .sidebar-content{display:none}.sidebar.open{width:280px}.sidebar-header{padding:var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.sidebar-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.new-diagram-section{padding:0px var(--space-lg) var(--space-md) var(--space-lg);border-bottom:1px solid var(--gray-200)}.sidebar-header-collapsed{padding:var(--space-lg);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:center}.sidebar-brand-collapsed{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.sidebar-toggle-btn-collapsed{position:absolute;top:0;left:0;right:0;bottom:0;display:none;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;z-index:10}.sidebar-footer-collapsed{border-top:1px solid var(--gray-200);padding:var(--space-lg);display:flex;align-items:center;justify-content:center;margin-top:auto}.user-profile-collapsed{display:flex;align-items:center;justify-content:center;position:relative}.profile-button-collapsed{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;padding:0}.profile-button-collapsed:hover{background:var(--gray-100);box-shadow:var(--shadow-sm)}.profile-button-collapsed .profile-avatar{width:32px;height:32px}.sidebar-brand{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none!important;color:#fff;transition:all .3s ease}.sidebar-brand:hover{text-decoration:none!important;transform:none!important}.sidebar-brand:after{display:none!important}.sidebar-brand:hover:after{display:none!important}.sidebar-logo{width:28px;height:28px;border-radius:var(--radius-md)}.sidebar-title{font-size:var(--text-lg);font-weight:600}.new-diagram-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;font-weight:500;font-size:13px;cursor:pointer;transition:all .3s ease;white-space:nowrap}.new-diagram-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.new-diagram-btn.disabled,.new-diagram-btn:disabled{background:var(--gray-300);color:var(--gray-500);cursor:not-allowed;opacity:.6}.new-diagram-btn.disabled:hover,.new-diagram-btn:disabled:hover{background:var(--gray-300);transform:none}.plus-icon{font-size:14px;font-weight:700}.sidebar-content{flex:1;overflow-y:auto;padding:var(--space-md)}.section-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:.5px}.diagrams-list{display:flex;flex-direction:column;gap:0}.diagram-item{display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-radius:6px;color:var(--gray-500);text-decoration:none;transition:background-color .15s ease;position:relative;cursor:pointer;margin:0;height:0px}.diagram-item:hover{background:var(--gray-200);color:#fff}.diagram-item.active{background:var(--gray-200);color:#fff;border-left:3px solid var(--primary)}.diagram-info{flex:1;min-width:0;padding-right:8px}.diagram-name{font-size:13px;font-weight:400;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:.95;color:inherit}.diagram-actions{display:flex;opacity:0;transition:opacity .15s ease}.diagram-item:hover .diagram-actions{opacity:1}.menu-button{padding:2px 4px;background:transparent;border:none;border-radius:4px;color:var(--gray-500);cursor:pointer;transition:background-color .15s ease;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;font-weight:700}.menu-button:hover{background:var(--gray-200);color:#fff}.sidebar-footer{border-top:1px solid var(--gray-200);padding:var(--space-lg)}.quota-info{margin-bottom:var(--space-md)}.quota-bar{width:100%;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden;margin-bottom:var(--space-sm)}.quota-used{height:100%;background:linear-gradient(90deg,var(--primary-dark),var(--primary));transition:width .3s ease}.quota-text{font-size:var(--text-xs);color:var(--gray-500);margin:0 0 var(--space-sm) 0}.upgrade-btn{width:100%;padding:4px 8px;background:linear-gradient(135deg,var(--primary-dark),var(--primary));border:none;border-radius:var(--radius-sm);color:#fff;font-weight:500;font-size:13px;cursor:pointer;transition:all .3s ease}.upgrade-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.user-profile{position:relative}.profile-button{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md);background:var(--gray-200);border:1px solid var(--gray-400);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.profile-button:hover{background:var(--gray-200);border-color:var(--gray-400)}.profile-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-info{flex:1;text-align:left;min-width:0}.profile-name{display:block;font-weight:500;color:#fff;font-size:var(--text-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{display:block;font-size:var(--text-xs);color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown{position:absolute;bottom:calc(100% + var(--space-sm));left:0;right:0;background:var(--gray-200);border:1px solid var(--gray-400);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;padding:var(--space-sm);animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dropdown-divider{margin:var(--space-sm) 0;border:none;height:1px;background:var(--gray-300)}.dropdown-icon{font-size:var(--text-sm);opacity:.7}.dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:transparent}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--gray-50)}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;padding:0}.sidebar-toggle-btn:hover{background:var(--gray-100);box-shadow:var(--shadow-sm)}.sidebar-toggle-btn .minimize-icon{color:var(--primary)!important;font-size:24px}.sidebar-toggle-btn-collapsed .minimize-icon{color:var(--primary)!important;font-size:20px}.floating-toggle-btn{position:fixed;top:var(--space-lg);left:var(--space-lg);z-index:1000;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:50%;cursor:pointer;transition:all .3s ease;padding:0;box-shadow:var(--shadow-lg)}.floating-toggle-btn:hover{background:var(--primary-50);border-color:var(--primary-200);box-shadow:var(--shadow-xl);transform:scale(1.05)}.floating-toggle-btn .menu-icon{font-size:24px;color:var(--text-primary)}.floating-toggle-btn:hover .menu-icon{color:var(--primary-600)}@media (max-width: 768px){.sidebar{width:280px;position:fixed;top:0;left:0;z-index:1000;transform:translate(-100%);transition:transform .3s ease;height:100vh}.sidebar.open{transform:translate(0)}.sidebar.closed{transform:translate(-100%)}.main-content{width:100%}}.dashboard-page{padding:0;height:100%;overflow-y:auto}.dashboard-header{margin-bottom:var(--space-xl)}.dashboard-header h1{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin:0 0 var(--space-sm) 0}.dashboard-header p{font-size:var(--text-lg);color:var(--gray-500);margin:0}.feature-list{list-style:none;padding:0;margin:var(--space-lg) 0 0 0}.feature-list li{padding:var(--space-sm) 0;color:var(--gray-700);font-weight:500}.activity-list{margin-top:var(--space-lg)}.activity-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--gray-200)}.activity-item:last-child{border-bottom:none}.activity-icon{font-size:var(--text-lg)}.activity-time{font-size:var(--text-xs);color:var(--gray-500);margin-top:4px}.editor-page{height:100%;display:flex;flex-direction:column}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color);background:var(--surface-color);gap:var(--space-lg)}.editor-title{flex:1}.editor-title h1{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.editor-meta{display:flex;align-items:center;flex-shrink:0}.diagram-id{font-size:var(--text-md);color:var(--text-secondary);font-weight:500;background:var(--glass-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm)}.action-button{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .3s ease;border:1px solid transparent}.action-button.secondary{background:var(--gray-200);color:var(--text-primary);border-color:var(--border-color)}.action-button.secondary:hover{background:var(--gray-300);border-color:var(--border-color-hover)}.editor-content{flex:1;display:flex;overflow:hidden;gap:var(--space-md);padding:var(--space-md);background:var(--gray-50)}.editor-tools{width:280px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:var(--glass-shadow);overflow:hidden;max-height:100vh}.tools-section{padding:var(--space-md);border-bottom:1px solid var(--border-color);flex-shrink:0}.tools-section:last-child{border-bottom:none;flex:1;overflow-y:auto;padding-bottom:var(--space-md)}.tools-section:last-child::-webkit-scrollbar{width:6px}.tools-section:last-child::-webkit-scrollbar-track{background:transparent}.tools-section:last-child::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.tools-section:last-child::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.tools-section:last-child{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.tools-section h3{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-sm) 0;text-transform:uppercase;letter-spacing:.5px;opacity:.8}.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.tool-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease;color:var(--text-secondary)}.tool-item:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700);transform:translateY(-1px)}.tool-icon{font-size:var(--text-lg)}.tool-item span:last-child{font-size:var(--text-xs);font-weight:500}.properties-panel{padding:var(--space-md);background:var(--gray-100);border-radius:var(--radius-md);min-height:200px}.placeholder-text{color:var(--text-secondary);font-size:var(--text-sm);text-align:center;margin:var(--space-lg) 0}.editor-canvas{flex:1;display:flex;flex-direction:column;background:var(--gray-100);height:100%}.canvas-container{flex:1;display:flex;flex-direction:column;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);overflow:hidden}.canvas-toolbar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--surface-color);border-bottom:1px solid var(--border-color)}.toolbar-btn{padding:var(--space-sm);background:var(--gray-200);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .3s ease;color:var(--text-secondary)}.toolbar-btn:hover{background:var(--gray-300);color:var(--text-primary)}.zoom-info{padding:var(--space-sm) var(--space-md);background:var(--gray-200);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-primary);margin-left:auto}.canvas-area{flex:1;position:relative;overflow:hidden;height:100%;width:100%}.canvas-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#fff;border:2px dashed var(--gray-300);margin:var(--space-lg);border-radius:var(--radius-lg)}.placeholder-content{text-align:center;color:var(--text-secondary)}.placeholder-content h2{font-size:var(--text-xl);margin:0 0 var(--space-sm) 0;color:var(--text-primary)}.placeholder-content p{margin:var(--space-xs) 0}.diagram-info{color:var(--primary-600)!important;font-weight:500!important}@media (max-width: 1024px){.welcome-section{grid-template-columns:1fr}.editor-tools{width:240px}.tool-grid{grid-template-columns:1fr}.editor-header{flex-wrap:wrap;gap:var(--space-sm)}.editor-meta{order:3;width:100%;justify-content:center}.action-button{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs)}}.sidebar.closed~.main-content .dashboard-content{max-width:calc(100vw - 60px)}@media (max-width: 1024px){.dashboard-content{max-width:calc(100vw - 60px)}.quick-actions{grid-template-columns:1fr}.features-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width: 768px){.dashboard-page{padding:0}.dashboard-header{padding:var(--space-lg) var(--space-md)}.header-text h1{font-size:24px}.header-text p{font-size:16px}.dashboard-content{padding:var(--space-lg) var(--space-md);gap:var(--space-xl);max-width:100vw}.welcome-card,.features-card{padding:var(--space-lg)}.card-header h2{font-size:24px}.quick-actions{grid-template-columns:1fr;gap:var(--space-lg)}.action-item{padding:var(--space-lg);flex-direction:column;text-align:center;gap:var(--space-md)}.action-icon{width:40px;height:40px;font-size:24px}.features-grid{grid-template-columns:1fr;gap:var(--space-md)}.feature-item{padding:var(--space-md);flex-direction:column;text-align:center;gap:var(--space-sm)}.feature-icon{width:36px;height:36px;font-size:20px}.mcp-steps{grid-template-columns:1fr;gap:var(--space-lg)}.mcp-step{flex-direction:column;text-align:center;gap:var(--space-md)}.step-number{width:36px;height:36px;font-size:16px}}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1;font-family:var(--font-mono);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.badge.primary{background:var(--gradient-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.badge.secondary{background:var(--gradient-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.badge.accent{background:var(--gradient-accent);color:var(--text-primary);box-shadow:var(--shadow-sm)}.badge:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.input{border:2px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);font-size:14px;line-height:1.5;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);min-height:36px;font-family:var(--font-family)}.input:focus{outline:none;border-color:var(--primary);box-shadow:var(--glow-primary);background:var(--surface-color)}.input:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-sm)}.divider{height:2px;background:var(--gradient-primary);margin:var(--space-md) 0;border-radius:1px;opacity:.3}.terminal{background:var(--code-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--code-fg);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.terminal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--gradient-primary)}.terminal-header{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.terminal-dot{width:12px;height:12px;border-radius:50%;background:var(--error);box-shadow:0 0 8px var(--error);animation:pulse 2s infinite}.terminal-dot.warning{background:var(--warning);box-shadow:0 0 8px var(--warning)}.terminal-dot.success{background:var(--success);box-shadow:0 0 8px var(--success)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.terminal-title{font-size:12px;color:var(--text-secondary);font-weight:600}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.m-xl{margin:var(--space-xl)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-disabled{color:var(--text-disabled)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-accent{background-color:var(--accent)}.bg-surface{background-color:var(--surface-color)}.border-primary{border-color:var(--primary)}.border-secondary{border-color:var(--secondary)}.border-accent{border-color:var(--accent)}.border-default{border-color:var(--border-color)}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:var(--space-xl)}.error-boundary-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;max-width:500px;box-shadow:var(--shadow-lg)}.error-boundary-content h2{color:var(--error);margin-bottom:var(--space-md);font-size:var(--text-xl);font-weight:600}.error-boundary-content p{color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.6}.error-details{margin:var(--space-lg) 0;text-align:left}.error-details summary{cursor:pointer;color:var(--text-primary);font-weight:500;margin-bottom:var(--space-sm)}.error-details pre{background:var(--code-bg);color:var(--code-fg);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-xs);overflow-x:auto;border:1px solid var(--border-color)}.retry-button{background:var(--gradient-primary);color:var(--text-primary);border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .3s ease;font-family:var(--font-family)}.retry-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.logo-container{margin-bottom:var(--space-xl);display:flex;justify-content:center;align-items:center}.planform-logo{height:60px;width:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));transition:all .3s cubic-bezier(.4,0,.2,1)}.planform-logo:hover{transform:scale(1.05);filter:drop-shadow(0 8px 16px rgba(88,67,223,.3))}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--gray-50);position:relative}.login-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);padding:var(--space-3xl);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);text-align:center;max-width:450px;width:100%;position:relative;border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1)}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.login-container:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.login-container h1{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:32px;font-weight:700;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-container p{color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:16px;line-height:1.6}.login-button{background:var(--gradient-primary);color:var(--text-primary);border:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;margin-bottom:var(--space-lg);width:100%;min-height:48px;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.login-button:hover:before{left:100%}.login-button:hover{box-shadow:var(--glow-primary),var(--shadow-lg);transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.login-button:disabled:hover{transform:none!important;background:var(--primary-color)}.error-message{margin:var(--space-md) 0;padding:var(--space-sm) var(--space-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--error);font-size:var(--text-sm);text-align:center}.login-info{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm)}.login-info p{margin:var(--space-xs) 0;font-size:14px;color:var(--text-secondary);line-height:1.6}.login-footer{margin-top:var(--space-xl)}.login-footer a{color:var(--primary);text-decoration:none;font-weight:600;font-size:14px;transition:all .3s ease;position:relative}.login-footer a:hover{color:var(--primary-light);transform:translateY(-1px)}.consent-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--gray-50);position:relative;padding:var(--space-lg)}.consent-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);padding:var(--space-3xl);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);border:1px solid var(--glass-border);max-width:600px;width:100%;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.consent-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--gradient-primary);opacity:.8}.consent-container:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.consent-content h1{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:28px;font-weight:700;letter-spacing:-.02em;text-align:center}.consent-description{color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:16px;line-height:1.6;text-align:center}.activation-code{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border);text-align:center}.activation-code label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm);font-size:14px;text-transform:uppercase;letter-spacing:.05em}.code-display{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:24px;font-weight:700;color:var(--primary);background:var(--gray-100);padding:var(--space-md);border-radius:var(--radius-md);border:2px solid var(--primary-light);letter-spacing:.1em;text-transform:uppercase}.auth-section,.approval-section{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border)}.auth-section h2,.approval-section h2{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:20px;font-weight:600}.auth-section p,.approval-section p{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:14px;line-height:1.6}.approval-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg);justify-content:center}.primary-button{background:var(--gradient-primary);color:#fff;border:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-weight:600;font-size:16px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-width:120px}.primary-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.primary-button:hover:before{left:100%}.primary-button:hover{box-shadow:var(--glow-primary),var(--shadow-lg);transform:translateY(-2px)}.primary-button:active{transform:translateY(0)}.primary-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.secondary-button{background:transparent;color:var(--text-secondary);border:2px solid var(--gray-300);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-weight:600;font-size:16px;cursor:pointer;transition:all .3s ease;min-width:120px}.secondary-button:hover{background:var(--gray-50);border-color:var(--gray-400);color:var(--text-primary);transform:translateY(-1px)}.secondary-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.consent-info{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border)}.consent-info h3{color:var(--text-primary);margin-bottom:var(--space-md);font-size:16px;font-weight:600}.consent-info ul{margin:var(--space-md) 0;padding-left:var(--space-lg)}.consent-info li{color:var(--text-secondary);margin-bottom:var(--space-xs);font-size:14px;line-height:1.6}.security-note{margin-top:var(--space-md);padding:var(--space-md);background:var(--success-light);border-radius:var(--radius-md);border-left:4px solid var(--success);font-size:14px;color:var(--text-secondary);line-height:1.6}.security-note strong{color:var(--success-dark)}.dashboard-page{min-height:100vh;background:var(--gray-50);padding:0;display:flex;flex-direction:column}.dashboard-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:var(--space-xl) var(--space-2xl);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-content{width:100%;display:flex;justify-content:center;align-items:center}.header-text h1{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:32px;font-weight:700;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-text p{margin:0;color:var(--text-secondary);font-size:18px;line-height:1.5}.dashboard-content{flex:1;padding:var(--space-2xl);width:100%;max-width:calc(100vw - 280px);display:flex;flex-direction:column;align-items:center;gap:var(--space-2xl);overflow-x:hidden;box-sizing:border-box}.dashboard-content>*{width:100%;max-width:1040px}.diagrams-section{margin-bottom:var(--space-xl);width:100%}.diagrams-section .section-title{margin-bottom:var(--space-sm)}.dashboard-welcome{margin-bottom:var(--space-2xl);text-align:center;max-width:600px;margin-left:auto;margin-right:auto}.dashboard-welcome h1{margin:0 0 var(--space-sm) 0;font-size:28px;font-weight:600;color:var(--text-primary);line-height:1.3}.dashboard-welcome p{margin:0;font-size:16px;color:var(--text-secondary);line-height:1.5}.dashboard-info{padding:var(--space-xl);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);position:relative;overflow:hidden;max-width:700px}.dashboard-info:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:.6}.dashboard-info-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.dashboard-info-icon{font-size:24px;line-height:1;flex-shrink:0;opacity:.9}.dashboard-info h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary);line-height:1.3}.dashboard-info p{margin:0;font-size:15px;color:var(--text-secondary);line-height:1.7}.create-diagram-form-inline{display:flex;align-items:center;gap:var(--space-sm)}.create-diagram-form-inline .diagram-title-input{padding:var(--space-sm) var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background:var(--surface-color);color:var(--text-primary);transition:all .3s ease;width:200px}.create-diagram-form-inline .diagram-title-input:focus{outline:none;border-color:var(--primary);box-shadow:var(--glow-primary)}.form-actions-inline{display:flex;gap:var(--space-xs)}.form-actions-inline button{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;min-height:36px}.dashboard-content .diagrams-list{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.dashboard-content .diagram-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);min-height:56px;height:56px;border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.dashboard-content .diagram-item:last-child{border-bottom:none}.dashboard-content .diagram-item:hover{background:var(--surface-color)}.dashboard-content .diagram-info{flex:1;min-width:0;padding-right:var(--space-md)}.dashboard-content .diagram-name{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diagram-open-btn{padding:4px var(--space-sm);background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block;white-space:nowrap}.diagram-open-btn:hover{color:var(--text-primary);border-color:var(--primary);background:var(--surface-color)}.empty-state-simple{padding:var(--space-xl) var(--space-lg);text-align:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.empty-state-text{margin:0 0 var(--space-md) 0;font-size:14px;color:var(--text-secondary)}.empty-state-cta{padding:var(--space-sm) var(--space-lg);background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.empty-state-cta:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.section-header h2{margin:0;color:var(--text-primary);font-size:24px;font-weight:600}.create-form{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--glass-border);margin-bottom:var(--space-lg)}.create-form form{display:flex;flex-direction:column;gap:var(--space-md)}.create-form input{padding:var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:16px;background:var(--surface-color);color:var(--text-primary);transition:all .3s ease}.create-form input:focus{outline:none;border-color:var(--primary);box-shadow:var(--glow-primary)}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.form-actions button{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .3s ease;border:none;min-height:40px}.form-actions button[type=submit]{background:var(--primary);color:#fff}.form-actions button[type=submit]:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.form-actions button[type=button]{background:var(--gray-200);color:var(--text-secondary);border:1px solid var(--border-color)}.form-actions button[type=button]:hover:not(:disabled){background:var(--gray-300);color:var(--text-primary)}.form-actions button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.loading-state,.error-state,.empty-state{text-align:center;padding:var(--space-3xl);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);box-shadow:none;border:1px solid var(--border-color)}.loading-state p,.error-state p{color:var(--text-secondary);font-size:16px;margin:0 0 var(--space-lg) 0}.error-state p{color:var(--error)}.empty-state .empty-icon{font-size:48px;margin-bottom:var(--space-lg)}.empty-state h3{margin:0 0 var(--space-md) 0;color:var(--text-primary);font-size:20px;font-weight:600}.empty-state p{margin:0 0 var(--space-lg) 0;color:var(--text-secondary)}.diagrams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.diagram-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.diagram-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity .4s ease}.diagram-card:hover{box-shadow:var(--shadow-lg);border-color:var(--glass-border);transform:translateY(-4px)}.diagram-card:hover:before{opacity:1}.diagram-header{margin-bottom:var(--space-md)}.diagram-header h3{margin:0 0 var(--space-xs) 0;color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.3}.diagram-type{background:var(--gradient-secondary);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:600;font-family:var(--font-mono);box-shadow:var(--shadow-sm)}.diagram-meta{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.diagram-id{color:var(--text-secondary);font-size:12px;font-family:var(--font-mono)}.diagram-date{color:var(--text-secondary);font-size:13px}.diagram-actions{display:flex;justify-content:flex-end}.version-badge{background:var(--gradient-accent);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:11px;font-weight:600;font-family:var(--font-mono);box-shadow:var(--shadow-sm)}.dashboard-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.dashboard-header h1{margin:0;color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-diagram-button{background:var(--gradient-primary);color:var(--text-primary);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:14px;display:flex;align-items:center;gap:var(--space-xs);min-height:40px;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.create-diagram-button:before{content:"+";font-size:18px;font-weight:700}.create-diagram-button:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.create-diagram-button:hover:after{left:100%}.create-diagram-button:hover{box-shadow:var(--glow-primary),var(--shadow-lg);transform:translateY(-2px)}.create-diagram-button:active{transform:translateY(0)}.dashboard-content{display:flex;padding:var(--space-xl);gap:var(--space-xl);max-width:1400px;margin:0 auto}.diagrams-list{flex:1;display:grid;gap:var(--space-sm)}.diagram-item{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.diagram-item:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--gradient-primary);transition:all .4s ease}.diagram-item:hover{box-shadow:var(--shadow-lg);border-color:var(--glass-border);transform:translateY(-2px)}.diagram-item:hover:before{width:6px;box-shadow:var(--glow-primary)}.diagram-item h3{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:20px;font-weight:600;letter-spacing:-.01em}.diagram-item p{margin:0 0 var(--space-lg) 0;color:var(--text-secondary);font-size:14px;display:flex;align-items:center;gap:var(--space-xs)}.diagram-item p:before{content:"📊";font-size:16px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}.diagram-actions{display:flex;gap:var(--space-sm)}.edit-button{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);text-decoration:none;font-size:12px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:28px;display:flex;align-items:center;font-family:var(--font-family);position:relative;overflow:hidden}.edit-button{background:var(--gradient-primary);color:var(--text-primary);border:none;box-shadow:var(--shadow-sm)}.edit-button:hover{box-shadow:var(--glow-primary),var(--shadow-md);transform:translateY(-1px)}.dashboard-sidebar{width:300px}.quota-info{background:var(--gray-100);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--glass-border);position:relative;overflow:hidden}.quota-info:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.quota-info h3{margin:0 0 var(--space-md) 0;color:var(--text-primary);font-size:18px;font-weight:600}.quota-info p{margin:0 0 var(--space-md) 0;color:var(--text-secondary);font-size:14px;display:flex;align-items:center;gap:var(--space-xs)}.quota-info p:before{font-size:16px;animation:pulse 2s infinite}.upgrade-button{background:var(--gradient-secondary);color:var(--text-primary);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;width:100%;font-weight:600;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:40px;font-family:var(--font-family);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.upgrade-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.upgrade-button:hover:before{left:100%}.upgrade-button:hover{box-shadow:var(--glow-secondary),var(--shadow-lg);transform:translateY(-2px)}.upgrade-button:active{transform:translateY(0)}.editor-page{height:100vh;display:flex;flex-direction:column;background:var(--gray-50)}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-xl);background:var(--surface-color);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;gap:var(--space-lg)}.editor-title{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.editor-title h1{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.01em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-title h1.editable-title{cursor:pointer;transition:color .2s ease;border-bottom:2px solid transparent}.editor-title h1.editable-title:hover{color:var(--primary);border-bottom-color:var(--primary)}.title-edit-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all .2s ease;font-size:14px;opacity:0;transform:scale(.8)}.editor-title:hover .title-edit-btn{opacity:1;transform:scale(1)}.title-edit-btn:hover{color:var(--primary-600);background:var(--primary-50)}.editor-meta{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.diagram-type-badge{background:var(--primary-100);color:var(--primary-700);padding:2px var(--space-xs);border-radius:var(--radius-sm);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-mono)}.diagram-id{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500;font-family:var(--font-mono)}.editor-actions{display:flex;align-items:center;flex-shrink:0}.action-button{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent;font-size:var(--text-sm);font-family:var(--font-family);display:flex;align-items:center;gap:var(--space-xs);min-height:28px}.action-button.primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.action-button.primary:hover{background:var(--primary-700);border-color:var(--primary-700);transform:translateY(-1px)}.action-button:active{transform:translateY(0)}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.delete-diagram-button{background:var(--error);color:#fff;border:1px solid var(--error);padding:var(--space-xs);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease;font-size:var(--text-xs);font-family:var(--font-family);display:flex;align-items:center;justify-content:center;min-height:28px;min-width:28px;width:28px;height:28px}.delete-diagram-button:hover{background:var(--error-dark);border-color:var(--error-dark);transform:translateY(-1px)}.delete-diagram-button:active{transform:translateY(0)}.delete-diagram-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.editor-sidebar{width:280px;background:#1e293b;border-right:1px solid #334155;display:flex;flex-direction:column;position:relative}.sidebar-section{padding:var(--space-md);border-bottom:1px solid #334155}.sidebar-icon{width:24px;height:24px;background:#8b5cf6;color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.node-properties{background:#334155;border-radius:8px;padding:var(--space-md)}.property-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm);padding:var(--space-xs) 0;border-bottom:1px solid #475569}.property-item:last-child{border-bottom:none;margin-bottom:0}.property-label{font-weight:600;color:#94a3b8;font-size:var(--text-sm)}.property-value{color:#f1f5f9;font-size:var(--text-sm);font-family:var(--font-mono)}.canvas-toolbar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:#1e293b;border-bottom:1px solid #334155}.toolbar-btn{padding:var(--space-sm);background:#334155;border:1px solid #475569;border-radius:6px;cursor:pointer;transition:all .3s ease;color:#f1f5f9;font-size:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.toolbar-btn:hover{background:#475569;color:#fff;border-color:#64748b}.zoom-info{padding:var(--space-sm) var(--space-md);background:#334155;border-radius:6px;font-size:var(--text-sm);font-weight:500;color:#f1f5f9;font-family:var(--font-mono)}.editor-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.editor-nav{display:flex;align-items:center;gap:var(--space-md)}.back-button{color:var(--text-secondary);text-decoration:none;font-weight:600;display:flex;align-items:center;gap:var(--space-xs);transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.back-button:before{content:"←";font-size:18px;font-weight:700}.back-button:hover{color:var(--primary);background:var(--glass-bg);transform:translate(-2px)}.editor-nav h1{margin:0;font-size:20px;color:var(--text-primary);font-weight:600}.diagram-id{background:var(--gradient-primary);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:600;font-family:var(--font-mono);box-shadow:var(--shadow-sm)}.editor-actions{display:flex;gap:var(--space-sm)}.save-version-button{background:var(--gradient-accent);color:var(--text-primary);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.save-version-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.save-version-button:hover:before{left:100%}.save-version-button:hover{box-shadow:var(--glow-accent),var(--shadow-lg);transform:translateY(-2px)}.save-version-button:active{transform:translateY(0)}.editor-content{flex:1;display:flex}.editor-sidebar{width:300px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.palette,.inspector{padding:var(--space-xl);border-bottom:1px solid var(--glass-border)}.palette h3,.inspector h3{margin:0 0 var(--space-md) 0;color:var(--text-primary);font-size:16px;font-weight:600;display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-family)}.inspector h3:before{content:"⚙️";font-size:18px}.palette-item{display:block;width:100%;margin-bottom:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:var(--font-family);font-size:13px;color:var(--text-secondary)}.palette-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(59,130,246,.1),transparent);transition:left .3s ease}.palette-item:hover:before{left:100%}.palette-item:hover{background:var(--gradient-primary);color:var(--text-primary);border-color:var(--primary);transform:translate(6px);box-shadow:var(--glow-primary)}.editor-canvas{flex:1;background:var(--gray-200);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.editor-canvas:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,92,246,.08) 0%,transparent 50%),radial-gradient(circle at 40% 60%,rgba(16,185,129,.08) 0%,transparent 50%);pointer-events:none;animation:backgroundShift 15s ease-in-out infinite}.canvas-placeholder{text-align:center;color:var(--text-secondary);background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);padding:var(--space-3xl);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);border:2px dashed var(--glass-border);max-width:450px;transition:all .4s cubic-bezier(.4,0,.2,1)}.canvas-placeholder:hover{border-color:var(--primary);box-shadow:var(--glow-primary),var(--shadow-lg);transform:translateY(-4px)}.canvas-placeholder h2{margin-bottom:var(--space-lg);color:var(--text-primary);font-size:20px;font-weight:600;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.canvas-placeholder p{margin-bottom:var(--space-sm);font-size:14px}.canvas-placeholder p:last-child{font-family:var(--font-mono);color:var(--primary);font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-sm);transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}::-webkit-scrollbar-corner{background:var(--gray-100)}*{scrollbar-width:thin;scrollbar-color:var(--gray-300) var(--gray-100)}.create-diagram-form{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--gray-600);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--glass-shadow);width:100%;box-sizing:border-box;overflow:hidden}.diagram-title-input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--primary-50);color:var(--text-primary);font-size:14px;margin-bottom:var(--space-md);transition:all .2s ease;box-sizing:border-box}.diagram-title-input:focus{outline:none;border-color:var(--primary-500);background:var(--primary-100);box-shadow:0 0 0 3px var(--primary-200)}.create-diagram-form .form-actions{display:flex;gap:var(--space-sm);justify-content:space-between;width:100%;box-sizing:border-box}.cancel-btn,.create-btn{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);font-size:13px;flex:1;min-width:0;font-weight:500;cursor:pointer;transition:all .3s ease}.cancel-btn{background:var(--gray-100);color:var(--text-primary);border:1px solid var(--gray-300)}.cancel-btn:hover:not(:disabled){background:var(--gray-200);color:var(--text-primary);border-color:var(--gray-400)}.create-btn{background:var(--primary);color:#fff}.create-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.create-btn:disabled,.cancel-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.diagrams-list{padding:var(--space-xs) 0}.loading-state,.empty-state{text-align:center;padding:var(--space-lg);color:var(--text-secondary)}.empty-state .empty-hint{font-size:12px;margin-top:var(--space-sm);opacity:.7}.diagram-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:all .2s ease;text-decoration:none;color:var(--text-primary);margin-bottom:var(--space-xs);background:transparent;border:none}.diagram-item:hover{background:var(--bg-secondary);transform:translate(2px)}.diagram-item.active{background:var(--bg-tertiary);color:var(--text-primary);font-weight:500;position:relative}.diagram-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--primary)}.diagram-info{display:flex;flex-direction:column;flex:1;min-width:0;padding-right:var(--space-sm)}.diagram-name{font-weight:400;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary);line-height:1.3}.diagram-actions{margin-left:var(--space-sm)}.menu-button{background:none;border:none;color:inherit;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);font-size:16px;opacity:.3;transition:all .2s ease;min-width:24px;min-height:24px;display:flex;align-items:center;justify-content:center}.menu-button:hover{opacity:.6;background:#ffffff1a}.welcome-section{margin-bottom:0}.welcome-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-2xl);box-shadow:var(--glass-shadow);position:relative;overflow:hidden}.welcome-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:.8}.card-header{margin-bottom:var(--space-xl)}.card-header h2{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:28px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card-header p{margin:0;color:var(--text-secondary);font-size:16px;line-height:1.5}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg);margin-top:var(--space-xl)}.action-item{background:var(--surface-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-xl);border-radius:var(--radius-xl);border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:var(--space-lg)}.action-item:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:opacity .4s ease}.action-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.action-item:hover:before{opacity:1}.action-icon{font-size:32px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-50);border-radius:var(--radius-lg);border:1px solid var(--primary-200)}.action-content h3{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.3}.action-content p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5}.features-section{margin-top:var(--space-2xl)}.features-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-2xl);box-shadow:var(--glass-shadow);position:relative;overflow:hidden}.features-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-secondary);opacity:.8}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg);margin-top:var(--space-xl)}.feature-item{background:var(--surface-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--glass-border);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;align-items:flex-start;gap:var(--space-md)}.feature-item:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-secondary);opacity:0;transition:opacity .4s ease}.feature-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--secondary)}.feature-item:hover:before{opacity:1}.feature-icon{font-size:24px;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--secondary-50);border-radius:var(--radius-md);border:1px solid var(--secondary-200)}.feature-content h3{margin:0 0 var(--space-xs) 0;color:var(--text-primary);font-size:16px;font-weight:600;line-height:1.3}.feature-content p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.4}.mcp-guide-section{margin-top:var(--space-2xl)}.mcp-guide-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-2xl);box-shadow:var(--glass-shadow);position:relative;overflow:hidden}.mcp-guide-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);opacity:.8}.mcp-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-xl);margin-top:var(--space-xl)}.mcp-step{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border);transition:all .3s ease}.mcp-step:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}.step-number{width:40px;height:40px;background:var(--gradient-accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;box-shadow:var(--shadow-sm)}.step-content h3{margin:0 0 var(--space-sm) 0;color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.3}.step-content p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5}.mcp-note{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--accent-50);border-radius:var(--radius-lg);border-left:4px solid var(--accent)}.mcp-note p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.6}.mcp-note strong{color:var(--text-primary)}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}.skeleton-title{height:28px;width:200px}.skeleton-button{height:36px;width:80px}.skeleton-section-title{height:20px;width:100px;margin-bottom:12px}.skeleton-tool{height:60px;width:100%;margin-bottom:8px}.skeleton-property{height:40px;width:100%}.skeleton-zoom{height:20px;width:50px}.skeleton-canvas{height:100%;width:100%;min-height:400px}.editor-page{opacity:1;transition:opacity .3s ease-in-out}.editor-page.loading{opacity:.8}.editor-content{transition:all .3s ease-in-out}.palette{background:transparent;border:none;padding:0;box-shadow:none}.palette-title{display:none}.palette-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xs)}.palette-button{display:flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-height:36px;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.palette-button:hover{border-color:var(--primary);background:var(--surface-color-hover);transform:translateY(-1px)}.palette-button:focus,.palette-button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.palette-button:active{transform:translateY(0)}.palette-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.palette-button:disabled:hover{border-color:var(--border-color);background:var(--surface-color);transform:none}.palette-label{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);text-align:center;line-height:1.2}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);margin:var(--space-sm) 0}.error-message p{color:var(--error);font-size:var(--text-sm);margin:0;font-weight:500}.properties-panel{background:transparent;border:none;padding:0;min-height:auto}.node-properties{display:flex;flex-direction:column;gap:var(--space-sm)}.node-header{display:flex;flex-direction:column;gap:2px;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.node-header h4{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin:0;line-height:1.2}.node-type{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.properties-list{display:flex;flex-direction:column;gap:var(--space-xs)}.property-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0;border-bottom:1px solid var(--border-color)}.property-item:last-child{border-bottom:none}.property-label{font-size:var(--text-xs);font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.property-value{font-size:var(--text-xs);color:var(--text-primary);font-family:var(--font-mono);font-weight:500}.property-id{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-new{color:var(--blue-600);background:var(--blue-50);padding:2px var(--space-xs);border-radius:var(--radius-sm)}.status-implemented{color:var(--green-600);background:var(--green-50);padding:2px var(--space-xs);border-radius:var(--radius-sm)}.status-out_of_sync{color:var(--orange-600);background:var(--orange-50);padding:2px var(--space-xs);border-radius:var(--radius-sm)}.status-removed-from-code{color:var(--red-600);background:var(--red-50);padding:2px var(--space-xs);border-radius:var(--radius-sm)}.empty-properties{display:flex;align-items:center;justify-content:center;padding:var(--space-lg);text-align:center;min-height:80px}.empty-properties p{font-size:var(--text-xs);color:var(--text-tertiary);margin:0;line-height:1.4}.node-inspector{padding:var(--space-md);background:var(--gray-100);border-radius:var(--radius-md);min-height:200px;max-height:80vh;overflow-y:auto}.node-inspector.empty{display:flex;align-items:center;justify-content:center}.node-inspector .empty-properties{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);font-style:italic}.node-properties{display:flex;flex-direction:column;gap:var(--space-md)}.node-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.node-header h4{margin:0;color:var(--text-primary);font-size:var(--text-lg);font-weight:600}.node-type{background:var(--primary);color:#fff;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase}.properties-list{display:flex;flex-direction:column;gap:var(--space-sm)}.property-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0}.property-label{font-weight:500;color:var(--text-secondary);font-size:var(--text-sm)}.property-value{font-weight:600;color:var(--text-primary);font-size:var(--text-sm);font-family:var(--font-mono)}.property-value.status-new{color:var(--accent-blue)}.property-value.status-implemented{color:var(--accent-green)}.property-value.status-out_of_sync{color:var(--accent-yellow)}.property-value.status-removed-from-code{color:var(--accent-red)}.property-id{font-size:var(--text-xs);background:var(--gray-200);padding:2px 6px;border-radius:4px}.editable-properties{display:flex;flex-direction:column;gap:var(--space-lg)}.property-section{display:flex;flex-direction:column;gap:var(--space-sm)}.property-section h5{margin:0;color:var(--text-primary);font-size:var(--text-md);font-weight:600;display:flex;align-items:center;gap:var(--space-xs)}.section-header{display:flex;align-items:center;justify-content:space-between}.add-btn{background:var(--primary);color:#fff;border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all .2s ease}.add-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.editable-field-display{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-sm);cursor:pointer;transition:all .2s ease;min-height:20px;display:flex;align-items:center}.editable-field-display:hover{border-color:var(--primary);background:var(--primary-50)}.editable-field-input{background:var(--surface-color);border:2px solid var(--primary);border-radius:var(--radius-sm);padding:var(--space-sm);font-size:var(--text-sm);font-family:var(--font-family);color:var(--text-primary);width:100%;outline:none;transition:all .2s ease}.editable-field-input:focus{box-shadow:0 0 0 3px #5843df1a}.node-name-input{font-weight:600;font-size:var(--text-md)}.node-group-input{font-family:var(--font-mono);font-size:var(--text-sm)}.fields-list,.methods-list{display:flex;flex-direction:column;gap:var(--space-sm)}.field-editor,.method-editor{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:all .2s ease}.field-editor:hover,.method-editor:hover{border-color:var(--primary);box-shadow:0 2px 8px #5843df1a}.field-header,.method-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);cursor:pointer;background:var(--gray-50);border-bottom:1px solid var(--border-color);transition:background .2s ease}.field-header:hover,.method-header:hover{background:var(--primary-50)}.field-visibility,.method-visibility{background:var(--primary);color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;font-family:monospace}.field-name,.method-name{font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.field-type,.method-returns{color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-sm)}.field-delete-btn,.method-delete-btn{background:var(--accent-red);color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:var(--text-sm);font-weight:700;margin-left:auto;transition:all .2s ease}.field-delete-btn:hover,.method-delete-btn:hover{background:var(--accent-red-dark);transform:scale(1.1)}.field-details,.method-details{padding:var(--space-md);background:var(--surface-color);display:flex;flex-direction:column;gap:var(--space-sm)}.field-input-group,.method-input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.field-input-group label,.method-input-group label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.field-input,.method-input{font-size:var(--text-sm);padding:var(--space-xs) var(--space-sm)}.field-select,.method-select{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.field-select:focus,.method-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #5843df1a}.field-input-group input[type=checkbox],.method-input-group input[type=checkbox]{margin-right:var(--space-xs);cursor:pointer}.empty-list{text-align:center;color:var(--text-disabled);font-size:var(--text-sm);font-style:italic;padding:var(--space-lg);background:var(--gray-50);border-radius:var(--radius-sm);border:1px dashed var(--border-color)}.error-message{background:var(--accent-red-light);border:1px solid var(--accent-red);border-radius:var(--radius-sm);padding:var(--space-sm);margin-bottom:var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.error-message p{margin:0;color:var(--accent-red-dark);font-size:var(--text-sm);font-weight:500}.error-dismiss{background:none;border:none;color:var(--accent-red-dark);font-size:var(--text-lg);font-weight:700;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.error-dismiss:hover{background:var(--accent-red);color:#fff}.landing-page{min-height:100vh;background:var(--gray-50);color:var(--text-primary);font-family:var(--font-family);position:relative;scroll-behavior:smooth;display:flex;flex-direction:column}.landing-header{position:sticky;top:0;z-index:1000;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:var(--space-md) 0;transition:all .3s cubic-bezier(.16,1,.3,1);transform:translateY(0)}.landing-header.scrolled{padding:var(--space-sm) 0;box-shadow:var(--shadow-md);border-bottom-color:var(--primary);opacity:.98}.landing-header-container{max-width:1200px;margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between}.landing-header-logo{display:flex;align-items:center}.landing-header-logo img{height:40px;width:auto;transition:transform .3s ease}.landing-header-logo:hover img{transform:scale(1.05)}.landing-header-nav{display:flex;align-items:center;gap:var(--space-md)}.landing-header-cta{padding:var(--space-xs) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);font-family:var(--font-family);border:1px solid transparent;min-width:80px}.landing-header-cta-primary{background:var(--gradient-primary);color:#fff;border:none;box-shadow:var(--glow-primary),var(--shadow-sm)}.landing-header-cta-primary:hover{box-shadow:var(--glow-primary),var(--shadow-md);transform:translateY(-1px)}.landing-header-cta-primary:active{transform:translateY(0)}.landing-header-cta-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.landing-header-cta-secondary:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.landing-header-cta-secondary:active{transform:translateY(0)}.landing-container{max-width:800px;margin:0 auto;padding:var(--space-xl) var(--space-lg)}.landing-hero{padding:var(--space-3xl) var(--space-lg);text-align:center;min-height:70vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,rgba(88,67,223,.1) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(66,140,254,.1) 0%,transparent 50%);animation:heroGlow 20s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes heroGlow{0%,to{transform:translate(0) scale(1);opacity:.5}50%{transform:translate(-10%,-10%) scale(1.1);opacity:.8}}.landing-hero-content{position:relative;z-index:1;animation:fadeInUpHero 1s cubic-bezier(.16,1,.3,1)}@keyframes fadeInUpHero{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-hero-headline{font-size:56px;font-weight:700;line-height:1.1;margin:0 0 var(--space-lg) 0;letter-spacing:-.03em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:fadeInUp .8s ease-out .2s both}.landing-hero-subheadline{font-size:var(--text-xl);color:var(--text-secondary);line-height:1.7;margin:0 0 var(--space-2xl) 0;max-width:650px;margin-left:auto;margin-right:auto;animation:fadeInUp .8s ease-out .4s both}.landing-hero-ctas{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;animation:fadeInUp .8s ease-out .6s both}.landing-cta-primary{background:var(--gradient-primary);color:#fff;border:none;padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-md);font-size:var(--text-lg);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);box-shadow:var(--glow-primary),var(--shadow-md);min-width:140px}.landing-cta-primary:hover{box-shadow:var(--glow-primary),var(--shadow-lg);transform:translateY(-2px)}.landing-cta-primary:active{transform:translateY(0)}.landing-cta-secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border-color);padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-md);font-size:var(--text-lg);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:var(--font-family);min-width:140px}.landing-cta-secondary:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}.landing-cta-secondary:active{transform:translateY(0)}.landing-divider{max-width:800px;margin:0 auto;padding:0 var(--space-lg);height:1px;background:linear-gradient(90deg,transparent,var(--border-color) 20%,var(--border-color) 80%,transparent);position:relative;overflow:visible;will-change:opacity,transform;backface-visibility:hidden;transform-origin:center}.landing-divider-hidden{opacity:0;transform:scale3d(0,1,1);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.landing-divider-visible{opacity:1;transform:scaleZ(1);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.landing-divider:before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:4px;height:4px;background:var(--primary);border-radius:50%;box-shadow:0 0 8px var(--primary);transition:all .6s ease-out}.landing-divider-visible:before{animation:dividerPulse 2s ease-in-out infinite .5s}@keyframes dividerPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.5)}}@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}.landing-section{padding:var(--space-3xl) var(--space-lg);max-width:800px;margin:0 auto;will-change:opacity,transform;backface-visibility:hidden;-webkit-font-smoothing:antialiased}.landing-section-hidden{opacity:0;transform:translate3d(0,30px,0);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.landing-section-visible{opacity:1;transform:translateZ(0);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.landing-section-highlight{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid var(--glass-border);margin:var(--space-2xl) auto;padding:var(--space-3xl) var(--space-lg)}.landing-section-title{font-size:var(--text-3xl);font-weight:600;margin:0 0 var(--space-lg) 0;color:var(--text-primary);letter-spacing:-.01em;position:relative;display:inline-block;will-change:opacity,transform;backface-visibility:hidden}.landing-section-hidden .landing-section-title{opacity:0;transform:translate3d(-20px,0,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .2s,transform .6s cubic-bezier(.16,1,.3,1) .2s}.landing-section-visible .landing-section-title{opacity:1;transform:translateZ(0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .2s,transform .6s cubic-bezier(.16,1,.3,1) .2s}.landing-section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:0;height:3px;background:var(--gradient-primary);border-radius:2px;will-change:width;backface-visibility:hidden}.landing-section-hidden .landing-section-title:after{width:0;transition:width .8s cubic-bezier(.16,1,.3,1) .5s}.landing-section-visible .landing-section-title:after{width:60px;transition:width .8s cubic-bezier(.16,1,.3,1) .5s}.landing-section-text{font-size:var(--text-lg);line-height:1.7;color:var(--text-secondary);margin:0 0 var(--space-md) 0;will-change:opacity,transform;backface-visibility:hidden}.landing-section-hidden .landing-section-text{opacity:0;transform:translate3d(0,20px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .3s,transform .6s cubic-bezier(.16,1,.3,1) .3s}.landing-section-visible .landing-section-text{opacity:1;transform:translateZ(0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .3s,transform .6s cubic-bezier(.16,1,.3,1) .3s}.landing-section-text:last-child{margin-bottom:0}.landing-section-text strong{color:var(--text-primary);font-weight:600}.landing-problem-list,.landing-features-list{list-style:none;padding:0;margin:0}.landing-problem-list li,.landing-features-list li{font-size:var(--text-lg);line-height:1.7;color:var(--text-secondary);padding:var(--space-md) 0;padding-left:var(--space-xl);position:relative;border-bottom:1px solid var(--border-color);will-change:opacity,transform;backface-visibility:hidden}.landing-section-hidden .landing-problem-list li,.landing-section-hidden .landing-features-list li{opacity:0;transform:translate3d(-20px,0,0);transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1)}.landing-section-visible .landing-problem-list li,.landing-section-visible .landing-features-list li{opacity:1;transform:translateZ(0);transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1)}.landing-section-visible .landing-problem-list li:nth-child(1),.landing-section-visible .landing-features-list li:nth-child(1){transition-delay:.1s}.landing-section-visible .landing-problem-list li:nth-child(2),.landing-section-visible .landing-features-list li:nth-child(2){transition-delay:.2s}.landing-section-visible .landing-problem-list li:nth-child(3),.landing-section-visible .landing-features-list li:nth-child(3){transition-delay:.3s}.landing-section-visible .landing-problem-list li:nth-child(4),.landing-section-visible .landing-features-list li:nth-child(4){transition-delay:.4s}.landing-problem-list li:hover,.landing-features-list li:hover{padding-left:var(--space-2xl);color:var(--text-primary)}.landing-problem-list li:last-child,.landing-features-list li:last-child{border-bottom:none}.landing-problem-list li:before{content:"•";position:absolute;left:0;color:var(--primary);font-size:24px;line-height:1;transition:all .3s ease}.landing-problem-list li:hover:before{transform:scale(1.3);color:var(--primary-light)}.landing-features-list li:before{content:"✓";position:absolute;left:0;color:var(--accent-green);font-size:20px;line-height:1;font-weight:600;transition:all .3s ease}.landing-features-list li:hover:before{transform:scale(1.2) rotate(5deg)}.landing-cta-section{text-align:center;padding:var(--space-3xl) var(--space-lg);margin:var(--space-3xl) auto 0 auto;position:relative;overflow:hidden;max-width:900px}.landing-cta-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-radius:var(--radius-2xl);border:1px solid var(--glass-border);padding:var(--space-3xl) var(--space-2xl);position:relative;box-shadow:var(--shadow-lg);overflow:hidden}.landing-cta-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);opacity:1;z-index:1}.landing-cta-content:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,rgba(88,67,223,.08) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(66,140,254,.08) 0%,transparent 50%);animation:ctaGlow 12s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes ctaGlow{0%,to{transform:translate(0) scale(1);opacity:.6}50%{transform:translate(-5%,-5%) scale(1.1);opacity:1}}.landing-cta-content>*{position:relative;z-index:1}.landing-cta-title{font-size:42px;font-weight:700;margin:0 0 var(--space-md) 0;color:var(--text-primary);letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.landing-cta-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0 0 var(--space-2xl) 0;line-height:1.6;max-width:500px;margin-left:auto;margin-right:auto;will-change:opacity,transform;backface-visibility:hidden}.landing-section-hidden .landing-cta-subtitle{opacity:0;transform:translate3d(0,10px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .4s,transform .6s cubic-bezier(.16,1,.3,1) .4s}.landing-section-visible .landing-cta-subtitle{opacity:1;transform:translateZ(0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .4s,transform .6s cubic-bezier(.16,1,.3,1) .4s}.landing-section-hidden .landing-cta-title{opacity:0;transform:translate3d(0,20px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .2s,transform .6s cubic-bezier(.16,1,.3,1) .2s}.landing-section-visible .landing-cta-title{opacity:1;transform:translateZ(0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .2s,transform .6s cubic-bezier(.16,1,.3,1) .2s}.landing-section-hidden .landing-hero-ctas{opacity:0;transform:translate3d(0,20px,0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .6s,transform .6s cubic-bezier(.16,1,.3,1) .6s}.landing-section-visible .landing-hero-ctas{opacity:1;transform:translateZ(0);transition:opacity .6s cubic-bezier(.16,1,.3,1) .6s,transform .6s cubic-bezier(.16,1,.3,1) .6s}.landing-footer{margin-top:auto;padding:var(--space-3xl) var(--space-lg) var(--space-2xl) var(--space-lg);border-top:1px solid var(--border-color);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.landing-footer-content{max-width:800px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.landing-footer-logo{display:flex;justify-content:center;margin-bottom:var(--space-xs)}.landing-footer-logo img{height:32px;width:auto;opacity:.8;transition:opacity .3s ease}.landing-footer-logo:hover img{opacity:1}.landing-footer-text{font-size:var(--text-sm);color:var(--text-secondary);margin:0;font-weight:500}.landing-footer-copyright{font-size:var(--text-xs);color:var(--text-tertiary);margin:0}@media (max-width: 768px){.landing-hero-headline{font-size:40px}.landing-header-container{padding:0 var(--space-md)}.landing-header-logo img{height:32px}.landing-header-nav{gap:var(--space-sm)}.landing-header-cta{padding:var(--space-xs) var(--space-md);font-size:var(--text-xs);min-width:70px}.landing-hero-subheadline{font-size:var(--text-lg)}.landing-section-title{font-size:var(--text-2xl)}.landing-section-text{font-size:var(--text-md)}.landing-problem-list li,.landing-features-list li{font-size:var(--text-md);padding-left:var(--space-lg)}.landing-hero-ctas{flex-direction:column;align-items:stretch}.landing-cta-primary,.landing-cta-secondary{width:100%}.landing-cta-title{font-size:32px}.landing-cta-content{padding:var(--space-2xl) var(--space-lg)}.landing-cta-section{margin-bottom:var(--space-2xl)}.landing-container{padding:var(--space-lg) var(--space-md)}.landing-section{padding:var(--space-2xl) var(--space-md)}}:root{--primary: #5843df;--primary-dark: #4c3bc7;--primary-light: #6d62fe;--secondary: #428cfe;--secondary-dark: #3b7de8;--accent: #8472f6;--accent-dark: #6d62fe;--accent-light: #9d8ff8;--accent-yellow: #f59e0b;--accent-orange: #f97316;--accent-blue: #428cfe;--accent-green: #10b981;--accent-red: #ef4444;--accent-red-light: rgba(239, 68, 68, .1);--accent-red-dark: #dc2626;--gray-50: #0a0a0f;--gray-100: #1a1a2e;--gray-200: #16213e;--gray-300: #0f3460;--gray-400: #533483;--gray-500: #6b7280;--gray-600: #9ca3af;--gray-700: #d1d5db;--gray-800: #e5e7eb;--gray-900: #f9fafb;--success: #428cfe;--success-dark: #2563eb;--warning: #f59e0b;--warning-dark: #d97706;--error: #ef4444;--error-dark: #dc2626;--info: #5843df;--info-dark: #4338ca;--font-family: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", "Monaco", "Consolas", monospace;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--shadow-xs: 0 2px 4px rgba(0, 0, 0, .1);--shadow-sm: 0 4px 8px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 8px 16px rgba(0, 0, 0, .15), 0 4px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 16px 32px rgba(0, 0, 0, .18), 0 8px 16px rgba(0, 0, 0, .12);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .2), 0 12px 24px rgba(0, 0, 0, .15);--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3);--border-color: rgba(255, 255, 255, .08);--border-color-hover: rgba(255, 255, 255, .15);--surface-color: rgba(26, 26, 46, .6);--surface-color-hover: rgba(26, 26, 46, .8);--text-primary: #ffffff;--text-secondary: #a0aec0;--text-disabled: #718096;--code-bg: #0a0a0f;--code-fg: #ffffff;--code-comment: #718096;--code-string: #f59e0b;--code-keyword: #428cfe;--code-function: #5843df;--code-number: #8472f6;--code-operator: #65bcfe;--text-tertiary: #64748b;--bg-secondary: rgba(26, 26, 46, .4);--bg-tertiary: rgba(26, 26, 46, .6);--editor-sidebar-width: 280px;--editor-header-height: 80px;--control-bg: rgba(71, 85, 105, .4);--control-bg-hover: rgba(71, 85, 105, .3);--control-border: rgba(100, 116, 139, .3);--zoom-feedback-bg: rgba(88, 67, 223, .2);--gradient-primary: linear-gradient(135deg, #4c3bc7 0%, #5843df 25%, #6d62fe 50%, #8472f6 75%, #6d62fe 100%);--gradient-secondary: linear-gradient(135deg, #65bcfe 0%, #428cfe 25%, #3b7de8 50%, #2d5aa0 75%, #1e3a8a 100%);--gradient-accent: linear-gradient(135deg, #9d8ff8 0%, #8472f6 25%, #6d62fe 50%, #5b4bc7 75%, #4a3bb6 100%);--gradient-yellow: linear-gradient(135deg, #fef3c7 0%, #fde68a 25%, #f59e0b 50%, #d97706 75%, #b45309 100%);--gradient-bg: linear-gradient(135deg, #0a0a0f 0%, #1a1a2e 20%, #4c3bc7 40%, #5843df 60%, #6d62fe 80%, #8472f6 100%);--gradient-glass: linear-gradient(135deg, rgba(255, 255, 255, .05) 0%, rgba(255, 255, 255, .02) 100%);--glow-primary: 0 0 20px rgba(88, 67, 223, .2);--glow-secondary: 0 0 20px rgba(66, 140, 254, .2);--glow-accent: 0 0 20px rgba(132, 114, 246, .2);--glow-yellow: 0 0 20px rgba(245, 158, 11, .3);--glow-white: 0 0 15px rgba(255, 255, 255, .05);font-family:var(--font-family);line-height:1.6;font-weight:400;color:var(--text-primary);background:var(--gradient-bg);background-attachment:fixed;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-feature-settings:"liga" 1,"calt" 1,"ss01" 1,"ss02" 1,"ss03" 1}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 20%,rgba(88,67,223,.05) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(66,140,254,.05) 0%,transparent 50%),radial-gradient(circle at 40% 60%,rgba(132,114,246,.05) 0%,transparent 50%);pointer-events:none;z-index:-1;animation:backgroundShift 20s ease-in-out infinite}@keyframes backgroundShift{0%,to{transform:translate(0) scale(1)}25%{transform:translate(-10px,-10px) scale(1.05)}50%{transform:translate(10px,-5px) scale(.95)}75%{transform:translate(-5px,10px) scale(1.02)}}a{font-weight:500;color:var(--primary);text-decoration:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}a:hover{color:var(--primary-light);transform:translateY(-1px)}a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--gradient-primary);transition:width .3s cubic-bezier(.4,0,.2,1)}a:hover:after{width:100%}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:32px;font-weight:700;line-height:1.2;color:var(--text-primary);margin:0;letter-spacing:-.02em;font-family:var(--font-family);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:24px;font-weight:600;line-height:1.3;color:var(--text-primary);margin:0;letter-spacing:-.01em;font-family:var(--font-family)}h3{font-size:20px;font-weight:600;line-height:1.4;color:var(--text-primary);margin:0;letter-spacing:-.01em;font-family:var(--font-family)}h4{font-size:18px;font-weight:600;line-height:1.5;color:var(--text-primary);margin:0;font-family:var(--font-family)}h5{font-size:16px;font-weight:600;line-height:1.4;color:var(--text-primary);margin:0;text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-family)}.code-text{font-family:var(--font-mono);font-size:14px;color:var(--code-fg);background:var(--code-bg);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-xs);border:1px solid var(--border-color);box-shadow:var(--shadow-xs);transition:all .3s ease}.code-text:hover{box-shadow:var(--shadow-sm);border-color:var(--primary)}.code-block{font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--code-fg);background:var(--code-bg);padding:var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border-color);overflow-x:auto;box-shadow:var(--shadow-sm);transition:all .3s ease}.code-block:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}button{border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:var(--space-sm) var(--space-md);font-size:14px;font-weight:500;font-family:var(--font-family);background:var(--surface-color);color:var(--text-primary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);min-height:36px;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);transition:left .5s ease}button:hover:before{left:100%}button:hover{border-color:var(--primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}button:focus,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px;box-shadow:var(--glow-primary)}button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}button.primary{background:var(--gradient-primary);color:#fff;border:none;box-shadow:var(--glow-primary)}button.secondary{background:var(--gradient-secondary);color:#fff;border:none;box-shadow:var(--glow-secondary)}button.accent{background:var(--gradient-accent);color:#fff;border:none;box-shadow:var(--glow-accent)}button.warning{background:var(--gradient-yellow);color:var(--gray-900);border:none;box-shadow:var(--glow-yellow);font-weight:600}button.outline{background:transparent;color:var(--primary);border:2px solid var(--primary);box-shadow:none}button.ghost{background:transparent;color:var(--gray-400);border:none;box-shadow:none}button.small{padding:.5rem 1rem;font-size:.875rem}button.large{padding:1rem 2rem;font-size:1.125rem}button.code{background:var(--code-bg);color:var(--code-string);border:1px solid var(--gray-700);font-family:var(--font-mono);box-shadow:none}button.code:hover{background:var(--surface-color-hover);border-color:var(--primary);color:var(--primary);box-shadow:var(--glow-primary)}button.static{background:transparent!important;background-color:transparent!important;background-image:none!important;border:none!important;border-radius:4px!important;box-shadow:none!important;transform:none!important;transition:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;font-family:var(--font-family)!important;font-size:12px!important;font-weight:400!important;color:var(--text-secondary)!important;cursor:pointer!important;padding:2px 4px!important;display:inline-block!important;align-items:unset!important;justify-content:unset!important;gap:unset!important;min-height:unset!important;position:static!important;overflow:visible!important}button.static:hover,button.static:focus,button.static:active{background:transparent!important;background-color:transparent!important;background-image:none!important;border:none!important;border-radius:4px!important;box-shadow:none!important;transform:none!important;transition:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;font-family:var(--font-family)!important;font-size:12px!important;font-weight:400!important;color:var(--text-secondary)!important;cursor:pointer!important;padding:2px 4px!important;display:inline-block!important;align-items:unset!important;justify-content:unset!important;gap:unset!important;min-height:unset!important;position:static!important;overflow:visible!important;outline:none!important}button.static:before{display:none!important}.editor-page{display:flex;flex-direction:column;height:100vh;background:var(--gray-50);color:var(--text-primary);font-family:var(--font-family)}.editor-page.loading{background:var(--gray-50)}.editor-content{flex:1;display:flex;overflow:hidden}.editor-canvas{flex:1;display:flex;flex-direction:column;overflow:hidden}.canvas-area{flex:1;position:relative;overflow:hidden}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-300) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-spinner{display:inline-flex;flex-direction:column;align-items:center;gap:.5rem}.loading-spinner__circle{position:relative;border-radius:50%;border:2px solid transparent;animation:spin 1s linear infinite}.loading-spinner--sm .loading-spinner__circle{width:16px;height:16px;border-top-color:var(--primary)}.loading-spinner--md .loading-spinner__circle{width:24px;height:24px;border-top-color:var(--primary)}.loading-spinner--lg .loading-spinner__circle{width:32px;height:32px;border-top-color:var(--primary)}.loading-spinner--primary .loading-spinner__circle{border-top-color:var(--primary)}.loading-spinner--secondary .loading-spinner__circle{border-top-color:var(--text-secondary)}.loading-spinner--white .loading-spinner__circle{border-top-color:#fff}.loading-spinner__text{font-size:.875rem;color:var(--text-secondary)}.loading-state{display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.loading-state--fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--background-color);z-index:1000}.loading-state--overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100}.loading-state__content{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-state__message{margin:0;font-size:1rem;color:var(--text-primary)}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.toast{border:1px solid;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:all;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:300px;max-width:400px}.toast__content{display:flex;align-items:flex-start;gap:12px;padding:16px}.toast__icon{font-size:18px;line-height:1;flex-shrink:0;margin-top:2px}.toast__text{flex:1;min-width:0}.toast__title{font-weight:600;font-size:var(--text-sm);line-height:1.4;margin:0 0 4px}.toast__message{font-size:var(--text-xs);line-height:1.4;margin:0;opacity:.9}.toast__action{background:transparent;border:1px solid currentColor;color:inherit;padding:4px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-left:8px}.toast__action:hover{background:currentColor;color:#fff}.toast__close{background:transparent;border:none;color:inherit;font-size:18px;line-height:1;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease;flex-shrink:0;margin-left:8px;opacity:.7}.toast__close:hover{opacity:1;background:#0000001a}.toast[style*=success]{--success-bg: #f0f9ff;--success-border: #22c55e;--success-text: #15803d}.toast[style*=error]{--error-bg: #fef2f2;--error-border: #ef4444;--error-text: #dc2626}.toast[style*=warning]{--warning-bg: #fffbeb;--warning-border: #f59e0b;--warning-text: #d97706}.toast[style*=info]{--info-bg: #f8fafc;--info-border: #64748b;--info-text: #475569}@media (prefers-color-scheme: dark){.toast[style*=success]{--success-bg: #064e3b;--success-border: #10b981;--success-text: #6ee7b7}.toast[style*=error]{--error-bg: #7f1d1d;--error-border: #f87171;--error-text: #fca5a5}.toast[style*=warning]{--warning-bg: #78350f;--warning-border: #fbbf24;--warning-text: #fcd34d}.toast[style*=info]{--info-bg: #1e293b;--info-border: #94a3b8;--info-text: #cbd5e1}}.confirmation-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.confirmation-modal{background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:450px;min-width:320px;width:100%;max-height:90vh;overflow:hidden;border:1px solid var(--border-color);animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirmation-modal__header{display:flex;align-items:center;gap:12px;padding:20px 20px 0}.confirmation-modal__icon{font-size:24px;flex-shrink:0}.confirmation-modal__title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.confirmation-modal__body{padding:16px 20px}.confirmation-modal__message{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin:0}.confirmation-modal__footer{display:flex;gap:12px;padding:16px 20px 20px;justify-content:flex-end;flex-wrap:wrap}.confirmation-modal__button{padding:10px 20px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent;min-width:90px;font-family:var(--font-family);white-space:nowrap;flex-shrink:0}.confirmation-modal__button--cancel{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.confirmation-modal__button--cancel:hover{background:var(--hover-color);color:var(--text-primary);border-color:var(--border-color)}.confirmation-modal__button--confirm{color:#fff;border:1px solid}.confirmation-modal__button--confirm:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.confirmation-modal__button--confirm:active{transform:translateY(0)}@media (max-width: 480px){.confirmation-modal{max-width:calc(100vw - 40px);min-width:280px}.confirmation-modal__footer{flex-direction:column;gap:8px}.confirmation-modal__button{width:100%;justify-content:center}}.error-state{display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-primary)}.error-state__content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px}.error-state__icon{font-size:2rem}.error-state__title{margin:0;font-size:1.25rem;font-weight:600;color:var(--accent-red)}.error-state__message{margin:0;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.error-state__details{width:100%;text-align:left;margin-top:.5rem}.error-state__details summary{cursor:pointer;font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.error-state__error{background:var(--surface-color);border:1px solid var(--border-color);border-radius:4px;padding:.5rem;font-size:.75rem;color:var(--accent-red);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.error-state__actions{display:flex;gap:.5rem;margin-top:.5rem}.error-state__retry,.error-state__reload{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;background:var(--surface-color);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.error-state__retry:hover,.error-state__reload:hover{background:var(--control-bg-hover);border-color:var(--primary)}.error-state__reload{background:var(--primary);color:#fff;border-color:var(--primary)}.error-state__reload:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.empty-state{display:flex;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.empty-state__content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:300px}.empty-state__icon{font-size:3rem;opacity:.6}.empty-state__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.empty-state__message{margin:0;font-size:.9rem;line-height:1.5}.empty-state__action{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.empty-state__action:hover{background:var(--primary-hover);transform:translateY(-1px)}.skeleton-title{height:32px;width:200px}.skeleton-id{height:16px;width:120px}.skeleton-button{height:32px;width:80px}.skeleton-canvas{height:400px;width:100%;border-radius:8px}.skeleton-diagram-item{height:60px;width:100%;margin-bottom:8px;border-radius:6px}.skeleton-section-title{height:20px;width:100px;margin-bottom:var(--space-md)}.skeleton-tool{height:40px;width:100%;margin-bottom:var(--space-sm)}.skeleton-property{height:24px;width:100%;margin-bottom:var(--space-xs)}.skeleton-toolbar-btn{height:32px;width:32px}.skeleton-zoom{height:20px;width:60px}.skeleton-canvas{height:100%;width:100%}.error-state{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--space-xl);text-align:center}.error-state p{color:var(--error);font-size:var(--text-lg);margin:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:6px;background:var(--primary);color:#fff;padding:var(--space-sm) var(--space-md);text-decoration:none;border-radius:var(--radius-sm);z-index:1000;transition:top .3s ease;font-weight:600;font-size:var(--text-sm)}.skip-link:focus{top:6px;outline:2px solid var(--primary-light);outline-offset:2px}*:focus{outline:2px solid var(--primary);outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media (prefers-contrast: high){:root{--border-color: rgba(255, 255, 255, .3);--text-secondary: #ffffff;--text-tertiary: #e5e7eb}.card,.diagram-card,.palette-button,button{border:2px solid var(--border-color)}button:hover,.palette-button:hover{border-color:var(--primary);background:var(--primary);color:#fff}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.card:hover,.diagram-card:hover,.palette-button:hover{transform:none!important}}@media (forced-colors: active){:root{--primary: ButtonText;--primary-dark: ButtonText;--primary-light: ButtonText;--secondary: ButtonText;--accent: ButtonText;--text-primary: ButtonText;--text-secondary: ButtonText;--text-tertiary: ButtonText;--border-color: ButtonText;--surface-color: ButtonFace;--glass-bg: ButtonFace}.card,.diagram-card,.palette-button{border:1px solid ButtonText;background:ButtonFace}button{border:1px solid ButtonText;background:ButtonFace;color:ButtonText}button:hover{background:Highlight;color:HighlightText}}:root{--gray-50: #0a0a0f;--gray-100: #1a1a2e;--gray-200: #16213e;--gray-300: #0f3460;--gray-400: #533483;--gray-500: #6b7280;--gray-600: #9ca3af;--gray-700: #d1d5db;--gray-800: #e5e7eb;--gray-900: #f9fafb}[data-theme=light]{--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--text-primary: #111827;--text-secondary: #4b5563;--text-tertiary: #6b7280;--glass-bg: rgba(255, 255, 255, .9);--glass-border: rgba(0, 0, 0, .1);--background-color: #f9fafb;--sidebar-bg: rgba(255, 255, 255, .95);--card-bg: rgba(255, 255, 255, .9);--surface-color: rgba(255, 255, 255, .8);--border-color: rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .15)}[data-theme=light] .diagram-id,[data-theme=light] .diagram-item:hover,[data-theme=light] .diagram-item.active,[data-theme=light] .diagram-item:hover *,[data-theme=light] .diagram-item.active *{color:#fff!important}[data-theme=light] .sidebar{background:var(--sidebar-bg);border-right:1px solid var(--glass-border)}[data-theme=light] .card,[data-theme=light] .diagram-card{background:var(--card-bg);border:1px solid var(--glass-border)}[data-theme=light] .profile-dropdown{background:var(--card-bg);border:1px solid var(--glass-border);box-shadow:0 8px 24px #00000026}[data-theme=light] .react-flow__controls{background:#fffffff2!important;border:1px solid var(--glass-border)!important;box-shadow:0 4px 12px #0000001a!important}[data-theme=light] .react-flow__controls-button{background:transparent!important;border-bottom:1px solid var(--glass-border)!important;color:var(--text-primary)!important}[data-theme=light] .react-flow__controls-button:hover{background:var(--primary)!important;color:#fff!important}[data-theme=light] .react-flow__panel.element-counter-panel{background:transparent!important;border:none!important;box-shadow:none!important}[data-theme=light] .react-flow__panel:not(.element-counter-panel){background:#fffffff2!important;border:1px solid var(--glass-border)!important;color:var(--text-primary)!important;box-shadow:0 4px 12px #0000001a!important}[data-theme=light] .dropdown-menu,[data-theme=light] .profile-dropdown{background:var(--card-bg)!important;border:1px solid var(--glass-border)!important;box-shadow:0 8px 24px #00000026!important}[data-theme=light] .dropdown-item{color:var(--text-primary)!important;border-bottom:1px solid var(--glass-border)!important}[data-theme=light] .dropdown-item:hover{background:var(--primary)!important;color:#fff!important}[data-theme=light] .dropdown-item.danger:hover{background:var(--error)!important;color:#fff!important}[data-theme=light] .form-input,[data-theme=light] .form-select{background:var(--card-bg)!important;border:1px solid var(--glass-border)!important;color:var(--text-primary)!important}[data-theme=light] .form-input:focus,[data-theme=light] .form-select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #5843df1a!important}[data-theme=light] .btn,[data-theme=light] .palette-button{background:var(--card-bg)!important;border:1px solid var(--glass-border)!important;color:var(--text-primary)!important}[data-theme=light] .btn:hover,[data-theme=light] .palette-button:hover{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}[data-theme=light] [data-tooltip]:hover:after{background:var(--gray-800)!important;color:#fff!important;border:1px solid var(--glass-border)!important}[data-theme=light] .profile-name{color:var(--text-primary)!important}[data-theme=light] .profile-email{color:var(--text-secondary)!important}[data-theme=light] .profile-info{color:var(--text-primary)!important}[data-theme=light] .quota-text{color:var(--text-secondary)!important}[data-theme=light] .sidebar-header,[data-theme=light] .sidebar-brand{color:var(--text-primary)!important}[data-theme=light] .new-diagram-btn{background:var(--primary)!important;border:1px solid var(--primary)!important;color:#fff!important;box-shadow:0 2px 4px #5843df4d!important}[data-theme=light] .new-diagram-btn:hover{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;box-shadow:0 4px 8px #5843df66!important}[data-theme=light] .diagram-item{color:var(--text-primary)!important;background:var(--surface-color)!important;border:1px solid var(--border-color)!important}[data-theme=light] .diagram-item:hover{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}[data-theme=light] .diagram-item.active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;box-shadow:0 0 0 2px #5843df4d!important}[data-theme=light] .diagram-item.active *{color:#fff!important}[data-theme=light] .modal[role=dialog]{background:#0000004d!important}[data-theme=light] .modal[role=dialog] .modal-content{background:var(--card-bg)!important;border:1px solid var(--glass-border)!important;box-shadow:0 20px 40px #0003!important}[data-theme=dark]{--gray-50: #0a0a0f;--gray-100: #1a1a2e;--gray-200: #16213e;--gray-300: #0f3460;--gray-400: #533483;--gray-500: #6b7280;--gray-600: #9ca3af;--gray-700: #d1d5db;--gray-800: #e5e7eb;--gray-900: #f9fafb;--surface-color: rgba(26, 26, 46, .9);--border-color: rgba(255, 255, 255, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--accent-red: #f87171;--accent-red-dark: #ef4444;--accent-red-light: rgba(248, 113, 113, .15)}[data-theme=dark] .react-flow__controls{background:#1a1a2ee6!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 4px 12px #0000004d!important}[data-theme=dark] .react-flow__controls-button{background:transparent!important;border-bottom:1px solid rgba(255,255,255,.2)!important;color:#fff!important}[data-theme=dark] .react-flow__controls-button:hover{background:#ffffff1a!important;color:#fff!important}[data-theme=dark] .react-flow__controls-button svg{fill:#fff!important;stroke:#fff!important}[data-theme=dark] .react-flow__panel.element-counter-panel{background:transparent!important;border:none!important;box-shadow:none!important}[data-theme=dark] .react-flow__panel:not(.element-counter-panel){background:#1a1a2ee6!important;border:1px solid rgba(255,255,255,.2)!important;color:#fff!important;box-shadow:0 4px 12px #0000004d!important}[data-theme=dark] .diagram-item{color:#fff!important;background:#1a1a2ee6!important;border:1px solid rgba(255,255,255,.2)!important}[data-theme=dark] .diagram-item:hover{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}[data-theme=dark] .diagram-item.active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;box-shadow:0 0 0 2px #5843df80!important}.editor-page .editor-header .editor-title h1.editable-title{cursor:pointer!important;transition:color .2s ease!important;color:var(--text-primary)!important}.editor-page .editor-header .editor-title h1.editable-title:hover{color:var(--primary)!important}.keyboard-navigation .palette-button:focus,.keyboard-navigation .diagram-item:focus,.keyboard-navigation .toolbar-btn:focus{outline:3px solid var(--primary);outline-offset:2px;box-shadow:var(--glow-primary)}[aria-live]{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.loading[aria-busy=true]{position:relative}.loading[aria-busy=true]:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;display:flex;align-items:center;justify-content:center}.error[aria-invalid=true]{border-color:var(--error);box-shadow:0 0 0 3px #ef44441a}[data-tooltip]{position:relative}[data-tooltip]:hover:after,[data-tooltip]:focus:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--gray-800);color:#fff;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);white-space:nowrap;z-index:1000;margin-bottom:var(--space-xs)}.modal[role=dialog]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal[role=dialog] .modal-content{background:var(--surface-color);border-radius:var(--radius-lg);padding:var(--space-lg);max-width:90vw;max-height:90vh;overflow:auto}.dropdown-section{padding:0;border-bottom:1px solid var(--border-color)}.dropdown-label{font-size:10px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.dropdown-divider{height:1px;background:var(--border-color);margin:6px 0}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;margin-bottom:var(--space-xs);font-weight:600;color:var(--text-primary)}.form-input{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface-color);color:var(--text-primary);font-size:var(--text-md);transition:all .2s ease}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #5843df1a}.form-input[aria-invalid=true]{border-color:var(--error);box-shadow:0 0 0 3px #ef44441a}.form-error{color:var(--error);font-size:var(--text-sm);margin-top:var(--space-xs)}.form-help{color:var(--text-secondary);font-size:var(--text-sm);margin-top:var(--space-xs)}.status-removed-from-code{opacity:.7}.status-user-deleted{opacity:.5;text-decoration:line-through}.status-badge{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;z-index:10;box-shadow:0 2px 4px #0003}.status-badge-new{background:var(--accent-blue);color:#fff}.status-badge-implemented{background:var(--accent-green);color:#fff}.status-badge-out-of-sync{background:var(--accent-orange);color:#fff}.status-badge-removed-from-code{background:var(--accent-red);color:#fff}.status-badge-user-deleted{background:var(--gray-500);color:#fff}@keyframes statusPulse{0%,to{box-shadow:0 0 #f9731666}50%{box-shadow:0 0 0 4px #f973161a}}.edge-status-removed-from-code{opacity:.7}.edge-status-user-deleted{opacity:.5}.status-tooltip,.status-badge .status-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--gray-200);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);font-style:normal;white-space:nowrap;z-index:1000;margin-bottom:var(--space-xs);opacity:0;pointer-events:none;transition:opacity .2s ease;border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.status-badge:hover .status-tooltip,.status-badge .status-tooltip:hover{opacity:1}.status-badge:focus{outline:2px solid var(--primary);outline-offset:2px}.status-announcement{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.refresh-button{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.refresh-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.refresh-button:active:not(:disabled){transform:translateY(0)}.refresh-button:disabled{background:var(--gray-500);cursor:not-allowed;opacity:.6}.refresh-button svg{transition:transform .2s ease}.refresh-button:hover:not(:disabled) svg{transform:rotate(180deg)}.refresh-button .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
