.scanner-container{display:flex;flex-direction:column;height:100vh;max-height:800px;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);color:#e6e6e6;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px #00000080;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{display:flex;align-items:center;gap:12px}.header-title{font-size:1.5rem;font-weight:700;background:linear-gradient(90deg,#4cc9f0,#4361ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0}.header-right{display:flex;align-items:center;gap:20px}.step-indicator{display:flex;flex-direction:column;gap:4px}.step-label{font-size:.75rem;color:#a0a0a0;text-transform:uppercase;letter-spacing:.5px}.step-name{font-size:.875rem;font-weight:600;color:#4cc9f0;text-transform:uppercase;letter-spacing:1px}.progress-indicator{display:flex;align-items:center;gap:12px;min-width:150px}.progress-bar{flex:1;height:6px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4cc9f0,#4361ee);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.75rem;font-weight:600;color:#a0a0a0;min-width:40px;text-align:right}.scanner-content{flex:1;padding:24px;overflow-y:auto}.scanner-step{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.init-step{text-align:center;gap:32px}.step-icon{margin-bottom:16px}.step-content{max-width:500px;width:100%}.step-title{font-size:2rem;font-weight:700;margin:0 0 16px;color:#fff}.step-description{font-size:1.125rem;line-height:1.6;color:#b0b0b0;margin:0 0 32px}.requirements-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;padding:20px;background:rgba(255,255,255,.05);border-radius:12px;border:1px solid rgba(255,255,255,.1)}.requirement-item{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#d0d0d0}.step-actions{display:flex;gap:16px;justify-content:center}.scan-step{width:100%;gap:24px}.camera-container{position:relative;width:100%;max-width:600px;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:#000}.camera-video{width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.scan-guide{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.guide-frame{width:80%;height:60%;border:3px solid rgba(76,201,240,.8);border-radius:8px;box-shadow:0 0 0 9999px #000000b3;animation:pulse 2s infinite}@keyframes pulse{0%,to{border-color:#4cc9f0cc}50%{border-color:#4361eecc}}.guide-text{position:absolute;bottom:20px;display:flex;align-items:center;gap:8px;color:#fff;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}.scan-controls{width:100%;max-width:600px;display:flex;flex-direction:column;gap:20px}.alignment-indicator{display:flex;flex-direction:column;gap:8px}.indicator-label{display:flex;align-items:center;gap:8px;font-size:.95rem;color:#b0b0b0}.indicator-bar{height:8px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden}.indicator-fill{height:100%;background:linear-gradient(90deg,#4cc9f0,#4361ee);border-radius:4px;transition:width .3s ease}.control-buttons{display:flex;gap:16px}.processing-step{text-align:center;gap:32px}.processing-animation{position:relative;width:120px;height:120px}.spinner{position:absolute;top:0;left:0;width:100%;height:100%;border:4px solid rgba(255,255,255,.1);border-top:4px solid #4cc9f0;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-content{max-width:500px;width:100%}.processing-title{font-size:1.75rem;font-weight:700;margin:0 0 16px;color:#fff}.processing-description{font-size:1.125rem;line-height:1.6;color:#b0b0b0;margin:0 0 24px}.processing-progress{display:flex;align-items:center;gap:16px;margin-bottom:32px}.processing-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.processing-step-item{display:flex;align-items:center;gap:12px;padding:12px;background:rgba(255,255,255,.05);border-radius:8px;font-size:.95rem;color:#d0d0d0}.review-step{width:100%;max-width:800px}.credential-review{display:flex;flex-direction:column;gap:24px;margin:32px 0}.review-section{background:rgba(255,255,255,.05);border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.1)}.section-title{display:flex;align-items:center;gap:12px;font-size:1.25rem;font-weight:600;margin:0 0 20px;color:#fff}.data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.data-item{display:flex;flex-direction:column;gap:4px}.data-label{font-size:.875rem;color:#a0a0a0;text-transform:uppercase;letter-spacing:.5px}.data-value{font-size:1.125rem;font-weight:600;color:#fff;word-break:break-word}.security-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.security-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:8px;font-size:.95rem}.security-item.valid{background:rgba(76,201,240,.1);border:1px solid rgba(76,201,240,.3)}.security-item.invalid{background:rgba(244,67,54,.1);border:1px solid rgba(244,67,54,.3)}.security-item.warning{background:rgba(255,193,7,.1);border:1px solid rgba(255,193,7,.3)}.security-label{color:#d0d0d0}.security-value{font-weight:600}.completed-step{text-align:center}.completion-details{margin:32px 0}.detail-card{background:rgba(255,255,255,.05);border-radius:12px;padding:24px;border:1px solid rgba(255,255,255,.1)}.detail-card.success{border-color:#4caf504d;background:rgba(76,175,80,.05)}.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.detail-header h4{font-size:1.25rem;font-weight:600;margin:0;color:#fff}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:.875rem;color:#a0a0a0;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:1.125rem;font-weight:600;color:#fff}.detail-value.code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.95rem;color:#4cc9f0}.error-step{text-align:center}.error-details{margin:32px 0}.error-card{background:rgba(244,67,54,.1);border:1px solid rgba(244,67,54,.3);border-radius:12px;padding:24px;text-align:left}.error-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.error-header h4{font-size:1.25rem;font-weight:600;margin:0;color:#fff}.error-solutions{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.error-solutions li{display:flex;align-items:center;gap:12px;font-size:.95rem;color:#d0d0d0}.btn-primary,.btn-secondary,.btn-warning,.btn-capture{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-decoration:none;min-width:140px}.btn-primary{background:linear-gradient(90deg,#4cc9f0,#4361ee);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #4cc9f04d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover:not(:disabled){background:rgba(255,255,255,.15);transform:translateY(-2px)}.btn-warning{background:linear-gradient(90deg,#ff9800,#ff5722);color:#fff}.btn-warning:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ff98004d}.btn-capture{background:linear-gradient(90deg,#00e676,#00c853);color:#fff;flex:1}.btn-capture:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #00e6764d}.btn-capture:disabled{opacity:.5;cursor:not-allowed}.scanner-footer{padding:16px 24px;background:rgba(255,255,255,.05);border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.footer-status,.status-indicator{display:flex;align-items:center;gap:8px}.status-indicator.active .status-dot{background:#00e676;box-shadow:0 0 10px #00e67680}.status-indicator.inactive .status-dot{background:#ff9800}.status-indicator.error .status-dot{background:#ff5252;animation:pulseError 1s infinite}@keyframes pulseError{0%,to{box-shadow:0 0 5px #ff525280}50%{box-shadow:0 0 15px #ff5252cc}}.status-dot{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.status-text{font-size:.875rem;color:#b0b0b0}.footer-info{display:flex;align-items:center;gap:8px;font-size:.75rem;color:#a0a0a0;max-width:300px}.info-text{line-height:1.4}.hidden-canvas{display:none}.text-blue-500{color:#4cc9f0}.text-green-500{color:#00e676}.text-yellow-500{color:#ff9800}.text-red-500{color:#ff5252}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s infinite}@media (max-width: 768px){.scanner-container{border-radius:0;max-height:none;height:100vh}.scanner-header{flex-direction:column;gap:16px;padding:16px}.header-right{width:100%;justify-content:space-between}.progress-indicator{min-width:120px}.scanner-content{padding:16px}.step-actions{flex-direction:column}.btn-primary,.btn-secondary,.btn-warning,.btn-capture{width:100%}.control-buttons{flex-direction:column}.data-grid,.security-grid,.detail-grid,.processing-steps{grid-template-columns:1fr}.scanner-footer{flex-direction:column;gap:12px;text-align:center}.footer-info{max-width:100%}}@media (max-width: 480px){.step-title{font-size:1.5rem}.step-description{font-size:1rem}.camera-container{aspect-ratio:3/4}.guide-frame{width:90%;height:50%}}@media (prefers-color-scheme: dark){.scanner-container{background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 100%)}.btn-secondary{background:rgba(255,255,255,.05)}.requirements-list,.review-section,.detail-card,.error-card{background:rgba(255,255,255,.03)}}@media print{.scanner-container{background:white;color:#000;box-shadow:none;border-radius:0}.scanner-header,.scanner-footer,.step-actions,.scan-controls{display:none}.scanner-content{padding:0}.scanner-step{min-height:auto}}
