*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;color:#fff;background:#1a1a2e;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit}img,svg{display:block;max-width:100%}.app{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#1a1a2e,#16213e,#0f3460);padding:2rem 1.5rem}.app-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4rem;width:100%;max-width:400px;animation:fadeIn .8s ease-out}.logo-section{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.logo{width:140px;height:140px;filter:drop-shadow(0 8px 32px rgba(233,69,96,.25));animation:float 4s ease-in-out infinite}.app-title{font-size:2.25rem;font-weight:700;color:#fff;letter-spacing:.04em;margin:0}.app-tagline{font-size:1rem;color:#ffffff8c;margin:0;letter-spacing:.02em}.action-section{width:100%}.login-button{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;letter-spacing:.04em;color:#fff;background:linear-gradient(135deg,#e94560,#c73659);border:none;border-radius:14px;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 20px #e9456059,0 0 #e9456000}.login-button:hover{transform:translateY(-2px);box-shadow:0 8px 30px #e9456073,0 0 #e9456000}.login-button:active{transform:translateY(0);box-shadow:0 2px 10px #e945604d,0 0 0 4px #e9456026}.scanner-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:440px;animation:fadeIn .5s ease-out}.scanner-header{display:flex;align-items:center;width:100%;padding-bottom:1.5rem}.back-button{display:flex;align-items:center;gap:.35rem;background:none;border:none;color:#ffffffbf;font-size:.95rem;font-weight:500;cursor:pointer;padding:.5rem .6rem .5rem 0;transition:color .2s;flex-shrink:0}.back-button:hover{color:#fff}.scanner-title{flex:1;text-align:center;font-size:1.25rem;font-weight:600;color:#fff;margin:0}.scanner-header-spacer{width:72px;flex-shrink:0}.qr-viewport{width:100%;border-radius:20px;overflow:hidden;background:#0d0d1a;border:2px solid rgba(255,255,255,.08)}.qr-reader{width:100%!important}.qr-reader video{border-radius:18px}#qr-reader__scan_region{min-height:300px}#qr-reader__dashboard{display:none!important}.bottom-hint{margin-top:1.5rem}.scanner-status-area{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:4rem 1rem}.status-text{font-size:1rem;color:#fff9;text-align:center}.spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.12);border-top-color:#e94560;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.handshake-display{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem}.handshake-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:#fff6}.handshake-code{font-size:2rem;font-weight:700;letter-spacing:.3em;color:#e94560;font-variant-numeric:tabular-nums}.scanner-error-area{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:3rem 1rem}.error-icon{width:56px;height:56px;border-radius:50%;background:#e9456026;color:#e94560;font-size:1.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid rgba(233,69,96,.3)}.error-text{font-size:1rem;color:#ffffffbf;text-align:center;max-width:300px;line-height:1.5}.retry-button{padding:.75rem 2.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#e94560,#c73659);border:none;border-radius:12px;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 16px #e945604d;margin-top:.5rem}.retry-button:hover{transform:translateY(-2px);box-shadow:0 6px 24px #e9456066}.retry-button:active{transform:translateY(0)}.poll-error{font-size:.85rem;color:#e94560;text-align:center;margin:.5rem 0 0;max-width:300px;animation:fadeIn .3s ease-out}.cards-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0 0 1.5rem;text-align:center}.cards-loading{display:flex;justify-content:center;padding:3rem 0}.cards-empty{font-size:1rem;color:#ffffff80;text-align:center;padding:2rem 0}.cards-list{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-bottom:2rem}.card-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1.1rem 1.25rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:14px;cursor:pointer;transition:all .2s ease;text-align:left;color:#fff;font-family:inherit;font-size:inherit}.card-item:hover{background:#ffffff1a;border-color:#e945604d}.card-item:active{transform:scale(.98);background:#e945601a}.card-category{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#e94560}.card-pan{font-size:.95rem;font-family:SF Mono,Fira Code,monospace;color:#ffffffb3;letter-spacing:.04em}.logout-button{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;letter-spacing:.04em;color:#fff;background:transparent;border:2px solid rgba(255,255,255,.15);border-radius:14px;cursor:pointer;transition:all .25s ease}.logout-button:hover{border-color:#e9456080;background:#e9456014;color:#e94560}.logout-button:active{background:#e9456026}.detail-header{display:flex;align-items:center;width:100%;margin-bottom:1.5rem}.detail-title{flex:1;text-align:center;font-size:1.25rem;font-weight:600;color:#fff;margin:0}.card-detail-grid{display:flex;flex-direction:column;gap:0;width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.85rem;color:#ffffff80;font-weight:500}.detail-value{font-size:.95rem;color:#fff;font-weight:600;text-align:right}.error-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1.5rem;animation:fadeIn .2s ease-out}.error-modal{display:flex;flex-direction:column;align-items:center;gap:1rem;background:#1e2742;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:2rem 1.75rem;max-width:340px;width:100%;box-shadow:0 16px 48px #0006}.error-modal-text{font-size:.95rem;color:#ffffffbf;text-align:center;margin:0;line-height:1.5}.error-modal-btn{width:100%;padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#e94560,#c73659);border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #e945604d;margin-top:.5rem}.error-modal-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #e9456066}.error-modal-btn:active{transform:translateY(0)}.pin-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:360px;animation:fadeIn .5s ease-out}.pin-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:2.5rem}.pin-title{font-size:1.5rem;font-weight:700;color:#fff;margin:0}.pin-subtitle{font-size:.9rem;color:#ffffff80;margin:0;text-align:center}.unlock-lock-icon{width:56px;height:56px;border-radius:50%;background:#e945601a;border:2px solid rgba(233,69,96,.25);display:flex;align-items:center;justify-content:center;color:#e94560;margin-bottom:.5rem}.pin-dots{display:flex;gap:1.25rem;margin-bottom:1.5rem}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:transparent;transition:all .15s ease}.pin-dot.filled{background:#e94560;border-color:#e94560;box-shadow:0 0 10px #e9456066}.pin-error{font-size:.85rem;color:#e94560;margin:0 0 1rem;text-align:center}.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;width:100%;max-width:280px}.keypad-btn{width:100%;aspect-ratio:1.4;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;color:#fff;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:14px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.keypad-btn:hover{background:#ffffff1f}.keypad-btn:active{background:#e9456033;transform:scale(.95)}.keypad-back{color:#fff9}.keypad-spacer{visibility:hidden}.switch-mode-link{margin-top:2rem;background:none;border:none;color:#ffffff80;font-size:.9rem;font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .2s}.switch-mode-link:hover{color:#fff}.bio-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:360px;animation:fadeIn .5s ease-out}.bio-icon{width:100px;height:100px;border-radius:50%;background:#e9456014;border:2px solid rgba(233,69,96,.2);display:flex;align-items:center;justify-content:center;color:#e94560;margin-bottom:1.5rem}.bio-icon.pulsing{animation:pulse 2s ease-in-out infinite}.bio-title{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .5rem}.bio-subtitle{font-size:.9rem;color:#ffffff80;margin:0 0 2rem;text-align:center;max-width:280px;line-height:1.5}.bio-error{font-size:.85rem;color:#e94560;margin:0 0 1rem;text-align:center;max-width:280px}.bio-register-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;letter-spacing:.04em;color:#fff;background:linear-gradient(135deg,#e94560,#c73659);border:none;border-radius:14px;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 20px #e9456059}.bio-register-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #e9456073}.bio-register-btn:active:not(:disabled){transform:translateY(0)}.bio-register-btn:disabled{opacity:.7;cursor:not-allowed}.spinner-small{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.shake{animation:shake .5s ease-in-out}@keyframes pulse{0%,to{box-shadow:0 0 #e945604d}50%{box-shadow:0 0 0 16px #e9456000}}
