*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;padding:0}.home-container{background:#fff;min-height:100vh;overflow-x:hidden;position:relative}.home-container:before{background:linear-gradient(135deg,#1e3a8a,#3b82f6 50%,#60a5fa);-webkit-clip-path:ellipse(135% 92% at 48% 0);clip-path:ellipse(135% 92% at 48% 0);content:"";height:65vh;left:0;position:absolute;right:0;top:0;z-index:0}@media (max-width:768px){.home-container:before{-webkit-clip-path:ellipse(145% 95% at 50% 0);clip-path:ellipse(145% 95% at 50% 0);height:70vh}}.upload-content-wrapper{align-items:center;display:flex;flex-direction:column;min-height:100vh;padding:0 24px;position:relative;z-index:1}.header{display:none}.upload-hero{margin:0 auto;max-width:800px;padding:80px 24px 60px;text-align:center}.upload-hero-title{color:#fff;font-size:3.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.1;margin:0 0 24px}.upload-hero-subtitle{color:#fffffff2;font-size:1.25rem;font-weight:400;line-height:1.6;margin:0}@media (max-width:768px){.upload-hero{padding:60px 20px 40px}.upload-hero-title{font-size:2.25rem}.upload-hero-subtitle{font-size:1.125rem}}.upload-main-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px #1e3a8a26,0 8px 24px #3b82f61f,0 0 40px #3b82f614;margin-bottom:80px;max-width:680px;padding:48px 40px;transition:transform .3s ease,box-shadow .3s ease;width:100%}.upload-main-card:hover{box-shadow:0 24px 80px #1e3a8a2e,0 12px 32px #3b82f626,0 0 60px #3b82f626;transform:translateY(-4px)}@media (max-width:768px){.upload-main-card{margin-bottom:60px;padding:32px 24px}}.upload-steps{align-items:center;display:flex;justify-content:center;margin-bottom:48px;padding:0 20px}.upload-step{flex-direction:column;gap:8px}.upload-step,.upload-step-circle{align-items:center;display:flex;position:relative}.upload-step-circle{background:#e5e7eb;border-radius:50%;color:#9ca3af;font-size:1rem;font-weight:600;height:48px;justify-content:center;transition:all .4s ease;width:48px;z-index:2}.upload-step.active .upload-step-circle{background:#3b82f6;box-shadow:0 4px 16px #3b82f680,0 0 24px #3b82f666,0 0 40px #3b82f633;color:#fff;transform:scale(1.1)}.upload-step.completed .upload-step-circle{background:#10b981;color:#fff;font-size:.85rem}.upload-step.pulsing .upload-step-circle{animation:pulse-glow-upload 2s ease-in-out infinite}@keyframes pulse-glow-upload{0%,to{box-shadow:0 4px 16px #3b82f680,0 0 24px #3b82f666,0 0 40px #3b82f633;transform:scale(1.1)}50%{box-shadow:0 6px 20px #3b82f699,0 0 32px #3b82f680,0 0 60px #3b82f64d;transform:scale(1.15)}}.upload-step-label{color:#9ca3af;font-size:.875rem;font-weight:500;transition:color .3s ease}.upload-step.active .upload-step-label{color:#3b82f6;font-weight:600}.upload-step.completed .upload-step-label{color:#10b981;font-weight:500}.upload-step-line{background:#e5e7eb;height:2px;margin:0 16px 32px;transition:background .4s ease;width:80px;z-index:1}.upload-step-line.active-line{background:linear-gradient(90deg,#10b981 0,#3b82f6);box-shadow:0 0 8px #3b82f666}@media (max-width:640px){.upload-steps{padding:0}.upload-step-line{margin:0 8px 32px;width:40px}.upload-step-circle{font-size:.9rem;height:42px;width:42px}.upload-step-label{font-size:.75rem}}.upload-zone{background:#f8fafc;border:3px dashed #93c5fd;border-radius:16px;cursor:pointer;overflow:hidden;padding:80px 40px;position:relative;text-align:center;transition:all .3s ease}@keyframes gentle-pulse-upload{0%,to{background:#f8fafc;border-color:#93c5fd;box-shadow:0 0 0 #3b82f600}50%{background:#eff6ff;border-color:#60a5fa;box-shadow:0 0 20px #3b82f61f,inset 0 0 30px #3b82f60f}}.upload-zone{animation:gentle-pulse-upload 3s ease-in-out infinite}.upload-zone:hover{animation:none;background:#eff6ff;border-color:#3b82f6;box-shadow:0 8px 32px #3b82f640,0 0 40px #3b82f633,inset 0 0 60px #3b82f614;transform:scale(1.02)}.upload-zone.dragging{animation:none;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;border-width:4px;box-shadow:0 12px 40px #3b82f659,0 0 60px #3b82f64d,inset 0 0 80px #3b82f61f;transform:scale(1.03)}.file-input{display:none}.upload-box{align-items:center;display:flex;flex-direction:column;justify-content:center}.upload-icon{height:64px;margin-bottom:20px;transition:all .3s ease;width:64px}.upload-icon svg{color:#9ca3af;height:100%;transition:all .3s ease;width:100%}.upload-zone:hover .upload-icon svg{color:#3b82f6;filter:drop-shadow(0 8px 20px rgba(59,130,246,.35));transform:translateY(-8px)}.upload-text-main{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0 0 8px;transition:color .3s ease}.upload-zone:hover .upload-text-main{color:#3b82f6}.upload-text-sub{color:#6b7280;font-size:.875rem;margin:0}@media (max-width:768px){.upload-zone{padding:60px 24px}.upload-icon{height:56px;width:56px}}.upload-zone.file-processing{animation:processing-pulse-upload 2s ease-in-out infinite;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 8px 32px #3b82f640,0 0 40px #3b82f633,inset 0 0 60px #3b82f614;cursor:default}@keyframes processing-pulse-upload{0%,to{border-color:#3b82f6;box-shadow:0 8px 32px #3b82f640,0 0 40px #3b82f633,inset 0 0 60px #3b82f614}50%{border-color:#60a5fa;box-shadow:0 12px 40px #3b82f659,0 0 60px #3b82f64d,inset 0 0 80px #3b82f61f}}.processing-spinner-container{align-items:center;display:flex;height:48px;justify-content:center;width:48px}.processing-spinner{animation:rotate-spinner 1.5s linear infinite}.spinner-track{stroke:#dbeafe}.spinner-progress{stroke:#3b82f6;stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0;animation:dash-spinner 1.5s ease-in-out infinite}@keyframes rotate-spinner{to{transform:rotate(1turn)}}@keyframes dash-spinner{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.processing-text{color:#3b82f6;font-size:.875rem;font-weight:600;margin:0}.processing-subtitle{color:#6b7280;font-size:.75rem;font-weight:400;line-height:1.4;margin:8px 0 0}.animated-dots:after{animation:dots-animate 1.5s steps(4) infinite;content:""}@keyframes dots-animate{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.file-selected-display{align-items:center;background:#eff6ff;border:2px solid #3b82f6;border-radius:12px;box-shadow:0 0 20px #3b82f626;display:flex;gap:12px;justify-content:center;margin-top:24px;padding:16px 24px}.file-selected-icon{color:#3b82f6;font-size:1.25rem}.file-selected-name{color:#1f2937;flex:1 1;font-size:.9375rem;font-weight:600;text-align:left}.file-selected-remove{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.125rem;padding:4px 8px;transition:all .3s ease}.file-selected-remove:hover{filter:drop-shadow(0 0 10px rgba(239,68,68,.5));transform:scale(1.2)}.upload-submit-btn{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border:none;border-radius:12px;box-shadow:0 4px 16px #3b82f659,0 0 30px #3b82f640;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:24px;padding:16px 24px;transition:all .3s ease;width:100%}.upload-submit-btn:hover{box-shadow:0 8px 28px #3b82f680,0 0 50px #3b82f659,0 0 80px #3b82f633;transform:translateY(-2px)}.upload-submit-btn:active{transform:translateY(0)}.upload-submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.upload-loading-overlay{align-items:center;animation:fadeIn .3s ease-in-out;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f8f9fafa;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.loading-card{animation:slideUp .4s ease-out;background:#fff;border-radius:24px;box-shadow:0 24px 60px #1e3a8a26,0 0 60px #3b82f633;max-width:420px;min-height:380px;padding:32px;text-align:center;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.loading-logo{animation:perfectBounce 1.5s ease-in-out infinite;display:block;filter:drop-shadow(0 4px 16px rgba(59,130,246,.3));height:auto;margin:0 auto 24px;width:70px}@keyframes perfectBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.loading-spinner{animation:smoothSpin 1s linear infinite;border:3px solid #dbeafe;border-radius:50%;border-top-color:#3b82f6;box-shadow:0 0 20px #3b82f64d;height:40px;margin:0 auto 20px;width:40px}@keyframes smoothSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-status{color:#1f2937;font-size:18px;font-weight:600;margin-bottom:12px}.loading-substatus{color:#6b7280;font-size:13px;margin:8px 0}.loading-dots:after{animation:dots 1.5s steps(4) infinite;content:""}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.compact-progress-section{background:#f8f9fa;border-radius:8px;margin:15px 0;padding:12px}.progress-bar-container{background:#e5e7eb;border-radius:3px;height:6px;margin:8px 0;overflow:hidden;position:relative;width:100%}.progress-bar{background:linear-gradient(90deg,#1e3a8a,#3b82f6);border-radius:3px;box-shadow:0 0 20px #3b82f680;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-text{color:#1f2937;font-size:11px;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.time-note{color:#6b7280;font-size:12px;font-weight:500;margin-top:6px;text-align:center}.compact-loading-progress{margin:20px 0 10px}.compact-loading-step{align-items:center;background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:8px;display:flex;margin:8px 0;padding:12px 16px;transition:all .4s cubic-bezier(.4,0,.2,1)}.compact-loading-step.active{background:#3b82f61a;border-left-color:#3b82f6;box-shadow:0 0 20px #3b82f633;transform:translateX(4px)}.compact-loading-step.completed{background:#10b9811a;border-left-color:#10b981;opacity:.8}.compact-loading-step.hidden{height:0;margin:0;opacity:0;padding:0}.compact-step-icon{align-items:center;background:#e5e7eb;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:24px;justify-content:center;margin-right:12px;width:24px}.compact-step-icon.active{animation:pulse-icon 1.5s ease-in-out infinite;background:#3b82f6;box-shadow:0 4px 12px #3b82f666,0 0 20px #3b82f64d;color:#fff}@keyframes pulse-icon{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.compact-step-icon.completed{background:#10b981;color:#fff}.compact-step-text{color:#6b7280;font-size:13px;font-weight:500}.compact-step-text.active{color:#3b82f6;font-weight:600}.compact-step-text.completed{color:#10b981}.success-checkmark{align-items:center;animation:checkmarkBounce .6s ease-in-out;background:#10b981;border-radius:50%;box-shadow:0 8px 24px #10b98166,0 0 40px #10b9814d;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.success-checkmark:after{color:#fff;content:"✓";font-size:40px;font-weight:700}@keyframes checkmarkBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.error-message-container{align-items:flex-start;animation:slideDownError .4s ease-out;background:#fef2f2;border:2px solid #ef4444;border-radius:12px;box-shadow:0 4px 16px #ef444433,0 0 30px #ef44441a;display:flex;gap:16px;margin-top:24px;padding:20px}@keyframes slideDownError{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-icon{animation:shake .5s ease-in-out;flex-shrink:0;font-size:24px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.error-content{flex:1 1}.error-title{color:#dc2626;font-size:16px;font-weight:600;margin:0 0 8px}.error-text{color:#991b1b;font-size:14px;line-height:1.5;margin:0 0 16px;white-space:pre-wrap}.error-hints{background:#ffffff80;border-radius:8px;margin:16px 0;padding:12px 16px}.error-hints-title{color:#7c2d12;font-size:13px;font-weight:600;margin:0 0 8px}.error-hints ul{list-style-type:disc;margin:0;padding-left:20px}.error-hints li{color:#991b1b;font-size:13px;line-height:1.6;margin:4px 0}.error-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.error-action-primary{background:#dc2626;border:none;border-radius:8px;box-shadow:0 2px 8px #dc262640;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.error-action-primary:hover{background:#b91c1c;box-shadow:0 4px 12px #dc262659;transform:translateY(-1px)}.error-action-primary:active{transform:translateY(0)}.error-action-secondary{background:#0000;border:2px solid #dc2626;border-radius:8px;color:#dc2626;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.error-action-secondary:hover{background:#dc26261a;transform:translateY(-1px)}.error-action-secondary:active{transform:translateY(0)}.error-dismiss{align-items:center;background:none;border:none;border-radius:50%;color:#dc2626;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.error-dismiss:hover{background:#dc262626;transform:rotate(90deg)}@media (max-width:640px){.error-message-container{gap:12px;padding:16px}.error-icon{font-size:20px}.error-title{font-size:14px}.error-text{font-size:13px}.error-hints li,.error-hints-title{font-size:12px}.error-actions{flex-direction:column;gap:8px}.error-action-primary,.error-action-secondary{text-align:center;width:100%}}.form-container{display:none}.upload-content-wrapper+*{position:relative;z-index:1}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.card-component{height:280px}.card-component:hover{border-color:#93c5fd;box-shadow:0 20px 40px #00000026;transform:translateY(-4px)}.card-height-280{height:280px}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#94a3b8}