body{margin:0;padding:0}#root{width:100%;min-height:100vh}:root{--bg-dark:#1a1a2e;--bg-panel:#16213e;--accent:#0f3460;--highlight:#e94560;--success:#4caf50;--text:#eee;--text-dim:#888}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-dark);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}header{background:var(--bg-panel);border-bottom:1px solid var(--accent);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:relative}header h1{font-size:1.5rem;font-weight:600}.progress{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.progress .dot{background:var(--accent);cursor:pointer;border-radius:50%;width:12px;height:12px;transition:all .2s}.progress .dot:hover{transform:scale(1.2)}.progress .dot.current{background:var(--highlight);box-shadow:0 0 8px var(--highlight)}.progress .dot.completed{background:var(--success)}.auth-signin{border:1px solid var(--accent);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.4rem .9rem;font-size:.85rem;transition:all .2s}.auth-signin:hover{background:var(--accent)}.auth-user{align-items:center;gap:.5rem;display:flex}.auth-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.auth-name{color:var(--text-dim);font-size:.85rem}.auth-signout{border:1px solid var(--accent);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;padding:.3rem .7rem;font-size:.8rem;transition:all .2s}.auth-signout:hover{border-color:var(--highlight);color:var(--highlight)}.collection-pills{background:var(--bg-panel);border-bottom:1px solid var(--accent);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem 2rem;display:flex}.collection-pill{border:1px solid var(--accent);color:var(--text-dim);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:.3rem .9rem;font-size:.85rem;transition:all .2s}.collection-pill:hover{border-color:var(--text-dim);color:var(--text)}.collection-pill.active{background:var(--accent);border-color:var(--accent);color:var(--text)}.sign-nav{background:var(--bg-panel);border-bottom:1px solid var(--accent);justify-content:center;align-items:center;gap:1rem;padding:.6rem 2rem;display:flex}.sign-nav-arrow{border:1px solid var(--accent);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.25rem .7rem;font-size:1rem;line-height:1;transition:all .15s}.sign-nav-arrow:hover{background:var(--accent);border-color:var(--highlight)}.tabs{background:var(--bg-dark);border-radius:8px;gap:2px;padding:3px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem 1.2rem;font-size:.9rem;transition:all .2s}.tab:hover{color:var(--text)}.tab.active{background:var(--accent);color:var(--text)}.library-view{flex-direction:column;flex:1;gap:2rem;padding:1.5rem 2rem;display:flex;overflow-y:auto}.library-toolbar{justify-content:flex-end;margin-bottom:.5rem;display:flex}.library-section{flex-direction:column;gap:.75rem;display:flex}.library-section-header{justify-content:space-between;align-items:center;display:flex}.library-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:.75rem}.library-section-delete{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.8rem;transition:all .15s}.library-section-delete:hover{color:var(--highlight);background:#e945601a}.icon-picker{flex-wrap:wrap;gap:.4rem;display:flex}.icon-option{background:var(--bg-dark);cursor:pointer;border:2px solid #0000;border-radius:6px;padding:.3rem;font-size:1.3rem;transition:all .15s}.icon-option.active{border-color:var(--highlight)}.word-picker{background:var(--bg-dark);border:1px solid var(--accent);border-radius:6px;flex-wrap:wrap;gap:.4rem;max-height:160px;padding:.5rem;display:flex;overflow-y:auto}.word-option{border:1px solid var(--accent);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:14px;padding:.25rem .7rem;font-size:.82rem;transition:all .15s}.word-option.active{background:var(--accent);border-color:var(--accent);color:var(--text)}.modal-input{background:var(--bg-dark);border:1px solid var(--accent);color:var(--text);border-radius:6px;outline:none;width:100%;padding:.6rem .8rem;font-size:1rem;transition:border-color .2s}.modal-input:focus{border-color:var(--highlight)}.library-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;display:grid}.sign-card{background:var(--bg-panel);border:1px solid var(--accent);border-radius:10px;transition:border-color .2s,transform .15s,box-shadow .2s;overflow:hidden}.sign-card:hover{border-color:var(--text-dim);transform:translateY(-2px);box-shadow:0 4px 16px #0006}.sign-card.active{border-color:var(--highlight);box-shadow:0 0 0 1px var(--highlight)}.sign-card.completed{border-color:var(--success)}.sign-card-video{aspect-ratio:4/3;background:#000;position:relative;overflow:hidden}.sign-card-video video{object-fit:cover;width:100%;height:100%}.sign-card-badge{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.sign-card-delete{width:22px;height:22px;color:var(--text-dim);cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;transition:all .15s;display:flex;position:absolute;top:6px;left:6px}.sign-card:hover .sign-card-delete{opacity:1}.sign-card-delete:hover{background:var(--highlight);color:#fff}.sign-card.selectable{cursor:pointer}.sign-card.selected{outline:2px solid var(--highlight);outline-offset:-2px}.sign-card-checkbox{color:#fff;background:#00000080;border:2px solid #ffffff80;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:6px;left:6px}.sign-card-checkbox.checked{background:var(--highlight);border-color:var(--highlight)}.sign-card-custom-badge{background:var(--accent);color:#fff;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:600;position:absolute;top:6px;left:6px}.select-btn,.cancel-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:.45rem .9rem;font-size:.85rem;transition:all .2s}.select-btn:hover,.cancel-btn:hover{background:var(--border)}.delete-btn{color:#fff;cursor:pointer;background:#dc3545;border:none;border-radius:6px;padding:.45rem .9rem;font-size:.85rem;transition:all .2s}.delete-btn:hover:not(:disabled){background:#c82333}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.sign-card-footer{flex-direction:column;align-items:flex-start;gap:.35rem;padding:.6rem .75rem;display:flex}.sign-card-footer-row{justify-content:space-between;align-items:center;gap:.5rem;width:100%;display:flex}.sign-card-description{color:var(--text-dim);margin:0;font-size:.72rem;font-style:italic;line-height:1.4}.sign-card-label{font-size:.95rem;font-weight:500}.sign-card-practice{background:var(--accent);color:var(--text);cursor:pointer;white-space:nowrap;border:none;border-radius:5px;padding:.3rem .7rem;font-size:.78rem;transition:background .2s}.sign-card-practice:hover{background:var(--highlight)}.library-empty{color:var(--text-dim);font-size:.9rem}.add-sign-btn{border:1px solid var(--accent);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:.4rem .9rem;font-size:.9rem;transition:all .2s}.add-sign-btn:hover{background:var(--accent);border-color:var(--highlight)}.inventory-modal{width:560px;max-height:80vh;overflow-y:auto}.inventory-header{justify-content:space-between;align-items:center;display:flex}.inventory-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .5rem;font-size:1.1rem;transition:color .2s}.inventory-close:hover{color:var(--highlight)}.inventory-section-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.6rem;font-size:.8rem}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem;margin-bottom:1.2rem;display:grid}.inventory-card{background:var(--bg-dark);border:1px solid var(--accent);cursor:pointer;color:var(--text);text-align:center;border-radius:8px;justify-content:center;align-items:center;padding:.7rem .5rem;font-size:.9rem;transition:all .15s;display:flex;position:relative}.inventory-card:hover{border-color:var(--text-dim)}.inventory-card.active{border-color:var(--highlight);box-shadow:0 0 0 1px var(--highlight)}.inventory-card.completed{border-color:var(--success)}.inventory-card.custom{padding:0;overflow:hidden}.inventory-card-main{color:var(--text);cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.7rem .4rem;font-size:.9rem;display:flex}.inventory-delete{border:none;border-left:1px solid var(--accent);color:var(--text-dim);cursor:pointer;background:0 0;align-self:stretch;align-items:center;padding:.4rem .5rem;font-size:.75rem;transition:all .15s;display:flex}.inventory-delete:hover{background:var(--highlight);color:#fff}.inventory-check{color:var(--success);font-size:.8rem}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-panel);border:1px solid var(--accent);border-radius:12px;flex-direction:column;gap:1.2rem;width:420px;max-width:90vw;padding:2rem;display:flex}.modal h2{font-size:1.3rem;font-weight:600}.modal-field{flex-direction:column;gap:.4rem;display:flex}.modal-field label{color:var(--text-dim);font-size:.85rem}.modal-field input{background:var(--bg-dark);border:1px solid var(--accent);color:var(--text);border-radius:6px;outline:none;padding:.6rem .8rem;font-size:1rem;transition:border-color .2s}.modal-field input:focus{border-color:var(--highlight)}.drop-zone{border:2px dashed var(--accent);cursor:pointer;color:var(--text-dim);border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;font-size:.95rem;transition:all .2s;display:flex}.drop-zone:hover,.drop-zone.dragging{border-color:var(--highlight);background:#e945600d}.drop-zone.has-file{border-style:solid;border-color:var(--success);color:var(--text)}.drop-icon{font-size:2rem}.drop-filename{word-break:break-all;text-align:center;font-size:.9rem}.extraction-progress{flex-direction:column;gap:.4rem;display:flex}.progress-msg{color:var(--text-dim);font-size:.85rem}.progress-track{background:var(--accent);border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:var(--highlight);border-radius:3px;height:100%;transition:width .1s linear}.modal-error{color:var(--highlight);font-size:.9rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:.25rem;display:flex}.modal-cancel{border:1px solid var(--accent);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.6rem 1.2rem;font-size:.95rem;transition:all .2s}.modal-cancel:hover:not(:disabled){background:var(--accent)}.modal-cancel:disabled{opacity:.4;cursor:not-allowed}.modal-submit{background:var(--highlight);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;transition:all .2s}.modal-submit:hover:not(:disabled){background:#ff6b81}.modal-submit:disabled{opacity:.4;cursor:not-allowed}main{flex:1;gap:1rem;padding:1rem;display:flex}.panel{background:var(--bg-panel);border-radius:12px;flex-direction:column;flex:1;padding:1rem;display:flex;overflow:hidden}.panel h2{text-align:center;margin-bottom:1rem;font-size:1.25rem;font-weight:500}.video-container{aspect-ratio:16/9;background:#000;border-radius:8px;width:100%;position:relative;overflow:hidden}.video-container video{object-fit:contain;width:100%;height:100%}.video-container canvas.overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.video-panel .controls{align-items:center;gap:1rem;margin-top:.5rem;padding:.5rem;display:flex}.play-btn{background:var(--accent);width:40px;height:40px;color:var(--text);cursor:pointer;border:none;border-radius:50%;font-size:1.2rem;transition:background .2s}.play-btn:hover{background:var(--highlight)}.scrubber{appearance:none;background:var(--accent);cursor:pointer;border-radius:3px;flex:1;height:6px}.scrubber::-webkit-slider-thumb{appearance:none;background:var(--highlight);cursor:pointer;border-radius:50%;width:16px;height:16px;transition:transform .1s}.scrubber::-webkit-slider-thumb:hover{transform:scale(1.2)}.scrubber::-moz-range-thumb{background:var(--highlight);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.frame-counter{color:var(--text-dim);text-align:right;min-width:70px;font-size:.9rem}.time-display{color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:40px;font-size:.85rem}.timeline-container{background:var(--accent);border-radius:3px;flex:1;height:6px;position:relative;overflow:hidden}.timeline-container .scrubber{z-index:2;background:0 0;width:100%;height:100%;margin:0;position:absolute;top:0;left:0}.timeline-progress{background:var(--highlight);pointer-events:none;border-radius:3px;height:100%;transition:width 50ms linear;position:absolute;top:0;left:0}.speed-controls{justify-content:center;gap:.5rem;margin-top:.5rem;display:flex}.speed-controls button{border:1px solid var(--accent);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.4rem .8rem;transition:all .2s}.speed-controls button:hover,.speed-controls button.active{background:var(--accent);border-color:var(--highlight)}.webcam-panel{width:100%}.error-container{background:linear-gradient(135deg,#2a1a1a,#1a1a2a);justify-content:center;align-items:center;display:flex}.error-content{text-align:center;flex-direction:column;align-items:center;padding:2rem;display:flex}.error-icon{opacity:.8;margin-bottom:1rem;font-size:3rem}.error-content h3{color:var(--highlight);margin-bottom:.5rem}.error-content p{color:var(--text-dim);max-width:280px;margin-bottom:1rem}.retry-btn{background:var(--accent);color:var(--text);cursor:pointer;border:none;border-radius:6px;padding:.6rem 1.2rem;transition:background .2s}.retry-btn:hover{background:var(--highlight)}.webcam-panel.error{aspect-ratio:16/9;text-align:center;color:#e94560;background:#2a1a1a;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;display:flex}.loading-overlay{background:#000c;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.spinner{border:3px solid var(--accent);border-top-color:var(--highlight);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.status-bar{align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem;font-size:.9rem;display:flex}.status-dot{background:var(--text-dim);border-radius:50%;width:10px;height:10px;transition:background .3s}.status-dot.detected{background:var(--success);box-shadow:0 0 6px var(--success)}.recording-badge{color:var(--highlight);margin-left:auto;font-weight:700;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.score-display{background:var(--accent);border-radius:6px;flex-direction:row;justify-content:center;align-items:center;gap:.75rem;min-height:2.4rem;margin-top:.4rem;padding:.4rem .75rem;display:flex}.score-display .word{font-size:1rem;font-weight:700}.score-display .instruction{color:var(--text-dim);font-size:1rem}.score-display .score{font-size:1rem;font-weight:700}.score-display .result{font-size:1rem}.score-display.passed{background:linear-gradient(135deg,#1b5e20,#2e7d32)}.score-display.passed .result{color:#a5d6a7}.score-display.failed{background:linear-gradient(135deg,#b71c1c,#c62828)}.score-display.failed .result{color:#ef9a9a}.sign-description{color:var(--text-dim);text-align:center;margin:.25rem 0 0;font-size:.8rem;font-style:italic;line-height:1.4}.feedback{color:var(--text-dim);border-left:2px solid var(--accent);margin:.4rem 0 0;padding:.4rem .6rem;font-size:.85rem;font-style:italic;line-height:1.5}.feedback-loading{opacity:.5;animation:1.5s ease-in-out infinite pulse}.action-buttons{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.action-buttons button{cursor:pointer;border:none;border-radius:8px;padding:.8rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.record-btn{background:var(--highlight);color:#fff}.record-btn:hover{background:#ff6b81;transform:scale(1.02)}.stop-btn{color:#fff;background:#ff9800;animation:1s ease-in-out infinite pulse}.stop-btn:hover{background:#ffb74d}.next-btn{background:var(--success);color:#fff}.next-btn:hover{background:#66bb6a;transform:scale(1.02)}footer{text-align:center;background:var(--bg-panel);border-top:1px solid var(--accent);color:var(--text-dim);padding:1rem}footer kbd{background:var(--accent);border-radius:4px;padding:.2rem .5rem;font-family:monospace;display:inline-block}@media (width<=900px){main{flex-direction:column}.panel{min-height:auto}}.debug-panel{color:#0f0;z-index:1000;background:#000000e6;border-top:1px solid #333;max-height:150px;padding:8px;font-family:monospace;font-size:12px;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.debug-panel strong{color:#ff0}.recording-indicator{color:#e94560;font-weight:700;animation:1s infinite pulse}.ready-indicator{color:var(--text-dim)}.recording-overlay{color:#fff;z-index:10;background:#e94560e6;border-radius:4px;padding:6px 12px;font-size:14px;font-weight:700;animation:1s infinite pulse;position:absolute;top:10px;left:10px}.recording-overlay .rec-dot{color:#fff;margin-right:4px}
