.scan-page{background:linear-gradient(135deg,#002147 0%,#003a7d 50%,#001a38 100%);justify-content:center;align-items:flex-start;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.scan-bg-gradient{pointer-events:none;background:radial-gradient(at 20% 20%,#d4af3726 0%,#0000 50%),radial-gradient(at 80% 80%,#d4af371a 0%,#0000 50%);position:fixed;inset:0}.scan-container{z-index:1;width:100%;max-width:480px;padding-top:2rem;padding-bottom:2rem;position:relative}.scan-header{text-align:center;color:#fff;margin-bottom:2rem}.university-logo{filter:drop-shadow(0 0 20px #d4af3780);margin-bottom:.5rem;font-size:3.5rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.scan-header h1{color:#d4af37;text-shadow:0 2px 10px #0000004d;margin-bottom:.25rem;font-size:1.8rem}.scan-subtitle{color:#ffffffb3;letter-spacing:.1em;font-size:.9rem}.qr-card{background:#fffffff2;border-radius:24px;padding:2rem;animation:.5s slideUp;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-indicator{justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.step-dot{background:#e0e0e0;border-radius:50%;width:10px;height:10px;transition:all .3s}.step-dot.active{background:#002147;transform:scale(1.3)}.step-dot.done{background:#d4af37}.form-label{color:#002147;margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.form-input{color:#171717;background:#fff;border:2px solid #e0e0e0;border-radius:12px;outline:none;width:100%;margin-bottom:1rem;padding:.85rem 1rem;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:#002147}.form-select{color:#171717;appearance:none;background:#fff;border:2px solid #e0e0e0;border-radius:12px;outline:none;width:100%;margin-bottom:1rem;padding:.85rem 1rem;font-size:1rem;transition:border-color .2s}.form-select:focus{border-color:#002147}.btn-gold{color:#002147;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:12px;width:100%;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d4af3766}.btn-gold:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-outline{color:#002147;cursor:pointer;background:0 0;border:2px solid #002147;border-radius:12px;width:100%;margin-top:.75rem;padding:.85rem;font-size:.95rem;font-weight:600;transition:all .2s}.btn-outline:hover{color:#fff;background:#002147}.section-title{color:#002147;margin-bottom:.5rem;font-size:1.3rem;font-weight:700}.section-subtitle{color:#666;margin-bottom:1.5rem;font-size:.9rem}.divider{background:#e0e0e0;height:1px;margin:1.25rem 0}.info-row{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.info-label{color:#666;font-size:.85rem}.info-value{color:#002147;text-align:right;font-size:.9rem;font-weight:600}.token-display{text-align:center;color:#fff;background:linear-gradient(135deg,#002147,#003a7d);border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.token-number{color:#d4af37;text-shadow:0 0 30px #d4af3780;margin:.5rem 0;font-size:5rem;font-weight:900;line-height:1}.token-label{letter-spacing:.15em;color:#ffffffb3;font-size:.8rem}.cabin-badge{color:#d4af37;background:#d4af3733;border:1px solid #d4af37;border-radius:8px;margin-top:.75rem;padding:.4rem 1rem;font-size:.9rem;font-weight:600;display:inline-block}.waiting-badge{color:#fffc;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;font-size:.9rem;display:flex}.waiting-count{color:#fff;font-size:1.1rem;font-weight:700}.success-icon{background:linear-gradient(135deg,#2e7d32,#43a047);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1rem;font-size:1.8rem;display:flex}.error-text{color:#d32f2f;margin-top:-.5rem;margin-bottom:.75rem;font-size:.85rem}.otp-inputs{justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.otp-input{text-align:center;color:#002147;border:2px solid #e0e0e0;border-radius:10px;outline:none;width:50px;height:56px;font-size:1.4rem;font-weight:700}.otp-input:focus{border-color:#d4af37}.loading-spinner{vertical-align:middle;border:2px solid #0021474d;border-top-color:#002147;border-radius:50%;width:20px;height:20px;margin-right:.5rem;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:480px){.scan-container{padding:1rem}.qr-card{padding:1.5rem}.token-number{font-size:4rem}}
