:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.App{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.face-recognition-system{max-width:1200px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;overflow:hidden}.system-header{background:#2c3e50;color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.system-header h1{margin:0;font-size:24px}.connection-status{display:flex;align-items:center;gap:10px}.status-indicator{padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500}.status-indicator.connected{background:#27ae60;color:#fff}.status-indicator.disconnected{background:#e74c3c;color:#fff}.error-banner{background:#e74c3c;color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.retry-button{background:#fff;color:#e74c3c;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500}.retry-button:hover{background:#f8f9fa}.main-content{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px}.camera-section,.results-section{background:#f8f9fa;border-radius:8px;padding:20px}.camera-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.camera-header h2{margin:0;color:#2c3e50}.control-button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.control-button.start{background:#27ae60;color:#fff}.control-button.stop{background:#e74c3c;color:#fff}.control-button:disabled{background:#bdc3c7;cursor:not-allowed}.control-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0003}.camera-capture{position:relative}.video-container{position:relative;background:#000;border-radius:8px;overflow:hidden}.error-message,.loading-message{text-align:center;padding:20px;color:#e74c3c;background:#fdf2f2;border-radius:6px;margin-top:10px}.loading-message{color:#3498db;background:#ebf3fd}.recognition-results{min-height:200px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #ecf0f1}.results-header h3{margin:0;color:#2c3e50}.timestamp{font-size:12px;color:#7f8c8d}.no-results,.no-faces{text-align:center;padding:40px 20px;color:#7f8c8d;background:#f8f9fa;border-radius:6px}.processing{text-align:center;padding:40px 20px;color:#3498db}.spinner{width:40px;height:40px;border:4px solid #ecf0f1;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)}}.faces-count{font-weight:500;color:#2c3e50;margin-bottom:15px}.face-item{background:#fff;border:1px solid #ecf0f1;border-radius:6px;padding:15px;margin-bottom:10px}.face-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.face-name{font-weight:500;color:#2c3e50}.face-confidence{font-size:14px;color:#27ae60;font-weight:500}.face-bounds{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:12px;color:#7f8c8d}.bound-info{display:flex;justify-content:space-between}.system-info{background:#ecf0f1;padding:15px 20px;display:flex;justify-content:space-around;border-top:1px solid #bdc3c7}.info-item{display:flex;flex-direction:column;align-items:center;gap:5px;font-size:14px}.info-item span:first-child{color:#7f8c8d;font-weight:500}.info-item span:last-child{color:#2c3e50;font-weight:600}.fps-settings{margin:20px 0;padding:15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #3498db}.fps-settings h4{margin:0 0 15px;color:#2c3e50;font-size:16px}.fps-controls{display:grid;grid-template-columns:1fr 1fr;gap:15px}.fps-control{display:flex;flex-direction:column;gap:5px}.fps-control label{font-size:14px;color:#2c3e50;font-weight:500}.fps-control select{padding:8px 12px;border:1px solid #bdc3c7;border-radius:4px;background:#fff;font-size:14px;color:#2c3e50;cursor:pointer;transition:border-color .3s ease}.fps-control select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.fps-control select:disabled{background:#ecf0f1;color:#7f8c8d;cursor:not-allowed}.control-buttons{display:flex;flex-direction:column;gap:10px}.verification-controls{margin-top:10px}.control-button.verification{background:#9b59b6;color:#fff}.control-button.stop-verification{background:#e67e22;color:#fff}.control-button.clear-results{background:#95a5a6;color:#fff;margin-top:15px}.control-button.clear-results:hover:not(:disabled){background:#7f8c8d}.results-controls{margin-top:20px;text-align:center}.verification-completed{margin-top:20px;padding:20px;background:#d5f4e6;border-radius:8px;border-left:4px solid #27ae60;text-align:center}.success-icon{font-size:48px;margin-bottom:15px}.verification-completed h3{color:#27ae60;margin:0 0 10px;font-size:24px}.verification-completed p{color:#2c3e50;margin:0 0 20px}.system-stopped{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:10px;margin:15px 0}.system-stopped p{margin:0;color:#856404;font-weight:500}.completed-actions{text-align:left;margin-top:15px}.completed-actions h4{color:#2c3e50;margin:0 0 10px}.completed-actions ul{list-style:none;padding:0;margin:0}.completed-action{padding:8px 12px;margin:5px 0;background:#fff;border-radius:4px;color:#27ae60;font-weight:500}.verification-active{margin-top:20px;padding:20px;background:#e8f4fd;border-radius:8px;border-left:4px solid #3498db}.verification-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.verification-header h3{margin:0;color:#2c3e50}.progress-info{background:#3498db;color:#fff;padding:5px 12px;border-radius:15px;font-weight:500;font-size:14px}.current-action{margin-bottom:15px}.current-action h4{color:#2c3e50;margin:0 0 10px;font-size:16px}.action-instruction{background:#fff;padding:15px;border-radius:6px;font-size:18px;font-weight:500;color:#2c3e50;text-align:center;border:2px solid #3498db}.progress-bar{width:100%;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden;margin-top:15px}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease}.action-completed{background:#d5f4e6;border:1px solid #27ae60;border-radius:6px;padding:12px;margin:10px 0;text-align:center;animation:pulse 1s infinite}.action-completed p{margin:0;color:#27ae60;font-weight:500}.timeout-message{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:12px;margin:10px 0;text-align:center}.timeout-icon{font-size:24px;margin-bottom:5px;animation:spin 1s linear infinite}.timeout-message p{margin:0;color:#856404;font-weight:500}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.analysis-logs{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #3498db}.analysis-logs h4{margin:0 0 10px;color:#2c3e50;font-size:16px}.logs-list{list-style:none;padding:0;margin:0}.log-item{padding:8px 12px;margin:5px 0;background:#fff;border-radius:4px;border-left:3px solid #27ae60;font-size:14px;color:#2c3e50;box-shadow:0 1px 3px #0000001a}.log-item:before{content:"🧠 ";margin-right:5px}@media(max-width:768px){.main-content{grid-template-columns:1fr}.system-header,.camera-header{flex-direction:column;gap:15px;text-align:center}.system-info{flex-direction:column;gap:15px}.fps-controls{grid-template-columns:1fr}.control-buttons{align-items:center}.verification-header{flex-direction:column;gap:10px;text-align:center}.action-instruction{font-size:16px;padding:12px}}.video-container{position:relative;display:inline-block;width:100%;max-width:960px;border-radius:12px;overflow:hidden;background:#000}.camera-video{width:100%;height:auto;display:block}.face-oval-overlay{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.face-oval-svg{display:block}.verification-preparing{margin-top:20px;padding:20px;background:#e8f5e8;border-radius:8px;border-left:4px solid #4caf50;text-align:center}.verification-preparing .verification-header h3{color:#2e7d32;margin:0 0 15px}.preparing-message{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:15px;padding:15px;background:#fff;border-radius:8px;border:2px solid #4caf50}.preparing-icon{font-size:24px;animation:preparing-pulse 2s ease-in-out infinite}.preparing-message p{margin:0;color:#2e7d32;font-weight:500;font-size:16px}@keyframes preparing-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}.verification-approach{margin-top:20px;padding:20px;background:#fff8e1;border-radius:8px;border-left:4px solid #ff9800}.countdown-timer{display:flex;align-items:center;justify-content:center;gap:10px;margin:15px 0;padding:12px 20px;background:#fff;border-radius:8px;border:2px solid #ff9800;font-weight:600;font-size:18px;color:#e65100;transition:all .3s ease}.countdown-timer.low-time{background:#ffebee;border-color:#e74c3c;color:#c62828;animation:timer-warning 1s ease-in-out infinite}.timer-icon{font-size:24px}.timer-text{font-family:Courier New,monospace;font-weight:700}@keyframes timer-warning{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.verification-approach .verification-header h3{color:#e65100}.verification-approach .progress-info{background:#ff9800}.approach-message{display:flex;align-items:center;gap:10px;margin-bottom:15px;padding:12px;background:#fff;border-radius:6px;border:1px solid #ffcc02}.approach-icon{font-size:24px}.approach-message p{margin:0;color:#e65100;font-weight:500;font-size:16px}.approach-stats{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fff;border-radius:6px;border:1px solid #ffcc02}.stat-item span:first-child{color:#e65100;font-weight:500;font-size:14px}.stat-value{font-weight:600;font-size:16px}.stat-value.success{color:#27ae60}.stat-value.warning{color:#e67e22}.approach-progress{margin-bottom:15px}.approach-progress .progress-bar{margin-bottom:8px}.approach-progress-fill{background:linear-gradient(90deg,#ff9800,#ff5722)}.progress-text{text-align:center;font-size:14px;color:#e65100;font-weight:500}.verification-failed{margin-top:20px;padding:20px;background:#ffebee;border-radius:8px;border-left:4px solid #e74c3c;text-align:center}.error-icon{font-size:48px;margin-bottom:15px}.verification-failed h3{color:#e74c3c;margin:0 0 10px;font-size:24px}.verification-failed p{color:#2c3e50;margin:0 0 20px}.approach-failed{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:12px;margin:15px 0}.error-icon-small{font-size:24px;margin-bottom:5px}.approach-failed p{margin:5px 0;color:#856404;font-weight:500}.approach-success{background:#d5f4e6;border:1px solid #27ae60;border-radius:6px;padding:12px;margin:15px 0}.success-icon-small{font-size:24px;margin-bottom:5px}.approach-success p{margin:0;color:#27ae60;font-weight:500}@keyframes approach-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.verification-approach{animation:approach-pulse 2s ease-in-out infinite}@media(max-width:768px){.approach-stats{grid-template-columns:1fr}.approach-message{flex-direction:column;text-align:center;gap:8px}.stat-item{flex-direction:column;gap:5px;text-align:center}}.video-container{position:relative}.step-timer-badge{position:absolute;top:8px;right:8px;background:#000000a6;color:#fff;padding:6px 10px;border-radius:8px;font-weight:600;font-size:14px}.warnings-panel{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:6px}.warning-chip{background:#ffc400e6;color:#222;padding:6px 10px;border-radius:8px;font-size:13px;font-weight:600;box-shadow:0 2px 6px #00000026}
