:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-card h1{text-align:center;color:#333;margin-bottom:30px;font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{color:#e74c3c;background-color:#fee;padding:12px;border-radius:8px;margin-bottom:20px;text-align:center}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.scan-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;flex-direction:column;align-items:center}.scan-header{width:100%;max-width:600px;padding:20px;text-align:center}.logo-placeholder{background:#fff;padding:20px;border-radius:12px;font-size:24px;font-weight:700;color:#667eea;display:inline-block}.scan-content{flex:1;display:flex;justify-content:center;align-items:center;width:100%;max-width:600px}.scan-options{display:flex;flex-direction:column;align-items:center;gap:30px;width:100%}.scan-button{padding:20px 60px;font-size:24px;font-weight:700;background:#fff;color:#667eea;border:none;border-radius:50px;cursor:pointer;box-shadow:0 10px 30px #0000004d;transition:transform .2s,box-shadow .2s}.scan-button:hover:not(:disabled){transform:translateY(-5px);box-shadow:0 15px 40px #0006}.scan-button:disabled{opacity:.6;cursor:not-allowed}.error-message{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#e74c3c;color:#fff;padding:15px 40px 15px 20px;border-radius:8px;box-shadow:0 5px 20px #0000004d;max-width:90%;z-index:1000}.close-error{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0 5px}.scanner-modal{position:fixed;inset:0;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.scanner-content{background:#fff;border-radius:12px;width:100%;max-width:500px;overflow:hidden}.scanner-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#667eea;color:#fff}.scanner-header h2{margin:0;font-size:20px}.close-scanner{background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close-scanner:hover{background:#fff3}.scanner-view{width:100%;height:400px;position:relative;background:#000}.scanner-view video{width:100%;height:100%;object-fit:cover}.upload-section{display:flex;flex-direction:column;align-items:center;gap:15px}.upload-divider{color:#fff;font-size:18px;margin:0;opacity:.8}.upload-label{padding:15px 40px;font-size:18px;font-weight:600;background:#ffffffe6;color:#667eea;border:2px dashed #667eea;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s;box-shadow:0 5px 15px #0003}.upload-label:hover:not(:disabled){background:#fff;transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.upload-label:disabled{opacity:.6;cursor:not-allowed}.upload-icon{font-size:24px}.reward-container{min-height:100vh;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;flex-direction:column}.reward-header{display:flex;justify-content:space-between;align-items:center;max-width:100%;margin-bottom:20px;color:#fff;flex-shrink:0}.reward-header h1{margin:0;font-size:32px}.logout-button{padding:10px 20px;background:#fff3;color:#fff;border:2px solid white;border-radius:8px;cursor:pointer;font-size:16px;transition:background .2s}.logout-button:hover{background:#ffffff4d}.reward-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;min-height:0}.wheel-container{position:relative;width:auto;height:min(70dvh,70vw);aspect-ratio:1 / 1;margin:0 auto;flex-shrink:0}.wheel{width:100%;height:100%;border-radius:50%;background:#fff;position:relative;overflow:hidden;border:clamp(6px,1dvh,12px) solid #667eea;box-shadow:0 10px 40px #0000004d}.wheel-segment{position:absolute;width:50%;height:50%;left:50%;top:50%;transform-origin:0 0;display:flex;align-items:center;justify-content:center}.segment-text{position:absolute;top:37.5%;left:0;width:100%;text-align:center;font-size:clamp(14px,2dvh,24px);font-weight:700;color:#fff;text-shadow:1px 1px 3px rgba(0,0,0,.7);white-space:pre-line;overflow:hidden;text-overflow:ellipsis;transform-origin:center}.long-name{white-space:pre-line;text-align:center;font-size:clamp(14px,2dvh,24px);font-weight:700;color:#fff;text-shadow:1px 1px 3px rgba(0,0,0,.7)}.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8%;height:8%;min-width:60px;min-height:60px;background:#667eea;border-radius:50%;border:4px solid white;z-index:10;box-shadow:0 2px 10px #0000004d}.wheel-pointer{position:absolute;top:-15px;left:50%;transform:translate(-50%);width:0;height:0;border-left:20px solid transparent;border-right:20px solid transparent;border-top:40px solid #e74c3c;z-index:20;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.spin-button{padding:clamp(14px,2dvh,20px) clamp(50px,8vw,80px);font-size:clamp(20px,3dvh,28px);font-weight:700;background:#fff;color:#667eea;border:none;border-radius:50px;cursor:pointer;box-shadow:0 10px 30px #0000004d;transition:transform .2s,box-shadow .2s;flex-shrink:0;margin-top:1em}.spin-button:hover:not(:disabled){transform:translateY(-5px);box-shadow:0 15px 40px #0006}.spin-button:disabled{opacity:.6;cursor:not-allowed}.popup-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:3000;padding:20px;margin:0}.popup-content{background:#fff;border-radius:16px;padding:40px;max-width:90dvw;text-align:center;box-shadow:0 20px 60px #0000004d;animation:popupAppear .3s ease-out;margin:auto;transform-origin:center center}@keyframes popupAppear{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.popup-content h2{color:#667eea;margin-bottom:20px;font-size:28px}.gift-name{font-size:32px;font-weight:700;color:#f5576c;margin:20px 0;padding:20px;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;color:#fff}.popup-content p{color:#666;margin-bottom:30px;line-height:1.6}.popup-button{padding:14px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.popup-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.no-gifts-message{color:#fff;font-size:24px;text-align:center;padding:40px}#root{width:100%;min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
