@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0e1a;--bg-secondary:#0f1629;--bg-card:#141c2e;--bg-card-hover:#1a2438;--bg-input:#0d1220;--border:#1e2d4a;--border-active:#3b82f6;--accent-blue:#3b82f6;--accent-blue-light:#60a5fa;--accent-indigo:#6366f1;--accent-purple:#8b5cf6;--accent-teal:#14b8a6;--accent-amber:#f59e0b;--accent-rose:#f43f5e;--accent-green:#22c55e;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--shadow-glow:0 0 30px #3b82f626;--shadow-card:0 4px 24px #0006;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .25s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,sans-serif;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #3b82f633}50%{box-shadow:0 0 40px #3b82f666}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:.4s forwards fadeIn}.animate-slide-in{animation:.35s forwards slideIn}.app-wrapper{background:var(--bg-primary);background-image:radial-gradient(80% 50% at 50% -10%,#3b82f61f 0%,#0000 70%),radial-gradient(40% 30% at 80% 80%,#6366f114 0%,#0000 60%);flex-direction:column;min-height:100vh;display:flex}.navbar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:100;background:#0f1629d9;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.navbar-brand{color:var(--text-primary);align-items:center;gap:10px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.1rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--accent-blue), var(--accent-indigo));justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.navbar-badge{color:var(--accent-blue-light);background:#3b82f61a;border:1px solid #3b82f640;border-radius:99px;padding:2px 8px;font-size:.65rem;font-weight:600}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:32px;animation:.4s fadeIn}.page-header{margin-bottom:28px}.page-title{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:6px;font-family:Plus Jakarta Sans,sans-serif;font-size:1.65rem;font-weight:800;display:flex}.page-title-icon{font-size:1.4rem}.page-subtitle{color:var(--text-secondary);font-size:.9rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);padding:24px}.card:hover{border-color:#3b82f64d}.card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700;display:flex}.card-icon{border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;display:flex}.icon-blue{color:var(--accent-blue-light);background:#3b82f626}.icon-purple{color:var(--accent-purple);background:#8b5cf626}.icon-teal{color:var(--accent-teal);background:#14b8a626}.icon-amber{color:var(--accent-amber);background:#f59e0b26}.icon-green{color:var(--accent-green);background:#22c55e26}.icon-rose{color:var(--accent-rose);background:#f43f5e26}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-2>div{min-width:0}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.grid-3>div{min-width:0}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg-input);padding:36px 24px;position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-blue);background:#3b82f60d}.upload-zone input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-icon{border-radius:var(--radius-md);width:52px;height:52px;transition:var(--transition);background:#3b82f61a;border:1px solid #3b82f633;justify-content:center;align-items:center;margin:0 auto 12px;font-size:22px;display:flex}.upload-zone:hover .upload-icon,.upload-zone.drag-over .upload-icon{background:#3b82f633;transform:scale(1.05)}.upload-title{color:var(--text-primary);margin-bottom:4px;font-size:.95rem;font-weight:600}.upload-subtitle{color:var(--text-muted);font-size:.8rem}.upload-formats{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:10px;display:flex}.format-badge{text-transform:uppercase;letter-spacing:.05em;border:1px solid;border-radius:99px;padding:3px 9px;font-size:.7rem;font-weight:600}.format-badge.csv{color:var(--accent-teal);background:#14b8a614;border-color:#14b8a64d}.format-badge.xlsx{color:var(--accent-green);background:#22c55e14;border-color:#22c55e4d}.format-badge.xls{color:var(--accent-amber);background:#f59e0b14;border-color:#f59e0b4d}.file-preview{border-radius:var(--radius-sm);background:#22c55e0f;border:1px solid #22c55e33;justify-content:space-between;align-items:center;margin-top:10px;padding:10px 14px;display:flex}.file-preview-info{align-items:center;gap:10px;display:flex}.file-preview-icon{font-size:20px}.file-preview-name{color:var(--accent-green);font-size:.85rem;font-weight:500}.file-preview-size{color:var(--text-muted);font-size:.75rem}.file-remove-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:4px;padding:2px;font-size:16px;line-height:1}.file-remove-btn:hover{color:var(--accent-rose)}.table-container{border-radius:var(--radius-sm);border:1px solid var(--border);max-height:300px;overflow:auto}.data-table{border-collapse:collapse;width:100%;font-size:.82rem}.data-table th{color:var(--accent-blue-light);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);background:#3b82f61a;padding:10px 14px;font-weight:600;position:sticky;top:0}.data-table td{color:var(--text-secondary);white-space:nowrap;border-bottom:1px solid #1e2d4a80;padding:8px 14px}.data-table tbody tr:hover{background:#3b82f60a}.data-table tbody tr:last-child td{border-bottom:none}.data-table .col-name{color:var(--text-primary);font-weight:500}.data-table .row-number{color:var(--text-muted);width:40px;font-size:.75rem}.table-empty{text-align:center;color:var(--text-muted);padding:32px 20px;font-size:.875rem}.table-empty-icon{margin-bottom:8px;font-size:32px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:7px;padding:10px 20px;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;line-height:1.3;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg, var(--accent-blue), var(--accent-indigo));color:#fff;box-shadow:0 2px 12px #3b82f659}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #3b82f680}.btn-purple{background:linear-gradient(135deg, var(--accent-purple), var(--accent-indigo));color:#fff;box-shadow:0 2px 12px #8b5cf659}.btn-purple:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #8b5cf680}.btn-teal{background:linear-gradient(135deg, var(--accent-teal), #0891b2);color:#fff;box-shadow:0 2px 12px #14b8a659}.btn-teal:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #14b8a680}.btn-green{background:linear-gradient(135deg, var(--accent-green), #16a34a);color:#fff;box-shadow:0 2px 12px #22c55e59}.btn-green:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #22c55e80}.btn-outline{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-outline:hover:not(:disabled){color:var(--text-primary);background:#ffffff0a;border-color:#94a3b866}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:6px 12px}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:13px 28px;font-size:.95rem}.btn-icon{font-size:15px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase;font-size:.82rem;font-weight:600}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);transition:var(--transition);outline:none;width:100%;padding:10px 14px;font-family:Inter,sans-serif;font-size:.88rem}.form-input:focus,.form-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.form-select option{background:var(--bg-card)}.output-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.output-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-sm);min-width:260px;max-width:380px;box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);align-items:center;gap:10px;padding:12px 18px;font-size:.87rem;font-weight:500;animation:.3s slideIn;display:flex}.toast-success{color:#86efac;background:#22c55e26;border:1px solid #22c55e4d}.toast-error{color:#fda4af;background:#f43f5e26;border:1px solid #f43f5e4d}.toast-info{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f64d}.stats-row{flex-wrap:wrap;gap:12px;display:flex}.stat-chip{border:1px solid;border-radius:99px;align-items:center;gap:6px;padding:5px 12px;font-size:.78rem;font-weight:600;display:flex}.stat-chip.blue{color:var(--accent-blue-light);background:#3b82f614;border-color:#3b82f64d}.stat-chip.purple{color:var(--accent-purple);background:#8b5cf614;border-color:#8b5cf64d}.stat-chip.teal{color:var(--accent-teal);background:#14b8a614;border-color:#14b8a64d}.steps{align-items:center;gap:0;margin-bottom:28px;padding-bottom:4px;display:flex;overflow-x:auto}.step{flex-shrink:0;align-items:center;gap:8px;display:flex}.step-num{border:2px solid var(--border);width:28px;height:28px;color:var(--text-muted);background:var(--bg-card);transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.step.done .step-num{border-color:var(--accent-green);color:var(--accent-green);background:#22c55e1f}.step.active .step-num{border-color:var(--accent-blue);color:var(--accent-blue-light);background:#3b82f626;box-shadow:0 0 12px #3b82f64d}.step-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.step.active .step-label{color:var(--text-primary)}.step.done .step-label{color:var(--accent-green)}.step-connector{background:var(--border);flex:0 0 32px;height:1px;margin:0 4px}.step-connector.done{background:#22c55e66}.divider{background:var(--border);height:1px;margin:20px 0}.helper-text{color:var(--text-muted);margin-top:4px;font-size:.78rem;line-height:1.5}.helper-text strong{color:var(--text-secondary)}.footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);padding:18px 32px;font-size:.78rem}.footer span{color:var(--accent-green);font-weight:500}@media (width<=768px){.navbar{padding:0 16px}.main-content{padding:16px}.grid-2,.grid-3{grid-template-columns:1fr}}.animate-spin{animation:1s linear infinite spin}
