: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}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0e1a;background-image:radial-gradient(ellipse at 20% 0%,rgba(99,102,241,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(139,92,246,.1) 0%,transparent 60%);min-height:100vh;color:#e2e8f0}#root{width:100%;max-width:100%;margin:0;padding:0;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh;width:100%}.header{background:#0f1423cc;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);padding:16px 20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.06)}.logo{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px;color:#fff}.logo-text{font-size:20px;font-weight:700;letter-spacing:-.3px}.subtitle{font-size:12px;opacity:.5;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.content{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;width:100%;max-width:100%;overflow-x:hidden}.footer{background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px 20px;text-align:center;font-size:12px;line-height:1.6;opacity:.6;border-top:1px solid rgba(255,255,255,.04)}.footer .small{font-size:11px;opacity:.7;margin-top:2px}.scanner-container{width:100%;max-width:500px;margin:0 auto}.scanner-frame{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #00000080;border:1px solid rgba(255,255,255,.06)}.scanner-video{width:100%;height:100%;object-fit:cover}.scanner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0000004d}.scanner-box{position:relative;width:250px;height:250px;border:2px solid rgba(255,255,255,.3);border-radius:12px}.corner{position:absolute;width:20px;height:20px;border:3px solid #818cf8}.corner.top-left{top:-2px;left:-2px;border-right:none;border-bottom:none;border-radius:12px 0 0}.corner.top-right{top:-2px;right:-2px;border-left:none;border-bottom:none;border-radius:0 12px 0 0}.corner.bottom-left{bottom:-2px;left:-2px;border-right:none;border-top:none;border-radius:0 0 0 12px}.corner.bottom-right{bottom:-2px;right:-2px;border-left:none;border-top:none;border-radius:0 0 12px}.scan-line{position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,#818cf8,transparent);animation:scan 2s linear infinite}@keyframes scan{0%{top:0}to{top:100%}}.scanner-instructions{margin-top:28px;text-align:center}.scanner-instructions h3{font-size:20px;margin-bottom:8px;font-weight:600;color:#fff}.scanner-instructions p{font-size:14px;opacity:.6;line-height:1.5}.scanner-status{text-align:center;padding:40px 20px}.scanner-status .icon{font-size:64px;margin-bottom:20px}.scanner-status h3{font-size:20px;margin-bottom:8px;color:#fff}.scanner-status p{font-size:14px;opacity:.6;line-height:1.5;max-width:300px;margin:0 auto}.biometric-container{width:100%;max-width:400px;margin:0 auto}.biometric-card{background:#ffffff0a;-webkit-backdrop-filter:blur(24px) saturate(180%);backdrop-filter:blur(24px) saturate(180%);border-radius:24px;padding:32px 24px;box-shadow:0 0 0 1px #ffffff0f,0 20px 60px #0006}.biometric-icon{display:flex;justify-content:center;margin-bottom:24px}.icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.icon-wrapper.pulse{animation:pulse 2s ease-in-out infinite}.icon-wrapper.scanning{animation:pulse 1s ease-in-out infinite}.icon-wrapper.success .complete-check{width:80px;height:80px;background:linear-gradient(135deg,#34d399,#10b981);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px #34d39966;animation:successPop .5s cubic-bezier(.175,.885,.32,1.275)}.capture-ring{position:absolute;width:100px;height:100px;border:2px solid rgba(129,140,248,.4);border-radius:50%;animation:ringPulse 1.5s ease-out infinite}.capture-icon{color:#818cf8}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes successPop{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes ringPulse{0%{transform:scale(.8);opacity:1}to{transform:scale(2);opacity:0}}.biometric-status{text-align:center;margin-bottom:24px}.biometric-status h2{font-size:22px;margin-bottom:6px;font-weight:700;color:#fff}.biometric-status p{font-size:14px;opacity:.5;line-height:1.5}.bio-options{display:flex;flex-direction:column;gap:10px}.bio-option{display:flex;align-items:center;gap:14px;padding:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;transition:all .2s cubic-bezier(.4,0,.2,1);color:#e2e8f0;font:inherit;cursor:default;text-align:left;width:100%}.bio-option.available{cursor:pointer;border-color:#818cf840;background:#818cf80f}.bio-option.available:active{transform:scale(.98);background:#818cf81f}.bio-option.disabled{opacity:.35}.bio-option-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border-radius:12px;flex-shrink:0;color:#a5b4fc}.bio-option.disabled .bio-option-icon{color:#64748b}.bio-option-info{flex:1;min-width:0}.bio-option-info h3{font-size:15px;font-weight:600;color:#fff;margin-bottom:2px}.bio-option-info p{font-size:12px;opacity:.5;margin:0}.bio-badge{padding:4px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.5px;flex-shrink:0}.bio-badge.ready{background:#34d39926;color:#34d399;border:1px solid rgba(52,211,153,.3)}.bio-badge.coming{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.progress-container{width:100%;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin:16px 0 8px}.progress-bar{height:100%;background:linear-gradient(90deg,#818cf8,#a78bfa);border-radius:3px;transition:width .3s ease}.progress-text{font-size:12px;font-weight:600;opacity:.5;margin-top:4px}.privacy-notice{display:flex;gap:10px;align-items:flex-start;background:#ffffff08;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.04);margin-top:20px}.privacy-notice p{font-size:11px;line-height:1.5;opacity:.4;text-align:left;margin:0}.status-card{background:#ffffff0a;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:24px;padding:48px 28px;text-align:center;max-width:400px;width:100%;margin:0 auto;border:1px solid rgba(255,255,255,.06)}.status-card.error{border-color:#ff453a33}.status-icon{margin-bottom:20px;line-height:1}.status-card h2{font-size:22px;margin-bottom:8px;font-weight:700;color:#fff}.status-card p{font-size:14px;opacity:.6;line-height:1.5;margin-bottom:8px}.btn-primary,.btn-secondary{padding:14px 28px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:20px;min-width:160px}.btn-primary{background:linear-gradient(135deg,#818cf8,#6366f1);color:#fff;box-shadow:0 4px 16px #6366f14d}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:#ffffff14;color:#e2e8f0;border:1px solid rgba(255,255,255,.1)}.btn-secondary:active{background:#ffffff1f}.completion{width:100%;max-width:400px;margin:0 auto;animation:completionEnter .6s cubic-bezier(.16,1,.3,1)}@keyframes completionEnter{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.completion-badge{position:relative;width:96px;height:96px;margin:0 auto 24px}.badge-glow{position:absolute;inset:-16px;border-radius:50%;background:radial-gradient(circle,rgba(52,211,153,.3),transparent 70%);animation:glowPulse 2.5s ease-in-out infinite}.badge-ring{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(52,211,153,.3);animation:ringRotate 8s linear infinite;background:conic-gradient(from 0deg,rgba(52,211,153,.4),transparent,rgba(52,211,153,.4));mask:radial-gradient(farthest-side,transparent calc(100% - 2px),#000 calc(100% - 2px));-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 2px),#000 calc(100% - 2px))}.badge-check{position:absolute;inset:0;background:linear-gradient(135deg,#34d399,#10b981);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #34d39959}@keyframes glowPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes ringRotate{to{transform:rotate(360deg)}}.completion-title{text-align:center;font-size:26px;font-weight:700;color:#fff;margin-bottom:6px}.completion-subtitle{text-align:center;font-size:14px;opacity:.45;margin-bottom:28px}.completion-bio-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#34d3990f;border:1px solid rgba(52,211,153,.15);border-radius:16px;margin-bottom:20px;animation:cardSlideIn .5s .2s cubic-bezier(.16,1,.3,1) both}@keyframes cardSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.bio-card-visual{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#34d3991a;border-radius:14px;flex-shrink:0;color:#34d399;position:relative;overflow:hidden}.bio-card-scanline{position:absolute;width:100%;height:2px;background:linear-gradient(90deg,transparent,rgba(52,211,153,.6),transparent);animation:bioScan 2s ease-in-out infinite}@keyframes bioScan{0%,to{top:0;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.bio-card-text{flex:1}.bio-card-text h3{font-size:15px;font-weight:600;color:#fff;margin-bottom:2px}.bio-card-text p{font-size:12px;opacity:.45;margin:0}.bio-card-badge{width:28px;height:28px;background:#34d39926;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#34d399;flex-shrink:0}.completion-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.completion-grid-item{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:14px;padding:14px;text-align:center;animation:gridFade .4s ease both}.completion-grid-item:nth-child(1){animation-delay:.3s}.completion-grid-item:nth-child(2){animation-delay:.4s}.completion-grid-item:nth-child(3){animation-delay:.5s}.completion-grid-item:nth-child(4){animation-delay:.6s}@keyframes gridFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.grid-item-icon{width:36px;height:36px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;background:#818cf814;border-radius:10px;color:#a5b4fc}.grid-item-label{display:block;font-size:11px;opacity:.4;margin-bottom:2px;text-transform:uppercase;letter-spacing:.3px;font-weight:500}.grid-item-value{display:block;font-size:13px;font-weight:600;color:#fff}.completion-privacy{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:12px;margin-bottom:20px;color:#64748b;animation:gridFade .4s .7s ease both}.completion-privacy svg{flex-shrink:0;margin-top:1px}.completion-privacy p{font-size:11px;line-height:1.5;margin:0;opacity:.8}.completion-footer{text-align:center;animation:gridFade .4s .8s ease both}.completion-footer p{font-size:13px;opacity:.5;font-weight:500}.completion-footer-sub{font-size:12px;opacity:.3!important;margin-top:4px}.spinner{width:44px;height:44px;border:3px solid rgba(255,255,255,.1);border-top-color:#818cf8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
