*{margin:0;padding:0;box-sizing:border-box}body{font-family:Schoolbell,Roboto,Helvetica,Arial,sans-serif;overflow-x:hidden}.app{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;color:#fff}.background-image{position:fixed;top:0;left:0;width:100vw;height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:-1;transition:background-image .5s ease}.background-image:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#0000004d}.content{text-align:center;z-index:1;max-width:800px;padding:2rem;background:#0003;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;height:100vh;align-items:center;justify-content:center;width:100%}.title{font-size:3.5rem;font-weight:700;margin-bottom:3rem;text-shadow:2px 2px 4px rgba(0,0,0,.7);background:linear-gradient(45deg,#ff6b6b,#4ecdc4,#45b7d1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-button{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;min-width:200px}.loading-button:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.button-image{width:100px;height:100px;border-radius:15px;object-fit:cover;border:3px solid rgba(255,255,255,.5)}.loading-container{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.progress-bar{width:400px;height:20px;background:#fff3;border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,.3)}.progress-fill{height:100%;background:linear-gradient(90deg,#a2a0a0,#191d1d,#deecef);border-radius:8px;transition:width .1s ease}.progress-text{font-size:2rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.7)}.preload-container{display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.preload-title{font-size:2.25rem;font-weight:700;color:#7d7777}.preload-progress-bar{width:420px;height:16px;background:#fff;border-radius:999px;overflow:hidden;border:1px solid #e0ddd4;box-shadow:inset 0 1px 2px #0000000a}.preload-progress-fill{height:100%;background:linear-gradient(90deg,#484344,#d0c0cd);border-radius:999px;transition:width .3s ease}.preload-text{font-size:1.25rem;font-weight:700;color:#000}.preload-subtitle{font-size:1.1rem;color:#000000b3}.progress-button{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 2rem;background:linear-gradient(45deg,#9b9595,#444949);border:none;border-radius:25px;color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 8px 25px #0000004d;transition:all .3s ease;min-width:250px;position:relative;overflow:hidden}.current-image{width:200px;height:200px;border-radius:20px;object-fit:cover;border:4px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0000004d;margin-top:2rem}.progress-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #0006;background:linear-gradient(45deg,#ff5252,#26a69a)}.progress-button:active:not(:disabled){transform:translateY(-1px)}.progress-button:disabled{background:linear-gradient(45deg,#9e9e9e,#757575);cursor:not-allowed;transform:none;box-shadow:0 4px 15px #0003}.progress-button-text{font-size:1.2rem;font-weight:700}.progress-button-subtitle{font-size:.9rem;opacity:.9;font-weight:400}.progress-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.progress-button:hover:before{left:100%}.current-image-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.current-image{width:200px;height:200px;border-radius:20px;object-fit:cover;border:4px solid rgba(255,255,255,.5);box-shadow:0 10px 30px #0000004d}.image-label{font-size:1.2rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.7);background:#00000080;padding:.5rem 1rem;border-radius:20px}.success-container{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.success-icon{width:120px;height:120px;background:linear-gradient(45deg,#4ecdc4,#45b7d1);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 40px #0000004d;border:5px solid rgba(255,255,255,.3);overflow:hidden}.success-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.success-text{font-size:3rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.7);background:linear-gradient(45deg,#4ecdc4,#45b7d1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.confetti-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.confetti{position:absolute;width:10px;height:10px;border-radius:50%;animation:confetti-fall 3s linear infinite}@keyframes confetti-fall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:0}}.reset-button{padding:1rem 2rem;background:linear-gradient(45deg,#ff6b6b,#4ecdc4);border:none;border-radius:25px;color:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;box-shadow:0 10px 30px #0000004d;transition:all .3s ease}.reset-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #0006}@media (max-width: 768px){.title{font-size:2.5rem}.preload-title{font-size:2rem}.preload-progress-bar{width:320px}.progress-bar{width:300px}.progress-button{min-width:200px;padding:1.2rem 1.5rem}.current-image{width:150px;height:150px}.success-icon{width:100px;height:100px}.success-text{font-size:2rem}}@media (max-width: 480px){.content{padding:1rem}.title{font-size:2rem}.preload-title{font-size:1.6rem}.preload-progress-bar{width:260px}.progress-bar{width:250px}.progress-button{min-width:180px;padding:1rem 1.2rem}.progress-button-text{font-size:1rem}.progress-button-subtitle{font-size:.8rem}.loading-button{min-width:150px;padding:1.5rem}.button-image{width:80px;height:80px}}
