*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;color:#333;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-blue-50{background-color:#eff6ff}.bg-green-50{background-color:#f0fdf4}.text-gray-700{color:#374151}.text-gray-600{color:#4b5563}.text-blue-600{color:#2563eb}.text-green-600{color:#16a34a}.text-red-600{color:#dc2626}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.w-full{width:100%}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s ease-in-out;font-size:.875rem;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #667eea4d}.btn-secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-success{background:linear-gradient(135deg,#10b981 0%,#059669 100%);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #10b9814d}.btn-danger{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #ef44444d}.card{background:white;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;overflow:hidden;transition:all .3s ease}.card:hover{transform:translateY(-2px);box-shadow:0 25px 50px -12px #00000040}.card-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%)}.card-body{padding:1.5rem}.card-footer{padding:1.5rem;border-top:1px solid #e5e7eb;background-color:#f9fafb}.scanner-container{position:relative;border-radius:1rem;overflow:hidden;background-color:#000;box-shadow:0 25px 50px -12px #00000040}.scanner-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;z-index:10}.scanner-frame{width:250px;height:250px;border:3px solid #667eea;border-radius:1rem;position:relative;background:transparent}.scanner-frame:before,.scanner-frame:after{content:"";position:absolute;width:30px;height:30px;border:3px solid #667eea}.scanner-frame:before{top:-3px;left:-3px;border-right:none;border-bottom:none}.scanner-frame:after{bottom:-3px;right:-3px;border-left:none;border-top:none}.fade-in{animation:fadeIn .5s ease-in-out}.slide-up{animation:slideUp .5s ease-out}.bounce-in{animation:bounceIn .6s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.container{padding:0 15px}.card{margin:0 10px}.scanner-frame{width:200px;height:200px}.text-3xl{font-size:1.5rem}.p-8{padding:1.5rem}}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-success{color:#16a34a;background-color:#f0fdf4;border:1px solid #bbf7d0;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem}.status-error{color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem}.status-info{color:#2563eb;background-color:#eff6ff;border:1px solid #bfdbfe;padding:.5rem 1rem;border-radius:.5rem;display:flex;align-items:center;gap:.5rem}.json-display{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.url-display{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;padding:1rem;word-break:break-all;color:#2563eb;font-weight:500}.permission-request{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #f59e0b;border-radius:.75rem;padding:1.5rem;text-align:center;color:#92400e}.permission-request i{font-size:2rem;margin-bottom:1rem;display:block}
