*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#111;--surface2:#181818;--border:#252525;--accent:#e8ff47;--accent-dim:#b8cc1a;--text:#f0f0f0;--muted:#666;--danger:#ff4f4f;--success:#47ffb0;--font-display:"Bebas Neue", sans-serif;--font-body:"DM Sans", sans-serif;--font-mono:"DM Mono", monospace}body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;font-weight:300;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}.app{flex-direction:column;min-height:100vh;display:flex;position:relative}.noise{pointer-events:none;opacity:.03;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px 128px;position:fixed;inset:0}.header{z-index:1;padding:3rem 2rem 0;position:relative}.header-inner{flex-wrap:wrap;align-items:baseline;gap:2rem;max-width:860px;margin:0 auto;display:flex}.logo{font-family:var(--font-display);letter-spacing:.04em;color:var(--accent);font-size:clamp(3.5rem,8vw,6rem);line-height:1}.tagline{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:.85rem;font-weight:400}.header-rule{background:var(--border);max-width:860px;height:1px;margin:1.5rem auto 0}.main{z-index:1;flex-direction:column;flex:1;gap:1.5rem;width:100%;max-width:860px;margin:0 auto;padding:2.5rem 2rem 4rem;display:flex;position:relative}.upload-row{grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;display:grid}.swap-arrow{font-family:var(--font-display);color:var(--muted);text-align:center;-webkit-user-select:none;user-select:none;padding:0 .5rem;font-size:2.5rem}.dropzone{border:1px solid var(--border);cursor:pointer;background:var(--surface);text-align:center;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;min-height:180px;padding:2rem 1.5rem;transition:border-color .15s,background .15s;display:flex;position:relative;overflow:hidden}.dropzone:before{content:"";background:var(--zone-color);opacity:0;transition:opacity .15s;position:absolute;inset:0}.dropzone:hover:before,.dropzone.dragging:before{opacity:.04}.dropzone.dragging,.dropzone.has-file{border-color:var(--zone-color)}.zone-icon{color:var(--zone-color);font-size:1.8rem;line-height:1;position:relative}.zone-label{font-family:var(--font-display);letter-spacing:.1em;color:var(--zone-color);font-size:1.4rem;position:relative}.zone-hint{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:.75rem;position:relative}.zone-file{flex-direction:column;gap:3px;display:flex;position:relative}.zone-filename{font-family:var(--font-mono);color:var(--text);word-break:break-all;max-width:220px;font-size:.78rem}.zone-size{color:var(--muted);font-size:.72rem;font-family:var(--font-mono)}.zone-check{color:var(--success);font-size:.85rem;font-weight:500;position:absolute;top:12px;right:14px}.progress-wrap{align-items:center;gap:1rem;display:flex}.progress-bar{background:var(--border);border-radius:2px;flex:1;height:3px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.progress-label{font-family:var(--font-mono);color:var(--muted);text-align:right;min-width:36px;font-size:.78rem}.actions{flex-direction:column;gap:1rem;display:flex}.btn-primary{background:var(--accent);color:#0a0a0a;font-family:var(--font-display);letter-spacing:.08em;cursor:pointer;border:none;border-radius:3px;align-self:flex-start;align-items:center;gap:.75rem;padding:.9rem 2.5rem;font-size:1.3rem;transition:opacity .15s,transform .1s;display:inline-flex}.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.3;cursor:not-allowed}.btn-primary.processing{opacity:.7;cursor:default}.spinner{border:2px solid #0000004d;border-top-color:#000;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.result-row{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.btn-download{background:var(--success);color:#0a0a0a;font-family:var(--font-display);letter-spacing:.06em;cursor:pointer;border:none;border-radius:3px;padding:.9rem 2rem;font-size:1.3rem;text-decoration:none;transition:opacity .15s;display:inline-block}.btn-download:hover{opacity:.85}.btn-reset{color:var(--muted);border:1px solid var(--border);font-family:var(--font-body);letter-spacing:.04em;cursor:pointer;background:0 0;border-radius:3px;padding:.9rem 1.5rem;font-size:.85rem;transition:color .15s,border-color .15s}.btn-reset:hover{color:var(--text);border-color:var(--muted)}.btn-reset.small{padding:.4rem .8rem;font-size:.78rem}.error-banner{color:#ff9090;background:#ff4f4f14;border:1px solid #ff4f4f40;border-radius:3px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;font-size:.85rem;display:flex}.log-wrap{border:1px solid var(--border);background:var(--surface);border-radius:3px;overflow:hidden}.log-header{background:var(--surface2);border-bottom:1px solid var(--border);font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.72rem;display:flex}.log-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.log-body{flex-direction:column;gap:2px;max-height:200px;padding:.75rem 1rem;display:flex;overflow-y:auto}.log-line{font-family:var(--font-mono);color:var(--muted);white-space:pre-wrap;word-break:break-all;font-size:.72rem;line-height:1.5}.footer{text-align:center;z-index:1;border-top:1px solid var(--border);padding:1.5rem 2rem;position:relative}.footer p{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem}@media (width<=560px){.upload-row{grid-template-columns:1fr}.swap-arrow{display:none}.header-inner{flex-direction:column;gap:.5rem}}
