:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;--primary: #059669;--primary-dark: #047857;--primary-light: #10b981;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--text: #1f2937;--text-light: #6b7280;--text-muted: #9ca3af;--bg: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border: #e5e7eb;--border-light: #f3f4f6;--shadow: rgba(0, 0, 0, .1);--shadow-lg: rgba(0, 0, 0, .15);--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(135deg,#064e3b,#059669,#10b981)}#app{max-width:1400px;margin:0 auto;padding:1rem;min-height:100vh;display:flex;flex-direction:column}header{text-align:center;margin-bottom:2rem;color:#fff;padding:2rem 0}header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.2)}header p{font-size:1.1rem;opacity:.95;margin-bottom:1rem}.version-info{display:flex;justify-content:center;align-items:center;gap:1rem}.version{background:#fff3;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500}.status{font-size:.875rem;opacity:.9;transition:all .3s ease;padding:.25rem .75rem;border-radius:12px;font-weight:500}.status.loading{background:#3b82f633;color:#2563eb}.status.ready{background:#22c55e33;color:#16a34a}.status.error{background:#ef444433;color:#dc2626}main{flex:1;background:var(--bg);border-radius:var(--radius-xl);padding:2rem;box-shadow:0 20px 60px #0000004d}.config-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;display:grid;grid-template-columns:1fr 2fr;gap:2rem}.config-section h3{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--text);font-size:1.1rem}.config-section label{display:flex;align-items:center;gap:.5rem;font-weight:500;margin-bottom:.5rem;color:var(--text)}.config-section select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:.95rem}.preset-info{margin-top:1rem;padding:1rem;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius);font-size:.875rem}.preset-info h4{color:var(--primary);margin-bottom:.5rem}.preset-info details{margin-top:.5rem}.preset-info summary{cursor:pointer;font-weight:500;color:var(--text-light)}.preset-info pre{background:var(--bg-tertiary);padding:.75rem;border-radius:var(--radius);font-size:.75rem;overflow-x:auto;margin-top:.5rem}.advanced-options{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.range-label{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.range-label input[type=range]{flex:1;accent-color:var(--primary)}.range-label output{min-width:50px;font-weight:500;color:var(--primary)}.background-options{display:flex;flex-direction:column;gap:1rem}.background-controls{padding:1rem;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border-light)}.background-controls label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text)}.background-controls select,.background-controls input[type=color],.background-controls input[type=file]{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:.9rem}.bg-type-controls{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.gradient-colors{display:flex;gap:1rem;margin-top:.5rem}.gradient-colors label{display:flex;align-items:center;gap:.5rem;margin-bottom:0}.gradient-colors input[type=color]{width:50px;height:30px;padding:0;border:1px solid var(--border);border-radius:4px}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid var(--border)}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:var(--text-light);font-size:1rem;cursor:pointer;transition:all .3s;position:relative;top:2px;display:inline-flex;align-items:center;gap:.5rem;-webkit-user-select:none;user-select:none}.tab i{width:18px;height:18px;pointer-events:none}.tab span{pointer-events:none}.tab:hover{color:var(--text)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-content{display:none}.tab-content.active{display:block}.upload-area{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:3rem;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg-secondary)}.upload-area:hover{border-color:var(--primary);background:var(--bg)}.upload-area.dragover{border-color:var(--primary);background:#ecfdf5}.upload-icon{width:64px;height:64px;color:var(--text-light);margin-bottom:1rem;stroke-width:1.5}.upload-area p{font-size:1.1rem;color:var(--text);margin-bottom:.5rem}.upload-area span{font-size:.9rem;color:var(--text-light)}#preview-canvas{max-width:100%;border-radius:var(--radius-lg);box-shadow:0 4px 6px var(--shadow)}.camera-container{position:relative}#camera-overlay{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:var(--radius-lg);pointer-events:none;z-index:2}#camera-video{width:100%;max-width:640px;height:auto;min-height:480px;border-radius:var(--radius-lg);background:#1a1a1a;display:block;margin:0 auto;object-fit:cover;border:2px solid var(--border)}.realtime-feedback{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem;text-align:center;min-width:200px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.realtime-feedback.excellent{background:#22c55ee6}.realtime-feedback.good{background:#3b82f6e6}.realtime-feedback.fair{background:#f59e0be6}.realtime-feedback.poor{background:#ef4444e6}.camera-controls{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;line-height:1}.btn i{width:16px;height:16px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #05966966}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-info{background:var(--info);color:#fff}.btn-info:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.btn-info.active{background:#1d4ed8}.btn-outline{background:#fff;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.validation-section{margin-top:3rem;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.validation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.validation-header h2{font-size:1.75rem;color:var(--text)}.score-badges{display:flex;gap:1rem}.score-badge,.confidence-badge{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;border-radius:var(--radius-lg);background:var(--bg-secondary);border:2px solid var(--border);min-width:80px}.score-badge.excellent,.confidence-badge.excellent{background:#dcfce7;border-color:var(--success)}.score-badge.good,.confidence-badge.good{background:#dbeafe;border-color:var(--info)}.score-badge.fair,.confidence-badge.fair{background:#fef3c7;border-color:var(--warning)}.score-badge.poor,.confidence-badge.poor{background:#fee2e2;border-color:var(--danger)}.score-value,.confidence-value{font-size:1.75rem;font-weight:700;line-height:1}.score-label,.confidence-label{font-size:.75rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.validation-status{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:2rem;background:var(--bg-secondary)}.validation-status.success{background:#dcfce7;color:#14532d}.validation-status.danger{background:#fee2e2;color:#7f1d1d}.status-icon{font-size:2rem;display:flex;align-items:center}.status-icon i{width:32px;height:32px}.status-text{font-size:1.1rem;font-weight:500}.metrics-container{margin-bottom:2rem}.metrics-container h3{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--text);font-size:1.25rem}.detailed-metrics{display:flex;flex-direction:column;gap:1.5rem}.metric-section h4{color:var(--primary);font-size:1rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.metric-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.metric-card{padding:1rem;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);transition:all .3s}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.metric-card.ok{border-left:4px solid var(--success)}.metric-card.fail{border-left:4px solid var(--danger)}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.metric-label{font-size:.875rem;color:var(--text-light);font-weight:500}.metric-status{font-size:1.25rem;display:flex;align-items:center}.metric-status i{width:20px;height:20px}.metric-card.ok .metric-status{color:var(--success)}.metric-card.fail .metric-status{color:var(--danger)}.metric-value{font-size:1.1rem;font-weight:600;color:var(--text)}.messages-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.messages-section,.suggestions-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem}.messages-section h3,.suggestions-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}.messages-section ul,.suggestions-section ul{list-style:none;padding:0}.message{padding:.75rem 1rem;margin-bottom:.5rem;border-radius:var(--radius);font-size:.9rem;border-left:4px solid}.message.error{background:#fee2e2;border-left-color:var(--danger);color:#7f1d1d}.message.warning{background:#fef3c7;border-left-color:var(--warning);color:#78350f}.processing-section{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.processing-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}.processing-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg);border-radius:var(--radius);font-size:.9rem}.stat-label{color:var(--text-light);font-weight:500}.stat-value{color:var(--primary);font-weight:600}.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.crop-section,.thumbnail-section{text-align:center;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem}.crop-section h3,.thumbnail-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}#crop-canvas{max-width:100%;border-radius:var(--radius);box-shadow:0 4px 6px var(--shadow);margin-bottom:1rem}#thumbnail{max-width:128px;border-radius:var(--radius);box-shadow:0 4px 6px var(--shadow)}.action-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.loading{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-content{text-align:center;color:#fff;max-width:300px}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:var(--primary-light);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.progress-bar{width:100%;height:32px;background:#ffffff26;border-radius:16px;overflow:hidden;margin-bottom:1rem;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:16px;width:0%;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 0 10px #10b98180}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:.875rem;text-shadow:0 1px 2px rgba(0,0,0,.5);z-index:1}.progress-text{font-size:1rem;margin:0;margin-bottom:.25rem;font-weight:500}.progress-subtext{font-size:.875rem;margin:0;opacity:.8;color:#ffffffe6}.validation-progress{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000e6;color:#fff;padding:1rem 2rem;border-radius:var(--radius-lg);display:flex;align-items:center;gap:1rem;z-index:1001;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.progress-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.face-indicator{position:fixed;top:20px;right:20px;background:#000c;color:#fff;padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;z-index:100}.notification{position:fixed;top:20px;right:20px;padding:1rem 1.5rem;border-radius:var(--radius);color:#fff;font-weight:500;z-index:1002;max-width:400px;animation:slideIn .3s ease-out}.notification.success{background:var(--success)}.notification.error{background:var(--danger)}.notification.warning{background:var(--warning)}.notification.info{background:var(--info)}.notification.fade-out{animation:fadeOut .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{to{opacity:0;transform:translate(100px)}}footer{margin-top:2rem;color:#fff;text-align:center;padding:1rem 0}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-links{display:flex;gap:1rem}.footer-links a{color:#fff;text-decoration:none;opacity:.8;transition:opacity .3s}.footer-links a:hover{opacity:1}@media (max-width: 1200px){.config-panel,.messages-container,.results-grid{grid-template-columns:1fr}}@media (max-width: 768px){#app{padding:.5rem}header h1{font-size:2rem}main{padding:1rem}.validation-header{flex-direction:column;text-align:center}.tabs{flex-direction:column;border-bottom:none}.tab{border-bottom:none;border-left:3px solid transparent;justify-content:center}.tab.active{border-left-color:var(--primary);border-bottom-color:transparent}.camera-controls,.action-buttons{flex-direction:column;align-items:center}.footer-content{flex-direction:column;text-align:center}.metric-cards{grid-template-columns:1fr}}@media (max-width: 480px){.score-badges{flex-direction:column;align-items:center}.processing-stats{grid-template-columns:1fr}.version-info{flex-direction:column;gap:1rem}.nav-links{justify-content:center}}.comparison-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:var(--bg);border-radius:var(--radius-lg);box-shadow:0 10px 40px var(--shadow-lg);max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;color:var(--text)}.close-modal{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-modal:hover{background:var(--bg-tertiary);color:var(--text)}.modal-body{padding:1.5rem}.similarity-meter{background:var(--bg-secondary);border-radius:var(--radius);height:40px;position:relative;overflow:hidden;margin:1rem 0}.similarity-bar{height:100%;background:var(--primary);transition:width .5s ease,background .3s ease;display:flex;align-items:center;justify-content:center}.similarity-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:600;color:var(--text);z-index:1}.similarity-label{text-align:center;font-weight:500;margin-top:.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.validation-history{background:var(--bg);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px var(--shadow)}.validation-history h3{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.history-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.history-item{background:var(--bg-secondary);border-radius:var(--radius);padding:1rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .2s;border-left:4px solid transparent}.history-item:hover{background:var(--bg-tertiary);transform:translate(4px)}.history-item.pass{border-left-color:var(--success)}.history-item.fail{border-left-color:var(--danger)}.history-item-info{flex:1}.history-item-score{font-size:1.5rem;font-weight:700;margin-left:1rem}.history-item.pass .history-item-score{color:var(--success)}.history-item.fail .history-item-score{color:var(--danger)}.history-item-time{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.history-actions{display:flex;gap:.5rem;margin-top:1rem}.history-empty{text-align:center;padding:2rem;color:var(--text-muted)}
