:root{--color-primary: rgb(51, 128, 255);--color-secondary: rgb(153, 89, 230);--color-accent: rgb(255, 214, 77);--color-bg: #0f0f1a;--color-surface: rgba(255, 255, 255, .08);--color-surface-hover: rgba(255, 255, 255, .12);--color-text: #f0f0f0;--color-text-secondary: rgba(240, 240, 240, .6);--color-error: #ff6b6b;--radius: 16px;--radius-sm: 10px;--max-width: 480px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--color-bg);color:var(--color-text);font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{min-height:100%;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;min-height:100dvh;background:linear-gradient(160deg,var(--color-bg) 0%,color-mix(in srgb,var(--color-primary) 15%,var(--color-bg)) 50%,color-mix(in srgb,var(--color-secondary) 10%,var(--color-bg)) 100%);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-sm);font-family:inherit;font-weight:700;font-size:16px;padding:12px 24px;cursor:pointer;transition:transform .15s,opacity .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;box-shadow:0 4px 16px #0000004d}.btn-primary:hover:not(:disabled){box-shadow:0 6px 24px #0006}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:8px 16px;font-size:14px}.btn-ghost:hover{color:var(--color-text)}.btn-large{width:100%;max-width:var(--max-width);padding:16px 32px;font-size:18px;border-radius:var(--radius)}.btn-small{padding:8px 16px;font-size:14px}.name-entry-card,.intro-card,.step-card,.error-card,.loading-card,.done-card{width:100%;max-width:var(--max-width);background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);padding:32px 24px;text-align:center}.name-entry{gap:16px}.name-entry-icon{font-size:64px;margin-bottom:8px}.name-entry-card h1{font-size:24px;font-weight:800;margin-bottom:8px;white-space:pre-line}.name-entry-card p{color:var(--color-text-secondary);font-size:14px;margin-bottom:20px}.name-entry-card form{display:flex;flex-direction:column;gap:12px}.name-input{width:100%;padding:14px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:16px;font-weight:600;text-align:center;outline:none;transition:border-color .2s}.name-input:focus{border-color:var(--color-primary)}.name-input::placeholder{color:var(--color-text-secondary);font-weight:400}.hunt-intro{gap:16px}.intro-card{display:flex;flex-direction:column;align-items:center;gap:20px}.intro-cover{width:100%;max-height:240px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,.1)}.intro-icon{font-size:80px;line-height:1}.intro-card h1{font-size:28px;font-weight:800}.intro-meta{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.meta-badge{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;text-transform:capitalize}.intro-caption{font-size:14px;color:var(--color-text-secondary);margin-top:-8px}.step-play{justify-content:flex-start;padding-top:0;gap:16px}.progress-bar-container{width:100%;max-width:var(--max-width);height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-top:24px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:3px;transition:width .4s ease}.step-header{width:100%;max-width:var(--max-width)}.step-counter{font-size:14px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.step-card{display:flex;flex-direction:column;gap:20px;text-align:left}.unlock-heading{font-size:22px;font-weight:700;text-align:center;margin-bottom:4px}.clue-text{font-size:20px;font-weight:700;line-height:1.5;text-align:center}.hint-section{width:100%}.hint-content{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:16px;animation:fadeIn .3s ease-out}.hint-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-accent);margin-bottom:8px}.hint-image{width:100%;border-radius:8px}.hint-audio{width:100%;margin-top:4px}.hint-text-content{color:var(--color-text-secondary);font-size:15px;line-height:1.5}.hint-loading{color:var(--color-text-secondary);font-size:14px}.voice-hint-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.unlock-section{width:100%}.passcode-form{display:flex;flex-direction:column;gap:10px}.passcode-input{width:100%;padding:14px 16px;background:#ffffff0f;border:2px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:16px;font-weight:600;text-align:center;outline:none;transition:border-color .2s}.passcode-input:focus{border-color:var(--color-primary)}.passcode-input.error{border-color:var(--color-error);animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.error-text{color:var(--color-error);font-size:13px;font-weight:600}.qr-section{text-align:center}.continue-section{display:flex;flex-direction:column;align-items:center;gap:16px;animation:fadeIn .3s ease-out}.unlocked-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:22px;font-weight:800}.qr-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease-out}.qr-scanner-container{width:100%;max-width:var(--max-width);background:var(--color-bg);border-radius:var(--radius);overflow:hidden}.qr-header{display:flex;align-items:center;justify-content:space-between;padding:16px}.qr-header h3{font-size:18px;font-weight:700}.qr-reader{width:100%}.qr-reader video{width:100%!important;border-radius:0}.qr-error{padding:32px 16px;text-align:center;display:flex;flex-direction:column;gap:16px;color:var(--color-text-secondary)}.qr-error h4{font-size:18px;font-weight:700;color:var(--color-text)}.qr-instructions{padding:16px;text-align:center;color:var(--color-text-secondary);font-weight:600}.qr-instructions-detail{font-size:14px;font-weight:400;margin-top:4px}.qr-wrong-code{position:absolute;bottom:80px;left:50%;transform:translate(-50%);background:#dc3232e6;color:#fff;padding:12px 24px;border-radius:var(--radius-sm);text-align:center;animation:fadeIn .2s ease-out}.qr-wrong-code p{font-weight:800;font-size:16px}.qr-wrong-code span{font-size:13px;opacity:.8}.qr-instruction{font-size:16px;color:var(--color-text-secondary);text-align:center;margin-bottom:8px}.final-reveal{gap:24px;padding-top:48px;padding-bottom:48px}.reveal-header{display:flex;flex-direction:column;align-items:center;gap:16px;opacity:0;transform:scale(.8);transition:opacity .6s ease,transform .6s cubic-bezier(.34,1.56,.64,1)}.reveal-header.visible{opacity:1;transform:scale(1)}.trophy-container{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center}.trophy-ring{position:absolute;border-radius:50%;border:2px solid var(--color-accent)}.trophy-ring.ring-1{width:130px;height:130px;opacity:.15;animation:pulseRing 2s ease-in-out infinite}.trophy-ring.ring-2{width:150px;height:150px;opacity:.1;animation:pulseRing 2s ease-in-out infinite .3s}.trophy-ring.ring-3{width:170px;height:170px;opacity:.05;animation:pulseRing 2s ease-in-out infinite .6s}@keyframes pulseRing{0%,to{transform:scale(1);opacity:.15}50%{transform:scale(1.08);opacity:.05}}.trophy-icon{font-size:64px;filter:drop-shadow(0 4px 12px rgba(255,214,77,.4))}.reveal-header h1{font-size:32px;font-weight:800}.sparkle{display:inline-block;animation:twinkle 1.5s ease-in-out infinite alternate}.sparkle:last-child{animation-delay:.5s}@keyframes twinkle{0%{opacity:.6;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.reveal-subtitle{font-size:18px;font-weight:600;color:var(--color-primary)}.reveal-image-container{width:100%;max-width:var(--max-width);opacity:0;transform:scale(.9);transition:opacity .6s ease,transform .6s cubic-bezier(.34,1.56,.64,1)}.reveal-image-container.visible{opacity:1;transform:scale(1)}.reveal-image{width:100%;max-height:300px;object-fit:contain;border:3px solid;border-image:linear-gradient(135deg,var(--color-primary),var(--color-secondary)) 1;border-radius:var(--radius);overflow:hidden}.reveal-text-container{width:100%;max-width:var(--max-width);background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);padding:24px;text-align:center;opacity:0;transition:opacity .6s ease}.reveal-text-container.visible{opacity:1}.reveal-text{font-size:20px;font-weight:700;line-height:1.5;margin-bottom:12px}.reveal-from{font-size:13px;color:var(--color-text-secondary)}.reveal-actions{width:100%;max-width:var(--max-width);opacity:0;transition:opacity .4s ease}.reveal-actions.visible{opacity:1}.error-card,.loading-card,.done-card{display:flex;flex-direction:column;align-items:center;gap:16px}.error-icon,.done-icon{font-size:64px}.error-card h1,.done-card h1{font-size:24px;font-weight:800}.error-card p,.done-card p{color:var(--color-text-secondary);font-size:15px;line-height:1.5}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-card p{color:var(--color-text-secondary);font-size:15px}@media(min-width:600px){.screen{padding:32px 24px}.name-entry-card,.intro-card,.step-card,.error-card,.loading-card,.done-card{padding:40px 32px}.clue-text{font-size:22px}.reveal-header h1{font-size:36px}}@supports (padding: env(safe-area-inset-top)){.screen{padding-top:calc(24px + env(safe-area-inset-top));padding-bottom:calc(24px + env(safe-area-inset-bottom));padding-left:calc(16px + env(safe-area-inset-left));padding-right:calc(16px + env(safe-area-inset-right))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
