.portal-root{min-height:100vh;width:100%;flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background:radial-gradient(ellipse at top,#13132a 0,var(--bg) 70%);position:relative;overflow:hidden}.portal-root:after,.portal-root:before{content:"";position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0}.portal-root:before{width:600px;height:600px;background:rgba(99,102,241,.12);top:-200px;left:-200px}.portal-root:after{width:500px;height:500px;background:rgba(139,92,246,.1);bottom:-200px;right:-200px}.portal-card{background:rgba(15,15,30,.85);border:1px solid var(--border2);border-radius:20px;padding:36px 32px;width:100%;max-width:420px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px rgba(99,102,241,.05);position:relative;z-index:1;animation:slideUp .4s ease}.portal-logo{flex-direction:column;margin-bottom:28px;gap:10px}.portal-logo,.portal-logo-icon{display:flex;align-items:center}.portal-logo-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:16px;justify-content:center;font-size:24px;font-weight:800;color:#fff;box-shadow:0 8px 24px rgba(99,102,241,.45)}.portal-logo-title{font-size:20px;font-weight:700}.portal-logo-sub{font-size:13px;color:var(--text-muted)}.portal-step-header{text-align:center;margin-bottom:24px}.portal-step-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 12px}.portal-step-title{font-size:18px;font-weight:700;margin-bottom:4px}.portal-step-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.portal-user-preview{display:flex;align-items:center;gap:12px;background:hsla(0,0%,100%,.04);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:20px}.portal-user-preview .user-avatar-fallback,.portal-user-preview img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.portal-user-preview .user-avatar-fallback{background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.pup-name{font-size:15px;font-weight:600}.pup-email{font-size:12px;color:var(--text-muted)}.portal-camera-wrap{position:relative;width:100%;aspect-ratio:1;background:#000;border-radius:16px;overflow:hidden;margin-bottom:16px;border:2px solid var(--border)}.portal-camera-wrap.active{border-color:var(--accent)}.portal-camera-wrap video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.portal-camera-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.face-guide{width:180px;height:180px;border-radius:50%;border:2px dashed hsla(0,0%,100%,.3);animation:breathe 3s ease infinite}@keyframes breathe{0%,to{transform:scale(1);border-color:hsla(0,0%,100%,.3)}50%{transform:scale(1.04);border-color:rgba(99,102,241,.6)}}.portal-camera-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim);gap:10px;cursor:pointer;transition:background var(--t)}.portal-camera-placeholder:hover{background:hsla(0,0%,100%,.03)}.portal-camera-placeholder svg{opacity:.4}.portal-camera-placeholder p{font-size:13px}.portal-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:16px}.portal-qr-image{border-radius:16px;border:4px solid rgba(99,102,241,.2);box-shadow:0 0 40px rgba(99,102,241,.15);transition:all .3s ease;width:240px;height:240px}.portal-qr-image.refreshing{opacity:.3;transform:scale(.97)}.qr-timer-ring{position:relative;width:60px;height:60px}.qr-timer-ring svg{transform:rotate(-90deg)}.qr-timer-ring circle{fill:none;stroke-width:4;transition:stroke-dashoffset 1s linear}.qr-timer-ring .bg{stroke:hsla(0,0%,100%,.08)}.qr-timer-ring .bar{stroke:var(--accent);stroke-linecap:round}.qr-timer-seconds{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:var(--accent)}.qr-timer-label{font-size:12px;color:var(--text-muted);text-align:center}.portal-security-badge{display:flex;align-items:center;gap:7px;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);border-radius:99px;padding:5px 12px;font-size:12px;color:#34d399;font-weight:500}.verify-spinner{width:48px;height:48px;border-radius:50%;border:3px solid rgba(99,102,241,.15);border-top:3px solid var(--accent);animation:spin .8s linear infinite;margin:24px auto}.verify-progress{text-align:center;color:var(--text-muted);font-size:13px;margin-top:8px}.portal-result{text-align:center;padding:16px 0}.portal-result-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px}.portal-result.success .portal-result-icon{background:rgba(16,185,129,.15)}.portal-result.error .portal-result-icon{background:rgba(239,68,68,.15)}.portal-result-text{font-size:15px;font-weight:600;margin-bottom:6px}.portal-result-sub{font-size:13px;color:var(--text-muted)}.steps-bar{display:flex;align-items:center;gap:8px;margin-bottom:28px;justify-content:center}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);transition:all var(--t)}.step-dot.active{background:var(--accent);transform:scale(1.2)}.step-dot.done{background:var(--green)}.step-line{flex:1 1;max-width:40px;height:2px;background:var(--border);border-radius:99px}.btn-full{width:100%;justify-content:center;padding:12px;font-size:15px}.portal-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);padding:12px 14px;font-size:13px;color:#f87171;margin-bottom:16px;display:flex;align-items:flex-start;gap:8px}.security-info{margin-top:20px;display:flex;flex-direction:column;gap:6px}.security-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.security-item svg{flex-shrink:0;opacity:.6}