*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0f;--surface:#13131a;--surface2:#1c1c27;--border:#2a2a3d;--accent:#7c3aed;--accent-light:#a855f7;--accent-glow:#7c3aed4d;--text:#f0f0ff;--text-muted:#88a;--success:#22c55e;--error:#ef4444}body{background:var(--bg);color:var(--text);flex-direction:column;align-items:center;min-height:100vh;padding:2rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.container{width:100%;max-width:760px}.header{text-align:center;margin-bottom:2.5rem}.logo{background:linear-gradient(135deg,#a855f7,#7c3aed);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:800}.tagline{color:var(--text-muted);margin-top:.4rem;font-size:.95rem}.input-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.input-row{gap:.75rem;display:flex}.url-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:10px;outline:none;flex:1;padding:.75rem 1rem;font-size:.95rem;transition:border-color .2s}.url-input::placeholder{color:var(--text-muted)}.url-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.analyze-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;border-radius:10px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:opacity .2s,transform .1s}.analyze-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.analyze-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.spinner{border:2px solid var(--border);border-top-color:var(--accent-light);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:.85rem;margin-bottom:1.5rem;padding:1.25rem;display:flex}.progress-header{justify-content:space-between;align-items:center;display:flex}.progress-title{color:var(--accent-light);align-items:center;gap:.6rem;font-size:.95rem;font-weight:600;display:flex}.progress-time{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.82rem}.progress-track{background:var(--surface2);border-radius:99px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#7c3aed,#a855f7);border-radius:99px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-percent{color:var(--text-muted);text-align:right;margin-top:-.4rem;font-size:.78rem}.step-list{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding-top:.85rem;display:flex}.step-item{align-items:flex-start;gap:.7rem;font-size:.88rem;transition:opacity .3s;display:flex}.step-item.step-pending{opacity:.35}.step-icon-wrap{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;display:flex}.step-item.step-done .step-icon-wrap{color:var(--success);background:#22c55e26}.step-dot-active{background:var(--accent-light);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite pulse}.step-dot-pending{background:var(--border);border-radius:50%;width:8px;height:8px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}.step-text{flex-direction:column;gap:.15rem;display:flex}.step-label{color:var(--text);font-weight:500}.step-item.step-done .step-label{color:var(--text-muted)}.step-sublabel{color:var(--text-muted);font-size:.78rem}.result-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden}.result-header{background:var(--surface2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex}.tabs{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:2px;padding:3px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.35rem .9rem;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.tab-btn:hover:not(.tab-active){color:var(--text)}.tab-btn.tab-active{background:var(--accent);color:#fff}.copy-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.85rem;font-weight:600;transition:background .2s}.copy-btn:hover{background:var(--accent-light)}.copy-btn.copied{background:var(--success)}.result-body{white-space:pre-wrap;color:var(--text);padding:1.25rem;font-family:inherit;font-size:.92rem;line-height:1.7}.error-card{color:#fca5a5;background:#ef444414;border:1px solid #ef44444d;border-radius:12px;padding:1rem 1.25rem;font-size:.9rem}
