: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;display:flex;place-items:center;min-width:320px;min-height:100vh}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}}.container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:300px;height:300px;gap:20px}.box{background-color:#8df0cc;position:relative;z-index:1}.liveness-container{text-align:center;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.video-container{position:relative;display:inline-block;border-radius:20px;overflow:hidden;box-shadow:0 20px 40px #0000004d}.video-canvas{position:absolute;top:0;left:0;pointer-events:none;border-radius:20px}.title{margin-bottom:30px;color:#fff;font-size:2.5rem;font-weight:300;text-shadow:0 4px 15px rgba(0,0,0,.3)}.face-guide-square{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;height:300px;border:2px solid #2196F3;border-radius:10px;pointer-events:none;z-index:10;transition:border-color 2s ease,box-shadow 2s ease,opacity 2s ease,transform 2s ease;opacity:1}.face-guide-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.face-guide-overlay-sharp{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none;z-index:5;clip-path:polygon(0% 0%,0% 100%,calc(50% - 125px) 100%,calc(50% - 125px) calc(50% + 125px),calc(50% + 125px) calc(50% + 125px),calc(50% + 125px) 100%,100% 100%,100% 0%,calc(50% + 125px) 0%,calc(50% + 125px) calc(50% - 125px),calc(50% - 125px) calc(50% - 125px),calc(50% - 125px) 0%);transition:opacity .3s ease}.face-guide-square.face-detected{border-color:#4caf50;box-shadow:0 0 20px #4caf5099}.face-guide-square.hiding{opacity:0;transform:translate(-50%,-50%) scale(.9)}.guide-text{position:absolute;top:50%;left:50%;transform:translate(-50%,calc(-50% + 155px));color:#fff;font-size:14px;font-weight:600;text-align:center;background:#000000b3;padding:8px 12px;border-radius:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);pointer-events:none;z-index:11;transition:color .3s ease}.guide-text.face-detected{color:#4caf50}.guide-text.verifying{color:#2196f3;animation:text-pulse 1.5s infinite ease-in-out}.guide-text.complete{color:#4caf50;animation:text-success .5s ease-out}.controls{margin-top:30px}.loading-container{text-align:center;padding:40px;font-size:18px;color:#fff;min-height:50;display:flex;flex-direction:column;justify-content:center;align-items:center}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px;will-change:transform}.control-button{padding:15px 30px;color:#fff;border:none;border-radius:25px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 25px #0003}.control-button:hover{transform:translateY(-2px);box-shadow:0 12px 35px #0000004d}.control-button:active{transform:translateY(0)}.start-button{background:linear-gradient(135deg,#2196f3,#1976d2)}.stop-button{background:linear-gradient(135deg,#f44336,#d32f2f)}.success-checkmark{animation:checkmark-appear .6s ease-out;will-change:transform,opacity}.failed-cross{animation:cross-appear .6s ease-out;will-change:transform,opacity}@keyframes checkmark-appear{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}@keyframes cross-appear{0%{transform:scale(0) rotate(-90deg);opacity:0}50%{transform:scale(1.2) rotate(0);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}@keyframes text-pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes text-success{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.camera-overlay{position:absolute;top:0%;left:0%;width:100%;height:100%;z-index:10;background:#000000b3;-webkit-mask-image:radial-gradient(circle at center,transparent 35%,black 30%);mask-image:radial-gradient(circle at center,transparent 35%,black 30%);animation:shrink-circle-smooth .8s cubic-bezier(.25,.46,.45,.94) forwards;will-change:mask-size}.progress-ring{pointer-events:none;position:absolute;top:50%;left:50%;opacity:0;transform:translate(-50%,-50%) rotate(30deg);animation:fade-in-progress .3s ease-out .8s forwards;will-change:opacity,transform}.progress-circle{animation:progress-fill 10s linear infinite}.tick-mark{animation:tick-fill 10s linear infinite .5s}.tick-mark-static{transition:stroke .2s ease,opacity .2s ease;will-change:stroke,opacity}@keyframes progress-fill{0%{stroke-dashoffset:754}to{stroke-dashoffset:0}}@keyframes tick-fill{0%{stroke:#fff3;opacity:.3}5%{stroke:#4caf50;opacity:1}95%{stroke:#4caf50;opacity:1}to{stroke:#fff3;opacity:.3}}@keyframes tick-fade{0%,to{opacity:.6}50%{opacity:1}}@keyframes shrink-circle-smooth{0%{-webkit-mask-image:radial-gradient(circle at center,transparent 100%,black 100%);mask-image:radial-gradient(circle at center,transparent 100%,black 100%)}10%{-webkit-mask-image:radial-gradient(circle at center,transparent 92%,black 92%);mask-image:radial-gradient(circle at center,transparent 92%,black 92%)}20%{-webkit-mask-image:radial-gradient(circle at center,transparent 85%,black 85%);mask-image:radial-gradient(circle at center,transparent 85%,black 85%)}30%{-webkit-mask-image:radial-gradient(circle at center,transparent 77%,black 77%);mask-image:radial-gradient(circle at center,transparent 77%,black 77%)}40%{-webkit-mask-image:radial-gradient(circle at center,transparent 70%,black 70%);mask-image:radial-gradient(circle at center,transparent 70%,black 70%)}50%{-webkit-mask-image:radial-gradient(circle at center,transparent 62%,black 62%);mask-image:radial-gradient(circle at center,transparent 62%,black 62%)}60%{-webkit-mask-image:radial-gradient(circle at center,transparent 55%,black 55%);mask-image:radial-gradient(circle at center,transparent 55%,black 55%)}70%{-webkit-mask-image:radial-gradient(circle at center,transparent 47%,black 47%);mask-image:radial-gradient(circle at center,transparent 47%,black 47%)}80%{-webkit-mask-image:radial-gradient(circle at center,transparent 40%,black 40%);mask-image:radial-gradient(circle at center,transparent 40%,black 40%)}90%{-webkit-mask-image:radial-gradient(circle at center,transparent 35%,black 35%);mask-image:radial-gradient(circle at center,transparent 35%,black 35%)}}@keyframes fade-in-progress{0%{opacity:0;transform:translate(-50%,-50%) rotate(-40deg) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) rotate(-40deg) scale(1)}}@media (prefers-reduced-motion: reduce){.success-checkmark,.failed-cross,.loading-spinner,.progress-ring{animation:none!important}.tick-mark-static{transition:none!important}}@media (max-width: 480px) and (max-height: 800px){.camera-overlay{animation-duration:.3s}.progress-ring{animation-duration:.2s}.success-checkmark,.failed-cross{animation-duration:.4s}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e);color:#fff;overflow:hidden}.app{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;position:relative}.liveness-container{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:radial-gradient(circle at center,rgba(59,130,246,.1) 0%,transparent 70%)}.camera-container{position:relative;width:400px;height:400px;border-radius:50%;overflow:hidden;margin-bottom:2rem}.camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.face-overlay{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;border:4px solid transparent;background:linear-gradient(45deg,#3b82f6,#8b5cf6,#06b6d4,#10b981) border-box;mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:xor;animation:pulse 2s ease-in-out infinite}.face-overlay.detected{border-color:#10b981;animation:none;box-shadow:0 0 30px #10b98180}.face-overlay.not-detected{border-color:#ef4444;animation:shake .5s ease-in-out}.face-overlay.loading{border-color:#3b82f6;animation:spin 2s linear infinite}.face-landmarks{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.landmark-point{position:absolute;width:6px;height:6px;background:#10b981;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px #10b981cc}.face-corner{position:absolute;width:20px;height:20px;border:2px solid #10b981;transform:translate(-50%,-50%)}.face-corner.top-left{border-right:none;border-bottom:none}.face-corner.top-right{border-left:none;border-bottom:none}.face-corner.bottom-left{border-right:none;border-top:none}.face-corner.bottom-right{border-left:none;border-top:none}.camera-status{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#000000b3;padding:8px 16px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-indicator{width:12px;height:12px;border-radius:50%;background:#ef4444;transition:all .3s ease}.status-text{font-size:.875rem;color:#fff}.camera-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;background:#000c;padding:2rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.camera-loading p{margin-top:1rem;color:#94a3b8}@keyframes pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.instructions{text-align:center;margin-bottom:2rem;position:relative}.instruction-icon{margin-bottom:1rem;display:flex;justify-content:center}.instruction-title{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#fff}.instruction-text{font-size:1rem;color:#94a3b8;margin-bottom:1rem}.step-progress{width:200px;margin:1rem auto;text-align:center}.step-progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.step-progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.step-progress-text{font-size:.875rem;color:#94a3b8}.additional-hint{margin-top:1rem;padding:.75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:8px}.hint-text{font-size:.875rem;color:#93c5fd;margin:0}.success-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px;color:#10b981;font-weight:500}.progress-container{width:300px;margin-bottom:2rem}.progress-bar{width:100%;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:2px;transition:width .3s ease}.progress-steps{display:flex;justify-content:space-between;margin-top:1rem;position:relative}.progress-step{width:40px;height:40px;border-radius:50%;background:#fff3;transition:all .3s ease;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;font-size:.875rem;font-weight:600}.progress-step.active{background:#3b82f6;box-shadow:0 0 20px #3b82f680;transform:scale(1.1)}.progress-step.completed{background:#10b981;color:#fff}.step-number{color:#fff;font-weight:600}.step-tooltip{position:absolute;bottom:-35px;left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s ease}.progress-step:hover .step-tooltip{opacity:1}.progress-text{display:flex;justify-content:space-between;margin-top:1rem;font-size:.875rem}.current-step{color:#fff;font-weight:500}.total-progress{color:#94a3b8}.button{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #3b82f64d}.button:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-message{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mb-4{margin-bottom:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mt-4{margin-top:1rem}.text-blue-400{color:#60a5fa}.text-green-400{color:#4ade80}.text-sm{font-size:.875rem}@media (max-width: 768px){.camera-container{width:300px;height:300px}.progress-container{width:250px}.instruction-title{font-size:1.25rem}.progress-step{width:32px;height:32px;font-size:.75rem}}
