@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary: #6366f1;--primary-hover: #4f46e5;--bg: #f8fafc;--card-bg: #ffffff;--text: #0f172a;--text-light: #64748b;--border: #e2e8f0;--accent: #10b981;--sidebar-width: 280px;--radius: 12px;--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:2rem}header{margin-bottom:2.5rem;text-align:center}h1{font-size:2.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.subtitle{color:var(--text-light);font-size:1.1rem}.card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;gap:.5rem}label{font-size:.875rem;font-weight:600;color:var(--text)}input[type=text],input[type=date],input[type=number]{padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border);font-size:1rem;font-family:inherit;transition:all .2s;outline:none}input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:3rem;text-align:center;transition:all .2s;cursor:pointer;background:#fdfdfd}.upload-area:hover,.upload-area.dragging{border-color:var(--primary);background:#6366f10d}.upload-area .icon{margin-bottom:1rem;color:var(--primary)}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background:var(--text-light);cursor:not-allowed;transform:none}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.tab{padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;color:var(--text-light);transition:all .2s}.tab:hover{color:var(--text);background:var(--bg)}.tab.active{color:var(--primary);background:#6366f11a}.table-container{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}th{background:#f8fafc;padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-light);border-bottom:1px solid var(--border)}td{padding:.75rem 1rem;border-bottom:1px solid var(--border);color:var(--text)}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc}.loader{border:4px solid #f3f3f3;border-top:4px solid var(--primary);border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-right:.5rem}.file-list{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:#f1f5f9;border-radius:6px;font-size:.875rem}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--bg);transform:translateY(-1px)}.actions{display:flex;justify-content:flex-end;margin-top:1rem;gap:1rem}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.ok{background:#dcfce7;color:#166534}.status-badge.error{background:#fee2e2;color:#991b1b;animation:pulse 2s infinite}.status-badge.checking{background:#f1f5f9;color:#475569}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
