@import"https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@100;200;300;400;500;600;700;800;900&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--dark-green: #1B3A20;--dark-green-deep: #0F2214;--safety-yellow: #E4FF00;--marfim: #F2EBDC;--sand: #C8A87A;--sage-green: #7A9E72;--text-on-dark: #F2EBDC;--text-on-light: #1B3A20;--white: #FFFFFF;--shadow-dark: 0 6px 32px rgba(0, 0, 0, .45);--shadow-light: 0 4px 20px rgba(27, 58, 32, .2);--radius: 8px;--radius-sm: 4px}html,body{width:100%;height:100%;overflow:hidden;font-family:Big Shoulders Display,Segoe UI,sans-serif;background:var(--dark-green);color:var(--text-on-dark);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}#root{width:100%;height:100%}.app{width:100%;height:100dvh;position:relative;overflow:hidden}.screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.bandeirinhas{position:absolute;top:0;left:0;right:0;display:flex;justify-content:center;gap:3px;padding:0 6px;z-index:10;animation:sway 3.5s ease-in-out infinite}.bandeirinhas:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#c8a87a99}.flag{width:24px;height:32px;clip-path:polygon(0 0,100% 0,50% 100%);flex-shrink:0}@keyframes sway{0%,to{transform:rotate(-.8deg)}50%{transform:rotate(.8deg)}}.btn{border:none;border-radius:var(--radius-sm);font-family:Big Shoulders Display,sans-serif;font-size:20px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .15s ease;touch-action:manipulation;padding:14px 32px}.btn:active{transform:scale(.95)}.btn-primary{background:var(--safety-yellow);color:var(--dark-green-deep);box-shadow:var(--shadow-dark)}.btn-primary:active{background:#c8e000}.btn-secondary{background:transparent;color:var(--safety-yellow);border:2px solid var(--safety-yellow)}.btn-secondary:active{background:#e4ff0014}.btn-ghost{background:transparent;color:var(--sand);font-size:16px;font-weight:600;padding:10px 24px;letter-spacing:.04em}.btn-lg{font-size:22px;padding:18px 40px;width:100%;max-width:340px}.btn-back{background:#f2ebdc1f;color:var(--marfim);font-size:15px;font-weight:700;letter-spacing:.06em;padding:10px 20px;border-radius:var(--radius-sm);border:1px solid rgba(242,235,220,.25)}.pulse{animation:pulse 2.2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 6px 32px #e4ff0059}50%{transform:scale(1.04);box-shadow:0 8px 40px #e4ff008c}}.welcome-screen{background:radial-gradient(ellipse at 50% 0%,#2a5230,#1b3a20 45%,#0f2214);padding:20px 20px 32px;text-align:center;gap:0;justify-content:center}.welcome-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(228,255,0,.04) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}.welcome-content{display:flex;flex-direction:column;align-items:center;gap:20px;z-index:5;padding-top:8px;width:100%}.brand-zone{display:flex;flex-direction:column;align-items:center;gap:0}.straw-hat-wrap{position:relative;z-index:3;margin-bottom:-18px;filter:drop-shadow(0 -4px 12px rgba(0,0,0,.5))}.brand-logo{display:block;width:124px;height:auto;position:relative;z-index:2;filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}.brand-wordmark{font-family:Big Shoulders Display,sans-serif;font-weight:900;font-size:28px;color:var(--safety-yellow);letter-spacing:.22em;text-transform:uppercase;margin-top:6px}.brand-event{font-family:Big Shoulders Display,sans-serif;font-weight:600;font-size:14px;color:var(--sand);letter-spacing:.18em;text-transform:uppercase;margin-top:4px}.deco-corn-left,.deco-corn-right{position:absolute;font-size:40px;top:50%;transform:translateY(-50%);opacity:.55;pointer-events:none}.deco-corn-left{left:8px;transform:translateY(-50%) rotate(-15deg)}.deco-corn-right{right:8px;transform:translateY(-50%) rotate(15deg)}.welcome-heading{display:flex;flex-direction:column;align-items:center;gap:0;line-height:.9}.welcome-title{font-family:Big Shoulders Display,sans-serif;font-weight:900;font-size:52px;color:var(--marfim);text-transform:uppercase;letter-spacing:.02em;line-height:.92}.welcome-title-accent{font-family:Big Shoulders Display,sans-serif;font-weight:900;font-size:52px;color:var(--safety-yellow);text-transform:uppercase;letter-spacing:.02em;line-height:.92}.welcome-subtitle{font-family:Big Shoulders Display,sans-serif;font-weight:500;font-size:18px;color:var(--sand);max-width:280px;line-height:1.3;letter-spacing:.04em}.welcome-cta{width:100%;display:flex;justify-content:center}.welcome-footer{display:flex;align-items:center;gap:12px;font-family:Big Shoulders Display,sans-serif;font-size:17px;font-weight:700;color:var(--sage-green);letter-spacing:.12em;text-transform:uppercase}.welcome-footer-emoji{font-size:22px}.camera-screen{background:#000;justify-content:flex-start}.camera-header{width:100%;display:flex;align-items:center;gap:12px;padding:16px;z-index:10;position:absolute;top:0;left:0;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 100%)}.camera-title{font-family:Big Shoulders Display,sans-serif;font-weight:800;font-size:22px;letter-spacing:.08em;color:var(--marfim);text-transform:uppercase}.camera-preview{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.camera-error{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px;color:var(--marfim);text-align:center;font-family:Big Shoulders Display,sans-serif;font-weight:600;font-size:18px}.camera-loading{position:absolute;color:var(--marfim);font-family:Big Shoulders Display,sans-serif;font-size:18px;font-weight:700;letter-spacing:.08em}.camera-controls{position:absolute;bottom:40px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:14px;z-index:10}.btn-capture{width:84px;height:84px;border-radius:50%;background:transparent;border:4px solid var(--safety-yellow);padding:5px;cursor:pointer;transition:transform .15s ease;box-shadow:0 0 #e4ff0066;animation:capture-glow 2s ease-in-out infinite}.btn-capture:active{transform:scale(.9)}@keyframes capture-glow{0%,to{box-shadow:0 0 #e4ff0066}50%{box-shadow:0 0 0 8px #e4ff0000}}.capture-ring{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center}.capture-dot{width:58px;height:58px;border-radius:50%;background:var(--safety-yellow)}.camera-hint{font-family:Big Shoulders Display,sans-serif;font-weight:500;color:#f2ebdcbf;font-size:16px;text-align:center;letter-spacing:.04em}.loading-screen{background:radial-gradient(ellipse at 50% 30%,#2a5230,#1b3a20,#0f2214);color:var(--marfim);text-align:center;padding:24px}.loading-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(228,255,0,.03) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}.loading-content{display:flex;flex-direction:column;align-items:center;gap:24px;z-index:2}.loading-icon{font-size:80px;line-height:1;display:inline-block;animation:flicker .6s ease-in-out infinite alternate}@keyframes flicker{0%{transform:scale(1) rotate(-2deg);opacity:.88}to{transform:scale(1.12) rotate(2deg);opacity:1}}.loading-label{font-family:Big Shoulders Display,sans-serif;font-weight:700;font-size:13px;letter-spacing:.28em;color:var(--sage-green);text-transform:uppercase}.loading-title{font-family:Big Shoulders Display,sans-serif;font-weight:900;font-size:38px;color:var(--safety-yellow);text-transform:uppercase;letter-spacing:.04em;line-height:.95}.loading-message{font-family:Big Shoulders Display,sans-serif;font-weight:500;font-size:18px;color:var(--sand);letter-spacing:.04em;min-height:26px;transition:opacity .4s ease}.loading-bar-container{width:80%;max-width:300px;height:5px;background:#f2ebdc1f;border-radius:3px;overflow:hidden}.loading-bar{height:100%;background:var(--safety-yellow);border-radius:3px;animation:loading-progress 55s linear forwards;box-shadow:0 0 10px #e4ff0099}@keyframes loading-progress{0%{width:0%}to{width:100%}}.loading-hint{font-family:Big Shoulders Display,sans-serif;font-weight:400;font-size:14px;color:#f2ebdc80;letter-spacing:.04em}.result-screen{background:var(--marfim);padding:52px 16px 16px;gap:16px}.result-screen .bandeirinhas:before{background:#1b3a2040}.result-title{font-family:Big Shoulders Display,sans-serif;font-weight:900;font-size:30px;letter-spacing:.04em;color:var(--dark-green);text-align:center;text-transform:uppercase;z-index:5;line-height:1}.result-title span{color:var(--dark-green)}.result-title .highlight{color:#2a8030}.result-body{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;gap:14px;min-height:0;z-index:5}.result-image-container{flex:1;width:100%;display:flex;align-items:center;justify-content:center;min-height:0}.result-image{max-width:100%;max-height:100%;border-radius:var(--radius);box-shadow:var(--shadow-light);object-fit:contain;border:3px solid var(--sand)}.result-side{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;flex-shrink:0}.qr-section{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--marfim);border-radius:var(--radius);border:2px dashed var(--sage-green)}.qr-title{display:none;font-family:Big Shoulders Display,sans-serif;font-weight:800;font-size:20px;color:var(--dark-green);letter-spacing:.04em;text-transform:uppercase;text-align:center;line-height:1}.qr-code{width:120px;height:120px}.qr-hint{font-family:Big Shoulders Display,sans-serif;font-weight:700;font-size:14px;color:var(--dark-green);letter-spacing:.06em;text-transform:uppercase}.result-actions{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.result-screen .btn-primary{background:var(--dark-green);color:var(--safety-yellow)}.result-screen .btn-primary:active{background:var(--dark-green-deep)}.result-screen .btn-secondary{border-color:var(--dark-green);color:var(--dark-green)}.result-screen .btn-ghost{color:var(--sage-green)}.error-toast{position:fixed;top:16px;left:16px;right:16px;background:#8b1c1c;color:var(--marfim);padding:16px;border-radius:var(--radius);z-index:100;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:var(--shadow-dark);animation:slideDown .3s ease;border-left:4px solid var(--safety-yellow)}.error-toast p{font-family:Big Shoulders Display,sans-serif;font-size:16px;font-weight:600;flex:1;letter-spacing:.03em}.error-toast button{background:transparent;border:1px solid var(--marfim);color:var(--marfim);padding:6px 14px;border-radius:var(--radius-sm);font-family:Big Shoulders Display,sans-serif;font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;flex-shrink:0}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.fireworks{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;overflow:hidden}.firework{position:absolute;width:0;height:0;transform:scale(var(--scale, 1))}.firework-flash{position:absolute;left:-7px;top:-7px;width:14px;height:14px;border-radius:50%;background:var(--hue);box-shadow:0 0 22px 8px var(--hue);animation:fw-flash .45s ease-out forwards}.firework-particle{position:absolute;left:0;top:0;width:5px;height:5px;border-radius:50%;background:var(--hue);box-shadow:0 0 7px var(--hue);transform:rotate(var(--angle)) translateY(0) scale(1);animation:fw-fly 1.4s cubic-bezier(.18,.7,.32,1) forwards;animation-delay:var(--delay)}@keyframes fw-flash{0%{opacity:1;transform:scale(.4)}to{opacity:0;transform:scale(1.6)}}@keyframes fw-fly{0%{opacity:1;transform:rotate(var(--angle)) translateY(0) scale(1)}70%{opacity:1}to{opacity:0;transform:rotate(var(--angle)) translateY(-92px) scale(.25)}}.floaties{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;overflow:hidden}.floatie{position:absolute;bottom:-10%;line-height:1;opacity:0;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));animation-name:floatie-rise;animation-timing-function:ease-in-out;animation-iteration-count:infinite;will-change:transform,opacity}@keyframes floatie-rise{0%{transform:translate(0) rotate(-6deg);opacity:0}12%{opacity:.85}88%{opacity:.85}to{transform:translate(var(--drift),-118vh) rotate(6deg);opacity:0}}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-8%;display:block;opacity:.9;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:infinite;will-change:transform}@keyframes confetti-fall{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(var(--sway),112vh) rotate(540deg);opacity:.9}}.flag-flutter{transform-origin:top center;animation:flag-flutter 2.6s ease-in-out infinite}@keyframes flag-flutter{0%,to{transform:rotate(-4deg) skew(2deg)}50%{transform:rotate(4deg) skew(-2deg)}}.straw-hat-wrap{animation:hat-float 3.6s ease-in-out infinite}@keyframes hat-float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-9px) rotate(2deg)}}.welcome-content>*{animation:reveal-up .7s cubic-bezier(.2,.8,.25,1) both}.welcome-content>.brand-zone{animation-delay:.05s}.welcome-content>.welcome-heading{animation-delay:.18s}.welcome-content>.welcome-subtitle{animation-delay:.3s}.welcome-content>.welcome-cta{animation-delay:.42s}.welcome-content>.welcome-footer{animation-delay:.54s}@keyframes reveal-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.bonfire{position:relative;width:160px;height:130px;display:flex;align-items:center;justify-content:center}.bonfire-glow{position:absolute;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,150,40,.35) 0%,rgba(228,255,0,.12) 40%,transparent 70%);animation:glow-pulse 1.8s ease-in-out infinite}@keyframes glow-pulse{0%,to{transform:scale(.9);opacity:.7}50%{transform:scale(1.15);opacity:1}}.embers{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.ember{position:absolute;bottom:38%;width:5px;height:5px;border-radius:50%;background:#ffb627;box-shadow:0 0 8px #ff9d2e;opacity:0;animation-name:ember-rise;animation-timing-function:ease-out;animation-iteration-count:infinite}@keyframes ember-rise{0%{transform:translateY(0) scale(1);opacity:0}15%{opacity:1}to{transform:translateY(-90px) scale(.2);opacity:0}}.loading-message{animation:msg-fade .5s ease}@keyframes msg-fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.loading-bar-container{position:relative}.loading-bar-container:after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:bar-shine 1.6s ease-in-out infinite}@keyframes bar-shine{0%{transform:translate(-120%)}to{transform:translate(320%)}}.result-screen .result-title{position:relative;z-index:7;animation:title-pop .6s cubic-bezier(.2,1.3,.4,1) both}@keyframes title-pop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.result-image-container{position:relative;z-index:5}.result-image{animation:img-pop .7s cubic-bezier(.16,1,.3,1) .15s both}@keyframes img-pop{0%{opacity:0;transform:scale(.82) rotate(-3deg)}60%{opacity:1}to{opacity:1;transform:scale(1) rotate(0)}}.qr-section{position:relative;z-index:7;animation:reveal-up .6s ease .45s both}.result-actions{position:relative;z-index:7;animation:reveal-up .6s ease .55s both}@media (prefers-reduced-motion: reduce){.fireworks,.floaties,.confetti,.embers,.bonfire-glow,.loading-bar-container:after{display:none}.flag-flutter,.straw-hat-wrap,.welcome-content>*,.result-title,.result-image,.result-actions,.qr-section,.loading-message,.pulse,.loading-icon{animation:none!important}}@media (min-width: 768px){.welcome-title,.welcome-title-accent{font-size:68px}.welcome-subtitle{font-size:22px;max-width:380px}.flag{width:30px;height:38px}.brand-wordmark{font-size:34px}.loading-title{font-size:48px}.result-title{font-size:36px}.result-body{flex-direction:row;align-items:stretch;justify-content:center;gap:32px;max-width:1100px;margin:0 auto;padding:8px 16px 16px}.result-image-container{flex:1 1 auto}.result-side{width:280px;flex-shrink:0;justify-content:center}.qr-section{gap:12px;padding:22px 24px;border:3px solid var(--dark-green);box-shadow:0 12px 34px #1b3a204d}.qr-title{display:block}.qr-code{width:216px;height:216px}.qr-hint{color:var(--sage-green)}}
