*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0b0f;--bg2: #10121a;--bg3: #161926;--border: rgba(255, 255, 255, .07);--border2: rgba(255, 255, 255, .12);--accent: #e8c547;--accent2: #f5d76a;--accent-dim: rgba(232, 197, 71, .12);--accent-glow: rgba(232, 197, 71, .25);--text: #f0f0f0;--text2: #8b8fa8;--text3: #5a5e72;--danger: #ff4d4d;--success: #3ecf8e;--warning: #ffa94d;--info: #5c7cfa;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--shadow-accent: 0 0 30px rgba(232, 197, 71, .15)}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.layout{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.main-content{flex:1;min-width:0;padding:32px;overflow-x:hidden}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--border)}.sidebar-logo .logo-text{font-family:var(--font-display);font-size:1.1rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}.sidebar-logo .logo-sub{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}.sidebar-nav{padding:12px 10px;flex:1}.nav-section-label{font-size:.65rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;padding:12px 10px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text2);text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s;margin-bottom:2px;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:#ffffff0d;color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item.active svg{opacity:1}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg3)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--accent);font-family:var(--font-display);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:var(--text3);text-transform:capitalize}.logout-btn{background:none;border:none;cursor:pointer;color:var(--text3);padding:4px;border-radius:4px;transition:color .15s;display:flex}.logout-btn:hover{color:var(--danger)}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.card-sm{padding:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s}.stat-card:hover{border-color:var(--border2);transform:translateY(-2px)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.stat-card.yellow:before{background:var(--accent)}.stat-card.green:before{background:var(--success)}.stat-card.red:before{background:var(--danger)}.stat-card.blue:before{background:var(--info)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-value{font-family:var(--font-display);font-size:2rem;font-weight:800;line-height:1;margin-bottom:4px}.stat-label{font-size:.8rem;color:var(--text2);font-weight:500}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-title{font-family:var(--font-display);font-size:1.6rem;font-weight:800;letter-spacing:-.02em}.page-subtitle{font-size:.875rem;color:var(--text2);margin-top:4px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:var(--font-body);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover:not(:disabled){background:var(--accent2);box-shadow:var(--shadow-accent)}.btn-ghost{background:var(--bg3);color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover:not(:disabled){background:#ffffff14;color:var(--text)}.btn-danger{background:#ff4d4d26;color:var(--danger);border:1px solid rgba(255,77,77,.2)}.btn-danger:hover:not(:disabled){background:#ff4d4d40}.btn-success{background:#3ecf8e26;color:var(--success);border:1px solid rgba(62,207,142,.2)}.btn-sm{padding:7px 12px;font-size:.8rem}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.input-group{margin-bottom:16px}.input-label{display:block;font-size:.8rem;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.input{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;font-size:.9rem;font-family:var(--font-body);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input::placeholder{color:var(--text3)}select.input{cursor:pointer}.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead th{text-align:left;padding:12px 16px;background:var(--bg3);color:var(--text2);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);white-space:nowrap}tbody td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#ffffff05}tbody td.highlight{color:var(--text);font-weight:500}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-yellow{background:#e8c54726;color:var(--accent)}.badge-green{background:#3ecf8e26;color:var(--success)}.badge-red{background:#ff4d4d26;color:var(--danger)}.badge-blue{background:#5c7cfa26;color:var(--info)}.badge-gray{background:#ffffff12;color:var(--text2)}.badge-orange{background:#ffa94d26;color:var(--warning)}.dropzone{border:2px dashed var(--border2);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg3)}.dropzone:hover,.dropzone.active{border-color:var(--accent);background:var(--accent-dim)}.dropzone-icon{font-size:3rem;margin-bottom:12px}.dropzone-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:6px}.dropzone-sub{font-size:.875rem;color:var(--text2)}.mapping-row{display:grid;grid-template-columns:1fr 60px 1fr;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.mapping-arrow{color:var(--accent);font-size:1.2rem;text-align:center}.search-bar{position:relative;flex:1;min-width:200px;max-width:400px}.search-bar .input{padding-left:40px}.search-bar svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.empty-state{text-align:center;padding:64px 32px;color:var(--text2)}.empty-state svg{color:var(--text3);margin-bottom:12px}.empty-state h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:6px;color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:520px;max-height:80vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700}.progress-bar{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.steps{display:flex;gap:8px;align-items:center;margin-bottom:28px}.step{display:flex;align-items:center;gap:8px}.step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;background:var(--bg3);border:1px solid var(--border2);color:var(--text2)}.step.active .step-num{background:var(--accent);color:#000;border-color:var(--accent)}.step.done .step-num{background:var(--success);color:#000;border-color:var(--success)}.step-label{font-size:.8rem;color:var(--text2);font-weight:500}.step.active .step-label{color:var(--text)}.step-connector{flex:1;height:1px;background:var(--border2);min-width:20px}.pagination{display:flex;gap:4px;align-items:center}.page-btn{padding:6px 12px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:.8rem;cursor:pointer;transition:all .15s}.page-btn:hover{border-color:var(--border2);color:var(--text)}.page-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-200px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(232,197,71,.06) 0%,transparent 70%);pointer-events:none}.login-card{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow)}.login-logo{text-align:center;margin-bottom:32px}.login-logo .brand{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--accent);letter-spacing:-.03em}.login-logo .sub{font-size:.8rem;color:var(--text3);margin-top:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.fade-in{animation:fadeIn .3s ease}.pulse{animation:pulse 1.5s ease infinite}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text2)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg2);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 16px;z-index:200}.mobile-menu-btn{background:none;border:none;color:var(--text2);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background .15s}.mobile-menu-btn:hover{background:#ffffff12;color:var(--text)}.mobile-drawer{display:none;position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--bg2);border-right:1px solid var(--border);z-index:300;flex-direction:column;transform:translate(-100%);transition:transform .25s ease;overflow-y:auto}.mobile-drawer.open{transform:translate(0)}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:250;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.mobile-topbar,.mobile-drawer{display:flex}.mobile-overlay{display:block}.sidebar{display:none!important}.main-content{padding:72px 14px 24px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.stat-card{padding:14px}.stat-value{font-size:1.5rem}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.page-title{font-size:1.3rem}.card{padding:16px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:500px}thead th,tbody td{padding:10px 12px;font-size:.8rem}.mapping-row{grid-template-columns:1fr;gap:6px;padding:12px 0}.mapping-arrow{display:none}.steps{gap:4px;overflow-x:auto;padding-bottom:4px}.step-label{display:none}.step-connector{min-width:12px}.dropzone{padding:32px 16px}.dropzone-title{font-size:.95rem}.modal{max-width:100%;border-radius:var(--radius);padding:20px;max-height:90vh}.modal-overlay{padding:12px;align-items:flex-end}.grid-2,.grid-3{grid-template-columns:1fr}.login-card{padding:24px 18px}.search-bar{max-width:100%}.btn{padding:9px 14px;font-size:.82rem}.btn-sm{padding:6px 10px;font-size:.75rem}.empty-state{padding:40px 16px}.page-subtitle{font-size:.8rem}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-value{font-size:1.3rem}.main-content{padding:64px 12px 20px}}
