:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-card: #242424;--bg-card-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #6b6b6b;--accent-red: #dc2626;--accent-red-light: #ef4444;--accent-gold: #fbbf24;--accent-gold-light: #fcd34d;--accent-white: #fef3c7;--border-color: #333333;--border-color-light: #444444;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-red: 0 0 40px rgba(220, 38, 38, .3);--shadow-glow-gold: 0 0 20px rgba(251, 191, 36, .2);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes snowfall{0%{transform:translateY(-10px) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}.app{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden;background:radial-gradient(ellipse at top,rgba(220,38,38,.08) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(251,191,36,.05) 0%,transparent 50%),var(--bg-primary)}.snowflakes{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.snowflake{position:absolute;top:-30px;color:#ffffff26;font-size:1rem;animation:snowfall 10s linear infinite;-webkit-user-select:none;user-select:none}.header{text-align:center;padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);position:relative;z-index:1}.logo{display:inline-flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.logo-icon{font-size:2rem;animation:float 3s ease-in-out infinite}.logo h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-secondary);font-size:.875rem;font-weight:400}.main{flex:1;display:flex;flex-direction:column;align-items:center;padding:0 var(--spacing-md) var(--spacing-xl);position:relative;z-index:1}.container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--spacing-lg)}.image-section{width:100%}.image-display{position:relative;width:100%}.image-container{position:relative;width:100%;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg-secondary)}.preview-image{width:100%;height:auto;max-height:40vh;object-fit:contain;display:block}.image-badge{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;z-index:10}.badge-original{background:#000000b3;color:var(--text-secondary)}.badge-result{background:linear-gradient(135deg,var(--accent-red) 0%,var(--accent-red-dark) 100%);color:#fff}.reset-icon-button{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-normal);z-index:10}.reset-icon-button:hover{background:#000c}.image-hint{text-align:center;color:var(--text-muted);font-size:.75rem;margin-top:var(--spacing-sm)}.actions-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.result-actions{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--spacing-xs);width:100%}.toggle-button{padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#10b98180,#05966959);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.25);border-radius:14px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #10b98133,inset 0 1px #fff3,inset 0 -1px #0000000d;white-space:nowrap;position:relative;overflow:hidden}.toggle-button:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,#ffffff1f,#fff0);border-radius:14px 14px 0 0;pointer-events:none}.toggle-button:hover{transform:translateY(-2px) scale(1.02);background:linear-gradient(135deg,#10b981a6,#05966980);box-shadow:0 8px 28px #10b9814d,inset 0 1px #ffffff40,inset 0 -1px #0000000d;border-color:#ffffff59}.secondary-button{padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#ffffff1f,#ffffff0f);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:14px;color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0000000d;position:relative;overflow:hidden}.secondary-button:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,#ffffff14,#fff0);border-radius:14px 14px 0 0;pointer-events:none}.secondary-button:hover{transform:translateY(-2px) scale(1.02);background:linear-gradient(135deg,#ffffff2e,#ffffff1a);color:var(--text-primary);border-color:#ffffff40}.error-message{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius-md);color:var(--accent-red-light);font-size:.875rem}.error-icon{font-size:1rem}.footer{text-align:center;padding:var(--spacing-lg) var(--spacing-md);position:relative;z-index:1}.footer p{color:var(--text-muted);font-size:.875rem}@media(max-width:640px){.header{padding:var(--spacing-lg) var(--spacing-sm) var(--spacing-md)}.logo h1{font-size:1.5rem}.logo-icon{font-size:2rem}.tagline{font-size:.875rem}.main{padding:0 var(--spacing-sm) var(--spacing-lg)}.container{gap:var(--spacing-md)}}.compressing-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg);border:2px dashed rgba(255,255,255,.2);min-height:200px;gap:var(--spacing-md)}.compressing-state p{color:var(--text-secondary);font-size:.9rem}.compressing-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent-red);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.uploader-container{width:100%}.uploader-dropzone{width:100%;min-height:280px;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:var(--bg-card);border:2px dashed var(--border-color);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-normal)}.uploader-dropzone:hover,.uploader-dropzone:focus{border-color:var(--accent-gold);background:var(--bg-card-hover);box-shadow:var(--shadow-glow-gold)}.uploader-dropzone.drag-over{border-color:var(--accent-red);background:#dc26260d;box-shadow:var(--shadow-glow-red)}.uploader-content{text-align:center}.upload-icon{font-size:3rem;margin-bottom:var(--spacing-md);animation:float 3s ease-in-out infinite}.upload-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.upload-hint{font-size:.9375rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.upload-formats{font-size:.8125rem;color:var(--text-muted)}.upload-error{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius-md);color:var(--accent-red-light);font-size:.875rem}.uploader-preview{width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.preview-image-container{position:relative;max-width:100%;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}.preview-image{display:block;max-width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-xl)}.reset-button{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#000000b3;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.reset-button:hover{background:#dc2626cc;transform:scale(1.1)}.reset-icon{font-size:1rem;line-height:1}.preview-hint{font-size:.8125rem;color:var(--text-muted)}@media(max-width:640px){.uploader-dropzone{min-height:220px;padding:var(--spacing-lg)}.upload-icon{font-size:2.5rem}.upload-title{font-size:1.125rem}.preview-image{max-height:300px}}.fireworks{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;overflow:hidden;mix-blend-mode:screen}.firework{position:absolute;width:8px;height:8px;animation:fireworkFade 4.2s ease-out forwards}.spark{position:absolute;top:0;left:0;width:var(--spark-size, 8px);height:var(--spark-size, 8px);background:currentColor;border-radius:50%;box-shadow:0 0 12px currentColor;transform-origin:center;animation:fireworkBurst 2.8s ease-out forwards}@keyframes fireworkBurst{0%{transform:rotate(var(--spark-rotation, 0deg)) translateY(0) scale(1);opacity:1}60%{transform:rotate(var(--spark-rotation, 0deg)) translateY(var(--spark-distance, 60px)) scale(1);opacity:1}to{transform:rotate(var(--spark-rotation, 0deg)) translateY(var(--spark-distance, 60px)) scale(.35);opacity:0}}@keyframes fireworkFade{0%{opacity:.9}to{opacity:0}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);width:320px;text-align:center}.hat-animation{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.hat-emoji{font-size:3.5rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.1)}}.magic-particles{position:absolute;width:100%;height:100%;pointer-events:none}.particle{position:absolute;font-size:1rem;animation:particle 2s ease-in-out infinite}.particle:nth-child(1){top:0;left:50%;animation-delay:0s}.particle:nth-child(2){top:20%;right:0;animation-delay:.3s}.particle:nth-child(3){bottom:20%;right:0;animation-delay:.6s}.particle:nth-child(4){bottom:0;left:50%;animation-delay:.9s}.particle:nth-child(5){bottom:20%;left:0;animation-delay:1.2s}.particle:nth-child(6){top:20%;left:0;animation-delay:1.5s}@keyframes particle{0%,to{opacity:0;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(180deg)}}.progress-container{width:100%;height:8px;background:#ffffff26;border-radius:4px;overflow:hidden}.progress-bar-animated{height:100%;width:0%;background:linear-gradient(90deg,#dc2626,#f59e0b,#10b981);background-size:200% 100%;border-radius:4px;animation:progressGrow 25s ease-out forwards,shimmer 1.5s linear infinite}@keyframes progressGrow{0%{width:5%}20%{width:30%}40%{width:50%}60%{width:70%}80%{width:85%}to{width:95%}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-tip{display:flex;align-items:center;gap:var(--spacing-sm);white-space:nowrap;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tip-emoji{font-size:1.5rem}.tip-text{color:var(--text-primary);font-size:1.1rem;font-weight:500}.estimated-time{color:var(--text-muted);font-size:.8rem;margin-top:var(--spacing-sm)}.countdown-container{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:linear-gradient(135deg,#dc262626,#10b98126);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:var(--spacing-sm);animation:glowPulse 3s ease-in-out infinite}@keyframes glowPulse{0%,to{box-shadow:0 0 10px #dc262633,0 0 20px #10b9811a}50%{box-shadow:0 0 20px #dc26264d,0 0 30px #10b98133}}.countdown-label{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.countdown-digits{display:flex;align-items:center;gap:2px}.countdown-item{display:flex;flex-direction:column;align-items:center;min-width:28px}.countdown-number{font-size:1rem;font-weight:700;color:var(--text-primary);font-family:Inter,monospace;background:linear-gradient(180deg,#fff,#e5e5e5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.3)}.countdown-seconds{animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.countdown-unit{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.countdown-separator{font-size:1.1rem;font-weight:600;color:var(--accent-gold);animation:blink 1s step-end infinite;margin:0 2px;padding-bottom:18px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.countdown-message{font-size:1rem;font-weight:600;background:linear-gradient(90deg,var(--accent-red) 0%,var(--accent-green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:rainbow 2s linear infinite}@keyframes rainbow{0%,to{filter:hue-rotate(0deg)}50%{filter:hue-rotate(30deg)}}.countdown-icon{font-size:1.2rem;animation:swing 2s ease-in-out infinite}@keyframes swing{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}@media(max-width:400px){.countdown-container{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs)}.countdown-number{font-size:1rem}.countdown-item{min-width:28px}.countdown-label{font-size:.8rem}}.language-toggle{position:fixed;top:var(--spacing-md);right:var(--spacing-md);display:flex;align-items:center;gap:4px;padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);z-index:100;font-family:var(--font-family);font-size:.8rem}.language-toggle:hover{background:#fff3;transform:translateY(-1px)}.lang-option{color:var(--text-muted);font-weight:500;transition:color var(--transition-fast)}.lang-option.active{color:var(--accent-gold);font-weight:600}.lang-divider{color:var(--text-muted);opacity:.5}.hat-counter{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#dc262626,#16a34a26);border:1px solid rgba(255,255,255,.2);border-radius:2rem;font-size:.9rem;color:var(--text-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:counter-glow 3s ease-in-out infinite;margin-top:.75rem;margin-bottom:1rem}@keyframes counter-glow{0%,to{box-shadow:0 0 10px #dc262633,0 0 20px #16a34a1a}50%{box-shadow:0 0 15px #dc26264d,0 0 30px #16a34a33}}.hat-counter-icon{font-size:1.1rem;animation:hat-bounce 2s ease-in-out infinite}@keyframes hat-bounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-2px) rotate(-5deg)}75%{transform:translateY(-2px) rotate(5deg)}}.hat-counter-text{font-weight:500}.hat-counter-number{font-weight:700;color:#dc2626;font-size:1.05rem;text-shadow:0 0 10px rgba(220,38,38,.3);transition:transform .3s ease,color .3s ease;display:inline-block;min-width:2ch}.hat-counter-number.updating{animation:number-pop .4s ease-out;color:#16a34a}@keyframes number-pop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}@media(max-width:480px){.hat-counter{font-size:.8rem;padding:.4rem .8rem}.hat-counter-icon{font-size:1rem}.hat-counter-number{font-size:.95rem}}
