:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#ffffffde;background-color:#0f0f0f;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100vw;height:100vh;overflow:hidden;background:#000}.camera-toon{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;position:relative;user-select:none;-webkit-user-select:none}.camera-toon canvas{transform:rotate(-90deg);transform-origin:center center;width:100vh;height:100vw}.idle-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.idle-bg{width:100%;height:100%;object-fit:cover}.countdown-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;background:#0006}.countdown-number{font-size:12rem;font-weight:800;color:#fff;text-shadow:0 0 40px rgba(0,0,0,.6);animation:countdown-pulse 1s ease-in-out infinite}@keyframes countdown-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.rec-timer{position:absolute;top:1.5rem;right:1.5rem;z-index:10;display:flex;align-items:center;gap:.5rem;background:#0009;padding:.5rem 1rem;border-radius:8px;font-size:1.4rem;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.rec-dot{width:12px;height:12px;border-radius:50%;background:#ff3b3b;animation:rec-blink 1s ease-in-out infinite}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.3}}.processing-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:20}.processing-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.processing-content p{color:#fff;font-size:1.6rem;font-weight:600;text-align:center;max-width:400px}.spinner{width:60px;height:60px;border:5px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}.preview-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:20}.preview-card{display:flex;flex-direction:column;align-items:center;gap:2rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:3rem 3.5rem}.qr-container{background:#fff;padding:1.2rem;border-radius:16px;box-shadow:0 4px 30px #0000004d}.preview-text{display:flex;flex-direction:column;align-items:center;gap:.4rem}.scan-title{color:#fff;font-size:2rem;font-weight:800;text-align:center;letter-spacing:-.02em}.scan-subtitle{color:#ffffffbf;font-size:1.3rem;font-weight:500;text-align:center}.popup-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.popup{background:#1a1a1a;border-radius:16px;padding:2rem;min-width:320px;display:flex;flex-direction:column;gap:1.2rem;box-shadow:0 8px 40px #00000080}.popup h3{color:#fff;font-size:1.4rem;font-weight:700;text-align:center}.popup select{font-size:1.1rem;padding:.7rem 1rem;border-radius:8px;border:2px solid rgba(255,255,255,.2);background:#2a2a2a;color:#fff;cursor:pointer;outline:none;width:100%}.popup select:focus{border-color:#ffffff80}.popup-close{font-size:1.1rem;padding:.7rem;border:none;border-radius:8px;background:#fff;color:#000;font-weight:600;cursor:pointer}.popup-close:hover{background:#e0e0e0}
