*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f0e6;color:#5d4037;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;width:100%}.app-container{align-items:center;background:linear-gradient(135deg,#f8f5f0,#e8ddd0 50%,#f0e8dc);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:15px 15px 20px}.app-header{animation:fadeInDown .5s ease-out;margin-bottom:15px;text-align:center}.app-header h1{color:#5d4037;font-size:26px;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin:0 0 8px}.app-header p{color:#8d6e63;font-size:13px;margin:0}.video-section{align-items:center;animation:fadeInUp .5s ease-out .1s backwards;display:flex;flex-direction:column;gap:12px;margin-bottom:12px;max-width:1400px;position:relative;width:100%}.video-and-instructions{align-items:flex-start;display:flex;gap:15px;width:100%}.video-header{align-items:center;background:linear-gradient(135deg,#8d6e63,#6d4c41);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;margin:0;padding:12px 16px}.video-header h3{font-size:18px;font-weight:600;margin:0}.reference-video-container .video-header h3{font-size:20px}.video-container .video-header{padding:8px 12px}.video-container .video-header h3{font-size:13px;font-weight:600}.video-container .status-indicator{border-radius:10px;font-size:11px;padding:3px 8px}.status-indicator{background:#fff3;border-radius:12px;font-size:10px;font-weight:600;padding:4px 12px}.status-indicator.active{animation:pulse 2s ease-in-out infinite;background:#4caf50}.status-indicator.inactive{background:#ffffff4d}.reference-video-container{background:#000;border:4px solid #8d6e63;border-radius:12px;box-shadow:0 8px 32px #5d403740,inset 0 0 0 1px #ffffff80;flex:1 1;min-width:640px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.reference-video-container:hover{box-shadow:0 10px 40px #5d40374d,inset 0 0 0 1px #ffffff80;transform:translateY(-1px)}.reference-video{background:#000;display:block;height:auto;width:100%}.video-sync-indicator{bottom:60px;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0}.sync-message{animation:fadeInScale .3s ease-out;background:#000000d9;border-radius:8px;box-shadow:0 4px 12px #00000080;color:gold;font-size:16px;font-weight:600;padding:12px 24px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.remove-video-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .3s ease;width:32px}.remove-video-btn:hover{background:#ff4d4de6;transform:rotate(90deg)}.instruction-panel{background:linear-gradient(135deg,#fff,#f5f0e6);border:3px solid #d7ccc8;border-radius:12px;box-shadow:0 8px 32px #5d403733,inset 0 0 0 1px #fffc;flex:0 0 350px;max-height:650px;overflow-y:auto;padding:16px;transition:transform .2s ease,box-shadow .2s ease}.instruction-panel:hover{box-shadow:0 10px 40px #5d403740,inset 0 0 0 1px #fffc;transform:translateY(-1px)}.instruction-header{border-bottom:2px solid #e8ddd0;margin-bottom:14px;padding-bottom:12px}.instruction-header h3{color:#5d4037;font-size:18px;font-weight:700;margin:0}.instruction-message{align-items:center;animation:fadeIn .3s ease-out;border-radius:12px;display:flex;gap:16px;margin-bottom:20px;padding:20px;transition:all .3s ease}.instruction-message.positioning{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:2px solid #ff9800;box-shadow:0 4px 12px #ff980033}.instruction-message.confirming{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;box-shadow:0 4px 12px #2196f333}.instruction-message.ready{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;box-shadow:0 4px 12px #4caf5033}.instruction-message.feedback{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #d84315;box-shadow:0 4px 12px #d8431533}.message-icon{flex-shrink:0;font-size:28px}.message-text{color:#5d4037;font-size:16px;font-weight:600;line-height:1.4}.distance-indicator{align-items:center;border:2px solid;border-radius:10px;display:flex;gap:12px;margin-bottom:16px;padding:12px 16px;transition:all .3s ease}.distance-indicator.too_close{background:linear-gradient(135deg,#ffebee,#ffcdd2);border-color:#f44336;box-shadow:0 4px 12px #f4433633}.distance-indicator.too_far{background:linear-gradient(135deg,#fff8e1,#ffecb3);border-color:#ffc107;box-shadow:0 4px 12px #ffc10733}.distance-indicator.good{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#4caf50;box-shadow:0 4px 12px #4caf5033}.distance-indicator.unknown{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border-color:#9e9e9e;box-shadow:0 4px 12px #9e9e9e33}.distance-icon{flex-shrink:0;font-size:24px}.distance-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.distance-label{color:#6d4c41;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.distance-value{color:#5d4037;font-size:16px;font-weight:700}.distance-metric{color:#8d6e63;font-family:monospace;font-size:11px}.step-info{background:#8d6e6314;border-left:3px solid #8d6e63;border-radius:10px;margin-bottom:14px;padding:14px}.step-badge{background:#8d6e63;border-radius:12px;color:#fff;display:inline-block;font-size:11px;font-weight:700;margin-bottom:10px;padding:4px 10px}.step-current{align-items:center;color:#5d4037;display:flex;font-size:16px;gap:8px;margin-bottom:8px}.step-icon{font-size:18px}.step-description{background:#ffffff80;border-radius:6px;color:#6d4c41;margin-bottom:8px;padding:8px 10px}.step-description,.step-next{font-size:13px;font-weight:500}.step-next{align-items:center;border-top:1px dashed #d7ccc8;color:#8d6e63;display:flex;gap:6px;margin-top:8px;padding-top:8px}.next-icon{font-size:12px}.step-complete{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:8px;color:#4caf50;font-size:14px;font-weight:700;margin-top:10px;padding:10px;text-align:center}.metrics-display{background:#fff9;border:2px solid #e8ddd0;border-radius:10px;padding:14px}.metrics-display h4{color:#5d4037;font-size:16px;font-weight:700;margin:0 0 12px}.metrics-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.metric-item{align-items:center;background:#8d6e630d;border-radius:8px;display:flex;gap:10px;padding:10px;transition:all .2s ease}.metric-item:hover{background:#8d6e631f;transform:translateX(2px)}.metric-icon{flex-shrink:0;font-size:20px}.metric-content{align-items:center;display:flex;flex:1 1;justify-content:space-between}.metric-label{color:#6d4c41;font-size:13px;font-weight:600}.metric-value{background:#8d6e6326;border-radius:6px;color:#5d4037;font-size:16px;font-weight:700;padding:3px 10px}.metric-range{background:#4caf5014;border-left:3px solid #4caf50;border-radius:4px;color:#8d6e63;font-size:11px;font-weight:500;margin:-6px 0 8px;padding:4px 12px}.progress-section{border-top:1px solid #e8ddd0;margin-top:12px;padding-top:12px}.progress-label{color:#8d6e63;font-size:12px;font-weight:600;margin-bottom:6px;text-align:center}.progress-bar-container{background:#e8ddd0;border-radius:8px;box-shadow:inset 0 2px 4px #0000001a;height:8px;overflow:hidden;width:100%}.progress-bar-fill{background:linear-gradient(90deg,#8d6e63,#6d4c41);border-radius:8px;box-shadow:0 2px 4px #0003;height:100%;transition:width .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.video-upload-container{align-items:center;background:linear-gradient(135deg,#f5f0e6,#e8ddd0);border:6px dashed #bcaaa4;border-radius:16px;display:flex;flex:1 1;justify-content:center;min-height:600px;min-width:640px;transition:all .3s ease}.video-upload-container:hover{background:linear-gradient(135deg,#e8ddd0,#d7ccc8);border-color:#8d6e63;transform:translateY(-2px)}.upload-placeholder{padding:40px;text-align:center}.upload-icon{font-size:64px;margin-bottom:20px;opacity:.7}.upload-placeholder h3{color:#5d4037;font-size:24px;font-weight:700;margin:0 0 10px}.upload-placeholder p{color:#8d6e63;font-size:16px;margin:0 0 16px}.upload-placeholder code{background:#8d6e6326;border-radius:4px;color:#5d4037;font-family:Courier New,monospace;font-size:14px;padding:3px 8px}.upload-placeholder .video-names{color:#a1887f;font-size:13px;font-style:italic;margin-bottom:20px}.upload-divider{color:#bcaaa4;font-size:14px;font-weight:600;margin:20px 0 16px;position:relative}.upload-divider:after,.upload-divider:before{background:#bcaaa4;content:"";height:1px;position:absolute;top:50%;width:80px}.upload-divider:before{right:calc(50% + 30px)}.upload-divider:after{left:calc(50% + 30px)}.upload-label{cursor:pointer;display:inline-block}.upload-btn-text{background:linear-gradient(135deg,#8d6e63,#6d4c41);border-radius:12px;box-shadow:0 4px 12px #5d40374d;color:#fff;display:inline-block;font-size:16px;font-weight:600;padding:14px 32px;transition:all .3s ease}.upload-btn-text:hover{background:linear-gradient(135deg,#6d4c41,#5d4037);box-shadow:0 6px 20px #5d403766;transform:translateY(-2px)}.video-container{animation:slideInFromRight .5s ease-out .4s backwards;background-color:#1a1a1a;border:3px solid #8d6e63;border-radius:10px;bottom:20px;box-shadow:0 6px 24px #5d403766,inset 0 0 0 1px #ffffff80;max-width:calc(100vw - 40px);overflow:hidden;position:fixed;right:20px;transition:transform .3s ease,box-shadow .3s ease;width:min(90vw,520px);width:min(90vw,var(--camera-width,520px));z-index:1000}.video-container:hover{box-shadow:0 10px 32px #5d403780,inset 0 0 0 1px #ffffff80;transform:translateY(-3px) scale(1.03)}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}.video{background:#000;display:block;transform:scaleX(-1)}.video-container .video{aspect-ratio:16/9;background-color:#1a1a1a;display:block;height:auto;min-height:0;object-fit:cover;width:100%}.video-container .canvas{background:#0000;display:block;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.bottom-section{align-items:flex-start;animation:fadeInUp .5s ease-out .2s backwards;display:flex;gap:20px;justify-content:flex-start;margin-bottom:15px;max-width:1400px;width:100%}.exercise-info-card{background:linear-gradient(135deg,#fff,#f5f0e6);border:3px solid #d7ccc8;border-radius:12px;box-shadow:0 6px 24px #5d403726,inset 0 0 0 1px #fffc;flex:0 0 auto;max-width:640px;padding:16px 20px;transition:transform .2s ease,box-shadow .2s ease;width:640px}.exercise-info-card:hover{box-shadow:0 8px 32px #5d403733,inset 0 0 0 1px #fffc;transform:translateY(-1px)}.exercise-title{margin-bottom:10px}.exercise-title h2{color:#5d4037;font-size:18px;font-weight:700;line-height:1.3;margin:0}.controls{align-items:stretch;display:flex;flex-direction:column;gap:10px}.restart-btn,.voice-btn{align-items:center;border:none;border-radius:10px;box-shadow:0 3px 10px #5d403733,0 1px 3px #0000001a;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;max-width:200px;outline:none;padding:12px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;width:100%}.btn-icon{font-size:18px}.btn-icon,.btn-text{line-height:1}.restart-btn{background:linear-gradient(135deg,#8d6e63,#6d4c41);color:#fff}.restart-btn:hover{background:linear-gradient(135deg,#6d4c41,#5d4037);box-shadow:0 4px 14px #5d403740,0 2px 6px #00000026;transform:translateY(-1px)}.restart-btn:active{box-shadow:0 2px 8px #5d403733,0 1px 3px #0000001a;transform:translateY(0)}.voice-btn{background:linear-gradient(135deg,#bcaaa4,#a1887f);color:#3e2723}.voice-btn.voice-on{background:linear-gradient(135deg,#66bb6a,#4caf50);box-shadow:0 3px 10px #4caf504d,0 1px 3px #0000001a;color:#fff}.voice-btn.voice-on:hover{background:linear-gradient(135deg,#4caf50,#388e3c)}.voice-btn.voice-off{opacity:.75}.voice-btn:hover{box-shadow:0 4px 14px #5d403740,0 2px 6px #0000001a;transform:translateY(-1px)}.voice-btn:active{box-shadow:0 2px 8px #5d403726,0 1px 3px #0000000d;transform:translateY(0)}.status-badge{animation:pulse 2s ease-in-out infinite;border-radius:16px;display:inline-block;font-size:12px;font-weight:600;padding:6px 14px}.status-badge.ready{background:linear-gradient(135deg,#66bb6a,#4caf50);box-shadow:0 2px 8px #4caf504d;color:#fff}.status-badge.positioning{background:linear-gradient(135deg,#ffa726,#ff9800);box-shadow:0 2px 8px #ff98004d;color:#fff}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width:1200px){.video-and-instructions{flex-direction:column}.instruction-panel,.reference-video-container,.video-upload-container{min-width:100%;width:100%}.instruction-panel{flex:1 1;max-height:none}.bottom-section{align-items:center;flex-direction:column;gap:12px}.controls,.exercise-info-card{width:100%}.controls{align-items:center}.restart-btn,.voice-btn{max-width:100%}.video-container{max-width:480px}}@media (max-width:768px){.app-container{padding:12px 10px}.app-header h1{font-size:22px}.app-header p{font-size:12px}.video-section{gap:10px;margin-bottom:10px}.reference-video-container,.video-upload-container{max-width:100%;min-width:100%;width:100%}.instruction-panel{min-width:100%;padding:14px}.instruction-header h3{font-size:16px}.message-text{font-size:13px}.bottom-section{margin-bottom:10px}.exercise-title h2{font-size:16px}.restart-btn,.voice-btn{max-width:300px}.video-container{bottom:10px;right:10px;width:160px}.video-container .video-header{padding:4px 8px}.video-container .video-header h3{font-size:10px}.video-container .status-indicator{font-size:8px;padding:2px 5px}.reference-video{height:auto!important;width:100%!important}.video-header h3{font-size:14px}.upload-icon{font-size:48px}.upload-placeholder h3{font-size:18px}}@media (max-width:480px){.video-container{border-width:2px;bottom:8px;right:8px;width:140px}.video-container .video-header{padding:3px 6px}.video-container .video-header h3{font-size:9px}.video-container .status-indicator{font-size:7px;padding:1px 4px}}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #8d6e6333;border-radius:50%;border-top-color:#8d6e63;height:40px;margin:20px auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.restart-btn:focus,.voice-btn:focus{outline:3px solid #8d6e6380;outline-offset:2px}
/*# sourceMappingURL=main.bdab46f3.css.map*/