.login-container{background-color:#f8f9fa;border:none;border-radius:8px;box-shadow:0 4px 12px #00000026;left:50%;margin:0;max-width:400px;padding:30px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.login-container h2{color:#212529;font-size:2rem;font-weight:600;margin-bottom:30px}.login-container input{background-color:#fff;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;display:block;font-size:1rem;margin:15px 0;padding:12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.login-container input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40;outline:none}.login-container button{align-items:center;background-color:#2563eb;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;height:48px;justify-content:center;margin-top:20px;padding:12px;transition:all .2s ease;width:100%}.login-container button:hover{background-color:#1d4ed8;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.login-container button:active{background-color:#1e40af;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.error-message{margin-top:15px}.loading-spinner{height:24px;margin-right:8px;width:24px}.loading-spinner .spinner{border:2px solid #ffffff4d;border-top-color:#fff}.hub-container{align-items:center;background-color:#f8f9fa;display:flex;flex-direction:column;font-family:Arial,sans-serif;justify-content:center;min-height:100vh;padding:20px;text-align:center}.hub-container h1{color:#2c3e50;font-size:2.2rem;font-weight:700;letter-spacing:.5px;margin-bottom:40px}.hub-container button{align-items:center;background-color:#2563eb;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;height:48px;justify-content:center;margin:8px 0;min-width:200px;padding:12px 24px;transition:all .2s ease}.hub-container button:hover{background-color:#1d4ed8;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.hub-container button:active{background-color:#1e40af;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.hub-container .logout-button{background-color:#dc3545;font-size:.95rem;height:40px;margin-top:24px;min-width:150px}.hub-container .logout-button:hover{background-color:#b02a37}.hub-container .logout-button:active{background-color:#7f1e27}.feature-container{margin:10px 0;position:relative}button.maintenance{cursor:not-allowed;opacity:.6}.maintenance-indicator{color:#e74c3c;display:block;font-size:.9em;margin-top:5px}.create-user-container{background-color:#f8f9fa;border-radius:8px;box-shadow:0 4px 12px #00000026;left:50%;margin:0;max-width:500px;padding:35px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.create-user-container h1{color:#212529;font-size:2rem;font-weight:600;margin-bottom:30px}.create-user-container form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);text-align:left}.create-user-container form label:first-child,.create-user-container form label:nth-child(2){grid-column:span 2}.create-user-container label{color:#495057;display:flex;flex-direction:column;font-size:.95rem;font-weight:500;gap:8px}.create-user-container input,.create-user-container select{background-color:#fff;border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:12px;transition:all .2s ease;width:100%}.create-user-container input:focus,.create-user-container select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.create-user-container select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:40px}.create-user-container button[type=submit]{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;grid-column:span 2;margin-top:10px;padding:12px;transition:all .2s ease}.create-user-container button[type=submit]:hover{background-color:#0056b3;transform:translateY(-1px)}.create-user-container p.success-message{background-color:#28a7451a;color:#28a745}.create-user-container p.error-message,.create-user-container p.success-message{border-radius:6px;font-size:.95rem;grid-column:span 2;margin-top:20px;padding:12px;text-align:center;white-space:pre-line;width:100%}.create-user-container p.error-message{background-color:#dc35451a;color:#dc3545}.create-user-container p:empty{display:none}.create-user-container p[style*="color: red"],.error-message{background-color:#dc35451a;color:#dc3545}body:before{background:linear-gradient(135deg,#f8f9fa 25%,#0000 0) -50px 0,linear-gradient(225deg,#f8f9fa 25%,#0000 0) -50px 0,linear-gradient(315deg,#f8f9fa 25%,#0000 0),linear-gradient(45deg,#f8f9fa 25%,#0000 0);background-color:#fff;background-size:100px 100px;content:"";height:100%;left:0;opacity:.5;position:fixed;top:0;width:100%;z-index:-1}.training-container{display:flex;flex-direction:row;gap:30px;height:calc(100vh - 60px);justify-content:space-between;margin:0 auto;max-width:1800px;min-height:600px;overflow-y:hidden;padding:80px 20px 20px;width:100%}.video-section{align-items:center;display:flex;flex:2 1;flex-direction:column;gap:15px;min-width:0}.training-video-container,.video-section{flex-shrink:0;position:relative;width:100%}.training-video-container{aspect-ratio:16/9;background-color:#000;border-radius:8px;display:grid;margin-top:5px;max-width:min(1600px,calc(177.77778vh - 604.44444px));overflow:hidden;place-items:center;transition:all .3s ease}.training-video-container.recording-active{box-shadow:0 0 20px #4caf504d;outline:15px solid #4caf50}.video-preview{display:block;grid-area:1/1;height:100%;object-fit:contain;width:100%}.video-playback{align-items:center;display:flex;flex-direction:column;gap:35px;margin:0 auto;max-width:min(1600px,calc(177.77778vh - 515.55556px));position:relative;width:100%}.video-playback .video-preview{background-color:#000;border-radius:8px;max-height:calc(100vh - 250px);object-fit:contain;width:100%}.controls{display:flex;gap:12px;justify-content:center;margin:5px 0;max-width:400px;width:100%}.back-button,.record-button,.stop-button{align-items:center;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;height:40px;justify-content:center;min-width:140px;padding:8px 20px;text-align:center;transition:all .2s ease}.record-button{background-color:#2563eb;color:#fff}.record-button:hover{background-color:#1d4ed8;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.record-button:active{background-color:#1e40af;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.stop-button{background-color:#dc3545;color:#fff}.stop-button:hover{background-color:#b02a37;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.stop-button:active{background-color:#7f1e27;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.back-button{background-color:#4a5568;color:#fff}.back-button:hover{background-color:#2d3748;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.back-button:active{background-color:#1a202c;box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.video-playback .back-button{align-items:center;background-color:#4a5568;border:none;border-radius:8px;bottom:auto;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;height:48px;justify-content:center;left:auto;min-width:200px;padding:12px 24px;position:relative;transform:none;transition:all .2s ease;z-index:1000}.video-playback .back-button:hover{background-color:#2d3748;box-shadow:0 4px 12px #00000040;transform:translateY(-2px)}.video-playback .back-button:active{background-color:#1a202c;box-shadow:0 2px 4px #0003;transform:translateY(0)}.gesture-dropdown{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:1rem;height:40px;min-width:200px;padding:8px 12px;transition:border-color .2s ease}.gesture-dropdown:hover{border-color:#007bff}.gesture-dropdown:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.error-message{background-color:#dc35451a;font-size:.9rem;padding:10px 15px;width:100%}.my-videos-section{background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex:1 1;flex-direction:column;gap:20px;max-height:calc(100vh - 120px);max-width:450px;min-width:350px;overflow:hidden;padding:20px}.my-videos-section h3{color:#212529;font-size:1.5rem;font-weight:600;margin:0}.videos-list{display:flex;flex-direction:column;gap:15px;list-style:none;margin:0;padding:0}.video-list{flex:1 1;min-height:0;overflow-y:auto;padding-right:8px}.videos-list li{grid-gap:12px;background-color:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;display:grid;gap:12px;grid-template-columns:40px 100px 1fr auto;position:relative;transition:transform .2s ease,box-shadow .2s ease}.videos-list li:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.video-checkbox{cursor:pointer;height:20px;justify-self:center;margin:0;position:static;transform:none;width:20px}.video-thumbnail{border-radius:6px;height:75px;width:100px}.video-info{padding-right:8px}.videos-list p{color:#495057;margin:4px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.videos-list p:first-of-type{color:#212529;font-weight:600}.video-list::-webkit-scrollbar{width:8px}.video-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.video-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.video-list::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:1400px){.training-container{flex-direction:column;height:auto;min-height:auto;padding-bottom:20px}.video-section{width:100%}.video-preview{max-width:100%}.video-playback .video-preview{aspect-ratio:16/9}.my-videos-section{margin-bottom:20px;max-height:400px;max-width:1200px;width:100%}}@media (max-width:768px){.video-playback .video-preview,.video-preview{aspect-ratio:16/9}.video-playback .back-button{font-size:1rem;height:44px;min-width:180px;padding:10px 20px}}.videos-header{border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;padding-bottom:12px}.batch-tabs{border-bottom:1px solid #dee2e6;display:flex;gap:2px;margin-bottom:4px}.batch-tabs button{background:none;border:none;border-bottom:3px solid #0000;border-radius:4px 4px 0 0;color:#555;font-size:.9rem;margin-bottom:-1px;padding:6px 12px;transition:background-color .2s ease,color .2s ease}.batch-tabs button:hover{background-color:#e9ecef;color:#2563eb}.batch-tabs button.active{background-color:#fff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.videos-header h3{margin:0;padding:0}.delete-selected-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:background-color .2s ease}.delete-selected-button:hover{background-color:#c82333}.delete-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;margin:0;opacity:.7;padding:8px;transition:opacity .2s ease}.delete-button:hover{opacity:1}.videos-controls{align-items:center;display:flex;flex-wrap:wrap;gap:12px;width:100%}.gesture-filter{background-color:#fff;border-radius:4px;cursor:pointer;min-width:120px;padding:8px 12px;transition:border-color .2s ease}.gesture-filter,.user-filter-select{border:1px solid #ddd;font-size:.9rem}.user-filter-select{background:#fff;border-radius:4px;padding:6px 8px}.user-filter-select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.gesture-filter:hover{border-color:#007bff}.gesture-filter:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.videos-actions{display:flex;flex-direction:column;gap:12px;width:100%}.filter-container{align-items:center;display:flex;gap:8px;position:relative}.filter-button{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:background-color .2s ease;width:36px}.filter-button:hover{background-color:#0000000d}.clear-filters-button{background:none;border:1px solid #dc3545;border-radius:4px;color:#dc3545;cursor:pointer;font-size:.8rem;padding:4px 8px;transition:all .2s ease}.clear-filters-button:hover{background-color:#dc3545;color:#fff}.icon{display:block;height:18px;width:18px}.recording-settings{align-items:flex-start;display:flex;flex-direction:row;gap:15px;justify-content:center;margin:0 auto;position:relative;width:fit-content;z-index:1}.gesture-selection-container{display:flex;flex-direction:column;gap:10px;width:250px}.gesture-dropdown-row{align-items:center;display:flex;gap:10px}.batch-size-dropdown,.countdown-length-dropdown,.gesture-category-dropdown,.gesture-dropdown{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:1rem;height:40px;padding:8px 12px;transition:all .2s ease;width:250px}.batch-size-dropdown:hover,.countdown-length-dropdown:hover,.gesture-category-dropdown:hover,.gesture-dropdown:hover{border-color:#007bff}.batch-size-dropdown:focus,.countdown-length-dropdown:focus,.gesture-category-dropdown:focus,.gesture-dropdown:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.recording-info{align-items:center;display:flex;flex-direction:column;gap:8px;margin:5px 0}.countdown{animation:pulse 1s infinite;color:#dc3545;font-size:3.5rem;font-weight:700;line-height:1;margin:0}.countdown.paused{animation:none;opacity:.6}.batch-progress{background-color:#2563eb1a;border-radius:6px;color:#2563eb;font-size:1.1rem;font-weight:500;min-width:300px;padding:6px 14px;text-align:center}.batch-progress span{display:inline-block;transition:opacity .2s ease}.recording-status-indicator{pointer-events:none;position:absolute;right:20px;top:20px;z-index:10}.recording-status-content{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;border-radius:8px;color:#fff;font-family:Arial,sans-serif;padding:16px 20px}.recording-instruction,.recording-instructions-list{font-size:18px;margin-bottom:8px}.recording-instructions-list{padding-left:20px;text-align:left}.recording-instructions-list li{margin-bottom:4px}.recording-gesture{font-size:24px;font-weight:700;margin-bottom:8px;text-transform:capitalize}.recording-progress{font-size:18px;margin-bottom:4px;opacity:.9}.recording-saving{color:#4caf50;font-size:18px;font-weight:500}.firewall-mode-toggle{align-items:center;display:flex;justify-content:center;margin-top:10px}.toggle-label{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{-webkit-appearance:none;appearance:none;background:#ddd;border:none;border-radius:22px;cursor:pointer;height:22px;margin:0;outline:none;padding:0;position:relative;transition:background .3s;width:44px}.toggle-label input[type=checkbox]:checked{background:#4caf50}.toggle-label input[type=checkbox]:before{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;content:"";height:18px;left:2px;position:absolute;top:2px;transition:transform .3s ease;width:18px}.admin-view-toggle .toggle-label input[type=checkbox]:checked:before,.toggle-label input[type=checkbox]:checked:before{transform:translateX(22px)}.toggle-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.toggle-text{color:#333;font-size:14px}.toggle-tooltip{color:#666;cursor:help;font-size:14px;margin-left:4px}.video-username{font-style:italic;margin-top:4px}.loading-container{gap:12px;height:200px;width:100%}.loading-container span{color:#4a5568;font-size:1.2rem;font-weight:500}.loading-spinner .spinner{animation:spin 1s linear infinite;border:4px solid #0000;border-radius:50%;border-top-color:#2563eb;height:100%;width:100%}.delete-confirm-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.delete-confirm-popup{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:400px;padding:24px;text-align:center;width:90%}.sample-popup-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.sample-popup{align-items:center;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;gap:16px;max-width:700px;padding:24px;width:90%}.sample-popup-title{margin:0;text-transform:capitalize}.sample-popup-video{background-color:#000;border-radius:8px;width:100%}.sample-popup-instructions{text-align:left;width:100%}.sample-popup-instructions p{margin:0 0 8px}.sample-popup-instructions ul{margin:0;padding-left:20px}.sample-popup-instructions li{margin-bottom:4px}.sample-popup-buttons{display:flex;gap:12px}.add-button-container,.help-button-container{display:inline-block;position:relative}.sample-help-button,.settings-button{background:#e2e8f0;border:none;border-radius:50%;cursor:pointer;font-weight:700;height:40px;width:40px}.settings-button{margin-left:8px}.next-gesture-button{background:#e2e8f0;border:none;border-radius:6px;cursor:pointer;font-weight:700;height:40px;padding:8px 12px}.next-gesture-button:disabled{background:#ccc;cursor:not-allowed}.settings-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.settings-panel{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;gap:16px;max-width:400px;padding:24px;width:90%}.countdown-input{border:1px solid #ddd;border-radius:6px;font-size:1rem;margin-top:4px;padding:8px 12px;width:100%}.save-button{align-self:flex-end;background:#e2e8f0;border:none;border-radius:6px;cursor:pointer;padding:8px 16px}.help-hint{animation:hint-fade 3s forwards;border:2px dashed #2563eb;border-radius:8px;bottom:-6px;left:-6px;pointer-events:none;position:absolute;right:-6px;top:-6px}@keyframes hint-fade{0%{opacity:1}to{opacity:0}}.delete-confirm-popup h4{color:#212529;font-size:1.2rem;margin:0 0 16px}.delete-confirm-popup p{color:#495057;margin:0 0 24px}.delete-confirm-buttons{display:flex;gap:12px;justify-content:center}.delete-confirm-buttons button{border-radius:6px;font-weight:500;padding:8px 24px;transition:all .2s ease}.confirm-delete{background-color:#dc3545;border:none;color:#fff}.confirm-delete:hover{background-color:#c82333;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.cancel-delete{background-color:#f8f9fa;border:1px solid #dee2e6;color:#212529}.cancel-delete:hover{background-color:#e9ecef;box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.count-list-section{background:var(--surface-color);border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:100%;overflow:hidden}.count-list-header{border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;gap:.75rem;padding:1rem}.count-list-title-row{display:flex;flex-direction:column;gap:.5rem}.title-and-count{align-items:center;display:flex;justify-content:space-between}.title-and-count h3{color:var(--text-color);font-size:1.2rem;margin:0}.total-count{color:var(--text-color-secondary);font-size:1rem}.total-count strong{color:var(--primary-color);margin-left:.5rem}.show-all-toggle,.show-all-toggle label{align-items:center;display:flex}.show-all-toggle label{color:var(--text-color-secondary);cursor:pointer;font-size:.9rem;gap:.5rem}.show-all-toggle input[type=checkbox]{cursor:pointer;height:16px;width:16px}.count-list-container{flex:1 1;min-height:0;overflow-y:auto;padding:1rem}.count-list-item{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.75rem;transition:background-color .2s}.count-list-item:last-child{border-bottom:none}.count-list-item:hover{background-color:var(--hover-color)}.gesture-name{color:var(--text-color);font-weight:500}.gesture-count{color:var(--primary-color);font-weight:600;min-width:3rem;text-align:right}.no-counts-message{color:var(--text-color-secondary);font-style:italic;padding:2rem;text-align:center}.view-toggle-button{align-items:center;background:var(--surface-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.view-toggle-button:hover{background:var(--hover-color)}.view-toggle-button img{height:16px;width:16px}.action-button{align-items:center;background-color:#fff;border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;height:36px;padding:8px 12px;transition:all .2s ease}.action-button:hover{background-color:var(--hover-color);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.action-button:active{box-shadow:none;transform:translateY(0)}.action-button .icon{height:16px;width:16px}.view-counts-button{margin-left:auto;margin-right:12px}.admin-view-toggle.disabled{cursor:not-allowed;opacity:.6}.admin-view-toggle.disabled .toggle-label,.admin-view-toggle.disabled input[type=checkbox]{cursor:not-allowed}.admin-view-toggle.disabled .toggle-text{color:var(--text-color-secondary)}.video-thumbnail{background-color:#f0f0f0;border-radius:8px;flex-shrink:0;height:90px;overflow:hidden;position:relative;width:120px}.thumbnail-image{height:100%;object-fit:cover;width:100%}.gesture-overlay{background:#000000b3;bottom:0;color:#fff;font-size:.9em;left:0;padding:4px 8px;position:absolute;right:0;text-align:center}.videos-list li{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:16px;padding:12px;transition:background-color .2s}.videos-list li:hover{background-color:#f5f5f5}.video-info{flex:1 1;min-width:0}.video-info p{margin:4px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-username{color:#666;font-size:.9em}.loading{align-items:center;color:#666;display:flex;justify-content:center;padding:20px}.error-message{background-color:#f8d7da;border-radius:4px;color:#dc3545;margin:10px 0;padding:20px;text-align:center}.video-playback .loading-container{align-items:center;background-color:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;justify-content:center;min-height:400px;width:100%}.scroll-loader{align-items:center;height:60px;padding:20px;width:100%}.loading-spinner.small .spinner{border-width:2px}.load-more-button,.load-more-container{display:none}.list-controls{gap:1.5rem;margin-top:.5rem}.list-controls,.show-all-toggle,.sort-toggle{align-items:center;display:flex}.show-all-toggle label,.sort-toggle label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.show-all-toggle input[type=checkbox],.sort-toggle input[type=checkbox]{cursor:pointer;height:16px;margin:0;width:16px}.toggle-text{color:var(--text-color-secondary);font-size:.9rem;-webkit-user-select:none;user-select:none}.batch-item{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:16px;overflow:hidden}.batch-item:last-child{margin-bottom:0}.batch-header{align-items:center;background-color:#f5f5f5;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:background-color .2s ease}.batch-header:hover{background-color:#eee}.batch-header.expanded{border-bottom:1px solid #e0e0e0}.batch-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.batch-main-info{align-items:center;display:flex;gap:16px}.batch-gesture{align-items:center;display:flex;font-size:1.1em;font-weight:600;gap:8px}.batch-count{color:#666}.batch-username,.phrase-text{color:#666;font-size:.9em}.batch-username{display:block}.batch-complete-icon,.batch-incomplete-icon{height:16px;margin-left:4px;width:16px}.batch-timestamps{align-items:center;color:#666;display:flex;font-size:.9em;gap:8px}.timestamp-separator{color:#999}.batch-expand-icon{color:#666;font-size:.8em;margin-left:16px}.batch-videos{background-color:#fff;padding:16px}.no-batches-message{color:#666;padding:32px;text-align:center}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:32px}.loading-spinner{border:3px solid #f3f3f3;border-top-color:#3498db}.loading-spinner.small{border-width:2px;height:24px;width:24px}.scroll-loader{display:flex;justify-content:center;padding:16px}.legacy-tag{background-color:#6b7280;border-radius:4px;color:#fff;font-size:.7em;font-weight:500;letter-spacing:.05em;padding:2px 6px;text-transform:uppercase}.pause-button{background-color:#ffc107;border:none;border-radius:6px;color:#000;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.pause-button:hover{background-color:#ffca2c;transform:translateY(-1px)}.pause-button.paused{background-color:#28a745;color:#fff}.pause-button.paused:hover{background-color:#2dbb4c}.abort-button{background-color:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.abort-button:hover{background-color:#b02a37;transform:translateY(-1px)}.recording-paused{animation:blink 1s infinite;color:#ffc107;font-size:.9rem;font-weight:500;margin-top:4px}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.my-videos-section.batch-active{opacity:.7;pointer-events:none;position:relative}.batch-active-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0003;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:100}.batch-active-message{align-items:center;background:#000c;border-radius:8px;color:#fff;display:flex;font-size:1.1rem;font-weight:500;gap:12px;padding:16px 24px}.batch-active-message .icon{height:20px;opacity:.9;width:20px}.batch-item.batch-locked{opacity:.7;pointer-events:none;position:relative}.batch-lock-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0003;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:50}.batch-lock-message{align-items:center;background:#000c;border-radius:8px;color:#fff;display:flex;font-size:1.1rem;font-weight:500;gap:12px;padding:16px 24px}.batch-lock-message .icon{height:20px;opacity:.9;width:20px}.orientation-countdown-overlay{align-items:center;background:#000000b3;border-radius:8px;color:#fff;display:flex;flex-direction:column;gap:12px;left:50%;padding:24px 32px;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:15}.orientation-icon{font-size:3rem}.countdown-label{font-size:2.5rem;font-weight:700}.replacement-popup-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.replacement-popup{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;gap:16px;max-width:500px;padding:24px;width:90%}.replacement-list{list-style:none;margin:0;padding:0}.replacement-list li{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.replacement-buttons{display:flex;gap:12px;justify-content:flex-end}.add-replacements-button{cursor:pointer;font-size:.9em;margin-left:8px;padding:4px 8px}.replacement-banner{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:10px}.filter-popup{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-height:80vh;overflow-y:auto;position:fixed;width:320px;z-index:1000}.filter-popup.dragging{cursor:grabbing}.filter-popup-header{align-items:center;background:#fff;border-bottom:1px solid #eee;cursor:grab;display:flex;justify-content:space-between;padding:12px 16px;position:sticky;top:0;z-index:1}.filter-popup-header:active{cursor:grabbing}.filter-popup-header h4{font-size:16px;font-weight:600;margin:0}.close-filter-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;opacity:.7;padding:4px;transition:opacity .2s}.close-filter-button:hover{opacity:1}.close-filter-button .icon{height:16px;width:16px}.filter-options{max-height:calc(80vh - 120px);overflow-y:auto;padding:8px 8px 56px}.filter-category{border:1px solid #eee;border-radius:6px;margin-bottom:16px;overflow:hidden}.filter-category:last-child{margin-bottom:0}.filter-category-header{align-items:center;cursor:pointer;display:flex;padding:8px 12px;-webkit-user-select:none;user-select:none}.filter-category-header:hover{background-color:#0000000d}.filter-category-header h5{font-size:14px;font-weight:600;margin:0}.collapse-arrow{display:inline-block;font-size:10px;margin-right:8px;transition:transform .2s ease}.collapse-arrow.collapsed{transform:rotate(-90deg)}.filter-category-options{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));opacity:1;overflow:hidden;padding:8px;transition:all .3s ease-in-out}.filter-category-options.collapsed{margin:0;max-height:0;opacity:0;padding:0}.filter-option{align-items:center;border-radius:4px;cursor:pointer;display:flex;font-size:14px;padding:4px 8px;transition:background-color .2s}.filter-option:hover{background-color:#f5f5f5}.filter-option input[type=checkbox]{margin-right:8px}.apply-filters-button{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#007bff;border:none;border-radius:0;bottom:0;box-shadow:0 -4px 12px #0000001a;color:#fff;cursor:pointer;font-weight:500;left:0;margin:0;padding:12px;position:absolute;right:0;transition:all .2s ease;z-index:2}.apply-filters-button:hover{background:#0056b3}.filter-search{border-bottom:1px solid #e5e7eb;padding:10px 16px;position:relative}.filter-search-input{border:1px solid #e5e7eb;border-radius:6px;font-size:14px;outline:none;padding:8px 32px 8px 12px;transition:border-color .2s ease;width:100%}.filter-search-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.filter-search-input::placeholder{color:#9ca3af}.filter-search-clear{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:.6;position:absolute;right:24px;top:16px;transition:opacity .15s ease;width:24px}.filter-search-clear:hover{background-color:#0000000d;opacity:1}.filter-search-clear:active{background-color:#0000001a}.filter-search-clear .icon{height:14px;width:14px}.no-results{color:#6b7280;font-size:14px;padding:16px;text-align:center}.video-section{margin-top:20px}.training-video-container{margin-bottom:20px}.phrase-controls{align-items:center;display:flex;gap:8px;justify-content:center;margin:5px 0;width:100%}.phrase-controls .gesture-dropdown{flex:1 1}.phrase-controls .settings-button{margin-left:0}.sample-popup-signs{margin:0}.sample-popup-sign-title{margin:0;text-transform:capitalize}.sample-popup-nav-button{align-items:center;border-radius:8px;display:inline-flex;height:40px;justify-content:center;padding:6px;width:40px}.sample-popup-nav-button .nav-icon{display:block;height:100%;max-height:100%;max-width:100%;object-fit:contain;width:100%}.variation-options{list-style:none}.variation-option{align-items:center;display:flex;gap:8px}.sample-popup-instructions.variation-error{border:2px solid #dc3545;border-radius:8px;padding:8px 12px}.sample-popup-instructions.variation-error label{color:#dc3545}.sample-popup-instructions strong{display:block;margin-bottom:12px}.emotion-warning{align-items:center;color:#dc3545;display:flex;font-weight:700;margin-bottom:10px}.emotion-warning .warning-icon{height:16px;margin-right:8px;width:16px}.speed-select{display:flex;justify-content:center;margin:8px 0;width:100%}.speed-select select.error{border:2px solid #dc3545}.non-manual-section{margin-top:16px}.non-manual-section .slider-row select{flex:1 1}.notes-section{display:flex;flex-direction:column;gap:8px;margin-top:12px}.notes-textarea{border:1px solid #ddd;border-radius:6px;font-size:1rem;min-height:60px;padding:8px 12px;resize:vertical;width:100%}.notes-textarea:hover{border-color:#007bff}.notes-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.emotion-submit{display:flex;gap:10px;justify-content:flex-end}.emotion-cancel-button{background-color:#6c757d;border-radius:6px;color:#fff;padding:8px 16px}.emotion-cancel-button:hover{background-color:#5a6268}.emotion-cancel-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.emotion-cancel-popup{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:400px;padding:24px;text-align:center;width:90%}.emotion-cancel-actions{display:flex;justify-content:space-around;margin-top:20px}.emotion-confirm-button{background-color:#dc3545;border-radius:6px;color:#fff;font-weight:500;padding:8px 16px}.emotion-confirm-button:hover{background-color:#b02a37}.emotion-abort-button{background-color:#6c757d;border-radius:6px;color:#fff;padding:8px 16px}.emotion-abort-button:hover{background-color:#5a6268}.video-actions{align-items:center;display:flex;flex-direction:column;gap:4px}.edit-rating-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;opacity:.7;padding:8px;transition:opacity .2s ease}.edit-rating-button:hover{opacity:1}.phrase-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.phrase-modal{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:600px;padding:32px;width:90%}.phrase-modal.scroll-on-step2{max-height:95vh;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable both-edges}.phrase-modal-title{color:#2d3748;font-size:1.5rem;margin-bottom:24px;margin-top:0;text-align:center}.slider-row{align-items:center;display:flex;gap:12px;margin-bottom:16px}.slider-row.disabled{opacity:.5;pointer-events:none}.slider-label{align-items:center;color:#2d3748;display:flex;font-weight:500;gap:4px}.slider-row>.slider-label{flex:0 0 150px}.tooltip-icon{background-color:#2563eb;border-radius:50%;color:#fff;cursor:help;display:inline-block;font-size:12px;font-weight:700;height:16px;line-height:16px;text-align:center;width:16px}.tooltip-floating{background:#2d3748;border-radius:4px;box-shadow:0 4px 10px #0003;color:#fff;padding:6px 8px;pointer-events:none;position:fixed;white-space:nowrap;z-index:11000}.scoring-slider{flex:1 1}.scoring-slider input[type=range]{-webkit-appearance:none;appearance:none;background:#4a5568;border-radius:4px;height:8px;outline:none;width:100%}.scoring-slider input[type=range]:disabled{background:#a0aec0;cursor:not-allowed}.scoring-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#2563eb;border:none;border-radius:50%;cursor:pointer;height:24px;width:24px}.scoring-slider input[type=range]::-webkit-slider-thumb:hover{background:#1d4ed8}.scoring-slider input[type=range]::-moz-range-thumb{background:#2563eb;border:none;border-radius:50%;cursor:pointer;height:24px;width:24px}.scoring-slider input[type=range]::-moz-range-thumb:hover{background:#1d4ed8}.slider-value{color:#4a5568;font-weight:500;text-align:center;width:32px}.phrase-modal-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.phrase-button{border:none;border-radius:6px;cursor:pointer;font-weight:500;padding:10px 20px}.phrase-button.primary{background-color:#2563eb;color:#fff}.phrase-button.primary:hover{background-color:#1d4ed8}.phrase-button.secondary{background-color:#4a5568;color:#fff}.phrase-button.secondary:hover{background-color:#2d3748}.video-capture-container{align-items:center;aspect-ratio:16/9;background-color:#000;display:flex;height:100%;justify-content:center;margin:0 auto;max-height:80vh}.prediction-overlay{pointer-events:none;z-index:2}.prediction-overlay,.status-overlay{height:100%;left:0;position:absolute;top:0;width:100%}.status-overlay{align-items:center;background-color:#000c;display:flex;justify-content:center;opacity:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden}.status-overlay.visible{opacity:1;visibility:visible}.error-message,.loading-message{align-items:center;background-color:#000000d9;border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;flex-direction:column;font-size:1.2rem;gap:1rem;padding:2rem 3rem;text-align:center}.loading-spinner{border:4px solid #ffffff4d;border-top-color:#fff}.error-message{background-color:#dc3545f2;max-width:400px}.error-icon{font-size:2rem;margin-bottom:.5rem}.error-text{margin-bottom:1rem}.retry-button{background-color:#fff;border:none;border-radius:6px;color:#dc3545;cursor:pointer;font-weight:700;padding:.5rem 2rem;transition:background-color .2s ease}.retry-button:hover{background-color:#f8f9fa}.retry-message{color:#fffc;font-size:.9rem}.metrics-container{background-color:#000c;border-radius:8px;color:#fff;font-family:monospace;font-size:.9rem;padding:1rem;position:absolute;right:1rem;top:1rem;z-index:10}.metrics p{margin:.25rem 0;white-space:nowrap}.demo-indicator{animation:pulse 2s infinite;background-color:#dc3545;border-radius:4px;color:#fff;font-size:.9rem;font-weight:700;left:1rem;padding:.5rem 1rem;position:absolute;top:1rem;z-index:10}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.heygen-avatar-container{aspect-ratio:16/9;background-color:#1a1a1a;position:relative}.heygen-avatar-video{transform:scale(1.5);transform-origin:center top}.avatar-loading{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff1a;border-left-color:#fff;border-radius:50%;height:40px;width:40px}.loading-text{font-size:16px;font-weight:500}@keyframes spin{to{transform:rotate(1turn)}}.transcript-popup{background:#000000e6;border-radius:10px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:default;flex-direction:column;max-height:80vh;max-width:80vw;min-width:300px;padding:20px;position:absolute;z-index:1000}.transcript-header,.transcript-popup{display:flex;-webkit-user-select:none;user-select:none}.transcript-header{align-items:center;border-bottom:1px solid #fff3;cursor:move;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.transcript-header:hover{background:#ffffff0d;border-radius:4px}.transcript-header h3{color:#fff;font-size:1.2em;margin:0}.close-button{background:none;border:none;color:#fff;cursor:pointer;font-size:24px;opacity:.7;padding:0 5px;transition:opacity .2s}.close-button:hover{opacity:1}.transcript-content{flex-grow:1;overflow-y:auto;padding-right:10px;scroll-behavior:smooth}.transcript-sentence{background:#ffffff1a;border-radius:6px;line-height:1.4;margin:10px 0;padding:8px 12px}.transcript-sentence.completed{color:#fff}.transcript-sentence.current{background:#4caf5033;border:1px solid #4caf504d;color:#4caf50}.raw-indicator{color:#fff9;font-size:.8em;font-style:italic;margin-left:8px}.transcript-status{color:#64b5f6;margin:10px 0;text-align:center}.loading-dots{display:inline-block}.loading-dots:after{animation:dots 1.5s steps(4) infinite;content:"..."}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.transcript-empty{color:#ffffff80;font-style:italic;padding:20px;text-align:center}.transcript-content::-webkit-scrollbar{width:8px}.transcript-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.transcript-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.transcript-content::-webkit-scrollbar-thumb:hover{background:#fff6}.gesture-to-speech-container{align-items:center;display:flex;flex-direction:column;height:100%;margin:0 auto;max-width:1900px;padding:20px;width:100%}.main-content{align-items:flex-start;display:flex;gap:40px;justify-content:center;margin-bottom:20px;width:100%}.video-capture-container{background:#000;border-radius:8px;overflow:hidden;position:relative;width:100%}.video-capture-container canvas{border-radius:8px;display:block;width:100%}.avatar-section{align-items:center;display:flex;flex-direction:column;min-width:640px;width:640px}.avatar-wrapper,.video-capture-wrapper{display:none}.debug-message{color:#666;font-size:14px;margin-bottom:10px}.button-container{display:flex;gap:10px;margin-top:20px}.debug-toggle-button,.mode-switch-button{border:none;border-radius:5px;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s}.mode-switch-button:not(:disabled){background-color:#4caf50;color:#fff}.mode-switch-button:not(:disabled):hover{background-color:#45a049}.mode-switch-button:disabled{background-color:#ccc;color:#666;cursor:not-allowed;opacity:.7}.debug-toggle-button{background-color:#f0f0f0;color:#333}.debug-toggle-button:hover{background-color:#e0e0e0}.debug-toggle-button.active{background-color:#2196f3;color:#fff}.results-container{background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:15px;padding:20px;width:100%}.sentence{color:#212529;font-size:1.1rem;max-height:100px;min-height:45px;overflow-y:auto}.sentence::-webkit-scrollbar{width:6px}.sentence::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.sentence::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.sentence::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:1900px){.main-content{align-items:center;flex-direction:column;gap:20px}.video-capture-container{max-width:1120px;min-width:auto;width:100%}.avatar-section{max-width:640px;min-width:auto;width:100%}}.heygen-avatar-container{align-items:center;aspect-ratio:1/1;background:#000;border-radius:8px;display:flex;justify-content:center;overflow:hidden;width:100%}.heygen-avatar-video{height:100%;object-fit:cover;width:100%}.transcript-toggle-button{background-color:#f0f0f0;border:none;border-radius:5px;color:#333;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s}.transcript-toggle-button:hover{background-color:#e0e0e0}.transcript-toggle-button.active{background-color:#2196f3;color:#fff}.web-demo-container{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:1200px;min-height:calc(100vh - 60px);padding:80px 20px 20px;width:100%}.web-demo-container h1{color:#212529;font-size:2rem;font-weight:600;margin-bottom:30px}@media (max-width:1400px){.web-demo-container{padding:20px}}@media (max-width:768px){.web-demo-container{padding:15px}}.header-container{align-items:center;background-color:#f8f9fa;border-bottom:2px solid #ddd;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;left:0;padding:12px 24px;position:fixed;top:0;width:100vw;z-index:1000}.header-brand{align-items:flex-start;display:flex;flex-direction:column;width:200px}.company-name{color:#2c3e50;font-size:1.4rem;font-weight:700;letter-spacing:.5px}.portal-name{color:#666;font-size:.9rem;letter-spacing:.3px}.page-title{color:#2c3e50;flex-grow:1;font-size:1.5rem;font-weight:600;letter-spacing:1px;text-align:center;text-transform:uppercase}.nav-buttons{align-items:center;display:flex;gap:12px;justify-content:flex-end;width:200px}.header-container button{align-items:center;border:none;border-radius:5px;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;height:32px;justify-content:center;padding:6px 16px;transition:all .2s ease}.header-container button:hover{transform:translateY(-2px)}.header-container button:active{transform:translateY(0)}.header-container .back-button{background-color:#4a5568;border:2px solid #0000}.header-container .back-button:hover{background-color:#2d3748}.header-container .back-button:active{background-color:#1a202c}.header-container .logout-button{background-color:#dc3545}.header-container .logout-button:hover{background-color:#b02a37}.header-container .logout-button:active{background-color:#7f1e27}body,html{box-sizing:border-box;font-family:Arial,sans-serif;margin:0;padding:0}*,:after,:before{box-sizing:inherit}button{border:none;cursor:pointer;font-family:inherit;transition:all .2s ease}button:hover{transform:translateY(-2px)}button:active{transform:translateY(0)}.app-container{display:flex;flex-direction:column;min-height:100vh}
/*# sourceMappingURL=main.b27b6b61.css.map*/