body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column;background-color:#f8f9fa}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion: no-preference){.App-logo{animation:App-logo-spin infinite 20s linear}}.app-nav{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.nav-container{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:64px;max-width:1200px;margin:0 auto}.app-title{margin:0;font-size:20px;font-weight:600;color:#111827}.nav-buttons{display:flex;gap:8px}.nav-button{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.nav-button:hover{background:#f9fafb;border-color:#9ca3af}.nav-button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.nav-button.active:hover{background:#2563eb;border-color:#2563eb}.user-section{display:flex;align-items:center;gap:16px}.logout-button{padding:8px 16px;border:1px solid #ef4444;border-radius:6px;background:#fff;color:#ef4444;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{background:#ef4444;color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px #ef444433}.app-main{flex:1;overflow:auto;background-color:#f8f9fa}.app-footer{background:#fff;border-top:1px solid #e5e7eb;padding:8px 24px;text-align:center;flex-shrink:0}.version-info{font-size:12px;color:#6b7280;font-family:monospace}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.track-component{display:flex;align-items:center;margin-bottom:2px;background-color:#fff;border-bottom:1px solid #e9ecef;transition:background-color .2s ease}.track-component:hover{background-color:#f8f9fa}.track-label{width:150px;min-width:150px;height:100%;display:flex;align-items:center;padding:0 16px;background-color:#f8f9fa;border-right:1px solid #dee2e6;box-sizing:border-box}.track-name{font-size:14px;font-weight:500;color:#495057;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-content{position:relative;background-color:#fff;border:1px solid #e9ecef;overflow:hidden;flex:1}.track-zoom-container{position:relative;transition:transform .3s ease-out;will-change:transform;background-color:#fff;min-height:100%}.timeline-container{position:absolute;top:0;left:0;width:100%;height:18px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;z-index:3;pointer-events:none;overflow:visible}.timeline-marks{position:relative;width:100%;height:100%;min-width:100%;overflow:visible}.timeline-mark{position:absolute;top:0;height:100%;pointer-events:none;backface-visibility:hidden;will-change:transform;transform-style:preserve-3d}.timeline-mark-major{border-left:2px solid #495057;transform-origin:left center}.timeline-mark-major:before{content:"";position:absolute;top:0;left:-1px;width:2px;height:12px;background-color:#495057;transform-origin:left center}.timeline-mark-minor{border-left:1px solid #adb5bd;transform-origin:left center}.timeline-mark-minor:before{content:"";position:absolute;top:0;left:0;width:1px;height:6px;background-color:#adb5bd;transform-origin:left center}.timeline-label{position:absolute;top:12px;left:2px;font-size:9px;color:#495057;font-weight:500;white-space:nowrap;background-color:transparent;padding:0;border-radius:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;backface-visibility:hidden;will-change:transform}.timeline-label-minor{font-size:8px!important;color:#6c757d!important;font-weight:400!important;opacity:.8!important}.drag-timeline-indicator{position:absolute;top:0;bottom:0;z-index:1000;pointer-events:none;transform:translate(-1px)}.drag-timeline-line{width:2px;height:100%;background-color:#ff6d00;box-shadow:0 0 4px #ff6d0080;animation:dragLineGlow 1s ease-in-out infinite alternate}.drag-timeline-label{position:absolute;top:1px;left:3px;font-size:9px;color:#fff;font-weight:600;background-color:#ff6d00;padding:1px 4px;border-radius:2px;white-space:nowrap;box-shadow:0 1px 3px #0003;z-index:10;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.drag-timeline-label:after{display:none}@keyframes dragLineGlow{0%{box-shadow:0 0 4px #ff6d0080}to{box-shadow:0 0 8px #ff6d00cc}}.track-grid{position:absolute;top:18px;left:0;width:100%;height:calc(100% - 18px);min-width:100%;background-color:#fff;background-image:linear-gradient(to right,#f1f3f4 1px,transparent 1px),linear-gradient(to bottom,#f1f3f4 1px,transparent 1px);background-size:20px 20px;pointer-events:none;z-index:1;overflow:visible}.track-items{position:relative;width:100%;height:100%;z-index:2;padding-top:18px}.track-item{position:absolute;top:6px;height:calc(100% - 26px);min-width:60px;background-color:#4285f4;border:1px solid #3367d6;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:500;-webkit-user-select:none;user-select:none;transition:transform .3s ease,box-shadow .3s ease;box-shadow:0 1px 3px #0000001a;z-index:10;will-change:transform;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;backface-visibility:hidden}.track-item:hover:not(.track-item-dragging){box-shadow:0 2px 6px #00000026;border-color:#2c5aa0;filter:brightness(1.1)}.track-item-dragging{opacity:1!important;box-shadow:0 6px 16px #0000004d;z-index:1000;cursor:grabbing!important;transition:box-shadow .2s ease-out!important}.track-item-ghost{opacity:.5;background-color:#e3f2fd!important;border-color:#bbdefb!important;color:#1976d2!important;z-index:5;pointer-events:none}.track-item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px;max-width:100%;font-weight:600;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.track-item-time{font-size:10px;font-weight:400;opacity:.9;margin-top:2px;white-space:nowrap;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.track-item.theme-green{background-color:#34a853;border-color:#2d8f47}.track-item.theme-orange{background-color:#ff9800;border-color:#f57c00}.track-item.theme-red{background-color:#ea4335;border-color:#d33b2c}.track-item.theme-purple{background-color:#9c27b0;border-color:#7b1fa2}@media (max-width: 768px){.track-label{width:120px;min-width:120px;padding:0 12px}.track-name{font-size:13px}.track-item{min-width:50px;font-size:11px}}@keyframes trackItemAppear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.track-item{animation:trackItemAppear .3s ease-out}.track-item{cursor:grab}.track-item:active{cursor:grabbing}.track-item.disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.track-item.selected{border-width:2px;border-color:#ff6d00;box-shadow:0 0 0 2px #ff6d0033}.component-selector-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.component-selector-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}.component-selector-header{padding:20px 24px 16px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.component-selector-header h3{margin:0;font-size:1.5rem;font-weight:600}.track-type-info{margin:4px 0 0;font-size:.9rem;opacity:.9}.close-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.close-button:hover{background:#ffffff4d;transform:translateY(-1px)}.component-selector-filters{padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.search-container{margin-bottom:16px}.search-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.category-filter{display:flex;align-items:center;gap:12px}.category-filter label{font-weight:500;color:#374151;white-space:nowrap}.category-select{padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer;transition:all .2s ease}.category-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.component-list-container{flex:1;overflow-y:auto;padding:0;max-height:400px}.component-list{padding:8px}.component-item{padding:16px 20px;border:2px solid transparent;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s ease;background:#fff;box-shadow:0 1px 3px #0000001a}.component-item:hover,.component-item.focused{border-color:#667eea;background:#f0f4ff;transform:translateY(-1px);box-shadow:0 4px 12px #667eea26}.component-item:active{transform:translateY(0);box-shadow:0 2px 6px #667eea33}.component-name{font-weight:600;font-size:1.1rem;color:#1f2937;margin-bottom:8px}.component-details{display:flex;gap:16px;margin-bottom:6px}.component-category,.component-duration{font-size:.85rem;color:#6b7280;background:#f3f4f6;padding:4px 8px;border-radius:4px}.component-path{font-size:.8rem;color:#9ca3af;font-family:Monaco,Menlo,Ubuntu Mono,monospace;background:#f9fafb;padding:4px 8px;border-radius:4px;border-left:3px solid #e5e7eb}.no-components{text-align:center;padding:40px 20px;color:#6b7280;font-size:1rem;background:#f9fafb;margin:16px;border-radius:8px;border:2px dashed #d1d5db}.component-selector-footer{padding:16px 24px;border-top:1px solid #e5e7eb;background:#f8fafc}.keyboard-hints{display:flex;gap:16px;justify-content:center;font-size:.8rem;color:#6b7280}.keyboard-hints span{background:#e5e7eb;padding:4px 8px;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace}@media (max-width: 768px){.component-selector-modal{width:95%;max-height:90vh}.component-selector-header{padding:16px 20px 12px}.component-selector-header h3{font-size:1.3rem}.component-selector-filters{padding:16px 20px}.category-filter{flex-direction:column;align-items:flex-start;gap:8px}.category-select{width:100%}.component-details{flex-direction:column;gap:8px}.keyboard-hints{flex-wrap:wrap;gap:8px}}.component-list-container::-webkit-scrollbar{width:6px}.component-list-container::-webkit-scrollbar-track{background:#f1f5f9}.component-list-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.component-list-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.component-item:focus{outline:2px solid #667eea;outline-offset:2px}.component-item{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.component-selector-loading{display:flex;justify-content:center;align-items:center;padding:40px;color:#6b7280}.component-selector-loading:after{content:"";width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-left:8px}.workflow-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.workflow-dialog{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;width:90%;max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.workflow-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e5e7eb;background-color:#f9fafb}.workflow-dialog-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#6b7280;padding:4px;border-radius:4px;transition:all .2s}.workflow-dialog-content{padding:24px;flex:1;overflow-y:auto}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.error-message{display:block;margin-top:4px;font-size:12px;color:#ef4444;line-height:1.4}.file-drop-zone{border:2px dashed #d1d5db;border-radius:8px;padding:32px 16px;text-align:center;transition:all .2s;cursor:pointer;background-color:#f9fafb}.file-drop-zone:hover{border-color:#3b82f6;background-color:#eff6ff}.file-drop-zone.drag-over{border-color:#3b82f6;background-color:#dbeafe;transform:scale(1.02)}.file-drop-zone.has-file{border-color:#10b981;background-color:#ecfdf5;padding:16px}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:12px}.drop-icon{font-size:32px;opacity:.6}.drop-zone-content p{margin:0;color:#6b7280;font-size:14px}.file-select-btn{background-color:#3b82f6;color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s;border:none}.file-select-btn:hover{background-color:#2563eb}.selected-file{display:flex;align-items:center;gap:12px;padding:8px;background-color:#fff;border-radius:6px;border:1px solid #10b981}.file-icon{font-size:20px}.file-name{flex:1;font-size:14px;color:#374151;font-weight:500}.remove-file-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.remove-file-btn:hover{background-color:#f3f4f6;color:#ef4444}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:8px}.checkbox-label input[type=checkbox]{width:auto;margin:0}.checkbox-text{font-size:14px;color:#374151}.help-text{display:block;margin:4px 0 0;font-size:12px;color:#6b7280;line-height:1.4}.import-status{margin-top:8px;min-height:22px}.status-row{display:flex;align-items:center;gap:8px;font-size:14px}.status-row.success{color:#059669}.status-row.error{color:#ef4444}.status-text{vertical-align:middle;white-space:pre-line;word-wrap:break-word;max-width:100%}.spinner{width:16px;height:16px;border:2px solid #bfdbfe;border-top-color:#3b82f6;border-radius:50%;display:inline-block;animation:spin .8s linear infinite;margin-right:2px}.workflow-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb}.cancel-btn,.confirm-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.cancel-btn{background-color:#fff;color:#374151;border-color:#d1d5db}.cancel-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.confirm-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.confirm-btn.loading{opacity:.9;position:relative}.confirm-btn.loading:after{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid rgba(255,255,255,.6);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.confirm-btn:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.confirm-btn:disabled{background-color:#9ca3af;border-color:#9ca3af;cursor:not-allowed;opacity:.6}.workflow-dialog-shortcuts{padding:8px 24px 16px;text-align:center;background-color:#f9fafb;border-top:1px solid #f3f4f6}.workflow-dialog-shortcuts small{color:#6b7280;font-size:12px}@media (max-width: 640px){.workflow-dialog{width:95%;max-height:90vh}.workflow-dialog-header,.workflow-dialog-content,.workflow-dialog-footer{padding-left:16px;padding-right:16px}.file-drop-zone{padding:24px 12px}.drop-icon{font-size:24px}}.robot-behavior-player{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;padding:24px;box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a;border:1px solid #e2e8f0;margin-bottom:24px;position:relative;overflow:hidden}.robot-behavior-player:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4);background-size:200% 100%;animation:gradientShift 3s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.console-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f1f5f9;position:relative}.console-header h2{margin:0;font-size:24px;font-weight:700;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:8px}.connection-info{display:flex;align-items:center;gap:12px;background:#fffc;padding:12px 16px;border-radius:12px;border:1px solid #e2e8f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.status-indicator{font-size:16px;display:flex;align-items:center;animation:statusPulse 2s ease-in-out infinite}.status-text{font-size:14px;font-weight:600;color:#475569;transition:color .3s ease}.status-text.connected{color:#059669}.status-text.connecting{color:#d97706}.status-text.disconnected{color:#64748b}.status-text.error{color:#dc2626}@keyframes statusPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.client-monitoring{background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;padding:20px;margin-bottom:24px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #0000000a}.client-monitoring h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.status-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.status-card{background:#fff;border-radius:12px;padding:20px;text-align:center;border:2px solid #f1f5f9;transition:all .3s ease;position:relative;overflow:hidden}.status-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;transition:all .3s ease}.status-card.admin:before{background:linear-gradient(90deg,#3b82f6,#1d4ed8)}.status-card.executor:before{background:linear-gradient(90deg,#10b981,#059669)}.status-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001a}.status-label{font-size:14px;font-weight:600;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.status-count{font-size:32px;font-weight:700;margin-bottom:4px;transition:color .3s ease}.status-card.admin .status-count{color:#3b82f6}.status-card.executor .status-count{color:#10b981}.status-desc{font-size:12px;color:#94a3b8;font-weight:500}.admin-list{margin-top:20px}.admin-list h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#374151}.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.admin-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:16px;border:1px solid #5a67d8;box-shadow:0 2px 8px #667eea33;transition:all .3s ease;color:#fff}.admin-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #667eea4d}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.2)}.admin-id{font-size:14px;font-weight:600;color:#fff}.admin-status{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.admin-status.connected{background:#dcfce7e6;color:#166534}.admin-info{font-size:13px;line-height:1.6}.admin-info>div{margin-bottom:4px;color:#ffffffe6}.username-conflict-warning{background:#ffc10733;border:1px solid #ffc107;border-radius:4px;padding:8px;margin-top:8px;color:#ffc107;font-size:12px;font-weight:500}.conflict-warning{color:#ff6b6b!important;font-weight:600;background:#ff6b6b1a;padding:4px 8px;border-radius:4px;border:1px solid rgba(255,107,107,.3)}.executor-list{margin-top:20px}.executor-list h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#374151}.executor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.executor-card{background:#fff;border-radius:12px;padding:16px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a;transition:all .3s ease}.executor-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000014}.executor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.executor-id{font-size:14px;font-weight:600;color:#1e293b}.executor-status{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.executor-status.connected{background:#dcfce7;color:#166534}.executor-status.playing{background:#dbeafe;color:#1e40af}.executor-status.paused{background:#fef3c7;color:#92400e}.executor-progress{margin-bottom:12px}.progress-label{font-size:12px;color:#64748b;margin-bottom:4px;font-weight:500}.executor-progress .progress-bar{width:100%;height:6px;background-color:#f1f5f9;border-radius:3px;overflow:hidden;margin-bottom:4px}.executor-progress .progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s ease}.progress-text{font-size:12px;color:#10b981;font-weight:600;text-align:right}.executor-info{font-size:12px;color:#64748b;line-height:1.4}.executor-info div{margin-bottom:2px}.console-controls{background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;padding:20px;margin-bottom:24px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #0000000a}.connection-controls{margin-bottom:20px}.websocket-url-config,.username-config{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.websocket-url-config h4,.username-config h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.url-input-group,.username-input-group{margin-bottom:8px}.url-display,.username-display{display:flex;align-items:center;gap:12px;padding:8px 0}.url-text{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;color:#1e293b;background:#f8fafc;padding:8px 12px;border-radius:6px;border:1px solid #e2e8f0;flex:1;min-width:0;word-break:break-all}.username-text{font-size:14px;color:#1e293b;background:#f8fafc;padding:8px 12px;border-radius:6px;border:1px solid #e2e8f0;flex:1;min-width:0;word-break:break-word;font-weight:500}.url-edit,.username-edit{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.url-input{flex:1;min-width:200px;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;transition:all .3s ease;background:#fff}.username-input{flex:1;min-width:200px;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .3s ease;background:#fff}.url-input:focus,.username-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.url-input.url-input-error{border-color:#ef4444;background:#fef2f2}.url-input.url-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.url-input::placeholder,.username-input::placeholder{color:#94a3b8}.edit-url-btn,.save-url-btn,.cancel-url-btn,.edit-username-btn,.save-username-btn,.cancel-username-btn{padding:8px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:4px;white-space:nowrap}.edit-url-btn,.edit-username-btn{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.edit-url-btn:hover:not(:disabled),.edit-username-btn:hover:not(:disabled){background:#e2e8f0;color:#334155}.edit-url-btn:disabled,.edit-username-btn:disabled{opacity:.5;cursor:not-allowed}.save-url-btn,.save-username-btn{background:#10b981;color:#fff}.save-url-btn:hover:not(:disabled),.save-username-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.save-url-btn:disabled,.save-username-btn:disabled{background:#94a3b8;cursor:not-allowed;transform:none}.cancel-url-btn,.cancel-username-btn{background:#ef4444;color:#fff}.cancel-url-btn:hover,.cancel-username-btn:hover{background:#dc2626;transform:translateY(-1px)}.url-error-message{background:#fef2f2;color:#dc2626;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;margin-bottom:8px;border:1px solid #fecaca;display:flex;align-items:center;gap:6px}.url-help-text,.username-help-text{font-size:12px;color:#64748b;line-height:1.4;margin-top:4px}.connection-buttons{display:flex;gap:12px;flex-wrap:wrap}.broadcast-controls{border-top:1px solid #f1f5f9;padding-top:20px}.broadcast-controls h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.no-executors-warning{background:#fef3c7;color:#92400e;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;margin-top:12px;border:1px solid #fde68a}.connect-btn,.disconnect-btn,.reconnect-btn,.play-btn,.pause-btn,.stop-btn,.simulate-btn,.broadcast-btn{padding:12px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;min-width:120px;justify-content:center;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.connect-btn:before,.disconnect-btn:before,.reconnect-btn:before,.play-btn:before,.pause-btn:before,.stop-btn:before,.simulate-btn:before,.broadcast-btn: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}.connect-btn:hover:before,.disconnect-btn:hover:before,.reconnect-btn:hover:before,.play-btn:hover:before,.pause-btn:hover:before,.stop-btn:hover:before,.simulate-btn:hover:before,.broadcast-btn:hover:before{left:100%}.connect-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.connect-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 16px #10b9814d}.connect-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.disconnect-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.disconnect-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 16px #ef44444d}.reconnect-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.reconnect-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 4px 16px #f59e0b4d}.reconnect-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.play-btn,.broadcast-btn.play-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.play-btn:hover:not(:disabled),.broadcast-btn.play-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 16px #3b82f64d}.play-btn:disabled,.broadcast-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.pause-btn,.broadcast-btn.pause-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.pause-btn:hover,.broadcast-btn.pause-btn:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 4px 16px #f59e0b4d}.stop-btn,.broadcast-btn.stop-btn{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.stop-btn:hover,.broadcast-btn.stop-btn:hover{background:linear-gradient(135deg,#4b5563,#374151);transform:translateY(-2px);box-shadow:0 4px 16px #6b72804d}.simulate-btn{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff}.simulate-btn:hover:not(:disabled){background:linear-gradient(135deg,#7b1fa2,#6b21a8);transform:translateY(-2px);box-shadow:0 4px 16px #9c27b04d}.simulate-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.error-message{display:flex;align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,#fef2f2,#fecaca);border:1px solid #f87171;border-radius:12px;color:#dc2626;font-size:14px;font-weight:500;margin-bottom:20px;box-shadow:0 4px 16px #dc26261a;animation:errorSlideIn .3s ease-out}.error-icon{font-size:18px;animation:errorPulse 1s ease-in-out infinite}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes errorPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.console-info{background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;padding:20px;margin-top:20px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #0000000a}.console-info h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.info-item{background:#fffc;padding:12px 16px;border-radius:10px;border:1px solid #e2e8f0;transition:all .3s ease}.info-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.info-item label{display:block;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.info-item span{font-size:14px;color:#1e293b;font-weight:500;word-break:break-all}.role-badge{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.username-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.3px}.playback-progress{background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px;padding:20px;margin:20px 0;border:1px solid #e2e8f0;box-shadow:0 4px 16px #0000000a}.progress-bar{width:100%;height:8px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0);border-radius:4px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#06b6d4);background-size:200% 100%;transition:width .3s ease;border-radius:4px;position:relative;animation:progressShimmer 2s ease-in-out infinite}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressGlow 1.5s ease-in-out infinite}@keyframes progressShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes progressGlow{0%,to{transform:translate(-100%)}50%{transform:translate(100%)}}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:13px;color:#64748b;font-weight:500}.progress-info span{padding:4px 8px;background:#fffc;border-radius:6px;border:1px solid #e2e8f0}.workflow-info{background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid #e2e8f0;border-radius:16px;padding:20px;margin-top:20px;box-shadow:0 4px 16px #0000000a}.workflow-info h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:8px}.workflow-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.workflow-details div{background:#fffc;padding:8px 12px;border-radius:8px;font-size:13px;color:#475569;font-weight:500;border:1px solid #e2e8f0}@media (max-width: 1024px){.robot-behavior-player{padding:20px}.status-summary,.executor-grid{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.robot-behavior-player{padding:16px;margin-bottom:16px}.console-header{flex-direction:column;align-items:flex-start;gap:12px}.console-header h2{font-size:20px}.connection-info{width:100%;justify-content:center}.connection-controls{justify-content:center;flex-wrap:wrap}.info-grid,.workflow-details{grid-template-columns:1fr}.connect-btn,.disconnect-btn,.reconnect-btn,.play-btn,.pause-btn,.stop-btn,.simulate-btn,.broadcast-btn{min-width:100px;padding:10px 16px}}@media (max-width: 480px){.robot-behavior-player{padding:12px}.console-header h2{font-size:18px}.client-monitoring,.console-controls,.playback-progress,.workflow-info,.console-info{padding:16px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.client-monitoring{animation:fadeIn .6s ease-out}.console-controls{animation:slideInFromLeft .5s ease-out}.status-card{animation:bounceIn .8s ease-out}.status-card:nth-child(2){animation-delay:.1s}.status-indicator.connected{color:#059669}.status-indicator.connecting{color:#d97706}.status-indicator.disconnected{color:#64748b}.status-indicator.error{color:#dc2626}.tooltip{position:relative;display:inline-block}.tooltip .tooltiptext{visibility:hidden;width:200px;background:linear-gradient(135deg,#1e293b,#374151);color:#fff;text-align:center;border-radius:8px;padding:10px;position:absolute;z-index:1000;bottom:125%;left:50%;margin-left:-100px;font-size:12px;font-weight:500;opacity:0;transition:all .3s ease;box-shadow:0 4px 16px #0003}.tooltip .tooltiptext:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#1e293b transparent transparent transparent}.tooltip:hover .tooltiptext{visibility:visible;opacity:1;transform:translateY(-5px)}.broadcast-mode-selector{background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid #e2e8f0;border-radius:12px;padding:16px;margin:16px 0;display:flex;gap:20px;align-items:center}.mode-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s ease;font-weight:500}.mode-option:hover{background:#3b82f61a}.mode-option input[type=radio]{margin:0;accent-color:#3b82f6}.mode-option span{font-size:14px;color:#374151}.executor-selector{background:linear-gradient(135deg,#fefefe,#f9fafb);border:1px solid #d1d5db;border-radius:12px;padding:16px;margin:16px 0;box-shadow:0 2px 8px #0000000d}.executor-selector h5{margin:0 0 12px;font-size:14px;font-weight:600;color:#374151}.executor-list{display:flex;flex-direction:column;gap:8px}.executor-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.executor-option:hover{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f626}.executor-option input[type=checkbox]{margin:0;accent-color:#3b82f6}.executor-info{display:flex;flex-direction:column;gap:2px}.executor-username{font-weight:600;color:#1f2937;font-size:14px}.executor-id{font-size:12px;color:#6b7280;font-family:Courier New,monospace}.selection-warning{background:linear-gradient(135deg,#fef3cd,#fde68a);border:1px solid #f59e0b;border-radius:8px;padding:10px 12px;margin-top:12px;font-size:13px;color:#92400e;font-weight:500}.playback-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}.broadcast-btn{position:relative;overflow:hidden}.broadcast-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.broadcast-btn:disabled:hover{transform:none;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.broadcast-mode-selector{flex-direction:column;align-items:flex-start;gap:12px}.playback-buttons{flex-direction:column}.broadcast-btn{width:100%}}.context-menu{background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 10px #0000001a;padding:4px 0;min-width:120px;font-size:14px}.context-menu-item{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s}.context-menu-item:hover{background-color:#f5f5f5}.context-menu-item.delete-item{color:#d93025}.context-menu-item.delete-item:hover{background-color:#fce8e6}.delete-icon{font-size:12px}.confirm-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001}.confirm-dialog{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;min-width:400px;max-width:500px}.confirm-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.confirm-dialog-header h3{margin:0;font-size:18px;font-weight:500;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.confirm-dialog-body{padding:20px}.confirm-dialog-body p{margin:0;color:#666;line-height:1.5}.confirm-dialog-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #eee}.cancel-btn,.confirm-btn{padding:8px 16px;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.cancel-btn{background:#fff;color:#333}.cancel-btn:hover{background:#f5f5f5}.confirm-btn{background:#d93025;color:#fff;border-color:#d93025}.confirm-btn:hover{background:#c62828}.save-behavior-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.save-behavior-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;width:90%;max-width:500px;max-height:90vh;overflow:hidden;animation:dialogSlideIn .3s ease-out}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background-color:#f8f9fa}.dialog-header h2{margin:0;font-size:18px;font-weight:600;color:#1f2937}.close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;line-height:1}.close-btn:hover{background-color:#f3f4f6;color:#374151}.dialog-content{padding:24px;overflow-y:auto;max-height:calc(90vh - 140px)}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:8px}.error-message:before{content:"⚠️";font-size:16px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;background-color:#fff;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.dialog-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:20px;border-top:1px solid #e5e7eb}.cancel-btn,.save-btn{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid;min-width:100px}.cancel-btn{background-color:#fff;color:#6b7280;border-color:#d1d5db}.cancel-btn:hover{background-color:#f9fafb;color:#374151;border-color:#9ca3af}.save-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.save-btn:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.save-btn:disabled{background-color:#d1d5db;color:#9ca3af;border-color:#d1d5db;cursor:not-allowed}@media (max-width: 640px){.save-behavior-dialog{width:95%;margin:20px}.dialog-header{padding:16px 20px}.dialog-content{padding:20px}.dialog-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}}@media (prefers-color-scheme: dark){.save-behavior-dialog{background:#1f2937;color:#f9fafb}.dialog-header{background-color:#111827;border-bottom-color:#374151}.dialog-header h2{color:#f9fafb}.close-btn{color:#9ca3af}.close-btn:hover{background-color:#374151;color:#f3f4f6}.form-group label{color:#f3f4f6}.form-group input,.form-group textarea,.form-group select{background-color:#374151;border-color:#4b5563;color:#f9fafb}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.form-hint{color:#9ca3af}.dialog-actions{border-top-color:#374151}.cancel-btn{background-color:#374151;color:#d1d5db;border-color:#4b5563}.cancel-btn:hover{background-color:#4b5563;color:#f3f4f6}}.track-test-page{min-height:100%;background-color:#f8f9fa;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.test-header{text-align:center;margin-bottom:30px;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.test-header h1{color:#333;margin:0 0 10px;font-size:28px;font-weight:600}.test-header p{color:#666;margin:0 0 20px;font-size:16px}.header-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;margin-top:20px}.config-info{color:#666;font-size:14px}.zoom-controls{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e5e7eb}.zoom-controls label{font-size:14px;font-weight:500;color:#374151;margin-right:8px}.zoom-btn{width:32px;height:32px;border:1px solid #d1d5db;background-color:#fff;border-radius:4px;font-size:16px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.zoom-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.zoom-btn:active:not(:disabled){background-color:#e5e7eb}.zoom-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f9fafb}.zoom-display{min-width:50px;text-align:center;font-size:14px;font-weight:600;color:#374151;padding:0 8px}.zoom-reset-btn{padding:6px 12px;border:1px solid #d1d5db;background-color:#fff;border-radius:4px;font-size:12px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s;margin-left:8px}.zoom-reset-btn:hover{background-color:#f3f4f6;border-color:#9ca3af}.zoom-reset-btn:active{background-color:#e5e7eb}.zoom-shortcuts{margin-left:12px;padding-left:12px;border-left:1px solid #e5e7eb}.zoom-shortcuts small{color:#6b7280;font-size:11px;line-height:1.2;white-space:nowrap}.timeline-zoom-controls{background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px 16px;margin-bottom:16px;box-shadow:0 1px 3px #0000001a}.timeline-zoom-controls .zoom-controls{justify-content:flex-start}.timeline-zoom-controls .zoom-controls label{color:#1f2937;font-weight:600}@media (max-width: 768px){.header-controls{flex-direction:column;align-items:stretch}.zoom-controls{justify-content:center;flex-wrap:wrap}.zoom-shortcuts{margin-left:0;margin-top:8px;padding-left:0;border-left:none;border-top:1px solid #e5e7eb;padding-top:8px;text-align:center}.zoom-shortcuts small{white-space:normal}.timeline-zoom-controls .zoom-controls{justify-content:center}}.test-content{display:flex;flex-direction:column;gap:20px;flex:1;overflow:hidden}.test-content .robot-behavior-player{margin-bottom:20px;border:1px solid #e0e0e0;border-radius:8px;background:#fafafa}.workflow-controls{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;border:1px solid #e5e7eb}.workflow-controls h2{margin:0 0 12px;font-size:16px;font-weight:600;color:#374151}.workflow-buttons{display:flex;gap:12px;flex-wrap:wrap}.workflow-btn{padding:8px 16px;border:1px solid;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;min-width:120px;justify-content:center}.workflow-btn:disabled{opacity:.5;cursor:not-allowed}.save-behavior-btn{background-color:#28a745;border-color:#28a745;color:#fff}.save-behavior-btn:hover:not(:disabled){background-color:#218838;border-color:#1e7e34}.save-behavior-btn:disabled{background-color:#6c757d;border-color:#6c757d;color:#fff;opacity:.5}.compact-btn{background-color:#17a2b8;border-color:#17a2b8;color:#fff}.compact-btn:hover:not(:disabled){background-color:#138496;border-color:#117a8b}.compact-btn:disabled{background-color:#6c757d;border-color:#6c757d;color:#fff;opacity:.5}.success-notification{position:fixed;top:20px;right:20px;z-index:1000;animation:slideInRight .3s ease-out}.success-content{display:flex;align-items:center;gap:10px;background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:500px}.success-icon{font-size:18px;flex-shrink:0}.success-text{flex:1;font-weight:500;font-size:14px}.success-close{background:none;border:none;color:#155724;font-size:18px;font-weight:700;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.success-close:hover{background-color:#1557241a}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.export-btn{background-color:#10b981;color:#fff;border-color:#10b981}.export-btn:hover:not(:disabled){background-color:#059669;border-color:#059669}.import-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.import-btn:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.refresh-btn{background-color:#f59e0b;color:#fff;border-color:#f59e0b}.refresh-btn:hover:not(:disabled){background-color:#d97706;border-color:#d97706}.tracks-and-info{display:flex;flex-direction:column;gap:20px;flex:1;overflow:hidden}.tracks-container{width:100%;background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;border:1px solid #e5e7eb}.tracks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.tracks-header h2{margin:0;color:#333;font-size:20px;font-weight:600}.track-selector-dropdown{position:relative}.track-selector{padding:8px 16px;border:1px solid #4285f4;border-radius:6px;background-color:#4285f4;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-width:180px;outline:none}.track-selector:hover{background-color:#3367d6;border-color:#3367d6}.track-selector:focus{background-color:#3367d6;border-color:#3367d6;box-shadow:0 0 0 2px #4285f433}.track-selector option{background-color:#fff;color:#333;padding:8px}.track-selector option:disabled{color:#6c757d;font-style:italic}.tracks-wrapper{border:1px solid #e9ecef;border-radius:6px;overflow-x:auto;overflow-y:hidden}.track-wrapper{display:flex;align-items:center;border-bottom:1px solid #e9ecef;min-width:fit-content}.track-wrapper:last-child{border-bottom:none}.track-controls{display:flex;flex-direction:column;gap:8px;padding:10px;background-color:#f8f9fa;border-left:1px solid #e9ecef;min-width:100px;justify-content:center}.add-item-btn,.delete-item-btn{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-item-btn{background-color:#4285f4;color:#fff}.add-item-btn:hover{background-color:#3367d6}.delete-item-btn{background-color:#ea4335;color:#fff}.delete-item-btn:hover{background-color:#d33b2c}.info-panel{width:100%;display:flex;flex-direction:column;gap:20px}.selected-info{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;min-height:200px}.selected-info h3{margin:0 0 15px;color:#333;font-size:16px;font-weight:600}.item-details{background-color:#f8f9fa;border-radius:6px;padding:15px}.item-detail p{margin:8px 0;font-size:14px;color:#495057}.item-detail strong{color:#333;font-weight:600}.no-selection{color:#6c757d;font-style:italic;text-align:center;padding:20px;margin:0}.event-log{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;min-height:200px}.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.log-header h3{margin:0;color:#333;font-size:16px;font-weight:600}.clear-log-btn{padding:4px 8px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.clear-log-btn:hover{background-color:#5a6268}.log-content{max-height:300px;overflow-y:auto;border:1px solid #e9ecef;border-radius:4px;background-color:#f8f9fa}.log-list{list-style:none;margin:0;padding:0}.log-item{padding:8px 12px;border-bottom:1px solid #e9ecef;font-size:13px;color:#495057;font-family:Consolas,Monaco,monospace}.log-item:last-child{border-bottom:none}.no-events{color:#6c757d;font-style:italic;text-align:center;padding:20px;margin:0}.instructions{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.instructions h3{margin:0 0 15px;color:#333;font-size:18px;font-weight:600}.instructions ul{margin:0;padding-left:20px}.instructions li{margin-bottom:8px;color:#495057;line-height:1.5}.instructions strong{color:#333;font-weight:600}@media (max-width: 1024px){.info-panel{flex-direction:column}}@media (max-width: 768px){.track-test-page{padding:10px}.test-header{padding:15px}.test-header h1{font-size:24px}.tracks-container,.selected-info,.event-log,.instructions{padding:15px}.info-panel{flex-direction:column}.tracks-header{flex-direction:column;align-items:flex-start;gap:15px}.track-selector{width:100%;min-width:auto}.track-wrapper{flex-direction:column;align-items:stretch}.track-controls{flex-direction:row;justify-content:center;border-left:none;border-top:1px solid #e9ecef}}.track-component.has-selection .track-item.selected{border-color:#ff6d00;box-shadow:0 0 0 2px #ff6d0033}.log-content::-webkit-scrollbar{width:6px}.log-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.log-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.log-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.new-atom-list{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.new-atom-list-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.header-left{display:flex;align-items:center;gap:16px}.header-right{display:flex;align-items:center}.batch-select-all{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#495057}.batch-select-all input[type=checkbox]{margin:0;cursor:pointer}.new-atom-list-header h3{margin:0;color:#2c3e50;font-size:18px;font-weight:600}.atom-count{color:#7f8c8d;font-size:14px;font-weight:500}.new-atom-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.new-atom-list-empty h3{color:#7f8c8d;margin:0 0 8px;font-size:20px}.new-atom-list-empty p{color:#95a5a6;margin:0;font-size:14px}.new-atom-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;padding:16px}.new-atom-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden;transition:all .2s ease;box-shadow:0 2px 4px #0000000d;position:relative;display:flex;flex-direction:column;padding:30px;min-height:300px;box-sizing:border-box}.new-atom-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.new-atom-card.selected{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.batch-select-checkbox{position:absolute;top:12px;left:12px;transform:scale(1.2);cursor:pointer;z-index:10}.batch-select-checkbox input[type=checkbox]{margin:0;cursor:pointer;width:16px;height:16px;background:#fff;border-radius:4px;border:1px solid #dee2e6;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.batch-select-checkbox input[type=checkbox]:hover{border-color:#007bff}.batch-select-checkbox input[type=checkbox]:checked{background:#007bff;border-color:#007bff;color:#fff}.new-atom-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;padding:0;margin:0 0 12px;min-width:0;border:none;width:100%}.atom-title{display:flex;align-items:center;gap:12px;flex:1;flex-wrap:nowrap;overflow:hidden;margin-top:21px}.atom-icon{font-size:24px;flex-shrink:0}.atom-title h4{margin:0;color:#2c3e50;font-size:16px;font-weight:600;word-break:break-word;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.download-button{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:90px;height:36px;font-weight:500;position:absolute;top:12px;right:12px}.download-button:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 2px 8px #3498db4d}.atom-actions{display:flex;gap:8px;flex-shrink:0;padding:12px 0 0;border-top:1px solid #e9ecef;margin-top:12px;margin-left:-12px;justify-content:flex-start;width:calc(100% + 12px)}.preview-btn,.download-btn,.edit-btn,.delete-btn{border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:12px;display:flex;align-items:center;justify-content:center;min-width:70px;height:28px;padding:5px 12px}.edit-btn,.delete-btn{background:#f8f9fa;border:1px solid #dee2e6}.edit-btn:hover{background:#e9ecef;transform:translateY(-1px)}.delete-btn:hover{background:#f5c6cb;border-color:#f1aeb5;color:#dc3545;transform:translateY(-1px)}.new-atom-card-body{display:flex;flex-direction:column;padding:0;overflow-y:visible;gap:12px;flex:1;width:100%}.atom-type-badge{display:inline-block;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;margin-right:0;flex-shrink:0;width:80px;text-align:center;margin-bottom:8px}.atom-description{color:#7f8c8d;font-size:14px;line-height:1.4;margin:0 0 8px;word-break:break-word;max-width:100%;white-space:normal;overflow:visible;text-overflow:clip}.atom-details{display:flex;flex-direction:column;gap:8px;align-items:flex-start;margin:12px 0}.detail-item{display:flex;align-items:center;font-size:13px;margin:0}.detail-label{color:#7f8c8d;font-weight:500;min-width:60px;margin-right:4px}.detail-value{color:#2c3e50;font-weight:400;word-break:break-word;text-align:left;max-width:none;overflow:visible;text-overflow:clip;white-space:normal}.atom-tags{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 12px;flex-shrink:0}.atom-tag{background:#ecf0f1;color:#2c3e50;padding:2px 6px;border-radius:10px;font-size:11px;font-weight:500}.atom-references{margin:0 0 12px;flex-shrink:0;width:100%}.references-header{display:flex;align-items:center}.references-label{color:#7f8c8d;font-size:12px;font-weight:500;margin-bottom:4px}.references-loading{color:#95a5a6;font-size:11px;font-style:italic}.references-content{min-height:20px;overflow:hidden;text-overflow:ellipsis}.no-references{color:#bdc3c7;font-size:11px;font-style:italic}.references-list{display:flex;flex-direction:column;gap:4px;max-height:40px;overflow-y:auto}.reference-group,.reference-item{display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:4px 8px;transition:all .2s ease;font-size:11px}.reference-group:hover,.reference-item:hover{background:#e9ecef;border-color:#dee2e6}.reference-group-name{color:#2c3e50;font-size:11px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.reference-details,.reference-count{color:#7f8c8d;font-size:10px;font-weight:400;margin-left:4px;flex-shrink:0}@media (max-width: 768px){.new-atom-grid{grid-template-columns:1fr;gap:16px;padding:16px}.new-atom-list-header{flex-direction:column;gap:8px;text-align:center}.atom-title h4{font-size:14px}.detail-value{max-width:150px}.reference-group-name{font-size:10px}.reference-count{font-size:9px}}@media (max-width: 480px){.new-atom-card-header,.new-atom-card-body{padding:12px}.atom-references{margin-top:8px;padding-top:8px}.references-list{gap:2px}.reference-group{padding:3px 6px}.detail-item{flex-direction:column;align-items:flex-start;gap:2px}.detail-value{max-width:100%;text-align:left}}.preview-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;gap:4px}.preview-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.preview-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.audio-preview-player{position:absolute;top:100%;left:0;right:0;margin-top:4px;padding:12px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef;box-shadow:0 4px 12px #0000001a;z-index:100}.audio-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.audio-preview-header span{font-size:14px;font-weight:500;color:#495057}.close-preview-btn{background:#dc3545;color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.close-preview-btn:hover{background:#c82333}.audio-preview-player audio{border-radius:4px;outline:none}.audio-preview-player audio:focus{box-shadow:0 0 0 2px #667eea4d}.pag-preview-modal{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.pag-preview-modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden}.pag-preview-container{padding:20px;display:flex;justify-content:center;align-items:center;background:#f8f9fa}.atom-timestamps{margin-top:8px;padding-top:8px;border-top:1px solid #f1f3f4}.atom-timestamps .detail-item{margin-bottom:4px}.atom-timestamps .detail-label{font-size:12px;color:#6c757d}.atom-timestamps .detail-value{font-size:12px;color:#495057;font-family:Courier New,monospace}.pag-preview-modal{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pag-preview-modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.pag-preview-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.pag-preview-header span{font-size:16px;font-weight:600;color:#2c3e50}.close-preview-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#6c757d;padding:4px 8px;border-radius:4px;transition:all .2s}.close-preview-btn:hover{background:#e9ecef;color:#495057}.pag-preview-container{padding:20px;display:flex;flex-direction:column;align-items:center;background:#f8f9fa;position:relative;min-height:300px}.pag-canvas{max-width:100%;max-height:400px;border-radius:8px;box-shadow:0 4px 16px #0000001a;background:transparent}.pag-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:#fffffff2;border-radius:8px;box-shadow:0 2px 12px #0000001a}.loading-spinner{width:32px;height:32px;border:3px solid #e9ecef;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.pag-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:#fffffff2;border-radius:8px;box-shadow:0 2px 12px #0000001a;color:#e74c3c;text-align:center}.retry-btn{background:#28a745;color:#fff;border:none;border-radius:6px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.pag-controls{display:flex;flex-direction:column;gap:16px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:16px;min-width:300px}.control-buttons{display:flex;gap:12px;justify-content:center}.control-btn{background:#007bff;color:#fff;border:none;border-radius:6px;padding:10px 16px;cursor:pointer;font-size:16px;transition:all .2s;min-width:48px;display:flex;align-items:center;justify-content:center}.control-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.control-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.progress-container{display:flex;align-items:center;gap:12px;width:100%}.time-display{font-size:12px;color:#666;min-width:50px;text-align:center;font-family:monospace}.progress-slider{flex:1;height:6px;background:#e1e5e9;border-radius:3px;outline:none;cursor:pointer;appearance:none}.progress-slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;background:#007bff;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s}.progress-slider::-webkit-slider-thumb:hover{background:#0056b3;transform:scale(1.1)}.progress-slider::-moz-range-thumb{width:18px;height:18px;background:#007bff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}@media (max-width: 768px){.pag-preview-modal-content{max-width:95vw;max-height:95vh}.pag-preview-container{padding:15px}.pag-canvas{max-height:300px}.pag-controls{min-width:auto;width:100%}.control-buttons{flex-wrap:wrap}.progress-container{flex-direction:column;gap:8px}.progress-slider{width:100%}}@media (max-width: 480px){.pag-preview-header{padding:12px 16px}.pag-preview-header span{font-size:14px}.pag-preview-container{padding:12px;min-height:250px}.control-btn{padding:8px 12px;font-size:14px;min-width:40px}.time-display{font-size:11px;min-width:45px}.pag-canvas{max-height:200px}}@media (prefers-color-scheme: dark){.pag-preview-modal-content{background:#2d3748;color:#e2e8f0}.pag-preview-header{background:#1a202c;border-color:#4a5568}.pag-preview-header span{color:#e2e8f0}.close-preview-btn{color:#a0aec0}.close-preview-btn:hover{background:#4a5568;color:#e2e8f0}.pag-preview-container{background:#1a202c}.pag-controls{background:#2d3748}.time-display{color:#a0aec0}.pag-loading,.pag-error{background:#2d3748f2}.pag-error{color:#fed7d7}}.new-atom-filter{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow:hidden}.filter-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.filter-header h3{margin:0;color:#2c3e50;font-size:16px;font-weight:600}.clear-filters-btn{background:#e74c3c;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-filters-btn:hover{background:#c0392b;transform:translateY(-1px)}.filter-content{padding:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#2c3e50;font-size:14px;font-weight:500}.search-icon{position:absolute;left:12px;width:16px;height:16px;color:#7f8c8d;z-index:1}.search-input{width:100%;padding:10px 12px 10px 36px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:all .2s ease;background:#fff}.search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.clear-search{position:absolute;right:8px;background:none;border:none;color:#7f8c8d;font-size:18px;cursor:pointer;padding:4px;border-radius:50%;transition:all .2s ease}.clear-search:hover{background:#ecf0f1;color:#2c3e50}.filter-select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s ease}.filter-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.tag-filter-container{position:relative}.tag-dropdown-trigger{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s ease;display:flex;justify-content:space-between;align-items:center;text-align:left}.tag-dropdown-trigger:hover{border-color:#3498db}.dropdown-arrow{transition:transform .2s ease;font-size:12px;color:#7f8c8d}.dropdown-arrow.open{transform:rotate(180deg)}.tag-dropdown{position:absolute;top:100%;left:0;right:0;z-index:10;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto}.tag-dropdown-content{padding:8px 0}.tag-option{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background-color .2s ease}.tag-option:hover{background:#f8f9fa}.tag-option input[type=checkbox]{margin:0;cursor:pointer}.tag-name{font-size:14px;color:#2c3e50}.selected-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.selected-tag{display:flex;align-items:center;gap:4px;background:#3498db;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.remove-tag{background:none;border:none;color:#fff;font-size:14px;cursor:pointer;padding:0;margin-left:2px;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.remove-tag:hover{background:#fff3}@media (max-width: 768px){.filter-content{grid-template-columns:1fr;gap:16px;padding:16px}.filter-header{flex-direction:column;gap:12px;text-align:center}.clear-filters-btn{width:100%}}@media (max-width: 480px){.filter-header,.filter-content{padding:12px 16px}.search-input{font-size:16px}}.new-atom-stats-panel{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow:hidden}.stats-header{padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.stats-header h3{margin:0;color:#2c3e50;font-size:16px;font-weight:600}.stats-content{padding:20px}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-card.total{border-left-color:#3498db}.stat-card.tags{border-left-color:#9b59b6}.stat-card.duration{border-left-color:#e67e22}.stat-card.types{border-left-color:#27ae60}.stat-icon{font-size:24px;opacity:.8}.stat-info{flex:1}.stat-value{font-size:20px;font-weight:700;color:#2c3e50;line-height:1;margin-bottom:4px}.stat-label{font-size:12px;color:#7f8c8d;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stats-by-type{border-top:1px solid #e9ecef;padding-top:20px}.stats-by-type h4{margin:0 0 16px;color:#2c3e50;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.type-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.type-stat-item{padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;transition:all .2s ease}.type-stat-item:hover{background:#ecf0f1;border-color:#bdc3c7}.type-stat-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.type-icon{font-size:16px}.type-name{font-size:14px;font-weight:500;color:#2c3e50;flex:1}.type-stat-data{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.type-count{font-size:16px;font-weight:600;color:#2c3e50}.type-percentage{font-size:12px;color:#7f8c8d;font-weight:500}.type-progress-bar{height:4px;border-radius:2px;background:#f1f3f4;overflow:hidden}@media (max-width: 768px){.stats-overview{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:12px;gap:8px}.stat-icon{font-size:20px}.stat-value{font-size:18px}.stat-label{font-size:11px}.type-stats-grid{grid-template-columns:1fr;gap:8px}.stats-content{padding:16px}}@media (max-width: 480px){.stats-overview{grid-template-columns:1fr}.stat-card{padding:10px}.stat-icon{font-size:18px}.stat-value{font-size:16px}.type-stat-item{padding:10px}.stats-content{padding:12px}.stats-header{padding:12px 16px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.new-atom-stats-panel,.stat-card,.type-stat-item{animation:fadeInUp .3s ease-out}.atom-create-form-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.atom-create-form{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.form-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.progress-fill{background:linear-gradient(90deg,#3b82f6,#1d4ed8);height:100%;border-radius:8px;transition:width .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.readonly-input{background:#f3f4f6!important;color:#4b5563!important;cursor:not-allowed!important;border-color:#d1d5db!important}.add-tag-btn{background:#3b82f6;color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.add-tag-btn:hover:not(:disabled){background:#2563eb}.tag{display:inline-flex;align-items:center;gap:6px;background:#3b82f6;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.submit-btn{background:#3b82f6;color:#fff;border-color:#3b82f6}.submit-btn:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.auto-generated-field{background-color:#f8f9fa!important;color:#6c757d!important;cursor:not-allowed!important}.field-hint{display:block;margin-top:4px;color:#6c757d;font-size:12px;font-style:italic}@media (max-width: 768px){.atom-create-form-overlay{padding:10px}.atom-create-form{max-width:100%}.form-row{grid-template-columns:1fr;gap:12px}.form-header{padding:16px 20px}.form-content{padding:20px}.tag-input-container{flex-direction:column}.add-tag-btn{align-self:flex-start}.form-actions{flex-direction:column-reverse}.cancel-btn,.submit-btn{width:100%}}.atom-create-form-overlay{animation:fadeIn .2s ease-out}.atom-create-form{animation:slideUp .3s ease-out}.detecting-indicator{color:#f59e0b;font-weight:500;font-size:.875rem;animation:pulse 1.5s ease-in-out infinite}.detected-indicator{color:#10b981;font-weight:500;font-size:.875rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.duration-info{display:block;margin-top:4px;color:#10b981;font-weight:500;font-size:.875rem;background-color:#d1fae5;padding:4px 8px;border-radius:4px;border:1px solid #a7f3d0}.field-hint{display:block;margin-top:4px;color:#6b7280;font-size:.875rem;font-style:italic}input:disabled.detecting{background-color:#fef3c7;border-color:#fbbf24;color:#92400e}.audio-preview{margin-top:12px;padding:12px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.audio-preview label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:.875rem}.audio-preview audio{width:100%;height:40px;border-radius:6px;outline:none}.audio-preview audio:focus{box-shadow:0 0 0 2px #3b82f6}.file-preview{border:1px solid #e1e5e9;border-radius:8px;background:#fff;overflow:hidden;box-shadow:0 2px 8px #0000001a;margin:16px 0}.file-preview.unsupported{border-color:#f0f0f0}.preview-header{padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e1e5e9;display:flex;justify-content:space-between;align-items:center}.preview-header h4{margin:0;font-size:14px;font-weight:600;color:#333}.file-info{display:flex;flex-direction:column;align-items:flex-end}.file-name,.file-path{font-size:12px;color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-content{padding:16px}.preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#999}.placeholder-icon{font-size:48px;margin-bottom:12px}.placeholder-text{font-size:14px}.pag-preview{display:flex;flex-direction:column;gap:16px}.pag-canvas-container{position:relative;display:flex;justify-content:center;align-items:center;background:#f5f5f5;border-radius:6px;min-height:300px}.pag-canvas{max-width:100%;max-height:400px;border-radius:4px;box-shadow:0 2px 8px #0000001a}.pag-loading,.pag-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:#ffffffe6;border-radius:6px;box-shadow:0 2px 8px #0000001a}.pag-error{color:#e74c3c}.error-icon{font-size:24px}.retry-btn{background:#28a745;color:#fff;border:none;border-radius:4px;padding:6px 12px;cursor:pointer;font-size:12px;margin-top:8px;transition:background-color .2s}.retry-btn:hover:not(:disabled){background:#218838}.retry-btn:disabled{background:#ccc;cursor:not-allowed}.pag-controls{display:flex;flex-direction:column;gap:12px;padding:12px;background:#f8f9fa;border-radius:6px}.control-buttons{display:flex;gap:8px;justify-content:center}.control-btn{background:#007bff;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:16px;transition:background-color .2s;min-width:40px}.control-btn:hover:not(:disabled){background:#0056b3}.control-btn:disabled{background:#ccc;cursor:not-allowed}.progress-container{display:flex;align-items:center;gap:12px}.time-display{font-size:12px;color:#666;min-width:40px;text-align:center}.progress-slider{flex:1;height:4px;background:#e1e5e9;border-radius:2px;outline:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background:#007bff;border-radius:50%;cursor:pointer}.progress-slider::-moz-range-thumb{width:16px;height:16px;background:#007bff;border-radius:50%;cursor:pointer;border:none}.audio-preview{display:flex;flex-direction:column;gap:16px}.audio-info{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:6px}.audio-icon{font-size:32px;color:#007bff}.file-details{flex:1}.file-name{font-weight:600;color:#333;margin-bottom:4px}.file-meta{font-size:12px;color:#666;display:flex;align-items:center;gap:6px}.separator{color:#ccc}.audio-loading,.audio-error{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;background:#f8f9fa;border-radius:6px}.audio-error{color:#e74c3c;background:#fdf2f2}.audio-controls{display:flex;flex-direction:column;gap:12px;padding:12px;background:#f8f9fa;border-radius:6px}.main-controls{display:flex;align-items:center;gap:12px}.volume-controls{display:flex;align-items:center;gap:8px;justify-content:center}.volume-slider{width:100px;height:4px;background:#e1e5e9;border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{appearance:none;width:14px;height:14px;background:#007bff;border-radius:50%;cursor:pointer}.volume-slider::-moz-range-thumb{width:14px;height:14px;background:#007bff;border-radius:50%;cursor:pointer;border:none}.loading-spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.file-preview{margin:12px 0}.preview-header{padding:10px 12px;flex-direction:column;align-items:flex-start;gap:8px}.file-info{align-items:flex-start;width:100%}.file-name,.file-path{max-width:100%}.preview-content{padding:12px}.pag-canvas{max-height:250px}.pag-controls,.audio-controls{padding:10px}.progress-container{flex-direction:column;gap:8px}.progress-slider{width:100%}.main-controls{flex-wrap:wrap;justify-content:center}.volume-controls{margin-top:8px}.audio-info{padding:10px}.file-meta{flex-wrap:wrap}}@media (max-width: 480px){.preview-header h4{font-size:13px}.file-name,.file-path{font-size:11px}.control-btn{padding:6px 10px;font-size:14px;min-width:36px}.time-display{font-size:11px;min-width:35px}.audio-icon{font-size:28px}.pag-canvas{max-height:200px}.volume-slider{width:80px}}@media (prefers-color-scheme: dark){.file-preview{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.preview-header{background:#1a202c;border-color:#4a5568}.preview-header h4{color:#e2e8f0}.file-name,.file-path{color:#a0aec0}.pag-canvas-container,.pag-controls,.audio-controls,.audio-info{background:#1a202c}.time-display,.file-meta{color:#a0aec0}.separator{color:#4a5568}.audio-loading{background:#1a202c}.audio-error{background:#742a2a;color:#fed7d7}}.atom-edit-form-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.atom-edit-form{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f0f9ff}.form-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#0369a1}.close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.close-btn:hover{background:#e5e7eb;color:#374151}.close-btn:disabled{opacity:.5;cursor:not-allowed}.form-content{padding:24px;overflow-y:auto;flex:1}.progress-bar{position:relative;background:#e5e7eb;border-radius:8px;height:8px;margin-bottom:20px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#0ea5e9,#0284c7);height:100%;border-radius:8px;transition:width .3s ease}.progress-text{position:absolute;top:12px;left:0;right:0;text-align:center;font-size:12px;color:#6b7280}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.field-note{margin-top:6px;font-size:12px;color:#6b7280;font-style:italic}.file-info{margin-top:8px;padding:8px 12px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;font-size:12px;color:#0369a1}.tag-input-container{display:flex;gap:8px;margin-bottom:12px}.tag-input-container input{flex:1;margin-bottom:0}.add-tag-btn{background:#0ea5e9;color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.add-tag-btn:hover:not(:disabled){background:#0284c7}.add-tag-btn:disabled{background:#9ca3af;cursor:not-allowed}.tags-display{display:flex;flex-wrap:wrap;gap:8px;min-height:32px;padding:8px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb}.tag{display:inline-flex;align-items:center;gap:6px;background:#0ea5e9;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.remove-tag-btn{background:none;border:none;color:#fff;font-size:14px;cursor:pointer;padding:0;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-tag-btn:hover:not(:disabled){background:#fff3}.remove-tag-btn:disabled{opacity:.5;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.cancel-btn,.submit-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.submit-btn{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.submit-btn:hover:not(:disabled){background:#0284c7;border-color:#0284c7}.cancel-btn:disabled,.submit-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.atom-edit-form-overlay{padding:10px}.atom-edit-form{max-width:100%}.form-row{grid-template-columns:1fr;gap:12px}.form-header{padding:16px 20px}.form-content{padding:20px}.tag-input-container{flex-direction:column}.add-tag-btn{align-self:flex-start}.form-actions{flex-direction:column-reverse}.cancel-btn,.submit-btn{width:100%}}.atom-edit-form-overlay{animation:fadeIn .2s ease-out}.atom-edit-form{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.duration-detection-status{margin-top:8px}.detection-info{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:6px;font-size:.875rem;font-weight:500;animation:slideUp .3s ease-out}.detection-icon{font-size:1rem;line-height:1}.detection-info.detecting{background-color:#fef3c7;color:#92400e;border:1px solid #fbbf24}.detection-info.success{background-color:#d1fae5;color:#065f46;border:1px solid #10b981}.detection-info.error{background-color:#fee2e2;color:#991b1b;border:1px solid #ef4444}.detection-info.unsupported{background-color:#e0e7ff;color:#3730a3;border:1px solid #6366f1}.detection-info.detecting .detection-icon{animation:spin 1s linear infinite}.atom-delete-confirm-overlay{position:fixed;inset:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1100;padding:20px}.atom-delete-confirm{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.confirm-header{display:flex;align-items:center;gap:12px;padding:24px;border-bottom:1px solid #e5e7eb;background:#fef2f2}.warning-icon{color:#dc2626;flex-shrink:0}.confirm-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#dc2626}.confirm-content{padding:24px;overflow-y:auto;flex:1}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.warning-text{margin-bottom:20px}.warning-text p{margin:0;color:#374151;line-height:1.5}.warning-text strong{color:#dc2626;font-weight:600}.atom-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:20px}.info-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:12px}.info-row:last-child{margin-bottom:0}.info-row .label{font-weight:500;color:#6b7280;min-width:80px;flex-shrink:0}.info-row .value{color:#111827;word-break:break-all;text-align:right}.danger-notice{display:flex;align-items:flex-start;gap:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px}.notice-icon{font-size:20px;flex-shrink:0}.notice-text{color:#374151;line-height:1.5}.notice-text strong{color:#dc2626;font-weight:600}.verify-text{margin-bottom:20px}.verify-text p{margin:0 0 12px;color:#374151;line-height:1.5}.expected-text{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;color:#111827;word-break:break-all}.verify-input{margin-bottom:16px}.verify-input input{width:100%;padding:12px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;box-sizing:border-box}.verify-input input:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.verify-input input:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.verify-status{min-height:24px}.status{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.status.match{color:#059669}.status.mismatch{color:#dc2626}.status-icon{font-weight:700;font-size:16px}.confirm-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.cancel-btn,.danger-btn,.delete-btn,.back-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.cancel-btn{background:#fff;color:#6b7280;border-color:#d1d5db}.cancel-btn:hover:not(:disabled){background:#f9fafb;color:#374151}.back-btn{background:#fff;color:#3b82f6;border-color:#3b82f6}.back-btn:hover:not(:disabled){background:#eff6ff}.danger-btn{background:#dc2626;color:#fff;border-color:#dc2626}.danger-btn:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.delete-btn{background:#dc2626;color:#fff;border-color:#dc2626}.delete-btn:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.cancel-btn:disabled,.danger-btn:disabled,.delete-btn:disabled,.back-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.atom-delete-confirm-overlay{padding:10px}.atom-delete-confirm{max-width:100%}.confirm-header,.confirm-content{padding:20px}.confirm-actions{padding:16px 20px;flex-direction:column-reverse}.cancel-btn,.danger-btn,.delete-btn,.back-btn{width:100%}.info-row{flex-direction:column;align-items:flex-start;gap:4px}.info-row .value{text-align:left}}.atom-delete-confirm-overlay{animation:fadeIn .2s ease-out}.atom-delete-confirm{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.new-atom-manager{padding:20px;max-width:1200px;margin:0 auto;background:#f8f9fa;min-height:100vh}.new-atom-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.new-atom-manager-header h2{margin:0;color:#2c3e50;font-size:24px;font-weight:600}.header-actions{display:flex;align-items:center;gap:12px}.refresh-button{background:#27ae60;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.refresh-button:hover{background:#229954;transform:translateY(-1px);box-shadow:0 4px 8px #27ae604d}.refresh-button:active{transform:translateY(0)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-container p{color:#7f8c8d;font-size:16px;margin:0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center}.error-container h3{color:#e74c3c;font-size:20px;margin:0 0 12px}.error-container p{color:#7f8c8d;font-size:16px;margin:0 0 20px;max-width:400px}.retry-button{background:#e74c3c;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 8px #e74c3c4d}.retry-button:active{transform:translateY(0)}.create-btn,.download-btn,.batch-delete-btn{border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;gap:8px;color:#fff}.create-btn{background:#007bff}.create-btn:hover{background:#0056b3;transform:translateY(-1px)}.batch-delete-btn{background:#dc3545}.batch-delete-btn:hover{background:#c82333;transform:translateY(-1px)}.batch-delete-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.download-btn{background:#28a745}.download-btn:hover{background:#218838;transform:translateY(-1px)}.download-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}@media (max-width: 768px){.new-atom-manager{padding:12px}.new-atom-manager-header{flex-direction:column;gap:16px;text-align:center}.new-atom-manager-header h2{font-size:20px}.header-actions{width:100%;justify-content:center}}.behavior-group-manager-page{display:flex;flex-direction:column;height:100vh;background-color:#f8f9fa;overflow:hidden}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-message{color:#ef4444;font-size:16px;margin-bottom:16px}.retry-button{padding:8px 16px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.retry-button:hover{background-color:#2563eb}.page-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.header-content{display:flex;align-items:center;gap:24px}.page-title{margin:0;font-size:20px;font-weight:600;color:#111827}.header-stats{display:flex;gap:16px}.stat-item{padding:4px 12px;background-color:#f3f4f6;border-radius:16px;font-size:14px;color:#6b7280}.header-actions{display:flex;gap:12px}.create-button,.generate-all-button,.refresh-button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.create-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.create-button:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.generate-all-button{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.generate-all-button:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.export-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.export-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.import-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.import-button:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.refresh-button{background-color:#6b7280;color:#fff}.refresh-button:hover{background-color:#4b5563}.behavior-group-filter{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 20px;flex-shrink:0}.filter-section{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.search-section{flex:1;min-width:300px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:#9ca3af;font-size:16px}.search-input{width:100%;padding:10px 12px 10px 40px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.clear-search-btn{position:absolute;right:8px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px}.clear-search-btn:hover{background-color:#f3f4f6;color:#6b7280}.category-section{display:flex;align-items:center;gap:8px}.filter-label{font-size:14px;font-weight:500;color:#374151}.category-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.category-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tags-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.tags-container{display:flex;flex-wrap:wrap;gap:6px}.tag-filter{padding:4px 8px;border:1px solid #d1d5db;border-radius:16px;background:#fff;font-size:12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px}.tag-filter:hover{border-color:#3b82f6;background-color:#f0f9ff}.tag-filter-active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.tag-check{font-size:10px}.clear-filters-section{margin-left:auto}.clear-filters-btn{padding:8px 16px;background-color:#ef4444;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.clear-filters-btn:hover{background-color:#dc2626}.filter-status{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.active-filters{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:flex;align-items:center;gap:6px;padding:4px 8px;background-color:#dbeafe;color:#1e40af;border-radius:16px;font-size:12px}.filter-chip-remove{background:none;border:none;color:#1e40af;cursor:pointer;padding:0;font-size:12px;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.filter-chip-remove:hover{background-color:#1e40af;color:#fff}.behavior-group-list{flex:1;overflow-y:auto;padding:24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;text-align:center;color:#6b7280}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{margin:0 0 8px;font-size:18px;color:#374151}.empty-state p{margin:0;font-size:14px}.behavior-group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.behavior-group-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:8px;padding:12px}.behavior-group-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0;border-bottom:none}.card-title-row{display:flex;justify-content:space-between;align-items:center;flex:1;min-width:0}.card-title{margin:0;font-size:15px;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-category{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;color:#fff}.card-actions{display:flex;gap:8px;justify-content:flex-start;align-items:center}.action-btn{height:32px;padding:0 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s;display:flex;align-items:center;gap:6px;min-width:60px}.import-btn{background-color:#10b981;color:#fff}.import-btn:hover{background-color:#059669}.edit-btn{background-color:#3b82f6;color:#fff}.edit-btn:hover{background-color:#2563eb}.duplicate-btn{background-color:#6b7280;color:#fff}.duplicate-btn:hover{background-color:#4b5563}.delete-btn{background-color:#ef4444;color:#fff}.delete-btn:hover{background-color:#dc2626}.card-content{display:flex;flex-direction:column;gap:8px;padding:0}.card-description{margin-bottom:6px}.card-description p{margin:0;font-size:14px;color:#6b7280;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.tag{padding:2px 6px;background-color:#f3f4f6;color:#6b7280;border-radius:8px;font-size:11px}.card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:6px}.stat-item{text-align:center;padding:4px;background-color:#f9fafb;border-radius:4px}.card-actions .stat-item{text-align:left;padding:4px 8px;background-color:#e0f2fe;border-radius:6px;min-width:80px;flex-shrink:0}.action-buttons{display:flex;gap:4px}.stat-label{display:block;font-size:11px;color:#6b7280;margin-bottom:2px}.stat-value{display:block;font-size:14px;font-weight:600;color:#111827}.card-tracks-preview{margin-bottom:10px}.tracks-header{margin-bottom:6px}.tracks-title{font-size:12px;font-weight:500;color:#6b7280}.tracks-list{display:flex;flex-direction:column;gap:3px}.track-preview{display:flex;align-items:center;gap:8px;padding:4px 8px;background-color:#f9fafb;border-radius:4px}.track-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.track-name{flex:1;font-size:12px;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-items{font-size:11px;color:#6b7280}.more-tracks{justify-content:center;transition:all .2s ease}.more-tracks:hover{background-color:#e5e7eb;transform:translateY(-1px)}.more-text{font-size:11px;color:#6b7280;font-style:italic;-webkit-user-select:none;user-select:none}.card-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background-color:#f9fafb;border-top:1px solid #f3f4f6}.card-metadata{display:flex;flex-direction:column;gap:2px}.metadata-item{display:flex;gap:4px;font-size:11px}.metadata-label{color:#6b7280}.metadata-value{color:#374151}.card-version{font-size:11px;color:#6b7280;background-color:#e5e7eb;padding:2px 6px;border-radius:8px}.behavior-group-form-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.behavior-group-form-container{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.form-title{margin:0;font-size:20px;font-weight:600;color:#111827}.form-close-btn{width:32px;height:32px;border:none;background:none;color:#6b7280;cursor:pointer;border-radius:6px;font-size:16px;transition:all .2s}.form-close-btn:hover{background-color:#f3f4f6;color:#374151}.behavior-group-form{padding:24px}.form-errors{margin-bottom:20px;padding:12px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px}.error-message{color:#dc2626;font-size:14px;margin:0}.form-info{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;padding:12px;background-color:#f9fafb;border-radius:6px}.info-item{display:flex;gap:8px;font-size:12px}.info-label{color:#6b7280;font-weight:500}.info-value{color:#374151}.form-label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.required{color:#ef4444}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tags-input-section{display:flex;flex-direction:column;gap:8px}.tag-input-wrapper{display:flex;gap:8px}.tag-input{flex:1}.add-tag-btn{padding:10px 16px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.add-tag-btn:hover:not(:disabled){background-color:#2563eb}.add-tag-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.tags-display{display:flex;flex-wrap:wrap;gap:6px}.tag-item{display:flex;align-items:center;gap:4px;padding:4px 8px;background-color:#dbeafe;color:#1e40af;border-radius:16px;font-size:12px}.tag-remove-btn{background:none;border:none;color:#1e40af;cursor:pointer;padding:0;font-size:12px;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.tag-remove-btn:hover{background-color:#1e40af;color:#fff}.tracks-info{padding:12px;background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:6px}.tracks-info p{margin:0 0 8px;font-size:14px;color:#0c4a6e}.tracks-note{font-size:12px!important;color:#0369a1!important}.form-note{padding:12px;background-color:#fffbeb;border:1px solid #fed7aa;border-radius:6px;margin-bottom:20px}.form-note p{margin:0;font-size:14px;color:#92400e}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e5e7eb}.form-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.form-btn:disabled{opacity:.5;cursor:not-allowed}.form-btn-cancel{background-color:#6b7280;color:#fff}.form-btn-cancel:hover:not(:disabled){background-color:#4b5563}.form-btn-secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.form-btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.form-btn-submit{background-color:#10b981;color:#fff}.form-btn-submit:hover:not(:disabled){background-color:#059669}.behavior-group-delete-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.behavior-group-delete-container{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.delete-header{display:flex;align-items:center;gap:12px;padding:20px 24px;border-bottom:1px solid #e5e7eb;position:relative}.delete-icon{font-size:24px}.delete-title{margin:0;font-size:20px;font-weight:600;color:#dc2626;flex:1}.delete-close-btn{position:absolute;right:20px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.delete-close-btn:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.delete-close-btn:disabled{opacity:.5;cursor:not-allowed}.delete-content{padding:24px}.delete-error{margin-bottom:16px;padding:12px 16px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;display:flex;align-items:center;gap:8px}.error-icon{font-size:16px;color:#dc2626}.error-text{color:#dc2626;font-size:14px;margin:0}.delete-warning{margin-bottom:20px;padding:16px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px}.warning-text{margin:0;font-size:16px;color:#dc2626;text-align:center}.delete-info{margin-bottom:20px;padding:16px;background-color:#f9fafb;border-radius:8px}.info-title{margin:0 0 12px;font-size:16px;font-weight:600;color:#374151}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.info-description{margin-bottom:12px}.description-text{margin:4px 0 0;font-size:14px;color:#6b7280;line-height:1.5}.info-tags{display:flex;flex-direction:column;gap:8px}.tags-list{display:flex;flex-wrap:wrap;gap:6px}.delete-confirm{margin-bottom:20px}.confirm-instruction{margin:0 0 12px;font-size:14px;color:#374151}.confirm-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.confirm-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.confirm-input-error{border-color:#ef4444}.confirm-error{margin:8px 0 0;font-size:12px;color:#ef4444;display:flex;align-items:center;gap:6px}.confirm-success{margin:8px 0 0;font-size:12px;color:#059669;display:flex;align-items:center;gap:6px}.success-icon{font-size:14px}.delete-impact{padding:16px;background-color:#fffbeb;border:1px solid #fed7aa;border-radius:8px}.impact-title{margin:0 0 12px;font-size:14px;font-weight:600;color:#92400e}.impact-list{margin:0;padding-left:20px;color:#92400e}.impact-list li{margin-bottom:4px;font-size:13px}.delete-actions{display:flex;gap:12px;justify-content:flex-end;padding:20px 24px;border-top:1px solid #e5e7eb}.delete-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn-cancel{background-color:#6b7280;color:#fff}.delete-btn-cancel:hover:not(:disabled){background-color:#4b5563}.delete-btn-confirm{background-color:#dc2626;color:#fff}.delete-btn-confirm:hover:not(:disabled){background-color:#b91c1c}.batch-delete-button{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.batch-delete-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.batch-select-header{padding:16px 0;border-bottom:1px solid #e5e7eb;margin-bottom:16px}.batch-select-all{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:#374151}.batch-select-all input[type=checkbox]{width:18px;height:18px;cursor:pointer}.batch-select-text{-webkit-user-select:none;user-select:none}.behavior-group-card{position:relative}.behavior-group-card.selected{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.card-select-checkbox{position:absolute;top:4px;right:4px;z-index:10;background:#fffffff2;border-radius:6px;padding:6px;box-shadow:0 2px 8px #00000026;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(0,0,0,.1)}.card-select-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.delete-confirm-content{padding:24px}.delete-warning{display:flex;align-items:flex-start;gap:12px;padding:16px;background-color:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:20px}.warning-icon{font-size:24px;flex-shrink:0}.warning-text h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#92400e}.warning-text p{margin:0;font-size:14px;color:#92400e}.delete-list{margin-bottom:20px}.delete-list h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#374151}.delete-items{max-height:200px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:6px;padding:8px}.delete-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:4px;margin-bottom:4px;background-color:#f9fafb}.delete-item:last-child{margin-bottom:0}.delete-item-name{font-weight:500;color:#374151}.delete-item-id{font-size:12px;color:#6b7280}.confirm-input-section{margin-bottom:20px}.confirm-label{display:block;margin-bottom:8px;font-size:14px;color:#374151}.confirm-label strong{color:#ef4444}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid #ffffff;border-radius:50%;border-top-color:transparent;animation:spin 1s ease-in-out infinite}@media (max-width: 768px){.page-header{flex-direction:column;gap:16px;align-items:stretch}.header-content{flex-direction:column;gap:12px;align-items:flex-start}.header-stats{flex-wrap:wrap}.filter-section{flex-direction:column;align-items:stretch}.search-section{min-width:auto}.behavior-group-grid,.card-stats,.info-grid{grid-template-columns:1fr}.form-actions,.delete-actions{flex-direction:column}}@media (max-width: 480px){.behavior-group-form-overlay,.behavior-group-delete-overlay{padding:10px}.behavior-group-form-container,.behavior-group-delete-container{max-height:95vh}.card-header{flex-direction:column;gap:12px;align-items:stretch}.card-actions{margin-left:0;justify-content:flex-end}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.login-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 40px #0000001a;position:relative;z-index:10;animation:slideInUp .8s ease-out;border:1px solid rgba(255,255,255,.2)}.login-form,.form-group{margin-bottom:20px}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;font-size:14px}.checkbox-wrapper{display:flex;align-items:center;cursor:pointer;color:#4a5568}.checkbox-input{display:none}.checkbox-custom{width:18px;height:18px;border:2px solid #e2e8f0;border-radius:4px;margin-right:8px;position:relative;transition:all .3s ease}.checkbox-input:checked+.checkbox-custom{background:#667eea;border-color:#667eea}.checkbox-input:checked+.checkbox-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.forgot-password{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s ease}.forgot-password:hover{color:#5a67d8;text-decoration:underline}.login-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;margin-bottom:15px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.demo-login{text-align:center;margin-bottom:20px}.signup-link{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease}.signup-link:hover{color:#5a67d8;text-decoration:underline}.wave{position:absolute;bottom:0;left:0;width:200%;height:100%;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,0V46.29c47.79,22.2,103.59,32.17,158,28,70.36-5.37,136.33-33.31,206.8-37.5C438.64,32.43,512.34,53.67,583,72.05c69.27,18,138.3,24.88,209.4,13.08,36.15-6,69.85-17.84,104.45-29.34C989.49,25,1113-14.29,1200,52.47V0Z' opacity='.25' fill='%23ffffff'%3E%3C/path%3E%3Cpath d='M0,0V15.81C13,36.92,27.64,56.86,47.69,72.05,99.41,111.27,165,111,224.58,91.58c31.15-10.15,60.09-26.07,89.67-39.8,40.92-19,84.73-46,130.83-49.67,36.26-2.85,70.9,9.42,98.6,31.56,31.77,25.39,62.32,62,103.63,73,40.44,10.79,81.35-6.69,119.13-24.28s75.16-39,116.92-43.05c59.73-5.85,113.28,22.88,168.9,38.84,30.2,8.66,59,6.17,87.09-7.5,22.43-10.89,48-26.93,60.65-49.24V0Z' opacity='.5' fill='%23ffffff'%3E%3C/path%3E%3Cpath d='M0,0V5.63C149.93,59,314.09,71.32,475.83,42.57c43-7.64,84.23-20.12,127.61-26.46,59-8.63,112.48,12.24,165.56,35.4C827.93,77.22,886,95.24,951.2,90c86.53-7,172.46-45.71,248.8-84.81V0Z' fill='%23ffffff'%3E%3C/path%3E%3C/svg%3E");background-size:50% 100%;animation:wave 10s linear infinite}@media (max-width: 768px){.login-card{margin:20px;padding:30px 25px;max-width:100%}.app-title{font-size:24px}.form-input{padding:14px 45px 14px 16px;font-size:16px}.login-button{padding:14px}.floating-shape{display:none}}@media (max-width: 480px){.login-card{padding:25px 20px}.card-header{margin-bottom:25px}.logo-icon{width:50px;height:50px;font-size:20px}.app-title{font-size:22px}.form-options{flex-direction:column;gap:10px;align-items:flex-start}}@media (prefers-color-scheme: dark){.login-card{background:#1a202cf2;border-color:#ffffff1a}.app-title{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-input{background:#1a202ccc;border-color:#4a5568;color:#fff}.form-input:focus{border-color:#667eea}.form-input::placeholder{color:#718096}}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.particles-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.background-decoration{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2;pointer-events:none}.floating-shape{position:absolute;border-radius:50%;background:#ffffff1a;animation:float 6s ease-in-out infinite}.shape-1{width:80px;height:80px;top:20%;left:10%;animation-delay:0s}.shape-2{width:120px;height:120px;top:60%;right:15%;animation-delay:2s}.shape-3{width:60px;height:60px;bottom:20%;left:20%;animation-delay:4s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.register-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px;width:100%;max-width:480px;box-shadow:0 20px 40px #0000001a;position:relative;z-index:10;animation:slideInUp .8s ease-out;border:1px solid rgba(255,255,255,.2)}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.card-header{text-align:center;margin-bottom:30px}.logo-container{margin-bottom:20px}.logo-icon{width:60px;height:60px;margin:0 auto 15px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;box-shadow:0 8px 20px #667eea4d}.app-title{font-size:28px;font-weight:700;color:#2d3748;margin:0 0 8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{font-size:14px;color:#718096;margin:0;font-weight:500}.register-form,.form-group{margin-bottom:20px}.input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:16px 50px 16px 20px;border:2px solid #e2e8f0;border-radius:12px;font-size:16px;transition:all .3s ease;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:translateY(-2px)}.form-input::placeholder{color:#a0aec0}.form-input.error{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1a}.form-input.error:focus{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e33}.input-icon{position:absolute;right:15px;color:#a0aec0;width:20px;height:20px}.password-toggle{position:absolute;right:15px;background:none;border:none;color:#a0aec0;cursor:pointer;padding:5px;border-radius:5px;transition:all .3s ease;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#667eea;background:#667eea1a}.error-message{color:#e53e3e;font-size:12px;margin-top:5px;margin-left:5px;display:flex;align-items:center;gap:4px}.error-message:before{content:"⚠";font-size:10px}.help-text{display:flex;align-items:center;gap:8px;margin-top:8px;margin-left:5px;font-size:12px;color:#718096;background:#667eea1a;padding:8px 12px;border-radius:8px;border-left:3px solid #667eea}.help-text svg{width:16px;height:16px;color:#667eea;flex-shrink:0}.register-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;margin-bottom:15px}.register-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.register-button:active:not(:disabled){transform:translateY(0)}.register-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:10px}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.demo-fill{text-align:center;margin-bottom:20px}.demo-button{background:none;border:2px solid #e2e8f0;color:#4a5568;padding:12px 24px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s ease;font-weight:500}.demo-button:hover{border-color:#667eea;color:#667eea;background:#667eea0d}.card-footer{text-align:center;font-size:14px;color:#4a5568}.login-link{background:none;border:none;color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease;cursor:pointer;padding:0;font-size:inherit}.login-link:hover{color:#5a67d8;text-decoration:underline}.bottom-decoration{position:absolute;bottom:0;left:0;width:100%;height:150px;z-index:3;pointer-events:none}.wave{position:absolute;bottom:0;left:0;width:200%;height:100%;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,0V46.29c47.79,22.2,103.59,32.17,158,28,70.36-5.37,136.33-33.31,206.8-37.5C438.64,32.43,512.34,53.67,583,72.05c69.27,18,138.3,24.88,209.4,13.08,36.15-6,69.85-17.84,104.45-29.34C989.49,25,1113-14.29,1200,52.47V0Z' opacity='.25' fill='%23ffffff'%3E%3C/path%3E%3Cpath d='M0,0V15.81C13,36.92,27.64,56.86,47.69,72.05,99.41,111.27,165,111,224.58,91.58c31.15-10.15,60.09-26.07,89.67-39.8,40.92-19,84.73-46,130.83-49.67,36.26-2.85,70.9,9.42,98.6,31.56,31.77,25.39,62.32,62,103.63,73,40.44,10.79,81.35-6.69,119.13-24.28s75.16-39,116.92-43.05c59.73-5.85,113.28,22.88,168.9,38.84,30.2,8.66,59,6.17,87.09-7.5,22.43-10.89,48-26.93,60.65-49.24V0Z' opacity='.5' fill='%23ffffff'%3E%3C/path%3E%3Cpath d='M0,0V5.63C149.93,59,314.09,71.32,475.83,42.57c43-7.64,84.23-20.12,127.61-26.46,59-8.63,112.48,12.24,165.56,35.4C827.93,77.22,886,95.24,951.2,90c86.53-7,172.46-45.71,248.8-84.81V0Z' fill='%23ffffff'%3E%3C/path%3E%3C/svg%3E");background-size:50% 100%;animation:wave 10s linear infinite}.wave-1{animation-delay:0s;opacity:.3}.wave-2{animation-delay:-5s;opacity:.2}.wave-3{animation-delay:-10s;opacity:.1}@keyframes wave{0%{transform:translate(0)}to{transform:translate(-50%)}}.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (max-width: 768px){.register-card{margin:20px;padding:30px 25px;max-width:100%}.app-title{font-size:24px}.form-input{padding:14px 45px 14px 16px;font-size:16px}.register-button{padding:14px}.floating-shape{display:none}}@media (max-width: 480px){.register-card{padding:25px 20px}.card-header{margin-bottom:25px}.logo-icon{width:50px;height:50px;font-size:20px}.app-title{font-size:22px}.help-text{font-size:11px;padding:6px 10px}}@media (prefers-color-scheme: dark){.register-card{background:#1a202cf2;border-color:#ffffff1a}.app-title{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-input{background:#1a202ccc;border-color:#4a5568;color:#fff}.form-input:focus{border-color:#667eea}.form-input::placeholder{color:#718096}.help-text{background:#667eea26;color:#a0aec0}}.version-manager-page{padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{margin:0;color:#1f2937;font-size:28px;font-weight:600}.btn-create{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-create:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-create:active{transform:translateY(0);box-shadow:0 2px 4px #3b82f64d}.version-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 2px 4px #0000000d;transition:all .3s ease;position:relative;overflow:hidden}.version-item:hover{box-shadow:0 4px 12px #0000001a;border-color:#d1d5db;transform:translateY(-2px)}.version-item.current{border-color:#3b82f6;background:linear-gradient(135deg,#f8faff,#fff)}.version-item.current:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#3b82f6,#1d4ed8)}.version-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.version-info{flex:1;min-width:0}.version-name{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px;display:flex;align-items:center;gap:12px;line-height:1.4}.current-badge{display:inline-flex;align-items:center;padding:4px 8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;font-size:12px;font-weight:500;border-radius:6px;white-space:nowrap}.version-desc{color:#6b7280;font-size:14px;line-height:1.5;margin:0;word-break:break-word}.version-actions{display:flex;gap:8px;flex-shrink:0;align-items:flex-start}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid transparent;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;min-height:36px}.btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f61a}.btn svg{flex-shrink:0}.btn-edit{background:#f3f4f6;color:#374151;border-color:#d1d5db}.btn-edit:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af;color:#1f2937}.btn-set-current{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981}.btn-set-current:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);border-color:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.btn-delete{background:#fef2f2;color:#dc2626;border-color:#fecaca}.btn-delete:hover:not(:disabled){background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.btn-delete:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb;color:#9ca3af;border-color:#e5e7eb}.version-meta{display:flex;gap:24px;padding-top:16px;border-top:1px solid #f3f4f6}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.meta-value{font-size:13px;color:#374151;font-weight:400}@media (max-width: 768px){.version-header{flex-direction:column;align-items:stretch;gap:12px}.version-actions{justify-content:flex-end}.btn{padding:6px 10px;font-size:12px;min-height:32px}.version-meta{flex-direction:column;gap:12px}}@media (max-width: 480px){.version-item{padding:16px}.version-actions{flex-wrap:wrap;gap:6px}.btn{flex:1;justify-content:center;min-width:0}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.modal-header h2{margin:0;color:#1f2937;font-size:20px;font-weight:600}.close-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#f3f4f6;color:#374151}.modal-form{padding:0 24px 24px}.form-group label{display:block;margin-bottom:6px;color:#374151;font-weight:500;font-size:14px}.form-group textarea{resize:vertical;min-height:80px}.error-text{display:block;color:#ef4444;font-size:12px;margin-top:4px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:20px;border-top:1px solid #e5e7eb}.btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover:not(:disabled){background:#e5e7eb}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.loading-spinner{animation:spin 1s linear infinite}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:#1f2937}.modal-close-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#6b7280;transition:all .2s}.modal-close-btn:hover{background-color:#f3f4f6;color:#374151}.modal-close-btn:disabled{cursor:not-allowed;opacity:.5}.modal-form{padding:20px 24px 24px}.form-group:last-child{margin-bottom:0}.form-input,.form-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px}.form-input.error,.form-textarea.error{border-color:#ef4444}.form-input.error:focus,.form-textarea.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-hint{display:block;margin-top:4px;font-size:12px;color:#6b7280}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent;display:inline-flex;align-items:center;gap:6px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-cancel{background-color:#fff;color:#374151;border-color:#d1d5db}.btn-cancel:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.btn-primary{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.btn-primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.btn-primary:active:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8}.loading-spinner{width:14px;height:14px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.modal-content{width:95%;margin:20px}.modal-header,.modal-form{padding-left:16px;padding-right:16px}.modal-actions{flex-direction:column-reverse}.btn{width:100%;justify-content:center}}.firmware-card{background:#fff;border:1px solid #e1e5e9;border-radius:8px;padding:20px;margin-bottom:16px;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.firmware-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.firmware-card.current{border-color:#4caf50;background:linear-gradient(135deg,#f8fff8,#fff)}.firmware-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #f0f0f0}.firmware-name{margin:0;font-size:18px;font-weight:600;color:#333}.current-badge{background:#4caf50;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.firmware-info{margin-bottom:20px}.info-row{display:flex;margin-bottom:8px;align-items:flex-start}.info-label{font-weight:500;color:#666;min-width:80px;margin-right:12px;flex-shrink:0}.info-value{color:#333;word-break:break-all;flex:1}.info-value.md5{font-family:Courier New,monospace;font-size:13px;background:#f5f5f5;padding:2px 6px;border-radius:4px}.info-value.filepath{font-family:Courier New,monospace;font-size:13px;background:#f0f8ff;padding:2px 6px;border-radius:4px;color:#06c}.info-value.description{line-height:1.5}.firmware-actions{display:flex;gap:12px;justify-content:flex-end}.btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;min-width:80px}.btn:hover{transform:translateY(-1px)}.btn-download{background:#2196f3;color:#fff}.btn-download:hover{background:#1976d2;box-shadow:0 2px 4px #2196f34d}.btn-set-current{background:#4caf50;color:#fff}.btn-set-current:hover{background:#45a049;box-shadow:0 2px 4px #4caf504d}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{background:#d32f2f;box-shadow:0 2px 4px #f443364d}.btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.btn:disabled:hover{transform:none;box-shadow:none}@media (max-width: 768px){.firmware-card{padding:16px}.firmware-card-header{flex-direction:column;align-items:flex-start;gap:8px}.info-row{flex-direction:column;gap:4px}.info-label{min-width:auto;margin-right:0}.firmware-actions{justify-content:stretch}.btn{flex:1}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:#111827}.close-button{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-button:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.close-button:disabled{opacity:.5;cursor:not-allowed}.firmware-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group input:disabled,.form-group textarea:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.disabled-input{background-color:#f9fafb!important;color:#6b7280!important}.help-text{display:block;margin-top:4px;font-size:12px;color:#6b7280}.error-message{display:block;margin-top:4px;font-size:12px;color:#ef4444}.submit-error{margin-bottom:16px;padding:8px 12px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;font-size:14px}.file-upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:16px;text-align:center;transition:all .2s ease}.file-upload-area:hover{border-color:#3b82f6;background-color:#f8faff}.file-select-button{background-color:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease}.file-select-button:hover:not(:disabled){background-color:#2563eb}.file-select-button:disabled{background-color:#9ca3af;cursor:not-allowed}.file-info{margin-top:12px;padding:8px 12px;background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;text-align:left}.file-name{font-weight:500;color:#0369a1}.file-size{color:#6b7280;font-size:12px;margin-left:8px}.upload-progress{margin-bottom:16px}.progress-bar{width:100%;height:8px;background-color:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);transition:width .3s ease;border-radius:4px}.progress-text{font-size:12px;color:#6b7280;text-align:center;display:block}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.cancel-button,.submit-button{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.cancel-button{background-color:#fff;color:#6b7280;border-color:#d1d5db}.cancel-button:hover:not(:disabled){background-color:#f9fafb;color:#374151}.submit-button{background-color:#3b82f6;color:#fff}.submit-button:hover:not(:disabled){background-color:#2563eb}.cancel-button:disabled,.submit-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.modal-content{width:95%;margin:20px}.modal-header,.firmware-form{padding:16px}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.firmware-list-container{max-width:1200px;margin:0 auto;padding:20px}.firmware-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 0;border-bottom:1px solid #e5e7eb}.header-info{display:flex;align-items:center;gap:12px}.header-actions{display:flex;gap:12px;align-items:center}.header-info{display:flex;align-items:center;gap:16px}.header-info h2{margin:0;font-size:24px;font-weight:600;color:#333}.firmware-count{background:#f5f5f5;color:#666;padding:4px 12px;border-radius:12px;font-size:14px}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.btn-add{background-color:#3b82f6;color:#fff}.btn-add:hover:not(:disabled){background-color:#2563eb}.btn-refresh{background-color:#6366f1;color:#fff;border:1px solid #6366f1}.btn-refresh:hover:not(:disabled){background-color:#5855eb;border-color:#5855eb;box-shadow:0 2px 4px #6366f14d}.btn:disabled{opacity:.5;cursor:not-allowed}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#666;font-size:16px;margin:0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-message{color:#f44336;font-size:16px;margin-bottom:20px}.btn-retry{background:#f44336;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.btn-retry:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 4px #f443364d}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-message{color:#666;font-size:16px;margin-bottom:20px}.current-firmware-section{margin-bottom:32px}.current-firmware-section h3,.all-firmware-section h3{font-size:18px;font-weight:600;color:#333;margin-bottom:16px;padding-left:8px;border-left:4px solid #2196F3}.all-firmware-section{margin-top:32px}.firmware-list{display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.firmware-list-container{padding:16px}.firmware-list-header{flex-direction:column;align-items:flex-start;gap:16px}.header-info{flex-direction:column;align-items:flex-start;gap:8px}.header-info h2{font-size:20px}.btn-refresh{align-self:stretch;text-align:center}.loading-container,.error-container,.empty-container{padding:40px 16px}}@media (max-width: 480px){.firmware-list-container{padding:12px}.header-info h2{font-size:18px}.firmware-count{font-size:12px;padding:3px 8px}}.firmware-page{min-height:100vh;background:#f5f5f5;padding:0}
