@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--sans:"Outfit", system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font-family:var(--sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#e2e8f0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0b0c10;font-size:16px;font-weight:400;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:#090a0f;min-height:100vh;margin:0;overflow-x:hidden}#root{width:100%;min-height:100vh}.app-container{z-index:1;flex-direction:column;justify-content:space-between;min-height:100vh;padding:2rem 1.5rem;display:flex;position:relative;overflow:hidden}.bg-gradient-orb{filter:blur(140px);z-index:-1;opacity:.45;pointer-events:none;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#6366f1 0%,#6366f100 70%);width:450px;height:450px;top:-10%;left:-10%}.orb-2{background:radial-gradient(circle,#a855f7 0%,#a855f700 70%);width:500px;height:500px;bottom:-15%;right:-5%}.orb-3{background:radial-gradient(circle,#3b82f6 0%,#3b82f600 70%);width:350px;height:350px;top:40%;left:35%}.app-header{text-align:center;margin-bottom:2.5rem}.logo-wrapper{justify-content:center;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.logo-icon{font-size:2.2rem;animation:4s ease-in-out infinite float}.gradient-text{background:linear-gradient(135deg,#a855f7 0%,#6366f1 50%,#3b82f6 100%);-webkit-text-fill-color:transparent;letter-spacing:-1.5px;-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:700}.subtitle{color:#94a3b8;max-width:600px;margin:0 auto;font-size:1.1rem;font-weight:300}.main-content{flex-grow:1;grid-template-columns:1.2fr .8fr;align-items:start;gap:2rem;width:100%;max-width:1200px;margin:0 auto;display:grid}@media (width<=900px){.main-content{grid-template-columns:1fr}}.glass-card{-webkit-backdrop-filter:blur(20px);background:#161c2d73;border:1px solid #ffffff14;border-radius:20px;padding:2.5rem;transition:transform .3s,border-color .3s,box-shadow .3s;box-shadow:0 20px 40px -15px #00000080}.glass-card:hover{border-color:#ffffff1f;box-shadow:0 25px 45px -12px #0009}.glass-card h2{color:#f8fafc;border-left:4px solid #6366f1;margin-bottom:1.5rem;padding-left:.75rem;font-size:1.6rem;font-weight:600}.upload-form{flex-direction:column;gap:1.5rem;display:flex}.drag-area{text-align:center;cursor:pointer;background:#0f172a4d;border:2px dashed #ffffff26;border-radius:16px;padding:3rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.drag-area.active{background:#a855f714;border-color:#a855f7;transform:scale(1.02)}.drag-area.has-file{background:#6366f10a;border-color:#6366f1}.hidden-input{display:none}.drag-label{cursor:pointer;flex-direction:column;align-items:center;gap:1rem;width:100%;display:flex}.upload-icon-circle{background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:2.2rem;transition:transform .3s,background .3s;display:flex}.drag-area:hover .upload-icon-circle{background:#ffffff1a;transform:translateY(-5px)}.drag-area.has-file .upload-icon-circle{background:#6366f126}.upload-instructions{flex-direction:column;gap:.25rem;display:flex}.primary-instruction{color:#f1f5f9;font-size:1.1rem;font-weight:500}.secondary-instruction{color:#64748b;font-size:.9rem}.file-details{flex-direction:column;gap:.25rem;display:flex}.file-name{color:#3b82f6;word-break:break-all;font-size:1.1rem;font-weight:500}.file-size{color:#64748b;font-size:.85rem}.btn-clear{color:#94a3b8;cursor:pointer;background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;transition:background .2s,color .2s;display:flex;position:absolute;top:12px;right:12px}.btn-clear:hover{color:#ef4444;background:#ef444433}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;padding:.85rem 1.75rem;font-size:1rem;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#a855f7 0%,#6366f1 100%);box-shadow:0 10px 20px -5px #a855f766}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 15px 25px -5px #a855f780}.btn-primary:active{transform:translateY(0)}.btn-download{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);margin-top:1rem;text-decoration:none;box-shadow:0 10px 20px -5px #10b98166}.btn-download:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 15px 25px -5px #10b98180}.status-container{border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:1.5rem;animation:.3s slideIn;display:flex}.status-msg{color:#f1f5f9;text-align:center;font-weight:500}.loading-spinner{border:4px solid #6366f126;border-top-color:#6366f1;border-radius:50%;width:45px;height:45px;animation:1s linear infinite spin}.progress-bar-container{background:#ffffff0d;border-radius:10px;width:100%;height:6px;margin-top:.5rem;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#a855f7,#6366f1);border-radius:10px;width:75%;height:100%;animation:2.5s ease-in-out infinite progressPulse}.status-container.success{background:#10b98114;border:1px solid #10b98140}.status-container.success .status-icon{color:#34d399;background:#10b98126;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex}.file-saved-info{color:#94a3b8;font-size:.9rem}.output-name{color:#3b82f6;word-break:break-all;background:#0003;border:1px solid #ffffff0d;border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.status-container.error{background:#ef444414;border:1px solid #ef444440}.status-container.error .status-icon{color:#f87171;background:#ef444426;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex}.error-details{color:#f87171;text-align:center;font-size:.9rem}.section-description{color:#94a3b8;margin-bottom:1.5rem;font-size:.95rem;font-weight:300;line-height:1.45}.translation-playground{background:#0f172a40;border:1px solid #ffffff0a;border-radius:14px;flex-direction:column;gap:1.25rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.input-group{flex-direction:column;gap:.5rem;display:flex}.input-group label,.result-group label{text-transform:uppercase;letter-spacing:1px;color:#64748b;font-size:.85rem;font-weight:600}.input-group input{color:#f8fafc;background:#0003;border:1px solid #ffffff14;border-radius:8px;outline:none;padding:.75rem 1rem;font-size:1.1rem;font-weight:500;transition:border-color .2s,box-shadow .2s}.input-group input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.result-group{flex-direction:column;gap:.5rem;display:flex}.translation-preview{text-align:center;background:#00000059;border:1px solid #ffffff08;border-radius:8px;justify-content:center;align-items:center;min-height:80px;padding:1rem;display:flex}.translating-indicator{color:#a855f7;font-size:.95rem;animation:1.5s infinite pulse}.translation-text{color:#f1f5f9;font-size:1.05rem;line-height:1.4}.words-result{color:#a855f7;font-weight:600}.original-number{color:#64748b}.placeholder-text{color:#475569;font-size:.95rem;font-style:italic}.explanation-box{border-top:1px solid #ffffff0f;padding-top:1.25rem}.explanation-box h3{color:#f1f5f9;margin-bottom:.5rem;font-size:1rem;font-weight:500}.explanation-box p{color:#64748b;font-size:.85rem;font-weight:300;line-height:1.45}footer.app-footer{text-align:center;border-top:1px solid #ffffff0d;margin-top:2rem;padding-top:2rem}footer.app-footer p{color:#475569;font-size:.85rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes progressPulse{0%{width:10%;transform:translate(0%)}50%{width:60%;transform:translate(30%)}to{width:10%;transform:translate(90%)}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
