*{margin:0;padding:0;box-sizing:border-box}body{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;background-color:#f5f5f5;color:#333;line-height:1.6}#root{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px}.card{background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px;margin-bottom:20px}.btn{display:inline-block;padding:12px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s}.btn:hover{background-color:#0056b3}.btn:disabled{background-color:#ccc;cursor:not-allowed}.btn-secondary{background-color:#6c757d}.btn-secondary:hover{background-color:#545b62}.btn-danger{background-color:#dc3545}.btn-danger:hover{background-color:#c82333}.upload-area{border:3px dashed #007bff;border-radius:12px;padding:50px;text-align:center;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#f8f9ff 0%,#ffffff 100%);position:relative;overflow:hidden}.upload-area:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(0,123,255,.05) 0%,rgba(0,123,255,.02) 100%);opacity:0;transition:opacity .3s ease}.upload-area:hover{border-color:#0056b3;transform:translateY(-2px);box-shadow:0 8px 25px #007bff26}.upload-area:hover:before{opacity:1}.upload-area.dragover{border-color:#0056b3;background:linear-gradient(135deg,#e3f2fd 0%,#f8f9ff 100%);transform:scale(1.02);box-shadow:0 12px 35px #007bff33}.progress-bar{width:100%;height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden;margin:10px 0}.progress-fill{height:100%;background-color:#007bff;transition:width .3s ease}.error{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;padding:12px;margin:10px 0}.success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;padding:12px;margin:10px 0}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.pose-canvas{max-width:100%;border:1px solid #ddd;border-radius:8px}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.angle-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #eee}.angle-item:last-child{border-bottom:none}.angle-value{font-weight:700;color:#007bff}.quality-indicator{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.quality-high{background-color:#d4edda;color:#155724}.quality-medium{background-color:#fff3cd;color:#856404}.quality-low{background-color:#f8d7da;color:#721c24}.extended-results-display{background:white;border-radius:12px;padding:24px;margin:20px 0;box-shadow:0 4px 12px #0000001a}.overall-assessment{margin-bottom:30px}.fit-quality-card{border-radius:12px;overflow:hidden;box-shadow:0 4px 8px #0000001a}.fit-quality-header{color:#fff;padding:20px;text-align:center}.fit-quality-header h2{margin:0 0 10px;font-size:24px;font-weight:700}.overall-grade{font-size:16px;opacity:.9}.primary-concerns{padding:20px;background:#f8f9fa}.primary-concerns h4{color:#2c3e50;margin-bottom:10px}.primary-concerns ul{margin:0;padding-left:20px}.primary-concerns li{margin-bottom:5px;color:#34495e}.quality-section{margin-bottom:30px}.quality-section h3{color:#2c3e50;margin-bottom:15px;border-bottom:2px solid #3498db;padding-bottom:8px}.quality-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.quality-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.angles-analysis{margin-bottom:30px}.angles-analysis h3{color:#2c3e50;margin-bottom:20px;border-bottom:2px solid #e74c3c;padding-bottom:8px}.angle-section{margin-bottom:25px;padding:20px;background:#f8f9fa;border-radius:10px;border-left:4px solid #e74c3c}.angle-section h4{color:#2c3e50;margin-bottom:15px;font-size:18px}.angle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px}.angle-item{background:white;padding:15px;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.angle-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.angle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.angle-name{font-weight:700;color:#2c3e50;font-size:14px}.angle-value-grade{display:flex;align-items:center;gap:8px}.angle-value{font-size:16px;font-weight:700;color:#34495e}.grade-badge{color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.angle-recommendation{margin-top:8px;padding:8px;background:#ecf0f1;border-radius:6px;border-left:3px solid #3498db}.angle-recommendation small{color:#34495e;line-height:1.4}.critical-issues{margin-bottom:30px;padding:20px;background:#fdf2f2;border-radius:10px;border-left:4px solid #e74c3c}.critical-issues h3{color:#c0392b;margin-bottom:15px}.critical-list{display:flex;flex-direction:column;gap:10px}.critical-item{padding:12px;background:white;border-radius:6px;border-left:3px solid #e74c3c;color:#c0392b;font-weight:500}.professional-recommendations{margin-bottom:30px}.professional-recommendations h3{color:#2c3e50;margin-bottom:20px;border-bottom:2px solid #27ae60;padding-bottom:8px}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.recommendation-item{padding:20px;background:#f0fff4;border-radius:10px;border-left:4px solid #27ae60}.recommendation-item h4{color:#27ae60;margin-bottom:10px;font-size:16px}.recommendation-item p{color:#2c3e50;margin:0;line-height:1.5}.general-suggestions{margin-bottom:30px;padding:20px;background:#f0f8ff;border-radius:10px;border-left:4px solid #3498db}.general-suggestions h3{color:#2980b9;margin-bottom:15px}.suggestions-list{margin:0;padding-left:20px}.suggestions-list li{margin-bottom:8px;color:#34495e;line-height:1.5}.analysis-info{margin-bottom:30px;padding:20px;background:#f8f9fa;border-radius:10px}.analysis-info h3{color:#2c3e50;margin-bottom:15px;border-bottom:2px solid #95a5a6;padding-bottom:8px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:white;border-radius:6px}.status-passed{color:#27ae60;font-weight:700}.status-failed{color:#e74c3c;font-weight:700}.results-actions{display:flex;gap:15px;justify-content:center;flex-wrap:wrap;padding-top:20px;border-top:2px solid #ecf0f1}@media (max-width: 768px){.extended-results-display{padding:16px}.quality-grid,.angle-grid,.recommendations-grid,.info-grid{grid-template-columns:1fr}.angle-header{flex-direction:column;align-items:flex-start;gap:8px}.angle-value-grade{align-self:flex-end}.results-actions{flex-direction:column}.fit-quality-header h2{font-size:20px}}.extended-pose-detector{max-width:1200px;margin:0 auto;padding:20px}.step-indicator{display:flex;justify-content:center;align-items:center;margin-bottom:30px;padding:20px;background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a}.step{display:flex;flex-direction:column;align-items:center;position:relative;flex:1;max-width:150px}.step:not(:last-child):after{content:"";position:absolute;top:20px;right:-50%;width:100%;height:2px;background:#e0e0e0;z-index:1}.step.completed:not(:last-child):after{background:#27ae60}.step-number{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;background:#e0e0e0;color:#666;margin-bottom:8px;position:relative;z-index:2;transition:all .3s ease}.step.active .step-number{background:#3498db;color:#fff;transform:scale(1.1)}.step.completed .step-number{background:#27ae60;color:#fff}.step-label{font-size:14px;color:#666;text-align:center;font-weight:500}.step.active .step-label{color:#3498db;font-weight:700}.step.completed .step-label{color:#27ae60}.no-image-message{text-align:center;padding:60px 20px;background:#f8f9fa;border-radius:12px;border:2px dashed #dee2e6}.no-image-message h3{color:#6c757d;margin-bottom:10px}.no-image-message p{color:#6c757d;margin:0}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;padding:20px;margin-bottom:20px;text-align:center}.error-message h4{color:#721c24;margin-bottom:10px}.error-message p{color:#721c24;margin-bottom:15px}.retry-button{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.retry-button:hover{background:#c82333}.loading-container{text-align:center;padding:40px 20px;background:white;border-radius:12px;box-shadow:0 2px 8px #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:0 auto 15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#666;margin:0;font-size:16px}.annotation-step,.results-step{background:white;border-radius:12px;padding:30px;box-shadow:0 4px 12px #0000001a}.step-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f1f3f4}.step-header h3{color:#2c3e50;margin-bottom:10px;font-size:24px}.step-header p{color:#666;margin:0;font-size:16px;line-height:1.5}.step-actions{display:flex;justify-content:center;gap:15px;margin-top:30px;padding-top:20px;border-top:2px solid #f1f3f4}.primary-button{background:#3498db;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:all .2s ease;min-width:120px}.primary-button:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 4px 8px #3498db4d}.secondary-button{background:#95a5a6;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:all .2s ease;min-width:120px}.secondary-button:hover{background:#7f8c8d;transform:translateY(-1px);box-shadow:0 4px 8px #95a5a64d}@media (max-width: 768px){.extended-pose-detector{padding:10px}.step-indicator{padding:15px 10px}.step{max-width:100px}.step:not(:last-child):after{right:-40%;width:80%}.step-number{width:35px;height:35px;font-size:14px}.step-label{font-size:12px}.annotation-step,.results-step{padding:20px 15px}.step-header h3{font-size:20px}.step-header p{font-size:14px}.step-actions{flex-direction:column;align-items:center}.primary-button,.secondary-button{width:100%;max-width:200px}}.mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.mode-option{padding:25px;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s ease;background:#f8f9fa;position:relative;overflow:hidden}.mode-option:hover{border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 12px #3498db33}.mode-option.active{border-color:#3498db;background:#e3f2fd;box-shadow:0 4px 12px #3498db4d}.mode-option.active:before{content:"✓";position:absolute;top:15px;right:15px;width:25px;height:25px;background:#3498db;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.mode-option h3{color:#2c3e50;margin-bottom:10px;font-size:20px;font-weight:700}.mode-option.active h3{color:#2980b9}.mode-option p{color:#666;margin-bottom:15px;line-height:1.5;font-size:14px}.mode-option.active p{color:#34495e}.mode-option ul{margin:0;padding-left:20px;list-style-type:disc}.mode-option li{color:#666;margin-bottom:8px;font-size:13px;line-height:1.4}.mode-option.active li{color:#34495e}@media (max-width: 768px){.mode-selector{grid-template-columns:1fr;gap:15px}.mode-option{padding:20px}.mode-option h3{font-size:18px}.mode-option.active:before{top:12px;right:12px;width:22px;height:22px;font-size:12px}}
